<?xml version='1.0' encoding='utf-8'?>
<!DOCTYPE rfc [
  <!ENTITY nbsp    "&#160;">
  <!ENTITY zwsp   "&#8203;">
  <!ENTITY nbhy   "&#8209;">
  <!ENTITY wj     "&#8288;">
]>
<?xml-stylesheet type="text/xsl" href="rfc2629.xslt" ?>
<!-- generated by https://github.com/cabo/kramdown-rfc version 1.7.39 (Ruby 3.2.3) -->
<?rfc compact="yes"?>
<?rfc subcompact="no"?>
<rfc xmlns:xi="http://www.w3.org/2001/XInclude" ipr="trust200902" docName="draft-moccia-dkim2-deployment-profile-05" category="info" submissionType="IETF" tocInclude="true" sortRefs="true" symRefs="true" version="3">
  <!-- xml2rfc v2v3 conversion 3.34.0 -->
  <front>
    <title abbrev="DKIM2 Deployment Profile">A Deployment Profile for DKIM2 via Milter Interface</title>
    <seriesInfo name="Internet-Draft" value="draft-moccia-dkim2-deployment-profile-05"/>
    <author initials="V." surname="Moccia" fullname="Vittorio Moccia">
      <organization>ITB.it</organization>
      <address>
        <email>v.moccia@itb.it</email>
      </address>
    </author>
    <date year="2026" month="June" day="22"/>
    <area>Applications and Real-Time</area>
    <workgroup>DKIM Working Group</workgroup>
    <keyword>DKIM2</keyword>
    <keyword>milter</keyword>
    <keyword>email authentication</keyword>
    <keyword>deployment profile</keyword>
    <abstract>
      <?line 119?>

<t>This document defines a deployment profile for DomainKeys Identified Mail v2 (DKIM2) that is implementable via the existing milter interface without modifications to Mail Transfer Agent (MTA) core software. It identifies a mandatory core profile (DKIM2-core) covering envelope binding, chain of custody, header accountability, replay prevention and DSN authentication and an optional extended profile (DKIM2-extended) covering body recipes and Message-Instance headers. The separation is motivated by deployment realism: the core profile addresses the primary threat models identified in the DKIM2 motivation document and is deployable incrementally across heterogeneous infrastructure, including small operators, universities and research institutions, using the same milter-based deployment model that has proven effective for DKIM1 and ARC.</t>
      <t>The intent of this document is not to obstruct DKIM2 but to make it deployable. DKIM2-core can be deployed incrementally across the heterogeneous ecosystem in a short timeframe. DKIM2-extended requires significantly longer implementation cycles and may not be deployable in jurisdictions with stricter privacy requirements. Both profiles are part of DKIM2 - the separation serves adoption, not opposition.</t>
    </abstract>
  </front>
  <middle>
    <?line 125?>

