<?xml version="1.0" encoding="UTF-8"?>
  <?xml-stylesheet type="text/xsl" href="rfc2629.xslt" ?>
  <!-- generated by https://github.com/cabo/kramdown-rfc version 1.7.19 (Ruby 2.6.10) -->


<!DOCTYPE rfc  [
  <!ENTITY nbsp    "&#160;">
  <!ENTITY zwsp   "&#8203;">
  <!ENTITY nbhy   "&#8209;">
  <!ENTITY wj     "&#8288;">

]>


<rfc ipr="trust200902" docName="draft-ietf-dkim-dkim2-spec-03" category="std" consensus="true" submissionType="IETF" tocInclude="true" sortRefs="true" symRefs="true">
  <front>
    <title abbrev="DKIM2 Signatures">DomainKeys Identified Mail Signatures v2 (DKIM2)</title>

    <author initials="R." surname="Clayton" fullname="Richard Clayton">
      <organization>Yahoo</organization>
      <address>
        <email>rclayton@yahooinc.com</email>
      </address>
    </author>
    <author initials="W." surname="Chuang" fullname="Wei Chuang">
      <organization>Google</organization>
      <address>
        <email>weihaw@google.com</email>
      </address>
    </author>
    <author initials="B." surname="Gondwana" fullname="Bron Gondwana">
      <organization>Fastmail Pty Ltd</organization>
      <address>
        <postal>
          <street>Level 2, 114 William Street</street>
          <code>3000</code>
          <country>Australia</country>
        </postal>
        <phone>+61 457 416 436</phone>
        <email>brong@fastmailteam.com</email>
      </address>
    </author>

    <date year="2026" month="June" day="24"/>

    
    
    <keyword>Internet-Draft</keyword>

    <abstract>


<?line 63?>

<t>DomainKeys Identified Mail v2 (DKIM2) permits a person, role, or
organization that owns a signing domain to document that it has
handled an email message by associating their domain with the
message.  This is achieved by providing a hash value that has
been calculated on the current contents of the message and then applying a cryptographic
signature that covers the hash values and other details about the
transmission of the message. Verification is performed by querying an entry
within the signing domain's DNS space to retrieve an appropriate public
key. As a message is transferred from author to recipient systems that
alter the body or header fields will provide details of their changes
and calculate new hash values. Further signatures 
will be added to provide a validatable "chain". This permits validators
to identify the nature of changes made by intermediaries and apply a
reputation to the systems that made changed. DKIM2 also allows
recipients to detect when messages have been unexpectedly "replayed"
and will ensure that Delivery Status Notifications are only sent
to entities that were involved in the transmission of a message.</t>



    </abstract>



  </front>

  <middle>


<?line 83?>

<section anchor="introduction"><name>Introduction</name>

<t>DomainKeys Identified Mail v2 (DKIM2) permits a person, role, or
organization to document that they have handled an email message by
associating a domain name <xref target="RFC1034"></xref> with the message <xref target="RFC5322"></xref>. A
public key signature is used to record that they have been able
to read the contents of the message and write to it.</t>

<t>Verification of claims is achieved by fetching a public key stored
in the DNS under the relevant domain and then checking the signature.</t>

<t>Message transit from author to recipient is through
Forwarders that typically make no substantive change to the message
content and thus preserve the DKIM2 signature. Where they do make
a change the changes they have made are documented so that
these can be "undone" and the original signature validated.</t>

<t>When a message is forwarded from one system to another an
additional DKIM2 signature is added on each occasion. This chain
of custody assists validators in distinguishing between messages that
were intended to be sent to a particular email address and those
that are being "replayed" to that address.</t>

<t>The chain of custody can also be used to ensure that delivery status
notifications are only sent to entities that were involved in the
transmission of a message.</t>

<t>Organizations that process a message can add to their signature
a request for feedback as to any opinion (for example, that the
email was considered to be spam) that the eventual recipient of
the message wishes to share.</t>

<section anchor="dkim2-architecture-documents"><name>DKIM2 Architecture Documents</name>

<t>Readers are advised to be familiar with the material in TBA, TBA and TBA
which provide the background for the development of DKIM2, an overview
of the service, and deployment and operations guidance and advice.</t>

</section>
</section>
<section anchor="terminology-and-definitions"><name>Terminology and Definitions</name>

<t>This section defines terms used in the rest of the document.</t>

<t>The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT",
"SHOULD", "SHOULD NOT", "RECOMMENDED", "NOT RECOMMENDED", "MAY", and
"OPTIONAL" in this document are to be interpreted as described in
<xref target="RFC2119"></xref>.  These words take their normative meanings only when they
are presented in ALL UPPERCASE.</t>

<t>DKIM2 is designed to operate within the Internet Mail service, as
defined in <xref target="RFC5598"></xref>.  Basic email terminology is taken from that
specification.</t>

<t>DKIM2 inherits many ideas from DKIM (<xref target="RFC6376"></xref>) which, for clarity
we refer to in this specification as DKIM1. In addition, some features
were influenced by experience with (see <xref target="CONCLUDEARC"></xref>) the experimental
ARC protocol (<xref target="RFC8617"></xref>).</t>

<t>Syntax descriptions use Augmented BNF (ABNF) <xref target="RFC5234"></xref>.</t>

<t>This document uses JSON <xref target="RFC8259"></xref> to encode the "recipes" which
record changes made to a message header fields or body.
The JSON objects are then base64 encoded. This means that a
standard JSON parser can be used to create what may be quite
complex data structures. Unrecognised fields within JSON objects
MUST be ignored.</t>

<section anchor="signer"><name>Signer</name>

<t>Elements in the mail system that sign messages on behalf of a domain
are referred to as Signers.  These may be MUAs (Mail User Agents),
MSAs (Mail Submission Agents), MTAs (Mail Transfer Agents), or other
agents such as mailing list "exploders".  In general, any Signer will
be involved in the injection of a message into the message system in
some way.  The key point is that a message must be signed before it
leaves the administrative domain of the Signer.</t>

</section>
<section anchor="forwarder"><name>Forwarder</name>

<t><xref target="RFC5598"></xref> defines a Relay as transmitting or retransmitting a message
but states that it will not modify the envelope information or the
message content semantics. It also defines a Gateway as a hybrid of
User and Relay that connects heterogeneous mail services. In this
document we use the concept of a Forwarder which is an MTA that receives
a message and then, as an alternative to delivering it into a
destination mailbox, can forward it on to another system in an
automated, pre-determined, manner.</t>

</section>
<section anchor="reviser"><name>Reviser</name>

<t>As will be seen, a Forwarder may alter the message content or header
fields, in such a way that existing signatures on the message will
no longer validate. If so, then a record will be made of these
changes. We call a Forwarder that makes such changes a Reviser.</t>

</section>
<section anchor="verifier"><name>Verifier</name>

<t>Elements in the mail system that verify signatures are referred to as
Verifiers.  These may be Forwarders, Revisers, MTAs, Mail Delivery
Agents (MDAs), or MUAs.
It is an expectation of DKIM2 that a recipient of a message will
wish to verify some or all signatures before determining whether or
not to accept the message or pass it on to another entity.</t>

</section>
<section anchor="signing-domain"><name>Signing Domain</name>

<t>A domain name associated with a signature. This domain may be
associated with the author of an email, their organization, a
company hired to deliver the email, a mailing list operator, or
some other entity that handles email. What they have in common is
that at some point they had access to the entire contents of the
email and were in a position to add their signature to the email.</t>

</section>
<section anchor="originator"><name>Originator</name>

<t>The entity that creates and sends the initial form of a message.
The Originator adds the first Message-Instance header field (m=1) and
the first DKIM2-Signature header field (i=1) to the message.</t>

</section>
<section anchor="header-field"><name>Header Field</name>

<t>As defined in <xref target="RFC5322"></xref>, a header field is a single logical line in
the message header consisting of a field name, a colon, and a field
body (value).  In this document "header field" always refers to a
single field; "header fields" (plural) refers to multiple fields.
The unqualified term "header" is avoided to prevent ambiguity.</t>

</section>
<section anchor="tag"><name>Tag</name>

<t>A named element within a header field (see <xref target="hfMessageInstance"/>
and <xref target="hfDKIM2signature"/>).  A tag
consists of a tag-name and a tag-value separated by an equals sign.
Tags are separated by semicolons within the header field.</t>

</section>
<section anchor="message-body"><name>Message Body</name>

<t>The content of an email message that follows the blank line after
the header fields, treated as a sequence of octets.  In this document,
the terms "body" and "message body" are used interchangeably.</t>

</section>
<section anchor="hash"><name>Hash</name>

<t>A fixed-length value produced by applying a cryptographic hash
function (such as SHA-256) to an input.  DKIM2 uses hashes to
create a compact, verifiable representation of message header fields
and the message body.</t>

</section>
<section anchor="glossary"><name>Glossary</name>

<t>The following terms are used throughout this document:</t>

<dl>
  <dt>DKIM1</dt>
  <dd>
    <t>The original DomainKeys Identified Mail protocol as specified in
<xref target="RFC6376"></xref>.</t>
  </dd>
  <dt>DKIM2-Signature</dt>
  <dd>
    <t>A header field containing a cryptographic signature over the
Message-Instance and DKIM2-Signature header fields of a message,
along with metadata about the signing domain, SMTP envelope, and
timestamp.</t>
  </dd>
  <dt>Message-Instance</dt>
  <dd>
    <t>A header field containing cryptographic hashes of the message
header fields and body, along with optional recipes that allow
undoing changes made at that hop.</t>
  </dd>
  <dt>Recipe</dt>
  <dd>
    <t>A set of instructions encoded as a JSON object within the r= tag
of a Message-Instance header field.  Recipes allow a Verifier to
reconstruct the previous state of a message from its current state,
by specifying which parts of the header fields or body to copy and
which literal values to substitute.</t>
  </dd>
  <dt>Chain of Custody</dt>
  <dd>
    <t>The sequence of DKIM2-Signature header fields on a message, each
recording the SMTP envelope addresses (MAIL FROM and RCPT TO) used
at each hop.  A valid chain of custody demonstrates that the message
followed a plausible path from Originator to the current recipient.</t>
  </dd>
  <dt>Selector</dt>
  <dd>
    <t>A subdivision of the key namespace for a signing domain, used
to look up the public key in DNS.  The selector value is combined
with the signing domain to form the DNS query name:
selector._domainkey.domain.</t>
  </dd>
</dl>

</section>
<section anchor="whitespace"><name>Whitespace</name>

<t>There are two forms of whitespace used in this specification:</t>

<t><list style="symbols">
  <t>WSP represents simple whitespace, i.e., a space or a tab character
(formal definition in <xref target="RFC5234"></xref>).</t>
  <t>FWS is folding whitespace.  It allows multiple lines separated by
CRLF followed by at least one whitespace, to be joined.</t>
</list></t>

<t>The formal ABNF for these are (WSP given for information only):</t>

<figure><artwork><![CDATA[
WSP =   SP / HTAB
FWS =   [*WSP CRLF] 1*WSP
]]></artwork></figure>

<t>The definition of FWS is identical to that in <xref target="RFC5322"></xref> except for
the exclusion of obs-FWS.</t>

</section>
<section anchor="imported-abnf-tokens"><name>Imported ABNF Tokens</name>

<t>The following tokens are imported from other RFCs as noted.  Those
RFCs should be considered definitive.</t>

<t>The following tokens are imported from <xref target="RFC5321"></xref>:</t>

<t><list style="symbols">
  <t>"Domain"</t>
  <t>"Forward-path"</t>
  <t>"reverse-path"</t>
</list></t>

<t>The following tokens are imported from <xref target="RFC5322"></xref>:</t>

<t><list style="symbols">
  <t>"field-name" (name of a header field)</t>
