mirror of
https://github.com/curl/curl.git
synced 2026-04-11 12:01:42 +08:00
It's mostly a filler word. I've read through each use of it in the code base and did minor rephrasings when "simply" carried some meaning. The overwhelming majority of cases, removing it improved the text significantly. Inspired by #20793. Closes #20822
101 lines
3.4 KiB
Markdown
101 lines
3.4 KiB
Markdown
<!--
|
|
Copyright (C) Daniel Stenberg, <daniel@haxx.se>, et al.
|
|
|
|
SPDX-License-Identifier: curl
|
|
-->
|
|
|
|
# HTTPS RR
|
|
|
|
[RFC 9460](https://datatracker.ietf.org/doc/html/rfc9460) documents the HTTPS
|
|
DNS Resource Record.
|
|
|
|
curl features **experimental** support for HTTPS RR.
|
|
|
|
- The ALPN list from the record is parsed and used
|
|
- The ECH field is stored - and used if ECH is enabled in the build
|
|
- The port number is not used (Firefox supports it, Chrome does not)
|
|
- The target name is not used
|
|
- The IP addresses (`Ipv6hints`, `Ipv4hints`) from the HTTPS RR are not used
|
|
- It only supports a single HTTPS RR per hostname
|
|
- Hostnames without A/AAAA records but *with* HTTPS RR fails
|
|
- consider service profiles where the RR provides different addresses for TCP
|
|
vs QUIC etc
|
|
|
|
`HTTPSRR` is listed as a feature in the `curl -V` output if curl contains
|
|
HTTPS RR support. If c-ares is not included in the build, the HTTPS RR support
|
|
is limited to DoH.
|
|
|
|
`asyn-rr` is listed as a feature in the `curl -V` output if c-ares is used for
|
|
additional resolves in addition to a "normal" resolve done with the threaded
|
|
resolver.
|
|
|
|
The data extracted from the HTTPS RR is stored in the in-memory DNS cache to
|
|
be reused on subsequent uses of the same hostnames.
|
|
|
|
## limitations
|
|
|
|
We have decided to work on the HTTPS RR support by following what seems to be
|
|
(widely) used, and wait with implementing the details of the record
|
|
that do not seem to be deployed. HTTPS RR is a DNS field with many odd corners
|
|
and complexities and we might as well avoid them if no one seems to want them.
|
|
|
|
## build
|
|
|
|
./configure --enable-httpsrr
|
|
|
|
or
|
|
|
|
cmake -DUSE_HTTPSRR=ON
|
|
|
|
## ALPN
|
|
|
|
The list of ALPN IDs is parsed but may not be completely respected because of
|
|
what the HTTP version preference is set to, which is a problem we are working
|
|
on. Also, getting an `HTTP/1.1` ALPN in the HTTPS RR field for an HTTP://
|
|
transfer should imply switching to HTTPS, HSTS style. Which curl currently
|
|
does not.
|
|
|
|
## DoH
|
|
|
|
When HTTPS RR is enabled in the curl build, The DoH code asks for an HTTPS
|
|
record in addition to the A and AAAA records, and if an HTTPS RR answer is
|
|
returned, curl parses it and stores the retrieved information.
|
|
|
|
## Non-DoH
|
|
|
|
If DoH is not used for name resolving in an HTTPS RR enabled build, we must
|
|
provide the ability using the regular resolver backends. We use the c-ares DNS
|
|
library for the HTTPS RR lookup. Version 1.28.0 or later.
|
|
|
|
### c-ares
|
|
|
|
If curl is built to use the c-ares library for name resolves, an HTTPS RR
|
|
enabled build makes a request for the HTTPS RR in addition to the regular
|
|
lookup.
|
|
|
|
### Threaded resolver
|
|
|
|
When built to use the threaded resolver, which is the default, an HTTPS RR
|
|
build still needs a c-ares installation provided so that a separate request
|
|
for the HTTPS record can be done in parallel to the regular getaddrinfo()
|
|
call.
|
|
|
|
This is done by specifying both c-ares and threaded resolver to configure:
|
|
|
|
./configure --enable-ares=... --enable-threaded-resolver
|
|
|
|
or to cmake:
|
|
|
|
cmake -DENABLE_ARES=ON -DENABLE_THREADED_RESOLVER=ON
|
|
|
|
Because the HTTPS record is handled separately from the A/AAAA record
|
|
retrieval, by a separate library, there is a small risk for discrepancies.
|
|
|
|
When building curl using the threaded resolver with HTTPS RR support (using
|
|
c-ares), the `curl -V` output looks exactly like a c-ares resolver build.
|
|
|
|
## HTTPS RR Options
|
|
|
|
Because curl is a low level transfer tool for which users sometimes want
|
|
detailed control, we need to offer options to control HTTPS RR use.
|