<?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.7.39 (Ruby 3.4.9) -->
<?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-22" category="std" consensus="true" submissionType="IETF" updates="8914" tocInclude="true" sortRefs="true" symRefs="true" version="3">
  <!-- xml2rfc v2v3 conversion 3.33.0 -->
  <front>
    <title abbrev="Structured DNS Error">Structured Error Data for Filtered DNS</title>
    <seriesInfo name="Internet-Draft" value="draft-ietf-dnsop-structured-dns-error-22"/>
    <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="2026" month="June" day="09"/>
    <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 86?>

<t>DNS filtering is widely deployed for various reasons, including
network security and policy enforcement. 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 99?>

<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>End users or network administrators leveraging 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 DNS service administrator to allowlist a DNS domain that
was erroneously filtered or to understand the reason a particular
domain was filtered. With that information, they can choose
to use another network, open a trouble ticket with the DNS service 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, Censored, 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 filtering.</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 end 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>As noted in <xref section="6" sectionFormat="of" target="RFC7754"/>, promptly informing the endpoint that blocking has occurred provides necessary transparency to redress any errors, particularly as they relate to collateral damage introduced by errant filters.</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 machine-readable data in the
EXTRA-TEXT field of <xref target="RFC8914"/>. The document 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 end 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="RFC9499"/>.</t>
      <t>"Encrypted DNS" refers to any encrypted scheme to convey DNS messages,
for example, DNS over HTTPS (DoH) <xref target="RFC8484"/>, DNS over TLS (DoT) <xref target="RFC7858"/>, or
DNS over QUIC (DoQ) <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", "Censored", and "Filtered" are thus used to refer to "Forged Answer (4)",
"Blocked (15)", "Censored (16)", and "Filtered (17)".</t>
      <t>In this document, "client security policy evaluation" refers to implementation-defined
decision-making performed by the DNS client or consuming application (e.g., web
browser) to
determine how, or whether, structured error information is used, displayed,
or acted upon.</t>
      <t>Structured DNS Error (SDE) is an EDNS(0) option indicating support for structured encoding of the EXTRA-TEXT field. See also <xref target="SDE"/>.</t>
      <t>"DNS administrator" refers to the party responsible for operating
and configuring the DNS server, including the definition of
filtering policies.</t>
      <t>"IT/InfoSec team" refers to the organizational team responsible
for receiving and handling end-user reports of misclassified DNS
filtering, including decisions on allowlisting domains or revising
filtering policies.</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 occurred 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>
      <ul spacing="normal">
        <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). If the host component <xref target="RFC3986"/>
of an HTTP URL 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. This works successfully with HTTP.
<br/><br/>
If this is an HTTPS URL, the network security device attempts to serve the block page over HTTPS.  In order to return a block page over HTTPS, the network security device uses a locally
generated root certificate and corresponding 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>
              <t>In deployments where DNSSEC is used, this approach becomes ineffective because DNSSEC
ensures the integrity and authenticity of DNS responses, preventing forged DNS
responses from being accepted.</t>
            </li>
            <li>
              <t>The HTTPS server hosted on the network security device will have access to the
client's IP address, the hostname, and the URL path component of the request. This information will be sensitive, as it will expose the end user's identity and the specific resource that an end user attempted to access.</t>
            </li>
            <li>
              <t>Configuring a 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.</t>
            </li>
            <li>
              <t>Enterprise networks do not always 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.</t>
            </li>
            <li>
              <t>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 end 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 end user has to (again) manually install the
new local root certificate.</t>
            </li>
          </ul>
        </li>
        <li>
          <t>The DNS response is forged to provide an NXDOMAIN answer, causing the DNS lookup to fail. This approach is incompatible with DNSSEC when the client performs validation, as the forged response will fail DNSSEC checks. However, in deployments where the client relies on the DNS server to perform DNSSEC validation, a filtering DNS server can forge an NXDOMAIN response for a valid domain, and the client will trust it. This undermines the integrity guarantees of DNSSEC, as the client has no way to distinguish between a genuine and a forged response. Further, the end user may not understand why a domain cannot be reached and may repeatedly attempt access without success. Frustrated, the end user may resort to using insecure methods to reach the domain, potentially compromising both security and privacy.</t>
        </li>
        <li>
          <t>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.
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 end user from
revealing sensitive information to the attacker, etc. An end user may need to
know the contact details of the IT/InfoSec team to raise a complaint.
Further, the information conveyed by <xref target="RFC8914"/> is intended for
diagnostic purposes and is not structured for automated processing,
localization, or extensibility.</t>
        </li>
      </ul>
      <t>This document defines a structured,
