<?xml version="1.0" encoding="US-ASCII"?> encoding="UTF-8"?>
<!DOCTYPE rfc SYSTEM "rfc2629.dtd" [
<!ENTITY rfc2119 PUBLIC "" ".//reference.RFC.2119.xml">
]>
<!-- WK: Set category, IPR, docName --> "rfc2629-xhtml.ent">

<rfc category="std" xmlns:xi="http://www.w3.org/2001/XInclude" docName="draft-ietf-dnsop-extended-error-16"
     ipr="trust200902">
  <?xml-stylesheet type='text/xsl' href='rfc2629.xslt' ?>

  <?rfc toc="yes" ?>

  <?rfc symrefs="yes" ?>

  <?rfc sortrefs="yes"?>

  <?rfc iprnotified="no" ?>

  <?rfc strict="yes"?>

  <?rfc compact="yes" ?>
  <?rfc subcompact="yes" ?>

  <front> number="8914" ipr="trust200902" obsoletes="" updates="" submissionType="IETF" category="std" consensus="true" xml:lang="en" tocInclude="true" symRefs="true" sortRefs="true" version="3">

 <!-- WK: Set long title. xml2rfc v2v3 conversion 2.44.0 -->

 <front>

   <title abbrev="draft-ietf-dnsop-extended-error">Extended abbrev="Extended DNS Errors">Extended DNS
   Errors</title>
   <seriesInfo name="RFC" value="8914"/>
   <author fullname="Warren Kumari" initials="W." surname="Kumari">
     <organization>Google</organization>
     <address>
       <postal>
         <street>1600 Amphitheatre Parkway</street>
         <city>Mountain View, CA</city> View</city><region>CA</region>
         <code>94043</code>

          <country>US</country>
         <country>United States of America</country>
       </postal>
       <email>warren@kumari.net</email>
     </address>
   </author>
   <author fullname="Evan Hunt" initials="E." surname="Hunt">
     <organization>ISC</organization>
     <address>
       <postal>
         <street>950 Charter St</street>
         <city>Redwood City, CA</city> City</city><region>CA</region>
         <code>94063</code>

          <country>US</country>
         <country>United States of America</country>
       </postal>
       <email>each@isc.org</email>
     </address>
   </author>
   <author fullname="Roy Arends" initials="R." surname="Arends">
     <organization>ICANN</organization>
     <address>
       <postal>
         <street/>
       </postal>
       <email>roy.arends@icann.org</email>
     </address>
   </author>
   <author fullname="Wes Hardaker" initials="W." surname="Hardaker">
     <organization>USC/ISI</organization>
     <address>
       <postal>
         <street>P.O. Box 382</street>

          <city>Davis, CA</city>
         <city>Davis</city><region>CA</region>
         <code>95617</code>

          <country>US</country>
         <country>United States of America</country>
       </postal>
       <email>ietf@hardakers.net</email>
     </address>
   </author>
   <author fullname="David C Lawrence" initials="D." surname="Lawrence">
      <organization>Oracle + Dyn</organization>
     <organization>Salesforce</organization>
     <address>
       <postal>
          <street>150 Dow
         <street>415 Mission St</street>

          <city>Manchester, NH</city>

          <code>03101</code>

          <country>US</country>
         <city>San Francisco</city><region>CA</region>
         <code>94105</code>
         <country>United States of America</country>
       </postal>
       <email>tale@dd.org</email>
     </address>
   </author>
   <date day="05" month="May" month="October" year="2020"/>

