<?xml version='1.0' encoding='utf-8'?>
<!DOCTYPE rfc [
  <!ENTITY nbsp    "&#160;">
  <!ENTITY zwsp   "&#8203;">
  <!ENTITY nbhy   "&#8209;">
  <!ENTITY wj     "&#8288;">
]>
<?xml-stylesheet type="text/xsl" href="rfc2629.xslt" ?>
<!-- generated by https://github.com/cabo/kramdown-rfc version 1.6.34 (Ruby 3.2.2) -->
<?rfc strict="yes"?>
<?rfc comments="yes"?>
<?rfc docmapping="yes"?>
<rfc xmlns:xi="http://www.w3.org/2001/XInclude" ipr="trust200902" docName="draft-ietf-dnsop-structured-dns-error-03" category="std" consensus="true" submissionType="IETF" updates="8914" tocInclude="true" sortRefs="true" symRefs="true" version="3">
  <!-- xml2rfc v2v3 conversion 3.17.1 -->
  <front>
    <title abbrev="Structured DNS Error">Structured Error Data for Filtered DNS</title>
    <seriesInfo name="Internet-Draft" value="draft-ietf-dnsop-structured-dns-error-03"/>
    <author fullname="Dan Wing">
      <organization abbrev="Citrix">Citrix Systems, Inc.</organization>
      <address>
        <postal>
          <country>United States of America</country>
        </postal>
        <email>danwing@gmail.com</email>
      </address>
    </author>
    <author fullname="Tirumaleswar Reddy">
      <organization>Nokia</organization>
      <address>
        <postal>
          <city>Bangalore</city>
          <region>Karnataka</region>
          <country>India</country>
        </postal>
        <email>kondtir@gmail.com</email>
      </address>
    </author>
    <author fullname="Neil Cook">
      <organization>Open-Xchange</organization>
      <address>
        <postal>
          <country>United Kingdom</country>
        </postal>
        <email>neil.cook@noware.co.uk</email>
      </address>
    </author>
    <author fullname="Mohamed Boucadair">
      <organization>Orange</organization>
      <address>
        <postal>
          <street>Rennes</street>
          <code>35000</code>
          <country>France</country>
        </postal>
        <email>mohamed.boucadair@orange.com</email>
      </address>
    </author>
    <date year="2023" month="May" day="27"/>
    <area>Internet</area>
    <workgroup>DNS Operations Working Group</workgroup>
    <keyword>Customer experience</keyword>
    <keyword>Informed decision</keyword>
    <keyword>transparency</keyword>
    <keyword>enriched feedback</keyword>
    <abstract>
      <?line 84?>

<t>DNS filtering is widely deployed for various reasons, including
network security. However, filtered DNS responses lack information
for end users to understand the reason for the filtering.
Existing mechanisms to provide explanatory details to end users cause harm
especially if the blocked DNS response is to an HTTPS server.</t>
      <t>This document updates RFC 8914 by signaling client support for structuring the EXTRA-TEXT field of
the Extended DNS Error to provide details on the DNS filtering. Such
details can be parsed by the client and displayed, logged, or used for
other purposes.</t>
    </abstract>
    <note removeInRFC="true">
      <name>About This Document</name>
      <t>
        The latest revision of this draft can be found at <eref target="https://ietf-wg-dnsop.github.io/draft-ietf-dnsop-structured-dns-error/draft-ietf-dnsop-structured-dns-error.html"/>.
        Status information for this document may be found at <eref target="https://datatracker.ietf.org/doc/draft-ietf-dnsop-structured-dns-error/"/>.
      </t>
      <t>
        Discussion of this document takes place on the
        dnsop Working Group mailing list (<eref target="mailto:dnsop@ietf.org"/>),
        which is archived at <eref target="https://mailarchive.ietf.org/arch/browse/dnsop/"/>.
        Subscribe at <eref target="https://www.ietf.org/mailman/listinfo/dnsop/"/>.
      </t>
      <t>Source for this draft and an issue tracker can be found at
        <eref target="https://github.com/ietf-wg-dnsop/draft-ietf-dnsop-structured-dns-error"/>.</t>
    </note>
  </front>
  <middle>
    <?line 97?>

<section anchor="introduction">
      <name>Introduction</name>
      <t>DNS filters are deployed for a variety of reasons, e.g., endpoint
security, parental filtering, and filtering required by law
enforcement. Network-based security solutions such as firewalls and
Intrusion Prevention Systems (IPS) rely upon network traffic
inspection to implement perimeter-based security policies and operate
by filtering DNS responses. In a home network, DNS filtering is used for the
same reasons as above and additionally for parental control. Internet
Service Providers (ISPs) typically block access to some DNS domains due to a
requirement imposed by an external entity (e.g., law enforcement
agency) also performed using DNS-based content filtering.</t>
      <t>Users of DNS services that perform filtering may wish to receive more
explanatory information about such a filtering to resolve problems with the filter
-- for example to contact the administrator to allowlist a DNS domain that
was erroneously filtered or to understand the reason a particular
domain was filtered. With that information, a user can choose
another network, open a trouble ticket with the DNS administrator to
resolve erroneous filtering, log the information, or other uses.</t>
      <t>For the DNS filtering mechanisms described in <xref target="existing-techniques"/> the DNS
server can return extended error codes Blocked, Filtered, or
Forged Answer defined in <xref section="4" sectionFormat="of" target="RFC8914"/>. However, these codes
only explain that filtering occurred but lack detail for the user to
diagnose erroneous filterings.</t>
      <t>No matter which type of response is generated (forged IP address(es),
NXDOMAIN or empty answer, even with an extended error code), the user
who triggered the DNS query has little chance to understand which
entity filtered the query, how to report a mistake in the filter, or
why the entity filtered it at all. This document describes a mechanism
to provide such detail.</t>
      <t>One of the other benefits of the approach described in this document is to eliminate the need to
"spoof" block pages for HTTPS resources. This is achieved since
clients implementing this approach would be able to display a
meaningful error message, and would not need to connect to such a
block page. This approach thus avoids the need to install a local root
certificate authority on those IT-managed devices.</t>
      <t>This document describes a format for computer-parsable data in the
EXTRA-TEXT field of <xref target="RFC8914"/>. It updates <xref section="2" sectionFormat="of" target="RFC8914"/> which
says the information in EXTRA-TEXT field is intended for human
consumption (not automated parsing).</t>
      <t>This document does not recommend DNS filtering but provides a
mechanism for better transparency to explain to the users why some DNS
queries are filtered.</t>
    </section>
    <section anchor="conventions-and-definitions">
      <name>Conventions and Definitions</name>
      <t>The key words "<bcp14>MUST</bcp14>", "<bcp14>MUST NOT</bcp14>", "<bcp14>REQUIRED</bcp14>", "<bcp14>SHALL</bcp14>", "<bcp14>SHALL