</list></t>

<t>Other tokens not defined herein are imported from <xref target="RFC5234"></xref>.  These
are intuitive primitives such as SP, HTAB, WSP, ALPHA, DIGIT, CRLF,
etc.</t>

</section>
<section anchor="common-abnf-tokens"><name>Common ABNF Tokens</name>

<t>The following ABNF tokens are used elsewhere in this document:</t>

<figure><artwork><![CDATA[
ALPHADIGITD  = (ALPHA / DIGIT / "-" / "_")

textstring   =  [FWS] ALPHADIGITD *(ALPHADIGITD) [FWS]

ALPHADIGITPS =  (FWS / ALPHA / DIGIT / "+" / "/")

base64string =  ALPHADIGITPS *(ALPHADIGITPS) [[FWS] "=" [[FWS] "="]]
]]></artwork></figure>

<t>Note that base64strings are defined in <xref target="RFC4648"></xref>, but that document
does not contain any ABNF. A base64string MUST be padded with zero
bits and trailing = characters provided if needed. This allows
implementations to compare base64string values without decoding
them.</t>

<t>Note that the definition of base64string allows
for the presence of FWS, which simplifies folding header fields
to an allowable line length. FWS within base64strings will be
ignored when their value is being used.</t>

</section>
</section>
<section anchor="algorithms"><name>Signing and Verification Cryptographic Algorithms</name>

<t>DKIM2 supports multiple hashing and digital signature algorithms. One
hash function (SHA256) is specified here and two signing algorithms
are defined by this specification: RSA-SHA256 and Ed25519-SHA256.
Signers and Verifiers MUST implement SHA256. Signers SHOULD implement
both RSA-SHA256 and Ed25519-SHA256. Verifiers MUST implement both
RSA-SHA256 and Ed25519-SHA256.</t>

<section anchor="the-sha256-hashing-algorithm"><name>The SHA256 Hashing Algorithm</name>

<t>The SHA256 hashing algorithm is used to compute body and
header hashes as defined in <xref target="computing-body-hash"/> and
<xref target="computing-header-hash"/>.</t>

<t>The resultant values are identified by the text string "sha256" and
placed into Message-Instance header fields.</t>

</section>
<section anchor="the-rsa-sha256-signing-algorithm"><name>The RSA-SHA256 Signing Algorithm</name>