machine-readable format for conveying such details in the EXTRA-TEXT
field, enabling clients to process the information programmatically
and present it to end users (e.g., with localization support), while
allowing for extensibility and more granular, client security
policy-driven handling of the information. This specification requires
that clients only act upon such information when it is received
over an integrity-protected DNS response.</t>
    </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"/> as a JSON object encoded using the Internet JSON (I-JSON) message format <xref target="RFC7493"/>.</t>
      <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 misclassified
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>The field is a JSON array of contact URIs. When multiple contact details are provided, each contact URI is
represented as a separate array element in the JSON array.</t>
        </dd>
        <dt/>
        <dd>
          <t>Contact URIs conveyed in the "c" field <bcp14>MUST</bcp14> use URI schemes registered in <xref target="IANA-Contact"/>.</t>
        </dd>
        <dt/>
        <dd>
          <t>This field is optional.</t>
        </dd>
        <dt>j: (justification)</dt>
        <dd>
          <t>'UTF-8'-encoded <xref target="RFC5198"/> human-readable explanation for the DNS
filtering decision.</t>
        </dd>
        <dt/>
        <dd>
          <t>This field is particularly useful when no applicable sub-error code
is defined or provided for the returned Extended DNS Error.</t>
        </dd>
        <dt/>
        <dd>
          <t>The information conveyed in this field <bcp14>MUST NOT</bcp14> be used as input to
automated processing that affects security policy enforcement or DNS
protocol behavior.</t>
        </dd>
        <dt/>
        <dd>
          <t>The DNS client determines, according to its client security policy,
whether the contents of this field are displayed to the end user,
logged, or ignored.</t>
        </dd>
        <dt/>
        <dd>
          <t>Returning non-UTF-8 data, syntactically invalid content, or
deliberately meaningless values (including empty strings) indicates that
a DNS server is misbehaving.</t>
        </dd>
        <dt/>
        <dd>
          <t>This field is optional.</t>
        </dd>
        <dt>s: (sub-error)</dt>
        <dd>
          <t>An integer representing the sub-error code for this particular DNS filtering case.</t>
        </dd>
        <dt/>
        <dd>
          <t>The integer values are defined in the IANA-managed registry for DNS Sub-Error Codes in <xref target="IANA-SubError"/>.</t>
        </dd>
        <dt/>
        <dd>
          <t>This field is optional.</t>
        </dd>
      </dl>
      <t>When multiple blocking causes apply simultaneously
(e.g., a domain is blocked for both malware and phishing reasons),
a single SDE response is returned. The "s" field <bcp14>MUST</bcp14> convey the
primary blocking cause. The "j" field <bcp14>MUST</bcp14> be used to provide
additional context describing all applicable causes.</t>
      <dl>
        <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>
        <dt>l: (language)</dt>
        <dd>
          <t>The "l" field indicates the language used for the JSON-encoded "j" and "o" fields.  The value of this field <bcp14>MUST</bcp14> conform to the
language tag syntax specified in <xref section="2.1" sectionFormat="of" target="RFC5646"/>.</t>
        </dd>
        <dt/>
        <dd>
          <t>This field is <bcp14>REQUIRED</bcp14> when either the "j" or "o" fields are present.</t>
        </dd>
      </dl>
      <t>The text in the "j" and "o" names can include international
characters. The text will be in natural language, chosen by the DNS administrator
to match its expected audience.</t>
      <t>The "o" field <bcp14>MAY</bcp14> be displayed to end users, subject to the conditions described in <xref target="security"/>.</t>
      <t>To avoid exceeding the maximum EDNS0 size <xref target="RFC9715"/> the generated JSON values <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). Otherwise, there is a risk that the response will get fragmented.</t>
      <t>The JSON data can be parsed to display to the user, logged, or
otherwise used to assist troubleshooting and diagnosis of DNS filtering.</t>
      <t>The sub-error codes provide a structured way to communicate more detailed and precise description of the cause of an error (e.g., distinguishing between malware-related blocking and phishing-related blocking under the general blocked error).</t>
      <ul empty="true">
        <li>
          <t>An alternate design for conveying the sub-error 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 sub-error applies (e.g., "Malware" sub-error in <xref target="reg"/> would consume three EDE codes).</t>
        </li>
      </ul>
      <t>New JSON names <bcp14>MUST</bcp14> consist only of lower-case ASCII characters, digits,
and hyphen-minus (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 to reduce contribution to exceeding maximum EDNS0 response
size. Refer to <xref target="RFC9715"/> for a discusson on IP fragmentation avoidance in DNS.</t>
    </section>
    <section anchor="protocol-operation">
      <name>Protocol Operation</name>
      <section anchor="client-request">
        <name>Client Generating Request</name>
        <t>When generating a DNS query, a client that supports this specification
<bcp14>SHOULD</bcp14> include the Structured DNS Error (SDE) option defined in <xref target="SDE"/>, unless instructed by local policy otherwise.</t>
        <t>The presence of the SDE option indicates that the client desires the
DNS server to include an EDE option in the DNS response when DNS
filtering is performed, and that any data conveyed in the EXTRA-TEXT
field of the EDE option is encoded and processed in accordance with
this 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 resource record query), the DNS response <bcp14>MAY</bcp14> contain an empty answer, NXDOMAIN, or (less
ideally) forged response, as desired by the DNS
server.</t>
        <t>If the query contained the SDE EDNS option (<xref target="client-request"/>), and the DNS server returns an EDE code of "Blocked", "Filtered", "Censored", or "Blocked by Upstream DNS Server", the DNS server <bcp14>SHOULD</bcp14> include additional detail in the EXTRA-TEXT field encoded as structured and machine-readable data in accordance with the present specification, unless configured otherwise. If the DNS response is sent over UDP and including the additional detail would cause the response to exceed the EDNS0 size
