<?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.36 (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-05" 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-05"/>
    <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="07"/>
    <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>SHOULD
NOT</bcp14> make any of those elements into actionable (clickable) links and these
fields need to be rendered as text, not as HTML.</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 665?>

<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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
uE11AAA=

-->

</rfc>