<keyword>DNS</keyword>
<keyword>Error</keyword>
<keyword>Domain</keyword>
<keyword>Name</keyword>
<keyword>System</keyword>

   <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>
 <middle>
   <section title="Introduction anchor="intro" numbered="true" toc="default">
     <name>Introduction and background" anchor="intro"> Background</name>
     <t>There are many reasons that a DNS query may fail, fail -- some of
     them transient, some permanent; some can be resolved by querying
     another server, some are likely best handled by stopping
     resolution.  Unfortunately, the error signals that a DNS server
     can return are very limited, limited and are not very expressive. This
     means that applications and resolvers often have to "guess" at
     what the issue is - e.g. is, e.g., was the answer marked REFUSED because
     of a lame delegation, delegation or because the nameserver is still
     starting up and loading zones? Is a SERVFAIL a DNSSEC validation
     issue, or is the nameserver experiencing some other failure?
     What error messages should be presented to the user or logged
     under these conditions?</t>
     <t>A good example of issues that would benefit from additional
     error information are errors caused by DNSSEC validation
     issues. When a stub resolver queries a name which that is DNSSEC
     bogus <xref target="RFC8499" /> format="default"/> (using a validating resolver),
     the stub resolver receives only a SERVFAIL in
     response. Unfortunately, the SERVFAIL Response Code (RCODE) is
     used to signal many sorts of DNS errors, and so the stub
     resolver's only option is to ask the next configured DNS
     resolver. The result of trying the next resolver is one of two
     outcomes: either the next resolver also validates, validates and a
     SERVFAIL is returned again, again or the next resolver is not a
     validating resolver, resolver and the user is returned a potentially
     harmful result.  With an Extended DNS Error (EDE) option
     enclosed in the response message, the resolver is able to return
     a more descriptive reason as to why any failures happened, happened or
     add additional context to a message containing a NOERROR
     RCODE.</t>
     <t>This document specifies a mechanism to extend DNS errors to
     provide additional information about the cause of an error.
      These extended
     The Extended DNS error Error codes are described in this document
     can be used by any system that sends DNS queries and receives a
     response containing an EDE option. Different codes are useful
     in different circumstances, and thus different systems (stub
     resolvers, recursive resolvers, and authoritative resolvers)
     might receive and use them.</t>
     <section title="Requirements notation">
      <t>The numbered="true" toc="default">
       <name>Requirements Notation</name>
       <t>
   The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL
      NOT", "SHOULD", "SHOULD NOT", "RECOMMENDED", "NOT RECOMMENDED",
      "MAY", "<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 "OPTIONAL" "<bcp14>OPTIONAL</bcp14>" in this document are
   to be interpreted as described in BCP 14 BCP&nbsp;14 <xref target="RFC2119"/>
   <xref target="RFC8174"/> when, and only when, they appear in all capitals,
   as shown here.</t> here.
       </t>
     </section>
   </section>
   <section title="Extended numbered="true" toc="default">
     <name>Extended DNS Error EDNS0 option format"> Option Format</name>
     <t>This draft document uses an EDNS0 (<xref Extended Mechanism for DNS (EDNS0) <xref
     target="RFC6891" />) format="default"/> option to include
     Extended DNS Error (EDE) information in DNS messages. The option
     is structured as follows:</t>

      <figure>
     <artwork align="left"><![CDATA[ align="left" name="" type="" alt=""><![CDATA[
                                             1   1   1   1   1   1
     0   1   2   3   4   5   6   7   8   9   0   1   2   3   4   5
   +---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+
0: |                            OPTION-CODE                        |
   +---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+
2: |                           OPTION-LENGTH                       |
   +---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+
4: | INFO-CODE                                                     |
   +---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+
6: / EXTRA-TEXT ...                                                /
   +---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+---+
]]></artwork>
      </figure>
     <t/>
     <t>Field definition details:</t>

      <t><list style="symbols">
          <t>OPTION-CODE, 2-octets/16-bits
     <dl newline="true">
       <dt>OPTION-CODE: </dt>
	<dd>2 octets / 16 bits (defined in <xref target="RFC6891"
          />]), for EDE is TBD.
          [RFC Editor: change TBD to
	format="default"/>) contains the proper code once assigned by IANA.]</t>

          <t>OPTION-LENGTH, 2-octets/16-bits ((defined value 15 for EDE.</dd>

         <dt>OPTION-LENGTH: </dt>
	  <dd>2 octets / 16 bits (defined in <xref target="RFC6891" />]) format="default"/>) contains
         the length of the payload (everything after OPTION-LENGTH)
         in octets and should be 2 plus the length of the EXTRA-TEXT
         field (which may be a zero-length string).</t>

          <t>INFO-CODE, 16-bits, string).</dd>

         <dt>INFO-CODE:</dt>
	  <dd>16 bits, which is the principal contribution
         of this document.  This 16-bit value, encoded in network
         most significant bit (MSB) byte order, provides the additional context for the
         RESPONSE-CODE of the DNS message. The INFO-CODE serves as an
         index into the "Extended DNS Errors" registry registry, defined and
         created in <xref target="IANA" />.</t>

          <t>EXTRA-TEXT, a variable length, UTF-8 encoded format="default"/>.</dd>

         <dt>EXTRA-TEXT: </dt>
	  <dd>a variable-length, UTF-8-encoded <xref target="RFC5198" />,
	  format="default"/> text field that may hold additional
         textual information. This information is intended for human
         consumption (not automated parsing).  EDE text may be null
         terminated but MUST NOT <bcp14>MUST NOT</bcp14> be assumed to be; the length MUST <bcp14>MUST</bcp14> be
         derived from the OPTION-LENGTH field. The EXTRA-TEXT field
         may be zero octets in length, indicating that there is no
         EXTRA-TEXT included.  Care should be taken not to include
         private information in the EXTRA-TEXT field that an observer
         would not otherwise have access to, such as account
          numbers.</t>
        </list></t>
         numbers.</dd>
	</dl>

     <t>The Extended DNS Error (EDE) option can be included in any
     response (SERVFAIL, NXDOMAIN, REFUSED, and even NOERROR, etc) etc.) to
     a query that includes an OPT Pseudo-RR pseudo-RR <xref target="RFC6891" />. format="default"/>.
     This document includes a set of initial codepoints, codepoints but is
     extensible via the IANA registry defined and created in <xref target="IANA" />.</t> format="default"/>.</t>
   </section>
   <section title="Extended numbered="true" toc="default">
     <name>Extended DNS Error Processing"> Processing</name>
     <t>When the response grows beyond the requestor's UDP payload
     size <xref target="RFC6891" />, format="default"/>, servers SHOULD <bcp14>SHOULD</bcp14> truncate messages
     by dropping EDE options before dropping other data from packets.
     Implementations SHOULD <bcp14>SHOULD</bcp14> set the truncation bit when dropping EDE
     options.  Because long EXTRA-TEXT fields may trigger truncation
     (which is undesirable given the supplemental nature of
      EDE)
     EDE), implementers and operators creating EDE options SHOULD <bcp14>SHOULD</bcp14>
     avoid lengthy EXTRA-TEXT contents.</t>
     <t>When a resolver or forwarder receives an EDE option, whether
     or not (and how) to pass along EDE information on to their
     original client is implementation dependent. Implementations MAY <bcp14>MAY</bcp14>
     choose to not forward information, or they MAY <bcp14>MAY</bcp14> choose to create
     a new EDE option(s) that conveys the information encoded in the
     received EDE.  When doing so, the source of the error SHOULD <bcp14>SHOULD</bcp14> be
     attributed in the EXTRA-TEXT field, since an EDNS0 option
     received by the original client will appear to have come from
     the resolver or forwarder sending it.</t>
     <t>This document does not allow or prohibit any particular
     extended error codes and information to be matched with any
     particular RCODEs. Some combinations of extended error codes and
     RCODEs may seem nonsensical (such as resolver-specific extended
     error codes received in responses from authoritative servers), so systems
     interpreting the extended error codes MUST NOT <bcp14>MUST NOT</bcp14> assume that a
     combination will make sense.  Receivers MUST <bcp14>MUST</bcp14> be able to accept
     EDE codes and EXTRA-TEXT in all messages, including those with a
     NOERROR RCODE, RCODE but need not act on them.  Applications MUST <bcp14>MUST</bcp14>
     continue to follow requirements from applicable specifications on how to
     process RCODEs no matter what EDE values are also received.
     Senders MAY <bcp14>MAY</bcp14> include more than one EDE option and receivers MUST <bcp14>MUST</bcp14>
     be able to accept (but not necessarily process or act on)
     multiple EDE options in a DNS message.</t>
   </section>
   <section title="Defined numbered="true" toc="default">
     <name>Defined Extended DNS Errors"> Errors</name>
     <t>This document defines some initial EDE codes. The mechanism
     is intended to be extensible, and additional code-points codepoints can be
     registered in the "Extended DNS Errors" registry <xref (<xref target="IANA" />.
     format="default"/>).  The INFO-CODE from the EDE EDNS option is
     used to serve as an index into the "Extended DNS Error" IANA
     registry, the initial values for which are defined in the
     following sub-sections.</t> subsections.</t>
     <section anchor="errother" title="Extended numbered="true" toc="default">
       <name>Extended DNS Error Code 0 - Other"> Other</name>
       <t>The error in question falls into a category that does
	      not match known extended error codes.  Implementations
	      SHOULD
	      <bcp14>SHOULD</bcp14> include an EXTRA-TEXT value to augment this error
	      code with additional information.</t>
     </section>
     <section anchor="errbaddnskeyalg"
                 title="Extended numbered="true" toc="default">
       <name>Extended DNS Error Code 1 - Unsupported DNSKEY Algorithm"> Algorithm</name>
       <t>The resolver attempted to perform DNSSEC validation, but a DNSKEY
          RRSET
         RRset contained only unsupported DNSSEC algorithms.</t>
     </section>
     <section anchor="errbaddsdigest"
                 title="Extended numbered="true" toc="default">
       <name>Extended DNS Error Code 2 - Unsupported DS Digest Type"> Type</name>
       <t>The resolver attempted to perform DNSSEC validation, but a DS
          RRSET
         RRset contained only unsupported Digest Types.</t>
     </section>
     <section anchor="stalenoerror"
	         title="Extended numbered="true" toc="default">
       <name>Extended DNS Error Code 3 - Stale Answer"> Answer</name>
       <t>The resolver was unable to resolve the answer within its
         time limits and decided to answer with previously cached
         data instead of answering with an error.  This is typically
         caused by problems communicating with an authoritative
         server, possibly as result of a denial of service (DoS)
         attack against another network. (See also Code 19.)</t>
     </section>
     <section anchor="forgedanswer"
                 title="Extended numbered="true" toc="default">
       <name>Extended DNS Error Code 4 - Forged Answer"> Answer</name>
       <t>For policy reasons (legal obligation, obligation or malware
         filtering, for instance), an answer was forged.  Note that
         this should be used when an answer is still provided, not
         when failure codes are returned instead.  See Blocked(15), Blocked (15),
         Censored (16), and Filtered (17) for use when returning
         other response codes.</t>
     </section>
     <section anchor="errindeterminate"
                 title="Extended numbered="true" toc="default">
       <name>Extended DNS Error Code 5 - DNSSEC Indeterminate"> Indeterminate</name>
       <t>The resolver attempted to perform DNSSEC validation, but
         validation ended in the Indeterminate state <xref target="RFC4035" />.</t> format="default"/>.</t>
     </section>
     <section anchor="errbogus"
                 title="Extended numbered="true" toc="default">
       <name>Extended DNS Error Code 6 - DNSSEC Bogus"> Bogus</name>
       <t>The resolver attempted to perform DNSSEC validation, but
         validation ended in the Bogus state.</t>
     </section>
     <section anchor="errexpired"
                 title="Extended numbered="true" toc="default">
       <name>Extended DNS Error Code 7 - Signature Expired"> Expired</name>
       <t>The resolver attempted to perform DNSSEC validation, but
         no signatures are presently valid and some (often all) are
         expired.</t>
     </section>
     <section anchor="errprior"
                 title="Extended numbered="true" toc="default">
       <name>Extended DNS Error Code 8 - Signature Not Yet Valid"> Valid</name>
       <t>The resolver attempted to perform DNSSEC validation, but
          but
         no signatures are presently valid and at least some are
         not yet valid.</t>
     </section>
     <section anchor="errnodnskey"
                 title="Extended numbered="true" toc="default">
       <name>Extended DNS Error Code 9 - DNSKEY Missing"> Missing</name>
       <t>A DS record existed at a parent, but no supported
         matching DNSKEY record could be found for the child.</t>
     </section>
     <section anchor="errnorrsig"
                 title="Extended numbered="true" toc="default">
       <name>Extended DNS Error Code 10 - RRSIGs Missing"> Missing</name>
       <t>The resolver attempted to perform DNSSEC validation, but no
         RRSIGs could be found for at least one RRset where RRSIGs were
         expected.</t>
     </section>
     <section anchor="errnozonekey"
                 title="Extended numbered="true" toc="default">
       <name>Extended DNS Error Code 11 - No Zone Key Bit Set"> Set</name>
       <t>The resolver attempted to perform DNSSEC validation, but no Zone
         Key Bit was set in a DNSKEY.</t>
     </section>
     <section anchor="nonsec"
                 title="Extended numbered="true" toc="default">
       <name>Extended DNS Error Code 12 - NSEC Missing"> Missing</name>
       <t>The resolver attempted to perform DNSSEC validation, but
         the requested data was missing and a covering NSEC or NSEC3
         was not provided.</t>
     </section>
     <section anchor="cachederror"
                 title="Extended numbered="true" toc="default">
       <name>Extended DNS Error Code 13 - Cached Error"> Error</name>
       <t>The resolver is returning the SERVFAIL RCODE from its cache.</t>
     </section>
     <section anchor="notready"
                 title="Extended numbered="true" toc="default">
       <name>Extended DNS Error Code 14 - Not Ready"> Ready</name>
       <t>The server is unable to answer the query query, as it was not
         fully functional when the query was received.</t>
     </section>
     <section anchor="errblocked"
	         title="Extended numbered="true" toc="default">
       <name>Extended DNS Error Code 15 - Blocked"> Blocked</name>
       <t>The server is unable to respond to the request because
         the domain is blacklisted on a blocklist due to an internal security policy
         imposed by the operator of the server resolving or forwarding
         the query.</t>
     </section>
     <section anchor="errcensored"
	         title="Extended numbered="true" toc="default">
       <name>Extended DNS Error Code 16 - Censored"> Censored</name>
       <t>The server is unable to respond to the request because
         the domain is blacklisted on a blocklist due to an external requirement
         imposed by an entity other than the operator of the server
         resolving or forwarding the query. Note that how the imposed
         policy is applied is irrelevant (in-band DNS filtering,
         court order, etc).</t> etc.).</t>
     </section>
     <section anchor="errfiltered"
	         title="Extended numbered="true" toc="default">
       <name>Extended DNS Error Code 17 - Filtered"> Filtered</name>
       <t>The server is unable to respond to the request because
         the domain is blacklisted on a blocklist as requested by the client.
         Functionally, this amounts to "you requested that we filter
         domains like this one."</t>
     </section>
     <section anchor="errprohibted"
	         title="Extended numbered="true" toc="default">
       <name>Extended DNS Error Code 18 - Prohibited"> Prohibited</name>
       <t>An authoritative server or recursive resolver that receives a query from
         an "unauthorized" client can annotate its REFUSED message with this
         code. Examples of "unauthorized" clients are recursive queries from
         IP addresses outside the network, blacklisted blocklisted IP addresses, local
         policy, etc.</t>
     </section>
     <section anchor="stalenx"
	         title="Extended numbered="true" toc="default">
       <name>Extended DNS Error Code 19 - Stale NXDOMAIN Answer"> Answer</name>
       <t>The resolver was unable to resolve an answer within its
         configured time limits and decided to answer with a
         previously cached NXDOMAIN answer instead of answering with
         an error. This may be caused, for example, by problems
         communicating with an authoritative server, possibly as
         result of a denial of service (DoS) attack against another
         network. (See also Code 3.) </t>
     </section>
     <section anchor="errlame"
	         title="Extended numbered="true" toc="default">
       <name>Extended DNS Error Code 20 - Not Authoritative"> Authoritative</name>
       <t>An authoritative server that receives a query with the RD Recursion
	Desired (RD) bit clear,
        or when it is not configured for recursion for a domain for which it is
        not authoritative SHOULD authoritative, <bcp14>SHOULD</bcp14> include this EDE code in the REFUSED
        response.  A resolver that receives a query with the RD bit clear
         SHOULD
        <bcp14>SHOULD</bcp14> include this EDE code in the REFUSED response.</t>
     </section>
     <section anchor="deprecated"
	         title="Extended numbered="true" toc="default">
       <name>Extended DNS Error Code 21 - Not Supported"> Supported</name>
       <t>The requested operation or query is not supported.</t>
     </section>
     <section anchor="noreachable"
                 title="Extended numbered="true" toc="default">
       <name>Extended DNS Error Code 22 - No Reachable Authority"> Authority</name>
       <t>The resolver could not reach any of the authoritative name servers
         (or they potentially refused to reply).</t>
     </section>
     <section anchor="networkerror"
                 title="Extended numbered="true" toc="default">
       <name>Extended DNS Error Code 23 - Network Error"> Error</name>
       <t>An unrecoverable error occurred while communicating with
         another server.</t>
     </section>
     <section anchor="invaliddata"
                 title="Extended numbered="true" toc="default">
       <name>Extended DNS Error Code 24 - Invalid Data"> Data</name>
       <t>The authoritative server cannot answer with data for
         a zone it is otherwise configured to support.  Examples of
         this include its most recent zone being too old, old or having
         expired.</t>
     </section>
   </section>
   <section title="IANA Considerations">
      <section title="A numbered="true" toc="default">
     <name>IANA Considerations</name>
     <section numbered="true" toc="default">
       <name>A New Extended DNS Error Code EDNS Option"> Option</name>
       <t>This document defines a new EDNS(0) option, entitled
       "Extended DNS Error", with the assigned a value of TBD 15 from the "DNS
       EDNS0 Option Codes (OPT)" registry [to be removed upon
        publication:
        [http://www.iana.org/assignments/dns-parameters/dns-parameters.xhtml#dns-parameters-11]</t>

        <t><figure>
            <artwork><![CDATA[Value registry:
	</t>

       <table anchor="ext-DNS">
	<thead>
	<tr>
	<th> Value </th>
	<th> Name </th>
	<th> Status </th>
	<th> Reference
-----  ----------------     ------    ------------------
 TBD   Extended DNS Error    Standard       [ This document ]]]></artwork>
          </figure></t>
      </section>

      <section title="New </th>
	</tr>
	</thead>

	<tbody>
	<tr>
	<td>15</td>
	<td>Extended DNS Error</td>
	<td>Standard</td>
	<td>RFC 8914</td>
     </tr>
	</tbody>

	</table>
     </section>
     <section anchor="IANA" numbered="true" toc="default">
       <name>New Registry for Extended DNS Error Codes" anchor="IANA"> Codes</name>
       <t>IANA is requested to create has created and will maintain a new registry
        table
       called "Extended DNS Error Codes" on the "Domain Name
       System (DNS) Parameters" web page as follows:</t>

        <t>Registry Name: Extended DNS Error Codes</t>
        <t>Registration Procedures:</t>
        <t><list style="symbols">
            <t>0

<table anchor="reg_proc">
 <thead>
   <tr>
     <th>Range</th>
     <th>Registration Procedures</th>
   </tr>
 </thead>
 <tbody>
   <tr>
     <td>0 - 49151: 49151</td><td>First Come First come, first served.</t>
            <t>49152 - 65535: Private use.</t>
        </list></t>
        <t>Reference: [this document]</t> Served</td>
   </tr>
   <tr>
     <td>49152 - 65535</td><td>Private Use</td>
   </tr>
 </tbody>
</table>

       <t>The Extended "Extended DNS Error Codes Codes" registry is a table with
       three columns: INFO-CODE, Purpose, and Reference. The initial
        contents
       content is as below with [this document] added to
        each reference given.</t>

    <t><list style="hanging" hangIndent="10">
    <t hangText="INFO-CODE:">0</t>
    <t hangText="Purpose:">Other Error</t>
    <t hangText="Reference:"><xref below.</t>
       <table>
	    <thead>
	      <tr>
		<th>INFO-CODE </th>
		<th>Purpose </th>
		<th>Reference </th>
	      </tr>
	    </thead>
	    <tbody>
	      <tr>
		<td> 0 </td>
		<td> Other Error</td>
		<td>  <xref target="errother" /></t>
    </list></t>

    <t><list style="hanging" hangIndent="10">
    <t hangText="INFO-CODE:">1</t>
    <t hangText="Purpose:">Unsupported format="default"/> </td>
	      </tr>
	      <tr>
		<td> 1  </td>
		<td align="center"> Unsupported DNSKEY Algorithm</t>
    <t hangText="Reference:"><xref Algorithm  </td>
		<td>  <xref target="errbaddnskeyalg" /></t>
    </list></t>

    <t><list style="hanging" hangIndent="10">
    <t hangText="INFO-CODE:">2</t>
    <t hangText="Purpose:">Unsupported format="default"/>  </td>
	      </tr>
	       <tr>
		<td> 2  </td>
		<td>Unsupported DS Digest Type</t>
    <t hangText="Reference:"><xref Type </td>
		<td> <xref target="errbaddsdigest" /></t>
    </list></t>

    <t><list style="hanging" hangIndent="10">
    <t hangText="INFO-CODE:">3</t>
    <t hangText="Purpose:">Stale Answer</t>
    <t hangText="Reference:"><xref format="default"/>  </td>
	       </tr>
	        <tr>
		<td> 3  </td>
		<td> Stale Answer  </td>
		<td>  <xref target="stalenoerror" />, format="default"/> and
   <xref target="RFC8767" /></t>
    </list></t>

    <t><list style="hanging" hangIndent="10">
    <t hangText="INFO-CODE:">4</t>
    <t hangText="Purpose:">Forged Answer</t>
    <t hangText="Reference:"><xref format="default"/>  </td>
		</tr>
		 <tr>
		<td> 4  </td>
		<td> Forged Answer  </td>
		<td>  <xref target="forgedanswer" /></t>
    </list></t>

    <t><list style="hanging" hangIndent="10">
    <t hangText="INFO-CODE:">5</t>
    <t hangText="Purpose:">DNSSEC Indeterminate</t>
    <t hangText="Reference:"><xref format="default"/>  </td>
		 </tr>
		  <tr>
		<td> 5  </td>
		<td> DNSSEC Indeterminate  </td>
		<td> <xref target="errindeterminate" /></t>
    </list></t>

    <t><list style="hanging" hangIndent="10">
    <t hangText="INFO-CODE:">6</t>
    <t hangText="Purpose:">DNSSEC Bogus</t>
    <t hangText="Reference:"><xref format="default"/>  </td>
		  </tr>
		   <tr>
		<td> 6  </td>
		<td>DNSSEC Bogus </td>
		<td>  <xref target="errbogus" /></t>
    </list></t>

    <t><list style="hanging" hangIndent="10">
    <t hangText="INFO-CODE:">7</t>
    <t hangText="Purpose:">Signature Expired</t>
    <t hangText="Reference:"><xref format="default"/>   </td>
		   </tr>
		    <tr>
		<td> 7  </td>
		<td> Signature Expired  </td>
		<td>  <xref target="errexpired" /></t>
    </list></t>

    <t><list style="hanging" hangIndent="10">
    <t hangText="INFO-CODE:">8</t>
    <t hangText="Purpose:">Signature format="default"/>   </td>
		    </tr>
		    <tr>
		      <td>8 </td>
		      <td>Signature Not Yet Valid</t>
    <t hangText="Reference:"><xref Valid </td>
		      <td> <xref target="errprior" /></t>
    </list></t>

    <t><list style="hanging" hangIndent="10">
    <t hangText="INFO-CODE:">9</t>
    <t hangText="Purpose:">DNSKEY Missing</t>
    <t hangText="Reference:"> format="default"/> </td>
		    </tr>
		       <tr>
		      <td>9 </td>
		      <td>DNSKEY Missing </td>
		      <td> <xref target="errnodnskey" /></t>
    </list></t>

    <t><list style="hanging" hangIndent="10">
    <t hangText="INFO-CODE:">10</t>
    <t hangText="Purpose:">RRSIGs Missing</t>
    <t hangText="Reference:"><xref format="default"/> </td>
		       </tr>
		          <tr>
		      <td>10 </td>
		      <td>RRSIGs Missing </td>
		      <td> <xref target="errnorrsig" /></t>
    </list></t>

    <t><list style="hanging" hangIndent="10">
    <t hangText="INFO-CODE:">11</t>
    <t hangText="Purpose:">No format="default"/> </td>
			  </tr>
			     <tr>
		      <td>11 </td>
		      <td>No Zone Key Bit Set</t>
    <t hangText="Reference:"><xref Set </td>
		      <td> <xref target="errnozonekey" /></t>
    </list></t>

    <t><list style="hanging" hangIndent="10">
    <t hangText="INFO-CODE:">12</t>
    <t hangText="Purpose:">NSEC Missing</t>
    <t hangText="Reference:"><xref format="default"/> </td>
			     </tr>
			        <tr>
		      <td>12 </td>
		      <td>NSEC Missing </td>
		      <td> <xref target="nonsec" /></t>
    </list></t>

    <t><list style="hanging" hangIndent="10">
    <t hangText="INFO-CODE:">13</t>
    <t hangText="Purpose:">Cached Error</t>
    <t hangText="Reference:"><xref format="default"/> </td>
				</tr>
				   <tr>
		      <td>13 </td>
		      <td>Cached Error </td>
		      <td> <xref target="cachederror" /></t>
    </list></t>

    <t><list style="hanging" hangIndent="10">
    <t hangText="INFO-CODE:">14</t>
    <t hangText="Purpose:">Not Ready.</t>
    <t hangText="Reference:"><xref format="default"/> </td>
				   </tr>
				      <tr>
		      <td>14 </td>
		      <td>Not Ready</td>
		      <td> <xref target="notready" /></t>
    </list></t>

    <t><list style="hanging" hangIndent="10">
    <t hangText="INFO-CODE:">15</t>
    <t hangText="Purpose:">Blocked</t>
    <t hangText="Reference:"><xref format="default"/> </td>
				      </tr>
				         <tr>
		      <td>15 </td>
		      <td>Blocked </td>
		      <td> <xref target="errblocked" /></t>
    </list></t>

    <t><list style="hanging" hangIndent="10">
    <t hangText="INFO-CODE:">16</t>
    <t hangText="Purpose:">Censored</t>
    <t hangText="Reference:"><xref format="default"/> </td>
		     </tr>
			<tr>
			<td>16 </td>
		      <td>Censored </td>
		      <td> <xref target="errcensored" /></t>
    </list></t>

    <t><list style="hanging" hangIndent="10">
    <t hangText="INFO-CODE:">17</t>
    <t hangText="Purpose:">Filtered</t>
    <t hangText="Reference:"><xref format="default"/> </td>
			</tr>
		       <tr>
			<td>17 </td>
		      <td>Filtered </td>
		      <td> <xref target="errfiltered" /></t>
    </list></t>

    <t><list style="hanging" hangIndent="10">
    <t hangText="INFO-CODE:">18</t>
    <t hangText="Purpose:">Prohibited</t>
    <t hangText="Reference:"><xref format="default"/> </td>
		      </tr>
			 <tr>
		      <td>18 </td>
		      <td>Prohibited </td>
		      <td> <xref target="errprohibted" /></t>
    </list></t>

    <t><list style="hanging" hangIndent="10">
    <t hangText="INFO-CODE:">19</t>
    <t hangText="Purpose:">Stale format="default"/> </td>
			</tr>
			 <tr>
		      <td>19 </td>
		      <td>Stale NXDomain Answer</t>
    <t hangText="Reference:"><xref Answer </td>
		      <td> <xref target="stalenx" /></t>
    </list></t>

    <t><list style="hanging" hangIndent="10">
    <t hangText="INFO-CODE:">20</t>
    <t hangText="Purpose:">Not Authoritative</t>
    <t hangText="Reference:"><xref format="default"/> </td>
			 </tr>
			 <tr>
		      <td>20 </td>
		      <td>Not Authoritative </td>
		      <td> <xref target="errlame" /></t>
    </list></t>

    <t><list style="hanging" hangIndent="10">
    <t hangText="INFO-CODE:">21</t>
    <t hangText="Purpose:">Not Supported</t>
    <t hangText="Reference:"><xref format="default"/> </td>
			 </tr>
			  <tr>
		       <td>21 </td>
		      <td>Not Supported </td>
		      <td><xref target="deprecated" /></t>
    </list></t>

    <t><list style="hanging" hangIndent="10">
    <t hangText="INFO-CODE:">22</t>
    <t hangText="Purpose:">No format="default"/> </td>
			  </tr>

			  <tr>
		       <td>22 </td>
		      <td>No Reachable Authority</t>
    <t hangText="Reference:"><xref Authority </td>
		      <td> <xref target="noreachable" /></t>
    </list></t>

    <t><list style="hanging" hangIndent="10">
    <t hangText="INFO-CODE:">23</t>
    <t hangText="Purpose:">Network Error</t>
    <t hangText="Reference:"><xref format="default"/> </td>
			  </tr>

			  <tr>
		       <td>23 </td>
		      <td>Network Error </td>
		      <td> <xref target="networkerror" /></t>
    </list></t>

    <t><list style="hanging" hangIndent="10">
    <t hangText="INFO-CODE:">24</t>
    <t hangText="Purpose:">Invalid Data</t>
    <t hangText="Reference:"><xref format="default"/> </td>
			  </tr>

			  <tr>
		       <td>24 </td>
		      <td>Invalid Data </td>
		      <td> <xref target="invaliddata" /></t>
    </list></t>

    <t><list style="hanging" hangIndent="10">
    <t hangText="INFO-CODE:">25-65535</t>
    <t hangText="Purpose:">Unassigned</t>
    <t hangText="Reference:"><xref target="IANA" /></t>
    </list></t> format="default"/> </td>
			  </tr>

			  <tr>
		       <td>25-49151</td>
		      <td>Unassigned</td>
		      <td></td>
			  </tr>
			  <tr>
			    <td>49152-65535</td>
			    <td>Reserved for Private Use</td>
			    <td><xref target="IANA"/></td>
			  </tr>
	    </tbody>
	</table>

     </section>
   </section>
   <section anchor="security" title="Security Considerations"> numbered="true" toc="default">
     <name>Security Considerations</name>
     <t>Though DNSSEC continues to be deployed, unfortunately a
     significant number of clients (~11% according to <xref
      target="GeoffValidation"/>) target="GeoffValidation" format="default"/>) that receive a SERVFAIL from a
     validating resolver because of a DNSSEC validation issue will
     simply ask the next (potentially non-validating) resolver in
     their list, list and thus don't get the protections which that
     DNSSEC should provide.</t>
     <t>EDE information is unauthenticated information, unless
     secured by a form of secured DNS transaction transaction, such as <xref
      target="RFC2845"/>,
     target="RFC2845" format="default"/>, <xref target="RFC2931"/>, target="RFC2931"
     format="default"/>, <xref
      target="RFC8094"/> target="RFC8094" format="default"/>, or <xref
     target="RFC8484" />. format="default"/>. An attacker (e.g (e.g., a MITM man in the
     middle (MITM) or malicious
     recursive server) could insert an extended error response into
     untrusted data &mdash; although ideally -- although, ideally, clients and resolvers
     would not trust any unauthenticated information.  As such, EDE
     content should be treated only as diagnostic information and
      MUST NOT
     <bcp14>MUST NOT</bcp14> alter DNS protocol processing.  Until all DNS answers
     are authenticated via DNSSEC or the other mechanisms mentioned
     above, there are some tradeoffs. trade-offs. As an example, an attacker who
     is able to insert the DNSSEC Bogus Extended Error into a DNS
     message could instead simply reply with a fictitious address (A
     or AAAA) record.  Note that DNS Response Codes (RCODEs) RCODEs also
     contain no authentication and can be just as easily manipulated.
     </t>
     <t>By design, EDE potentially exposes additional information
     via DNS resolution processes that may leak information.

     An example
     of this is the Prohibited EDE code (18), which may leak the fact
     that the name is on a blacklist.</t> blocklist.</t>
   </section>
 </middle>
 <back>
   <references>
     <name>References</name>
     <references>
       <name>Normative References</name>
       <xi:include href="https://xml2rfc.tools.ietf.org/public/rfc/bibxml/reference.RFC.2119.xml"/>
       <xi:include href="https://xml2rfc.tools.ietf.org/public/rfc/bibxml/reference.RFC.4035.xml"/>
       <xi:include href="https://xml2rfc.tools.ietf.org/public/rfc/bibxml/reference.RFC.5198.xml"/>
       <xi:include href="https://xml2rfc.tools.ietf.org/public/rfc/bibxml/reference.RFC.6891.xml"/>
       <xi:include href="https://xml2rfc.tools.ietf.org/public/rfc/bibxml/reference.RFC.8174.xml"/>
       <xi:include href="https://xml2rfc.tools.ietf.org/public/rfc/bibxml/reference.RFC.8499.xml"/>
       <xi:include href="https://xml2rfc.tools.ietf.org/public/rfc/bibxml/reference.RFC.8767.xml"/>
     </references>
     <references>
       <name>Informative References</name>
       <xi:include href="https://xml2rfc.tools.ietf.org/public/rfc/bibxml/reference.RFC.2845.xml"/>
       <xi:include href="https://xml2rfc.tools.ietf.org/public/rfc/bibxml/reference.RFC.2931.xml"/>
       <xi:include href="https://xml2rfc.tools.ietf.org/public/rfc/bibxml/reference.RFC.8094.xml"/>
       <xi:include href="https://xml2rfc.tools.ietf.org/public/rfc/bibxml/reference.RFC.8484.xml"/>

       <reference anchor="GeoffValidation" target="http://www.potaroo.net/presentations/2016-06-27-dnssec.pdf">
         <front>
           <title abbrev="Validation today">A quick review of DNSSEC Validation
         in today's Internet</title>
           <author initials="G" surname="Huston" fullname="Geoff Huston">
             <organization>APNIC</organization>
           </author>
           <date month="June" year="2016"/>
         </front>
       </reference>
     </references>
   </references>
   <section title="Acknowledgements"> numbered="false" toc="default">
     <name>Acknowledgements</name>

     <t>The authors wish to thank <contact fullname=" Joe Abley, Mark Andrews, Tim April,
      Vittorio Bertola, Stephane Bortzmeyer, Vladimir Cunat, Ralph
      Dolmans, Peter DeVries, Peter Abley"/>, <contact
     fullname="Mark Andrews"/>, <contact fullname="Tim April"/>, <contact
     fullname="Vittorio Bertola"/>, <contact fullname="Stephane
     Bortzmeyer"/>, <contact fullname="Vladimir Cunat"/>, <contact
     fullname="Ralph Dolmans"/>, <contact fullname="Peter DeVries"/>,
     <contact fullname="Peter van Dijk, Mats Dufberg, Dijk"/>, <contact fullname="Mats
     Dufberg"/>, <contact fullname=" Donald
      Eastlake, Bob Harold, Paul Hoffman, Geoff Huston, Eastlake"/>, <contact
     fullname="Bob Harold"/>, <contact fullname="Paul Hoffman"/>, <contact
     fullname="Geoff Huston"/>, <contact fullname=" Shane Kerr,
      Edward Lewis, Carlos Kerr"/>, <contact
     fullname="Edward Lewis"/>, <contact fullname="Carlos M.  Martinez, George Michelson, Eric Orth,
      Michael Sheldon, Puneet Sood, Petr Spacek, Martinez"/>,
     <contact fullname="George Michelson"/>, <contact fullname="Eric Orth"/>,
     <contact fullname="Michael Sheldon"/>, <contact fullname="Puneet
     Sood"/>, <contact fullname="Petr Spacek"/>, <contact fullname=" Ondrej Sury, John
      Todd, Loganaden Velvindron, and Paul Vixie.
     Sury"/>, <contact fullname="John Todd"/>, <contact fullname="Loganaden
     Velvindron"/>, and <contact fullname="Paul Vixie"/>.  They also vaguely
     remember discussing this with a number of people over the years, years but have
     forgotten who all they were -- if you were one of them,
      and are not listed, please let us know and we'll them were. Apologies if we forgot to acknowledge
      you.</t>
     your contributions.</t>

     <t>One author also wants to thank the band "Infected Mushroom" Infected Mushroom
     for providing a good background soundtrack (and to see if he can
     get away with this in an RFC!). Another author would like to
     thank the band "Mushroom Infectors". Mushroom Infectors. This was funny at the time
     we wrote it, but we cannot remember why...</t>
      </section>
  </middle>

  <back>
    <references title="Normative References">
      <?rfc include='reference.RFC.2119' ?>
      <?rfc include='reference.RFC.4035' ?>
      <?rfc include='reference.RFC.5198' ?>
      <?rfc include='reference.RFC.6891' ?>
      <?rfc include='reference.RFC.8174' ?>
      <?rfc include='reference.RFC.8499' ?>
      <?rfc include='reference.RFC.8767' ?>
    </references>

    <references title="Informative References">
      <?rfc include='reference.RFC.2845' ?>
      <?rfc include='reference.RFC.2931' ?>
      <?rfc include='reference.RFC.8094' ?>
      <?rfc include='reference.RFC.8484' ?>

      <reference anchor="GeoffValidation"
                 target="http://www.potaroo.net/presentations/2016-06-27-dnssec.pdf">
        <front>
          <title abbrev="Validation today">A quick review of DNSSEC Validation
          in today&rsquo;s Internet</title>

          <author fullname="Geoff Huston, APNIC">
            <organization>IANA</organization>
          </author>

          <date month="June" year="2016"/>
        </front>
      </reference>
    </references>
 </back>
</rfc>