<xref target="RFC9715"/> (and thus setting TC=1), the server <bcp14>MUST</bcp14> first attempt to reduce the response size by omitting the "j" and "o" fields before omitting the EXTRA-TEXT entirely. In deployments using DoT, DoH, or DoQ, transport size limitations are unlikely to necessitate omission of structured data in the EXTRA-TEXT field.</t>
        <t>If the SDE option was not present in the DNS request, the DNS server <bcp14>MUST</bcp14> process the request in accordance with <xref target="RFC8914"/> and <bcp14>MUST NOT</bcp14> assume that the client supports this specification. This preserves compatibility with clients and servers that implement <xref target="RFC8914"/> but do not support this specification.</t>
        <t>Servers <bcp14>MAY</bcp14> decide to return small TTL values in filtered DNS
responses (e.g., 10 seconds) to handle domain category and reputation
updates. Short TTLs allow for quick adaptation to dynamic changes in domain filtering decisions,
but can result in increased query traffic. In cases where updates are less frequent,
TTL values of 30 to 60 seconds <bcp14>MAY</bcp14> provide a better balance, reducing server load while
still ensuring reasonable flexibility for updates.</t>
        <t>If the query includes the SDE option 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" or "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>
        <t>When the "Censored" extended error code is included in the DNS response,
the "c", "j", "o", and "l" fields may be conveyed in the EXTRA-TEXT field.
The sub-error codes defined in this specification are not applicable to
the "Censored" extended error code and <bcp14>MUST NOT</bcp14> be used in conjunction with it.
Future specifications may update this behavior by defining sub-error codes
applicable to "Censored".</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 server, the following ordered actions are performed on the EXTRA-TEXT
field:</t>
        <ol spacing="normal" type="1"><li>
            <t>If the integrity of the DNS response is not guaranteed, the
DNS client <bcp14>MUST NOT</bcp14> act upon data in the EXTRA-TEXT field, as the data
is vulnerable to
modification by an on-path attacker. An attacker can inject or
modify a structured DNS error response in transit without detection,
enabling fabrication of filtering information (e.g., misleading contact
information or false resolver identity information) that appears to
originate from the resolver. The data <bcp14>MAY</bcp14> be retained for diagnostic or
client security policy evaluation purposes.</t>
          </li>
          <li>
            <t>The DNS response <bcp14>MUST</bcp14> also contain an EDE code of
"Blocked by Upstream DNS Server", "Blocked", "Censored", or "Filtered" <xref target="RFC8914"/>,
otherwise the EXTRA-TEXT field is discarded.</t>
          </li>
          <li>
            <t>Servers that do not support this specification might use plain text in the
EXTRA-TEXT field. To ensure compatibility with those, DNS clients <bcp14>SHOULD</bcp14> handle both plaintext and structured content. The client attempts to parse the EXTRA-TEXT field as I-JSON. If parsing fails or the content is not valid I-JSON, the client <bcp14>MUST</bcp14> treat the data as invalid, <bcp14>MUST NOT</bcp14> process it according to this specification. The client <bcp14>MAY</bcp14> instead process the EXTRA-TEXT field as unstructured text as specified in <xref target="RFC8914"/>.</t>
          </li>
          <li>
            <t>If the JSON object contains an "s" field and the sub-error code
is not defined as applicable to the accompanying Extended DNS Error
(EDE) code, the client <bcp14>MUST</bcp14> ignore the value of the "s" field
and continue processing the remaining fields in accordance with this
specification.</t>
          </li>
          <li>
            <t>If the EXTRA-TEXT field does not contain at least one of the JSON
names "c", "j", or "s", or if all of the fields that are present have
empty values, the entire JSON object <bcp14>MUST</bcp14> be discarded.</t>
          </li>
          <li>
            <t>If the JSON object contains a "c" field any of its Contact URIs
with schemes not registered in the <xref target="IANA-Contact"/> registry are
ignored. Remaining Contact URIs using registered schemes can be
processed.</t>
          </li>
          <li>
            <t>If the identity of the DNS server cannot be verified (e.g., when
using opportunistic privacy such as <xref section="5" sectionFormat="of" target="RFC8310"/> or opportunistic discovery <xref target="RFC9462"/>), the DNS client <bcp14>MUST</bcp14> ignore the "c", "j", and "o" fields, as these fields may influence end user behavior and are vulnerable to active attacks in the absence of resolver authentication. If the DNS response was received over an encrypted connection without server authentication, the client <bcp14>MAY</bcp14> process the "s" field and other parts of the response, as the "s" field is a registry-defined, enumerated value and does not contain free-form text.</t>
          </li>
          <li>
            <t>If the DNS client uses an authenticated connection to the DNS server (e.g., when
using a strict privacy profile for DoT (<xref section="5" sectionFormat="of" target="RFC8310"/>) or an authenticated DoH or DoQ connection), this mitigates both passive eavesdropping and client redirection (at the expense of providing no DNS service if such a connection is not available). In such cases, the DNS client <bcp14>MAY</bcp14> process the EXTRA-TEXT field of the DNS response.</t>
          </li>
          <li>
            <t>The DNS client <bcp14>MUST</bcp14> ignore any other JSON names that it does not support.</t>
          </li>
        </ol>
        <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 anchor="SDE">
        <name>Structured DNS Error (SDE) EDNS(0) Option Format</name>
        <t>The Structured DNS Error (SDE) EDNS(0) option is used by a client to