NOT</bcp14>", "<bcp14>SHOULD</bcp14>", "<bcp14>SHOULD NOT</bcp14>", "<bcp14>RECOMMENDED</bcp14>", "<bcp14>NOT RECOMMENDED</bcp14>",
"<bcp14>MAY</bcp14>", and "<bcp14>OPTIONAL</bcp14>" in this document are to be interpreted as
described in BCP 14 <xref target="RFC2119"/> <xref target="RFC8174"/> when, and only when, they
appear in all capitals, as shown here.</t>
      <?line -18?>

<t>This document uses terms defined in DNS Terminology <xref target="RFC8499"/>.</t>
      <t>"Requestor" refers to the side that sends a request. "Responder"
refers to an authoritative, recursive resolver or other DNS component
that responds to questions.</t>
      <t>"Encrypted DNS" refers to any encrypted scheme to convey DNS messages,
for example, DNS-over-HTTPS <xref target="RFC8484"/>, DNS-over-TLS <xref target="RFC7858"/>, or
DNS-over-QUIC <xref target="RFC9250"/>.</t>
      <t>The document refers to an Extended DNS Error (EDE) using its purpose, not its
INFO-CODE as per Table 3 of <xref target="RFC8914"/>. "Forged Answer",
"Blocked", and "Filtered" are thus used to refer to "Forged Answer (4)",
"Blocked (15)", and "Filtered (17)".</t>
    </section>
    <section anchor="existing-techniques">
      <name>DNS Filtering Techniques and Their Limitations</name>
      <t>DNS responses can be filtered by sending a bogus (also called
"forged") A or AAAA response, NXDOMAIN error or empty answer, or an
Extended DNS Error code defined in <xref target="RFC8914"/>. Each of these
methods have advantages and disadvantages that are discussed below:</t>
      <ol spacing="normal" type="1"><li>
          <t>The DNS response is forged to provide a list of IP addresses that
points to an HTTP(S) server alerting the end user about the reason for
blocking access to the requested domain (e.g., malware). When an
HTTP(S) enabled domain name is blocked, the network security device
(e.g., Customer Premises Equipment (CPE) or firewall) presents a block page instead of the HTTP
response from the content provider hosting that domain. If an HTTP
enabled domain name is blocked, the network security device intercepts
the HTTP request and returns a block page over HTTP. If an HTTPS
enabled domain is blocked, the block page is also served over
HTTPS. In order to return a block page over HTTPS, man in the middle
(MITM) is enabled on endpoints by generating a local root certificate
and an accompanying (local) public/private key pair. The local root
certificate is installed on the endpoint while the network security
device stores a copy of the private key. During the TLS handshake,
the on-path network security device modifies the certificate provided by the
server and (re)signs it using the private key from the local root
certificate.  </t>
          <ul spacing="normal">
            <li>However, configuring the local root certificate on endpoints is
not a viable option in several deployments like home networks,
schools, Small Office/Home Office (SOHO), or Small/Medium
Enterprise (SME). In these cases, the typical behavior is that
the filtered DNS response points to a server that will display
the block page. If the client is using HTTPS (via a web browser or
another application) this results in a certificate validation
error which gives no information to the end-user about the reason
for the DNS filtering.</li>
            <li>Enterprise networks do not assume that all the connected devices
are managed by the IT team or Mobile Device Management (MDM)
devices, especially in the quite common Bring Your Own Device
(BYOD) scenario. In addition, the local root certificate cannot
be installed on IoT devices without a device management tool.</li>
            <li>An end user does not know why the connection was prevented and,
consequently, may repeatedly try to reach the domain but with no
success. Frustrated, the end user may switch to an alternate
network that offers no DNS filtering against malware and
phishing, potentially compromising both security and
privacy. Furthermore, certificate errors train users to click
through certificate errors, which is a bad security practice. To
eliminate the need for an end user to click through certificate
errors, an end user may manually install a local root certificate
on a host device. Doing so, however, is also a bad security
practice as it creates a security vulnerability that may be
exploited by a MITM attack. When a manually installed local root
certificate expires, the user has to (again) manually install the
new local root certificate.</li>
          </ul>
        </li>
        <li>The DNS response is forged to provide a NXDOMAIN response to cause
the DNS lookup to terminate in failure. In this case, an end user does
not know why the domain cannot be reached and may repeatedly try to
reach the domain but with no success. Frustrated, the end user may use
insecure connections to reach the domain, potentially compromising
both security and privacy.</li>
        <li>The extended error codes Blocked and Filtered defined in
<xref section="4" sectionFormat="of" target="RFC8914"/> can be returned by a DNS server to provide
additional information about the cause of a DNS error.</li>
        <li>These extended error codes do not suffer from the limitations
discussed in bullets (1) and (2), but the user still does not know the
exact reason nor he/she is aware of the exact entity blocking the
access to the domain. For example, a DNS server may block access to a
domain based on the content category such as "Malware" to protect the
endpoint from malicious software, "Phishing" to prevent the user from
revealing sensitive information to the attacker, etc. A user needs to
know the contact details of the IT/InfoSec team to raise a complaint.</li>
        <li>When a DNS resolver or forwarder forwards the received EDE option, the
EXTRA-TEXT field only conveys the source of the error (<xref section="3" sectionFormat="of" target="RFC8914"/>) and does not provide additional textual information about
the cause of the error.</li>
      </ol>
    </section>
    <section anchor="name-spec">
      <name>I-JSON in EXTRA-TEXT Field</name>
      <t>DNS servers that are compliant with this specification send I-JSON data in
the EXTRA-TEXT field <xref target="RFC8914"/> using the Internet JSON (I-JSON)
message format <xref target="RFC7493"/>.</t>
      <ul empty="true">
        <li>
          <t>Note that <xref target="RFC7493"/> was based on <xref target="RFC7159"/>, but <xref target="RFC7159"/> was replaced by <xref target="RFC8259"/>.</t>
        </li>
      </ul>
      <t>This document defines the following JSON names:</t>
      <dl>
        <dt>c: (contact)</dt>
        <dd>
          <t>The contact details of the IT/InfoSec team to report mis-classified
DNS filtering. This field is structured as an array of contact URIs
(e.g., tel, sips, https). At least one contact URI <bcp14>MUST</bcp14> be
included. This field is mandatory.</t>
        </dd>
        <dt>j: (justification)</dt>
        <dd>
          <t>'UTF-8'-encoded <xref target="RFC5198"/> textual justification for this particular
DNS filtering. The field should be treated only as diagnostic
information for IT staff. This field is mandatory.</t>
        </dd>
        <dt>s: (suberror)</dt>
        <dd>
          <t>the suberror code for this particular DNS filtering. This field is optional.</t>
        </dd>
        <dt>o: (organization)</dt>
        <dd>
          <t>'UTF-8'-encoded human-friendly name of the organization that filtered this particular DNS query. This field is optional.</t>
        </dd>
      </dl>
      <t>New JSON names can be defined in the IANA registry introduced in <xref target="IANA-Names"/>. Such names <bcp14>MUST</bcp14>
consist only of lower-case ASCII characters, digits, and hyphens (that
is, Unicode characters U+0061 through 007A, U+0030 through U+0039, and
U+002D). Also, these names <bcp14>MUST</bcp14> be 63 characters or shorter and it is
<bcp14>RECOMMENDED</bcp14> they be as short as possible.</t>
      <t>The text in the "j" and "o" names can include international