<section anchor="introduction">
      <name>Introduction</name>
      <t>DomainKeys Identified Mail v2 (DKIM2) addresses significant limitations of DKIM1 <xref target="RFC6376"/> and the experimental ARC protocol <xref target="RFC8617"/>, including DKIM replay attacks, backscatter from unauthorized use of envelope senders and the absence of cryptographic binding between message signatures and SMTP envelope parameters.</t>
      <t>The core technical contribution of DKIM2 - binding the MAIL FROM and RCPT TO values of each SMTP transaction to the message signature at every hop - is a genuine improvement over both DKIM1 and ARC and is sufficient to address the primary threat models identified in <xref target="I-D.ietf-dkim-dkim2-motivation"/>.</t>
      <t>However, the current specification also includes a body recipe mechanism that allows intermediaries to describe modifications made to the message body in sufficient detail to reconstruct previous versions. This mechanism introduces significant architectural complexity: it requires stateful milter implementations with persistent shared storage, JSON parsing in the delivery critical path and software modifications across the entire ecosystem of intermediaries. The body recipe mechanism also raises data protection concerns under GDPR and equivalent frameworks that have not yet been addressed in the specification.</t>
      <t>This document proposes a structured separation of DKIM2 functionality into two profiles:</t>
      <ul spacing="normal">
        <li>
          <t>DKIM2-core: a mandatory profile implementing envelope binding, chain of custody, header accountability, replay prevention and DSN authentication. DKIM2-core is fully implementable via the milter interface without MTA core modifications, using header formats already familiar to the ecosystem through ARC deployment. Critically, DKIM2-core requires no persistent state between SMTP sessions - all information needed for signing and verification is available within the current session and the message headers themselves. State management is only required for body recipe generation, which belongs exclusively to DKIM2-extended.</t>
        </li>
        <li>
          <t>DKIM2-extended: an optional profile adding body recipe generation and verification via Message-Instance headers and JSON-encoded recipes. DKIM2-extended may require stateful milter implementations or MTA core integration and is appropriate for operators who require full body accountability and are willing to accept the associated architectural cost.</t>
        </li>
      </ul>
      <t>This separation is consistent with the DKIM working group charter <xref target="DKIM-CHARTER"/>, which states that "the working group will prefer a result that is incremental to the deployed ecosystem" and that "proposed solutions are expected to be robust in terms of interoperability and scalability".</t>
      <t>The approach taken in this document is explicitly constructive: it does not propose to replace DKIM2 but to define a deployment path that allows the ecosystem to adopt the core benefits of DKIM2 incrementally, without requiring simultaneous changes to every node in the delivery chain.</t>
      <section anchor="relationship-to-dkim2-specifications">
        <name>Relationship to DKIM2 Specifications</name>
        <t>This document is a deployment profile, not a competing specification. It references and depends on <xref target="I-D.ietf-dkim-dkim2-spec"/> for the underlying mechanisms. Where this document proposes alternative encoding formats - specifically for envelope binding fields - these are offered as contributions to the ongoing design discussion in the working group.</t>
      </section>
      <section anchor="motivation">
        <name>Motivation</name>
        <t>The Internet email infrastructure is not composed solely of large providers with dedicated engineering teams. A substantial portion of email is handled by operators of all sizes outside the largest commercial providers: small ISPs, universities and research institutions, regional hosting providers, non-profit organizations and small businesses. What these operators have in common is not small scale per se - a university may handle millions of messages per day - but limited engineering resources dedicated to mail infrastructure. Their administrators depend on the milter interface for incremental deployment of new authentication features precisely because it allows them to adopt new protocols without modifying MTA core software, waiting for upstream vendor releases or dedicating engineering cycles to core system changes. Every authentication protocol that has achieved broad adoption - SPF, DKIM1, DMARC and to a limited extent ARC - has been deployable via this model. DKIM2 as currently specified breaks this pattern.</t>
        <t>Furthermore, the body recipe mechanism encounters a fundamental operational obstacle: the nodes most likely to make substantial body modifications - security gateways, DLP systems, URL rewriting proxies, antivirus engines - are precisely the nodes least likely to implement recipe generation. These nodes will systematically produce null recipes, which provide no additional accountability over incremental body hash chaining. The overhead of the recipe infrastructure is therefore paid by the entire ecosystem while the benefit accrues only to the minority of cases where all intermediaries cooperate fully.</t>
        <t>The pragmatic approach to body integrity documented in <xref target="RFC6376"/> Appendix B - using relaxed canonicalization to tolerate common benign transformations rather than requiring intermediaries to declare or reconstruct them - has proven effective in practice and has contributed to the broad adoption of DKIM1. It should be noted however that relaxed canonicalization does not address all categories of involuntary body transformation: base64 line-width re-encoding, for example, breaks both simple and relaxed canonicalization equally. DKIM2-core preserves the relaxed canonicalization approach for body integrity while adding the cryptographic envelope binding and header accountability that DKIM1 lacks. The body recipe mechanism of DKIM2-extended represents a deliberate departure from this model toward deterministic reconstruction - a departure whose operational cost and deployment implications are addressed in Section 4.</t>
      </section>
      <section anchor="design-philosophy">
        <name>Design Philosophy</name>
        <t>This document is guided by three principles that reflect the deployment realities described in Section 1.2.</t>
        <t>Additive, not transformative - every mechanism defined in DKIM2-core adds new header fields or new signed content to existing messages. Nothing in DKIM2-core requires existing software to change its core behavior. A legacy node that does not implement DKIM2 passes DKIM2 headers through without interpreting them, exactly as it handles any unrecognized header field today. This is the same property that allowed SPF, DKIM1, DMARC and ARC to be deployed incrementally across a heterogeneous ecosystem without flag-day transitions.</t>
        <t>Milter-first - the milter interface is the deployment mechanism that has enabled incremental adoption of every successful email authentication protocol. DKIM2-core is designed so that every mandatory feature is implementable as a milter without MTA core modifications. This is not a constraint imposed from outside - it is a deliberate architectural choice that maximizes the probability of adoption across the full range of operators described in Section 1.2, from large providers to small ISPs and universities.</t>
        <t>The term "milter" in the title of this document refers to the most widely deployed mechanism for extending MTA behavior without core modifications. The architectural arguments presented here apply to any filter interface that provides access to envelope callbacks during the SMTP transaction. Milter is used as the reference implementation because it is the dominant deployment model for email authentication protocols and because prototype DKIM2 implementations - including those demonstrated at the IETF hackathon - have converged on this interface independently.</t>
        <t>Stateless by design - DKIM2-core requires no persistent state between SMTP sessions. All information needed for signing and verification is available within the current session and the message headers themselves. This eliminates the need for shared storage between milter instances, reduces operational complexity and removes a category of failure modes that stateful implementations introduce. State management is only required for body recipe generation, which belongs exclusively to DKIM2-extended.</t>
        <t>These three principles together define the boundary between DKIM2-core and DKIM2-extended. Any mechanism that requires MTA core modifications, persistent inter-session state, or content parsing beyond what the milter interface provides belongs in DKIM2-extended. Any mechanism that can be implemented additively, via milter and statelessly belongs in DKIM2-core.</t>
      </section>
    </section>
    <section anchor="terminology-and-definitions">
      <name>Terminology and Definitions</name>
      <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"/>.</t>
      <t>This document uses terminology from <xref target="RFC5598"/> (Internet Mail Architecture) and inherits definitions from <xref target="I-D.ietf-dkim-dkim2-spec"/>. The following additional terms are defined for use in this document.</t>
      <dl>
        <dt>DKIM2-core:</dt>
        <dd>
          <t>The mandatory deployment profile defined in this document. DKIM2-core implements envelope binding, chain of custody, header accountability, replay prevention and DSN authentication. It is fully implementable via the milter interface without MTA core modifications and requires no persistent state between SMTP sessions.</t>
        </dd>
        <dt>DKIM2-extended:</dt>
        <dd>
          <t>The optional deployment profile defined in this document. DKIM2-extended adds body recipe generation and verification via Message-Instance headers and JSON-encoded recipes. It may require stateful milter implementations with persistent shared storage or MTA core integration.</t>
        </dd>
        <dt>Milter-capable node:</dt>
        <dd>
          <t>An MTA deployment that implements DKIM2-core functionality via the milter interface. A milter-capable node requires no modifications to the MTA core software.</t>
        </dd>
        <dt>Legacy node:</dt>
        <dd>
          <t>A node in the delivery chain that does not implement DKIM2 in any form. Legacy nodes pass DKIM2 headers through the delivery chain without interpreting them, exactly as they handle unrecognized header fields today.</t>
        </dd>
        <dt>Transparent relay:</dt>
        <dd>
          <t>A node that adds only trace headers (Received:, Return-Path:) and makes no other modifications to the message. Transparent relays do not need to participate in DKIM2 signing or verification. Note however that in practice many nominally transparent relays introduce involuntary body transformations - base64 re-encoding at different line widths, MIME reassembly by antivirus engines, whitespace normalization - that affect body hash values.</t>
        </dd>
        <dt>Reviser:</dt>
        <dd>
          <t>A node that makes intentional modifications to message headers or body. A Reviser MUST declare its modifications using DKIM2-Mod headers (DKIM2-core) or Message-Instance recipes (DKIM2-extended) and MUST add a new DKIM2 signature covering the modified message.</t>
        </dd>
        <dt>Inbound milter:</dt>
        <dd>
          <t>The milter instance responsible for verifying incoming DKIM2 signatures during the SMTP session. The inbound milter operates at EndOfBody and has access to the complete envelope state accumulated during the session via MailFromRequest and RcptToRequest callbacks.</t>
        </dd>
        <dt>Outbound milter:</dt>
        <dd>
          <t>The milter instance responsible for generating DKIM2-Mod headers and adding DKIM2 signatures to outgoing messages. The outbound milter is positioned last in the milter chain, after all other milters that may modify the message and signs the final state of the message.</t>
        </dd>
        <dt>DKIM2-Mod header:</dt>
        <dd>
          <t>A signed header field added by a Reviser to declare a modification made to an existing header field. DKIM2-Mod headers carry an instance index (i=) aligned with the DKIM2-Signature hop number, a sequence index (seq=) for multiple modifications to the same field at the same hop and an optional frame index (fr=) to split values longer than 998 characters per <xref target="RFC5322"/>.</t>
        </dd>
        <dt>Envelope binding:</dt>
        <dd>
          <t>The cryptographic binding of SMTP MAIL FROM and RCPT TO values to the DKIM2 signature at each hop, implemented via DKIM2-Sig-mf and DKIM2-Sig-rt header fields. Envelope binding prevents DKIM replay attacks by making it impossible to reuse a valid signature for a different recipient without breaking the chain.</t>
        </dd>
        <dt>Chain of custody:</dt>
        <dd>
          <t>The verifiable record of all entities that have handled a message, established by the sequence of DKIM2 signatures and envelope bindings from originator to final recipient. Each hop in the chain signs the current state of the message and references the previous hop's signature.</t>
        </dd>
        <dt>Null recipe:</dt>
        <dd>
          <t>A Message-Instance declaration that a modification was made to the message body but that the previous state cannot be reconstructed. Null recipes are only relevant in DKIM2-extended. In DKIM2-core, body modifications are declared implicitly through a changed bh= value with attribution to the signing hop.</t>
        </dd>
        <dt>Relaxed domain match:</dt>
        <dd>
          <t>The relaxed domain matching algorithm for matching the signing domain (d=) against the MAIL FROM domain, allowing subaddress schemes used for bounce handling. Labels are removed from the left side of the MAIL FROM domain until a match is found or no labels remain. Implementations MUST NOT remove more than two labels - that is, the MAIL FROM domain MUST be at most two levels below the d= domain. For example, bounce.mail.example.com matches d=example.com (two labels removed) but a.b.c.example.com does not (three labels would need to be removed). This limit is consistent with the subdomain matching defined in <xref target="RFC6376"/> Section 3.5.</t>
        </dd>
      </dl>
      <t>This document inherits definitions from <xref target="I-D.ietf-dkim-dkim2-spec"/>. Where terms are used without definition in this document, the definitions in that document apply.</t>
    </section>
    <section anchor="dkim2-core-mandatory-profile">
      <name>DKIM2-core: Mandatory Profile</name>
      <t>DKIM2-core is the mandatory deployment profile. All nodes that wish to participate in DKIM2 MUST implement DKIM2-core. Nodes that implement only DKIM2-core are fully interoperable with nodes that implement DKIM2-extended.</t>
      <t>The milter interface is an integration point, not a replacement for MTA functionality. DKIM2-core uses the milter interface to observe, verify and sign messages as they flow through the MTA's normal processing pipeline. Functions that belong to the MTA - transaction management, BCC splitting, queue handling, routing - remain with the MTA. The milter does not substitute for these functions and is not designed to do so. This separation of concerns is what makes milter-based deployment non-invasive and compatible with existing MTA infrastructure.</t>
      <section anchor="envelope-binding">
        <name>Envelope Binding</name>
        <t>Envelope binding is the primary technical contribution of DKIM2 over DKIM1 and ARC. By cryptographically binding the SMTP MAIL FROM and RCPT TO values to the message signature at every hop, DKIM2-core makes it impossible to replay a valid signature for a different recipient or sender without breaking the chain.</t>
        <t>Envelope binding is implemented via two new signed header fields: DKIM2-Sig-mf (carrying the MAIL FROM value) and DKIM2-Sig-rt (carrying the RCPT TO values).</t>
        <section anchor="envelope-binding-format">
          <name>Envelope Binding Format</name>
          <t>The DKIM2-Sig-mf field carries exactly one address - the SMTP MAIL FROM value. The DKIM2-Sig-rt field carries one or more RCPT TO values, using one header per address.</t>
          <t>Both fields use the i= instance indexing convention already established by ARC <xref target="RFC8617"/>, where ARC-Seal, ARC-Message-Signature and ARC-Authentication-Results use the same i= numbering to build a verifiable chain across multiple hops. Implementers familiar with ARC will recognize this pattern immediately. Major email providers including Google and Microsoft implement ARC natively in their infrastructure and ARC milter implementations are deployed across the ecosystem. DKIM2-Sig-mf and DKIM2-Sig-rt extend this existing pattern to carry envelope values, requiring no new parsing concepts beyond what ARC implementations already handle.</t>
          <artwork><![CDATA[
DKIM2-Sig-mf: i=1; addr=bounce@mailchimp.com
DKIM2-Sig-rt: i=1; v=1; addr=dest1@esempio.com
DKIM2-Sig-rt: i=1; v=2; addr=dest2@esempio.com
DKIM2-Sig-rt: i=1; v=3; addr="john;doe"@rare.com
]]></artwork>
          <t>One header per address, including recipients with quoted local parts. The v= tag provides a sequence number that distinguishes multiple DKIM2-Sig-rt headers at the same hop. DKIM2-Sig-mf always carries exactly one address and does not require v=.</t>
          <t>This format handles all RFC5321 local part cases including quoted local parts containing special characters - within a single header value there is no separator ambiguity regardless of the characters present in the local part. The format copies exactly the ARC instance indexing pattern, requires no new parsing logic beyond what ARC implementations already provide and produces output directly inspectable in mail logs and headers without decoding tools.</t>
          <t>The design avoids the parsing complexity that arises when envelope addresses with display names, quoted local parts or multiple addresses are embedded in more complex header formats. DKIM2-Sig-rt carries only the bare RFC5321 addr-spec - the envelope address without display name - one per header. This is the natural format for SMTP envelope values, which by definition do not carry display names. It avoids the parsing complexity of RFC5322 address-list syntax, which includes display names, group syntax and other constructs that are irrelevant for envelope binding purposes.</t>
          <t>This format could produce more bytes than the JSON+base64 encoding currently specified in <xref target="I-D.ietf-dkim-dkim2-spec"/> for messages with very many recipients. For the common case of messages with a small number of recipients - which represents the substantial majority of real-world email traffic - the size difference is negligible or absent. It remains directly human-readable without decoding tools, has a parsing complexity of O(1) per header rather than O(n) on the full recipient list and allows individual recipient membership verification without deserializing the complete list.</t>
          <t>DKIM2-core lists each RCPT TO value as an individual DKIM2-Sig-rt header, all covered by a single DKIM2-Signature. This provides per-address cryptographic binding: a verifier can confirm that the message was signed for exactly these recipients and no others. Replaying the message to a recipient not listed in a DKIM2-Sig-rt header produces a verifiable mismatch, even if that recipient is at the same domain as the original recipients. Alternative approaches such as DARA bind at the domain level - all recipients at the same destination domain share a single signature via darn=. DARA prevents replay to a different domain but does not prevent replay to a different recipient at the same domain. DKIM2-core closes this gap without requiring any additional MTA splitting beyond the standard per-domain delivery that MTAs already perform. The base specification <xref target="I-D.ietf-dkim-dkim2-spec"/> encodes rt= values as base64 without JSON in its current revision, which reduces parsing overhead but retains opacity - the values are not directly human-readable without decoding. DKIM2-core's plaintext tag-value format for envelope binding fields remains directly inspectable without tooling. DKIM2-core achieves equivalent cryptographic binding of each recipient to the signed message via the standard milter envrcpt callback, listing all transaction recipients in DKIM2-Sig-rt fields. No MTA modification is required, making the mechanism deployable by any operator regardless of infrastructure.</t>
          <t>It is worth noting that quoted local parts containing special characters such as semicolons are permitted by <xref target="RFC5321"/> but are not observed in practice in real-world email infrastructure. The format handles them correctly without any special-casing.</t>
        </section>
        <section anchor="relationship-to-existing-fromto-headers">
          <name>Relationship to Existing From:/To: Headers</name>
          <t>The DKIM2-Sig-mf and DKIM2-Sig-rt fields carry the SMTP envelope values, which may differ significantly from the RFC5322 From:, To: and Cc: header fields. This distinction is particularly important in two scenarios:</t>
          <t>Programmatic and bulk email - the envelope sender is typically a bounce handling address such as bounce-12345@mail.mailchimp.com and the envelope recipients are individual subscriber addresses that may not appear in the message headers at all. Using RFC5322 headers to infer envelope values would fail for this common case.</t>
          <t>Group syntax and empty groups - RFC5322 permits constructs such as To: Empty Group:; where the To: header carries no actual recipient addresses. The envelope RCPT TO values are the only reliable source of recipient information in these cases.</t>
          <t>Using existing RFC5322 headers to infer envelope values, as has been proposed in some alternatives, would require parsers to handle these edge cases correctly and would fail for programmatic email where no correspondence between envelope and headers exists. DKIM2-Sig-mf and DKIM2-Sig-rt carry the envelope values explicitly and independently of the IMF headers, eliminating this ambiguity.</t>
          <t>It is also worth noting that the support for multiple rt= values - rather than a single recipient per message - was motivated by a specific operational requirement from a large mailbox provider whose anti-fraud system relies on verifying consistency between envelope recipients and To:/Cc: header fields to detect messages fraudulently presented as sent to multiple recipients but actually sent to only one. This use case requires that all RCPT TO values for a given SMTP transaction be visible in the signed envelope binding.</t>
        </section>
        <section anchor="relaxed-domain-match">
          <name>Relaxed Domain Match</name>
          <t>The relaxed domain match algorithm is retained unchanged. The signing domain (d=) must match the domain of the DKIM2-Sig-mf address via relaxed domain match, allowing subaddress schemes used for bounce handling such as bounce-12345@mail.mailchimp.com to match d=mailchimp.com. The MAIL FROM domain MUST be at most two levels below the d= domain, consistent with <xref target="RFC6376"/> Section 3.5.</t>
        </section>
        <section anchor="bcc-recipients">
          <name>BCC Recipients</name>
          <t>BCC recipients require separate SMTP transactions to prevent disclosure of BCC addresses to other recipients, consistent with <xref target="RFC5322"/> Section 3.6.3. This is already best practice for correct BCC semantics independent of DKIM2 - most MTAs already split BCC recipients into separate transactions for privacy reasons. DKIM2-core makes this a cryptographic requirement in addition to a privacy requirement.</t>
          <t>The milter processes two distinct transaction types:</t>
          <t>For the To:/Cc: transaction, the milter receives all RCPT TO values in a single transaction, compares them against the To: and Cc: header fields and includes only the visible recipients in DKIM2-Sig-rt. The comparison requires address extraction from RFC5322 headers - display names and comments must be stripped to obtain bare addr-spec values - followed by case-insensitive comparison on the domain part. Note that a recipient appearing in both To: and BCC is possible but rare; in that case the milter correctly includes the address in rt= since it is a visible recipient. The signed DKIM2-Sig-rt reflects exactly the recipients who will see the message.</t>
          <t>For each BCC transaction, the MTA generates a separate SMTP transaction per BCC recipient. The milter signs each transaction independently with a single DKIM2-Sig-rt carrying that recipient's address. No special handling is required - the milter processes each BCC transaction as a normal single-recipient message.</t>
          <t>Including BCC recipients in the To:/Cc: transaction with all addresses listed in DKIM2-Sig-rt would reveal BCC addresses in the signed headers, visible to all recipients and any archiving system. This directly violates <xref target="RFC5322"/> Section 3.6.3 and MUST NOT be done.</t>
          <t>This design requires no MTA core modifications. BCC splitting is already standard MTA behavior for RFC 5322 compliance - DKIM2-core formalizes an existing practice rather than introducing a new operational burden. A future standardized mechanism for BCC signaling at the SMTP level would simplify this comparison but is not required for correct operation.</t>
          <t>The milter buffers RCPT TO values during the envrcpt callbacks and performs the comparison against To: and Cc: headers in the eom callback, when all header fields are available. Recipients present in RCPT TO but absent from To: and Cc: are identified as BCC recipients. The MTA is responsible for splitting BCC recipients into separate transactions: this is standard MTA behavior already implemented by Sendmail and Postfix for privacy reasons. The milter signs each transaction as presented, generating DKIM2-Sig-rt headers only for the recipients the MTA includes in that transaction. The splitting cost is operational, not architectural and it requires no changes to the MTA core.</t>
        </section>
        <section anchor="synthetic-hops-and-intra-admd-signing">
          <name>Synthetic Hops and Intra-ADMD Signing</name>
          <t>The base specification requires that the chain of custody form a contiguous sequence where the rt= value at hop i aligns with the mf= value at hop i+1. In deployment scenarios where multiple signatures are applied within the same administrative domain, such as an Email Service Provider signing on behalf of a brand or a vanity domain forwarded through a mailbox provider, no SMTP transaction occurs between the two signing identities.</t>
          <t>The base specification addresses this by generating synthetic DKIM2-Signature headers representing hops that never occurred at the SMTP level, requiring the invention of email addresses for transactions that never took place. Working group discussion has converged toward a declarative mechanism in which a signature asserts the domain expected to produce the next signature within the same administrative boundary, avoiding the need for an invented address - though the exact syntax remained under discussion at the time of this writing.</t>
          <t>DKIM2-core does not require this mechanism. Because DKIM2-Sig-mf and DKIM2-Sig-rt are separate header fields rather than tags within the DKIM2-Signature, the chain of custody is established by the sequence of signed headers, not by address matching between consecutive signatures. Each hop signs its own envelope values as observed in the actual SMTP transaction. If no SMTP transaction occurs, as in the ESP/brand scenario, no DKIM2-core signature is generated for that non-existent hop. The relationship between brand and ESP is a contractual arrangement, not a cryptographic assertion in the message chain.</t>
        </section>
        <section anchor="formal-syntax">
          <name>Formal Syntax</name>
          <t>The following ABNF defines the header fields introduced by this document. Rules are imported from <xref target="RFC5234"/> and <xref target="RFC5321"/> as noted.</t>
          <sourcecode type="abnf"><![CDATA[
; DKIM2-Sig-mf header field
; Carries exactly one SMTP MAIL FROM address
dkim2-sig-mf     = "DKIM2-Sig-mf:" SP dkim2-mf-params CRLF
dkim2-mf-params  = dkim2-hop-index ";" SP dkim2-addr

; DKIM2-Sig-rt header field
; Carries exactly one SMTP RCPT TO address per header
; Multiple recipients use multiple headers with incrementing v=
dkim2-sig-rt     = "DKIM2-Sig-rt:" SP dkim2-rt-params CRLF
dkim2-rt-params  = dkim2-hop-index ";" SP
                   dkim2-rcpt-index ";" SP
                   dkim2-addr

; DKIM2-Mod header field
; Declares a modification made to an existing header field
dkim2-mod        = "DKIM2-Mod:" SP dkim2-mod-params CRLF
dkim2-mod-params = dkim2-hop-index ";" SP
                   dkim2-mod-seq ";" SP
                   dkim2-field-tag
                   [ ";" SP dkim2-fr-tag ]
                   ";" SP dkim2-mod-value

dkim2-field-tag  = "field=" header-field-name
dkim2-fr-tag     = "fr=" 1*2DIGIT
                 ; DKIM2-core implementations MUST NOT use fr= values greater than 2
                 ; fragment index, 1-20
                 ; OPTIONAL - absent when value fits in single header

dkim2-mod-value  = 1*(VCHAR / WSP)
dkim2-del-tag    = "del=" dkim2-mod-value
                 ; MUST appear last in header
dkim2-new-tag    = "new=" dkim2-mod-value
                 ; MUST appear last in header

; del= and new= MUST be on separate header lines
; Presence rules per complete operation:
;   del= only  -> removal
;   new= only  -> addition
;   del= + new= -> modification


; Shared index rules
dkim2-hop-index  = "i=" 1*2DIGIT
                 ; hop sequence number, 1-20, starts at 1
dkim2-rcpt-index = "v=" 1*3DIGIT
                 ; recipient sequence number for DKIM2-Sig-rt
                 ; starts at 1, increments per recipient at same hop, 1-500
dkim2-mod-seq    = "seq=" 1*2DIGIT
                 ; modification sequence number for DKIM2-Mod, 1-20

; Address rule
dkim2-addr       = "addr=" addr-spec
                 ; addr-spec as defined in [RFC5321] Section 4.1.2
                 ; including quoted local parts

; Header field name
header-field-name = 1*( ALPHA / DIGIT / "-" )
                 ; as defined in [RFC5322] Section 2.2

; Supporting rules
tag-list         = tag-spec *( ";" tag-spec ) [ ";" ]
tag-spec         = tag-name "=" tag-value
tag-name         = ALPHA *( ALPHA / DIGIT / "_" )
tag-value        = *( %x21-3A / %x3C-7E )
                 ; printable ASCII except semicolon

domain-name      = sub-domain *("." sub-domain)
sub-domain       = 1*( ALPHA / DIGIT / "-" )
selector-name    = 1*( ALPHA / DIGIT / "-" / "_" )
base64string     = 1*( ALPHA / DIGIT / "+" / "/" / "=" )
                 ; standard base64 alphabet per [RFC4648]

; Core rules imported from [RFC5234]
ALPHA            = %x41-5A / %x61-7A
DIGIT            = %x30-39
SP               = %x20
CRLF             = %x0D %x0A
VCHAR            = %x21-7E
WSP              = SP / %x09
]]></sourcecode>
          <t>The <tt>base64string</tt> production uses the standard base64 alphabet defined in <xref target="RFC4648"/>.</t>
        </section>
        <section anchor="dkim2-signature-envelope-tags">
          <name>DKIM2-Signature Envelope Tags</name>
          <sourcecode type="abnf"><![CDATA[
; DKIM2-Signature envelope tags
; These tags appear within the DKIM2-Signature header field
; as defined in [I-D.ietf-dkim-dkim2-spec]

dkim2-sig-tag-i  = %x69 "=" 1*2DIGIT
                 ; i= hop sequence number
                 ; MUST start at 1 and increment by 1 at each signing hop
                 ; gaps in sequence MUST be treated as making the message unsigned

dkim2-sig-tag-v  = %x76 "=" 1*3DIGIT
                 ; v= value sequence number
                 ; used in DKIM2-Sig-rt to distinguish
                 ; multiple recipients at the same hop
                 ; MUST start at 1 and increment by 1

dkim2-sig-tag-d  = %x64 "=" domain-name
                 ; d= signing domain

dkim2-sig-tag-s  = %x73 "=" selector-name
                 ; s= selector

dkim2-sig-tag-bh = %x62 %x68 "=" base64string
                 ; bh= body hash

dkim2-sig-tag-b  = %x62 "=" base64string
                 ; b= signature value

dkim2-sig-tag-hh = %x68 %x68 "=" base64string
                 ; hh= header hash
                 ; hash of all non-excluded message header fields
                 ; computed before signing, using alphabetical ordering by lowercase field name
                 ; OPTIONAL in DKIM2-core signatures

; Tag-value list structure - as defined above
]]></sourcecode>
        </section>
      </section>
      <section anchor="chain-of-custody">
        <name>Chain of Custody</name>
        <t>Each hop in the delivery chain MUST add a DKIM2-Signature header field signing the current state of the message. The chain of custody is established by the sequence of signatures and envelope bindings from originator to final recipient.</t>
        <t>DKIM2-core verification is hop-by-hop, not end-to-end. Each hop verifies the previous signature against the body it actually receives at the time of receipt. Attribution of body modifications does not require post-facto reconstruction: if bh= changes between hop N and hop N+1, the signing domain at hop N+1 is cryptographically identified as the modifier at the moment N+1 signs. No subsequent reconstruction is needed to establish who modified the body - the chain of signatures provides this attribution directly and verifiably.</t>
        <section anchor="signature-content">
          <name>Signature Content</name>
          <t>The DKIM2-Signature at each hop covers:</t>
          <ul spacing="normal">
            <li>
              <t>All DKIM2-Sig-mf and DKIM2-Sig-rt headers with the current i= value</t>
            </li>
            <li>
              <t>All DKIM2-Mod headers with i= values less than or equal to the current hop</t>
            </li>
            <li>
              <t>All previous DKIM2-Signature headers</t>
            </li>
            <li>
              <t>The incomplete current DKIM2-Signature header with the signature value absent</t>
            </li>
          </ul>
        </section>
        <section anchor="body-hash">
          <name>Body Hash</name>
          <t>Each hop MUST calculate and include a body hash (bh=) of the current message body using the canonicalization algorithm specified in the signature. The bh= value changes whenever the body is modified, providing implicit notification that a modification occurred and attribution of that modification to the signing hop.</t>
          <t>No body recipe or reconstruction is required or expected in DKIM2-core. The change in bh= value between hops, combined with the identity of the signing domain at the modifying hop, provides sufficient accountability for delivery decisions.</t>
        </section>
        <section anchor="sequence-numbering">
          <name>Sequence Numbering</name>
          <t>DKIM2-Signature headers are numbered sequentially starting at i=1. Gaps in the sequence MUST be treated as making the message unsigned. Implementations MUST enforce the following per-type limits as a denial-of-service mitigation:</t>
          <ul spacing="normal">
            <li>
              <t>i= (hop index): MUST NOT exceed 20. A realistic worst-case delivery path including nested mailing lists and security gateways at both ends does not exceed 15-16 hops; 20 provides margin without permitting pathological chains.</t>
            </li>
            <li>
              <t>v= (recipient sequence): MUST NOT exceed 500 per hop. This is consistent with the recipient limits enforced by major MTA implementations.</t>
            </li>
            <li>
              <t>seq= (modification sequence): MUST NOT exceed 20 per hop per field. A single hop modifying more than 20 instances of the same header field is not a legitimate scenario.</t>
            </li>
            <li>
              <t>fr= (fragment index): In DKIM2-core, implementations MUST NOT exceed 2 fragments per declaration. This limit reflects the practical constraint that a standard <xref target="RFC5322"/> header field value cannot exceed 998 characters, requiring at most one continuation frame when combined with the DKIM2-Mod tag overhead of approximately 30 characters. A limit of 20 fragments would only be relevant if recipe content were transported in DKIM2-Mod headers - a use case that depends on architectural decisions about recipe storage not yet resolved in the base specification <xref target="I-D.ietf-dkim-dkim2-spec"/>. DKIM2-extended implementations MAY increase this limit when recipe transport in headers is formally specified.</t>
            </li>
          </ul>
          <t>In addition, implementations MUST reject messages whose total size of DKIM2-specific headers (DKIM2-Signature, DKIM2-Sig-mf, DKIM2-Sig-rt and DKIM2-Mod) exceeds 128KB. This global byte cap is a secondary defense-in-depth measure; the per-type limits above are the primary mitigation.</t>
        </section>
        <section anchor="signed-header-set">
          <name>Signed Header Set</name>
          <t>The DKIM2 signature at each hop covers a specific set of header fields. The signed header set MUST include:</t>
          <ul spacing="normal">
            <li>
              <t>All DKIM2-Sig-mf headers with i= value equal to the current hop</t>
            </li>
            <li>
              <t>All DKIM2-Sig-rt headers with i= value equal to the current hop</t>
            </li>
            <li>
              <t>All DKIM2-Mod headers with i= value less than or equal to the current hop. DKIM2-Mod headers are subject to the same canonicalization rules as other signed headers per <xref target="RFC6376"/> Section 3.4. The del= and new= values are canonicalized as header field values - line endings are normalized and folding whitespace is handled per the canonicalization algorithm specified in the signature.</t>
            </li>
            <li>
              <t>All previous DKIM2-Signature headers with i= value less than the current hop</t>
            </li>
            <li>
              <t>The incomplete current DKIM2-Signature header with the b= value set to empty or a placeholder as defined in <xref target="I-D.ietf-dkim-dkim2-spec"/></t>
            </li>
          </ul>
          <t>Received:, Return-Path: and other transport trace headers are excluded from the signed header set. They are also excluded from the hh= computation as specified in Section 3.2.5.</t>
          <t>Header fields not listed above MAY be included in the signed header set at the discretion of the signer. Signers SHOULD include headers that have security relevance for the message - From:, To:, Subject:, Date: - and SHOULD declare their inclusion or exclusion consistently across all messages.</t>
          <t>The b= value is calculated over the signed header set using the canonicalization algorithm specified in the signature, following the same procedure defined in <xref target="RFC6376"/> Section 3.7 with the modifications for DKIM2 header ordering defined in <xref target="I-D.ietf-dkim-dkim2-spec"/>.</t>
          <t>Implementations MUST NOT assume that header fields arrive in a specific order. The signed header set is identified by field name and instance index (i=, seq=), not by physical position in the message. Intermediate MTA software may reorder header fields during transit without affecting chain of custody verification, since canonical ordering is established through the i= and seq= index values embedded in DKIM2-Sig-mf, DKIM2-Sig-rt and DKIM2-Mod headers. Implementations MUST use these index values, not header field position, to reconstruct the chain of custody.</t>
        </section>
        <section anchor="header-hash-hh">
          <name>Header Hash (hh=)</name>
          <t>The hh= tag contains a hash of all message header fields not excluded from the signed header set. This tag is OPTIONAL in DKIM2-core signatures. When present, it enables additional hop-by-hop integrity verification of declared modifications: while b= and DKIM2-Mod already provide cryptographic proof of each hop's own declarations, hh= with the rollback mechanism described in Section 3.3.6 allows each hop to verify that its predecessor has not omitted undeclared header modifications.</t>
          <t>The following header fields are excluded from the hh= computation:</t>
          <ul spacing="normal">
            <li>
              <t>Headers managed by DKIM2 itself: DKIM2-Signature, DKIM2-Sig-mf, DKIM2-Sig-rt, DKIM2-Mod</t>
            </li>
            <li>
              <t>Headers with independent authentication mechanisms: DKIM-Signature, ARC-*</t>
            </li>
            <li>
              <t>Headers that change legitimately at every hop: Received, Return-Path, Authentication-Results</t>
            </li>
            <li>
              <t>Vendor-specific diagnostic headers: X-MS-<em>, X-GM-</em></t>
            </li>
          </ul>
          <t>All remaining header fields, including other X-* headers, are included in the hh= computation. The rationale for including non-vendor X-* headers and the security implications of excluding them are discussed in Section 8.</t>
          <t>The hash algorithm used for hh= MUST match the algorithm used for bh= in the same DKIM2-Signature, as specified in the a= tag.</t>
          <t>Canonicalization follows the DKIM1 relaxed algorithm per <xref target="RFC6376"/> Section 3.4: header field names are lowercased, whitespace is normalized and continuation lines are unfolded.</t>
        </section>
      </section>
      <section anchor="header-accountability">
        <name>Header Accountability</name>
        <t>When a Reviser modifies, removes or adds a header field, it MUST declare the change by adding one or more DKIM2-Mod headers before signing. These headers MUST be included in the signed header set of the modifying hop and all subsequent hops, making the declaration cryptographically bound to the chain.</t>
        <section anchor="modification-cases">
          <name>Modification Cases</name>
          <t>Modification - header existed and its value was changed. del= and new= on separate headers with same i= and seq=:</t>
          <artwork><![CDATA[
DKIM2-Mod: i=2; seq=1; field=Subject; del="Original subject text"
DKIM2-Mod: i=2; seq=1; field=Subject; new="Modified subject text"
]]></artwork>
          <t>Removal - header existed and was removed. Only del=:</t>
          <artwork><![CDATA[
DKIM2-Mod: i=2; seq=1; field=Subject; del="Removed subject text"
]]></artwork>
          <t>Addition - header did not exist and was added. Only new=:</t>
          <artwork><![CDATA[
DKIM2-Mod: i=2; seq=1; field=List-Id; new=<lista@esempio.com>
]]></artwork>
          <t>Note that new= is technically redundant for additions since the added value is already visible in the message headers. It is declared explicitly to provide an unambiguous cryptographic binding between the modification declaration and the hop signature, particularly in cases where multiple headers of the same type exist in the message.</t>
          <t>When a DKIM2-Mod header with del= and a DKIM2-Mod header with new= share the same (i=, seq=, field=) tuple, they MUST be interpreted as a single modification operation representing a value change. Implementations MUST NOT interpret them as independent operations - that is, as a removal followed by an unrelated addition. The tuple (i=, seq=, field=) is the sole correlating key. When present as a pair, the del= header MUST precede the new= header in the message.</t>
          <t>The dkim2-mod-value production requires at least one character - empty string values are not permitted. A header field whose value is the empty string is treated as absent for the purposes of DKIM2-Mod declarations.</t>
        </section>
        <section anchor="multiple-modifications">
          <name>Multiple Modifications</name>
          <t>Multiple instances of the same field, each with its own seq=:</t>
          <artwork><![CDATA[
DKIM2-Mod: i=2; seq=1; field=X-EVALUATION; del="pippo"
DKIM2-Mod: i=2; seq=1; field=X-EVALUATION; new="paperino"
DKIM2-Mod: i=2; seq=2; field=X-EVALUATION; del="pluto"
DKIM2-Mod: i=2; seq=2; field=X-EVALUATION; new="paperone"
]]></artwork>
          <t>Successive hops use their own i=:</t>
          <artwork><![CDATA[
DKIM2-Mod: i=2; seq=1; field=Subject; del="Value before hop 2"
DKIM2-Mod: i=2; seq=1; field=Subject; new="Value after hop 2"
DKIM2-Mod: i=3; seq=1; field=Subject; del="Value after hop 2"
DKIM2-Mod: i=3; seq=1; field=Subject; new="Value after hop 3"
]]></artwork>
          <t>The del= and new= tags MUST appear last in the DKIM2-Mod header field value. All other tags (i=, seq=, field=, fr=) MUST precede them.</t>
        </section>
        <section anchor="long-values">
          <name>Long Values</name>
          <t>For values that exceed practical inline length, implementations MAY use the optional fr= tag to split across multiple headers with incrementing fr= values. fr= is independent for del= and new=:</t>
          <artwork><![CDATA[
DKIM2-Mod: i=2; seq=1; field=X-Microsoft-Antispam; fr=1; del="first part..."
DKIM2-Mod: i=2; seq=1; field=X-Microsoft-Antispam; fr=2; del="...second part..."
DKIM2-Mod: i=2; seq=1; field=X-Microsoft-Antispam; fr=3; del="...third part"
DKIM2-Mod: i=2; seq=1; field=X-Microsoft-Antispam; new="new value"
]]></artwork>
          <t>fr= absent means value is complete in that single header. When fr= is present, headers with same i=, seq=, field= and same tag type (del= or new=) are concatenated in fr= order.</t>
          <t>Implementations that do not support fr= MUST treat a fragmented declaration as a null declaration for that field.</t>
          <t>Fragments MUST be concatenated without any intervening whitespace or separators. The reconstructed value is the exact concatenation of the fragment values in fr= order.</t>
          <t>The fr= tag value MUST be a positive integer starting at 1. A value of 0 or any negative value is malformed and MUST cause verification of that DKIM2-Mod declaration to fail. Fragments MAY appear in any physical order within the header set - implementations MUST reassemble them by fr= value rather than by physical position. If the fr= sequence contains a gap - that is, if fragment N is present but fragment N-1 is absent - verification of that DKIM2-Mod declaration MUST fail. Partial reconstruction from available fragments MUST NOT be attempted. A gap in the fr= sequence or a malformed fr= value SHOULD be logged as a potential integrity violation.</t>
        </section>
        <section anchor="relationship-to-existing-conventions">
          <name>Relationship to Existing Conventions</name>
          <t>DKIM2-Mod headers formalize and cryptographically bind the informal X-Original- convention already widely deployed in the ecosystem. Systems using X-Original-From, X-Original-Subject and similar headers preserve previous header values across intermediary modifications - the same semantic goal as the del= tag in DKIM2-Mod. The key difference is that DKIM2-Mod declarations are included in the signed header set and cryptographically bound to the chain of custody, making them verifiable rather than merely informational.</t>
          <t>This pattern is already practiced informally in the ecosystem - for example, Google Groups preserves the original sender address in an X-Original-Sender header alongside its own Sender: field. DKIM2-Mod formalizes this existing convention by making the declaration cryptographically signed and part of the verifiable chain of custody, rather than an informational annotation with no authentication binding.</t>
          <t>This approach has precedent in <xref target="I-D.chuang-mailing-list-modifications"/>, which proposed X-Prior- headers and Content-Footer headers as ARC extensions for the same purpose, declaring mailing list modifications in human-readable form without JSON encoding. DKIM2-Mod formalizes and generalizes this approach within the DKIM2 chain of custody framework.</t>
        </section>
        <section anchor="header-order-and-multiple-instances">
          <name>Header Order and Multiple Instances</name>
          <t>DKIM2-core signatures cover a defined set of header fields. The mandatory signed header set is specified in Section 3.2.4. Signers MAY additionally include security-relevant header fields such as From:, Subject: and Reply-To: by declaring them in the signature.</t>
          <t>DKIM2-core signatures protect header fields at two levels. The h= tag in DKIM2-Signature covers the mandatory set of security-critical header fields, providing value-level protection consistent with DKIM1. The optional hh= tag provides set-level integrity for all non-excluded header fields, detecting undeclared additions and removals as described in Section 3.2.5.</t>
          <t>When multiple header fields with the same name exist, their relative physical order in the message may be altered by intermediate systems - milters, antivirus scanners and content filters routinely reconstruct messages in ways that can reorder header fields with identical names. If the signed header set includes such fields and their order changes, any existing signature covering the original order will no longer validate.</t>
          <t>DKIM2-core addresses this through a two-level ordering strategy that minimises the surface area of ambiguous sorting.</t>
          <t>The first level covers all header fields included in the hh= computation. These are sorted alphabetically by lowercase field name. For most header fields, <xref target="RFC5322"/> prohibits multiple instances at origination, so this sort operates on unique keys and is fully deterministic. This ordering is required at every hop that computes hh=, making it a wire-level constraint - but one that operates on field names only, not on field values, and that produces a fixed-size hash rather than an ordered sequence that downstream verifiers must reconstruct.</t>
          <t>The second level handles duplicate instances of the same header field using explicit i= and seq= index values declared via DKIM2-Mod, rather than physical position in the message. This is an integer lookup, not a string sort, and is unambiguous by construction. Section 3.3.6 defines the precise verification procedure.</t>
          <t>A residual case exists: header fields that <xref target="RFC5322"/> permits in multiple instances at origination (such as Comments: and Keywords:) and that have no corresponding DKIM2-Mod entries. These instances are not attributed to any DKIM2-Mod declaration and must be disambiguated by a secondary sort on canonicalised field value. This sort is limited in scope - it applies only to the narrow set of <xref target="RFC5322"/> multi-instance fields, which are rare in production traffic. If a field that <xref target="RFC5322"/> defines as singular appears in multiple instances without a corresponding DKIM2-Mod declaration, this is a protocol violation; the verifier's required handling of this case is given in Section 3.3.6.</t>
          <t>Both DKIM2-core and the DKIM2 base specification <xref target="I-D.ietf-dkim-dkim2-spec"/> require ordering computations. The difference is in the scope and determinism of the sort. The base specification mandates alphabetical ordering of all header field names with bottom-up ordering for duplicate names - a sort that operates on the full header set including body recipes, whose size grows with message complexity and delivery path length. The sort result depends on the stability of the sort implementation, on tie-breaking rules for headers with the same name and on how headers containing non-ASCII characters are ordered - all points where independent implementations can and do diverge. Interoperability testing at the IETF 124 hackathon confirmed failures between independent implementations attributable to disagreements on tag ordering within DKIM2-Signature fields - a simpler problem than duplicate header ordering, yet sufficient to cause failures.</t>
          <t>DKIM2-core reduces the surface of ordering ambiguity to the minimum achievable without eliminating ordering entirely. Field-name sorting is deterministic on unique ASCII-lowercase keys. Duplicate ordering uses explicit integer indices for all hop-introduced instances. Value-based sorting is confined to the residual case of originals not attributed to any DKIM2-Mod declaration for <xref target="RFC5322"/> multi-instance fields - a corner case that is rare in practice and bounded in scope. The base specification has no equivalent mechanism for disambiguating duplicates without relying on physical header position, which intermediate systems may alter.</t>
        </section>
        <section anchor="hop-by-hop-header-integrity-verification">
          <name>Hop-by-Hop Header Integrity Verification</name>
          <t>When a verifier at hop i=N receives a message carrying an hh= tag, it performs verification in two sequential steps. This mechanism requires that all hops in the chain include hh= in their DKIM2-Signature.</t>
          <t>The verifier first establishes the canonical header set: all header fields present in the received message are ordered alphabetically by lowercase field name. Duplicate fields are ordered using the DKIM2-Mod declarations of hop i=N-1: fields without a corresponding DKIM2-Mod entry are originals; fields declared via DKIM2-Mod are ordered by their i= and seq= values. A duplicate field instance that cannot be explained by any DKIM2-Mod declaration in the chain is treated as an original field present at origination. If a header field defined as single-instance by <xref target="RFC5322"/> appears more than once, each additional instance beyond the first MUST be accounted for by a corresponding DKIM2-Mod with a new= declaration. Unaccounted duplicates of single-instance fields constitute a protocol violation and the verifier MUST treat it as a verification failure.</t>
          <t>The first step verifies the integrity of what hop i=N-1 signed. The verifier recomputes hh= over the canonical header set and compares the result against the hh= value declared in the DKIM2-Signature of hop i=N-1. If the values differ, the header set has been altered since hop i=N-1 signed it and the verifier MUST treat this as a verification failure.</t>
          <t>The second step is OPTIONAL and verifies that hop i=N-1 has not lied about its own declared modifications. The verifier applies the DKIM2-Mod declarations of hop i=N-1 in reverse: additions declared via new= are removed from the header set and removals declared via del= are restored to the header set with their original values. Modifications declared via both del= and new= are reversed by removing the new= value and restoring the del= value. The result is the header state as it should have been at hop i=N-2 according to what hop i=N-1 has declared. The verifier then recomputes hh= over this reconstructed header set and compares it against the hh= value declared in the DKIM2-Signature of hop i=N-2. If the values differ, hop i=N-1 has declared modifications that do not account for all changes it made and the verifier MUST treat this as a verification failure. In the transitional deployment phase described in Section 5.6, the verifier MAY record a dkim2=fail result in the DKIM2-Authentication-Results header rather than rejecting the message.</t>
          <t>This check is a single step backward, not a full chain traversal. Each honest hop performs the same check on its predecessor, so a lie introduced at any point in the chain is detected at the immediately following hop rather than at the final receiver. This property means that the chain self-validates during transit without requiring the receiver to reconstruct the entire message history.</t>
          <t>At i=1 there are no DKIM2-Mod declarations. The hh= value at i=1 covers the original header set and serves as the baseline against which hop i=2 will perform its rollback check.</t>
          <t>The mechanism does not require trust in intermediaries. Each hop verifies the previous signature cryptographically before signing its own. A hop that modifies a header without declaring it in DKIM2-Mod will produce a reconstructed header set that does not match the hh= of its predecessor and the discrepancy will be detected by the next honest verifier in the chain.</t>
          <t>The h= tag in DKIM2-Signature already provides cryptographic protection for the mandatory security-critical header fields. The hh= rollback mechanism extends this protection to the full non-excluded header set. The two mechanisms are complementary: h= provides hard guarantees on critical fields regardless of whether hh= is present and hh= provides additional assurance that no undeclared modification has occurred across the complete header set.</t>
          <t>Working group discussion has confirmed that localising a verification failure to a specific hop requires hop-by-hop verification, even when end-to-end verification is used as the primary mechanism.</t>
        </section>
      </section>
      <section anchor="replay-prevention">
        <name>Replay Prevention</name>
        <t>Replay prevention is a direct consequence of envelope binding. Since DKIM2-Sig-mf and DKIM2-Sig-rt are cryptographically signed at every hop and contain the actual SMTP envelope values, it is impossible to reuse a valid signature for a different recipient without breaking the chain. An attacker who attempts to replay a message to a recipient not listed in DKIM2-Sig-rt will produce a mismatch between the signed rt= value and the actual RCPT TO of the new transaction, which MUST be rejected by a conformant verifier.</t>
        <t>Mailing list redistribution is not a replay attack. When a mailing list receives a message and redistributes it to subscribers, it adds its own DKIM2 signature with its own mf= and rt= values, explicitly declaring the redistribution. The chain of custody shows the original sender, the mailing list and the final recipient as distinct entities in the chain.</t>
      </section>
      <section anchor="dsn-and-bounce-authentication">
        <name>DSN and Bounce Authentication</name>
        <t>DKIM2-core provides the infrastructure for authenticated Delivery Status Notifications (DSNs) that prevent backscatter to innocent sender domains.</t>
        <section anchor="verification-during-smtp-session">
          <name>Verification During SMTP Session</name>
          <t>DKIM2-core verification is performed during the SMTP session at two distinct points:</t>
          <t>During RCPT TO - the inbound milter MAY perform local policy checks based on the envelope sender and recipient, for example checking against local allowlists or denylists. No DKIM2-specific verification is possible at this stage because the message headers, including DKIM2 signatures, have not yet been received.</t>
          <t>At EndOfBody - full signature verification is performed when the complete message and accumulated envelope state are available. The inbound milter verifies the DKIM2 signature chain, the envelope binding in DKIM2-Sig-mf and DKIM2-Sig-rt and the consistency of DKIM2-Mod declarations with the signed header set. The milter then returns one of the following to instruct the MTA:</t>
          <ul spacing="normal">
            <li>
              <t>SMFIS_CONTINUE - the message is correctly signed and the chain is valid; the MTA proceeds with delivery</t>
            </li>
            <li>
              <t>SMFIS_REJECT - the signature is invalid, the chain is broken or the envelope binding does not match; the MTA issues a 5xx rejection to the connected peer</t>
            </li>
            <li>
              <t>SMFIS_TEMPFAIL - a transient error occurred, for example a DNS timeout during key lookup; the MTA issues a 4xx temporary failure to the connected peer</t>
            </li>
          </ul>
          <t>When the milter returns SMFIS_REJECT, the MTA issues a 5xx rejection directed at the connected peer - the system currently delivering the message over the active SMTP connection. This rejection is never directed at the original envelope sender. This is the fundamental mechanism that prevents backscatter: no DSN is ever generated toward an address that was not the source of the current SMTP session.</t>
        </section>
        <section anchor="reject-propagation-and-backscatter-prevention">
          <name>Reject Propagation and Backscatter Prevention</name>
          <t>When a DKIM2-core node rejects a message with 5xx during the SMTP session, the connected peer (the previous hop in the delivery chain) receives the rejection and is responsible for generating its own rejection toward its own peer in turn. Each hop manages its own rejection independently. The original sender is reached through this chain of independent rejections without generating backscatter at any point.</t>
          <t>A node that accepts a message with an invalid or missing DKIM2 signature and subsequently generates a DSN to the original envelope sender violates a MUST NOT in the protocol and produces backscatter. During the transition period, nodes MAY accept messages with invalid or missing DKIM2 signatures as a matter of local policy while adoption is incomplete. Nodes that do so MUST NOT generate DSNs to the original envelope sender - they MUST either discard silently or generate DSNs only to the connected peer.</t>
        </section>
        <section anchor="authenticated-dsn-generation">
          <name>Authenticated DSN Generation</name>
          <t>A node that has accepted a DKIM2-signed message and needs to generate a DSN does not need to possess a signing key aligned with the rt= value of the incoming signature. It needs only to sign the DSN with a key authorized for its own domain and direct it to the connected peer that delivered the original message. The DSN propagates back along the chain via the same hop-by-hop rejection mechanism described in Section 3.5.2.</t>
          <t>This is ordinary outbound signing, not a DSN-specific mechanism. The DSN itself is produced by standard MTA bounce-generation logic, independently of DKIM2; the milter's role is limited to signing it as a newly originated message, exactly as it would sign any other outbound mail from the domain. The bounce carries no DKIM2 signatures from the original delivery chain and there is no chain-of-custody state to extract, redact or forward from the rejected message into the bounce - a class of complexity that arises only when a DSN mechanism is required to carry and selectively strip prior chain state.</t>
        </section>
        <section anchor="transition-period-behavior">
          <name>Transition Period Behavior</name>
          <t>During the transition period when DKIM2-capable and legacy nodes coexist, a receiver that gets a message without a valid DKIM2 signature cannot perform DKIM2-specific verification - envelope binding, chain of custody validation and authenticated DSN generation toward the connected peer are not available. The receiver falls back to pre-DKIM2 behavior: verify DKIM1 signatures if present, apply DMARC policy if configured and generate DSNs as today - including the backscatter risk that DKIM2 was designed to eliminate. Backscatter prevention is only fully effective when all intermediate nodes participate in DKIM2. A single legacy node in the chain breaks authenticated DSN propagation for downstream receivers. This is a known limitation of the transition period addressed in Section 5.</t>
        </section>
      </section>
      <section anchor="cryptographic-algorithms">
        <name>Cryptographic Algorithms</name>
        <t>DKIM2-core mandates support for RSA-SHA256 and Ed25519-SHA256 signing algorithms as defined in <xref target="I-D.ietf-dkim-dkim2-spec"/>. Verifiers MUST implement both algorithms. Signers SHOULD implement both algorithms and MAY sign a message with multiple algorithms simultaneously - for example RSA-SHA256 for compatibility with legacy verifiers and Ed25519-SHA256 for efficiency. The tag-value format of DKIM2-Signature imposes no constraints on the signing algorithm beyond producing a binary output encodable in base64. This ensures forward compatibility with post-quantum algorithms when they are standardized for use in email authentication.</t>
        <t>When a message carries signatures for multiple algorithms at the same hop, a verifier that supports all those algorithms MUST treat the failure of any one signature as invalidating the entire hop. A partial pass - where one algorithm verifies and another fails - MUST be treated as a verification failure. This prevents downgrade attacks where an attacker invalidates the stronger algorithm signature to force acceptance based solely on the weaker one.</t>
        <t>For body hash calculation, DKIM2-core supports both relaxed and strict canonicalization as defined in <xref target="RFC6376"/> Section 3.4. The choice of canonicalization algorithm is indicated in the signature and is a per-hop decision.</t>
        <t>The choice between relaxed and strict canonicalization for body hashing reflects a fundamental tradeoff documented in <xref target="RFC6376"/> Appendix B. Relaxed canonicalization tolerates common benign transformations made by intermediate systems - whitespace normalization, line ending conversion, quoted-printable to 8bit transcoding - at the cost of reduced sensitivity to intentional modifications. Strict canonicalization detects all byte-level changes but is more sensitive to involuntary transformations. DKIM2-core implementations that include legacy infrastructure in their deployment path SHOULD use relaxed canonicalization for body hashing to maximize chain continuity.</t>
      </section>
      <section anchor="milter-implementation">
        <name>Milter Implementation</name>
        <t>DKIM2-core is designed to be implementable via the milter interface without modifications to MTA core software. This section describes the recommended deployment patterns.</t>
        <section anchor="two-milter-pattern">
          <name>Two-Milter Pattern</name>
          <t>The recommended implementation uses two milter instances. The protocol flow described in Section 3.5 maps to the milter callbacks as follows:</t>
          <t>Inbound milter - runs on the receiving MTA. Operates at two points in the SMTP session:</t>
          <ul spacing="normal">
            <li>
              <t>During RCPT TO: MAY perform local policy checks based on the envelope sender and recipient - for example checking against local allowlists or denylists. No DKIM2-specific verification is possible at this stage because the message headers, including DKIM2 signatures, have not yet been received.</t>
            </li>
            <li>
              <t>At EndOfBody: performs full DKIM2 verification with access to the complete message and accumulated envelope state from MailFromRequest and RcptToRequest callbacks. The milter verifies the DKIM2 signature chain, the envelope binding in DKIM2-Sig-mf and DKIM2-Sig-rt and the consistency of DKIM2-Mod declarations with the signed header set. The milter returns SMFIS_REJECT to instruct the MTA to issue a 5xx rejection, SMFIS_TEMPFAIL for transient errors or SMFIS_CONTINUE to accept.</t>
            </li>
          </ul>
          <t>The inbound milter requires no persistent state between sessions - all information needed for verification is available within the current SMTP session.</t>
          <t>Implementations using RSA-SHA256 MAY initiate DNS key lookup at EndOfHeaders as an optimization when d= and s= are available from the DKIM2-Signature header, reducing the time spent waiting for DNS resolution at EndOfBody. Implementations using Ed25519-SHA256 or supporting multiple algorithms MUST defer all DNS lookups and signature operations to EndOfBody, where the complete signed header set is available. Full signature verification including body hash comparison MUST be performed at EndOfBody regardless of algorithm.</t>
          <t>Outbound milter - runs on the transmitting MTA, positioned last in the milter chain after all other milters that may modify the message. Operates at EndOfBody with access to:</t>
          <ul spacing="normal">
            <li>
              <t>The complete message in its final state after all other milters</t>
            </li>
            <li>
              <t>Envelope values accumulated via MailFromRequest and RcptToRequest callbacks</t>
            </li>
            <li>
              <t>All DKIM2-Mod headers added by modifying entities earlier in the chain</t>
            </li>
          </ul>
          <t>Constructs DKIM2-Sig-mf and DKIM2-Sig-rt from envelope values, validates the formal correctness of any DKIM2-Mod headers present and adds the DKIM2 signature covering the final state of the message. Requires no persistent state between sessions.</t>
          <t>The inbound milter is inactive on outbound traffic and the outbound milter is inactive on inbound traffic - this is standard milter behavior already implemented and deployed.</t>
          <t>The two milter instances do not need to run on the same server. Each hop in the delivery chain signs independently with its own key. The inbound milter of hop N and the outbound milter of hop N+1 have no need to communicate - the chain of custody is established through the signed headers in the message itself.</t>
        </section>
        <section anchor="responsibility-for-declaring-modifications">
          <name>Responsibility for Declaring Modifications</name>
          <t>A fundamental principle of DKIM2-core is that every entity that modifies a message MUST declare its modifications via DKIM2-Mod headers at the time of modification. This responsibility belongs to the entity that makes the modification, not to the signing milter.</t>
          <t>This principle has an important architectural consequence: the outbound milter does not need to reconstruct what was changed by comparing the current message with a previously cached version. It trusts that modifications have already been declared by whoever made them and signs the message as presented. This eliminates the need for stateful milter implementations with persistent shared storage in the DKIM2-core profile.</t>
          <t>Implementations that delegate modification declaration to the signing milter rather than to the modifying entity - requiring the milter to infer changes by comparing with a cached copy - are technically possible but architecturally unsound. They couple the signing infrastructure to the modification logic in ways that create operational fragility and are incompatible with the stateless deployment model described here.</t>
        </section>
        <section anchor="mailing-list-managers-delegating-to-an-mta">
          <name>Mailing List Managers Delegating to an MTA</name>
          <t>When a mailing list manager such as Mailman, mlmmj or Sympa passes messages to a local MTA for transmission, the recommended pattern is:</t>
          <ul spacing="normal">
            <li>
              <t>The list manager modifies the message - adding List-* headers, modifying Subject, appending footer</t>
            </li>
            <li>
              <t>The list manager adds DKIM2-Mod headers declaring each modification it made</t>
            </li>
            <li>
              <t>The list manager submits the message to the local MTA, forcing the MAIL FROM to the list bounce address</t>
            </li>
            <li>
              <t>The outbound milter on the MTA constructs DKIM2-Sig-mf and DKIM2-Sig-rt from the envelope values and signs the message</t>
            </li>
          </ul>
          <t>List managers that cannot be modified to add DKIM2-Mod headers MAY rely on the outbound milter to detect undeclared modifications by comparing the signed headers against the incoming DKIM2 signature. However this approach requires stateful milter operation and is therefore classified as DKIM2-extended behavior. It is NOT part of the DKIM2-core profile.</t>
        </section>
        <section anchor="mailing-list-managers-with-integrated-smtp">
          <name>Mailing List Managers with Integrated SMTP</name>
          <t>Some mailing list managers - including mlmmj and similar lightweight implementations - can open SMTP connections directly without passing through a local MTA. These implementations act as their own MTA for the purpose of message transmission and MUST implement DKIM2-core signing directly, without relying on an external milter.</t>
          <t>Such implementations MUST:</t>
          <ul spacing="normal">
            <li>
              <t>Declare all modifications made to the message via DKIM2-Mod headers before signing</t>
            </li>
            <li>
              <t>Construct DKIM2-Sig-mf from the MAIL FROM value used in the SMTP transaction</t>
            </li>
            <li>
              <t>Construct DKIM2-Sig-rt from the RCPT TO values used in the SMTP transaction</t>
            </li>
            <li>
              <t>Sign the message with a key authorized for the signing domain</t>
            </li>
          </ul>
          <t>Alternatively, these implementations MAY be configured to relay through a local MTA that carries an outbound milter, delegating signing responsibility to that MTA. This is the RECOMMENDED approach for operators who wish to minimize the scope of DKIM2-core implementation.</t>
        </section>
        <section anchor="hop-counting-and-multiple-hops-within-the-same-administrative-domain">
          <name>Hop Counting and Multiple Hops Within the Same Administrative Domain</name>
          <t>When a message passes through multiple MTAs within the same administrative domain - for example, a receiving MTA that passes to a list manager that passes to a transmitting MTA - each SMTP transaction that adds a new DKIM2 signature constitutes a new hop with an incremented i= value.</t>
          <t>Operators MAY choose not to add a DKIM2 signature at intermediate hops within their own administrative domain if the intermediate hop does not modify the message and does not need to be independently attributed in the chain of custody. Transparent internal relays that add only Received: headers do not need to participate in DKIM2 signing.</t>
          <t>However, any hop that modifies the message - including a list manager - MUST be represented in the chain of custody with its own DKIM2 signature, regardless of whether that hop is within the same administrative domain as adjacent hops. A list manager's signature may be generated by the list manager itself, when it signs directly as its own MTA, or by a downstream MTA to which it delegates signing.</t>
          <t>Signing both before and after mailing list processing is supported as an optional mode. In this configuration the inbound milter verifies the previous hop and signs at i=N, the list manager adds DKIM2-Mod declarations for its modifications and the outbound milter signs at i=N+1 covering the declared modifications. This mode ensures that all outbound messages carry a DKIM2 signature regardless of the delivery path - including cases where a single submission results in both list-processed and direct-delivery copies. Operators who do not require this coverage may use the single-hop model described above.</t>
        </section>
        <section anchor="confirmation-of-milter-based-implementability">
          <name>Confirmation of Milter-Based Implementability</name>
          <t>The feasibility of implementing DKIM2-core via the milter interface without MTA core modifications has been confirmed by multiple participants in the working group discussion.</t>
          <t>Murray Kucherawy, co-chair of the DKIM working group, confirmed publicly on the working group mailing list that core MTA modifications are not necessary to add DKIM2 support via milter - consistent with the deployment model used for DKIM1, SPF, DMARC and ARC.</t>
          <t>G.W. Haywood, maintainer of Sendmail::PMilter - a Perl milter implementation supporting both Sendmail and Postfix - noted that milter protocol version 6 already provides the necessary primitives: adding, deleting and modifying headers and replacing the message body. He assessed that implementing DKIM2 via milter would not be a significant implementation effort once the specification stabilizes and expressed intent to implement DKIM2 support. John Levine subsequently confirmed on the working group list that the primary difference from existing DKIM in terms of milter implementation is access to envelope addresses - and that SMFIC_MAIL and SMFIC_RCPT callbacks already provide these in the milter protocol. He characterized the milter-based implementation of DKIM2 as a Small Matter Of Programming. G.W. Haywood concurred with this assessment.</t>
          <t>A working milter implementation of DKIM2 in Perl using Sendmail::PMilter has been published by Bron Gondwana, co-author of the DKIM2 specification, in the working group interoperability repository at https://github.com/dkim2wg/interop/. This implementation demonstrates that the milter interface provides the primitives necessary for DKIM2 implementation - including Message-Instance generation and outbound signing - without MTA core modifications. The existence of this implementation confirms the milter-based deployment model described in this document, independently of whether the full DKIM2-extended profile or only DKIM2-core is implemented.</t>
          <t>These confirmations from active MTA implementers are consistent with the DKIM2-core design principle described in this document: all mandatory functionality is expressible within the existing milter interface without requiring changes to MTA core software. An implementation of the specific deployment profile described in this document is documented in the Implementation Status section.</t>
        </section>
      </section>
    </section>
    <section anchor="dkim2-extended-optional-profile">
      <name>DKIM2-extended: Optional Profile</name>
      <section anchor="overview-and-scope">
        <name>Overview and Scope</name>
        <t>DKIM2-extended is a superset of DKIM2-core. A node that implements DKIM2-extended implements all of DKIM2-core plus the body recipe mechanism described in this section. DKIM2-extended is not a separate protocol - it is an additional layer of functionality built on top of the mandatory core profile.</t>
        <t>The body recipe mechanism allows intermediaries to describe modifications made to the message body in sufficient detail to allow reconstruction of previous versions. This capability has forensic value for operators who need to investigate message handling after the fact, audit modification chains or satisfy compliance requirements that mandate retention of original message content. Body recipes cannot provide guidance as to whether content is safe - safety determination remains in the domain of content scanning and reputation systems. The operational value of reconstruction data depends on the receiver's capacity to process it at scale, which varies enormously across the ecosystem.</t>
        <t>However, the body recipe mechanism is not required for the primary operational objectives identified in the DKIM working group charter: replay prevention, backscatter mitigation and modification attribution. These objectives are fully satisfied by DKIM2-core. The working group charter states that "the working group will prefer a result that is incremental to the deployed ecosystem" and that "proposed solutions are expected to be robust in terms of interoperability and scalability." DKIM2-extended should be evaluated against these criteria by operators considering deployment.</t>
        <t>Operators who do not require forensic body reconstruction SHOULD implement DKIM2-core only. Operators who require body accountability for compliance or forensic purposes MAY implement DKIM2-extended, subject to the operational considerations described in this section.</t>
        <t>A note on enforcement models: the deployment of DKIM2-extended cannot rely on the policy decisions of individual large providers as an enforcement mechanism. <xref target="RFC3935"/> states that the IETF works for the benefit of the Internet as a whole, not for the interests of particular entities. A protocol whose correct operation depends on major receivers choosing to penalise non-conformant implementations introduces a dependency that is outside the scope of the protocol specification and that structurally disadvantages operators who lack leverage with those receivers. DKIM2-core provides verifiable security properties through cryptographic mechanisms alone, independent of any provider's enforcement decisions. This ensures that small operators, universities, regional ISPs and non-commercial organisations can participate on equal terms.</t>
      </section>
      <section anchor="body-recipes-and-message-instance-headers">
        <name>Body Recipes and Message-Instance Headers</name>
        <t>The body recipe mechanism is described in detail in <xref target="I-D.ietf-dkim-dkim2-spec"/>. This section summarizes the mechanism and identifies operational considerations relevant to deployment decisions.</t>
        <t>A Message-Instance header is added by each hop that modifies the message body. It contains a JSON-encoded recipe - a structured description of the modifications made - encoded in base64. The recipe provides sufficient information for a verifier to reconstruct the previous version of the message body from the current version by applying the recipe in reverse.</t>
        <t>A null recipe declares that a modification was made but that the previous state cannot or should not be reconstructed. Null recipes are discussed further in Section 4.5.</t>
        <t>An alternative approach of storing the original message content in the MIME preamble or epilogue area has been discussed in the working group. This approach has two significant limitations identified during discussion: first, a substantial fraction of modern email - particularly bulk and transactional mail - is sent as single-part HTML without MIME boundaries, making preamble and epilogue areas unavailable; second, the use of these areas for structured signed content has not been tested and their behavior across the heterogeneous ecosystem of MTA and filtering software is unknown. The approach requires extensive testing before it could be considered for standardization.</t>
        <t>Furthermore, proposals to store original message content in the MIME epilogue and reference it via non-monotone copy instructions would require recipe processors to access arbitrary positions in the message rather than reading it sequentially. Working group discussion has confirmed that non-monotone recipes make streaming recipe processing with bounded memory impossible, as the processor must buffer the complete message before applying any recipe step. This eliminates the streaming processing model that DKIM1 and DKIM2-core support natively.</t>
        <t>The three architectural options for recipe transport each present fundamental limitations that cannot be resolved simultaneously. Storing recipes in message headers is subject to MTA header size limits that make the mechanism unusable for any recipe containing removed content of significant size, as documented in Section 4.3.1. Storing recipes as MIME attachments makes them visible to end users as message attachments, which is operationally unacceptable and raises additional privacy concerns. Storing recipes in the MIME preamble or epilogue requires non-monotone access patterns that make streaming processing impossible. No transport option exists that is simultaneously compatible with production MTA infrastructure, invisible to end users and streamable with bounded memory. Furthermore, any header-based recipe transport implicitly requires coordinated reconfiguration of header size limits across every MTA in the transit path - including nodes that do not implement DKIM2-extended - to prevent silent truncation. This represents a hidden dependency on ecosystem-wide MTA updates that contradicts the incremental deployment model that DKIM2 is intended to support.</t>
      </section>
      <section anchor="computational-and-traffic-overhead">
        <name>Computational and Traffic Overhead</name>
        <t>Operators considering DKIM2-extended deployment should be aware of the following overhead costs:</t>
        <t>JSON parsing in the delivery critical path - Message-Instance headers contain base64-encoded JSON that must be decoded and parsed at every verifying hop. JSON parsing introduces a dependency on a JSON library in the MTA or milter critical path. While JSON libraries are available in all languages, their presence in the delivery path introduces attack surface that does not exist in DKIM1 or DKIM2-core. Section 4.4 addresses the security implications.</t>
        <t>Traffic overhead - every message that transits DKIM2-extended-aware nodes accumulates Message-Instance headers with base64-encoded JSON recipes, additional DKIM2-Signature headers and potentially substantial body recipe content. These headers travel in the message to all recipients, including those on servers that do not implement DKIM2 at all. The overhead is not optional - it is imposed on the entire ecosystem by nodes that implement DKIM2-extended, regardless of whether downstream infrastructure can use it.</t>
        <t>Stateful milter requirement - unlike DKIM2-core, which is stateless by design, DKIM2-extended requires the signing milter to have access to the message state before and after modifications in order to calculate body recipes. This requires either a stateful milter implementation with persistent shared storage, accessible to both the inbound and outbound milter instances, or MTA core modifications that provide equivalent capability. This is a significant architectural difference from DKIM2-core and from all previous email authentication protocols.</t>
        <section anchor="recipe-size-limits-and-computational-overhead">
          <name>Recipe Size Limits and Computational Overhead</name>
          <t>The JSON recipe format introduces complexity dimensions that must be explicitly bounded to prevent denial of service attacks. Unlike DKIM1 and ARC whose computational cost is bounded and predictable, DKIM2-extended recipe processing has a cost that depends on recipe complexity - a parameter controlled by the sender or any intermediary in the delivery chain. Verification of a complete recipe chain has complexity O(n*m) where n is the number of hops with recipes and m is the maximum size of any version of the message. Both n and m grow with message complexity and delivery path length. DKIM2-core verification is O(1) per hop regardless of chain length or message size.</t>
          <t>The following limits MUST be enforced by all DKIM2-extended implementations:</t>
          <t>Maximum recipe object count</t>
          <t>Implementations MUST enforce a maximum limit on the number of top-level objects in a recipe. During the development of this specification, a limit of 50 top-level objects was proposed as a DoS mitigation measure. This value has not been formally validated and implementations MAY choose a different limit based on their operational experience. The need for any such limit is itself evidence of the attack surface introduced by the recipe mechanism.</t>
          <t>Maximum nesting depth</t>
          <t>The current specification does not define a maximum JSON nesting depth. Implementations MUST enforce a maximum nesting depth of 8 levels. This is sufficient for any legitimate MIME structure - real-world messages rarely exceed 4-5 levels of MIME nesting - while preventing attacks that use artificially deep nesting to exhaust parser stack space or trigger pathological behavior in JSON libraries.</t>
          <t>Maximum recipe size in bytes</t>
          <t>Implementations MUST enforce a maximum size for individual recipes and for the total accumulated Message-Instance header content in a message. Until normative limits are defined in <xref target="I-D.ietf-dkim-dkim2-spec"/>, implementations SHOULD enforce a maximum individual recipe size of 16KB and a maximum total Message-Instance header size of 32KB. These values are conservative estimates consistent with the header size limits enforced by production MTA software on default configurations.</t>
          <t>The recipe format uses copy-range instructions for unmodified content and literal data instructions for content that has been removed or replaced. For the common case of footer addition, copy-range instructions are compact. However, when an intermediary removes content - including attachments stripped by antivirus gateways, cloud security gateways performing DLP inspection or mailing list managers applying size or content-type policies - the removed content must be represented as literal data in the recipe. A removed attachment of n bytes produces a recipe of approximately n bytes, which then travels as a base64-encoded JSON structure in the Message-Instance header to all downstream recipients. This is the inverse of the intended purpose of attachment removal.</t>
          <t>When a removed attachment is represented as literal data in a recipe, the resulting Message-Instance header may reach sizes comparable to the removed content itself.</t>
          <t>Production MTA header size limits</t>
          <t>MTA implementations and milters that enforce header size limits - as most production systems do for operational reasons - may truncate or reject Message-Instance headers that exceed those limits, silently corrupting the recipe chain for all downstream verifiers. Postfix enforces a default header_size_limit of 102400 bytes per individual header; Sendmail enforces a default MaxHeadersLength of 32768 bytes for the total header block. A recipe containing a removed attachment of even modest size may exceed these limits on default-configured systems. The recipe size limits discussed in this section are therefore not merely a denial-of-service mitigation but a practical necessity imposed by the constraints of existing MTA infrastructure. However, any size limit that is low enough to be operationally safe is also low enough to exclude legitimate use cases involving common attachment removals and any limit high enough to accommodate those cases creates unacceptable memory pressure on constrained systems.</t>
          <t>Maximum header line count</t>
          <t>Operators with MTA configurations that enforce limits on header count or total header size MUST be aware that accumulated Message-Instance headers across multiple hops can exceed these limits, causing silent truncation that will break recipe chain verification downstream.</t>
          <t>The one concrete data point currently available is from an implementation demonstrated during the development of this specification: a message of six lines of plain text with a footer added produces a compact recipe. However, messages containing base64-encoded attachments require recipe content that describes base64 line-width re-alignment, which can produce Message-Instance headers substantially larger than the modified content itself. At the time of writing, no quantitative analysis of overhead across representative message types has been produced. Operators should evaluate this overhead against their specific traffic profiles before committing to DKIM2-extended deployment.</t>
          <t>The absence of a viable solution for attachment removal was confirmed during working group discussion at the April 2026 interim meeting <xref target="DKIM-INTERIM-2026-04"/>. The base specification authors proposed per-MIME-part hashing as a potential mechanism to allow cryptographic elision of removed attachments without null recipes. This approach was subsequently described by the lead author of the base specification as "super expensive" and "not worth the candle" - an acknowledgment that the body recipe mechanism as currently defined does not cover a fundamental use case and that the proposed alternative is operationally impractical. At the same meeting, Allen Robinson of Google confirmed that Google Workspace performs attachment removal actively in production - directly contradicting the characterization of this scenario as rare or legacy.</t>
          <t>It is worth noting that all four limits defined above are operationally motivated values derived from implementation experience rather than from principled bounds inherent in the protocol design. DKIM1 and ARC require no equivalent limits because their tag-value structure has bounded complexity by design: a tag-value list of N items has exactly N items, no recursive structures and no parser state beyond the current position in the list. The fact that DKIM2-extended requires explicit limits to prevent denial of service attacks is evidence that the recipe format introduces complexity that cannot be bounded by the protocol design itself. This is a qualitative difference from all previous email authentication protocols and should be evaluated as such by operators and implementers.</t>
          <t>Beyond CPU cycles, the requirement to reassemble fragmented Base64-encoded JSON buffers forces MTAs to move from a zero-copy or stream-oriented header processing model to a buffered model, significantly increasing the per-connection memory footprint and the pressure on memory allocation subsystems at scale. DKIM1, ARC and DKIM2-core tag-value headers can be processed in a streaming fashion with constant memory per header - each tag is read, processed and discarded. DKIM2-extended recipe processing requires accumulating the complete recipe content before any verification can begin.</t>
          <t>At tens of thousands of transactions per second, even a modest increase in per-message processing time - one millisecond of additional JSON parsing - translates to hundreds of core-seconds per second of additional load. On a server processing 50,000 messages per second, one additional millisecond per message requires 50 additional CPU cores dedicated exclusively to recipe processing.</t>
          <t>Containerized architectures support horizontal scaling to absorb this load, but scaling has latency. An attacker who sends a burst of messages with complex recipes can saturate the processing pool before the autoscaler responds. Operators running on-premise infrastructure without horizontal scaling - including universities, regional ISPs and small businesses, precisely the operators for whom milter-based deployment is most important - have no autoscaling fallback.</t>
          <t>The fundamental issue is that DKIM2-extended introduces a protocol component whose computational cost is controlled by potentially adversarial input - the recipe content - rather than being bounded by the protocol design itself. DKIM1 and ARC do not have this property.</t>
        </section>
        <section anchor="base64-re-encoding-and-recipe-complexity">
          <name>Base64 Re-encoding and Recipe Complexity</name>
          <t>Working group discussion has identified the need for additional recipe types beyond the initial design, including base64-decode-and-copy operations to handle transfer encoding changes. Each additional recipe type increases parser complexity and attack surface. This pattern of complexity growth under contact with real-world deployment scenarios is consistent with the general concern raised in this section about unbounded complexity.</t>
          <t>Base64 re-encoding with different line widths changes the body hash under both strict and relaxed canonicalization equally. Relaxed canonicalization per <xref target="RFC6376"/> Section 3.4.2 addresses trailing whitespace and internal whitespace compression but does not affect the CRLF line separators that determine base64 line boundaries. Re-wrapping base64 content at a different line width inserts CRLF sequences at different positions, producing a different hash regardless of canonicalization algorithm.</t>
          <t>The complexity of base64 re-wrapping in recipe generation has been acknowledged by the authors of the base specification. Maintaining synchronization between original and modified base64 line boundaries requires tracking both representations simultaneously and fails when the original line boundary information is unavailable due to prior intermediary processing. In practice, such cases are expected to produce null recipes.</t>
        </section>
      </section>
      <section anchor="security-considerations-for-body-recipes">
        <name>Security Considerations for Body Recipes</name>
        <t>The body recipe mechanism introduces security considerations beyond those of DKIM2-core. Three categories of concern are relevant to deployment decisions:</t>
        <t>JSON parsing attack surface - recipe processing introduces a JSON parser in the delivery critical path that processes untrusted external input. This creates attack surface that does not exist in DKIM2-core or DKIM1. The need for explicit resource limits, discussed in Section 4.3.1, is evidence that this attack surface is real.</t>
        <t>Recipe chain integrity - a malicious intermediary can construct a recipe that presents a clean original message to verifiers while delivering modified content to recipients. This attack is feasible for any compromised node in the chain.</t>
        <t>Recipe stripping - operators may strip recipe content for operational or compliance reasons, removing information that downstream verifiers depend on.</t>
        <t>These concerns are addressed in detail with normative requirements in Section 8.3.</t>
      </section>
      <section anchor="the-null-recipe-and-its-implications">
        <name>The Null Recipe and Its Implications</name>
        <t>A null recipe declares that a modification was made to the message body but that the previous state cannot be reconstructed. Null recipes are the correct response for several categories of intermediary that are common in real-world deployment:</t>
        <ul spacing="normal">
          <li>
            <t>Security gateways that rewrite URLs - the original URLs may be sensitive and should not be reconstructed</t>
          </li>
          <li>
            <t>Antivirus gateways that remove malicious attachments - the removed content should not be preserved or transmitted</t>
          </li>
          <li>
            <t>DLP systems that redact sensitive content - reconstruction would defeat the purpose of the redaction</t>
          </li>
          <li>
            <t>Legacy MTAs that perform 7bit/8bit conversion - the conversion may not be perfectly reversible</t>
          </li>
          <li>
            <t>Mailing list managers that strip attachments or filter content - Mailman supports configurable MIME type removal natively via its filter_content and filter_mime_types parameters, accessible to any list administrator without server-level configuration. Sympa supports attachment removal through custom delivery scenarios. Both represent active deployment options, not legacy configurations. A common operational variant replaces removed attachments with a URL pointing to a shared repository, preserving message flow while eliminating large or problematic content. The suggestion that lists simply reject messages containing attachments rather than stripping them does not reflect common operational practice - rejection is one option among several and stripping is frequently preferred to preserve the communication value of the message body. This is a currently deployed scenario, not a legacy or transitional case.</t>
          </li>
          <li>
            <t>Any intermediary that makes modifications it cannot or should not describe in a recipe</t>
          </li>
        </ul>
        <t>These categories collectively represent a substantial fraction of real-world email infrastructure. When any of these nodes is present in the delivery chain, the result is a null recipe at that hop - which provides no additional body accountability beyond the bh= change already available in DKIM2-core. If null recipes are acceptable at the nodes most likely to make substantial body modifications, the incremental benefit of DKIM2-extended over DKIM2-core for body accountability is limited to the cases where all intermediaries cooperate fully - which is the minority of real-world delivery paths.</t>
        <t>This is not a criticism of the body recipe mechanism. It is an accurate characterization of the deployment landscape that operators need to understand before committing to DKIM2-extended infrastructure.</t>
        <t>It is worth noting that <xref target="RFC6376"/> Appendix B already addressed the fragility of body signatures in DKIM1 through a pragmatic approach: relaxed canonicalization tolerates common benign transformations - whitespace normalization, line ending differences, quoted-printable to 8bit conversion - without requiring intermediaries to declare or reconstruct those changes. DKIM2's strict canonicalization and body recipe mechanism represent a deliberate departure from this pragmatism in favor of a deterministic reconstruction model. The null recipe outcome is the price of that departure: cases that relaxed canonicalization would have handled silently become explicit failures in the DKIM2-extended model. Operators should evaluate whether the forensic value of body reconstruction justifies this tradeoff for their specific deployment scenario.</t>
        <t>The systematic use of null recipes by security gateways is not a theoretical concern - it has been confirmed empirically by a major gateway vendor participating in this working group. Philip Guenther of Proofpoint, whose products perform substantial alteration of message headers and bodies under customer security policies, has stated explicitly on the working group list that reversibility of those changes is "the opposite of a goal" for their customers and that their products will use the null recipe mechanism "when necessary" - and will not follow the specification at all if null recipes are not available as an option.</t>
        <t>This confirmation from a major in-path gateway vendor illustrates the structural limitation of the body recipe mechanism: the nodes most likely to make substantial body modifications - security gateways, DLP systems, antivirus engines - are by design and by customer requirement the nodes that will systematically produce null recipes. The forensic value of body reconstruction is therefore unavailable precisely at the hops where attribution would matter most.</t>
        <t>This is not merely a question of adoption incentives. Allen Robinson of Google, addressing the security properties of body recipes on the working group list, noted that body hash verification is designed to require no trust in intermediaries, since each signature can be checked by reversing all later recipes back to the original content. He stated explicitly that null recipes break this property and "reintroduce the concept of trust to DKIM2," citing this as a reason not to support them. The mechanism therefore admits no resolution: disallowing null recipes is inconsistent with the operational requirements of major security gateway vendors, while allowing them concedes the trust-minimization property that is the stated rationale for body recipes in the first place.</t>
      </section>
      <section anchor="privacy-considerations-for-body-recipes">
        <name>Privacy Considerations for Body Recipes</name>
        <t>Body recipes raise data protection concerns that operators in GDPR and equivalent jurisdictions must evaluate before deployment. These concerns are addressed in detail in Section 6. A summary relevant to the deployment decision is provided here.</t>
        <t>Body recipes create structured, recoverable representations of previous message content that travel in the message to all downstream recipients and archiving systems. For most recipe types - range references, line counts - the privacy implications are limited. However for recipes that contain literal text from the original message or for the specific cases of DLP redaction and URL rewriting, the recipe mechanism may cause personal data or sensitive content to circulate in a form that was not intended by the operator that originally processed it.</t>
        <t>Operators subject to GDPR should evaluate whether body recipe generation and transmission is consistent with their data minimization obligations under Article 5 and whether their use of null recipes for sensitive content modifications is sufficient to meet their compliance requirements.</t>
      </section>
    </section>
    <section anchor="transition-and-interoperability">
      <name>Transition and Interoperability</name>
      <section anchor="overview">
        <name>Overview</name>
        <t>The deployment of DKIM2 will occur incrementally across a heterogeneous ecosystem that includes DKIM2-core nodes, DKIM2-extended nodes, DKIM1-only nodes and legacy nodes that implement no cryptographic authentication. This section describes the expected behavior of each node type in the presence of the others and identifies the properties that are and are not achievable during the transition period.</t>
      </section>
      <section anchor="node-types-and-behaviors">
        <name>Node Types and Behaviors</name>
        <t>DKIM2-core node - implements envelope binding, chain of custody, header accountability, replay prevention and DSN authentication as defined in Section 3. Adds DKIM2-Sig-mf, DKIM2-Sig-rt, DKIM2-Mod and DKIM2-Signature headers - verifies incoming DKIM2 signatures. Passes DKIM2-extended headers through without interpreting them.</t>
        <t>DKIM2-extended node - implements all of DKIM2-core plus body recipe generation and verification as defined in Section 4. Adds Message-Instance headers with JSON-encoded recipes in addition to all DKIM2-core headers.</t>
        <t>DKIM1-only node - implements DKIM1 <xref target="RFC6376"/> but not DKIM2. Passes DKIM2 headers through as unrecognized header fields. Does not add DKIM2 signatures. Does not break DKIM2 chains - it simply does not extend them.</t>
        <t>ARC node - implements ARC <xref target="RFC8617"/>. ARC and DKIM2-core address overlapping problems with different mechanisms. The relationship between ARC and DKIM2-core is described in Section 5.5.</t>
        <t>Legacy node - implements no cryptographic authentication. Passes all authentication headers through without interpreting them. Does not add signatures. Does not break chains but does not extend them.</t>
      </section>
      <section anchor="chain-continuity-and-legacy-nodes">
        <name>Chain Continuity and Legacy Nodes</name>
        <t>A legacy node in the delivery chain does not break the DKIM2 signature chain, it simply passes existing signatures through without adding new ones. A downstream receiver that encounters a message with a valid DKIM2 chain ending at a hop before the legacy node can verify the chain up to that point and apply local policy for the unsigned segment.</t>
        <t>A legacy node that makes modifications to the message - adding or changing headers, modifying the body, rewriting URLs - represents a more significant gap in the chain of custody than a transparent relay. Such modifications are not declared via DKIM2-Mod headers and cannot be attributed to any signing domain. A downstream receiver that encounters a changed bh= value or unexpected header differences between two consecutive DKIM2 signatures can identify that a modification occurred in the gap but cannot determine what was changed or by whom. Receivers that apply strict chain of custody policies SHOULD treat gaps containing undeclared modifications with additional suspicion, even if the signatures on either side of the gap are individually valid.</t>
        <t>This is a known limitation of the transition period. The properties achievable end-to-end depend on the composition of the delivery path:</t>
        <t>Replay prevention - fully effective only when every hop adds a DKIM2 signature with envelope binding. A legacy node between the originator and the final recipient means that the rt= value at the last signed hop does not necessarily reflect the actual final recipient.</t>
        <t>Backscatter prevention - fully effective only when every hop participates in DKIM2. A single legacy node breaks authenticated DSN propagation for all downstream receivers. During the transition period, receivers that encounter messages with broken DKIM2 chains MUST fall back to current DKIM1 behavior: apply local policy, generate DSNs as today.</t>
        <t>Chain of custody - provides attribution for all hops that participate in DKIM2. Legacy hops are visible as gaps in the i= sequence. A gap in the sequence does not invalidate the chain - it identifies the segment where accountability is absent.</t>
        <t>Header accountability - fully effective for all hops that implement DKIM2-core. Modifications made by legacy nodes are not declared but are detectable as changes in the signed header set between consecutive DKIM2 signatures.</t>
      </section>
      <section anchor="coexistence-with-dkim1">
        <name>Coexistence with DKIM1</name>
        <t>DKIM2 reuses DKIM1 DNS key infrastructure. A domain that has DKIM1 keys deployed does not need to make DNS changes to support DKIM2 signing by an ESP or MTA acting on its behalf. This is a deliberate design decision in <xref target="I-D.ietf-dkim-dkim2-spec"/> that significantly reduces the barrier to adoption for domain owners.</t>
        <t>During the transition period, messages MAY carry both DKIM1 and DKIM2 signatures. Receivers that implement only DKIM1 will verify the DKIM1 signature and ignore the DKIM2 headers. Receivers that implement DKIM2 will verify the DKIM2 chain and MAY also verify the DKIM1 signature for compatibility with existing policy frameworks such as DMARC.</t>
      </section>
      <section anchor="coexistence-with-arc">
        <name>Coexistence with ARC</name>
        <t>ARC <xref target="RFC8617"/> and DKIM2-core address overlapping problems with different mechanisms. ARC provides a trust chain for mailing list redistribution by recording the authentication state of a message as it passes through intermediaries. DKIM2-core is a functional superset of ARC - it provides the same modification attribution and trust chain capabilities plus cryptographic envelope binding that ARC lacks.</t>
        <t>During the transition period, nodes that implement ARC but not DKIM2-core continue to provide ARC chains independently of the DKIM2 chain. The two chains coexist without conflict but do not bridge each other - a gap in the DKIM2 chain caused by a non-participating node remains a gap regardless of whether that node implements ARC. ARC does not compensate for the absence of DKIM2 participation.</t>
        <t>Operators that have deployed ARC should not remove it during the DKIM2 transition period. ARC continues to provide value for receivers that evaluate ARC chains as part of their local policy, independently of DKIM2 adoption status.</t>
        <t>The limited adoption of ARC after six years of availability - approximately 10,000 signing domains compared to 9.5 million DKIM1 records as reported in <xref target="I-D.adams-arc-experiment-conclusion"/> - is informative for DKIM2 deployment expectations. ARC is milter-deployable and architecturally simpler than DKIM2-extended. Its adoption trajectory suggests that even milter-deployable protocols face significant ecosystem inertia. This reinforces the importance of the DKIM2-core profile: reducing deployment complexity to the minimum necessary to achieve the primary objectives of the protocol maximizes the probability of meaningful adoption.</t>
        <t>DKIM2-core enables a model of trust based on cryptographic chain of custody rather than direct domain alignment - a model that major providers already implement empirically through ARC evaluation. The approach taken in DKIM2-core is consistent with and builds upon experimental work already deployed in production. <xref target="I-D.chuang-replay-resistant-arc"/> proposes extending ARC with explicit envelope binding via dara= and darn= tags in the ARC-Seal, signing SMTP recipients at each hop and declaring the forwarding path. This protocol has been implemented in production by Google on Google Groups infrastructure, as evidenced by headers observed in real message flows. DKIM2-core formalizes and extends this approach with stronger cryptographic binding and a complete chain of custody model.</t>
        <section anchor="arc-header-selection-in-practice-google-and-microsoft">
          <name>ARC Header Selection in Practice: Google and Microsoft</name>
          <t>The following ARC-Message-Signature was captured from a live message relayed by Google's MTA during beta testing of a DKIM2-core milter implementation. It illustrates how production infrastructure interacts with DKIM2-core headers without any modification to Google's software:</t>
          <sourcecode type="example"><![CDATA[
ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed;
  d=google.com; s=arc-20240605;
  h=dkim2-sig-rt:dkim2-sig-mf:dkim2-signature
    :dkim2-authentication-results:content-transfer-encoding:message-id
    :mail-reply-to:reply-to:subject:to:from:date:mime-version
    :dkim-signature;
  bh=ZH14BpgDWH4ekZ2qz7x5de78YDPKMtMIePHA1LzPCFw=;
  fh=cFHJjx+I/cl9v81+GadEx4bWcN+lzkRpBVPfbJvMiUQ=;
  b=[...]; dara=google.com
]]></sourcecode>
          <t>Google's ARC implementation includes dkim2-sig-rt, dkim2-sig-mf, dkim2-signature and dkim2-authentication-results in its signed header set without any explicit knowledge of DKIM2. This is the natural consequence of a defensive signing strategy: when an MTA encounters header fields that carry authentication or chain-of-custody semantics, it includes them in its ARC signature to prevent downstream manipulation. The DKIM2-core headers are recognized as structural metadata and protected accordingly.</t>
          <t>The contrast with Microsoft Exchange Online Protection is instructive. Microsoft's ARC implementation includes vendor-specific diagnostic headers in its signed set:</t>
          <sourcecode type="example"><![CDATA[
ARC-Message-Signature: i=2; a=rsa-sha256; c=relaxed/relaxed;
  d=microsoft.com; s=arcselector10001;
  h=From:Date:Subject:Message-ID:Content-Type:MIME-Version
    :X-MS-Exchange-AntiSpam-MessageData-ChunkCount
    :X-MS-Exchange-AntiSpam-MessageData-0
    :X-MS-Exchange-AntiSpam-MessageData-1;
  bh=LfoXw5zEEFL0p4CikYely3pA5A1KXLrtYuUMyQ04I/c=;
  b=[...]
]]></sourcecode>
          <t>By signing internal diagnostic headers, Microsoft's ARC seal cryptographically binds downstream MTA infrastructure to Microsoft's internal telemetry format. Any system that strips or modifies these headers - as many security gateways do - will invalidate the Microsoft ARC seal, effectively requiring the entire delivery chain to preserve proprietary diagnostic data. This is architecturally unsound: the chain of custody mechanism is being used to enforce transport of vendor-specific payload rather than to protect message identity.</t>
          <t>The two examples illustrate a principle that applies equally to DKIM2 deployment: a protocol designed around message identity and envelope binding will be adopted and protected by existing infrastructure automatically, because the headers it produces are recognizable as structural metadata. A protocol that embeds implementation-specific complexity in its headers will produce fragile seals that break at the first hop that does not share the same implementation assumptions. This distinction argues for the minimal, identity-focused approach of DKIM2-core over approaches that bind body content or vendor-specific data into the signed set.</t>
        </section>
      </section>
      <section anchor="incremental-deployment-path">
        <name>Incremental Deployment Path</name>
        <t>The recommended incremental deployment path for operators adopting DKIM2-core is:</t>
        <t>Phase 1 - outbound signing only: deploy the outbound milter to add DKIM2-Sig-mf, DKIM2-Sig-rt and DKIM2-Signature headers to outgoing messages. No inbound verification. This establishes the operator's presence in the DKIM2 ecosystem and allows downstream receivers to begin building chain of custody records.</t>
        <t>Phase 2 - inbound verification: deploy the inbound milter to verify incoming DKIM2 signatures and record results in Authentication-Results headers. Apply local policy based on verification results. This phase can be implemented in monitoring-only mode initially - logging verification results without affecting delivery - to assess the impact before enforcing policy.</t>
        <t>During Phase 2, the verifier SHOULD add a DKIM2-Authentication-Results header to record the outcome of chain verification. The format is:</t>
        <sourcecode type="example"><![CDATA[
DKIM2-Authentication-Results: i=N; authserv-id; dkim2=result
]]></sourcecode>
        <t>where N is the current hop index, authserv-id is the verifying server identity (e.g. dns.itb.it) and result is one of:</t>
        <ul spacing="normal">
          <li>
            <t>pass - chain verified, envelope binding confirmed</t>
          </li>
          <li>
            <t>fail - invalid signature, body hash mismatch, hh= rollback mismatch or envelope mismatch</t>
          </li>
          <li>
            <t>none - no DKIM2-Signature present in the received message</t>
          </li>
          <li>
            <t>temperror - a transient error prevented verification, such as a DNS lookup failure for the signing key; the condition may resolve on retry</t>
          </li>
          <li>
            <t>permerror - a structural error prevented verification, such as a gap in the chain, a missing required signature or a malformed key record</t>
          </li>
        </ul>
        <t>In Phase 2 (monitoring), the verifier MUST NOT reject or delay messages based on any dkim2= result; all five outcomes are recorded in the DKIM2-Authentication-Results header for downstream policy decisions and local monitoring, with delivery proceeding via SMFIS_CONTINUE regardless of verification outcome.</t>
        <t>In Phase 3 (policy enforcement), each result maps to a specific milter action:</t>
        <ul spacing="normal">
          <li>
            <t>dkim2=fail and dkim2=permerror correspond to SMFIS_REJECT: both represent a definitive verification failure that will not change on retry, and the MTA issues a 5xx rejection to the connected peer.</t>
          </li>
          <li>
            <t>dkim2=temperror corresponds to SMFIS_TEMPFAIL: the condition - typically a DNS lookup failure - may resolve on retry, and the MTA issues a 4xx temporary failure rather than a permanent rejection. Without this distinction, a transient DNS outage would cause legitimate mail to be permanently rejected rather than retried.</t>
          </li>
          <li>
            <t>dkim2=none and dkim2=pass correspond to SMFIS_CONTINUE: the message proceeds to delivery.</t>
          </li>
        </ul>
        <t>In all enforcement cases other than SMFIS_CONTINUE, no DKIM2-Authentication-Results header is written, as the message does not reach any downstream processor.</t>
        <t>DKIM2-Authentication-Results is an implementation-defined header for transitional monitoring. It is not currently registered in the IANA header field registry <xref target="RFC3864"/> and its use is scoped to the transitional deployment period. The format of the definitive authentication result mechanism for DKIM2 will be specified when the IANA registry for DKIM2 authentication methods is established. This header is excluded from the hh= computation as specified in Section 3.2.5, consistently with the treatment of Authentication-Results in the DKIM2 base specification <xref target="I-D.ietf-dkim-dkim2-spec"/>.</t>
        <t>Phase 3 - policy enforcement: begin rejecting messages that fail DKIM2 verification according to local policy. This phase requires confidence that the majority of expected senders have deployed DKIM2 outbound signing.</t>
        <t>Phase 4 - mailing list and intermediary participation: update mailing list managers and other intermediaries to add DKIM2-Mod headers for their modifications. This phase completes the chain of custody for messages that transit these systems.</t>
        <t>DKIM2-extended MAY be added at any phase by operators who require body accountability, subject to the operational considerations described in Section 4.</t>
      </section>
      <section anchor="the-dmarc-preject-mailing-list-problem">
        <name>The DMARC p=reject Mailing List Problem</name>
        <t>The DMARC p=reject mailing list problem is a known limitation of the current email authentication ecosystem that predates DKIM2. It arises from the interaction between DMARC's domain alignment requirement and the routing changes introduced by mailing list redistribution. The problem has been extensively documented, including in <xref target="I-D.levine-dmarc-listugh"/>, which describes forwarding failures, mailing list failures and various workarounds - none of which provide a satisfactory solution. That document concludes that the workarounds available today all impose unacceptable costs: those that preserve sender identity break DMARC alignment and those that achieve DMARC alignment do so by destroying sender identity or degrading the user experience in ways that make the message unreadable in standard mail clients. DKIM2-core addresses the structural gap that all those workarounds fail to close.</t>
        <t>The mechanism of failure: DMARC requires that at least one of SPF or DKIM provide a pass with domain alignment to the RFC5322 From: header. When a message passes through a mailing list two failure modes are possible depending on how the list handles the From: header.</t>
        <t>Case A - list without From: rewriting</t>
        <t>When a mailing list redistributes a message without modifying the From: header, SPF alignment fails because the mailing list infrastructure is not authorized by the original sender's SPF record. If the list rewrites the envelope-from for bounce handling - as most do - SPF may technically pass for the list's own domain, but that pass is not aligned with the From: domain and DMARC therefore fails. Similarly, DKIM alignment fails because the list's signing domain differs from the From: domain.</t>
        <t>It should be noted that Case A is only trivially resolved if the mailing list makes no modifications whatsoever to the message. In practice, mailing lists invariably add List-* headers (List-Id, List-Unsubscribe, List-Archive), subject tags and footers. These additions invalidate the original DKIM1 signature through header modification alone, regardless of body integrity - adding List-Unsubscribe: to a message whose DKIM1 signature covers that header field is sufficient to break alignment. Major email platforms including Gmail and Microsoft 365 now require List-Unsubscribe headers with one-click unsubscribe support to avoid messages being classified as spam and to protect the sending domain's reputation - making this header addition a de facto mandate for any mailing list that wishes to reach subscribers at these providers without deliverability penalties. The invariant addition of this header means that the "body unchanged, signature preserved" scenario is operationally irrelevant for any compliant mailing list.</t>
        <t>The following Authentication-Results header was observed on a message from itb.it that transited Google Groups and was delivered to a Microsoft Exchange recipient:</t>
        <artwork><![CDATA[
dmarc=fail header.from=itb.it
dkim=pass header.d=googlegroups.com
spf=pass smtp.mailfrom=googlegroups.com
arc=pass
]]></artwork>
        <t>The message body was plain text with no modifications. DMARC failed purely on alignment grounds - not because the body was modified. Microsoft delivered the message via ARC override. Body recipes cannot fix this failure - even with full body reconstruction, the signing domain googlegroups.com is not aligned with the From: domain itb.it.</t>
        <t>Case A also applies to nested mailing lists - a list that redistributes to another list. Each list adds its own List-* headers and subject tags, producing multiple instances of the same header field. This creates the duplicate header problem documented in Section 3.3.5: signing software that relies on physical header position rather than explicit index values will compute different hashes depending on which instance it selects. This has been observed in production: OpenDKIM signing both instances of a duplicate header while Microsoft Exchange selecting only one, producing a hash mismatch and a DKIM verification failure despite the message being legitimate. DKIM2-Mod's explicit i= and seq= indexing eliminates this failure mode entirely.</t>
        <t>Case B - list with From: rewriting</t>
        <t>When a mailing list replaces the From: header with its own domain, DMARC passes because the list's signing domain is now aligned with the new From: domain. The following Authentication-Results header was observed on a message from vittorio.moccia@gmail.com that transited a mailing list on itb.it and was delivered to a Microsoft Exchange recipient:</t>
        <artwork><![CDATA[
dkim=pass header.d=itb.it
dmarc=pass header.from=itb.it
spf=pass smtp.mailfrom=itb.it
arc=pass
]]></artwork>
        <t>DMARC passed completely. But the original sender's identity was destroyed - the recipient sees "Lista Utenti utenti@itb.it" instead of the original author. This is the architectural hack that makes DMARC work today for mailing lists - and it is unsound because it destroys sender identity to achieve alignment, breaking the accountability chain that DKIM2 is designed to establish.</t>
        <t>In Case B, DMARC alignment is achieved at the cost of sender attribution. If the goal of DKIM2 is to enhance authentication, a solution that requires destroying the primary identity marker - the From: header - to function is self-defeating.</t>
        <t>Body recipes do not resolve this problem. DMARC fails due to an alignment failure - the signing domain does not match the From: domain. Body recipes address integrity - whether the body has been modified. These are orthogonal problems. In Case A, DMARC fails on domain alignment - a problem in the header and envelope layer that body reconstruction cannot address. In Case B, DMARC passes only because the From: header was replaced - a header modification that has nothing to do with body integrity. In neither case does body reconstruction affect the DMARC outcome.</t>
        <t>DKIM2-core offers a third path that neither Case A nor Case B provides today. A mailing list implementing DKIM2-core can:</t>
        <ul spacing="normal">
          <li>
            <t>Retain the original From: header - preserving the original sender's identity</t>
          </li>
          <li>
            <t>Declare the addition of List-* headers and any Subject: modifications via DKIM2-Mod headers</t>
          </li>
          <li>
            <t>Sign with its own DKIM2 key, cryptographically binding the envelope and the chain of custody</t>
          </li>
          <li>
            <t>Provide receivers with a verifiable record that the list handled the message and what modifications were made</t>
          </li>
        </ul>
        <t>This allows receivers that evaluate DKIM2 chain of custody - as Microsoft and Google already do empirically today - to make an informed trust decision without requiring From: rewriting or body reconstruction. The trust model is not theoretical - it is already deployed at scale. Critically, it achieves this without requiring new DNS records or SMTP capabilities.</t>
        <t>The concrete mechanism is not an override of DMARC but a transformation of the trust decision from probabilistic to deterministic. Today, receivers that accept mailing list messages despite DMARC failure do so based on reputation heuristics - an implicit judgment that the list infrastructure is trustworthy. This judgment cannot be verified cryptographically. DKIM2-core provides the substrate for a verifiable equivalent: the mailing list signs the message with its own DKIM2 key, binding its identity to the specific SMTP transaction via DKIM2-Sig-mf and DKIM2-Sig-rt and declaring any header modifications via DKIM2-Mod. The body hash bh= at each hop is not an isolated integrity check but a cryptographically attributed statement - any intermediary that modifies the body must sign the new hash with its own domain, making body modification traceable to a specific accountable identity in the chain. The receiver can then verify not just that a trusted party claims to have handled the message, but that a specific identifiable domain handled this specific message to this specific recipient with these specific declared modifications - a chain of custody that is mathematically verifiable rather than reputationally assumed. If the intermediary is trusted, the chain confirms the message transited through known hands. If the intermediary is not trusted, the chain identifies exactly who touched the message. In both cases the decision is based on cryptographic proof of the transit path, not on body content or reputation alone.</t>
        <t>By utilizing the i= and rt= fields, DKIM2-core establishes a verifiable cryptographic link between the original message and the modified version distributed by the list. Trust is derived from the verifiable path of the message rather than from an obsolete and hidden body state. This approach maintains the "What You See Is What Was Authenticated" principle, which is abandoned by the body reconstruction mechanism.</t>
        <t>DKIM2-core provides the cryptographic substrate necessary for an evolved DMARC policy evaluation that can recognize transitive trust through a verified chain of custody. This allows receivers to distinguish between messages that fail DMARC due to spoofing and those that fail due to legitimate mailing list redistribution where the original sender's authentication chain remains intact - a distinction that current DMARC cannot make. The trust model is not theoretical: major providers already apply equivalent heuristics empirically today when evaluating forwarded mail, accepting messages that fail strict DMARC alignment when the handling chain is verifiable. DKIM2-core formalizes and strengthens this existing practice by adding cryptographic envelope binding that makes the trust decision verifiable through cryptographic proof rather than dependent on external reputation systems or allow lists.</t>
        <t>The ongoing tightening of DMARC enforcement by major providers - including the adoption of strict alignment requirements that mandate exact domain matches rather than subdomain tolerance - makes the mailing list problem more acute over time. Solutions based on From: rewriting become less viable as strict alignment prevents subdomain matches that relaxed alignment would have tolerated. Body reconstruction addresses neither strict nor relaxed alignment failures. DKIM2-core chain of custody provides the only path that preserves original sender identity while remaining compatible with evolving DMARC enforcement requirements.</t>
        <t>Ultimately, DKIM2-core restores DMARC interoperability with mailing lists by authenticating the modification path, whereas DKIM2-extended fails to address the root cause of misalignment while introducing significant privacy and security overhead.</t>
        <t>Working group review of the companion best current practices document (<xref target="I-D.ietf-dkim-dkim2-bcp"/>) identified this gap: the base specification does not define alignment between the From: header and any signing domain in the chain. DKIM2-core's chain of custody model - where each hop's signing domain is bound to the version of the From: header it introduced via DKIM2-Mod - provides the structural basis for such an alignment definition. Formalizing it as a normative rule remains a question for the base specification.</t>
      </section>
    </section>
    <section anchor="privacy-considerations">
      <name>Privacy Considerations</name>
      <t>This section addresses privacy implications of DKIM2-core and DKIM2-extended in accordance with <xref target="RFC6973"/>, which provides guidance on privacy considerations in Internet protocol design.</t>
      <section anchor="dkim2-core-privacy-properties">
        <name>DKIM2-core Privacy Properties</name>
        <t>DKIM2-core adds the following information to messages in transit:</t>
        <t>DKIM2-Sig-mf and DKIM2-Sig-rt headers - these fields carry the SMTP envelope values, which may include email addresses not present in the RFC5322 headers. In the common case of direct delivery, these values are already implicit in the message routing. For mailing list redistribution, the rt= value at each hop reveals the address of the individual subscriber receiving that copy of the message. This is not new information - the SMTP envelope already contains this information - but it is now carried in a signed header field that persists in the message and may be archived by downstream systems.</t>
        <t>DKIM2-Mod headers - these fields carry previous values of modified header fields. For header modifications that involve personal data - for example a From: header that is rewritten by a mailing list - the original value is preserved in a signed header that travels with the message. Operators that modify headers containing personal data should be aware that the original values will be visible to all downstream recipients and archiving systems.</t>
        <t>This pattern is already practiced informally in the ecosystem, as described in Section 3.3.4.</t>
        <t>Authentication-Results headers - these fields record the outcome of DKIM2 verification at each hop. They do not contain message content or personal data beyond what is already present in the message headers.</t>
        <t>The privacy impact of DKIM2-core is limited and proportionate to its functional objectives. The additional data carried in DKIM2-core headers is necessary for the envelope binding and chain of custody mechanisms and does not represent a material increase in the personal data surface of the message beyond what is already present in the SMTP transaction.</t>
        <section anchor="re-origination-by-privacy-preserving-intermediaries">
          <name>Re-origination by Privacy-Preserving Intermediaries</name>
          <t>Some intermediaries exist specifically to remove identifying information from messages - relay services that strip tracking content and redact sender identity or alias and forwarding services with similar goals. For these intermediaries the chain of custody model described above is structurally unavailable at any recipe setting. A content-bearing recipe would disclose exactly the information the service exists to remove. A null recipe does not avoid this either: as noted above, mf= and rt= persist in signed header fields and may be archived by downstream systems, so retaining prior DKIM2-Signature header fields still exposes the originating envelope addresses and signing domain to every recipient.</t>
          <t>The correct behavior in this case is re-origination: the privacy-preserving intermediary terminates the inbound chain and signs as a new i=1, using its own domain and envelope. This was confirmed in working group discussion of an equivalent case: an intermediary that deliberately does not provide chain of custody through its systems is not extending the original message under DKIM2, but creating a new message from selected content, and is correctly treated as the originator of that new message once it re-enters the network. This is distinct from chain termination to conceal non-compliance with donotmodify, where the original message is forwarded without its provenance rather than replaced by a new message.</t>
          <t>This profile recognizes intentional re-origination by privacy-preserving intermediaries as a legitimate deployment pattern.</t>
        </section>
      </section>
      <section anchor="dkim2-extended-privacy-considerations">
        <name>DKIM2-extended Privacy Considerations</name>
        <t>DKIM2-extended raises privacy concerns that are qualitatively different from those of standard email processing. Email messages already transit through systems that read, analyze and archive them - existing data protection frameworks address this reality. What DKIM2-extended adds is the systematic creation of structured, cryptographically signed records of previous versions of message content that did not previously exist as discrete data objects. A standard email message represents the current state of a communication. A message with body recipes represents both the current state and a signed history of previous states distributed to every downstream recipient and archiving system in cryptographically immutable form.</t>
        <t>This distinction is relevant to data protection law in the ways described below.</t>
        <section anchor="the-null-recipe-mechanism">
          <name>The Null Recipe Mechanism</name>
          <t>The null recipe is the primary technical instrument available to intermediaries for managing privacy risk in DKIM2-extended deployments. An intermediary that modifies message content may declare null rather than generating a content-bearing recipe, signalling that a modification occurred and who made it without creating any structured record of the previous content.</t>
          <t>The null recipe preserves the core accountability property of DKIM2 - the modification is declared and attributed - while avoiding the creation of personal data records that would otherwise travel with the message to all downstream recipients and archiving systems. It is the correct response in any situation where generating a content-bearing recipe would conflict with data protection obligations or organizational security policy.</t>
          <t>The current specification does not provide normative guidance on when intermediaries are obligated to use null recipes. This document addresses that gap for specific deployment scenarios in the sections that follow.</t>
        </section>
        <section anchor="data-minimization">
          <name>Data Minimization</name>
          <t>GDPR Article 5(1)(c) requires that personal data be adequate, relevant and limited to what is necessary for the purposes for which it is processed. The primary operational objectives of DKIM2 - replay prevention, backscatter mitigation, modification attribution - are achievable without body recipes as argued in Section 4.5. Body recipe data collection may therefore not meet the necessity test under Article 5(1)(c).</t>
          <t>The specific minimization problem of body recipes is not that personal data is processed - it is that body recipes create a new category of structured data that did not previously exist: recoverable representations of previous message content, distributed in signed form to all downstream systems. This is qualitatively different from the processing that occurs in standard email transit and raises minimization questions that do not arise for DKIM2-core.</t>
          <t>This is not a definitive legal assessment. Operators subject to GDPR should seek legal advice on whether their specific use of body recipes is consistent with their data minimization obligations.</t>
        </section>
        <section anchor="data-retention">
          <name>Data Retention</name>
          <t>GDPR Article 5(1)(e) requires that personal data be kept in a form that permits identification of data subjects for no longer than necessary. Body recipes travel in the message and may be archived by any system that receives or intercepts it - including the final recipient's mail store, compliance archiving systems and, in some jurisdictions, systems operated under lawful interception or judicial oversight obligations. Unlike the message body itself, body recipes embedded in signed headers cannot be selectively removed without invalidating the signature chain. This creates a retention problem that has no clean technical resolution: the data persists in signed form in every copy of the message held by any system that archived it, regardless of the originating organization's retention policy.</t>
          <t>Furthermore, intermediaries that implement DKIM2-extended may find that the body recipe itself constitutes an audit trail of modifications - and in many jurisdictions, audit records are subject to mandatory retention obligations that may exceed the retention period applicable to the communication content itself. An intermediary may therefore find itself obligated to retain recipe content as an audit record for extended periods, regardless of its normal data retention policy. This obligation did not exist before DKIM2-extended because no structured modification record was created during transit.</t>
          <t>Operators should evaluate whether their archiving systems can handle recipe content consistently with applicable obligations under <xref target="GDPR"/> Article 5(1)(e) and any sector-specific retention requirements in their jurisdiction.</t>
        </section>
        <section anchor="dlp-systems-and-body-recipes">
          <name>DLP Systems and Body Recipes</name>
          <t>A Data Loss Prevention system that redacts sensitive content does so precisely because that data must not circulate. A body recipe that allows reconstruction of the content before redaction creates a structured record of the very data the DLP system was designed to protect - a structural contradiction between the purpose of the system and what DKIM2-extended asks it to generate.</t>
          <t>Operators deploying DLP systems in conjunction with DKIM2-extended MUST use null recipes as described in Section 6.2.1 for all modifications that involve redaction of sensitive content.</t>
        </section>
        <section anchor="antivirus-gateways-and-body-recipes">
          <name>Antivirus Gateways and Body Recipes</name>
          <t>When an antivirus gateway removes a malicious attachment, the removed content should be eliminated, not preserved. A content-bearing recipe for such a removal creates a structured record of content that should not exist downstream.</t>
          <t>Operators deploying antivirus gateways in conjunction with DKIM2-extended MUST use null recipes as described in Section 6.2.1 for all modifications that involve removal of malicious or suspicious content.</t>
        </section>
        <section anchor="url-rewriting-and-body-recipes">
          <name>URL Rewriting and Body Recipes</name>
          <t>Security gateways that rewrite URLs generate recipes containing the original URLs, which may reveal sensitive communication content or internal infrastructure details not intended for downstream exposure.</t>
          <t>Operators who cannot expose original URLs in recipe content MUST use null recipes as described in Section 6.2.1.</t>
        </section>
        <section anchor="compliance-with-data-subject-rights">
          <name>Compliance with Data Subject Rights</name>
          <t>GDPR Articles 16 and 17 grant data subjects the right to rectification of inaccurate personal data and the right to erasure. Body recipes create structural conflicts with both rights that manifest differently depending on the stage of the message lifecycle. In addition to GDPR, operators must consider Directive 2002/58/EC (ePrivacy Directive) <xref target="ePrivacy"/>, which mandates the confidentiality of communications. By creating structured, cryptographically signed records of previous body states that are durably embedded in the message itself, DKIM2-extended converts transient communication content into a verifiable content history that travels with the message to every downstream system. This conversion raises questions about the applicability of mere conduit exemptions under Article 12 of the e-Commerce Directive and its successor provisions, which condition that exemption on the intermediary not modifying the information transmitted. Generating a body recipe may be considered a form of content processing that goes beyond mere transport, potentially requiring an explicit legal basis for the creation and retention of such records at intermediate hops.</t>
          <t>The erasure problem - the null recipe described in Section 6.2.1 is a preventive instrument: if applied consistently before personal data enters the recipe, no erasure conflict arises. However it is not a remedial instrument. Once a content-bearing recipe has been generated and distributed, the Right to Erasure under Article 17 GDPR becomes technically unenforceable: the organization that generated the recipe can delete its own copy, but the recipe exists in cryptographically signed form in every downstream copy of the message. GDPR Article 17 imposes an obligation on the controller to erase data - but it provides no mechanism to compel deletion from systems in other administrative domains, other jurisdictions or operated by parties who are not data controllers under the same legal framework.</t>
          <t>Furthermore, an intermediary that generated a recipe may itself face conflicting obligations: the erasure request requires deletion, but audit trail or documentary evidence obligations - contractual, regulatory or legal - may require retention of records of modifications made. These two obligations cannot be simultaneously fulfilled. This conflict is not a gap in the legal framework - it is a structural consequence of DKIM2-extended creating cryptographically immutable records at transit nodes.</t>
          <t>The rectification problem - the rectification conflict is structurally irresolvable and arises specifically when the message is in archival state. During transit the message exists transiently and the problem does not arise. The problem emerges when the message is archived - by any system at any point in the delivery chain - with a recipe containing inaccurate personal data.</t>
          <t>At that point three obligations come into direct conflict. First, GDPR Article 16 requires that the inaccurate personal data be corrected. Second, correcting the value in the recipe invalidates the cryptographic signature of the hop that generated it, which cascades through all subsequent signatures in the chain. Third, if the archive is used as certified documentary evidence - for compliance, audit or legal purposes - its integrity must be preserved. Modifying it to fulfill the rectification request destroys its evidentiary value. Not modifying it violates the data subject's right.</t>
          <t>This three-way conflict between data subject rights, cryptographic integrity and documentary evidence obligations has no technical resolution within the current DKIM2-extended architecture. It does not arise in standard email archiving, where an organization can modify or delete its own archives without affecting cryptographic chains, because standard email archives do not carry immutable signed records of previous content versions.</t>
          <t>Joint controllership - an intermediary that generates body recipes is no longer merely transporting the message - it is creating a new structured record of personal data by determining what previous content to include in the recipe and ensuring its persistence through cryptographic binding. This may constitute joint controllership under GDPR Article 26, with associated obligations including the potential requirement for a Data Protection Impact Assessment under Article 35. Operators should evaluate whether their recipe generation activities trigger these obligations.</t>
        </section>
        <section anchor="privacy-review-recommendation">
          <name>Privacy Review Recommendation</name>
          <t>At the time of writing, <xref target="I-D.ietf-dkim-dkim2-spec"/> does not include a Privacy Considerations section and the Security Considerations section is marked TBA. Subsequent versions may address some of the concerns raised here following discussion on the ietf-dkim mailing list initiated in March 2026.</t>
          <t>For a specification intended to become an IETF Standards Track document, privacy and security considerations are required per <xref target="RFC3552"/> (BCP 72). This document provides suggested privacy considerations text based on <xref target="RFC6973"/> for consideration by the working group as a contribution to the base specification.</t>
          <t>Note on <xref target="RFC6973"/>: this is an IAB document rather than an IETF document. However IAB documents on protocol design are explicitly relevant to IETF Standards Track work - the IAB and IETF coordinate on architectural and privacy matters as part of the overall Internet standards process. The privacy considerations in this document are consistent with both <xref target="RFC6973"/> and the security considerations requirements of <xref target="RFC3552"/>.</t>
        </section>
        <section anchor="architectural-conclusion">
          <name>Architectural Conclusion</name>
          <t>The privacy considerations described in this section lead to a clear architectural conclusion: DKIM2-extended MUST remain optional and loosely coupled to DKIM2-core. This is not merely a deployment preference - it is a requirement derived from data protection principles.</t>
          <t>An operator subject to <xref target="GDPR"/> and <xref target="ePrivacy"/> who activates DKIM2-extended takes on explicit data processing obligations for the personal data contained in body recipes, including obligations that may not arise under standard email processing - among them the creation of audit-trail records at transit nodes, potential joint controllership under GDPR Article 26 and questions about mere conduit exemptions under the e-Commerce Directive. An operator who implements only DKIM2-core has no such obligations beyond those that exist today for standard email processing. The optional nature of DKIM2-extended is therefore not a technical convenience but a legal necessity for a significant portion of the global email infrastructure.</t>
          <t>The interoperability dimension of this concern extends beyond individual operators. The Digital Markets Act (DMA) requires gatekeepers to ensure interoperability with third-party services and prohibits technical measures that create barriers to entry for smaller operators. An email authentication standard that is only practically implementable by large providers with dedicated engineering teams and legal resources to manage GDPR obligations for body recipe processing raises questions about compliance with DMA interoperability requirements. DKIM2-core, by contrast, is implementable by any operator regardless of size and imposes no data processing obligations beyond those that exist today.</t>
          <t>DKIM2-core and DKIM2-extended are designed to coexist cleanly. A DKIM2-core-only node passes Message-Instance headers through as opaque signed content without interpreting them, preserving the integrity of the chain without requiring participation in body recipe processing. A DKIM2-extended node adds full body recipe functionality on top of the core.</t>
          <t>This is a deliberate application of graceful degradation: a core-only deployment does not break DKIM2-extended deployments - it simply does not extend them. The chain of custody remains intact, the envelope binding remains verifiable and the signed header accountability remains functional. Operators who cannot or choose not to implement body recipe processing - whether for technical, operational or legal reasons - remain full participants in the DKIM2 ecosystem. Activating DKIM2-extended adds capabilities; not activating it does not degrade the core functionality in any way.</t>
          <t>This clean separation is the architectural property that makes DKIM2 deployable across the heterogeneous ecosystem and across jurisdictions with different data protection requirements.</t>
        </section>
      </section>
    </section>
    <section anchor="implementation-status">
      <name>Implementation Status</name>
      <t>Note to RFC Editor: please remove this section, and the reference to <xref target="RFC7942"/>, before publication.</t>
      <t>This section records the status of known implementations of the profile described in this document, per <xref target="RFC7942"/>. Please note that the listing of any individual implementation here does not imply endorsement by the IETF. Furthermore, no effort has been spent to verify the information presented here that was supplied by IETF contributors. This is not intended as, and must not be construed to be, a catalog of available implementations or their features. Readers are advised to note that other implementations may exist. This section covers implementations of the specific deployment profile described in this document; implementations of other aspects of the DKIM2 ecosystem, such as body recipe tooling, are out of scope here and are not surveyed.</t>
      <section anchor="darkchain-darkchains">
        <name>DarkChain / DarkChains</name>
        <t>Organization: Independent</t>
        <t>Implementation: https://github.com/darkglobe-project/darkglobe-suite</t>
        <t>Description: DarkChain (verifier) and DarkChains (signer) implement the DKIM2-core profile described in this document as two independent milter processes. Written in C against libmilter, deployed on live mail infrastructure with Sendmail. No MTA core modifications required.</t>
        <t>Coverage: Envelope binding via DKIM2-Sig-mf and DKIM2-Sig-rt with per-recipient granularity. Chain of custody verification hop-by-hop. Header modification tracking via DKIM2-Mod (signing and verification of declarations produced by modifying components). Header integrity hash (hh=). SRS envelope rewriting for forwarding via smfi_chgfrom(). Full optional attestation mode (pre/post mailing list signing). Configurable X-* prefix exclusion.</t>
        <t>Level of maturity: Beta, deployed on live mail infrastructure processing traffic from Microsoft Exchange Online and Google MTA infrastructure.</t>
        <t>Licensing: Apache 2.0</t>
      </section>
    </section>
    <section anchor="security-considerations">
      <name>Security Considerations</name>
      <section anchor="security-properties-of-dkim2-core">
        <name>Security Properties of DKIM2-core</name>
        <t>Replay prevention - a valid DKIM2 signature cannot be reused for a different recipient without breaking the chain. The cryptographic binding of RCPT TO values in DKIM2-Sig-rt to the signature at every hop makes replay attacks detectable by any conformant verifier.</t>
        <t>DKIM2-core envelope binding uses one DKIM2-Sig-rt header per recipient address. A verifier checks that the RCPT TO of the current SMTP session matches exactly the addr= value of the corresponding DKIM2-Sig-rt header. This provides complete replay prevention - a message signed for recipients A, B and C cannot be replayed to only recipient A because the DKIM2-Sig-rt header carrying addr=A was signed as part of a chain that also includes headers for B and C. This is a structural improvement over designs that aggregate all recipients in a single signed blob, where a subset of recipients could be used without breaking the signature.</t>
        <t>The base specification <xref target="I-D.ietf-dkim-dkim2-spec"/> addresses this risk through an optional "exploded" flag (Section 8.9) that signals a message was sent to multiple recipients. However this mitigation has structural weaknesses: the flag is optional and depends on the signer including it and if the signer omits it or an attacker removes it, the protection fails. The flag also does not prevent replay to a subset of the original recipients - it only signals that multiple recipients existed. DKIM2-core's one-header-per-address design eliminates this category of attack without requiring any optional flag: the signed set of DKIM2-Sig-rt headers is cryptographically bound to the chain and any attempt to replay the message to a recipient subset or a different recipient produces a verifiable mismatch.</t>
        <t>Sender accountability - the signing domain at each hop is cryptographically bound to the message and the envelope. A receiver can establish a verifiable chain of custody from originator to final recipient, identifying every entity that handled the message and declared its modifications.</t>
        <t>Backscatter prevention - DSN generation is authenticated through the chain of custody. A receiver that rejects a message during the SMTP session directs the rejection to the connected peer, never to the envelope sender. This prevents backscatter to innocent sender domains.</t>
        <t>Header integrity - modifications to header fields are declared via DKIM2-Mod headers and are covered by the signature of the modifying hop. Undeclared header modifications are detectable as inconsistencies between the signed header set and the declared modifications.</t>
        <t>Body integrity - the bh= value at each hop provides a hash of the current message body. Changes in bh= between consecutive signatures identify hops where body modifications occurred and attribute them to the signing domain. Full body reconstruction is not provided in DKIM2-core and is not required for the primary security objectives.</t>
        <section anchor="the-binary-trust-model">
          <name>The Binary Trust Model</name>
          <t>The security model of DKIM2 relies on the chain of custody established by envelope binding. In operational environments, trust in an intermediary is a binary decision based on reputation and verifiable identity - there is no partial trust in email authentication. This has a direct consequence for the role of body recipes in security decisions.</t>
          <t>If a receiver does not trust intermediary B, body recipes provide no additional assurance. B could have inserted malicious content, removed a legal disclaimer or rewritten URLs to phishing sites - a JSON recipe documenting those changes does not make them safe. As the authors of the base specification have acknowledged, recipes "don't stop B from adding bad things."</t>
          <t>If a receiver does trust intermediary B, the chain of custody established by DKIM2-core is sufficient. The cryptographic binding of MAIL FROM and RCPT TO at every hop, combined with DKIM2-Mod declarations for header modifications, provides the verifiable path that enables the trust decision. This is precisely the model that Microsoft and Google already apply empirically today when evaluating forwarded mail.</t>
          <t>Body recipes are a descriptive capability for forensic and archival purposes. Envelope binding is the mandatory security foundation. Furthermore, body recipes provide zero protection against replay attacks where the content remains identical - only the envelope binding of DKIM2-core addresses this fundamental vulnerability. In summary: if trust is binary, recipes are a descriptive luxury, not a security necessity. The separation between DKIM2-core and DKIM2-extended reflects this distinction: core provides the security properties that matter for delivery decisions, extended provides additional accountability for operators who need it and can afford the operational cost.</t>
          <t>DKIM2 verification produces three qualitatively different outcomes that operators must distinguish in their delivery policy. A message that transits the chain without body modifications and with a complete chain of valid signatures provides the strongest assurance - full cryptographic accountability from originator to recipient. A message with body modifications declared via recipes provides weaker assurance - the modifications are attributed and reversible, but the displayed content differs from what was originally signed. A message with null recipes at one or more hops provides assurance equivalent to DKIM2-core: the chain of custody and envelope binding are intact, but no body reconstruction is possible for those hops. These three outcomes have different risk profiles and MUST NOT be treated equivalently in delivery policy. In particular, the second and third outcomes do not provide the same level of assurance as the first for purposes of domain reputation, BIMI display or any policy that depends on content integrity rather than transit accountability. DKIM2-core provides the properties common to all three outcomes - envelope binding, chain of custody, header accountability - without requiring operators to distinguish between them or to deploy the additional infrastructure that the second outcome requires. DKIM2-extended adds the distinction between the second and third outcomes at the deployment cost documented in Section 4 - a cost that is only justified for operators with the infrastructure to benefit from body reconstruction data.</t>
        </section>
        <section anchor="implementation-robustness-and-reduced-attack-surface">
          <name>Implementation Robustness and Reduced Attack Surface</name>
          <t>DKIM2-core uses the tag-value syntax of DKIM1 <xref target="RFC6376"/> throughout, without nested or opaque data structures such as JSON-encoded values within header fields. This design choice has direct security implications.</t>
          <t>The elimination of multi-layered parsing - JSON-in-base64 embedded in header fields - removes a category of attack surface that does not exist in DKIM1 or ARC. Parser vulnerabilities in JSON libraries, including memory exhaustion and type confusion attacks, cannot be triggered by DKIM2-core header processing. This is consistent with the attack surface analysis in Section 8.3.1.</t>
          <t>All DKIM2-core declarations - envelope binding, modification attribution, chain of custody - are in cleartext tag-value format, directly inspectable in mail logs without specialized tooling. This transparency supports real-time threat detection and incident response in ways that base64-encoded opaque blobs do not. The need for dedicated tooling to render DKIM2 header fields in human-readable form confirms that the current encoding is not suitable for operational diagnostics without specialised software, a property that tag-value encoding does not share.</t>
          <t>Interoperability testing of <xref target="I-D.ietf-dkim-dkim2-spec"/> conducted during IETF hackathon activities in March 2026 identified multiple confirmed interop failures between independent implementations, including disagreements on header ordering for signing input and header hash computation. DKIM2-core's use of explicit i= and seq= index values rather than positional ordering eliminates this category of implementation ambiguity.</t>
          <t>The practical consequence of these design choices is immediate implementability. DKIM2-core header processing requires only the tag-value parser already present in every DKIM1 and ARC implementation - no new libraries, no new data structures, no new parsing infrastructure. A conformant DKIM2-core milter can be built by extending an existing ARC milter with envelope binding and modification declaration. The incremental implementation cost above a working ARC milter is measured in a few weeks, not months. This stands in contrast to DKIM2-extended, which requires JSON parsing infrastructure, stateful message buffering and persistent shared storage, none of which are present in existing DKIM1 or ARC implementations.</t>
        </section>
      </section>
      <section anchor="security-limitations-of-dkim2-core">
        <name>Security Limitations of DKIM2-core</name>
        <t>Legacy node gap - a legacy node in the delivery chain does not extend the DKIM2 chain. Modifications made by legacy nodes are not declared and cannot be attributed. The gap is visible as a discontinuity in the i= sequence but the content of the gap is unknown. Receivers must apply local policy for messages with gaps in the chain.</t>
        <t>Key compromise - compromise of a signing key allows an attacker to generate valid signatures for that domain. Key rotation procedures as defined in <xref target="RFC6376"/> apply to DKIM2 keys. The i= sequence provides some mitigation - an attacker who generates a forged signature must insert it into a plausible position in the chain.</t>
        <t>DNS security - DKIM2 inherits the DNS security properties of DKIM1. Key publication relies on DNS, which is subject to cache poisoning and other attacks unless DNSSEC is deployed. Operators SHOULD deploy DNSSEC for their signing domains.</t>
        <t>Relaxed domain match - the relaxed domain match algorithm for mf= allows subaddress schemes used for bounce handling. Operators should be aware that this algorithm permits signatures from subdomains of the MAIL FROM domain, which may be exploitable if subdomain delegation is not carefully controlled.</t>
      </section>
      <section anchor="security-considerations-for-dkim2-extended">
        <name>Security Considerations for DKIM2-extended</name>
        <t>DKIM2-extended introduces additional attack surface beyond DKIM2-core. Operators considering DKIM2-extended deployment should evaluate the following.</t>
        <section anchor="json-parsing-attack-surface">
          <name>JSON Parsing Attack Surface</name>
          <t>Message-Instance headers contain base64-encoded JSON that must be decoded and parsed at every verifying hop. JSON parsers process untrusted external input in the delivery critical path and are subject to algorithmic complexity attacks that cause excessive CPU consumption, memory exhaustion through deeply nested structures, parser inconsistency across implementations and buffer overflows in poorly implemented parsers.</t>
          <t>A specific concern is Type Confusion: differences in JSON parser implementations regarding duplicate keys and numerical precision can cause a recipe to be interpreted differently by intermediaries and final recipients. An attacker could craft a recipe that validates correctly at intermediate hops - where the signature is verified - but is interpreted differently at the final recipient, causing signature validation to succeed on a message body that differs from what the signer intended. This attack exploits parser inconsistency rather than cryptographic weakness and cannot be mitigated by stronger signing algorithms.</t>
          <t>The JSON recipe syntax also exhibits semantic ambiguity: the same construct - an empty array [] - is used in different contexts with different meanings. In backward-looking recipes it declares that a header field was added by the current hop and had no previous value. In forward-looking recipe proposals discussed in the working group, the same construct declares that a header field should be ignored during verification of a future message. This dual meaning requires implementations to determine the correct interpretation from context, introducing a category of parser confusion that does not exist in the tag-value formats used by DKIM1 and DKIM2-core.</t>
          <t>The need to define explicit limits on object count, nesting depth and total recipe size - as discussed in Section 4.3.1 - demonstrates that this attack surface has been recognized. Operators MUST ensure that their JSON parsing implementation enforces strict resource limits on input size, nesting depth and object count appropriate to their operational environment. Implementations SHOULD use a JSON parser that strictly conforms to <xref target="RFC8259"/> and rejects input that is ambiguous under that specification - in particular, implementations MUST reject JSON objects with duplicate keys rather than silently selecting one value. Sandboxing the JSON parser from the MTA delivery process is RECOMMENDED where operationally feasible.</t>
        </section>
        <section anchor="recipe-chain-integrity">
          <name>Recipe Chain Integrity</name>
          <t>A malicious intermediary that controls a node in the delivery chain can construct a recipe that presents a clean original message to the verifier while the delivered content is malicious. This attack requires control of a node in the chain and the ability to generate a valid signature for that node's domain, but is feasible for a compromised or malicious intermediary. Verifiers MUST validate the complete recipe chain from originator to final recipient and MUST NOT rely on individual recipes in isolation.</t>
        </section>
        <section anchor="semantic-gap-between-verification-and-visualization">
          <name>Semantic Gap Between Verification and Visualization</name>
          <t>DKIM2-extended introduces a structural discrepancy between the reconstructed body - the previous state that is cryptographically verified - and the transferred body - the modified state that is rendered to the end user. This creates a semantic gap that undermines the fundamental premise of email authentication: that the content being displayed is the content that was authenticated.</t>
          <t>When a receiver applies a body recipe to validate a DKIM signature on a version of the message that is no longer present, a verification pass result is semantically ambiguous. The user is presented with a verified status - a positive Authentication-Results header or a trust indicator in a mail client - but the content displayed does not correspond to the cryptographically covered data.</t>
          <t>This gap is a vector for social engineering. A compromised intermediary can craft modifications that are functionally malicious while providing a valid reconstruction recipe that produces a clean original. The receiver's verification passes on the ghost version; the user sees and acts on the malicious version.</t>
          <t>There is no standardized mechanism to communicate a "reconstructed authentication" state to human recipients without creating UI confusion or warning fatigue. The DKIM2-extended body recipe mechanism therefore constitutes a departure from the "What You See Is What Was Signed" principle. It should be treated as a specialized tool for automated forensic processing rather than a general-purpose body integrity mechanism for end-user trust decisions.</t>
          <t>This concern is distinct from but related to the Recipe Injection attack described in Section 8.3.2. Recipe Injection exploits the gap to authenticate a stolen message. The semantic gap concern exists even without malicious intent - any legitimate body modification creates a divergence between what was authenticated and what is displayed.</t>
        </section>
        <section anchor="attribution-of-change-vs-verification-of-state">
          <name>Attribution of Change vs. Verification of State</name>
          <t>It has been argued that body recipes provide attribution for modifications. However, attribution of a state change is not equivalent to verification of the previous state. In mixed environments (DKIM1/DKIM2), an intermediary can provide a cryptographically consistent recipe for a state that never existed, effectively signing a fabrication. As long as the fabrication is consistent with a previously obtained DKIM1 signature, the mechanisms described in the DKIM2-extended profile validate the lie as truth.</t>
          <t>The attack proceeds as follows: a malicious intermediary in possession of a stolen DKIM1-signed message receives a legitimate but unsigned message. It provides a signed recipe that, when applied to the legitimate message, reconstructs the stolen DKIM1 message. The intermediary's DKIM2 signature validates the recipe's integrity. The recipe validates the stolen message's DKIM1 signature. The receiver sees a valid chain and believes the trusted domain sent the stolen message in the current delivery.</t>
          <t>DKIM2-core avoids this entirely. An intermediary declares what it received and what it changed - attestation of flow, not reconstruction of state. There is no recipe mechanism that can be used as a payload injector because there is no mechanism for claiming what the previous state was.</t>
          <t>DKIM2-core provides a stateless chain of custody over message headers and body content as transmitted. This property is well-suited to general Internet mail flow across administrative boundaries. DKIM2-extended introduces stateful body reconstruction across those same boundaries, with the verification limitations described above. Implementers SHOULD carefully evaluate the operational, security and legal implications of deploying DKIM2-extended before adoption and MUST NOT treat a passing DKIM2-extended verification result as equivalent to verification of the reconstructed prior message state.</t>
        </section>
        <section anchor="null-recipe-ambiguity">
          <name>Null Recipe Ambiguity</name>
          <t>A null recipe declares that a modification was made but provides no information about the nature or extent of the modification. A malicious intermediary can use a null recipe to conceal arbitrary body modifications while remaining nominally compliant with the protocol. Receivers that rely on body recipe verification for security decisions MUST treat null recipes as untrusted modifications equivalent to a complete body replacement.</t>
        </section>
        <section anchor="recipe-stripping">
          <name>Recipe Stripping</name>
          <t>An intermediary that strips body recipe content from a message removes information that downstream verifiers depend on. The specification does not currently define how receivers should handle messages with stripped or truncated recipes. Implementations MUST handle this case gracefully without crashing or producing incorrect verification results. Stripped recipes SHOULD be treated as null recipes for the purpose of verification policy.</t>
        </section>
        <section anchor="stateful-milter-attack-surface">
          <name>Stateful Milter Attack Surface</name>
          <t>The persistent shared storage required by stateful DKIM2-extended milter implementations is an additional attack surface. Compromise of the shared storage allows an attacker to manipulate cached message state and cause the milter to generate incorrect recipes or signatures. Operators MUST apply appropriate access controls to stateful milter storage and MUST monitor for unexpected modifications.</t>
        </section>
      </section>
      <section anchor="cryptographic-agility">
        <name>Cryptographic Agility</name>
        <t>DKIM2-core mandates support for RSA-SHA256 and Ed25519-SHA256, as specified in Section 3.6. DKIM2-core evaluates the body hash independently of signature generation: the bh= value is computed first and included as a tag in the DKIM2-Signature header, which is then signed as a whole. This pre-hashed input model is essential for streaming processing of message bodies and must be preserved by any future signing algorithm. Working group discussion has confirmed this constraint in the context of seeking post-quantum algorithm guidance from the Crypto Forum Research Group. Some post-quantum signature schemes incorporate their own hash function and do not accept pre-hashed input, which would be incompatible with this architecture. The tag-value format of DKIM2-Signature imposes no constraints on the signing algorithm beyond producing a binary output encodable in base64 and accepting pre-hashed input. This ensures forward compatibility with post-quantum algorithms that meet these requirements when they are standardized for use in email authentication. Operators should monitor the development of post-quantum algorithm standards and be prepared to add support for new algorithms as they are standardized.</t>
        <t>The base specification's chain matching model binds mf= and rt= as tags within DKIM2-Signature itself, alongside d=, s=, a=, b=, bh= and optional flags. A prior working group proposal to carry sender and recipient binding in separate plaintext header fields was not adopted. Combined with the working group's direction toward dual-algorithm signing - a classical algorithm alongside a post-quantum algorithm - within a single DKIM2-Signature header, this concentration of content into one field compounds under size pressure: post-quantum signature material must coexist with envelope binding tags and modification flags in the same field. A DKIM2-Signature carrying RSA-SHA256 and ML-DSA-44 signatures together with mf=, rt=, d=, s= and flags would exceed 4000 characters in a single header field. With separated envelope binding, each DKIM2-Signature carries only signature material - approximately 350 characters for RSA-SHA256 or 3300 for ML-DSA-44 - and the envelope headers remain unchanged regardless of algorithm count. DKIM2-core's separation of envelope binding into dedicated header fields (DKIM2-Sig-mf, DKIM2-Sig-rt) avoids this concentration - a second algorithm is accommodated by an additional DKIM2-Signature header field carrying only signature material, not by enlarging a single field that also carries envelope and modification state.</t>
        <t>The use of both RSA-SHA256 and Ed25519-SHA256 in parallel is RECOMMENDED during the transition period to provide cryptographic agility. Ed25519 signatures are significantly shorter than RSA signatures and impose lower computational overhead at scale.</t>
      </section>
      <section anchor="timestamp-handling">
        <name>Timestamp Handling</name>
        <t>DKIM2 signatures include a timestamp. Receivers MUST reject signatures with timestamps more than 5 minutes in the future. This prevents pre-generated signature replay while accommodating normal clock skew between NTP-synchronized systems. A tolerance of 5 minutes is sufficient for any NTP-synchronized infrastructure and eliminates the replay window that a looser future timestamp check would create.</t>
        <t>Signatures with timestamps more than 15 days in the past SHOULD be treated as potential replays and rejected subject to local policy. The 15-day threshold accommodates legitimate redistribution delays including mailing list queuing, temporary delivery failures and held messages without creating an excessive replay window. Note that mailing list redistribution introduces a new signature at the time of redistribution - the relevant timestamp is when the list signed the message, not when the original sender signed it. Operators SHOULD NOT configure thresholds beyond 15 days without explicit operational justification.</t>
      </section>
      <section anchor="x-header-inclusion-in-hh">
        <name>X-* Header Inclusion in hh=</name>
        <t>The DKIM2 base specification <xref target="I-D.ietf-dkim-dkim2-spec"/> excludes all X-* header fields from the signed header set. The hh= mechanism defined in this profile takes a more granular approach: vendor-specific diagnostic headers are excluded, but all other X-* headers are included.</t>
        <t>The exclusion covers header fields used as internal diagnostic telemetry by major mail infrastructure operators, which are legitimately stripped by security gateways and content filters at domain boundaries. Examples of such prefixes are X-MS-* (Microsoft Exchange Online Protection), X-GM-* (Google) and equivalent vendor-internal diagnostic namespaces used by other operators. Including them in hh= would cause verification failures at every hop that performs normal header hygiene, effectively requiring the entire delivery chain to preserve proprietary diagnostic data - the same architectural problem illustrated by Microsoft's ARC implementation in Section 5.5.1. The list of excluded prefixes is implementation-defined and SHOULD be configurable to accommodate the diagnostic namespaces of operators in the specific deployment environment.</t>
        <t>All remaining X-* headers are included in the hh= computation. This is a deliberate security decision. X-* headers that are not vendor diagnostic telemetry are frequently used to carry security-relevant metadata between trusted components: antispam scores, phishing detection results, authenticated user identities, original envelope information and compliance annotations. An attacker who can inject an X-* header without detection can attempt to influence downstream security decisions - suppressing a spam score, asserting a false authenticated identity, or altering retention classification. Including non-vendor X-* headers in hh= closes this attack surface: any undeclared addition or modification will cause the rollback check to fail at the next honest verifying hop.</t>
        <t>The security relevance of this category is not hypothetical. A message carrying the position that X-* headers are "generally specific to services" and should not be signed was itself authenticated with a DKIM1 signature whose h= tag includes X-MS-Exchange-SenderADCheck - a vendor-specific header carrying authentication-relevant information that Microsoft itself treats as significant enough to sign, yet that the proposed blanket exclusion would leave unprotected. The IETF DKIM working group's own mailing list infrastructure adds X-Spam-Status, X-Virus-Scanned and X-Original-To to every message processed through its list server - concrete instances of the antispam scoring and phishing detection metadata category, on infrastructure operated by participants in this discussion. A major mailbox provider operating at global scale, defending the value of such headers in the same working group discussion, stated that they exist because multiple parties introduce them for legitimate delivery-path purposes and confirmed that they are subject to attack in practice - corroborating, from the operator side, the same risk this profile is designed to close.</t>
        <t>Body recipes do not close this gap. A recipe declares a voluntary modification made by an intermediary that chooses to participate in the chain of custody. An attacker injecting a forged header has no incentive to declare it and DKIM2-extended provides no mechanism to compel or detect an undeclared X-* injection independently of the hh= mechanism described here. The regression is not a question of how frequently it is exploited today, but of whether the protocol's security coverage, relative to current DKIM1 practice, is reduced.</t>
        <t>Operators who use X-* headers for internal trust signals between their own components SHOULD ensure these headers are stripped before external delivery, independently of DKIM2.</t>
      </section>
    </section>
    <section anchor="iana-considerations">
      <name>IANA Considerations</name>
      <t>Header field names defined in this profile use the DKIM2- prefix in preference to X- in accordance with <xref target="RFC6648"/>.</t>
      <t>This document requests the registration of the following header fields in the Permanent Message Header Field Registry maintained by IANA in accordance with <xref target="RFC3864"/>: DKIM2-Sig-mf, DKIM2-Sig-rt and DKIM2-Mod. These headers are part of the DKIM2-core protocol and appear in messages in transit.</t>
      <section anchor="dkim2-sig-mf">
        <name>DKIM2-Sig-mf</name>
        <ul spacing="normal">
          <li>
            <t>Header field name: DKIM2-Sig-mf</t>
          </li>
          <li>
            <t>Applicable protocol: mail</t>
          </li>
          <li>
            <t>Status: standard</t>
          </li>
          <li>
            <t>Author/Change controller: IETF</t>
          </li>
          <li>
            <t>Specification document: this document, Section 3.1</t>
          </li>
          <li>
            <t>Related information: carries the SMTP MAIL FROM value bound to a DKIM2 signature at a specific hop, indexed by i=</t>
          </li>
        </ul>
      </section>
      <section anchor="dkim2-sig-rt">
        <name>DKIM2-Sig-rt</name>
        <ul spacing="normal">
          <li>
            <t>Header field name: DKIM2-Sig-rt</t>
          </li>
          <li>
            <t>Applicable protocol: mail</t>
          </li>
          <li>
            <t>Status: standard</t>
          </li>
          <li>
            <t>Author/Change controller: IETF</t>
          </li>
          <li>
            <t>Specification document: this document, Section 3.1</t>
          </li>
          <li>
            <t>Related information: carries exactly one SMTP RCPT TO address per header, bound to a DKIM2 signature at a specific hop. Multiple recipients use multiple headers with incrementing v= sequence index. Indexed by i= for hop and v= for recipient sequence.</t>
          </li>
        </ul>
      </section>
      <section anchor="dkim2-mod">
        <name>DKIM2-Mod</name>
        <ul spacing="normal">
          <li>
            <t>Header field name: DKIM2-Mod</t>
          </li>
          <li>
            <t>Applicable protocol: mail</t>
          </li>
          <li>
            <t>Status: standard</t>
          </li>
          <li>
            <t>Author/Change controller: IETF</t>
          </li>
          <li>
            <t>Specification document: this document, Section 3.3</t>
          </li>
          <li>
            <t>Related information: declares a modification made to a header field by a Reviser node, using:
            </t>
            <ul spacing="normal">
              <li>
                <t>field= - identifies the modified header field name</t>
              </li>
              <li>
                <t>del= - previous value, present for removals and modifications</t>
              </li>
              <li>
                <t>new= - new value, present for additions and modifications</t>
              </li>
              <li>
                <t>fr= - optional frame index for splitting long values across multiple headers</t>
              </li>
              <li>
                <t>i= - hop index</t>
              </li>
              <li>
                <t>seq= - field instance index</t>
              </li>
              <li>
                <t>del= and new= MUST appear on separate header lines and MUST be last in the header field value</t>
              </li>
            </ul>
          </li>
        </ul>
      </section>
    </section>
  </middle>
  <back>
    <references anchor="sec-combined-references">
      <name>References</name>
      <references anchor="sec-normative-references">
        <name>Normative References</name>
        <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="RFC3552">
          <front>
            <title>Guidelines for Writing RFC Text on Security Considerations</title>
            <author fullname="E. Rescorla" initials="E." surname="Rescorla"/>
            <author fullname="B. Korver" initials="B." surname="Korver"/>
            <date month="July" year="2003"/>
            <abstract>
              <t>All RFCs are required to have a Security Considerations section. Historically, such sections have been relatively weak. This document provides guidelines to RFC authors on how to write a good Security Considerations section. 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="72"/>
          <seriesInfo name="RFC" value="3552"/>
          <seriesInfo name="DOI" value="10.17487/RFC3552"/>
        </reference>
        <reference anchor="RFC3864">
          <front>
            <title>Registration Procedures for Message Header Fields</title>
            <author fullname="G. Klyne" initials="G." surname="Klyne"/>
            <author fullname="M. Nottingham" initials="M." surname="Nottingham"/>
            <author fullname="J. Mogul" initials="J." surname="Mogul"/>
            <date month="September" year="2004"/>
            <abstract>
              <t>This specification defines registration procedures for the message header fields used by Internet mail, HTTP, Netnews and other applications. 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="90"/>
          <seriesInfo name="RFC" value="3864"/>
          <seriesInfo name="DOI" value="10.17487/RFC3864"/>
        </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="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="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="I-D.ietf-dkim-dkim2-spec">
          <front>
            <title>DomainKeys Identified Mail Signatures v2 (DKIM2)</title>
            <author initials="R." surname="Clayton">
              <organization/>
            </author>
            <author initials="W." surname="Chuang">
              <organization/>
            </author>
            <author initials="B." surname="Gondwana">
              <organization/>
            </author>
            <date year="2026" month="May"/>
          </front>
          <seriesInfo name="Internet-Draft" value="draft-ietf-dkim-dkim2-spec-02"/>
        </reference>
      </references>
      <references anchor="sec-informative-references">
        <name>Informative References</name>
        <reference anchor="RFC3935">
          <front>
            <title>A Mission Statement for the IETF</title>
            <author fullname="H. Alvestrand" initials="H." surname="Alvestrand"/>
            <date month="October" year="2004"/>
            <abstract>
              <t>This memo gives a mission statement for the IETF, tries to define the terms used in the statement sufficiently to make the mission statement understandable and useful, argues why the IETF needs a mission statement, and tries to capture some of the debate that led to this point. 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="95"/>
          <seriesInfo name="RFC" value="3935"/>
          <seriesInfo name="DOI" value="10.17487/RFC3935"/>
        </reference>
        <reference anchor="RFC7942">
          <front>
            <title>Improving Awareness of Running Code: The Implementation Status Section</title>
            <author fullname="Y. Sheffer" initials="Y." surname="Sheffer"/>
            <author fullname="A. Farrel" initials="A." surname="Farrel"/>
            <date month="July" year="2016"/>
            <abstract>
              <t>This document describes a simple process that allows authors of Internet-Drafts to record the status of known implementations by including an Implementation Status section. This will allow reviewers and working groups to assign due consideration to documents that have the benefit of running code, which may serve as evidence of valuable experimentation and feedback that have made the implemented protocols more mature.</t>
              <t>This process is not mandatory. Authors of Internet-Drafts are encouraged to consider using the process for their documents, and working groups are invited to think about applying the process to all of their protocol specifications. This document obsoletes RFC 6982, advancing it to a Best Current Practice.</t>
            </abstract>
          </front>
          <seriesInfo name="BCP" value="205"/>
          <seriesInfo name="RFC" value="7942"/>
          <seriesInfo name="DOI" value="10.17487/RFC7942"/>
        </reference>
        <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="RFC6973">
          <front>
            <title>Privacy Considerations for Internet Protocols</title>
            <author fullname="A. Cooper" initials="A." surname="Cooper"/>
            <author fullname="H. Tschofenig" initials="H." surname="Tschofenig"/>
            <author fullname="B. Aboba" initials="B." surname="Aboba"/>
            <author fullname="J. Peterson" initials="J." surname="Peterson"/>
            <author fullname="J. Morris" initials="J." surname="Morris"/>
            <author fullname="M. Hansen" initials="M." surname="Hansen"/>
            <author fullname="R. Smith" initials="R." surname="Smith"/>
            <date month="July" year="2013"/>
            <abstract>
              <t>This document offers guidance for developing privacy considerations for inclusion in protocol specifications. It aims to make designers, implementers, and users of Internet protocols aware of privacy-related design choices. It suggests that whether any individual RFC warrants a specific privacy considerations section will depend on the document's content.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="6973"/>
          <seriesInfo name="DOI" value="10.17487/RFC6973"/>
        </reference>
        <reference anchor="I-D.chuang-replay-resistant-arc">
          <front>
            <title>Replay Resistant Authenticated Receiver Chain</title>
            <author initials="W." surname="Chuang">
              <organization/>
            </author>
            <date year="2024"/>
          </front>
          <seriesInfo name="Internet-Draft" value="draft-chuang-replay-resistant-arc-11"/>
        </reference>
        <reference anchor="I-D.adams-arc-experiment-conclusion">
          <front>
            <title>Wrap-up of the ARC Experiment</title>
            <author initials="T." surname="Adams">
              <organization/>
            </author>
            <author initials="J." surname="Levine">
              <organization/>
            </author>
            <date year="2026" month="January"/>
          </front>
          <seriesInfo name="Internet-Draft" value="draft-adams-arc-experiment-conclusion-01"/>
        </reference>
        <reference anchor="I-D.ietf-dkim-dkim2-motivation">
          <front>
            <title>DKIM Version 2 Motivation</title>
            <author initials="T." surname="Herr" fullname="Todd Herr">
              <organization/>
            </author>
            <date year="2025"/>
          </front>
          <seriesInfo name="Internet-Draft" value="draft-ietf-dkim-dkim2-motivation"/>
        </reference>
        <reference anchor="I-D.ietf-dkim-dkim2-bcp">
          <front>
            <title>DKIM2 Best Practices</title>
            <author initials="T." surname="Herr" fullname="Todd Herr">
              <organization/>
            </author>
            <date year="2026" month="June" day="18"/>
          </front>
          <seriesInfo name="Internet-Draft" value="draft-ietf-dkim-dkim2-bcp-00"/>
        </reference>
        <reference anchor="DKIM-CHARTER" target="https://datatracker.ietf.org/wg/dkim/about/">
          <front>
            <title>IETF DKIM Working Group Charter</title>
            <author>
              <organization/>
            </author>
            <date year="2026" month="March"/>
          </front>
        </reference>
        <reference anchor="GDPR" target="http://data.europa.eu/eli/reg/2016/679/oj">
          <front>
            <title>Regulation (EU) 2016/679 (General Data Protection Regulation)</title>
            <author>
              <organization>European Union</organization>
            </author>
            <date year="2016" month="April"/>
          </front>
        </reference>
        <reference anchor="ePrivacy" target="http://data.europa.eu/eli/dir/2002/58/oj">
          <front>
            <title>Directive 2002/58/EC (Directive on privacy and electronic communications)</title>
            <author>
              <organization>European Union</organization>
            </author>
            <date year="2002" month="July"/>
          </front>
        </reference>
        <reference anchor="I-D.chuang-mailing-list-modifications">
          <front>
            <title>Tolerating Mailing-List Modifications</title>
            <author initials="W." surname="Chuang">
              <organization/>
            </author>
            <date year="2024" month="February"/>
          </front>
          <seriesInfo name="Internet-Draft" value="draft-chuang-mailing-list-modifications-04"/>
        </reference>
        <reference anchor="I-D.levine-dmarc-listugh">
          <front>
            <title>Mailing lists and mail forwarders vs. DMARC</title>
            <author initials="J." surname="Levine">
              <organization/>
            </author>
            <date year="2023" month="August"/>
          </front>
          <seriesInfo name="Internet-Draft" value="draft-levine-dmarc-listugh-01"/>
        </reference>
        <reference anchor="DKIM-INTERIM-2026-04" target="https://meetings.conf.meetecho.com/interim/?session=35406">
          <front>
            <title>DKIM Working Group Virtual Interim Meeting</title>
            <author>
              <organization/>
            </author>
            <date year="2026" month="April" day="29"/>
          </front>
        </reference>
      </references>
    </references>
    <?line 1371?>