indicate support for I-JSON encoding in the EXTRA-TEXT field of an
Extended DNS Error (EDE) option.</t>
        <t>The SDE option has no OPTION-DATA. The OPTION-LENGTH field <bcp14>MUST</bcp14>
be set to 0. A server receiving an SDE option with a non-zero
OPTION-LENGTH <bcp14>MUST</bcp14> silently ignore the OPTION-DATA.</t>
        <t>The presence of the SDE option in a query indicates that the client
supports processing the EXTRA-TEXT field in accordance with this
specification.</t>
      </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. See <xref target="IANA-SubError"/>.</t>
      <section anchor="policy-reserved">
        <name>Reserved</name>
        <t>This sub-error code value <bcp14>MUST NOT</bcp14> be sent. If received, it has no meaning.</t>
      </section>
      <section anchor="policy-network">
        <name>Network Operator Policy</name>
        <t>The code indicates that the request was filtered according to a policy imposed by the operator of the local network (where local network is a relative term, e.g., it may refer to a Local Area Network or to the network of the ISP selected by the end user).</t>
      </section>
      <section anchor="policy-dns">
        <name>DNS Operator Policy</name>
        <t>The code indicates that the request was filtered according to policy determined by the operator of the DNS server. This is different from the "Network Operator Policy" code when a third-party DNS resolver is used.</t>
      </section>
    </section>
    <section anchor="new-extended-dns-errors">
      <name>New Extended DNS Errors</name>
      <t>This document defines an addition to the EDE codes defined in <xref target="RFC8914"/>.</t>
      <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 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. When the DNS forwarder receives a Blocked (15) error code
from the upstream DNS server, it can replace it with
"Blocked by Upstream DNS Server" (TBA1) before forwarding
the reply to the DNS client. Additionally, the EXTRA-TEXT field may
be forwarded to the DNS client.</t>
        <t>Implementations should ensure that the communication channel with the
upstream DNS server provides adequate integrity protection to mitigate
the threats described in step 1 of <xref target="client-processing"/>.</t>
      </section>
    </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"
  ],
  "j": "malware present for 23 days",
  "s": 1,
  "o": "example.net Filtering Service",
  "l": "en"
}
]]></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[
{ "c":["tel:+358-555-1234567","sips:bob@bobphone.example.com"],\
"j":"malware present for 23 days",\
"s":1,\
"o":"example.net Filtering Service",\
"l":"en" }
]]></artwork>
      </figure>
      <t><xref target="example-dig"/> shows how the SDE and EDE options appear in a <tt>dig</tt> response for the same query.</t>
      <figure anchor="example-dig">
        <name>dig Response Showing SDE and EDE Options</name>
        <artwork><![CDATA[
;; ->>HEADER<<- opcode: QUERY, status: NXDOMAIN, id: 12345
;; flags: qr rd ra; QUERY: 1, ANSWER: 0, AUTHORITY: 1, ADDITIONAL: 1

;; OPT PSEUDOSECTION:
; EDNS: version: 0, flags:; udp: 1232
; OPT=TBD1 (Structured DNS Error): (no data)
; EDE: 15 (Blocked): ({"c":["tel:+358-555-1234567",\
  "sips:bob@bobphone.example.com"],"j":"malware present for 23 days",\
  "s":1,"o":"example.net Filtering Service","l":"en"})
]]></artwork>
      </figure>
    </section>
    <section anchor="operational-considerations">
      <name>Operational Considerations</name>
      <t>When a forwarder receives an EDE option, whether or not (and how) to pass along JSON information in the
EXTRA-TEXT field to its client is implementation-dependent <xref target="RFC5625"/> and depends on operator policy. Implementations <bcp14>MAY</bcp14> choose not to
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.</t>
      <t>The application that triggered the DNS request may have a client security policy to override the contact information (e.g., redirect all complaint calls to a single contact point). In such cases, the content of the "c" attribute <bcp14>MAY</bcp14> be ignored.</t>
      <section anchor="backward-compatibility">
        <name>Backward Compatibility</name>
        <t>Future extensions <bcp14>MUST NOT</bcp14> introduce mandatory JSON attributes, as existing implementations are required to ignore unknown JSON names (see <xref target="client-processing"/>).</t>
      </section>
    </section>
    <section anchor="security">
      <name>Security Considerations</name>
      <section anchor="authentication-and-confidentiality">
        <name>Authentication and Confidentiality</name>
        <t>Security considerations in <xref section="6" sectionFormat="of" target="RFC8914"/> apply to this