characters. If the text is displayed in a language not known to the
end user, browser extensions to translate to user's native language
can be used.</t>
      <t>To reduce packet overhead the generated JSON <bcp14>SHOULD</bcp14> be as short as
possible: short domain names, concise text in the values for the "j"
and "o" names, and minified JSON (that is, without spaces or line
breaks between JSON elements).</t>
      <t>The JSON data can be parsed to display to the user, logged, or
otherwise used to assist the end-user or IT staff with troubleshooting
and diagnosing the cause of the DNS filtering.</t>
    </section>
    <section anchor="protocol-operation">
      <name>Protocol Operation</name>
      <section anchor="client-request">
        <name>Client Generating Request</name>
        <t>When generating a DNS query the client includes the EDE option (<xref section="2" sectionFormat="of" target="RFC8914"/>) in the OPT pseudo-RR <xref target="RFC6891"/> to
elicit the EDE option in the DNS response. It <bcp14>SHOULD</bcp14> use an
OPTION-LENGTH of 2, the INFO-CODE field set to "0"
(Other Error), and an empty EXTRA-TEXT field.  This signal indicates
that the client desires that the server responds in accordance with
the present specification.</t>
      </section>
      <section anchor="server-response">
        <name>Server Generating Response</name>
        <t>When the DNS server filters its DNS response to an A or AAAA record
query, the DNS response <bcp14>MAY</bcp14> contain an empty answer, NXDOMAIN, or (less
ideally) forged A or AAAA response, as desired by the DNS
server. In addition, if the query contained the OPT pseudo-RR the DNS
server <bcp14>MAY</bcp14> return more detail in the EXTRA-TEXT field as described in
<xref target="client-processing"/>.</t>
        <t>Servers may decide to return small TTL values in filtered DNS
responses (e.g., 2 seconds) to handle domain category and reputation
updates.</t>
        <t>Because the DNS client signals its EDE support (<xref target="client-request"/>)
and because EDE support is signaled via a non-cached OPT resource
record (<xref section="6.2.1" sectionFormat="of" target="RFC6891"/>) the EDE-aware DNS server can
tailor its filtered response to be most appropriate to that client's
EDE support.  If EDE support is signaled in the query the server <bcp14>MUST
NOT</bcp14> return the "Forged Answer" extended error code because the client
can take advantage of EDE's more sophisticated error reporting (e.g.,
"Filtered", "Blocked").  Continuing to send "Forged
Answer" even to an EDE-supporting client will cause the persistence of
the drawbacks described in <xref target="existing-techniques"/>.</t>
      </section>
      <section anchor="client-processing">
        <name>Client Processing Response</name>
        <t>On receipt of a DNS response with an EDE option from a
DNS responder, the following actions are performed on the EXTRA-TEXT
field:</t>
        <ul spacing="normal">
          <li>Verify the field contains valid JSON. If not, the requestor <bcp14>MUST</bcp14>
discard data in the EXTRA-TEXT field.</li>
          <li>The response <bcp14>MUST</bcp14> be received over an encrypted DNS channel. If not,
the requestor <bcp14>MUST</bcp14> discard data in the EXTRA-TEXT field.</li>
          <li>Servers which don't support this specification might use plain text
in the EXTRA-TEXT field so that requestors <bcp14>SHOULD</bcp14> properly handle
both plaintext and JSON text in the EXTRA-TEXT field.</li>
          <li>The DNS response <bcp14>MUST</bcp14> also contain an extended error code of
"Blocked by Upstream Server", "Blocked" or "Filtered" <xref target="RFC8914"/>, otherwise
the EXTRA-TEXT field is discarded.</li>
          <li>If either of the mandatory JSON names "c" and "j" are missing or
have empty values in the EXTRA-TEXT field, the entire JSON is
discarded.</li>
          <li>
            <t>If a DNS client has enabled opportunistic privacy profile (<xref section="5" sectionFormat="of" target="RFC8310"/>) for DoT, the DNS client will either fall back to an  </t>
            <t>
encrypted connection without authenticating the DNS server provided
by the local network or fall back to clear text DNS, and cannot
exchange encrypted DNS messages. Both of these fallback mechanisms
adversely impact security and privacy. If the DNS client has enabled
opportunistic privacy profile for DoT and the identity of the DNS server
cannot be verified, the DNS client <bcp14>MUST</bcp14> ignore the "c", "j", and "o" fields
but <bcp14>MAY</bcp14> process the "s" field and other parts of the response.</t>
          </li>
          <li>Opportunistic discovery <xref target="I-D.ietf-add-ddr"/>, where only the IP address is
validated, the DNS client <bcp14>MUST</bcp14> ignore the "c", "j", and "o" fields
but <bcp14>MAY</bcp14> process the "s" field and other parts of the response.</li>
          <li>If a DNS client has enabled strict privacy profile (<xref section="5" sectionFormat="of" target="RFC8310"/>) for DoT, the DNS client requires an encrypted connection
and successful authentication of the DNS server. In doing so, this mitigates both
passive eavesdropping and client redirection (at the expense of
providing no DNS service if an encrypted, authenticated connection
is not available). If the DNS client has enabled strict privacy
profile for DoT, the DNS client <bcp14>MAY</bcp14> process the EXTRA-TEXT field of the
DNS response.</li>
          <li>When a forwarder receives an EDE option, whether or not (and how) to
pass along JSON information in the EXTRA-TEXT on to their client is
implementation dependent <xref target="RFC5625"/>. Implementations <bcp14>MAY</bcp14> choose to
not forward the JSON information, or they <bcp14>MAY</bcp14> choose to create a new
EDE option that conveys the information in the "c", "s", and "j"
fields encoded in the JSON object.</li>
          <li>The application that triggered the DNS request may have a local policy to override the contact information
 (e.g., redirect all complaint calls to a single contact point). In such a case, the content of the
 "c" attribute can be ignored.</li>
        </ul>
        <ul empty="true">
          <li>
            <t>Note that the strict and opportunistic privacy profiles as defined in <xref target="RFC8310"/> only apply to DoT; there has been
no such distinction made for DoH.</t>
          </li>
        </ul>
      </section>
    </section>
    <section anchor="interoperation-with-rpz-servers">
      <name>Interoperation with RPZ Servers</name>
      <t>This section discusses operation with an RPZ server <xref target="RPZ"/> that
indicates filtering with a NXDOMAIN response with the Recursion
Available bit cleared (RA=0).</t>
      <t>When a DNS client supports this specification it includes the
EDE option in its DNS query.</t>
      <t>If the server does not support this specification and is performing
RPZ filtering, the server ignores the EDE option in the DNS query and
replies with NXDOMAIN and RA=0.  The DNS client can continue to accept
such responses.</t>
      <t>If the server does support this specification and is performing RPZ