<section anchor="implementation-notes-informative">
      <name>Implementation Notes (Informative)</name>
      <section anchor="dkim2-mod-header-representation">
        <name>DKIM2-Mod Header Representation</name>
        <t>A DKIM2-Mod header declaration maps directly to a simple flat data structure. The following Go example illustrates a complete representation:</t>
        <sourcecode type="go"><![CDATA[
// HeaderMod represents a single DKIM2-Mod header declaration
type HeaderMod struct {
    HopIndex   int    // i= tag: hop sequence number
    SeqIndex   int    // seq= tag: field instance index
    FrameIndex int    // fr= tag: fragment index, 0 if not fragmented
    FieldName  string // field= tag: name of the modified header field
    DelValue   string // del= tag: previous value, empty if addition
    NewValue   string // new= tag: new value, empty if removal
}

// ModChain accumulates all DKIM2-Mod declarations for a message
// at a single hop
type ModChain []HeaderMod

// ModificationType returns the type of modification
func (m HeaderMod) ModificationType() string {
    switch {
    case m.DelValue != "" && m.NewValue != "":
        return "modification"
    case m.DelValue != "":
        return "removal"
    case m.NewValue != "":
        return "addition"
    default:
        return "invalid"
    }
}
]]></sourcecode>
        <t>Note: the ModificationType function treats empty string as absence of the tag, which is consistent with the ABNF definition <tt>dkim2-mod-value = 1*(VCHAR / WSP)</tt> that requires at least one character. A del= or new= tag with an empty value is not valid per the grammar and MUST be rejected by parsers. The "invalid" return value covers this case and any other combination where both DelValue and NewValue are empty.</t>
        <t>All fields are primitive types. No JSON parser, no base64 decoder, no recursive structures. The complete state for a hop can be built by iterating the message headers once in O(n) time with O(1) memory per header.</t>
      </section>
      <section anchor="comparison-dkim2-mod-vs-json-header-recipe-encoding">
        <name>Comparison: DKIM2-Mod vs JSON Header Recipe Encoding</name>
        <t>The current DKIM2 specification encodes header modifications as JSON inside the Message-Instance header. The following is a real example from a working implementation demonstrated during the development of this specification. The r= field decoded from base64 contains:</t>
        <sourcecode type="json"><![CDATA[
{
  "h": {
    "content-transfer-encoding": [],
    "content-type": [],
    "list-help": [],
    "list-id": [],
    "list-owner": [],
    "list-post": [],
    "list-subscribe": [],
    "list-unsubscribe": [],
    "precedence": [],
    "subject": ["s= format 23:26:28"]
  },
  "b": [[1,1]]
}
]]></sourcecode>
        <t>This structure is not directly readable in mail logs - it requires base64 decoding followed by JSON parsing before any field can be inspected. The equivalent declaration using DKIM2-Mod headers:</t>
        <artwork><![CDATA[
DKIM2-Mod: i=2; seq=1; field=Subject; del="s= format 23:26:28"
DKIM2-Mod: i=2; seq=1; field=List-Id; new="dkim2.mailman.dkim2.com"
DKIM2-Mod: i=2; seq=1; field=List-Help; new="<mailto:dkim2-request@mailman.dkim2.com>"
DKIM2-Mod: i=2; seq=1; field=Precedence; new="list"
]]></artwork>
        <t>The Go data structures required for each approach illustrate the implementation complexity difference:</t>
        <sourcecode type="go"><![CDATA[
// DKIM2-Mod - flat structure, no JSON dependency
type HeaderMod struct {
    HopIndex   int    // i=
    SeqIndex   int    // seq=
    FrameIndex int    // fr= optional
    FieldName  string // field=
    DelValue   string // del= empty if addition
    NewValue   string // new= empty if removal
}

// JSON recipe - requires recursive structure and runtime type assertion
type HeaderRecipe struct {
    Headers map[string][]interface{} `json:"h"`
    Body    [][]int                  `json:"b"`
}

// Processing requires:
// 1. Accumulate complete base64 value across folded lines
// 2. Decode base64 into buffer
// 3. Unmarshal JSON into map with interface{} values
// 4. Type-assert each value to determine if string or empty
// 5. Apply resource limits before processing
]]></sourcecode>
        <t>The DKIM2-Mod approach requires only the tag-value parser already present in every DKIM1 and ARC implementation. The JSON recipe approach requires base64 decoding, JSON unmarshaling with dynamic type handling and resource limit enforcement as discussed in Sections 4.3.1 and 7.3.</t>
      </section>
    </section>
    <section numbered="false" anchor="appendix-b-milter-implementation-notes-informative">
      <name>Appendix B. Milter Implementation Notes (Informative)</name>
      <t>The following describes the milter callback structure for a DKIM2-core implementation. The structure demonstrates that all mandatory DKIM2-core functionality is expressible within the standard milter interface without MTA core modifications. DKIM2-core requires two separate milter instances: an inbound milter for verification and an outbound milter for signing, positioned respectively first and last in the milter chain.</t>
      <section numbered="false" anchor="b1-inbound-milter-verification-path">
        <name>B.1 Inbound milter - verification path</name>
        <t><tt>dk2_connect</tt>, <tt>dk2_helo</tt> - connection-level callbacks. No DKIM2-specific processing.</t>
        <t><tt>dk2_envfrom</tt> - initializes the per-session private structure and resets all hash contexts and header reservoirs. Stores the MAIL FROM value for later verification against DKIM2-Sig-mf. On connection reuse (RSET), resets all per-message state without freeing the allocated structures.</t>
        <t><tt>dk2_envrcpt</tt> - called once per recipient. Appends each RCPT TO value to a per-session list for later verification against DKIM2-Sig-rt headers.</t>
        <t><tt>dk2_header</tt> - called once per header field. Accumulates each field in a dynamically allocated in-memory reservoir with DoS protection via a configurable maximum header count and a limit on total header memory. Includes removal of other spoofed internal headers arriving from external sources. When fr= fragmentation tags are present in DKIM2-Mod headers, accumulates fragments for reassembly at <tt>dk2_eom</tt>.</t>
        <t><tt>dk2_eoh</tt> - end of headers. For RSA-SHA256 implementations MAY initiate DNS key lookup as an optimization, reducing the time spent waiting at <tt>dk2_eom</tt>. Signing algorithms that require the complete input before verification, including Ed25519-SHA256 and future elliptic curve algorithms, defer all operations to <tt>dk2_eom</tt>.</t>
        <t><tt>dk2_body</tt> - called in chunks as the body arrives. Updates the body hash incrementally using relaxed or strict canonicalization as specified in the signature. This streaming approach means the milter never holds the message body in memory - only the hash context state is updated at each chunk. A message of arbitrary size imposes no additional memory cost beyond the fixed hash context.</t>
        <t><tt>dk2_eom</tt> - finalizes the body hash, fetches the public key via DNS, reconstructs the signed header input from the reservoir, adds the incomplete DKIM2-Signature header to the signed input, verifies the signature, checks DKIM2-Sig-mf against the stored MAIL FROM and checks each stored RCPT TO against a corresponding DKIM2-Sig-rt header. Verifies that each DKIM2-Mod declaration accurately reflects the modification declared at that hop. Returns SMFIS_REJECT on envelope mismatch, invalid signature or inconsistent modification declaration, SMFIS_TEMPFAIL on transient DNS error and SMFIS_CONTINUE on success.</t>
        <t><tt>dk2_abort</tt>, <tt>dk2_close</tt> - release all per-session resources including the header reservoir and hash contexts.</t>
      </section>
      <section numbered="false" anchor="b2-outbound-milter-signing-path">
        <name>B.2 Outbound milter - signing path</name>
        <t><tt>dk2_connect</tt>, <tt>dk2_helo</tt> - connection-level callbacks. No DKIM2-specific processing.</t>
        <t><tt>dk2_envfrom</tt> - initializes the per-session private structure. Stores the MAIL FROM value for construction of DKIM2-Sig-mf.</t>
        <t><tt>dk2_envrcpt</tt> - called once per recipient. Appends each RCPT TO value to a per-session list for construction of DKIM2-Sig-rt headers.</t>
        <t><tt>dk2_header</tt> - called once per header field. Accumulates the field in the reservoir. For RSA-SHA256 implementations, simultaneously updates the signed header digest incrementally, allowing a single-pass streaming implementation. Signing algorithms that require the complete input before signing, including Ed25519-SHA256 and future elliptic curve algorithms, accumulate only in the reservoir and reconstruct the signed header input in <tt>dk2_eom</tt>.</t>
        <t><tt>dk2_eoh</tt> - no DKIM2-specific processing for the outbound path.</t>
        <t><tt>dk2_body</tt> - called in chunks. Updates the body hash incrementally using relaxed or strict canonicalization as specified in the signature. This streaming approach means the milter never holds the message body in memory - only the hash context state is updated at each chunk. A message of arbitrary size imposes no additional memory cost beyond the fixed hash context.</t>
        <t><tt>dk2_eom</tt> - Finalizes the body hash, constructs DKIM2-Sig-mf with i= and addr= from the MAIL FROM value, constructs one DKIM2-Sig-rt per stored RCPT TO with incrementing v= values, validates any DKIM2-Mod headers present, adds the incomplete DKIM2-Signature header to the digest, finalizes and signs, then adds the complete DKIM2-Signature to the message. For signing algorithms that require the complete input before signing, including Ed25519-SHA256 and future elliptic curve algorithms, the complete signed header input is constructed from the reservoir at this stage and signed in a single operation.</t>
        <t><tt>dk2_abort</tt>, <tt>dk2_close</tt> - release all per-session resources.</t>
      </section>
      <section numbered="false" anchor="b3-stateless-design-confirmation">
        <name>B.3 Stateless design confirmation</name>
        <t>Both milter instances are fully stateless between sessions. The private structure allocated at <tt>dk2_connect</tt> carries the complete session state - envelope values, header reservoir and hash contexts - and is released at <tt>dk2_close</tt>. No shared storage between milter instances or between sessions is required at any point. No MTA core modifications are required.</t>
        <t>DKIM2-core header and body processing is fully streaming - no message content is buffered at any point. The header reservoir holds only header field names and values, not body content. This is a fundamental architectural difference from DKIM2-extended, which requires buffering body content for recipe generation.</t>
      </section>
    </section>
    <section numbered="false" anchor="acknowledgements">
      <name>Acknowledgements</name>
      <t>The author would like to thank the participants of the IETF-DKIM mailing list for the rigorous technical exchange that motivated this document.</t>
      <t>Special thanks to Pete Resnick for his guidance on the IETF process, for encouraging the formalization of these concerns into an Internet-Draft and for clarifying the process by which any contributor may address the architectural and security implications of proposed standards.</t>
      <t>The author acknowledges Wei Chuang for his independent convergence on the importance of human-readable envelope binding fields and Bron Gondwana for the extensive debate regarding stateful delivery models.</t>
      <t>Valuable perspectives were provided by Philip Guenther on security gateway deployment requirements and by Steffen Nurpmeso on architectural simplification and attack surface reduction. Hannah Stern contributed detailed technical observations on base64 encoding complexity and recipe streaming limitations. John Levine and Richard Clayton are thanked for their participation in the working group discussion. R. Latimer is thanked for raising the perspective of MTA implementers and for drawing attention to the Alternate Submission Scenarios. Murray Kucherawy is thanked for his clarification on the scope of interface-level implementability in IETF protocol design.</t>
    </section>
  </back>
  <!-- ##markdown-source:
