<?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.2.3) -->
<?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-21" category="std" consensus="true" submissionType="IETF" updates="8914" tocInclude="true" sortRefs="true" symRefs="true" version="3">
  <!-- xml2rfc v2v3 conversion 3.34.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-21"/>
    <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).</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. 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:
H4sIAAAAAAAAA9V9WXfb2LXmO37FafrBYi5JW57KVmWSLTnWjQdFklOpDKsL
JEEKJRBgAFCyqsr3vR/6P9zf0sP/6v3tvc8EgrYrSa/VrZWUSRA4wz57njAe
j5M2b4vswAzO23ozazd1NjfHdV3V5ihtU7OgDy/zos1w/ejt+SBJp9M6u44f
oB/koUEyS9tsWdW3B6Zp58lmPafvzYF5+mz/UZLMq1mZrmi2eZ0u2nGetYvx
vGyq9bhxg+HCOMNg4wLPtkmzma7ypsmrsr1d08Mnxxcvk3Kzmmb1QYLxD5JZ
VTZZ2WxoJhooS2h9D5O0zlJa50lJqy+zdpDcVPXVsq42a7qKJb9bZ3Xa0riN
+YZ+ysul+R1+HiRX2S3dPD9IzNi82DRttcpqk32g+/OsnGW4fFISbFa0+Xk2
y7E4XGzrtGzWNHE5u8X3rKzz2SXdtMiy+TSdXSXJdVZuaMXG2JUwAAZ0QXY3
6CzFmFWaF/a+3wJmk6pe4oe0nl3SD5dtu24O7t3DfbiUX2cTe9s9XLg3raub
JrvHI9zDk8u8vdxM6Vk+gpulnMK9LzoWPC8nE8wdjTOR4Sd59WUjftldk8t2
VQySpGnTcv5f06IqCVq3WZOs8wPzl7aajUxT1W2dLRr6dLvSDy2dQDsys2q1
ysqWrhASrtL1mkD8tyRJN+1lVeOcaVfGLDZFIRh6lJbmG7qHLxMg0zL/gXHl
wLzIacwP5vy2abMVDXhSziZ8myUNuYEvzapN2YIa3pd5S3hw3gJyplqYQ0Kp
fJbyXZk94rS8oTl/u8T3CS15sL2wi7zerNIia27S2pxl8/ltzxLfVle5DD3L
W5r9eVouCWJ1xtfqbMl3/T6tSyLyqzRe6kk5z+N1XVXlvM3rT67rbZYX5kVV
XfUshwitHP9pdkmryHrB8nva9bxaRZOWGc9VXf22rGivGX2ebK56Zn5TXaYg
xOfVZpbO07zuW0Ht5iaMyDLC3bOsLAl7ZDlzGufh4/v378fLe0mPzbJoWSuZ
bTK1s/224rEFLElSElegSa+JxpOceYT9ZszJ4dvDMXGeAx7RKOs9qmjo0ryl
YRWpzB7dNDSnaU3XiHsRkh1/aLNyHvJaAvZc128cGsvf2H7ogmGAFQx09rRe
Ag6WhG9ubiZ5WqbCNojfLkumGLCN8dotpfN18gFkeSfT5QXce+aXx0zaLNKi
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

-->

</rfc>