<t>The RSA-SHA256 Signing Algorithm computes a hash over all the Message-Instance
and DKIM2-Signature header fields as described in <xref target="calculate-signature"/> using
SHA-256 (FIPS-180-4-2015) as the hash-alg.  That
hash is then signed by the Signer using the RSA algorithm (defined in
PKCS#1 version 1.5 <xref target="RFC8017"></xref>) as the crypt-alg and the Signer's
private key.  The hash MUST NOT be truncated or converted into any
form other than the native binary form before being signed.  The
signing algorithm MUST use a public exponent of 65537.</t>

<t>Signers MUST use RSA keys of at least 1024 bits.  Verifiers MUST be able
to validate signatures with keys ranging from 1024 bits to 2048 bits, and
they MAY be able to validate signatures with larger keys.</t>

<t>The signature value (expressed in base64) is placed (with the identifying
text string "rsa-sha256") into DKIM2-Signature header fields.</t>

</section>
<section anchor="the-ed25519-sha256-signing-algorithm"><name>The Ed25519-SHA256 Signing Algorithm</name>

<t>The Ed25519-SHA256 Signing Algorithm computes a hash over all the Message-Instance
and DKIM2-Signature fields as described in <xref target="calculate-signature"/> using
SHA-256 (FIPS-180-4-2015) as the hash-alg. It signs the hash with the PureEdDSA
variant Ed25519, as defined in Section 5.1 of <xref target="RFC8032"></xref>.</t>

<t>The signature value (expressed in base64) is placed (with the identifying
text string "ed25519-sha256") into DKIM2-Signature header fields.</t>

</section>
<section anchor="other-algorithms"><name>Other Algorithms</name>

<t>Other algorithms MAY be defined in the future.  Verifiers MUST ignore
any hashes or signatures using algorithms that they do not implement.</t>

</section>
<section anchor="selectors"><name>Selectors</name>

<t>To support multiple concurrent public keys per signing domain, the
key namespace is subdivided using "selectors".</t>

<t>The number of public keys and corresponding selectors for each domain
is determined by the domain owner. Many domain owners will use just one
selector, whereas administratively distributed organizations can choose
to manage disparate selectors
and key pairs in different regions or on different email servers.
Selectors can also be used to delegate a signing authority, which
can be withdrawn at any time. Selectors also make it possible to
seamlessly replace keys on a routine basis by signing with a new
selector, while keeping the key associated with the old selector
available.</t>

<t>Periods are allowed in selectors and are component separators. Periods in
selectors define DNS label boundaries in a manner similar to the
conventional use in domain names.  This will allow portions of
the selector namespace to be delegated.</t>

<t>ABNF:</t>

<figure><artwork><![CDATA[
selector = Domain
]]></artwork></figure>

</section>
<section anchor="key_management"><name>Key Management</name>

<t>Some level of assurance is required that
a public key is associated with the claimed Signer. DKIM2
does this by fetching the key from the DNS for the domain specified
in the d= field of the DKIM2-Signature header field.</t>

<t>DKIM2 keys are stored in a subdomain named "_domainkey".  Given a
DKIM2-Signature field with a "d=" tag of "example.com" and a selector
of "foo.bar", the DNS query will be for "foo.bar._domainkey.example.com".</t>

<t>NOTE: these keys are no different, and are stored in the same locations
as those for DKIM1 (<xref target="RFC6376"></xref>).</t>

<t>Further details can be found in <xref target="DKIMKEYS"></xref>.</t>

</section>
</section>
<section anchor="ignoreheaders"><name>Unsigned Header Fields</name>

<t>As explained in detail below, DKIM2 will provide a cryptographic
signature for all header fields that are present within a message,
whether they have a standardised meaning or are just placed there
at the whim of a particular sender.</t>

<t>However, for reasons of simplicity some header fields are not signed
and processing of the message MUST be performed as if they were not
present.</t>

<t>These exceptions fall into three classes:</t>

<section anchor="trace-headers"><name>Trace Headers</name>

<t>"Received" or "Return-Path" header fields MUST be ignored. These are
Trace Headers as described in <xref target="RFC5321"></xref> and serve only to document
details of the SMTP transmission process.</t>

<t>The experimental "Delivered-To:" header field (<xref target="RFC9228"></xref>) MUST also
be ignored.</t>

</section>
<section anchor="other-email-authentication-mechanisms"><name>Other Email Authentication Mechanisms</name>

<t>"DKIM-Signature" header fields and any header fields whose field name
starts with "ARC-" MUST be ignored.</t>

<t>Not including DKIM1 and ARC header fields means that systems that
wish to add other types of signature as well as a DKIM2 signature
are free to do this in any convenient order.</t>

</section>
<section anchor="headers-with-purely-local-meaning"><name>Headers With Purely Local Meaning</name>

<t>"Authentication-Results header fields MUST be ignored. These header
fields are defined in <xref target="RFC8601"></xref> where it is made clear that their
contents are only intended for use within the the ""trust boundary"
of an Administrative Management Domain". As they can only used
reliably within that trust boundary there has been no need to
secure them cryptographically and given how they may be added or
removed as messages cross trust boundaries it is inconvenient and
unnecessary for DKIM2 to sign them.</t>

<t>Header fields with a header field name starting with "X-" MUST be
ignored. Currently deployed email systems use these fields as
proprietary Trace headers or for other proprietary reasons. They
have no defined meaning for other systems and it considerably
simplifies reporting on changes to header fields to ignore them. Note
that the recommendations in <xref target="RFC6648"></xref> mean that it is most
unlikely that any header field name starting "X-" will be developed
within the IETF.</t>

</section>
</section>
<section anchor="JSONrecipe"><name>Recipes</name>

<t>A set of "recipes" is used to recreate the previous version of the body
and/or header fields of a message. The recipes are provided
within a JSON object with the schema:</t>

<figure><artwork><![CDATA[
{
  "$schema": "https://json-schema.org/draft/2020-12/schema",
  "$id": "https://dkim2.org/schemas/recipe-v1",
  "title": "DKIM2 recipes",
  "description": "see draft-dkim-dkim2-spec",
  "type": "object",
  "properties": {
    "h": {
      "description": "recipes to recreate specific header fields",
      "type": "object",
      "minProperties": 1,
      "additionalProperties": { "$ref": "#/$defs/recipe-steps" }
    },
    "b": {
      "description": "recipes to recreate the body",
      "oneOf": [
        {
          "description": "body recipes",
          "$ref": "#/$defs/recipe-steps"
        },
        {
          "description": "previous body state cannot be recreated",
          "type": "null"
        }
      ]
    }
  },
  "anyOf": [
    { "required": ["h"] },
    { "required": ["b"] }
  ],
  "$defs": {
    "recipe-steps": {
      "type": "array",
      "items": {
        "oneOf": [
          {
            "description": "copy lines/fields, start to end inclusive",
            "type": "object",
            "properties": {
              "c": { "type": "array",
                "items": { "type": "integer", "minimum": 1 },
                "minItems": 2, "maxItems": 2
              }
            },
            "required": ["c"], "additionalProperties": false
          },
          {
            "description": "data lines/values to emit",
            "type": "object",
            "properties": {
              "d": { "type": "array",
                "items": { "type": "string" },
                "minItems": 1
              }
            },
            "required": ["d"], "additionalProperties": false
          }
        ]
      }
    }
  }
}
]]></artwork></figure>

<t>Note that the specification of JSON schemas is maintained by the JSON Schema
organisation, and the relevant specification document is linked to by the
$schema field in each JSON schema.</t>

<section anchor="header-recipes"><name>Header Recipes</name>

<t>A Header Recipe is an array of instructions ("recipes") applied to the specified
header fields with the given header field name. These recipes
are applied in order to the message which has been received
so as to recreate the message as it was before modifications were made.
Recipes MUST be provided for any relevant header field (see <xref target="ignoreheaders"/>
for header fields that are not relevant) that is changed; i.e. it is
not possible to indicate that the previous state of the header fields
cannot be recreated.</t>

<t>If there is no "h" field in the JSON object then there was no
modification to the header fields.</t>

<t>Matching of header field names is always done without regard to case
and there MUST NOT be JSON keys that differ only in case. Recipes
SHOULD NOT be specified for header fields that will not be signed
(see <xref target="ignoreheaders"/></t>

<t>If a header field name is not present in the JSON object then all
header fields with that header field name are to be retained.</t>

<t>If the recipe array for a header field name that is present in the
JSON object is empty then all instances of that header field are to
be removed to reinstate the previous state of the message.</t>

<t>Header fields are numbered "bottom up" (the opposite direction to
the body lines). That is to say, when walking the header fields
from the top of the message to end of the header fields then
the last header field instance
encountered with any particular header field name is numbered 1,
the header field (with the same header field name) above that is
numbered 2, and so on.</t>

<t>The header fields should be treated as
being unwrapped (in the normal <xref target="RFC5321"></xref> manner). That is, all
of the physical lines that form a single header field are
processed under the same logical number.</t>

<t>The recipes are processed in order and the resulting header
fields are emitted so that later header field will appear above
earlier header fields in the recreated message.</t>

<t>Each recipe step is a JSON object with exactly one key:</t>

<t>A "c" step has the form {"c": [start, end]}. The relevant header field
instances numbered from start to end inclusive, are to be emitted.
The start value of each "c" step MUST be in ascending order and
MUST be greater than the end value of all preceding "c" steps
for this header field name.</t>

<t>A "d" step has the form {"d": ["value1", "value2", ...]}. Each
string in the array is treated as a value to which the
relevant header field name and a colon is prepended and a CRLF
is appended and the resultant string is then emitted. Note that
the way in which hashes are calculated (see <xref target="computing-header-hash"/>)
means that no heed needs to be taken of wrapping
or the case of the header field name. The text strings MUST NOT
contain CR or LF characters. If a string is empty then the
CRLF will immediately follow the header field name and colon.</t>

</section>
<section anchor="body-recipes"><name>Body Recipes</name>

<t>A Body Recipe is an array of instructions applied to the message
body which can recreate the message as it was before modifications
were made.</t>

<t>If there is no "b" field in the JSON object then there was no
modification to the message body. Note that the JSON schema
requires either "h" or "b" to be present.</t>

<t>If the "b" field is null (there are no recipes) then the previous
state of the message body
cannot be recreated. Verifiers of the message may be able to
determine, by seeing which entity makes this declaration, that
this is acceptable to them because, for example, that entity
is providing a contractually arranged service.</t>

<t>Body lines are numbered "top down" (the opposite direction to
the header fields). The first line of the body (immediately after
the blank line that indicates that there are no more header fields)
is numbered 1.</t>

<t>The recipes are processed in order and the resulting body lines
fields are emitted so that later lines will appear below
earlier lines in the recreated message.</t>

<t>Each recipe step is a JSON object with exactly one key:</t>

<t>A "c" step has the form {"c": [start, end]}. The message body lines
from start to end, inclusive, are to be emitted. The start value of
each "c" step MUST be in ascending order and MUST be greater than the
end value of all preceding "c" steps.</t>

<t>A "d" step has the form {"d": ["line1", "line2", ...]}. Each
string in the array has a CRLF
appended and the resultant string is emitted. The text strings MUST NOT
contain CR or LF characters. If a string is empty then just
a CRLF is emitted.</t>

</section>
</section>
<section anchor="messagehashes"><name>Message Hash Values</name>

<t>A set of cryptographic "hashes" are used to record the current
message body and header fields. The hashes are placed into the
h= tag of a Message-Instance header field.</t>

<t>To provide for algorithmic dexterity more that one hash value, using a
different algorithm MAY be supplied in the same Message-Instance
header field.</t>

<t>Since Message-Instance header fields are ignored when calculating the
header hash value, the body hash and header hash may be calculated in
any convenient order.</t>

<section anchor="computing-body-hash"><name>Computing the Body Hash</name>

<t>The body of messages is treated as merely a string of octets. DKIM2
messages MAY be either in plain-text or in MIME format; no special
treatment is afforded to MIME content. Message attachments in MIME
format MUST be included in the content that is signed.</t>

<t>The DKIM2 body hash is calculated in the same manner as DKIM1's "simple"
scheme:</t>

<t>All empty lines at the end of the message body are ignored. An empty line
is a line of zero length after removal of the line terminator.  If there
is no body or no trailing CRLF on the message body, a CRLF is added. That
is "*CRLF" at the end of the body is converted to "CRLF".</t>

<t>No other changes are made to the body, which is then processed by the
relevant hash algorithm(s). The name of the hash and the hash value
(converted to base64 form) is then inserted into (Signers) or compared
to (Verifiers) the value of the "h=" tag of the Message-Instance header
field that is being created/verified. If multiple hashes are calculated
then multiple entries within the "h=" value will be inserted/compared.</t>

</section>
<section anchor="computing-header-hash"><name>Computing the Header Fields Hash</name>

<t>The header fields hash calculation done by a Signer MUST apply the
following steps in the order given. A Verifier will need to do the
equivalent steps in order to check that the hash they have received
is correct.</t>

<t><list style="symbols">
  <t>Ignore some header fields  <vspace blankLines='1'/>
When calculating the header field hash some header fields
are entirely ignored. See <xref target="ignoreheaders"/> for the list of header
field names that MUST be ignored.  <vspace blankLines='1'/>
When calculating the header field hash any "Message-Instance" or
"DKIM2-Signature" header fields MUST be ignored. These header
fields will be included in the hash value that will be signed
by a DKIM2-Signature header field and it simplifies implementations
if they are not included twice, especially when determining
whether all modifications to a message have been correctly declared.</t>
  <t>Convert all header field names (not the header field values) to
lowercase.  For example, convert "SUBJect: AbC" to "subject: AbC".</t>
  <t>Unfold all header field continuation lines as described in
<xref target="RFC5322"></xref>; in particular, lines with terminators embedded in
continued header field values (that is, CRLF sequences followed by
WSP) MUST be interpreted without the CRLF.  Implementations MUST
NOT remove the CRLF at the end of the header field value.</t>
  <t>Convert all sequences of one or more WSP characters to a single SP
character.  WSP characters here include those before and after a
line folding boundary.</t>
  <t>Delete all WSP characters at the end of each unfolded header field
value.</t>
  <t>Delete any WSP characters remaining before and after the colon
separating the header field name from the header field value.  The
colon separator MUST be retained.</t>
  <t>Place the header fields in alphabetical order by the header field
name.</t>
  <t>If there is more than one header with the same header field name
then the header fields are placed in the order in which they were
likely to have been placed into the message header, that is from
the last within the header upwards (the same ordering as is used
in the header recipes (see <xref target="header-recipes"/>).  <vspace blankLines='1'/>
It is sometimes suggested that some MTAs re-order
header fields after they receive an email. If an MTA does change the
order of header fields with the same header field name (and those
header fields will be included in the hash calculation) then it is their
responsibility to recover the original order
before verifying an existing signature or passing a previously signed
message to another MTA that may wish to do such verification.</t>
  <t>The hash(es) of the concatenated header fields are calculated.</t>
</list></t>

<t>The name of the hash and the hash value
(converted to base64 form) is then inserted into (Signers) or compared
to (Verifiers) the value of the "h=" tag of the Message-Instance header
field that is being created/verified. If multiple hashes are calculated
then multiple entries within the "h=" value will be inserted/compared.</t>

</section>
</section>
<section anchor="hfMessageInstance"><name>The Message-Instance Header Field</name>

<t>A Message-Instance header field documents the current contents of
the message and, in the case of a Reviser, records any relevant
changes that have been made to the incoming message.</t>

<t>The Message-Instance header field is a list of tag values as described
below. The m= and h= tags MUST be present. The r= tag is optional. Note
that the syntax is such that semi-colons will never occur within
tags or values, they only act as a separators.</t>

<t>The tag identifiers (before the = sign) MUST be treated as case
insignificant, the tag value (after the = sign) is case significant. The
tags may appear in any order, but MUST be only one of each kind. Unknown
tags, for extensions, MUST be ignored.</t>

<t>ABNF:</t>

<figure><artwork><![CDATA[
mi-field    = "Message-Instance:" mi-tag-list
mi-tag-list = *([FWS] mi-tag [FWS] ";" [FWS])
mi-tag      = mi-m-tag / mi-h-tag / mi-r-tag / x-tag
              ; x-tag is for extension
x-tag       = x-tag-name [FWS] "=" [FWS] [x-tag-value]
x-tag-name  = ALPHA *(ALPHA / DIGIT / "_")
x-tag-char  = %x21-3A / %x3C-7E
x-tag-value = x-tag-char *([FWS] x-tag-char)
]]></artwork></figure>

<section anchor="m-the-revision-number-of-the-message-instance-header-field"><name>m= the revision number of the Message-Instance header field</name>

<t>The Originator of a message uses the
value 1. Further Message-Instance header fields are added with a value one
more than the current highest numbered Message-Instance header field. Gaps
in the numbering MUST be treated as making the whole message impossible
to verify.</t>

<t>ABNF:</t>

<figure><artwork><![CDATA[
mi-m-tag    = %x6d [FWS] "=" [FWS] 1*DIGIT
]]></artwork></figure>

</section>
<section anchor="r-recipes-to-recreate-the-previous-instance-of-the-message"><name>r= recipes to recreate the previous instance of the message</name>

<t>The r= tag value is the base64 encoded version of the JSON object that
contains the recipes that allow the previous instance of the message
to be recreated (see <xref target="JSONrecipe"/>}.</t>

<t>ABNF:</t>

<figure><artwork><![CDATA[
mi-r-tag    = %x72 [FWS] "=" base64string
]]></artwork></figure>

</section>
<section anchor="h-the-hash-values-for-the-message"><name>h= the hash values for the message</name>

<t>The h= tag value contains the hash name, header hash value and body
hash value. Calculating the hash values is explained in <xref target="messagehashes"/>.</t>

<t>ABNF:</t>

<figure><artwork><![CDATA[
mi-h-tag    = %x68 [FWS] "=" hash-set *("," hash-set)
hash-set    = [FWS] hash-name [FWS] ":" header-hash ":" body-hash
hash-name   = "sha256" / x-hash-name
header-hash = base64string
body-hash   = base64string
x-hash-name = textstring ; for later expansion
]]></artwork></figure>

</section>
</section>
<section anchor="hfDKIM2signature"><name>The DKIM2-Signature Header Field</name>

<t>The signature of the email is stored in a DKIM2-Signature header
field.  This header field contains tag values that provide the
signature and key-fetching data.  Note that the syntax is such that
semi-colons will never occur within tags or values, they only act
as a separators.</t>

<t>The i=, m=, t=, d= and s= tags MUST be present. There MUST be
either an nf= tag or both mf= and rt= tags. The other tags are optional.</t>

<t>The tag identifiers (before the = sign) MUST be treated as case
insignificant, the tag value (after the = sign) is case significant. The
tags may appear in any order, but there MUST be only one of each kind.
Unknown tags, for extensions, MUST be ignored.</t>

<t>ABNF:</t>

<figure><artwork><![CDATA[
sig-field    = "DKIM2-Signature:" sig-tag-list
sig-tag-list = *([FWS] sig-tag [FWS] ";" [FWS])
sig-tag      = sig-i-tag / sig-m-tag / sig-t-tag / sig-mf-tag /
               sig-rt-tag / sig-nd-tag / sig-d-tag / sig-s-tag /
               sig-n-tag / sig-f-tag / x-tag
]]></artwork></figure>

<t>It will be noted that we have not included a version number.  Experience
from IMF onwards shows that it is essentially impossible to change
version numbers. If it becomes necessary to change DKIM2 in the sort
of incompatible way that a v=2 / v=3 version number would support,
it is expected that header fields will be labelled as DKIM3 instead.</t>

<section anchor="i-the-sequence-number-of-the-dkim2-signature-header-field"><name>i= the sequence number of the DKIM2-Signature header field</name>

<t>The Originator of a message uses the
value 1. Further DKIM2-Signature header fields are added with a value one
more than the current highest numbered DKIM2-Signature header field. Gaps
in the numbering MUST be treated as making the whole message unsigned.</t>

<t>ABNF:</t>

<figure><artwork><![CDATA[
sig-i-tag = %x69 [FWS] "=" [FWS] 1*DIGIT
]]></artwork></figure>

</section>
<section anchor="m-the-highest-numbered-message-instance-header-field"><name>m= the highest numbered Message-Instance header field</name>

<t>This value allows verifiers to determine which entity made a particular
revision to the message header fields or body.</t>

<t>ABNF:</t>

<figure><artwork><![CDATA[
sig-m-tag = %x6d [FWS] "=" [FWS] 1*DIGIT
]]></artwork></figure>

</section>
<section anchor="n-nonce-value"><name>n=  nonce value</name>

<t>This text value, if present, has a meaning to the creator of the signature
but MUST NOT be assumed to have any meaning to any other entity. It
MAY be used as an index into a database to assist in handling Delivery
Status Notifications or for any other purpose.</t>

<t>To discourage use of this tag field as an alternative to the use of more
appropriate header fields, the length of the string MUST NOT
exceed 64 characters and implementations SHOULD reject messages
where this limit has been ignored.</t>

<t>Note the value MUST be simple ASCII and MUST NOT contain semicolon.</t>

<t>ABNF:</t>

<figure><artwork><![CDATA[
sig-n-tag   = %x6e [FWS] "=" [FWS] nonce-value
nonce-value = *64(%x21-3A / %x3C-7E)
                  ; printable ASCII except semicolon, max 64 chars
]]></artwork></figure>

</section>
<section anchor="t-signature-timestamp"><name>t=  signature timestamp</name>

<t>The time that this header field was created. The format is the number of
seconds since 00:00:00 on January 1, 1970 in the UTC time zone.  The value
is expressed as an unsigned integer in decimal ASCII.  This value
is not constrained to fit into a 31- or 32-bit integer.</t>

<t>Implementations SHOULD be prepared to handle values up to at least
10^12 (until approximately AD 200,000; this fits into 40 bits).</t>

<t>Implementations MAY ignore signatures that have a timestamp in the future.
Implementations MAY ignore signatures that are more than 14 days old.</t>

<t>ABNF:</t>

<figure><artwork><![CDATA[
sig-t-tag    = %x74 [FWS] "=" [FWS] 1*DIGIT
]]></artwork></figure>

</section>
<section anchor="mf-the-mail-from-used-when-the-message-was-sent"><name>mf= the MAIL FROM used when the message was sent</name>

<t>DKIM2 records the <xref target="RFC5321"></xref> MAIL FROM value that was used when the message
was transmitted over an SMTP link from the signing MTA. Note that MAIL FROM
may be just "&lt;&gt;", for example for a Delivery Status Notification.</t>

<t>The value is recorded as the base64 encoding of the <xref target="RFC5321"></xref> reverse-path
because of the complex syntax of reverse-path values (which can include
characters which would confuse naive parsers of DKIM2-Signature header
fields). The angle brackets MUST be included, but any "Mail-parameters"
that were present after the reverse-path MUST NOT be included.</t>

<t>ABNF:</t>

<figure><artwork><![CDATA[
sig-mf-tag  = %x6d %x66 [FWS] "=" base64string
]]></artwork></figure>

</section>
<section anchor="rt-the-rcpt-to-values-used-when-the-message-was-sent"><name>rt= the RCPT TO value(s) used when the message was sent</name>

<t>DKIM2 records the <xref target="RFC5321"></xref> RCPT TO value(s) that were used when the message
was transmitted over an SMTP link from the signing MTA.</t>

<t>The value is recorded as the base64 encoding of the <xref target="RFC5321"></xref> Forward-path
because of the complex syntax of Forward-path values (which can include
characters which would confuse naive parsers of DKIM2-Signature header
fields). The angle brackets MUST be included, but any "Rcpt-parameters"
that were present after the Forward-path MUST NOT be included.</t>

<t>When a message is intended for more than one recipient then the RCPT
TO values provided MAY include all of the recipients so that a single
copy of the email MAY be sent to all of the recipients in a single SMTP
transaction. Alternatively, multiple copies of the email may be
generated so as to not immediately reveal who else received the email.</t>

<t>However, if "bcc:" recipients are involved then in order to
meet the requirements of <xref target="RFC5322"></xref> Section 3.6.3 each and every
bcc recipients MUST NOT be revealed to any other message recipient.</t>

<t>ABNF:</t>

<figure><artwork><![CDATA[
sig-rt-tag = %x72 %x74 [FWS] "=" base64string *("," base64string)
]]></artwork></figure>

</section>
<section anchor="nd-the-domain-that-will-appear-in-the-next-dkim2-signature-header-field"><name>nd=  the domain that will appear in the next DKIM2-Signature header field</name>

<t>This tag is used in order to provide a valid "chain of custody" when a
message is being forwarded from a different domain than the one to
which it arrived. The domain MUST be a valid DNS name under which a
DKIM2 key record is published.</t>

<t>The domain name in the nd= tag MUST exactly match the domain name of the
d= tag of the next DKIM2-Signature in sequence (i=) order.</t>

<t>Note that when an nd= tag is present both mf= and rt= MUST be omitted.
It is permissible to have more than one DKIM2-Signature header fields
with an nd= tag, but there MUST always be a DKIM2-Signature with a
higher sequence number that contains rf= and mf= tags.</t>

<t>ABNF:</t>

<figure><artwork><![CDATA[
sig-nd-tag   = %6e %x64 [FWS] "=" [FWS] Domain
]]></artwork></figure>

</section>
<section anchor="d-the-domain-associated-with-this-signature"><name>d=  the domain associated with this signature.</name>

<t>This domain is used to form the query for the public key. The domain MUST be a valid DNS
name under which the DKIM2 key record is published.</t>

<t>The domain name in the d= tag MUST exactly match the rightmost labels of
the domain name of the mf= tag. That is to say, the domain name of the
mf= tag MUST either match the d= domain exactly or be a sub-domain
of the d= domain name.</t>

<t>When the mf= domain is empty ("&lt;&gt;"), as will be the case for Delivery
Status Notifications (DSNs), then no match is required.</t>

<t>ABNF:</t>

<figure><artwork><![CDATA[
sig-d-tag   = %x64 [FWS] "=" [FWS] Domain
]]></artwork></figure>

</section>
<section anchor="s-the-signature-values-for-the-message"><name>s= the signature value(s) for the message</name>

<t>The s= tag value contains the selector, signature algorithm name and
signature value. Calculating the value is explained in
<xref target="calculate-signature"/>.</t>

<t>The selector values subdivides the namespace for the domain being
used for signing.</t>

<t>The algorithm value is the one used to generate
the signature. Verifiers MUST support "RSA-SHA256" for which
the string "rsa-sha256" is used and "Ed25519-SHA256" for which the
string "ed25519-sha256" is used. See <xref target="algorithms"/> for a description
of these algorithms.</t>

<t>To provide for algorithmic dexterity more than one signature,
using different algorithms, MAY be supplied. Since the DNS lookup for
the public key will check that the k= algorithm value matches, a different
selector MUST necessarily be used for each signature.</t>

<t>ABNF:</t>

<figure><artwork><![CDATA[
sig-s-tag   = %x73 [FWS] "=" [FWS] sig-set *( "," sig-set )
sig-set     = selector [FWS] ":" [FWS] sig-name [FWS] ":" message-sig
sig-name    = "rsa-sha256" / "ed25519-sha256" / x-sig-name
x-sig-name  = textstring     ; for later extension
message-sig = base64string
]]></artwork></figure>

</section>
<section anchor="f-flags"><name>f=  flags</name>

<t>Flags serve two purposes; they either report what has been done to
the message by the system creating the DKIM2-Signature or they make
a request to systems that handle the mail thereafter. Flags are
separated by commas, and optional white-space allows systems to
add several flags without creating long lines.</t>

<t>If a flag value is not recognised it MUST be ignored.</t>

<t>The flag values that report things are:</t>

<t>"exploded": this message (identified by its unique header hash value (recorded
in the h= JSON object of the relevant Message-Instance) is being sent to more
than one email address. An
MTA which receives a message MAY use this information to help it distinguish
between malicious "DKIM replay" and legitimate activity performed by
mailing list. If this flag is not present in at least one DKIM2-Signature
header field then an MTA MAY assume that only one copy of a particular
message (identified by relevant cryptographic hash values) is intended
to exist;</t>

<t>The flags values that make requests are:</t>

<t>"donotexplode": this Signer requests that the message not be sent to more
than one recipient. A system that, by local policy, ignores this request
MUST NOT allow any of the copies it creates to be forwarded on to any
MTA outside its control.</t>

<t>"donotmodify": this Signer requests that the message not be modified from
the form in which it is sent. If this request is honored then the body
MUST NOT be changed in any way that alters the body hash and header fields
MUST NOT be removed or changed. It is permissible to add header fields
but a subsequent receiver SHOULD consider whether such header fields
have an impact on how the message will be viewed or responded to and
MAY reject the message if it has concerns. A  system that, by local
policy, ignores this request and makes other changes MUST NOT allow
the message to be forwarded on to any MTA outside its control.</t>

<t>"feedback": this Signer requests feedback about how this message is handled
during delivery and thereafter. This document does not describe what such
feedback might be or where it might be delivered. If this flag is absent
then feedback is explicitly not required.</t>

<t>"feedhere": this Signer requests that any feedback about how this message is
handled during delivery and thereafter is relayed via this hop. This flag
will be set by privacy-conscious Forwarders when a message has a "feedback"
flag set and the Forwarder does not wish the identity of systems to which
the message is forwarded to be reveal to the requestor of feedback.</t>

<t>ABNF:</t>

<figure><artwork><![CDATA[
sig-f-tag        = %x66 [FWS] "=" [FWS] sig-f-tag-data
                   *( [FWS] "," [FWS] sig-f-tag-data)
sig-f-tag-data   = "donotmodify" | "donotexplode" | "feedback" |
                   "feedhere" | "exploded" | x-sig-f-tag-data
x-sig-f-tag-data = textstring ; for later extension
]]></artwork></figure>

</section>
</section>
<section anchor="signer-actions"><name>Signer Actions</name>

<t>This section gives the actions that need to be undertaken by the signer
of a message. They may be done in any appropriate order.</t>

<section anchor="add-any-necessary-message-instance-header-fields"><name>Add any Necessary Message-Instance Header Fields</name>

<t>If a system is generating the initial form of a message or if
it is a Reviser that has made changes to the message body and/or
header fields then it MUST compute the body hash as described in
<xref target="computing-body-hash"/> and the hash of the header fields
as described in <xref target="computing-header-hash"/>.</t>

<t>If the message does not contain a Message-Instance header field then one
MUST be added.</t>

<t>If hashing the message body or relevant header fields does not
give the same hash values as those recorded in the highest version
(m=) Message-Instance header field then a new Message-Instance
header field MUST be added and if they are the same a new
Message-Instance header field SHOULD NOT be added.</t>

<t>A Message-Instance header field MUST contain "recipes" to be able to
recreate the message corresponding to the hash values in the
currently highest numbered Message-Instance header field, or a
null recipe to indicate that recreating the previous version
of the message will not be possible.</t>

<t>A system may add more than one Message-Instance header field if it
wishes to do so, but the DKIM2 design allows all modifications made by
any single system to be documented
in a single Message-Instance header field.</t>

<t>Note that the first (m=1) Message-Instance header field MAY
contain "recipes" if it is wished to record any changes made to a
message as it enters the DKIM2 ecosystem. All other Message-Instance
header fields SHOULD contain at least one "recipe".</t>

</section>
<section anchor="chain-of-custody"><name>Provide a "Chain of Custody" for the Message</name>

<t>The DKIM2-Signature header field contains the MAIL FROM
and RCPT TO values that will be used when the message is transmitted,
so these <xref target="RFC5321"></xref> "envelope" values MUST be available to (or
deducible by) a Signer.</t>

<t>The receiver of a message will check for an exact match (including
the local parts of the email addresses) between the MAIL FROM / RCPT TO
<xref target="RFC5321"></xref> protocol values and the mf= and rt= values in the highest numbered
(most recent) DKIM2-Signature header field. It is acceptable for there to
be more RCPT TO email addresses recorded in rt= than are actually used in
the SMTP conversation, but any RCPT TO value which is used MUST be present.</t>

<t>Verifiers will check for a relaxed domain match (see <xref target="relaxed-domain-match"/>)
between the signing domain (d=) and the domain in the MAIL FROM value.</t>

<t>When the message being signed already has a DKIM2-Signature header field
(i.e. it has already been transmitted at least once) then a valid
"chain of custody" MUST be apparent when all of the DKIM2-Signature header fields
are considered. This "chain of custody" contributes to the way in
which DKIM2 tackles "DKIM replay" attacks.</t>

<t>If an MTA does not change anything in the message which would require
a new Message-Instance header field and it is going to send it onwards
to a system that be able to verify the existing message (that is no
changes are made to the MAIL FROM and RCPT TO values) and there is no
other reason to add a DKIM2-Signature header field then the MTA MAY
choose not to add one. This means that an essentially transparent
SMTP forwarding system need not be made "DKIM2 aware".</t>

</section>
<section anchor="imaginaryhops"><name>"Chain of Custody" for Imaginary Hops</name>

<t>In any situation where a message will be forwarded in such a way that the
mf= on the outgoing message is such that the "chain of custody"
would be broken then the Signer MUST ensure this is not the case.</t>

<t>One way of doing this would be to generate an extra DKIM2-Signature
header field that causes values to match, i.e. a record is fabricated
that documents the mail being passed from one domain to another with
appropriate "mf=" and "rt=" tag values which document the imaginary
transfer of the email from one domain to the next.</t>

<t>Alternatively the "nd=" tag may be used. When present the next higher
sequence numbered DKIM2-Signature header field MUST be signed by the
specified domain. However, since there are no mf= or rt= tag values
there is no need to provide imaginary values for the imaginary "hop"
between the domain used for receiving the message and the domain used to
forward it.</t>

<t>It will be noted that the creation of an extra DKIM2-Signature header field
(whether the nd= scheme is used or not) will require the Signer to have access
to a DKIM2 private key associated with a domain in the RCPT TO entry of
the message as it arrived.</t>

<t>Access to this private key is
often achieved by the Signer creating the private key and never sharing it.
One of two approaches is then taken to publishing the public key.
The first is to provide the public key (and selector value) to the domain owner
who creates an appropriate DNS entry. The alternative is for the Signer 
to create a public
key DNS entry within a part of the DNS that they control and the domain owner
publishes a CNAME pointing at this.</t>

</section>
<section anchor="relaxed-domain-match"><name>The Relaxed Domain Match Algorithm</name>

<t>To assist in addressing the "DKIM replay" problem DKIM2 provides a
"chain of custody" for every message. This is established by checking
that the MAIL FROM value recorded in every DKIM2-Signature header field
(except of course the i=1 instance) can be matched with a RCPT TO value
of the next lower numbered DKIM2-Signature header field.</t>

<t>It is also necessary to check DKIM2-Signature header fields for a match
between the signing domain (specified in the d= tag) and the MAIL FROM
domain.</t>

<t>To allow systems to use existing "bounce-handling" schemes with special
subdomains in their MAIL FROM values a "relaxed" approach is taken
to the matches between these values.</t>

<t><list style="symbols">
  <t>Only the domain part of the MAIL FROM and RCPT TO values is used
for these matches The local part (and the @) are ignored.</t>
  <t>If there is not an exact match between the domain names then labels
are removed, one by one from the left hand side of the MAIL
FROM domain name and the comparison is repeated.</t>
  <t>If no labels remain then there is no match.</t>
</list></t>

</section>
<section anchor="signer_privatekey"><name>Select a Private Key and Corresponding Selector Value</name>

<t>This specification does not define the basis by which a Signer should
choose which private key and selector value to use -- this will be a
matter of administrative convenience.  Distribution and management of private
keys is also outside the scope of this document.</t>

</section>
<section anchor="calculate-signature"><name>Calculate a Signature Value</name>

<t>A Signer calculates a signature solely over the Message-Instance and
DKIM2-Signature header fields of the message. The hashes of
the body and other header fields are covered by the hashes in
the highest version (m=) Message-Instance header field and hence
the signature will in practice be signing the message as a whole.</t>

<t>Most cryptographic schemes proceed by first calculating a hash value
and then signing the hash value, but the DKIM2-Signature header field
only provides the final signature value. This means that there
is no difficulty if the hash value is inordinately long, or is
not emitted by the cryptographic routine being used.</t>

<t>The signature algorithm MUST apply the following steps
in the order given (which are not quite the same as the steps
undertaken in calculating header hashes).</t>

<t><list style="symbols">
  <t>Convert all relevant header field names (not the header field values) to
lowercase.  For example, convert "DKIM2-signature" to "dkim2-signature".</t>
  <t>Unfold all header field continuation lines as described in
<xref target="RFC5322"></xref>; in particular, lines with terminators embedded in
continued header field values (that is, CRLF sequences followed by
WSP) MUST be interpreted without the CRLF.  Implementations MUST
NOT remove the CRLF at the end of the header field value.</t>
  <t>Delete all WSP characters. This means all WSP characters before and
after the colon separating the header field name from the header
field value, all WSP characters within the unfolded header field
value and all trailing WSP characters before the CRLF. The colon
separator and the CRLF MUST be retained.</t>
  <t>Place the header fields in order. First come the Message-Instance
header fields in ascending instance (m=) order. Second are the
DKIM2-Signature header fields in ascending sequence (i=) order.
Last of all is an incomplete DKIM2-Signature header field (the
one that this system is creating) with all tags present except
that the signature value(s) within the (s=) value are set to
the null string (""). The incomplete header field MUST be
unfolded, MUST have a trailing CRLF and MUST have spaces removed
in just the same way as the
complete header fields being processed.</t>
  <t>The concatenated header fields are then fed to the signature
algorithm(s). Once all the values are available the null 
signature value strings
are replaced by the base64 values of the signatures.</t>
</list></t>

</section>
</section>
<section anchor="verification-requirements"><name>Verification Requirements</name>

<t>The details of verification appear in <xref target="verifier_actions"/> below.
This section considers when verification should be performed and
how thorough it needs to be.</t>

<section anchor="check-most-recent-signature-and-hashes-for-the-message"><name>Check Most Recent Signature and Hashes for the Message</name>

<t>A Verifier SHOULD check the validity of the most recently applied
(highest numbered i= value) DKIM2-Signature header field
and the associated (m=) Message-Instance before accepting an email.</t>

<t>If these checks
do not pass then a Delivery Status Notification (DSN) for the email MUST
NOT be generated thereafter -- hence the best strategy, if the email
is not wanted, is to reject it (with a 5xx error code) whilst the
relevant SMTP conversation is still ongoing. If the check gives
a TEMPFAIL result then a 4xx error code SHOULD be used to allow the
sending MTA to understand the situation.</t>

<t>If the checks do pass and it is later determined that the email
is unacceptable for any reason then a DSN MAY be created and
passed to the system that delivered the email. The details of
this procedure appear in <xref target="bounce"/>.</t>

</section>
<section anchor="checking-the-message-instance-header-fields"><name>Checking the Message-Instance Header Fields</name>

<t>If the message has been modified since its original creation then
the Message-Instance header fields will enable a Verifier to determine
whether or not all the changes made are correctly recorded
by using the "recipes" to construct each preceding version
of the message.</t>

<t>Note that if it is only the first form of the message is of
interest then all the "recipes" can be applied in turn and
only one hash value checked -- the correctness of the
intermediate hash values are not relevant to this assessment.</t>

</section>
<section anchor="checking-the-dkim2-signature-header-fields"><name>Checking the DKIM2-Signature Header Fields</name>

<t>However, in order to check the chain of custody, to assess
whether the message has been exploded, to pick out
"feedback" requests to be honoured or to assign reputation to
Revisers then all of the DKIM2-Signature header fields
will have to checked for validity. The TBA document explores
these issues in more detail.</t>

</section>
<section anchor="verifier_interpret"><name>Interpret Results/Apply Local Policy</name>

<t>It is beyond the scope of this specification to describe what actions
the recipient of an email performs, but mail carrying valid DKIM2
signatures gives the recipient opportunities that unauthenticated
email would not.  Specifically, an authenticated email provides
predictable information by which other decisions can reliably be
managed, such as trust and reputation.  Conversely, it is hard
to assign trust or reputation to unauthenticated email.</t>

<t>If an MTA wishes to reject messages where signatures are missing
or do not verify, the handling MTA
SHOULD use a 550/5.7.x reply code.</t>

<t>Where the Verifier is integrated within the MTA and it is not
possible to fetch the public key, perhaps because the key server is
not available, a temporary failure message MAY be generated using a
451/4.7.5 reply code.</t>

<t>Temporary failures such as inability to access the key server or
other external service are the only conditions that SHOULD use a 4xx
SMTP reply code.  In particular, cryptographic signature verification
failures MUST NOT provoke 4xx SMTP replies.</t>

</section>
</section>
<section anchor="verifier_actions"><name>Verifier Actions</name>

<t>This section discusses the detail of the actions taken by a
Verifier. In essence
this will involve repeating all the actions taken by a Signer to
produce a Message-Instance or DKIM2-Signature header field. To
avoid a lot of repetition these actions will not be spelled out
in detail. Once a hash value has been calculated it is then
compared with the value reported by the Signer, or the Signer's
public key is used to determine whether a signature that has
been provided is correct.</t>

<t>When a Verifier is determining whether a particular DKIM2-Signature
header field it MUST consider the state of the message when that
header field was added to the message. That means it MUST first apply
all relevant recipes to reconstruct the body and header fields and it
MUST ignore any Message-Instance and DKIM2-Signature fields that
were added after that point.</t>

<section anchor="output-states"><name>Output States</name>

<t>For compatibility with the Authentication-Results header field defined
in <xref target="RFC8601"></xref> a verification will result in one of four states:</t>

<t>PASS:  The message was successfully verified.</t>

<t>FAIL:  The message could be verified but a hash or signature was not
       correct.</t>

<t>PERMERROR:  The message could not be verified due to some error that
      is unrecoverable, such as a required header field being absent
      or malformed.</t>

<t>TEMPERROR:  The message could not be verified due a temporary
      inability to retrieve a public key. A later attempt may
      produce a different.</t>

<t>A Verifier MAY cease verifying once a single failure is detected.</t>

<t>Verifiers wishing to communicate the results of verification to other
parts of the mail system may do so in whatever manner they see fit. If
they wish to provide a human-readable string to describe a failure
to verify (any state except PASS) then in order to provide the
maximum possible assistance to senders they SHOULD use the text
strings specified in this document. These human-readable messages
are described with m=<spanx style="verb">&lt;x&gt;</spanx> or tag=<spanx style="verb">&lt;y&gt;</spanx> placeholders, the <spanx style="verb">&lt;x&gt;</spanx> and <spanx style="verb">&lt;y&gt;</spanx> MUST
be replaced with the relevant ordinal or tag name (without the &lt; and
&gt; characters). Similarly <spanx style="verb">&lt;value&gt;</spanx> MUST be replaced by a relevant
string for the particular message.</t>

<t>If the verification is being performed during an SMTP protocol
conversation the human-readable string SHOULD be part of the
5xx or 4xx response string.</t>

<t>If the results of the verification are being communicated in a
Delivery Status Notification message (<xref target="RFC3462"/>) the
human-readable string should be included.</t>

<t>If, by local policy, a system wishes to accept a message which
has failed authentication it might choose to add an email header
field to the message before passing it on.  Any such header field
SHOULD include the human-readable string and 
SHOULD be inserted before any existing DKIM2-Signature or pre-existing
authentication status header fields in the header field block.  The
Authentication-Results: header field (<xref target="RFC8601"></xref>) MAY be used for this
purpose. It should be noted that any "Authentication-Results" header
field does not count as a modification to the email if any further
DKIM2-Signature header fields are to be generated.</t>

</section>
<section anchor="ensure-that-the-dkim2-header-fields-are-valid"><name>Ensure that the DKIM2 Header Fields are Valid</name>

<t>Verifiers MUST meticulously validate the format and values of all
relevant Message-Instance and DKIM2-Signature header fields. It MUST
also ensure that all required instances of these header fields are
present and that all required tags are present and tags that
cannot appear together do not do so. Recall however
that unknown tags MUST be ignored.</t>

<t>As a special case, there MUST NOT be a Message-Instance field
with a higher m= value than occurs in any DKIM2-Signature field.</t>

<t>Possible errors:</t>

<figure><artwork><![CDATA[
PERMERROR Message-Instance m=<x> missing
PERMERROR Message-Instance m=<x> syntax error
PERMERROR Message-Instance m=<x> tag=<y> missing
PERMERROR Message-Instance m=<x> is not signed
PERMERROR DKIM2-Signature i=<x> missing
PERMERROR DKIM2-Signature i=<x> syntax error
PERMERROR DKIM2-Signature i=<x> tag=<y> missing
PERMERROR DKIM2-Signature i=<x> tag=<y> was unexpected
]]></artwork></figure>

</section>
<section anchor="check-the-timestamps"><name>Check the Timestamps</name>

<t>Verifiers SHOULD return a failure if it is more than 14 days since the
timestamp recorded in the "t=" tag of any DKIM2-Signature header field.</t>

<t>Possible errors:</t>

<figure><artwork><![CDATA[
PERMERROR DKIM2-Signature i=<x> signature expired
]]></artwork></figure>

</section>
<section anchor="check-the-chain-of-custody"><name>Check the Chain-of-Custody</name>

<t>As explained in <xref target="chain-of-custody"/> a Verifier MUST check an exact
match between the MAIL FROM and RCPT TO parameters used when delivering
a message and the values found in the mf= and rt= tags of the highest
numbered DKIM2-Signature header field. There may be extra values
in the rt= value, but all RCPT TO values actually used for
delivery MUST be present.</t>

<t>The values of domains MUST BE put into lower-case before doing these
checks. As is usual in email protocols the case of the local part of
an email address is assumed to matter. Note that these checks MUST NOT
use the relaxed domain match algorithm.</t>

<t>A Verifier SHOULD check that there is a relaxed domain match
(see {relaxed-domain-match}) between the signing domain of the
most recently applied DKIM2-Signature header field and the
mf= value in that header field.</t>

<t>If an nd= tag has been used instead of mf= and rt= tags then a
Verifier MUST ensure that there is an exact match with the d=
value in the next DKIM2-Signature field in sequence number order.</t>

<t>Possible errors:</t>

<figure><artwork><![CDATA[
PERMERROR: DKIM2-Signature i=<x> MAIL FROM <value> did not match
PERMERROR: DKIM2-Signature i=<x> RCPT TO <value> did not match
PERMERROR: DKIM2-Signature i=<x> MAIL FROM and d= do not match
PERMERROR: DKIM2-Signature i=<x> MAIL nd= does not match
]]></artwork></figure>

</section>
<section anchor="fetch-the-public-key"><name>Fetch the Public Key</name>

<t>The public keys of all the signatures in DKIM2-Signature fields are
needed to complete the verification process. Details of key management and
representation are described in <xref target="key_management"/> and <xref target="DKIMKEYS"></xref>.
The Verifier MUST validate the key record and MUST NOT use any public
key records that are malformed.</t>

<t>Note that DNS timeouts MUST be reported as TEMPERROR but a DNS
result that indicates the key is absent MUST be reported as a
PERMERROR. Additionally, as <xref target="DKIMKEYS"></xref> makes clear, if more than
one record is returned this is an error. The human-readable error
message SHOULD provide the selector value so that it is clear which
key has caused a problem.</t>

<t>Note that <xref target="DKIMKEYS"></xref> has retired the h= field and DKIM2 implementations
MUST ignore this tag if it is present.</t>

<t>Possible errors:</t>

<figure><artwork><![CDATA[
TEMPERROR: DKIM2-Signature i=<x> public key <value> could not be fetched
PERMERROR: DKIM2-Signature i=<x> public key <value> does not exist
PERMERROR: DKIM2-Signature i=<x> public key <value> has multiple records
PERMERROR: DKIM2-Signature i=<x> public key <value> has a syntax error
PERMERROR: DKIM2-Signature i=<x> public key <value> algorithm mismatch
PERMERROR: DKIM2-Signature i=<x> public key <value> has been revoked
]]></artwork></figure>

</section>
<section anchor="perform-the-signature-verification-calculation"><name>Perform the Signature Verification Calculation</name>

<t>Verifying a signature consists of actions semantically equivalent to the
following steps:</t>

<t><list style="numbers" type="1">
  <t>Prepare a canonicalized version of the Message-Instance and DKIM2-Signature
header fields as described in <xref target="calculate-signature"/>. The signature value(s)
themselves will need to be removed to correspond with what was actually
signed. Note that this canonicalized version does not actually replace
the original content.</t>
  <t>Use the relevant public key value(s) to check the signature(s).</t>
  <t>If there is more than one signature provided then they MUST all be
checked if the Verifier is able to do so. If any signature fails then
an error SHOULD be reported. If all signatures that can be checked fail
then PERMFAIL MUST be reported.</t>
  <t>If some signatures fail and other pass then any error that is
reported should provide that information (e.g. PERMFAIL "rsa-sha256
signature passed, ed25519-sha256 signature failed").</t>
</list></t>

<t>The reasoning for requiring that all signatures pass is that if a signature
scheme has recently become deprecated because it is known to be cryptographically
flawed then Signers will use a second (unbroken) signature scheme. However, such
a Signer may still provide the other signature for the benefit of Verifiers
that have yet to upgrade -- reasoning perhaps that attacks are too expensive
to be a very significant security issue. A Verifier that determines that
one signature passes whilst the other fails may well be in a position to
prevent an attack.</t>

<t>Possible errors:</t>

<figure><artwork><![CDATA[
FAIL: DKIM2-Signature i=<x> public key <value> incorrect signature
]]></artwork></figure>

</section>
<section anchor="validating-body-and-header-hashes"><name>Validating Body and Header Hashes</name>

<t>Verifying a hash value requires a Verifier to repeat the hash calculation
performed by the Signer as set out in <xref target="computing-body-hash"/>
and <xref target="computing-body-hash"/>. The values can then be directly compared.</t>

<t>Since there may be more than one hash algorithm given the human-readable
error message SHOULD indicate which algorithm's result failed to match.</t>

<t>Possible errors:</t>

<figure><artwork><![CDATA[
FAIL: Message Instance m=<x> header hash <value> mismatch
FAIL: Message Instance m=<x> body hash <value> mismatch
]]></artwork></figure>

</section>
<section anchor="check-if-donotmodify-and-donotexplode-requests-were-honored"><name>Check if donotmodify and donotexplode Requests Were Honored</name>

<t>If a verifier receives a message with a nonotmodify request and a later
hop has altered the message body or removed or altered header fields
then the message SHOULD be rejected.</t>

<t>If a verifier receives a message with a donotexplode request and
a later hop has indicated that it has exploded the message then
the message SHOULD be rejected.</t>

<t>Possible errors:</t>

<figure><artwork><![CDATA[
FAIL: Message has been modified despite a donotmodify request
FAIL: Message has been exploded despite a donotexplode request
]]></artwork></figure>

</section>
</section>
<section anchor="bounce"><name>Delivery Status Notifications in the DKIM2 Ecosystem</name>

<t>In the DKIM2 ecosystem, when a message cannot be delivered then
this is reported to the sending machine by means of an <xref target="RFC5321"></xref>
return code or, if the SMTP session has completed, by generating
a Delivery Status Notification (DSN), as defined in <xref target="RFC3462"></xref>.</t>

<t>A DSN MUST be addressed to the MTA that sent the message. This
prevents "backscatter" by passing failures back along the chain
of MTAs that were in involved in passing the message forwards. This
is achieved by using the mf= tag from the highest numbered
DKIM2-Signature field. If this field is null ("mf=&lt;&gt;") then a DSN
MUST NOT be sent.</t>

<section anchor="dsn-contents"><name>DSN Contents</name>

<t>As set out in <xref target="RFC3462"></xref>, a DSN has a top-level MIME part of
type <spanx style="verb">multipart/report</spanx>.</t>

<t>A valid DSN generated by a DKIM2 system MUST always contain three
sections, the human-readable text, the machine readable status (in a
message/delivery-status MIME part and either a MIME part of type
<spanx style="verb">message/rfc822</spanx> that holds the original message exactly as it was
submitted by the sending system or `text/rfc822-headers' which has
just the header fields of that message.</t>

<t>All relevant DKIM2-Signature header fields (and Message-Instance
header fields if the message body is supplied) MUST verify.</t>

<t>The DSN itself MUST have appropriate Message-Instance and
DKIM2-Signature fields, noting that the MAIL FROM to be used
will be null ("&lt;&gt;").</t>

<section anchor="dsn-propagation"><name>DSN Propagation</name>

<t>A Forwarder which receives a DSN MAY propagate this
DSN to the MAIL FROM address used to deliver the message to it
(which can be found in the relevant DKIM2-Signature header field).</t>

<t>The DSN MUST be rebuilt so that the message (or just the message
header fields) are placed into the DSN to reflect the state the
message was in when it was forwarded. This means that the
DKIM2-Signature header field that was added MUST be removed.</t>

<t>Additionally, if the
message was modified by the Forwarder on the outward journey
those modifications must be undone and the Message-Instance
header field documenting those changes MUST be removed.</t>

<t>If it is impossible to regenerate the body of the message, because
it was changed on the outgoing path and a "null recipe" means
that the previous version cannot be reconstructed then the
body MUST be removed from the third part of the DSN and
a text/rfc822-headers MIME part must be supplied.</t>

<t>Where appropriate the reason for the delivery failure (as
recorded in the first part of the DSN) should be rewritten
to remove destination specific information.</t>

<t>The resultant DSN is sent to the
MAIL FROM address from the now highest numbered DKIM2-Signature
header field. The DSN itself MUST have only one DKIM2-Signature
field and only one Message-Instance header : i.e. it is a new
message.</t>

<t>Following these procedures will ensure that limited details of
where the message was forwarded to will be revealed to
the previous hop.</t>

</section>
<section anchor="authentication-of-inbound-dsns"><name>Authentication of Inbound DSNs</name>

<t>When a system receives a DKIM2 signed DSN, and the
included original message is also DKIM2 signed, it SHOULD
verify that this message (or just the header fields if the body
is not present) has not been altered.</t>

<t>This means:</t>

<t><list style="numbers" type="1">
  <t>The DSN's DKIM2-Signature will have a signing domain that is
aligned with the recipient of the message that is being returned.
The recipient's address is located in the rt= tag of the
last (highest i= tag) DKIM2-Signature in the returned message.</t>
  <t>The last (highest <spanx style="verb">i=</spanx> tag) DKIM2-Signature header field of the
returned message will be one that was generated by the system
receiving the DSN, determined by examining the
d= and mf= tags of that DKIM2-Signature header field.</t>
  <t>The header fields of the embedded message (in the message/rfc822
MIME part) can be verified. If the message body is present then
that can also be verified by inspecting the Message-Instance
header field(s).</t>
</list></t>

<t>If the verification fails then the DSN MUST NOT be propagated
any further. If verification has been performed prior to
accepting the DSN from the sender the DSN SHOULD be rejected
with a 550/5.7.x return code. If the verification cannot be completed
because of a temporary issue (with DNS lookups) then a 4xx
return code should be used.</t>

</section>
</section>
</section>
<section anchor="signer_normalize"><name>Preventing Transport Conversions</name>

<t>DKIM2's design is predicated on valid input.</t>

<t>In order to be signed a message will need to be in "network normal" format
(text is ASCII encoded, lines are separated with CRLF characters, etc.).</t>

<t>A message that is not compliant with <xref target="RFC5322"></xref>, <xref target="RFC2045"></xref>, <xref target="RFC2047"></xref>
and other relevant message format standards can be subject to attempts
by intermediaries to correct or interpret such content.  See Section 8
of <xref target="RFC6409"></xref> for examples of changes that are commonly made.  Such
"corrections" may invalidate DKIM2 signatures or have other undesirable
effects, including some that involve changes to the way a message is
presented to an end user.</t>

<t>When calculating the hash on messages that will be transmitted using
base64 or quoted-printable encoding, Signers MUST compute the hash
after the encoding.  Likewise, the Verifier MUST incorporate the
values into the hash before decoding the base64 or quoted-printable
text.  However, the hash MUST be computed before transport-level
encodings such as SMTP "dot-stuffing" (the modification of lines
beginning with a "." to avoid confusion with the SMTP end-of-message
marker, as specified in <xref target="RFC5321"></xref>).</t>

<t>Further, if the message contains local encoding that will be modified before transmission,
that modification to canonical <xref target="RFC5322"></xref> form MUST be done before signing.
In particular, bare CR or LF characters (used by some systems as a local line
separator convention) MUST be converted to the SMTP-standard CRLF
sequence before the message is signed.  Any conversion of this sort
SHOULD be applied to the message actually sent to the recipient(s),
not just to the version presented to the signing algorithm.</t>

<t>More generally, the Signer MUST sign the message as it is expected to
be received by the Verifier rather than in some local or internal form.</t>

</section>
<section anchor="eai-rfc6530-considerations-for-dkim2"><name>EAI (<xref target="RFC6530"></xref>) Considerations for DKIM2</name>

<t>TBA</t>

</section>
<section anchor="iana-considerations"><name>IANA Considerations</name>

<t>TBA</t>

</section>
<section anchor="security-considerations"><name>Security Considerations</name>

<t>TBA</t>

</section>
<section anchor="changes-from-earlier-versions"><name>Changes from Earlier Versions</name>

<t>draft-ietf-dkim-dkim2-spec-03</t>

<t>Move list of ignored header fields into its own section.
Added the experimental Delivered-To: header field to the list.</t>

<t>Remove possibility of a null recipe for header field changes.</t>

<t>Add nd= tag as an alternative to mf= rt= for imaginary hops.</t>

<t>Change DSN propagation rules so that a DSN always contains
the message headers up to the point at which the DSN creator
saw the message on the outward journey.</t>

<t>"feedhere" flag added.</t>

<t>draft-ietf-dkim-dkim2-spec-02</t>

<t>Made explicit that base64strings must be padded with zero bits.</t>

<t>Fixed header field description in JSON to be single string. and moved
the removed info into the textual discussion. Removed the z body recipe
since DSNs do not actually need this.</t>

<t>Added text to emphasise that semi-colons are (easy to parse) separators
in Message-Instance and DKIM2-Signature. Also fixed the syntax for
extension tags.</t>

<t>Added Authentication-Results to the list of headers that are
excluded from being signed.</t>

<t>Added text about what donotmodify means and added text to the
verification section about this and the donotexplode flag.</t>

<t>draft-ietf-dkim-dkim2-spec-01</t>

<t>Additions to terminology. Improved ABNF. Removed definition of tag-list
and placed relevant text in the two header field definitions. Untangled 
the description of what needs to be verified from the description of how
to verify and provided a list of human-readable strings to generate for
errors.</t>

<t>draft-ietf-dkim-dkim2-spec-00</t>

<t>Removed JSON for hashes, signatures and SMTP parameters. Provided
valid JSON for recipes and added "z" for truncated body.
Changed algorithm names for signing. Simplified the canonicalisation
performed for the header fields signed by DKIM2-Signature.
Changed v= to m= for message instance numbering.</t>

<t>General tidying up of specifying tag=value specifications and
associated ABNF. Various other fixes for issues flagged in WG.</t>

<t>[[This section to be removed by RFC Editor]]</t>

</section>


  </middle>

  <back>


<references title='References' anchor="sec-combined-references">

    <references title='Normative References' anchor="sec-normative-references">



<reference anchor="RFC1034">
  <front>
    <title>Domain names - concepts and facilities</title>
    <author fullname="P. Mockapetris" initials="P." surname="Mockapetris"/>
    <date month="November" year="1987"/>
    <abstract>
      <t>This RFC is the revised basic definition of The Domain Name System. It obsoletes RFC-882. This memo describes the domain style names and their used for host address look up and electronic mail forwarding. It discusses the clients and servers in the domain name system and the protocol used between them.</t>
    </abstract>
  </front>
  <seriesInfo name="STD" value="13"/>
  <seriesInfo name="RFC" value="1034"/>
  <seriesInfo name="DOI" value="10.17487/RFC1034"/>
</reference>
<reference anchor="RFC2045">
  <front>
    <title>Multipurpose Internet Mail Extensions (MIME) Part One: Format of Internet Message Bodies</title>
    <author fullname="N. Freed" initials="N." surname="Freed"/>
    <author fullname="N. Borenstein" initials="N." surname="Borenstein"/>
    <date month="November" year="1996"/>
    <abstract>
      <t>This initial document specifies the various headers used to describe the structure of MIME messages. [STANDARDS-TRACK]</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="2045"/>
  <seriesInfo name="DOI" value="10.17487/RFC2045"/>
</reference>
<reference anchor="RFC2047">
  <front>
    <title>MIME (Multipurpose Internet Mail Extensions) Part Three: Message Header Extensions for Non-ASCII Text</title>
    <author fullname="K. Moore" initials="K." surname="Moore"/>
    <date month="November" year="1996"/>
    <abstract>
      <t>This particular document is the third document in the series. It describes extensions to RFC 822 to allow non-US-ASCII text data in Internet mail header fields. [STANDARDS-TRACK]</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="2047"/>
  <seriesInfo name="DOI" value="10.17487/RFC2047"/>
</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="RFC3462">
  <front>
    <title>The Multipart/Report Content Type for the Reporting of Mail System Administrative Messages</title>
    <author fullname="G. Vaudreuil" initials="G." surname="Vaudreuil"/>
    <date month="January" year="2003"/>
    <abstract>
      <t>The Multipart/Report Multipurpose Internet Mail Extensions (MIME) content-type is a general "family" or "container" type for electronic mail reports of any kind. Although this memo defines only the use of the Multipart/Report content-type with respect to delivery status reports, mail processing programs will benefit if a single content-type is used to for all kinds of reports. This document is part of a four document set describing the delivery status report service. This collection includes the Simple Mail Transfer Protocol (SMTP) extensions to request delivery status reports, a MIME content for the reporting of delivery reports, an enumeration of extended status codes, and a multipart container for the delivery report, the original message, and a human-friendly summary of the failure. [STANDARDS-TRACK]</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="3462"/>
  <seriesInfo name="DOI" value="10.17487/RFC3462"/>
</reference>
<reference anchor="RFC4648">
  <front>
    <title>The Base16, Base32, and Base64 Data Encodings</title>
    <author fullname="S. Josefsson" initials="S." surname="Josefsson"/>
    <date month="October" year="2006"/>
    <abstract>
      <t>This document describes the commonly used base 64, base 32, and base 16 encoding schemes. It also discusses the use of line-feeds in encoded data, use of padding in encoded data, use of non-alphabet characters in encoded data, use of different encoding alphabets, and canonical encodings. [STANDARDS-TRACK]</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="4648"/>
  <seriesInfo name="DOI" value="10.17487/RFC4648"/>
</reference>
<reference anchor="RFC5234">
  <front>
    <title>Augmented BNF for Syntax Specifications: ABNF</title>
    <author fullname="D. Crocker" initials="D." role="editor" surname="Crocker"/>
    <author fullname="P. Overell" initials="P." surname="Overell"/>
    <date month="January" year="2008"/>
    <abstract>
      <t>Internet technical specifications often need to define a formal syntax. Over the years, a modified version of Backus-Naur Form (BNF), called Augmented BNF (ABNF), has been popular among many Internet specifications. The current specification documents ABNF. It balances compactness and simplicity with reasonable representational power. The differences between standard BNF and ABNF involve naming rules, repetition, alternatives, order-independence, and value ranges. This specification also supplies additional rule definitions and encoding for a core lexical analyzer of the type common to several Internet specifications. [STANDARDS-TRACK]</t>
    </abstract>
  </front>
  <seriesInfo name="STD" value="68"/>
  <seriesInfo name="RFC" value="5234"/>
  <seriesInfo name="DOI" value="10.17487/RFC5234"/>
</reference>
<reference anchor="RFC5321">
  <front>
    <title>Simple Mail Transfer Protocol</title>
    <author fullname="J. Klensin" initials="J." surname="Klensin"/>
    <date month="October" year="2008"/>
    <abstract>
      <t>This document is a specification of the basic protocol for Internet electronic mail transport. It consolidates, updates, and clarifies several previous documents, making all or parts of most of them obsolete. It covers the SMTP extension mechanisms and best practices for the contemporary Internet, but does not provide details about particular extensions. Although SMTP was designed as a mail transport and delivery protocol, this specification also contains information that is important to its use as a "mail submission" protocol for "split-UA" (User Agent) mail reading systems and mobile environments. [STANDARDS-TRACK]</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="5321"/>
  <seriesInfo name="DOI" value="10.17487/RFC5321"/>
</reference>
<reference anchor="RFC5322">
  <front>
    <title>Internet Message Format</title>
    <author fullname="P. Resnick" initials="P." role="editor" surname="Resnick"/>
    <date month="October" year="2008"/>
    <abstract>
      <t>This document specifies the Internet Message Format (IMF), a syntax for text messages that are sent between computer users, within the framework of "electronic mail" messages. This specification is a revision of Request For Comments (RFC) 2822, which itself superseded Request For Comments (RFC) 822, "Standard for the Format of ARPA Internet Text Messages", updating it to reflect current practice and incorporating incremental changes that were specified in other RFCs. [STANDARDS-TRACK]</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="5322"/>
  <seriesInfo name="DOI" value="10.17487/RFC5322"/>
</reference>
<reference anchor="RFC6376">
  <front>
    <title>DomainKeys Identified Mail (DKIM) Signatures</title>
    <author fullname="D. Crocker" initials="D." role="editor" surname="Crocker"/>
    <author fullname="T. Hansen" initials="T." role="editor" surname="Hansen"/>
    <author fullname="M. Kucherawy" initials="M." role="editor" surname="Kucherawy"/>
    <date month="September" year="2011"/>
    <abstract>
      <t>DomainKeys Identified Mail (DKIM) permits a person, role, or organization that owns the signing domain to claim some responsibility for a message by associating the domain with the message. This can be an author's organization, an operational relay, or one of their agents. DKIM separates the question of the identity of the Signer of the message from the purported author of the message. Assertion of responsibility is validated through a cryptographic signature and by querying the Signer's domain directly to retrieve the appropriate public key. Message transit from author to recipient is through relays that typically make no substantive change to the message content and thus preserve the DKIM signature.</t>
      <t>This memo obsoletes RFC 4871 and RFC 5672. [STANDARDS-TRACK]</t>
    </abstract>
  </front>
  <seriesInfo name="STD" value="76"/>
  <seriesInfo name="RFC" value="6376"/>
  <seriesInfo name="DOI" value="10.17487/RFC6376"/>
</reference>
<reference anchor="RFC6409">
  <front>
    <title>Message Submission for Mail</title>
    <author fullname="R. Gellens" initials="R." surname="Gellens"/>
    <author fullname="J. Klensin" initials="J." surname="Klensin"/>
    <date month="November" year="2011"/>
    <abstract>
      <t>This memo splits message submission from message relay, allowing each service to operate according to its own rules (for security, policy, etc.), and specifies what actions are to be taken by a submission server.</t>
      <t>Message relay is unaffected, and continues to use SMTP over port 25.</t>
      <t>When conforming to this document, message submission uses the protocol specified here, normally over port 587.</t>
      <t>This separation of function offers a number of benefits, including the ability to apply specific security or policy requirements. [STANDARDS-TRACK]</t>
    </abstract>
  </front>
  <seriesInfo name="STD" value="72"/>
  <seriesInfo name="RFC" value="6409"/>
  <seriesInfo name="DOI" value="10.17487/RFC6409"/>
</reference>
<reference anchor="RFC6530">
  <front>
    <title>Overview and Framework for Internationalized Email</title>
    <author fullname="J. Klensin" initials="J." surname="Klensin"/>
    <author fullname="Y. Ko" initials="Y." surname="Ko"/>
    <date month="February" year="2012"/>
    <abstract>
      <t>Full use of electronic mail throughout the world requires that (subject to other constraints) people be able to use close variations on their own names (written correctly in their own languages and scripts) as mailbox names in email addresses. This document introduces a series of specifications that define mechanisms and protocol extensions needed to fully support internationalized email addresses. These changes include an SMTP extension and extension of email header syntax to accommodate UTF-8 data. The document set also includes discussion of key assumptions and issues in deploying fully internationalized email. This document is a replacement for RFC 4952; it reflects additional issues identified since that document was published. [STANDARDS-TRACK]</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="6530"/>
  <seriesInfo name="DOI" value="10.17487/RFC6530"/>
</reference>
<reference anchor="RFC6648">
  <front>
    <title>Deprecating the "X-" Prefix and Similar Constructs in Application Protocols</title>
    <author fullname="P. Saint-Andre" initials="P." surname="Saint-Andre"/>
    <author fullname="D. Crocker" initials="D." surname="Crocker"/>
    <author fullname="M. Nottingham" initials="M." surname="Nottingham"/>
    <date month="June" year="2012"/>
    <abstract>
      <t>Historically, designers and implementers of application protocols have often distinguished between standardized and unstandardized parameters by prefixing the names of unstandardized parameters with the string "X-" or similar constructs. In practice, that convention causes more problems than it solves. Therefore, this document deprecates the convention for newly defined parameters with textual (as opposed to numerical) names in application protocols. This memo documents an Internet Best Current Practice.</t>
    </abstract>
  </front>
  <seriesInfo name="BCP" value="178"/>
  <seriesInfo name="RFC" value="6648"/>
  <seriesInfo name="DOI" value="10.17487/RFC6648"/>
</reference>
<reference anchor="RFC8259">
  <front>
    <title>The JavaScript Object Notation (JSON) Data Interchange Format</title>
    <author fullname="T. Bray" initials="T." role="editor" surname="Bray"/>
    <date month="December" year="2017"/>
    <abstract>
      <t>JavaScript Object Notation (JSON) is a lightweight, text-based, language-independent data interchange format. It was derived from the ECMAScript Programming Language Standard. JSON defines a small set of formatting rules for the portable representation of structured data.</t>
      <t>This document removes inconsistencies with other specifications of JSON, repairs specification errors, and offers experience-based interoperability guidance.</t>
    </abstract>
  </front>
  <seriesInfo name="STD" value="90"/>
  <seriesInfo name="RFC" value="8259"/>
  <seriesInfo name="DOI" value="10.17487/RFC8259"/>
</reference>
<reference anchor="RFC8601">
  <front>
    <title>Message Header Field for Indicating Message Authentication Status</title>
    <author fullname="M. Kucherawy" initials="M." surname="Kucherawy"/>
    <date month="May" year="2019"/>
    <abstract>
      <t>This document specifies a message header field called "Authentication-Results" for use with electronic mail messages to indicate the results of message authentication efforts. Any receiver-side software, such as mail filters or Mail User Agents (MUAs), can use this header field to relay that information in a convenient and meaningful way to users or to make sorting and filtering decisions.</t>
      <t>This document obsoletes RFC 7601.</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="8601"/>
  <seriesInfo name="DOI" value="10.17487/RFC8601"/>
</reference>
<reference anchor="RFC9228">
  <front>
    <title>Delivered-To Email Header Field</title>
    <author fullname="D. Crocker" initials="D." role="editor" surname="Crocker"/>
    <date month="April" year="2022"/>
    <abstract>
      <t>The address to which email is delivered might be different than any of the addresses shown in any of the content header fields that were created by the email's author. For example, the address used by the email transport service is provided separately, such as through SMTP's "RCPT TO" command, and might not match any address in the To: or cc: fields. In addition, before final delivery, handling can entail a sequence of submission/delivery events, using a sequence of different destination addresses that (eventually) lead to the recipient. As well, a receiving system's delivery process can produce local address transformations.</t>
      <t>It can be helpful for a message to have a common way to record each delivery in such a sequence, noting each address used in the sequence to that recipient, such as for (1) analyzing the path a message has taken, (2) loop detection, or (3) formulating the author's address in a reply message. This document defines a header field for this information.</t>
      <t>Email handling information discloses details about the email infrastructure, as well as about a particular recipient; this can raise privacy concerns.</t>
      <t>A header field such as this is not automatically assured of widespread use. Therefore, this document is being published as an Experimental RFC, looking for constituency and for operational utility. This document was produced through the Independent Submission Stream and was not subject to the IETF's approval process.</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="9228"/>
  <seriesInfo name="DOI" value="10.17487/RFC9228"/>
</reference>

<reference anchor="DKIMKEYS">
   <front>
      <title>Domain Name Specification for DKIM2</title>
      <author fullname="Wei Chuang" initials="W." surname="Chuang">
         <organization>Google</organization>
      </author>
      <date day="18" month="March" year="2026"/>
      <abstract>
	 <t>   The updated DomainKeys Identified Mail (DKIM2) permits an
   organization that owns the signing domain to claim some
   responsibility for a message by associating the domain with the
   message through a digital signature.  This is done by publishing to
   Domain Name Service (DNS) of the domain a public key that is then
   associated to the domain and where messages can be signed by the
   corresponding private key.  Assertion of responsibility is validated
   through a cryptographic signature and by querying the Signer’s domain
   directly to retrieve the appropriate public key.  This document
   describes DKIM2 DNS record format and how to find the record.

	 </t>
      </abstract>
   </front>
   <seriesInfo name="Internet-Draft" value="draft-chuang-dkim2-dns-04"/>
   
</reference>



    </references>

    <references title='Informative References' anchor="sec-informative-references">



<reference anchor="RFC5598">
  <front>
    <title>Internet Mail Architecture</title>
    <author fullname="D. Crocker" initials="D." surname="Crocker"/>
    <date month="July" year="2009"/>
    <abstract>
      <t>Over its thirty-five-year history, Internet Mail has changed significantly in scale and complexity, as it has become a global infrastructure service. These changes have been evolutionary, rather than revolutionary, reflecting a strong desire to preserve both its installed base and its usefulness. To collaborate productively on this large and complex system, all participants need to work from a common view of it and use a common language to describe its components and the interactions among them. But the many differences in perspective currently make it difficult to know exactly what another participant means. To serve as the necessary common frame of reference, this document describes the enhanced Internet Mail architecture, reflecting the current service. This memo provides information for the Internet community.</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="5598"/>
  <seriesInfo name="DOI" value="10.17487/RFC5598"/>
</reference>
<reference anchor="RFC8017">
  <front>
    <title>PKCS #1: RSA Cryptography Specifications Version 2.2</title>
    <author fullname="K. Moriarty" initials="K." role="editor" surname="Moriarty"/>
    <author fullname="B. Kaliski" initials="B." surname="Kaliski"/>
    <author fullname="J. Jonsson" initials="J." surname="Jonsson"/>
    <author fullname="A. Rusch" initials="A." surname="Rusch"/>
    <date month="November" year="2016"/>
    <abstract>
      <t>This document provides recommendations for the implementation of public-key cryptography based on the RSA algorithm, covering cryptographic primitives, encryption schemes, signature schemes with appendix, and ASN.1 syntax for representing keys and for identifying the schemes.</t>
      <t>This document represents a republication of PKCS #1 v2.2 from RSA Laboratories' Public-Key Cryptography Standards (PKCS) series. By publishing this RFC, change control is transferred to the IETF.</t>
      <t>This document also obsoletes RFC 3447.</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="8017"/>
  <seriesInfo name="DOI" value="10.17487/RFC8017"/>
</reference>
<reference anchor="RFC8032">
  <front>
    <title>Edwards-Curve Digital Signature Algorithm (EdDSA)</title>
    <author fullname="S. Josefsson" initials="S." surname="Josefsson"/>
    <author fullname="I. Liusvaara" initials="I." surname="Liusvaara"/>
    <date month="January" year="2017"/>
    <abstract>
      <t>This document describes elliptic curve signature scheme Edwards-curve Digital Signature Algorithm (EdDSA). The algorithm is instantiated with recommended parameters for the edwards25519 and edwards448 curves. An example implementation and test vectors are provided.</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="8032"/>
  <seriesInfo name="DOI" value="10.17487/RFC8032"/>
</reference>
<reference anchor="RFC8617">
  <front>
    <title>The Authenticated Received Chain (ARC) Protocol</title>
    <author fullname="K. Andersen" initials="K." surname="Andersen"/>
    <author fullname="B. Long" initials="B." role="editor" surname="Long"/>
    <author fullname="S. Blank" initials="S." role="editor" surname="Blank"/>
    <author fullname="M. Kucherawy" initials="M." role="editor" surname="Kucherawy"/>
    <date month="July" year="2019"/>
    <abstract>
      <t>The Authenticated Received Chain (ARC) protocol provides an authenticated "chain of custody" for a message, allowing each entity that handles the message to see what entities handled it before and what the message's authentication assessment was at each step in the handling.</t>
      <t>ARC allows Internet Mail Handlers to attach assertions of message authentication assessment to individual messages. As messages traverse ARC-enabled Internet Mail Handlers, additional ARC assertions can be attached to messages to form ordered sets of ARC assertions that represent the authentication assessment at each step of the message-handling paths.</t>
      <t>ARC-enabled Internet Mail Handlers can process sets of ARC assertions to inform message disposition decisions, identify Internet Mail Handlers that might break existing authentication mechanisms, and convey original authentication assessments across trust boundaries.</t>
    </abstract>
  </front>
  <seriesInfo name="RFC" value="8617"/>
  <seriesInfo name="DOI" value="10.17487/RFC8617"/>
</reference>

<reference anchor="CONCLUDEARC">
   <front>
      <title>Concluding the ARC Experiment</title>
      <author fullname="J. Trent Adams" initials="J. T." surname="Adams">
         <organization>Proofpoint</organization>
      </author>
      <author fullname="John R. Levine" initials="J. R." surname="Levine">
         <organization>Taughannock Networks</organization>
      </author>
      <date day="4" month="December" year="2025"/>
      <abstract>
	 <t>   This document calls for a conclusion to the experiment defined by
   “The Authenticated Received Chain (ARC) Protocol,” (RFC8617) and
   recommends that ARC no longer be deployed or relied upon between
   disparate senders and receivers.  The document summarizes what ARC
   set out to do, reports on operational experience, and explains how
   the experience gained during the experiment is being incorporated
   into the proposed DKIM2 work as the successor to DomainKeys
   Identified Mail (DKIM).  To avoid any future confusion, it is
   therefore requested that ARC (RFC8617) be marked “Obsolete” by the
   publication of this Internet-Draft.

	 </t>
      </abstract>
   </front>
   <seriesInfo name="Internet-Draft" value="draft-adams-arc-experiment-conclusion-01"/>
   
</reference>



    </references>

</references>



  </back>

<!-- ##markdown-source:
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
AEuRXtzpFwEA

-->

</rfc>