filtering, the server can use the EDE option in the query to identify
an EDE-aware client and respond appropriately (that is, by generating
a response described in {#server-response}) as NXDOMAIN and RA=0
are not necessary when generating a response to such a client.</t>
    </section>
    <section anchor="new-sub-error-codes-definition">
      <name>New Sub-Error Codes Definition</name>
      <t>The document defines the following new IANA-registered Sub-Error codes.</t>
      <section anchor="policy-reserved">
        <name>Reserved</name>
        <ul spacing="normal">
          <li>Number: 0</li>
          <li>Meaning: Reserved. This sub-error code value <bcp14>MUST NOT</bcp14> be sent. If received, it has no meaning.</li>
          <li>Applicability: This code should never be used.</li>
          <li>Reference: This-Document</li>
          <li>Change Controller: IETF</li>
        </ul>
      </section>
      <section anchor="policy-network">
        <name>Network Operator Policy</name>
        <ul spacing="normal">
          <li>Number: 5</li>
          <li>Meaning: Network Operator Policy. The code indicates that the request was filtered according to policy determined by the operator of the local network.</li>
          <li>Applicability: Blocked</li>
          <li>Reference: This-Document</li>
          <li>Change Controller: IETF</li>
        </ul>
      </section>
      <section anchor="policy-dns">
        <name>DNS Operator Policy</name>
        <ul spacing="normal">
          <li>Number: 6</li>
          <li>Meaning: DNS Operator Policy. The code indicates that the request was filtered according to policy determined by the operator of the DNS server.</li>
          <li>Applicability: Blocked</li>
          <li>Reference:  This-Document</li>
          <li>Change Controller: IETF</li>
        </ul>
      </section>
    </section>
    <section anchor="extended-dns-error-code-tba1-blocked-by-upstream-dns-server">
      <name>Extended DNS Error Code TBA1 - Blocked by Upstream DNS Server</name>
      <t>The DNS server (e.g., a DNS forwarder) is unable to respond to the request
because the domain is on a blocklist due to an internal security policy
imposed by an upstream DNS server. This error code
is useful in deployments where a network-provided DNS forwarder
is configured to use an external resolver that filters malicious
domains. Typically, when the DNS forwarder receives a Blocked (15) error code from the upstream DNS server, it will replace it with "Blocked by Upstream DNS Server" (TBA1) before forwarding the reply to the DNS client.</t>
    </section>
    <section anchor="examples">
      <name>Examples</name>
      <t>An example showing the nameserver at 'ns.example.net' that filtered a
DNS "A" record query for 'example.org' is provided in <xref target="example-json"/>.</t>
      <figure anchor="example-json">
        <name>JSON Returned in EXTRA-TEXT Field of Extended DNS Error Response</name>
        <artwork><![CDATA[
{
  "c": [
    "tel:+358-555-1234567",
    "sips:bob@bobphone.example.com",
    "https://ticket.example.com?d=example.org&t=1650560748"
  ],
  "j": "malware present for 23 days",
  "s": 1,
  "o": "example.net Filtering Service"
}
]]></artwork>
      </figure>
      <t>In <xref target="example-json-minified"/> the same content is shown with minified JSON (no
whitespace, no blank lines) with <tt>'\'</tt> line wrapping per <xref target="RFC8792"/>.</t>
      <figure anchor="example-json-minified">
        <name>Minified Response</name>
        <artwork><![CDATA[
=============== NOTE: '\' line wrapping per RFC 8792 ===============

{"c":["tel:+358-555-1234567","sips:bob@bobphone.example.com","https\
://ticket.example.com?d=example.org&t=1650560748"],"j":"malware \
present for 23 days","s":1,"o":"example.net Filtering Service"}
]]></artwork>
      </figure>
    </section>
    <section anchor="security">
      <name>Security Considerations</name>
      <t>Security considerations in <xref section="6" sectionFormat="of" target="RFC8914"/> apply to this
document.</t>
      <t>To minimize impact of active on-path attacks on the DNS channel, the
client validates the response as described in <xref target="client-processing"/>.</t>
      <t>A client might choose to display the information in the "c", "j", and
"o" fields if and only if the encrypted resolver has sufficient
reputation, according to some local policy (e.g. user configuration,
administrative configuration, or a built-in list of respectable
resolvers). This limits the ability of a malicious encrypted resolver
to cause harm. If the client decides not to display the all of the
information in the EXTRA-TEXT field, it can be logged for diagnostics
purpose and the client can only display the resolver hostname that
blocked the domain, error description for the EDE code and the
suberror description for the "s" field to the end-user.</t>
      <t>When displaying the free-form text of "j" and "o", the browser <bcp14>SHOULD
NOT</bcp14> make any of those elements into actionable (clickable) links.</t>
      <t>An attacker might inject (or modify) the EDE EXTRA-TEXT field with a
DNS proxy or DNS forwarder that is unaware of EDE. Such a DNS proxy or
DNS forwarder will forward that attacker-controlled EDE option.  To
prevent such an attack, clients can be configured to process EDE from
explicitly configured DNS servers or utilize RESINFO
<xref target="I-D.ietf-add-resolver-info"/>.</t>
    </section>
    <section anchor="IANA">
      <name>IANA Considerations</name>
      <t>This document requests four IANA actions as described in the following subsections.</t>
      <ul empty="true">
        <li>
          <t>Note to the RFC Editor: Please replace RFCXXXX with the RFC number assigned to this document and "TBA1" with the value assigned by IANA.</t>
        </li>
      </ul>
      <section anchor="media-type-registration">
        <name>Media Type Registration</name>
        <t>This document requests IANA to register the
"application/json+structured-dns-error" media type in the "Media
Types" registry <xref target="IANA-MediaTypes"/>. This registration follows the
procedures specified in <xref target="RFC6838"/>:</t>
        <artwork><![CDATA[
   Type name: application

   Subtype name: json+structured-dns-error

   Required parameters: N/A

   Optional parameters: N/A

   Encoding considerations: as defined in Section 4 of RFCXXXX.

   Security considerations: See Section 10 of RFCXXXX.

   Interoperability considerations: N/A

   Published specification: RFCXXXX

   Applications that use this media type: Section 4 of RFCXXXX.

   Fragment identifier considerations: N/A

   Additional information: N/A

   Person & email address to contact for further information: IETF,
      iesg@ietf.org

   Intended usage: COMMON

   Restrictions on usage: none

   Author: See Authors' Addresses section.

   Change controller: IESG

   Provisional registration?  No
]]></artwork>
      </section>
      <section anchor="IANA-Names">
        <name>New Registry for JSON Names</name>
        <t>This document requests IANA to create a new registry, entitled "EXTRA-TEXT JSON Names"
under "Domain Name System (DNS) Parameters, Extended DNS Error Codes"
registry <xref target="IANA-DNS"/>. The registration request for a new JSON name must include the
following fields:</t>
        <dl>
          <dt>JSON Name:</dt>
          <dd>
            <t>Specifies the name of an attribute that is present in the JSON data enclosed in EXTRA-TEXT field. The name must follow the guidelines in <xref target="name-spec"/>.</t>
          </dd>
          <dt>Short description:</dt>
          <dd>
            <t>Includes a short description of the requested JSON name.</t>
          </dd>
          <dt>Mandatory (Y/N?):</dt>
          <dd>
            <t>Indicates whether this attribute is mandatory or optional.</t>
          </dd>
          <dt>Specification:</dt>
          <dd>
            <t>Provides a pointer to the reference document that specifies the attribute.</t>
          </dd>
        </dl>
        <t>The registry is initially populated with the following values:</t>
        <table anchor="reg-names">
          <name>Initial JSON Names Registry</name>
          <thead>
            <tr>
              <th align="center">JSON Name</th>
              <th align="left">Full JSON Name</th>
              <th align="left">Description</th>
              <th align="left">Mandatory</th>
              <th align="center">Specification</th>
            </tr>
          </thead>
          <tbody>
            <tr>
              <td align="center">c</td>
              <td align="left">contact</td>
              <td align="left">The contact details of the IT/InfoSec team to report mis-classified DNS filtering</td>
              <td align="left">Y</td>
              <td align="center">
                <xref target="name-spec"/> of RFCXXXX</td>
            </tr>
            <tr>
              <td align="center">j</td>
              <td align="left">justification</td>
              <td align="left">UTF-8-encoded <xref target="RFC5198"/> textual justification for a particular DNS filtering</td>
              <td align="left">Y</td>
              <td align="center">
                <xref target="name-spec"/> of RFCXXXX</td>
            </tr>
            <tr>
              <td align="center">s</td>
              <td align="left">suberror</td>
              <td align="left">the suberror code for this particular DNS filtering</td>
              <td align="left">N</td>
              <td align="center">
                <xref target="name-spec"/> of RFCXXXX</td>
            </tr>
            <tr>
              <td align="center">o</td>
              <td align="left">organization</td>
              <td align="left">UTF-8-encoded human-friendly name of the organization that filtered this particular DNS query</td>
              <td align="left">N</td>
              <td align="center">
                <xref target="name-spec"/> of RFCXXXX</td>
            </tr>
          </tbody>
        </table>
        <t>New JSON names are registered via IETF Review (<xref section="4.8" sectionFormat="of" target="RFC8126"/>).</t>
      </section>
      <section anchor="new-registry-for-dns-suberror-codes">
        <name>New Registry for DNS SubError Codes</name>
        <t>This document requests IANA to create a new registry, entitled "SubError Codes"
under "Domain Name System (DNS) Parameters, Extended DNS Error Codes"
registry <xref target="IANA-DNS"/>. The registration request for a new suberror codes <bcp14>MUST</bcp14> include the
following fields:</t>
        <ul spacing="normal">
          <li>Number: Is the wire format suberror code (range 0-255).</li>
          <li>Meaning: Provides a short description of the sub-error.</li>
          <li>Applicability: Indicates which RFC8914 error codes apply to this sub-error code.</li>
          <li>Reference: Provides a pointer to an IETF-approved specification that registered
the code and/or an authoritative specification that describes the
meaning of this code.</li>
          <li>Change Controller: Indicates the person or entity, with contact information if appropriate.</li>
        </ul>
        <t>The SubError Code registry is initially be populated with the
following suberror codes:</t>
        <table anchor="reg">
          <name>Initial SubError Code Registry</name>
          <thead>
            <tr>
              <th align="center">Number</th>
              <th align="left">Meaning</th>
              <th align="left">RFC8914 error code applicability</th>
              <th align="left">Reference</th>
              <th align="center">Change Controller</th>
            </tr>
          </thead>
          <tbody>
            <tr>
              <td align="center">0</td>
              <td align="left">Reserved</td>
              <td align="left">Not used</td>
              <td align="left">
                <xref target="policy-reserved"/> of this document</td>
              <td align="center">IETF</td>
            </tr>
            <tr>
              <td align="center">1</td>
              <td align="left">Malware</td>
              <td align="left">"Blocked", "Blocked by Upstream Server", "Filtered"</td>
              <td align="left">Section 5.5 of <xref target="RFC5901"/></td>
              <td align="center">IETF</td>
            </tr>
            <tr>
              <td align="center">2</td>
              <td align="left">Phishing</td>
              <td align="left">"Blocked", "Blocked by Upstream Server", "Filtered"</td>
              <td align="left">Section 5.5 of <xref target="RFC5901"/></td>
              <td align="center">IETF</td>
            </tr>
            <tr>
              <td align="center">3</td>
              <td align="left">Spam</td>
              <td align="left">"Blocked", "Blocked by Upstream Server", "Filtered"</td>
              <td align="left">Page 289 of <xref target="RFC4949"/></td>
              <td align="center">IETF</td>
            </tr>
            <tr>
              <td align="center">4</td>
              <td align="left">Spyware</td>
              <td align="left">"Blocked", "Blocked by Upstream Server", "Filtered"</td>
              <td align="left">Page 291 of <xref target="RFC4949"/></td>
              <td align="center">IETF</td>
            </tr>
            <tr>
              <td align="center">5</td>
              <td align="left">Network operator policy</td>
              <td align="left">"Blocked"</td>
              <td align="left">
                <xref target="policy-network"/> of this document</td>
              <td align="center">IETF</td>
            </tr>
            <tr>
              <td align="center">6</td>
              <td align="left">DNS operator policy</td>
              <td align="left">"Blocked"</td>
              <td align="left">
                <xref target="policy-dns"/> of this document</td>
              <td align="center">IETF</td>
            </tr>
          </tbody>
        </table>
        <t>New SubError Codes are registered via IETF Review (<xref section="4.8" sectionFormat="of" target="RFC8126"/>).</t>
      </section>
      <section anchor="new-extended-dns-error-code">
        <name>New Extended DNS Error Code</name>
        <t>IANA is requested to assign the following Extended DNS Error code from the "Domain Name System (DNS) Parameters, Extended DNS Error Codes"
registry <xref target="IANA-DNS"/>:</t>
        <table anchor="reg-ede">
          <name>New DNS Error Code</name>
          <thead>
            <tr>
              <th align="center">INFO-CODE</th>
              <th align="left">Purose</th>
              <th align="center">Reference</th>
            </tr>
          </thead>
          <tbody>
            <tr>
              <td align="center">TBA1</td>
              <td align="left">Blocked by Upstream Server</td>
              <td align="center">RFCXXXX</td>
            </tr>
          </tbody>
        </table>
      </section>
    </section>
  </middle>
  <back>
    <references>
      <name>References</name>
      <references>
        <name>Normative References</name>
        <reference anchor="RFC8914">
          <front>
            <title>Extended DNS Errors</title>
            <author fullname="W. Kumari" initials="W." surname="Kumari">
              <organization/>
            </author>
            <author fullname="E. Hunt" initials="E." surname="Hunt">
              <organization/>
            </author>
            <author fullname="R. Arends" initials="R." surname="Arends">
              <organization/>
            </author>
            <author fullname="W. Hardaker" initials="W." surname="Hardaker">
              <organization/>
            </author>
            <author fullname="D. Lawrence" initials="D." surname="Lawrence">
              <organization/>
            </author>
            <date month="October" year="2020"/>
            <abstract>
              <t>This document defines an extensible method to return additional information about the cause of DNS errors. Though created primarily to extend SERVFAIL to provide additional information about the cause of DNS and DNSSEC failures, the Extended DNS Errors option defined in this document allows all response types to contain extended error information. Extended DNS Error information does not change the processing of RCODEs.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8914"/>
          <seriesInfo name="DOI" value="10.17487/RFC8914"/>
        </reference>
        <reference anchor="RFC2119">
          <front>
            <title>Key words for use in RFCs to Indicate Requirement Levels</title>
            <author fullname="S. Bradner" initials="S." surname="Bradner">
              <organization/>
            </author>
            <date month="March" year="1997"/>
            <abstract>
              <t>In many standards track documents several words are used to signify the requirements in the specification.  These words are often capitalized. This document defines these words as they should be interpreted in IETF documents.  This document specifies an Internet Best Current Practices for the Internet Community, and requests discussion and suggestions for improvements.</t>
            </abstract>
          </front>
          <seriesInfo name="BCP" value="14"/>
          <seriesInfo name="RFC" value="2119"/>
          <seriesInfo name="DOI" value="10.17487/RFC2119"/>
        </reference>
        <reference anchor="RFC8174">
          <front>
            <title>Ambiguity of Uppercase vs Lowercase in RFC 2119 Key Words</title>
            <author fullname="B. Leiba" initials="B." surname="Leiba">
              <organization/>
            </author>
            <date month="May" year="2017"/>
            <abstract>
              <t>RFC 2119 specifies common key words that may be used in protocol  specifications.  This document aims to reduce the ambiguity by clarifying that only UPPERCASE usage of the key words have the  defined special meanings.</t>
            </abstract>
          </front>
          <seriesInfo name="BCP" value="14"/>
          <seriesInfo name="RFC" value="8174"/>
          <seriesInfo name="DOI" value="10.17487/RFC8174"/>
        </reference>
        <reference anchor="RFC7493">
          <front>
            <title>The I-JSON Message Format</title>
            <author fullname="T. Bray" initials="T." role="editor" surname="Bray">
              <organization/>
            </author>
            <date month="March" year="2015"/>
            <abstract>
              <t>I-JSON (short for "Internet JSON") is a restricted profile of JSON designed to maximize interoperability and increase confidence that software can process it successfully with predictable results.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="7493"/>
          <seriesInfo name="DOI" value="10.17487/RFC7493"/>
        </reference>
        <reference anchor="RFC7159">
          <front>
            <title>The JavaScript Object Notation (JSON) Data Interchange Format</title>
            <author fullname="T. Bray" initials="T." role="editor" surname="Bray">
              <organization/>
            </author>
            <date month="March" year="2014"/>
            <abstract>
              <t>JavaScript Object Notation (JSON) is a lightweight, text-based, language-independent data interchange format.  It was derived from the ECMAScript Programming Language Standard.  JSON defines a small set of formatting rules for the portable representation of structured data.</t>
              <t>This document removes inconsistencies with other specifications of JSON, repairs specification errors, and offers experience-based interoperability guidance.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="7159"/>
          <seriesInfo name="DOI" value="10.17487/RFC7159"/>
        </reference>
        <reference anchor="RFC5198">
          <front>
            <title>Unicode Format for Network Interchange</title>
            <author fullname="J. Klensin" initials="J." surname="Klensin">
              <organization/>
            </author>
            <author fullname="M. Padlipsky" initials="M." surname="Padlipsky">
              <organization/>
            </author>
            <date month="March" year="2008"/>
            <abstract>
              <t>The Internet today is in need of a standardized form for the transmission of internationalized "text" information, paralleling the specifications for the use of ASCII that date from the early days of the ARPANET.  This document specifies that format, using UTF-8 with normalization and specific line-ending sequences.  [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="5198"/>
          <seriesInfo name="DOI" value="10.17487/RFC5198"/>
        </reference>
        <reference anchor="RFC6891">
          <front>
            <title>Extension Mechanisms for DNS (EDNS(0))</title>
            <author fullname="J. Damas" initials="J." surname="Damas">
              <organization/>
            </author>
            <author fullname="M. Graff" initials="M." surname="Graff">
              <organization/>
            </author>
            <author fullname="P. Vixie" initials="P." surname="Vixie">
              <organization/>
            </author>
            <date month="April" year="2013"/>
            <abstract>
              <t>The Domain Name System's wire protocol includes a number of fixed fields whose range has been or soon will be exhausted and does not allow requestors to advertise their capabilities to responders.  This document describes backward-compatible mechanisms for allowing the protocol to grow.</t>
              <t>This document updates the Extension Mechanisms for DNS (EDNS(0)) specification (and obsoletes RFC 2671) based on feedback from deployment experience in several implementations.  It also obsoletes RFC 2673 ("Binary Labels in the Domain Name System") and adds considerations on the use of extended labels in the DNS.</t>
            </abstract>
          </front>
          <seriesInfo name="STD" value="75"/>
          <seriesInfo name="RFC" value="6891"/>
          <seriesInfo name="DOI" value="10.17487/RFC6891"/>
        </reference>
        <reference anchor="RFC8310">
          <front>
            <title>Usage Profiles for DNS over TLS and DNS over DTLS</title>
            <author fullname="S. Dickinson" initials="S." surname="Dickinson">
              <organization/>
            </author>
            <author fullname="D. Gillmor" initials="D." surname="Gillmor">
              <organization/>
            </author>
            <author fullname="T. Reddy" initials="T." surname="Reddy">
              <organization/>
            </author>
            <date month="March" year="2018"/>
            <abstract>
              <t>This document discusses usage profiles, based on one or more authentication mechanisms, which can be used for DNS over Transport Layer Security (TLS) or Datagram TLS (DTLS).  These profiles can increase the privacy of DNS transactions compared to using only cleartext DNS.  This document also specifies new authentication mechanisms -- it describes several ways that a DNS client can use an authentication domain name to authenticate a (D)TLS connection to a DNS server.  Additionally, it defines (D)TLS protocol profiles for DNS clients and servers implementing DNS over (D)TLS.  This document updates RFC 7858.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8310"/>
          <seriesInfo name="DOI" value="10.17487/RFC8310"/>
        </reference>
        <reference anchor="RFC6838">
          <front>
            <title>Media Type Specifications and Registration Procedures</title>
            <author fullname="N. Freed" initials="N." surname="Freed">
              <organization/>
            </author>
            <author fullname="J. Klensin" initials="J." surname="Klensin">
              <organization/>
            </author>
            <author fullname="T. Hansen" initials="T." surname="Hansen">
              <organization/>
            </author>
            <date month="January" year="2013"/>
            <abstract>
              <t>This document defines procedures for the specification and registration of media types for use in HTTP, MIME, and other Internet protocols.  This memo documents an Internet Best Current Practice.</t>
            </abstract>
          </front>
          <seriesInfo name="BCP" value="13"/>
          <seriesInfo name="RFC" value="6838"/>
          <seriesInfo name="DOI" value="10.17487/RFC6838"/>
        </reference>
        <reference anchor="RFC8126">
          <front>
            <title>Guidelines for Writing an IANA Considerations Section in RFCs</title>
            <author fullname="M. Cotton" initials="M." surname="Cotton">
              <organization/>
            </author>
            <author fullname="B. Leiba" initials="B." surname="Leiba">
              <organization/>
            </author>
            <author fullname="T. Narten" initials="T." surname="Narten">
              <organization/>
            </author>
            <date month="June" year="2017"/>
            <abstract>
              <t>Many protocols make use of points of extensibility that use constants to identify various protocol parameters.  To ensure that the values in these fields do not have conflicting uses and to promote interoperability, their allocations are often coordinated by a central record keeper.  For IETF protocols, that role is filled by the Internet Assigned Numbers Authority (IANA).</t>
              <t>To make assignments in a given registry prudently, guidance describing the conditions under which new values should be assigned, as well as when and how modifications to existing values can be made, is needed.  This document defines a framework for the documentation of these guidelines by specification authors, in order to assure that the provided guidance for the IANA Considerations is clear and addresses the various issues that are likely in the operation of a registry.</t>
              <t>This is the third edition of this document; it obsoletes RFC 5226.</t>
            </abstract>
          </front>
          <seriesInfo name="BCP" value="26"/>
          <seriesInfo name="RFC" value="8126"/>
          <seriesInfo name="DOI" value="10.17487/RFC8126"/>
        </reference>
        <reference anchor="RFC5901">
          <front>
            <title>Extensions to the IODEF-Document Class for Reporting Phishing</title>
            <author fullname="P. Cain" initials="P." surname="Cain">
              <organization/>
            </author>
            <author fullname="D. Jevans" initials="D." surname="Jevans">
              <organization/>
            </author>
            <date month="July" year="2010"/>
            <abstract>
              <t>This document extends the Incident Object Description Exchange Format (IODEF) defined in RFC 5070 to support the reporting of phishing events, which is a particular type of fraud.  These extensions are flexible enough to support information gleaned from activities throughout the entire electronic fraud cycle -- from receipt of the phishing lure to the disablement of the collection site.  Both simple reporting and complete forensic reporting are possible, as is consolidating multiple incidents.  [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="5901"/>
          <seriesInfo name="DOI" value="10.17487/RFC5901"/>
        </reference>
        <reference anchor="RFC4949">
          <front>
            <title>Internet Security Glossary, Version 2</title>
            <author fullname="R. Shirey" initials="R." surname="Shirey">
              <organization/>
            </author>
            <date month="August" year="2007"/>
            <abstract>
              <t>This Glossary provides definitions, abbreviations, and explanations of terminology for information system security. The 334 pages of entries offer recommendations to improve the comprehensibility of written material that is generated in the Internet Standards Process (RFC 2026). The recommendations follow the principles that such writing should (a) use the same term or definition whenever the same concept is mentioned; (b) use terms in their plainest, dictionary sense; (c) use terms that are already well-established in open publications; and (d) avoid terms that either favor a particular vendor or favor a particular technology or mechanism over other, competing techniques that already exist or could be developed.  This memo provides information for the Internet community.</t>
            </abstract>
          </front>
          <seriesInfo name="FYI" value="36"/>
          <seriesInfo name="RFC" value="4949"/>
          <seriesInfo name="DOI" value="10.17487/RFC4949"/>
        </reference>
      </references>
      <references>
        <name>Informative References</name>
        <reference anchor="IANA-MediaTypes" target="https://www.iana.org/assignments/media-types">
          <front>
            <title>Media Types</title>
            <author>
              <organization>IANA</organization>
            </author>
            <date/>
          </front>
        </reference>
        <reference anchor="IANA-DNS" target="https://www.iana.org/assignments/dns-parameters/dns-parameters.xhtml#extended-dns-error-codes">
          <front>
            <title>Domain Name System (DNS) Parameters, Extended DNS Error Codes</title>
            <author>
              <organization>IANA</organization>
            </author>
            <date/>
          </front>
        </reference>
        <reference anchor="RPZ" target="https://dnsrpz.info">
          <front>
            <title>Response Policy Zone</title>
            <author>
              <organization/>
            </author>
            <date/>
          </front>
        </reference>
        <reference anchor="RFC8499">
          <front>
            <title>DNS Terminology</title>
            <author fullname="P. Hoffman" initials="P." surname="Hoffman">
              <organization/>
            </author>
            <author fullname="A. Sullivan" initials="A." surname="Sullivan">
              <organization/>
            </author>
            <author fullname="K. Fujiwara" initials="K." surname="Fujiwara">
              <organization/>
            </author>
            <date month="January" year="2019"/>
            <abstract>
              <t>The Domain Name System (DNS) is defined in literally dozens of different RFCs.  The terminology used by implementers and developers of DNS protocols, and by operators of DNS systems, has sometimes changed in the decades since the DNS was first defined.  This document gives current definitions for many of the terms used in the DNS in a single document.</t>
              <t>This document obsoletes RFC 7719 and updates RFC 2308.</t>
            </abstract>
          </front>
          <seriesInfo name="BCP" value="219"/>
          <seriesInfo name="RFC" value="8499"/>
          <seriesInfo name="DOI" value="10.17487/RFC8499"/>
        </reference>
        <reference anchor="RFC8484">
          <front>
            <title>DNS Queries over HTTPS (DoH)</title>
            <author fullname="P. Hoffman" initials="P." surname="Hoffman">
              <organization/>
            </author>
            <author fullname="P. McManus" initials="P." surname="McManus">
              <organization/>
            </author>
            <date month="October" year="2018"/>
            <abstract>
              <t>This document defines a protocol for sending DNS queries and getting DNS responses over HTTPS.  Each DNS query-response pair is mapped into an HTTP exchange.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8484"/>
          <seriesInfo name="DOI" value="10.17487/RFC8484"/>
        </reference>
        <reference anchor="RFC7858">
          <front>
            <title>Specification for DNS over Transport Layer Security (TLS)</title>
            <author fullname="Z. Hu" initials="Z." surname="Hu">
              <organization/>
            </author>
            <author fullname="L. Zhu" initials="L." surname="Zhu">
              <organization/>
            </author>
            <author fullname="J. Heidemann" initials="J." surname="Heidemann">
              <organization/>
            </author>
            <author fullname="A. Mankin" initials="A." surname="Mankin">
              <organization/>
            </author>
            <author fullname="D. Wessels" initials="D." surname="Wessels">
              <organization/>
            </author>
            <author fullname="P. Hoffman" initials="P." surname="Hoffman">
              <organization/>
            </author>
            <date month="May" year="2016"/>
            <abstract>
              <t>This document describes the use of Transport Layer Security (TLS) to provide privacy for DNS.  Encryption provided by TLS eliminates opportunities for eavesdropping and on-path tampering with DNS queries in the network, such as discussed in RFC 7626.  In addition, this document specifies two usage profiles for DNS over TLS and provides advice on performance considerations to minimize overhead from using TCP and TLS with DNS.</t>
              <t>This document focuses on securing stub-to-recursive traffic, as per the charter of the DPRIVE Working Group.  It does not prevent future applications of the protocol to recursive-to-authoritative traffic.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="7858"/>
          <seriesInfo name="DOI" value="10.17487/RFC7858"/>
        </reference>
        <reference anchor="RFC9250">
          <front>
            <title>DNS over Dedicated QUIC Connections</title>
            <author fullname="C. Huitema" initials="C." surname="Huitema">
              <organization/>
            </author>
            <author fullname="S. Dickinson" initials="S." surname="Dickinson">
              <organization/>
            </author>
            <author fullname="A. Mankin" initials="A." surname="Mankin">
              <organization/>
            </author>
            <date month="May" year="2022"/>
            <abstract>
              <t>This document describes the use of QUIC to provide transport confidentiality for DNS. The encryption provided by QUIC has similar properties to those provided by TLS, while QUIC transport eliminates the head-of-line blocking issues inherent with TCP and provides more efficient packet-loss recovery than UDP. DNS over QUIC (DoQ) has privacy properties similar to DNS over TLS (DoT) specified in RFC 7858, and latency characteristics similar to classic DNS over UDP. This specification describes the use of DoQ as a general-purpose transport for DNS and includes the use of DoQ for stub to recursive, recursive to authoritative, and zone transfer scenarios.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="9250"/>
          <seriesInfo name="DOI" value="10.17487/RFC9250"/>
        </reference>
        <reference anchor="RFC8259">
          <front>
            <title>The JavaScript Object Notation (JSON) Data Interchange Format</title>
            <author fullname="T. Bray" initials="T." role="editor" surname="Bray">
              <organization/>
            </author>
            <date month="December" year="2017"/>
            <abstract>
              <t>JavaScript Object Notation (JSON) is a lightweight, text-based, language-independent data interchange format.  It was derived from the ECMAScript Programming Language Standard.  JSON defines a small set of formatting rules for the portable representation of structured data.</t>
              <t>This document removes inconsistencies with other specifications of JSON, repairs specification errors, and offers experience-based interoperability guidance.</t>
            </abstract>
          </front>
          <seriesInfo name="STD" value="90"/>
          <seriesInfo name="RFC" value="8259"/>
          <seriesInfo name="DOI" value="10.17487/RFC8259"/>
        </reference>
        <reference anchor="I-D.ietf-add-ddr">
          <front>
            <title>Discovery of Designated Resolvers</title>
            <author fullname="Tommy Pauly" initials="T." surname="Pauly">
              <organization>Apple Inc.</organization>
            </author>
            <author fullname="Eric Kinnear" initials="E." surname="Kinnear">
              <organization>Apple Inc.</organization>
            </author>
            <author fullname="Christopher A. Wood" initials="C. A." surname="Wood">
              <organization>Cloudflare</organization>
            </author>
            <author fullname="Patrick McManus" initials="P." surname="McManus">
              <organization>Fastly</organization>
            </author>
            <author fullname="Tommy Jensen" initials="T." surname="Jensen">
              <organization>Microsoft</organization>
            </author>
            <date day="5" month="August" year="2022"/>
            <abstract>
              <t>   This document defines Discovery of Designated Resolvers (DDR), a
   mechanism for DNS clients to use DNS records to discover a resolver's
   encrypted DNS configuration.  An encrypted DNS resolver discovered in
   this manner is referred to as a "Designated Resolver".  This
   mechanism can be used to move from unencrypted DNS to encrypted DNS
   when only the IP address of a resolver is known.  This mechanism is
   designed to be limited to cases where unencrypted DNS resolvers and
   their designated resolvers are operated by the same entity or
   cooperating entities.  It can also be used to discover support for
   encrypted DNS protocols when the name of an encrypted DNS resolver is
   known.

              </t>
            </abstract>
          </front>
          <seriesInfo name="Internet-Draft" value="draft-ietf-add-ddr-10"/>
        </reference>
        <reference anchor="RFC5625">
          <front>
            <title>DNS Proxy Implementation Guidelines</title>
            <author fullname="R. Bellis" initials="R." surname="Bellis">
              <organization/>
            </author>
            <date month="August" year="2009"/>
            <abstract>
              <t>This document provides guidelines for the implementation of DNS proxies, as found in broadband gateways and other similar network devices.  This document specifies an Internet Best Current Practices for the Internet Community, and requests discussion and suggestions for improvements.</t>
            </abstract>
          </front>
          <seriesInfo name="BCP" value="152"/>
          <seriesInfo name="RFC" value="5625"/>
          <seriesInfo name="DOI" value="10.17487/RFC5625"/>
        </reference>
        <reference anchor="RFC8792">
          <front>
            <title>Handling Long Lines in Content of Internet-Drafts and RFCs</title>
            <author fullname="K. Watsen" initials="K." surname="Watsen">
              <organization/>
            </author>
            <author fullname="E. Auerswald" initials="E." surname="Auerswald">
              <organization/>
            </author>
            <author fullname="A. Farrel" initials="A." surname="Farrel">
              <organization/>
            </author>
            <author fullname="Q. Wu" initials="Q." surname="Wu">
              <organization/>
            </author>
            <date month="June" year="2020"/>
            <abstract>
              <t>This document defines two strategies for handling long lines in width-bounded text content.  One strategy, called the "single backslash" strategy, is based on the historical use of a single backslash ('\') character to indicate where line-folding has occurred, with the continuation occurring with the first character that is not a space character (' ') on the next line.  The second strategy, called the "double backslash" strategy, extends the first strategy by adding a second backslash character to identify where the continuation begins and is thereby able to handle cases not supported by the first strategy.  Both strategies use a self-describing header enabling automated reconstitution of the original content.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8792"/>
          <seriesInfo name="DOI" value="10.17487/RFC8792"/>
        </reference>
        <reference anchor="I-D.ietf-add-resolver-info">
          <front>
            <title>DNS Resolver Information</title>
            <author fullname="Tirumaleswar Reddy.K" initials="T." surname="Reddy.K">
              <organization>Nokia</organization>
            </author>
            <author fullname="Mohamed Boucadair" initials="M." surname="Boucadair">
              <organization>Orange</organization>
            </author>
            <date day="26" month="May" year="2023"/>
            <abstract>
              <t>   This document specifies a method for DNS resolvers to publish
   information about themselves.  DNS clients can use the resolver
   information to identify the capabilities of DNS resolvers.  How such
   an information is then used by DNS clients is out of the scope of the
   document.

              </t>
            </abstract>
          </front>
          <seriesInfo name="Internet-Draft" value="draft-ietf-add-resolver-info-02"/>
        </reference>
      </references>
    </references>
    <?line 672?>

<section numbered="false" anchor="acknowledgements">
      <name>Acknowledgements</name>
      <t>Thanks to Vittorio Bertola, Wes Hardaker, Ben Schwartz, Erid Orth,
Viktor Dukhovni, Warren Kumari, Paul Wouters, John Levine, and Bob
Harold for the comments.</t>
      <t>Thanks to Ralf Weber and Gianpaolo Scalone for sharing details about their implementation.</t>
    </section>
  </back>
  <!-- ##markdown-source:
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

-->

</rfc>