document. <xref target="RFC8914"/> cautions against relying on EDE information because it may be unauthenticated and transmitted in cleartext. This specification assumes the use of authenticated, integrity-protected DNS transports (e.g., DoT, DoH, or DoQ). Such transports <bcp14>MUST</bcp14> be based on TLS 1.3 <xref target="RFC8446"/> or later.  Under these conditions, EDE information is integrity-protected, reducing the risks associated with relying on structured EDE content.</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>
      </section>
      <section anchor="restrictions-on-display-of-c-o-and-j-fields">
        <name>Restrictions on Display of "c", "o", and "j" Fields</name>
        <t>A client might choose to display the information in the "c" field
to the end user if and only if the encrypted resolver has sufficient
reputation, according to some client security policy (e.g.,
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
sub-error description for the "s" field to the end user.</t>
        <t>The same client security policy considerations apply to the display of the "j" field, as it
contains free-form, human-readable text that may influence end user behavior.</t>
        <t>When displaying the free-form text of "o", the client <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 end 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>Clients <bcp14>MUST NOT</bcp14> automatically initiate connections to URIs derived from the EXTRA-TEXT field. Doing so could allow a resolver to silently report client activity to third parties, enable denial-of-service reflection attacks, or be used to entrap a client. The restriction of Contact URI schemes to "sips", "tel", and "mailto" is intentional, as these schemes do not result in automatic HTTP connections.</t>
        <t>Further, clients <bcp14>MUST NOT</bcp14> display the value of the <tt>"o"</tt> field to the end user unless one of the following
conditions is met:</t>
        <ul spacing="normal">
          <li>
            <t>The value matches a registered organization name listed in the <xref target="IANA-Enterprise"/> OR</t>
          </li>
          <li>
            <t>The value consists solely of an organization name and does not contain any additional free-form content such
as instructions, URLs, or messaging intended to influence end user behavior, as determined by client security policy or heuristics.</t>
          </li>
        </ul>
        <t>If the organization name cannot be verified through registry checks or heuristics, the client <bcp14>MUST NOT</bcp14> display the "o" field to the end user.</t>
        <t>DNS clients <bcp14>MAY</bcp14> keep all fields conveyed in the EXTRA-TEXT field for evaluation according to the client security  policy. Such data <bcp14>MUST NOT</bcp14> be automatically trusted, displayed to end users, or used to influence security decisions without appropriate validation.</t>
      </section>
      <section anchor="security-risks-from-legacy-dns-forwarders">
        <name>Security Risks from Legacy DNS Forwarders</name>
        <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="RFC9606"/>.</t>
      </section>
      <section anchor="privacy-considerations">
        <name>Privacy Considerations</name>
        <t>The EXTRA-TEXT field may reveal details about the filtering organization and its policies. Clients <bcp14>MUST NOT</bcp14> log or transmit the contents of the EXTRA-TEXT field to third parties without the end user's knowledge.</t>
        <t>This specification requires the use of an encrypted DNS transport (e.g., DoT, DoH, or DoQ), which protects both the DNS query and the structured error response from passive observers.</t>
      </section>
    </section>
    <section anchor="IANA">
      <name>IANA Considerations</name>
      <t>This document requests five IANA actions as described in the following subsections.</t>
      <ul empty="true">
        <li>
          <t>Notes to the RFC Editor: Please replace RFCXXXX with the RFC number assigned to this document and "TBA1" with the value assigned by IANA, and replace "TBD1" in <xref target="example-dig"/> with the value assigned by IANA.</t>
        </li>
      </ul>
      <section anchor="structured-dns-error-edns-option">
        <name>Structured DNS Error EDNS Option</name>
        <t>IANA is requested to register the following new EDNS(0) Option Code in the
"DNS EDNS0 Option Codes (OPT)" registry under the "Domain Name System (DNS) Parameters" registry group <xref target="IANA-DNS"/>:</t>
        <dl>
          <dt>Value:</dt>
          <dd>
            <t>TBD</t>
          </dd>
          <dt>Name:</dt>
          <dd>
            <t>Structured DNS Error</t>
          </dd>
          <dt>Status:</dt>
          <dd>
            <t>Standard</t>
          </dd>
          <dt>Reference:</dt>
          <dd>
            <t>RFC XXXX</t>
          </dd>
        </dl>
      </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 "Extended DNS Error Codes" registry, which is under the "Domain Name System (DNS) Parameters" registry group <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>Field Meaning:</dt>
          <dd>
            <t>Provides a brief, human-readable label summarizing the purpose of the JSON attribute.</t>
          </dd>
          <dt>Short description:</dt>
          <dd>
            <t>Includes a short description of the requested JSON name.</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">Field Meaning</th>
              <th align="left">Description</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 misclassified DNS filtering</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="center">
                <xref target="name-spec"/> of RFCXXXX</td>
            </tr>
            <tr>
              <td align="center">s</td>
              <td align="left">sub-error</td>
              <td align="left">Integer representing the sub-error code for this DNS filtering case</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="center">
                <xref target="name-spec"/> of RFCXXXX</td>
            </tr>
            <tr>
              <td align="center">l</td>
              <td align="left">language</td>
              <td align="left">Indicates the language of the "j" and "o" fields as defined in <xref target="RFC5646"/></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"/>) and their formatting
constraints are described in <xref target="name-spec"/>.</t>
      </section>
      <section anchor="IANA-Contact">
        <name>New Registry for Contact URI Scheme</name>
        <t>This document requests IANA to create a new registry, entitled "Contact URI Schemes"
under "Extended DNS Error Codes"
registry, which is under the "Domain Name System (DNS) Parameters" registry group <xref target="IANA-DNS"/>. The registration request for a new Contact URI scheme has to include the
following fields:</t>
        <ul spacing="normal">
          <li>
            <t>Name: URI scheme name.</t>
          </li>
          <li>
            <t>Meaning: Provides a short description of the scheme.</t>
          </li>
          <li>
            <t>Reference: Provides a pointer to an IETF-approved specification that defines
the URI scheme.</t>
          </li>
        </ul>
        <t>The Contact URI scheme registry is initially populated with the
following schemes:</t>
        <table>
          <thead>
            <tr>
              <th align="center">Name</th>
              <th align="left">Meaning</th>
              <th align="center">Reference</th>
            </tr>
          </thead>
          <tbody>
            <tr>
              <td align="center">sips</td>
              <td align="left">SIP Call</td>
              <td align="center">
                <xref target="RFC5630"/></td>
            </tr>
            <tr>
              <td align="center">tel</td>
              <td align="left">Telephone Number</td>
              <td align="center">
                <xref target="RFC3966"/></td>
            </tr>
            <tr>
              <td align="center">mailto</td>
              <td align="left">Internet mail</td>
              <td align="center">
                <xref target="RFC6068"/></td>
            </tr>
          </tbody>
        </table>
        <t>The registration procedure for adding new Contact URI schemes to the "Contact URI Schemes" registry is "IETF
Review" as defined in <xref section="4.8" sectionFormat="of" target="RFC8126"/>.</t>
      </section>
      <section anchor="IANA-SubError">
        <name>New Registry for DNS Sub-Error Codes</name>
        <t>This document requests IANA to create a new registry, entitled "Sub-Error Codes"
under "Extended DNS Error Codes" registry, which is under the "Domain Name System (DNS) Parameters" registry group <xref target="IANA-DNS"/>. The registration request for a new sub-error code must include the
following fields:</t>
        <ul spacing="normal">
          <li>
            <t>Number: Is the wire format sub-error code (range 0-255).</t>
          </li>
          <li>
            <t>Meaning: Provides a short description of the sub-error.</t>
          </li>
          <li>
            <t>EDE Codes Applicability: Indicates which Extended DNS Error (EDE) Codes apply to this sub-error code.</t>
          </li>
          <li>
            <t>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.</t>
          </li>
        </ul>
        <t>The Sub-Error Code registry is initially populated with the
following values:</t>
        <table anchor="reg">
          <name>Initial Sub-Error Code Registry</name>
          <thead>
            <tr>
              <th align="center">Number</th>
              <th align="left">Meaning</th>
              <th align="left">EDE Codes Applicability</th>
              <th align="left">Reference</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>
            </tr>
            <tr>
              <td align="center">1</td>
              <td align="left">Malware</td>
              <td align="left">"Blocked", "Blocked by Upstream DNS Server", "Filtered"</td>
              <td align="left">Section 5.5 of <xref target="RFC5901"/></td>
            </tr>
            <tr>
              <td align="center">2</td>
              <td align="left">Phishing</td>
              <td align="left">"Blocked", "Blocked by Upstream DNS Server", "Filtered"</td>
              <td align="left">Section 5.5 of <xref target="RFC5901"/></td>
            </tr>
            <tr>
              <td align="center">3</td>
              <td align="left">Spam</td>
              <td align="left">"Blocked", "Blocked by Upstream DNS Server", "Filtered"</td>
              <td align="left">Page 289 of <xref target="RFC4949"/></td>
            </tr>
            <tr>
              <td align="center">4</td>
              <td align="left">Spyware</td>
              <td align="left">"Blocked", "Blocked by Upstream DNS Server", "Filtered"</td>
              <td align="left">Page 291 of <xref target="RFC4949"/></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>
            </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>
            </tr>
          </tbody>
        </table>
        <t>The registration procedure to add New Sub-Error Codes is IETF Review as defined in <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 "Extended DNS Error Codes"
registry under the "Domain Name System (DNS) Parameters" registry group <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">Purpose</th>
              <th align="center">Reference</th>
            </tr>
          </thead>
          <tbody>
            <tr>
              <td align="center">TBA1</td>
              <td align="left">Blocked by Upstream DNS Server</td>
              <td align="center">RFCXXXX</td>
            </tr>
          </tbody>
        </table>
      </section>
    </section>
  </middle>
  <back>
    <references anchor="sec-combined-references">
      <name>References</name>
      <references anchor="sec-normative-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="RFC9499">
          <front>
            <title>DNS Terminology</title>
            <author fullname="P. Hoffman" initials="P." surname="Hoffman"/>
            <author fullname="K. Fujiwara" initials="K." surname="Fujiwara"/>
            <date month="March" year="2024"/>
            <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 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 updates RFC 2308 by clarifying the definitions of "forwarder" and "QNAME". It obsoletes RFC 8499 by adding multiple terms and clarifications. Comprehensive lists of changed and new definitions can be found in Appendices A and B.</t>
            </abstract>
          </front>
          <seriesInfo name="BCP" value="219"/>
          <seriesInfo name="RFC" value="9499"/>
          <seriesInfo name="DOI" value="10.17487/RFC9499"/>
        </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="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="RFC5646">
          <front>
            <title>Tags for Identifying Languages</title>
            <author fullname="A. Phillips" initials="A." role="editor" surname="Phillips"/>
            <author fullname="M. Davis" initials="M." role="editor" surname="Davis"/>
            <date month="September" year="2009"/>
            <abstract>
              <t>This document describes the structure, content, construction, and semantics of language tags for use in cases where it is desirable to indicate the language used in an information object. It also describes how to register values for use in language tags and the creation of user-defined extensions for private interchange. 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="47"/>
          <seriesInfo name="RFC" value="5646"/>
          <seriesInfo name="DOI" value="10.17487/RFC5646"/>
        </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="RFC8446">
          <front>
            <title>The Transport Layer Security (TLS) Protocol Version 1.3</title>
            <author fullname="E. Rescorla" initials="E." surname="Rescorla"/>
            <date month="August" year="2018"/>
            <abstract>
              <t>This document specifies version 1.3 of the Transport Layer Security (TLS) protocol. TLS allows client/server applications to communicate over the Internet in a way that is designed to prevent eavesdropping, tampering, and message forgery.</t>
              <t>This document updates RFCs 5705 and 6066, and obsoletes RFCs 5077, 5246, and 6961. This document also specifies new requirements for TLS 1.2 implementations.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8446"/>
          <seriesInfo name="DOI" value="10.17487/RFC8446"/>
        </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="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="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="RFC6068">
          <front>
            <title>The 'mailto' URI Scheme</title>
            <author fullname="M. Duerst" initials="M." surname="Duerst"/>
            <author fullname="L. Masinter" initials="L." surname="Masinter"/>
            <author fullname="J. Zawinski" initials="J." surname="Zawinski"/>
            <date month="October" year="2010"/>
            <abstract>
              <t>This document defines the format of Uniform Resource Identifiers (URIs) to identify resources that are reached using Internet mail. It adds better internationalization and compatibility with Internationalized Resource Identifiers (IRIs; RFC 3987) to the previous syntax of 'mailto' URIs (RFC 2368). [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="6068"/>
          <seriesInfo name="DOI" value="10.17487/RFC6068"/>
        </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 anchor="sec-informative-references">
        <name>Informative References</name>
        <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="Impl-1" target="https://datatracker.ietf.org/meeting/116/materials/slides-116-dnsop-dns-errors-implementation-proposal-slides-116-dnsop-update-on-dns-errors-implementation-00">
          <front>
            <title>Use of DNS Errors To improve Browsing User Experience With network based malware protection</title>
            <author>
              <organization/>
            </author>
            <date year="2023" month="March"/>
          </front>
        </reference>
        <reference anchor="IANA-Enterprise" target="https://www.iana.org/assignments/enterprise-numbers/">
          <front>
            <title>Private Enterprise Numbers (PENs)</title>
            <author>
              <organization/>
            </author>
            <date/>
          </front>
        </reference>
        <reference anchor="RFC7754">
          <front>
            <title>Technical Considerations for Internet Service Blocking and Filtering</title>
            <author fullname="R. Barnes" initials="R." surname="Barnes"/>
            <author fullname="A. Cooper" initials="A." surname="Cooper"/>
            <author fullname="O. Kolkman" initials="O." surname="Kolkman"/>
            <author fullname="D. Thaler" initials="D." surname="Thaler"/>
            <author fullname="E. Nordmark" initials="E." surname="Nordmark"/>
            <date month="March" year="2016"/>
            <abstract>
              <t>The Internet is structured to be an open communications medium. This openness is one of the key underpinnings of Internet innovation, but it can also allow communications that may be viewed as undesirable by certain parties. Thus, as the Internet has grown, so have mechanisms to limit the extent and impact of abusive or objectionable communications. Recently, there has been an increasing emphasis on "blocking" and "filtering", the active prevention of such communications. This document examines several technical approaches to Internet blocking and filtering in terms of their alignment with the overall Internet architecture. When it is possible to do so, the approach to blocking and filtering that is most coherent with the Internet architecture is to inform endpoints about potentially undesirable services, so that the communicants can avoid engaging in abusive or objectionable communications. We observe that certain filtering and blocking approaches can cause unintended consequences to third parties, and we discuss the limits of efficacy of various approaches.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="7754"/>
          <seriesInfo name="DOI" value="10.17487/RFC7754"/>
        </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="RFC3986">
          <front>
            <title>Uniform Resource Identifier (URI): Generic Syntax</title>
            <author fullname="T. Berners-Lee" initials="T." surname="Berners-Lee"/>
            <author fullname="R. Fielding" initials="R." surname="Fielding"/>
            <author fullname="L. Masinter" initials="L." surname="Masinter"/>
            <date month="January" year="2005"/>
            <abstract>
              <t>A Uniform Resource Identifier (URI) is a compact sequence of characters that identifies an abstract or physical resource. This specification defines the generic URI syntax and a process for resolving URI references that might be in relative form, along with guidelines and security considerations for the use of URIs on the Internet. The URI syntax defines a grammar that is a superset of all valid URIs, allowing an implementation to parse the common components of a URI reference without knowing the scheme-specific requirements of every possible identifier. This specification does not define a generative grammar for URIs; that task is performed by the individual specifications of each URI scheme. [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="STD" value="66"/>
          <seriesInfo name="RFC" value="3986"/>
          <seriesInfo name="DOI" value="10.17487/RFC3986"/>
        </reference>
        <reference anchor="RFC9715">
          <front>
            <title>IP Fragmentation Avoidance in DNS over UDP</title>
            <author fullname="K. Fujiwara" initials="K." surname="Fujiwara"/>
            <author fullname="P. Vixie" initials="P." surname="Vixie"/>
            <date month="January" year="2025"/>
            <abstract>
              <t>The widely deployed Extension Mechanisms for DNS (EDNS(0)) feature in the DNS enables a DNS receiver to indicate its received UDP message size capacity, which supports the sending of large UDP responses by a DNS server. Large DNS/UDP messages are more likely to be fragmented, and IP fragmentation has exposed weaknesses in application protocols. It is possible to avoid IP fragmentation in DNS by limiting the response size where possible and signaling the need to upgrade from UDP to TCP transport where necessary. This document describes techniques to avoid IP fragmentation in DNS.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="9715"/>
          <seriesInfo name="DOI" value="10.17487/RFC9715"/>
        </reference>
        <reference anchor="RFC9462">
          <front>
            <title>Discovery of Designated Resolvers</title>
            <author fullname="T. Pauly" initials="T." surname="Pauly"/>
            <author fullname="E. Kinnear" initials="E." surname="Kinnear"/>
            <author fullname="C. A. Wood" initials="C. A." surname="Wood"/>
            <author fullname="P. McManus" initials="P." surname="McManus"/>
            <author fullname="T. Jensen" initials="T." surname="Jensen"/>
            <date month="November" year="2023"/>
            <abstract>
              <t>This document defines Discovery of Designated Resolvers (DDR), a set of mechanisms 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". These mechanisms can be used to move from unencrypted DNS to encrypted DNS when only the IP address of a resolver is known. These mechanisms are 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="RFC" value="9462"/>
          <seriesInfo name="DOI" value="10.17487/RFC9462"/>
        </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="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="RFC9606">
          <front>
            <title>DNS Resolver Information</title>
            <author fullname="T. Reddy.K" initials="T." surname="Reddy.K"/>
            <author fullname="M. Boucadair" initials="M." surname="Boucadair"/>
            <date month="June" year="2024"/>
            <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 DNS clients use such information is beyond the scope of this document.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="9606"/>
          <seriesInfo name="DOI" value="10.17487/RFC9606"/>
        </reference>
      </references>
    </references>
    <?line 761?>

<section anchor="interoperation-with-rpz-servers">
      <name>Interoperation with RPZ Servers</name>
      <t>This appendix provides a non-normative guidance for operation with a 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
SDE option in its DNS query.</t>
      <t>If the server does not support this specification and is performing
RPZ filtering, the server ignores the SDE 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 SDE option in the query to identify
an SDE-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 anchor="implementation-status">
      <name>Implementation Status</name>
      <ul empty="true">
        <li>
          <t>Note to the RFC Editor: please remove this appendix prior publication.</t>
        </li>
      </ul>
      <t>At IETF#116, Gianpaolo Scalone (Vodafone) and Ralf Weber (Akamai) presented an implementation of this specification. More details can be found at <xref target="Impl-1"/>.</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, Mukund Sivaraman, Gianpaolo Angelo Scalone, Mark Nottingham, Stephane Bortzmeyer, Daniel Migault, Lars Eggert, and Stephen Farrell for the comments.</t>
      <t>Thanks to Ralf Weber and Gianpaolo Scalone for sharing details about their implementation.</t>
      <t>Thanks Petr Špaček, Di Ma and Matt Brown for the DNSDIR reviews, Joseph Salowey for the SECDIR review, and Paul Kyzivat for the ARTART review.</t>
      <t>Thanks to Éric Vyncke for the AD review.</t>
    </section>
  </back>
  <!-- ##markdown-source:
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

-->

</rfc>
