<?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.39 (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-06" category="std" consensus="true" submissionType="IETF" updates="8914" tocInclude="true" sortRefs="true" symRefs="true" version="3">
  <!-- xml2rfc v2v3 conversion 3.17.4 -->
  <front>
    <title abbrev="Structured DNS Error">Structured Error Data for Filtered DNS</title>
    <seriesInfo name="Internet-Draft" value="draft-ietf-dnsop-structured-dns-error-06"/>
    <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="July" day="26"/>
    <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 structured 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 for HTTPS resources.</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
to use another network, open a trouble ticket with the DNS administrator to
resolve erroneous filtering, log the information, etc.</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, e.g., a bogus (also called
"forged") response, NXDOMAIN error, or empty answer. Also, clients can be informed that filtering has occured by sending 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 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 may need to
know the contact details of the IT/InfoSec team to raise a complaint.</li>
      </ol>
    </section>
    <section anchor="name-spec">
      <name>I-JSON in EXTRA-TEXT Field</name>
      <t>DNS servers that are compliant with this specification and have received an indication that the client also supports this specification as per <xref target="client-request"/> send data in the EXTRA-TEXT field <xref target="RFC8914"/> encoded 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 information is important for transparency and also to ease unblocking a legitimate domain name that got blocked due to wrong classification.</t>
        </dd>
        <dt/>
        <dd>
          <t>This field is structured as an array of contact URIs
(e.g., 'tel' <xref target="RFC3966"/>, 'sips' <xref target="RFC5630"/>, 'https' <xref target="RFC8615"/>). At least one contact URI <bcp14>MUST</bcp14> be
included.</t>
        </dd>
        <dt/>
        <dd>
          <t>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.</t>
        </dd>
        <dt/>
        <dd>
          <t>Whether the information provided in the "j" name is meaningful or considered as garbage data
(including empty values) is local to each IT teams. Returning garbage data
would indicate that a DNS server is misbehaving. Note also that the provided
justification is useful for cross-validation with another DNS server.</t>
        </dd>
        <dt/>
        <dd>
          <t>This field is mandatory.</t>
        </dd>
        <dt>s: (suberror)</dt>
        <dd>
          <t>The suberror code for this particular DNS filtering.</t>
        </dd>
        <dt/>
        <dd>
          <t>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.</t>
        </dd>
        <dt/>
        <dd>
          <t>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 DNS message size 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>
      <ul empty="true">
        <li>
          <t>An alternate design for conveying the suberror would be to define new EDE codes for these errors. However, such design is suboptimal because it requires replicating an error code for each EDE code to which the suberror applies (e.g., "Malware" suberror in <xref target="reg"/> would consume three EDE codes).</t>
        </li>
      </ul>
    </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>MUST</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 a
query (e.g., A or AAAA record query), the DNS response <bcp14>MAY</bcp14> contain an empty answer, NXDOMAIN, or (less
ideally) forged 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 as per <xref target="client-request"/>, 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 ordered actions are performed on the EXTRA-TEXT
field:</t>
        <ul spacing="normal">
          <li>Servers which don't support this specification might use plain text
in the EXTRA-TEXT field. Requestors <bcp14>SHOULD</bcp14> properly handle
both plaintext and JSON text in the EXTRA-TEXT field. The requestor verifies that
the field contains valid JSON. If not, the requestor <bcp14>MUST</bcp14> consider
the server does not support this specification and stop processing
rest of the actions defined in this section, but may instead choose
to treat EXTRA-TEXT as per <xref target="RFC8914"/>.</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>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>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
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 but the connection is encrypted, 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>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="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, except the guard against using EDE content to alter DNS protocol
processing. The guard is relaxed in the current specification as it mandates
encryption and recommends the use of an authenticated connection to the DNS
server, while <xref target="RFC8914"/> assumes that EDE information is unauthenticated
and sent over clear text.</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. For example, an end user can use the details in the "c" field to contact an attacker
to solve the problem of being unable to reach a domain. The attacker can mislead the end user to
install malware or spyware to compromise the device security posture or mislead the end user to reveal
personal data.
If the client decides not to display 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>MUST
NOT</bcp14> make any of those elements into actionable (clickable) links and these
fields need to be rendered as text, not as HTML. The contact details of "c" can be made
into clickable links to provide a convenient way for users to initiate, e.g., voice calls. The client might
choose to display the contact details only when the identity of the DNS server is verified.</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"/>
            <author fullname="E. Hunt" initials="E." surname="Hunt"/>
            <author fullname="R. Arends" initials="R." surname="Arends"/>
            <author fullname="W. Hardaker" initials="W." surname="Hardaker"/>
            <author fullname="D. Lawrence" initials="D." surname="Lawrence"/>
            <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"/>
            <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"/>
            <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"/>
            <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"/>
            <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"/>
            <author fullname="M. Padlipsky" initials="M." surname="Padlipsky"/>
            <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"/>
            <author fullname="M. Graff" initials="M." surname="Graff"/>
            <author fullname="P. Vixie" initials="P." surname="Vixie"/>
            <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"/>
            <author fullname="D. Gillmor" initials="D." surname="Gillmor"/>
            <author fullname="T. Reddy" initials="T." surname="Reddy"/>
            <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"/>
            <author fullname="J. Klensin" initials="J." surname="Klensin"/>
            <author fullname="T. Hansen" initials="T." surname="Hansen"/>
            <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"/>
            <author fullname="B. Leiba" initials="B." surname="Leiba"/>
            <author fullname="T. Narten" initials="T." surname="Narten"/>
            <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"/>
            <author fullname="D. Jevans" initials="D." surname="Jevans"/>
            <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"/>
            <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"/>
            <author fullname="A. Sullivan" initials="A." surname="Sullivan"/>
            <author fullname="K. Fujiwara" initials="K." surname="Fujiwara"/>
            <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"/>
            <author fullname="P. McManus" initials="P." surname="McManus"/>
            <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"/>
            <author fullname="L. Zhu" initials="L." surname="Zhu"/>
            <author fullname="J. Heidemann" initials="J." surname="Heidemann"/>
            <author fullname="A. Mankin" initials="A." surname="Mankin"/>
            <author fullname="D. Wessels" initials="D." surname="Wessels"/>
            <author fullname="P. Hoffman" initials="P." surname="Hoffman"/>
            <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"/>
            <author fullname="S. Dickinson" initials="S." surname="Dickinson"/>
            <author fullname="A. Mankin" initials="A." surname="Mankin"/>
            <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"/>
            <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="RFC3966">
          <front>
            <title>The tel URI for Telephone Numbers</title>
            <author fullname="H. Schulzrinne" initials="H." surname="Schulzrinne"/>
            <date month="December" year="2004"/>
            <abstract>
              <t>This document specifies the URI (Uniform Resource Identifier) scheme "tel". The "tel" URI describes resources identified by telephone numbers. This document obsoletes RFC 2806. [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="3966"/>
          <seriesInfo name="DOI" value="10.17487/RFC3966"/>
        </reference>
        <reference anchor="RFC5630">
          <front>
            <title>The Use of the SIPS URI Scheme in the Session Initiation Protocol (SIP)</title>
            <author fullname="F. Audet" initials="F." surname="Audet"/>
            <date month="October" year="2009"/>
            <abstract>
              <t>This document provides clarifications and guidelines concerning the use of the SIPS URI scheme in the Session Initiation Protocol (SIP). It also makes normative changes to SIP. [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="5630"/>
          <seriesInfo name="DOI" value="10.17487/RFC5630"/>
        </reference>
        <reference anchor="RFC8615">
          <front>
            <title>Well-Known Uniform Resource Identifiers (URIs)</title>
            <author fullname="M. Nottingham" initials="M." surname="Nottingham"/>
            <date month="May" year="2019"/>
            <abstract>
              <t>This memo defines a path prefix for "well-known locations", "/.well-known/", in selected Uniform Resource Identifier (URI) schemes.</t>
              <t>In doing so, it obsoletes RFC 5785 and updates the URI schemes defined in RFC 7230 to reserve that space. It also updates RFC 7595 to track URI schemes that support well-known URIs in their registry.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8615"/>
          <seriesInfo name="DOI" value="10.17487/RFC8615"/>
        </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"/>
            <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"/>
            <author fullname="E. Auerswald" initials="E." surname="Auerswald"/>
            <author fullname="A. Farrel" initials="A." surname="Farrel"/>
            <author fullname="Q. Wu" initials="Q." surname="Wu"/>
            <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="4" month="July" 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-03"/>
        </reference>
      </references>
    </references>
    <?line 667?>

<section anchor="interoperation-with-rpz-servers">
      <name>Interoperation with RPZ Servers</name>
      <t>This appendix provides a non-normative guidance for operation with an Response Policy Zones (RPZ) server <xref target="RPZ"/> that
indicates filtering with a NXDOMAIN response with the Recursion
Available bit cleared (RA=0). This guidance is provided to ease interoperation with RPZ.</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 <xref target="server-response"/>) as NXDOMAIN and RA=0
are not necessary when generating a response to such a client.</t>
    </section>
    <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, Bob
Harold, and Mukund Sivaraman for the comments.</t>
      <t>Thanks to Ralf Weber and Gianpaolo Scalone for sharing details about their implementation.</t>
      <t>Thanks Di Ma and Matt Brown for the DNS directorate reviews, and Joseph Salowey for the Security directorate review.</t>
    </section>
  </back>
  <!-- ##markdown-source:
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
cufH+LT09kD6Cw//CfbWGvU6dgAA

-->

</rfc>