H4sIAAAAAAAAA9S9e3Pb2JUv+r8+BcpTp9pOCNmSH92tvj5n5Fe3J5bta6mT
TE2lckASpNAmAQYAJTOpzGe/673X3gAluXvunDpdldiWSGA/1l57PX7rt/I8
P+irflWeZPdOs1flZtXs1mXdZx/bZlGtymzRtNmrP7w9O86uqiI7q1Z92WZv
a/j/RTEr7x0U02lbXsG3+UPDJ9w7mDezuljDG+ZtsejzdTObVUU+/1ytj/O5
fT7f8OfzR08PZkVfLpt2d5JV9aI56LbTddV1VVNf7DbwnLevL94cVJv2JOvb
bdcfP3r0/aPjg6Iti5PsdLNZVfB9+HCXFfU8+1QWq/yiWpcH1037edk2280J
zSj7E/y7qpfZj/izg8/lDj4wP8n+g2YyydY010lWrotqlRXb/hJGKY+eZGHg
mQz8LwcHXQ9v/GuxamoY5a7sDjbVyUGW9c2M/5llXdP2bbno7N+7tf/nrFlv
illvv91O7Sd1c3CAg2hafGQOKwPf+uNhdkbLCT/KMl7lP1Z937RV43/TtMui
rv5OY4f1u3hxWPX0C5rcSXZ1yLvyr1U/xV8d1E27hk9flfiyT29eHh8dfS9/
ffz06bH+9btnT+SvT549+U7++vT4sf706ePjo/BX/dqzx98+07+Gr313/FRf
8d2zo2/xr2/zV4dV2S9IWERiuk05O6Gxq9y+amAS9R/KXZe9neMeLapynp3h
rp1Xy7rot23ZZVfH2X3a2Qf36NthLfE/Wc9Ph9nLVbHrmzr++Z/g55fbol7G
P35xmP3Y1PProuZlnoPcnmTHj46foRTjT7qyrcoOpVjfRGenLvv8FZ4GPRRj
s8xBqA/wq/FWPP7+8VP567ffP9E1ffr0e13IZ99/+1hXb0ajzluQ1mIHf3QV
ymifF22yiJ/oE3Ba5BPZaRD4Ek/RrIQhtLAMsNY3rGC8UrYgT75qNW4YdX50
JFMr5sW6ox+VXzbwYFIis6aerbaoKuLp/aktNvl2kzWLDKaVnX56mb22b90w
nYvD7BTfE//03w6zd+VVVZeDXT/6qnneMgV+3NghWDcgEHya46OAeu2PZYvf
zo5BA+jHbp7iT2Xbyg9Vi1w083n4uU3xt0l1GPaeeU1nm+GEjrMXZYf3CejB
alZ2/1Vzge16lh9995tmBAPOHz2Cr+BA85c/nX66eP0pngLeViMXDp6kFl7B
s+mLdlnCWy77ftOdPHwIgyx6mPDnsqVFOgQN/vB6+RDf+rCYNtv+4WAyj+En
P776+Ck92MvtitY8u//65wfw2aNnD599+312/8eyLttilb2Cd+Ft3Zcz+lj4
xqiqhJHAY19v22ZTFnX2c23ipYM5gsE8GUxLZnVY4jfxj4flqnrYlsuHOqSH
zS/wrfJjC0Iy2yWCULU4vKsSnv/o+OHT7x6+fgkK3X4K497w9+jWL1fw87ap
qxneqettrTbBr5zSo+P80bd3nNK8ah/qIGlGThHjdQsikK9Ao8FxmMNdJQOL
p3vRrGBvepSWM/nKO/gKnGj3lV+hhvFO+RWaeP+weadxhivSiPl8jfoMP7hd
XsaTkplk+Es2zsi0ggvuumjnoLWyq+4we3UG2vmGqe1Rvo/zR193lMfGyxqX
zvLb93CS4U8+W09G9Gx8nP9Ytf0WThO9rFpnZ2WJ2zd+vNf8y+4QlP3iEP9V
zi4b+Nf6YcXff/i/upJM3uePnz559Gxw2J/kx98fHOR5nhXTDjUFGG0Xl1WX
gbW9JbN0Xi5gfrDOI7Yqm/X77aZgLMF1WfQZPLdab1YlPqOYwvfRGcCLtPwC
C4eLwNZyVqlnkF1XsHfbPoukBUxhfsFFW9TdAr5wusRh3T+7OH0AJ7UtwUJe
9CAO5WH2Ft6r48JprEFiCjBtd/xBnQoPNMef4SPASMHxlPVVuYLjnE2reg4/
mGQztFzQAJiBz9DMd5PssixA6rJiNmu2OC+Qzh5+zGYHPL+8wreDZkFRfXX+
PnEC6MegLpoN/gu2vvzSl/Uc1jAZmv7cDW8KA4AXzapNySfhDHa7WJb52xpN
HVg/HhychwtY5q7cFC2/FLZCrlF40XTnNxccIJDj9QntTLRGxXwOVhRIFP0K
FCUI/Q7+Dt+gHSpXXVjrOewifY4v33BpB9nCEaOs0btJIKp61rJ4rFaggmdt
03UwB5CGBna4bLYd+nJtAbK6naFFPsGvrLa4N1m3hm/BOqLKa9pukoG+vkIr
pq9keWD0JZzTS1QBcAi3JE3wuQ6/jmPt4KYXIcynRQeTcAtDM2RJviw6XBXY
2axcLOTyUCf3iN4F6ucQD1NJ0gxfJ6PRHy34e930KMzNlCckazXd0k/XxWf4
cu/W5zALUprNQGimpfyWlntk7XBS8fqVs6bbdX25xv0psg5UI7wNjEZY1rW9
wYSwLf+2rdDz6cAJoiNY9/B4cE6XeFDtONPOznazVak6eUezsxHK/ma/bNuq
m1czPsl4vjOYPPwbHqd3r7wUHwyi+6KBz4gMwsNRIMHmwfXk5cp564Jwg+6+
wk/O+UxNaCDNZtOgKDT1IWu8dTWfr8qDg39BZds28y0N6eDgbgotnAW3MHAn
ratelJSM7yj7xz/EW/3nP2lpWOOppQ4nHv0ImB84+M2KP42u6z//6YWb7grR
KUXfg00HgjvFP0CN4Not2mYNEs+XXfV3GPK2K3EQpsM63NG2szGAyi9RR6Ay
a3ebvlmCe3MJto4oO9i7/roEEV+zVqGZih+Mzzg/u/gYno6rv0ZJ60TsSUjx
RkKraQX/hFWupnTm/N7py3BEZ6dv32VvPn0445jLy48X2cWH7KpYbUtaz7KA
s0uv7VHzF2xpwlHBLw9GCeuUgfIFFXXZbPDeR/UPx2ALFxpKLp5fOoioTkGX
gpRFx1f1U7ddwPZW+El4lWz8nVXgP/5xs+v1z3/Cev3UXONIJ6xzt22LL0Pv
3S69rFh1jcgD3WNO98PU4VqqQWmzdgIF0Fx3fIuuy3lVoCmDY4dvzmAPyuQ6
XcMdka4iPR6G7yY/L3s8BPBBeC18j1UWXnAVKpYrdhjprsHrxcZUyfFKzgoq
4gq9hW1L4oGq5AtcnSeo84LageNULrYrMw0ijSMKZIOv7kjLduAPwcLD3dzC
NCbZv51/eI+ySSpebiTYpYrkAhajJ+HcFPAU3G61G5IVctoU9xZ+H9QoyGW8
0nzZju8P7WJbVKg40Oincy8eE7rsYGF2cIrRoEAnjL0QWAo4Azg70tEYgez0
HoJ7B7XbrkRVC2dV9ZJdv5EUHabmHbwe1CIJlN2pc69L7aQutvWMLRTYI5wx
yMt1Y3r5BJSqu51OIktLDQjbvP8m2yq6L2HaIEdwd43boHtNTzAqWZdFIqFW
g4yQw2uwjCvQBLDxiwKeB+KgxyqIC+iKBnwEUjDBuABHS2RxBfNzo7aDUDeR
mOOxMAVNKlEs/Q40HdpBFvKD1anLEu9yNFDoBMK4ccHQijT9gtrxCs43LQrO
XeTHtBE/3m4PVRRiYeLP1l25ukL5P6fRwf7DB9TUaeqVXew8FH9ClhRF4Nv6
Gu6gS5gb2hhgr3yhOBbIyg4XMzZPDoPU6Y9OImPama6JwexeOVwMylLssaXp
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
4H8DTpsx1azKAgA=

-->

</rfc>
