<?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.34 (Ruby 3.4.9) -->
<rfc xmlns:xi="http://www.w3.org/2001/XInclude" ipr="trust200902" docName="draft-petta-rfc4130bis-05" category="info" consensus="true" submissionType="IETF" tocInclude="true" sortRefs="true" symRefs="true" version="3">
  <!-- xml2rfc v2v3 conversion 3.32.0 -->
  <front>
    <title>AS2 Specification Modernization</title>
    <seriesInfo name="Internet-Draft" value="draft-petta-rfc4130bis-05"/>
    <author fullname="Debra Petta">
      <organization>Drummond Group, LLC</organization>
      <address>
        <email>debrap@drummondgroup.com</email>
      </address>
    </author>
    <date year="2026" month="March" day="18"/>
    <keyword>AS2</keyword>
    <keyword>EDIINT</keyword>
    <keyword>B2B</keyword>
    <abstract>
      <?line 65?>

<t>This document provides an applicability statement (RFC 2026, Section 3.2)
describing how to securely exchange structured business data over HTTP.
Structured business data may be XML; Electronic Data Interchange (EDI)
in either the American National Standards Committee (ANSI) X12 format or
the UN Electronic Data Interchange for Administration, Commerce, and
Transport (UN/EDIFACT) format; or other structured data formats. The data
is packaged using standard MIME structures. Authentication and data
confidentiality are obtained by using Cryptographic Message Syntax with
S/MIME security body parts (see <xref target="https-tls-reqs"/>).
Authenticated acknowledgements make use of multipart/signed
Message Disposition Notification (MDN) responses to the original HTTP message.
This applicability statement is informally referred to as "AS2" because
it is the second applicability statement, produced after "AS1" (RFC 3335).
This document obsoletes RFC 4130 and stands on its own without reference to AS1
or SMTP, except where required for IANA registry updates.</t>
      <t>This document also updates IANA registries originally created by RFC
3335 and RFC 4130.</t>
    </abstract>
    <note removeInRFC="true">
      <name>About This Document</name>
      <t>
        The latest revision of this draft can be found at <eref target="https://DrummondGroup.github.io/draft-petta-rfc4130bis/draft-petta-rfc4130bis.html"/>.
        Status information for this document may be found at <eref target="https://datatracker.ietf.org/doc/draft-petta-rfc4130bis/"/>.
      </t>
      <t>Source for this draft and an issue tracker can be found at
        <eref target="https://github.com/DrummondGroup/draft-petta-rfc4130bis"/>.</t>
    </note>
  </front>
  <middle>
    <?line 86?>

<section anchor="introduction">
      <name>Introduction</name>
      <t>This document is a revision ("bis") of RFC 4130, which defined the
Applicability Statement 2 (AS2) protocol for secure and reliable
transport of business data over HTTP. It obsoletes RFC 4130. The purpose
of this revision is to modernize the specification, clarify ambiguities,
and incorporate implementation experience gathered since the publication
of RFC 4130. Subsequent versions of this draft will refine these updates
based on discussion and consensus in the IETF community. This revision
also adheres to the principle of backward compatibility. Implementations
conformant with RFC 4130 remain valid under this specification, and no
breaking changes are introduced. In addition, this document updates
existing IANA registrations from RFC 3335 and RFC 4130. The specific
IANA actions are described in <xref target="iana-considerations"/>.</t>
      <t>Note to readers: Some contributors have suggested that this work could
eventually be split into two documents: a minimal RFC4130bis for errata and
clarifications, and a separate AS2 v2 specification with a clean
modern baseline. This document currently attempts to balance both
objectives within a single text, but further discussion may refine
the scope.</t>
      <section anchor="applicable-rfcs">
        <name>Applicable RFCs</name>
        <t>Previous work on Internet EDI focused on specifying MIME content types
for EDI data. <xref target="RFC1767"/> expands on this to specify a comprehensive set
of data security features, specifically data confidentiality, data
integrity/authenticity, non-repudiation of origin, and non-repudiation
of receipt over HTTP. This document recognizes contemporary RFCs and
avoids re-inventing mechanisms wherever possible. Although this
document focuses on EDI data, any other data types describable in a
MIME format are also supported.</t>
        <t>Internet MIME-based EDI can be accomplished by using and complying with
the following RFCs:</t>
        <artwork><![CDATA[
  o  RFC 2616 Hyper Text Transfer Protocol (baseline: HTTP/1.1)
  o  RFC 1767 EDI Content Type
  o  RFC 3023 XML Media Types
  o  RFC 1847 Security Multiparts for MIME
  o  RFC 3462 Multipart/Report
  o  RFC 2045 to 2049 MIME RFCs
  o  RFC 8098 Message Disposition Notification (updates RFC 3798)
  o  RFC 5751 S/MIME v3.2 Specification (obsoletes RFC 3851)
  o  RFC 8551 S/MIME v4.0 (obsoletes RFC 5751)
  o  RFC 5652 Cryptographic Message Syntax (CMS) (obsoletes RFC 3852)
]]></artwork>
        <t>This specification references S/MIME Version 4.0 <xref target="RFC8551"/> as the
baseline for algorithm requirements and security message formats.
S/MIME 4.0 introduces AuthEnvelopedData, which provides authenticated
encryption for algorithms such as AES-GCM and AES-CCM. For backward
compatibility with implementations that have not yet migrated to
S/MIME 4.0, this specification also permits the use of EnvelopedData
from S/MIME 3.2 <xref target="RFC5751"/> when using algorithms such as AES-CBC that
require separate integrity protection. The choice between
AuthEnvelopedData and EnvelopedData is determined by the content
encryption algorithm selected (see <xref target="encryption-algorithms"/>
for details).</t>
        <t>Our intent here is to define clearly and precisely how these are used
together, and what is required by user agents to be compliant with this
document. Implementers should note that HTTP/2 and HTTP/3 MAY be used
as transports, but are not required for interoperability.</t>
        <t>The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT",
"SHOULD", "SHOULD NOT", "RECOMMENDED", "NOT RECOMMENDED", "MAY", and
"OPTIONAL" in this document are to be interpreted as described in
BCP 14 <xref target="RFC2119"/> and <xref target="RFC8174"/> when, and only when, they appear in all
capitals, as shown here.</t>
      </section>
      <section anchor="backward-compatibility-and-interoperability">
        <name>Backward Compatibility and Interoperability</name>
        <t>A central design principle of this specification is "backward
compatibility" with RFC 4130 and with the underlying RFCs it references.
This specification does not redefine or override backward-compatibility
rules established in those RFCs. Implementations MUST rely on the
mechanisms provided in underlying standards.</t>
        <t>Consistent with the Robustness Principle ("be conservative in what you send and liberal in what you receive"),
this document clarifies requirements and aligns terminology but does not introduce breaking changes.
Implementations that conformed to RFC 4130 remain conformant to this specification. Any deviations
are limited to clarifications intended to improve interoperability.</t>
        <t>This specification establishes S/MIME Version 4.0 <xref target="RFC8551"/> as the
baseline for conformant implementations. Implementations MUST support
S/MIME 4.0 message formats (including AuthEnvelopedData) and the
algorithm requirements specified in <xref target="algorithm-requirements"/>.
Implementations SHOULD also support S/MIME Version 3.2 <xref target="RFC5751"/> for
backward compatibility with legacy trading partners that have not yet
migrated to S/MIME 4.0. When both partners support S/MIME 4.0,
implementations SHOULD use AuthEnvelopedData with authenticated
encryption algorithms (AES-GCM, AES-CCM) for improved security.
When interoperating with S/MIME 3.2 systems, implementations SHOULD use
EnvelopedData with algorithms such as AES-CBC that require separate
integrity protection via digital signatures.</t>
        <t>This specification defines requirements for modern AS2 deployments
using contemporary cryptographic algorithms. It does not redefine or
extend the use of weak algorithms such as 3DES or SHA-1. When both
partners support this version of AS2, only modern algorithms are in
scope.</t>
        <t>When interoperability with RFC 4130 systems is required, implementers
SHOULD apply the clarifications provided in <xref target="legacy-interoperability-non-normative"/>
(Legacy Interoperability). <xref target="legacy-interoperability-non-normative"/> is non-normative and does not alter the
algorithm requirements defined in <xref target="algorithm-requirements"/>, but records expected
behavior when communicating with legacy systems.</t>
        <section anchor="legacy-interoperability-non-normative">
          <name>Legacy Interoperability (Non-Normative)</name>
          <t>This section provides the conditions for interoperability with
   legacy AS2 implementations conforming to <xref target="RFC4130"/>. These provisions
   apply only when a modern AS2 implementation communicates with a
   partner that has not migrated to this specification. In such cases,
   both parties are effectively operating under <xref target="RFC4130"/>, not this
   document.</t>
          <t>These notes are provided to reduce ambiguity and ensure consistent
   behavior across implementations. They do not alter the algorithm
   requirements specified in <xref target="algorithm-requirements"/>, nor do they extend the use of
   deprecated algorithms.</t>
          <t>Examples of legacy considerations include:</t>
          <artwork><![CDATA[
     o  **Message Integrity Checks (MICs):** Implementations may continue
        to accept SHA-1 for MIC calculations when required by legacy
        partners. SHA-1 SHOULD NOT be generated by conformant modern
        implementations, but SHA-1 values SHOULD continue to be used to
        maintain backward compatibility.

     o  **Encryption Algorithms:** Implementations may accept inbound
        messages encrypted with 3DES from legacy partners. However, 3DES
        SHOULD NOT be generated by conformant implementations. AES (128-bit
        or stronger) remains the normative requirement in Section 7.2.

        Note: NIST withdrew the 3DES specification on 1 January 2024, and
        disallowed the two-key variant in 2017. Any residual use of 3DES is
        for backward compatibility only and SHOULD NOT be generated by
        conformant implementations.

     o  **Multiple-Recipient Encryption:** RFC 4130 did not clearly
        specify expected behavior for multiple-recipient support. Modern
        implementations SHOULD support recoverable encryption by including
        a copy of the content-encryption key (CEK) for each recipient,
        and SHOULD include one for the originator when feasible. Legacy
        implementations may omit this; modern systems should tolerate it.

     o  **Error Handling:** When encountering unsupported algorithms or
        malformed cryptographic structures in legacy exchanges,
        implementations SHOULD generate a clear error condition (e.g.,
        an unsigned MDN reporting "unsupported-mic-algorithm"). Silent
        fallback to weaker algorithms is NOT RECOMMENDED.

     o  **Profile Selection:** Implementations may provide administrators
        the ability to select profiles (e.g., "AS2-1.2 legacy mode" versus
        "AS2-1.3 modern mode") for specific trading partner agreements,
        ensuring predictable behavior without runtime handshakes.
]]></artwork>
          <t>These clarifications are provided for reference and consistency
   across vendors. They are non-normative and are not intended to
   redefine <xref target="RFC4130"/> or to weaken the algorithm requirements of this
   specification. Refer to <xref target="backward-compatibility-and-interoperability"/>
   for discussion of backward compatibility principles, and Section 7
   for normative algorithm requirements.</t>
        </section>
      </section>
      <section anchor="rationale">
        <name>Rationale</name>
        <t>The updates in this specification reflect community consensus to:</t>
        <artwork><![CDATA[
     o  Preserve backward compatibility with RFC 4130 and the underlying
        RFCs it references.
     o  Provide explicit guidance on which protocol versions form the
        interoperability baseline for certification and testing.
     o  Incorporate de facto updates already widely deployed (e.g., RFC 8098
        for MDNs, migration from SHA-1 to SHA-2 wherever possible).
     o  Document stronger security requirements while allowing
        backward-compatible fallback to enable phased adoption.
     o  Avoid unnecessary disruption by permitting, but not requiring,
        newer transport features such as HTTP/2, and by clarifying rather
        than redefining MDN behavior.
]]></artwork>
        <t>This approach reduces ambiguity, simplifies certification, and ensures
interoperability across implementations.</t>
      </section>
      <section anchor="terms">
        <name>Terms</name>
        <sourcecode type="text"><![CDATA[
   AS2:     Applicability Statement 2 (this document) and [RFC4130]; see RFC 2026
            [RFC2026], Section 3.2

   EDI:     Electronic Data Interchange

   EC:      Electronic Commerce (often referred to as Business to Business, B2B).

   B2B:     Business to Business

   Receipt: The functional message that is sent from a receiver to a
            sender to acknowledge that an EDI/EC interchange has been
            received. This message may be either synchronous or asynchronous
            in nature.

   Signed Receipt: A receipt with a digital signature.

   Synchronous Receipt: A receipt returned to the sender over the same
            TCP/IP connection as the sender's original message.

   Asynchronous Receipt: A receipt returned to the sender over a different
            TCP/IP connection than the sender's original message.

   Message Disposition Notification (MDN): The Internet messaging format
            used to convey a receipt. This term is used interchangeably
            with receipt. An MDN is a receipt.

   Non-repudiation of receipt (NRR): A "legal event" that occurs when
            the original sender of an signed EDI/EC interchange has
            verified the signed receipt coming back from the receiver.
            The receipt contains data identifying the original message
            for which it is a receipt, including the message-ID and a
            cryptographic hash (MIC). The original sender must retain
            suitable records providing evidence concerning the message
            content, its message-ID, and its hash value. The original
            sender verifies that the retained hash value is the same as
            the digest of the original message, as reported in the
            signed receipt. NRR is not considered a technical message,
            but instead is thought of as an outcome of possessing
            relevant evidence.

   S/MIME:  A format and protocol for adding cryptographic signature
            and/or encryption services to Internet MIME messages.

   Cryptographic Message Syntax (CMS): An encapsulation syntax used to
            digitally sign, digest, authenticate, or encrypt arbitrary
            messages.

   SHA-1:   A secure, one-way hash algorithm used in conjunction with
            digital signature. This algorithm is retained for backward
            compatibility but is deprecated in this specification.
            Implementations MUST support SHA-256 or stronger where possible,
            and SHOULD prefer these algorithms in production environments
            unless legacy partners cannot yet migrate to SHA-256 or stronger.

   MD5:     A secure, one-way hash algorithm used in conjunction with
            digital signature. This algorithm is obsolete and MUST NOT be generated
            by conformant implementations.

   MIC:     The Message Integrity Check (MIC) is a cryptographic method used
            to verify that a message has not been altered or tampered with during
            transmission or storage, ensuring the data is trustworthy and complete.
            It works by generating a unique hash value from the message's contents,
            which is then transmitted with the message. The recipient recalculates
            the hash on the received message and compares it to the provided MIC;
            if they don't match, the message is discarded, indicating it was modified.

   User Agent (UA): The application that handles and processes the AS2 request.
]]></sourcecode>
      </section>
    </section>
    <section anchor="overview">
      <name>Overview</name>
      <section anchor="overall-operation">
        <name>Overall Operation</name>
        <t>An HTTP POST operation <xref target="RFC2616"/> is used to send appropriately packaged EDI,
   XML, or other business data. The Request-URI (<xref target="RFC2616"/>, Section 10.5)
   identifies a process for unpacking and handling the message data and
   for generating a reply for the client that contains a message
   disposition acknowledgement (MDN), either signed or unsigned. The
   MDN is either returned in the HTTP response message body or by a new
   HTTP POST operation to a URL for the original sender.</t>
        <t>This request/reply transactional interchange can provide secure,
   reliable, and authenticated transport for EDI or other business data
   using HTTP as a transfer protocol. HTTPS is RECOMMENDED as the default
   transport for modern implementations (see <xref target="https-tls-reqs"/>).</t>
        <t>The security protocols and structures used also support auditable
   records of these document data transmissions, acknowledgements, and
   authentication.</t>
        <t>The message formats and processing requirements described below maintain
   strict backward compatibility (see <xref target="backward-compatibility-and-interoperability"/>).</t>
      </section>
      <section anchor="purpose-of-a-security-guideline-for-mime-edi">
        <name>Purpose of a Security Guideline for MIME EDI</name>
        <t>The purpose of these specifications is to ensure interoperability
   between B2B EC user agents, invoking some or all of the commonly
   expected security features.  This document is not limited to
   strict EDI use; it applies to any electronic commerce application for
   which business data needs to be exchanged securely over the Internet.</t>
      </section>
      <section anchor="definitions">
        <name>Definitions</name>
        <section anchor="the-secure-transmission-loop">
          <name>The Secure Transmission Loop</name>
          <t>This document's focus is on the formats and protocols for exchanging
   EDI/EC content securely in the Internet's HTTP environment.</t>
          <t>In the "secure transmission loop" for EDI/EC, one organization sends
   a signed, encrypted and compressed EDI/EC interchange to another organization
   and requests a signed receipt, and later the receiving organization sends
   this signed receipt back to the sending organization. In other words, the
   following transpires:</t>
          <artwork><![CDATA[
     o  The organization sending EDI/EC data signs, encrypts and compresses
        the data using S/MIME. In addition, the message will request that
        a signed receipt be returned to the sender. To support NRR,
        the original sender retains records of the message, message-ID,
        and digest (MIC) value.

     o  The receiving organization decompresses and decrypts the message and
        verifies the signature, resulting in verified integrity of the data and
        authenticity of the sender.

     o  The receiving organization then returns a signed receipt using
        the HTTP reply body or a separate HTTP POST operation to the
        sending organization in the form of a signed message
        disposition notification.  This signed receipt will contain the
        hash of the received message, allowing the original sender to
        have evidence that the received message was authenticated
        and/or decrypted properly by the receiver.
]]></artwork>
          <t>The above describes functionality that, if implemented, will satisfy
   all security requirements and implement non-repudiation of receipt
   for the exchange.  This specification, however, leaves full
   flexibility for users to decide the degree to which they want to
   deploy those security features with their trading partners.</t>
        </section>
        <section anchor="definition-of-receipts">
          <name>Definition of Receipts</name>
          <t>The term used for both the functional activity and the message for
   acknowledging delivery of an EDI/EC interchange is "receipt" or
   "signed receipt". The first term is used if the acknowledgment is
   for an interchange resulting in a receipt that is NOT signed. The
   second term is used if the acknowledgement is for an interchange
   resulting in a receipt that IS signed.</t>
          <t>The term non-repudiation of receipt (NRR) is often used in
   combination with receipts. NRR refers to a legal event that occurs
   only when the original sender of an interchange has verified the
   signed receipt coming back from the recipient of the message, and has
   verified that the returned MIC value inside the MDN matches the
   previously recorded value for the original message.</t>
          <t>NRR is best established when both the original message and the
   receipt make use of digital signatures. See the Security
   Considerations section for some cautions regarding NRR.
   For information on how to format and process receipts in AS2, refer
   to refer to Section 8.</t>
        </section>
      </section>
      <section anchor="assumptions">
        <name>Assumptions</name>
        <section anchor="ediec-process-assumptions">
          <name>EDI/EC Process Assumptions</name>
          <artwork><![CDATA[
  o  Encrypted object is an EDI/EC Interchange.

     This specification assumes that a typical EDI/EC interchange (i.e., the payload)
     is the lowest-level object that will be subject to security services.

     Specifically, in EDI ANSI X12, this means that anything between and
     including, segments ISA and IEA is secured. In EDIFACT, this means
     that anything between, and including, segments UNA/UNB and UNZ is
     secured. In other words, the EDI/EC interchanges including envelope
     segments remain intact and unreadable during fully secured transport.

  o  EDI envelope headers are encrypted.

     Congruent with the above statement, EDI envelope headers are NOT
     visible in the MIME package.

     In order to optimize routing from existing commercial EDI networks
    (called Value Added Networks or VANs) to the Internet, it was previously
    useful to make some envelope information visible. Since the EDI/EC message exchanges
    are routed over the public Internet and not over VANs, this
    specification provides no support for this optimization.

  o  X12.58 and UN/EDIFACT Security Considerations

    The most common EDI standards bodies, ANSI X12 and EDIFACT, have
    defined internal provisions for security. X12.58 is the security
    mechanism for ANSI X12, and AUTACK provides security for EDIFACT.
    This specification does NOT dictate use or non-use of these security
    standards. They are both fully compatible, though possibly
    redundant, with this specification.
]]></artwork>
        </section>
        <section anchor="flexibility-assumptions">
          <name>Flexibility Assumptions</name>
          <artwork><![CDATA[
  o  Encrypted or Unencrypted Data

    This specification allows for EDI/EC message exchange in which the
    EDI/EC data can be either unprotected or protected by means of
    encryption.

  o  Signed or Unsigned Data

    This specification allows for EDI/EC message exchange with or without
    digital signature of the original EDI transmission.

  o  Compressed or Uncompressed Data

    This specification allows for optional compression and MAY be applied alone
    or in combination with signing and/or encryption, as defined in [RFC3274].
    It is supported by AS2-Version: 1.1 and higher.

  o  Optional Use of Receipt

    This specification allows for EDI/EC message transmission with or
    without a request for receipt notification.  A signed receipt
    notification is requested; however, a MIC value is REQUIRED as part
    of the returned receipt, except when a severe error condition
    prevents computation of the digest value. In the exceptional case, a
    signed receipt should be returned with an error message that
    effectively explains why the required MIC value is absent.

  o  Use of Synchronous or Asynchronous Receipts

    In addition to a receipt request, this specification allows for the
    designation of the type of receipt that should be returned. It
    supports synchronous or asynchronous receipts in the MDN format
    specified in {{structure-and-processing-of-an-mdn-message}} of this document.

  o  Security Formatting

    This specification relies on the guidelines set forth in RFC
    5751/5652  [RFC5751] / [RFC5652] "S/MIME Version 3.2 Message Specification;
    Cryptographic Message Syntax" as well as RFC 8551 [RFC8551] "Secure/Multipurpose Internet
    Mail Extensions (S/MIME) Version 4.0" for modern implementations.

  o  Hash Function, Message Digest Choices

    When a signature is used, implementations MUST support SHA-256 and SHOULD
    support SHA-384 or stronger. SHA-1 MAY be supported for incoming messages
    for backward compatibility, but SHOULD NOT be generated for outgoing messages
    unless it is strictly required for interoperability. MD5 is obsolete
    and MUST NOT be generated by conformant implementations.

  o  Encryption Algorithms

    For content encryption, implementations MUST support AES-128-CBC and
    AES-256-CBC. Implementations are RECOMMENDED to support authenticated
    encryption modes such as AES-GCM and AES-CCM, which use AuthEnvelopedData
    (S/MIME 4.0). When using AES-GCM or AES-CCM, implementations MUST use
    AuthEnvelopedData. When using AES-CBC or other non-authenticated modes,
    implementations MUST use EnvelopedData with separate integrity protection
    via digital signatures. Triple-DES (3DES) and RC2 are deprecated and SHOULD NOT
    be generated by conformant implementations, though they SHOULD be accepted
    for backward compatibility with legacy systems. A single content encryption
    algorithm MUST be used for all recipients of a given message; it is not
    permitted to encrypt the same message with AES-CBC for some recipients and
    AES-GCM for others.

  o  Key Management Algorithms

    For key transport, implementations MUST support RSA with a minimum key
    length of 2048 bits. Implementations MAY support key agreement algorithms such
    as Diffie-Hellman or Elliptic Curve Diffie-Hellman (ECDH) as specified
    in [RFC5753]. When using elliptic curves, implementations SHOULD support
    NIST P-256 (secp256r1) or stronger curves.

  o  Permutation Summary

    The optional use of compression, as defined in [RFC3274] was introduced in AS2-Version 1.1.
    Compression can be applied to the message payload before signing and/or encryption,
    reducing transmission size and improving efficiency. Most modern AS2 implementations
    support compression, and it can be used by itself or in combination with signing and encryption.

    The following summary therefore extends the original AS2 security permutations to include
    the additional possibilities created by the use of compression, resulting in a total of
    twenty-four security permutations.
]]></artwork>
          <t>Without Compression (12 permutations)</t>
          <ol spacing="normal" type="1"><li>
              <t>Sender sends un-encrypted data and does NOT request a receipt.</t>
            </li>
            <li>
              <t>Sender sends un-encrypted data and requests an unsigned receipt.
Receiver sends back the unsigned receipt.</t>
            </li>
            <li>
              <t>Sender sends un-encrypted data and requests a signed receipt.
Receiver sends back the signed receipt.</t>
            </li>
            <li>
              <t>Sender sends encrypted data and does NOT request a receipt.</t>
            </li>
            <li>
              <t>Sender sends encrypted data and requests an unsigned receipt.
Receiver sends back the unsigned receipt.</t>
            </li>
            <li>
              <t>Sender sends encrypted data and requests a signed receipt.
Receiver sends back the signed receipt.</t>
            </li>
            <li>
              <t>Sender sends signed data and does NOT request a signed or
unsigned receipt.</t>
            </li>
            <li>
              <t>Sender sends signed data and requests an unsigned receipt.
Receiver sends back the unsigned receipt.</t>
            </li>
            <li>
              <t>Sender sends signed data and requests a signed receipt.
Receiver sends back the signed receipt.</t>
            </li>
            <li>
              <t>Sender sends encrypted and signed data and does NOT request a
signed or unsigned receipt.</t>
            </li>
            <li>
              <t>Sender sends encrypted and signed data and requests an unsigned
receipt.  Receiver sends back the unsigned receipt.</t>
            </li>
            <li>
              <t>Sender sends encrypted and signed data and requests a signed
receipt.  Receiver sends back the signed receipt.</t>
            </li>
          </ol>
          <t>With Compression (12 permutations)</t>
          <ol spacing="normal" type="1" start="13"><li>
              <t>Sender sends compressed data (not encrypted or signed) and does NOT request a receipt.</t>
            </li>
            <li>
              <t>Sender sends compressed data and requests an unsigned receipt. Receiver sends back the unsigned receipt.</t>
            </li>
            <li>
              <t>Sender sends compressed data and requests a signed receipt. Receiver sends back the signed receipt.</t>
            </li>
            <li>
              <t>Sender sends compressed and encrypted data and does NOT request a receipt.</t>
            </li>
            <li>
              <t>Sender sends compressed and encrypted data and requests an unsigned receipt. Receiver sends back the unsigned receipt.</t>
            </li>
            <li>
              <t>Sender sends compressed and encrypted data and requests a signed receipt. Receiver sends back the signed receipt.</t>
            </li>
            <li>
              <t>Sender sends compressed and signed data and does NOT request a signed or unsigned receipt.</t>
            </li>
            <li>
              <t>Sender sends compressed and signed data and requests an unsigned receipt. Receiver sends back the unsigned receipt.</t>
            </li>
            <li>
              <t>Sender sends compressed and signed data and requests a signed receipt. Receiver sends back the signed receipt.</t>
            </li>
            <li>
              <t>Sender sends compressed, encrypted, and signed data and does NOT request a signed or unsigned receipt.</t>
            </li>
            <li>
              <t>Sender sends compressed, encrypted, and signed data and requests an unsigned receipt. Receiver sends back the unsigned receipt.</t>
            </li>
            <li>
              <t>Sender sends compressed, encrypted, and signed data and requests a signed receipt. Receiver sends back the signed receipt.</t>
            </li>
          </ol>
          <t><strong>Key Notes</strong></t>
          <artwork><![CDATA[
     o  Compression MAY be applied alone or in combination with signing and/or encryption, as defined in [RFC3274] and is supported
        by AS2-Version 1.1 and higher.

     o  Users may choose any of these twenty-four possibilities, but only the final example (24), when compression, signing, encryption,
        and a signed receipt are all used, offers the full suite of security and efficiency features described in
        Section 2.3.1, “The Secure Transmission Loop.”

     o  As with the original permutations, the receipts may be either synchronous or asynchronous, and the choice does not change the nature of
        the secure transmission loop in support of NRR.
]]></artwork>
        </section>
      </section>
    </section>
    <section anchor="referenced-rfcs-and-their-contributions">
      <name>Referenced RFCs and Their Contributions</name>
      <section anchor="rfc-2616-http-v11">
        <name>RFC 2616 HTTP v1.1</name>
        <t><xref target="RFC2616"/> specifies how data is transferred using HTTP.</t>
      </section>
      <section anchor="rfc-1847-mime-security-multiparts">
        <name>RFC 1847 MIME Security Multiparts</name>
        <t><xref target="RFC1847"/> defines security multipart for MIME:
   multipart/encrypted and multipart/signed.</t>
      </section>
      <section anchor="rfc-3462-multipartreport">
        <name>RFC 3462 Multipart/Report</name>
        <t><xref target="RFC3462"/> defines the use of the multipart/report content type,
   something that the MDN RFC 3798 builds upon.</t>
      </section>
      <section anchor="rfc-1767-edi-content">
        <name>RFC 1767 EDI Content</name>
        <t><xref target="RFC1767"/> defines the use of content type "application" for ANSI X12
   (application/EDI-X12), EDIFACT (application/EDIFACT), and mutually
   defined EDI (application/EDI-Consent).</t>
      </section>
      <section anchor="rfc-2045-2046-and-2049-mime">
        <name>RFC 2045, 2046, and 2049 MIME</name>
        <t><xref target="RFC2045"/>, <xref target="RFC2046"/>, and <xref target="RFC2049"/> are the basic MIME standards, upon
   which all MIME related RFCs build, including this one. Key contributions
   include definitions of "content type", "sub-type", and "multipart", as
   well as encoding guidelines, which establish 7-bit US-ASCII as the
   canonical character set to be used in Internet messaging.</t>
      </section>
      <section anchor="rfc-3798-message-disposition-notification">
        <name>RFC 3798 Message Disposition Notification</name>
        <t><xref target="RFC3798"/> defines how an MDN is requested, and the format and
   syntax of the MDN. The MDN is the basis upon which receipts and
   signed receipts are defined in this specification.</t>
      </section>
      <section anchor="rfc-5751-and-5652-smime-version-32-message-specifications-and-cryptographic-message-syntax-cms">
        <name>RFC 5751 and 5652 S/MIME Version 3.2 Message Specifications and Cryptographic Message Syntax (CMS)</name>
        <t><xref target="RFC5751"/> and <xref target="RFC5652"/> describe how S/MIME carries CMS Objects.</t>
      </section>
      <section anchor="rfc-3023-xml-media-types">
        <name>RFC 3023 XML Media Types</name>
        <t><xref target="RFC3023"/> defines the use of content type "application" for XML
   (application/xml).</t>
      </section>
      <section anchor="rfc-3274-compressed-data-content-type-for-cryptographic-message-syntax-cms">
        <name>RFC 3274 Compressed Data Content Type for Cryptographic Message Syntax (CMS)</name>
        <t><xref target="RFC3274"/> defines a mechanism for compressing data within the Cryptographic Message Syntax (CMS),
   which is the foundation for Secure/Multipurpose Internet Mail Extensions (S/MIME).
   It specifies a CompressedData content type that allows data to be compressed prior to being
   signed or encrypted. This reduces the size of transmitted messages and improves efficiency without
   altering the security services provided by signing or encryption.
   AS2-Version 1.1 incorporated the compression capability described in RFC 3274, enabling trading partners
   to optionally apply compression to message payloads before signing and/or encrypting.
   Most modern AS2 implementations support this feature to reduce bandwidth usage and improve transmission
   performance, particularly for large payloads.</t>
      </section>
    </section>
    <section anchor="structure-of-an-as2-message">
      <name>Structure of an AS2 Message</name>
      <section anchor="introduction-1">
        <name>Introduction</name>
        <t>The basic structure of an AS2 message consists of MIME format inside
   an HTTP message with a few additional specific AS2 headers. The
   structures below are described hierarchically in terms of which RFCs
   are applied to form the specific structure. For details on how to
   code in compliance with all RFCs involved, refer to the specific RFCs.
   Any difference between AS2 implementations and RFCs are mentioned
   specifically in the sections below.</t>
      </section>
      <section anchor="structure-of-an-internet-edi-mime-message">
        <name>Structure of an Internet EDI MIME Message</name>
        <sourcecode type="text"><![CDATA[
   No encryption, no signature, no compression
      - RFC2616/2045
        - RFC1767/RFC3023 (application/EDIxxxx or /xml)

   No encryption, signature, no compression
      - RFC2616/2045
        - RFC1847 (multipart/signed)
          - RFC1767/RFC3023 (application/EDIxxxx or /xml)
          - RFC5751 (application/pkcs7-signature)

   Encryption, no signature, no compression
      - RFC2616/2045
        - RFC5751 (application/pkcs7-mime)
          - RFC1767/RFC3023  (application/EDIxxxx or /xml) (encrypted)

   Encryption, signature, no compression
      - RFC2616/2045
        - RFC5751 (application/pkcs7-mime)
          - RFC1847 (multipart/signed)(encrypted)
            - RFC1767/RFC3023  (application/EDIxxxx or /xml) (encrypted)
            - RFC5751 (application/pkcs7-signature)(encrypted)

   No encryption, no signature (with optional compression)
      - RFC2616/2045
        - RFC3274 (application/pkcs7-mime; CompressedData) [optional]
          - RFC1767/RFC3023 (application/EDIxxxx or /xml)

   No encryption, signature (compression may occur before or after signing)
      - RFC2616/2045
        - [optional RFC3274 (CompressedData) if compress-before-sign]
          - RFC1847 (multipart/signed)
            - [optional RFC3274 (CompressedData) if compress-after-sign]
              - RFC1767/RFC3023 (application/EDIxxxx or /xml)
              - RFC5751 (application/pkcs7-signature)

   Encryption, no signature (with optional compression)
       - RFC2616/2045
         - RFC5751 (application/pkcs7-mime)
           - [optional RFC3274 (CompressedData)]
             - RFC1767/RFC3023 (application/EDIxxxx or /xml) (encrypted)

   Encryption, signature (compression may occur before or after signing)
      - RFC2616/2045
        - RFC5751 (application/pkcs7-mime)
          - [optional RFC3274 (CompressedData) if compress-before-sign]
            - RFC1847 (multipart/signed) (encrypted)
              - [optional RFC3274 (CompressedData) if compress-after-sign]
              - RFC1767/RFC3023 (application/EDIxxxx or /xml) (encrypted)
              - RFC5751 (application/pkcs7-signature) (encrypted)

   MDN over HTTP, no signature
      - RFC2616/2045
        - RFC3798 (message/disposition-notification)

   MDN over HTTP, signature
      - RFC2616/2045
        - RFC1847 (multipart/signed)
         - RFC3798 (message/disposition-notification)
         - RFC5751 (application/pkcs7-signature)
]]></sourcecode>
        <t><strong>Key Notes</strong></t>
        <artwork><![CDATA[
     o  RFC 3274 (CompressedData) is the normative reference for compression.

     o  Compression MAY be combined with signing and/or encryption in either order,
        but the choice affects what the digital signature covers.

     o  Many implementations compress before signing and encrypting to maximize size
        reduction, but compression after signing and before encrypting MUST also be supported.

     o  Although all MIME content types SHOULD be supported, the following
        MIME content types MUST be supported:

            Content-type: multipart/signed
            Content-Type: multipart/report
            Content-type: message/disposition-notification
            Content-Type: application/PKCS7-signature
            Content-Type: application/PKCS7-mime
            Content-Type: application/EDI-X12
            Content-Type: application/EDIFACT
            Content-Type: application/edi-consent
            Content-Type: application/XML
]]></artwork>
      </section>
    </section>
    <section anchor="http-considerations">
      <name>HTTP Considerations</name>
      <t>This specification permits but does not require the use of HTTP/2 or
HTTP/3 as transport protocols. Interoperability testing and
certification are scoped to HTTP/1.1 unless otherwise agreed upon between
trading partners.</t>
      <section anchor="sending-edi-in-http-post-requests">
        <name>Sending EDI in HTTP POST Requests</name>
        <t>The request line will have the form: "POST Request-URI HTTP/1.1",
   with spaces and followed by a CRLF. The Request URI is typically
   exchanged out of band, as part of setting up a bilateral trading
   partner agreement. Applications SHOULD be prepared to deal with an
   initial reply containing a status indicating a need for
   authentication of the usual types used for authorizing access to the
   Request-URI (<xref target="RFC2616"/>, Section 10.4.2 and elsewhere).</t>
        <t>The request line is followed by entity headers specifying content
   length (<xref target="RFC2616"/>, Section 14.14) and content type (<xref target="RFC2616"/>, Section 14.18).
   The Host request header (<xref target="RFC2616"/>, Sections 9 and 14.23) is also included.</t>
        <t>When using Transport Layer Security (TLS), the request-URI MUST
   indicate the appropriate scheme value, HTTPS. Implementations MUST
   support TLS 1.2 or higher and SHOULD follow the guidance in <xref target="https-tls-reqs"/>.
   Encrypted message bodies MAY be used in addition to TLS when required
   by business policy.</t>
        <t>The receiving AS2 system MAY disconnect from the sending AS2 system
   before completing the reception of the entire entity if it determines
   that the entity being sent is too large to process.</t>
        <t>For HTTP version 1.1, TCP persistent connections are the default,
   (<xref target="RFC2616"/> Sections 8.1.2, 8.2, and 19.7.1). A number of other differences
   exist because HTTP does not conform to MIME <xref target="RFC2616"/> as used in SMTP
   transport.  Relevant differences are summarized below.</t>
      </section>
      <section anchor="unused-mime-headers-and-operations">
        <name>Unused MIME Headers and Operations</name>
        <section anchor="content-transfer-encoding-not-used-in-http-transport">
          <name>Content-Transfer-Encoding Not Used in HTTP Transport</name>
          <t>HTTP can handle binary data and so there is no need to use the
   content transfer encodings of MIME <xref target="RFC2616"/>. This difference is discussed
   in <xref target="RFC2616"/>, Section 19.4.5. However, a content transfer encoding value
   of binary or 8-bit is permissible but not required. The absence of
   this header MUST NOT result in transaction failure. Content transfer
   encoding of MIME bodyparts within the AS2 message body is also
   allowed.</t>
        </section>
        <section anchor="message-bodies">
          <name>Message Bodies</name>
          <t>In <xref target="RFC2616"/>, Section 3.7.2, it is explicitly noted that multiparts MUST
   have null epilogues.</t>
          <t>For HTTP transport, large files SHOULD be handled correctly by the TCP layer.
   In addition, <xref target="RFC2616"/>, Sections 3.5 and 3.6 describe options for compressing or
   chunking entities to be transferred, and Section 8.1.2.2 describes a pipelining
   option that is useful for segmenting large amounts of data.
   These clarifications are consistent with existing AS2 practice and maintain full
   backward compatibility (see <xref target="backward-compatibility-and-interoperability"/>).</t>
        </section>
      </section>
      <section anchor="modification-of-mime-or-other-headers-or-parameters-used">
        <name>Modification of MIME or Other Headers or Parameters Used</name>
        <section anchor="content-length">
          <name>Content-Length</name>
          <t>The use of the content-length header MUST follow the guidelines of
   <xref target="RFC2616"/>, specifically Sections 4.4 and 14.13.</t>
        </section>
        <section anchor="final-recipient-and-original-recipient">
          <name>Final Recipient and Original Recipient</name>
          <t>The final and original recipient values SHOULD be the same value.
   These values MUST NOT be aliases or mailing lists.</t>
        </section>
        <section anchor="message-id-and-original-message-id">
          <name>Message-Id and Original-Message-Id</name>
          <t>The <tt>Message-Id</tt> and <tt>Original-Message-Id</tt> headers identify a message
   uniquely and are formatted as defined in <xref target="RFC5322"/>, Section 3.6.4:</t>
          <artwork><![CDATA[
      "<" id-left "@" id-right ">"
]]></artwork>
          <t>The length of a <tt>Message-Id</tt> value MUST NOT exceed 998 characters.
   For maximum interoperability, the length SHOULD be 255 characters or less.</t>
          <t>The <tt>Message-Id</tt> value MUST be globally unique, and the <tt>id-right</tt>
   portion SHOULD be something unique to the sending host environment
   (for example, a fully qualified domain name).</t>
          <t>Implementations that generate <tt>Message-Id</tt> values MUST NOT include
   spaces or control characters. Implementations SHOULD remove spaces
   rather than substitute another character when constructing identifiers
   from other message attributes such as <tt>AS2-From</tt> or <tt>AS2-To</tt>.</t>
          <t>Receivers are not required to accept malformed identifiers. If a
   message is received with a <tt>Message-Id</tt> that contains spaces or
   control characters, the implementation SHOULD treat it as
   syntactically invalid and SHOULD return an MDN with a disposition of
   <tt>processed/error</tt> and a human-readable explanation such as
   "invalid-message-id" (see <xref target="RFC8098"/>). If an implementation chooses
   to proceed despite the malformed identifier, it MUST NOT propagate or
   generate a new message using that malformed value.</t>
          <t>When sending a message, the <tt>Message-Id</tt> field value MUST be enclosed
   in angle brackets (“&lt;” and “&gt;”). The brackets are not part of the
   actual identifier value. For backward compatibility, receiving
   implementations SHOULD NOT reject a message that omits angle brackets.</t>
          <t>When creating the <tt>Original-Message-Id</tt> header in an MDN, always use
   the exact syntax as received on the original message; do not strip or
   add angle brackets.</t>
          <t>See <xref target="RFC5322"/>, Section 3.6.4.</t>
        </section>
        <section anchor="host-header">
          <name>Host Header</name>
          <t>The host request header field MUST be included in the POST request
   made when sending business data. This field is intended to allow one
   server IP address to service multiple hostnames, and potentially to
   conserve IP addresses. See <xref target="RFC2616"/>, Sections 14.23 and 19.5.1.</t>
        </section>
      </section>
      <section anchor="http-response-status-codes">
        <name>HTTP Response Status Codes</name>
        <t>Implementations MUST use standard HTTP response codes to signal the
   outcome of the message transfer.  The meaning of the HTTP status code is
   limited to the success or failure of the transport operation itself,
   not the semantic processing of the AS2 message content. For
   example, the status code 401, together with the WWW-Authenticate
   header, is used to challenge the client to repeat the request with an
   Authorization header. Other explicit status codes are documented in
   <xref target="RFC2616"/>, Section 6.1.1 and throughout Section 10.</t>
        <t>Receiving implementations MAY send an interim 102 (Processing)
   response <xref target="RFC4918"/> under HTTP/1.1 to indicate that the inbound
   message has been fully received and that processing is underway. The
   102 response can help prevent sender-side network timeouts for large
   synchronous transfers by signaling progress while decryption,
   signature verification, or storage continues.</t>
        <t>Use of 102 (Processing) is OPTIONAL.  It has been deprecated in later
   HTTP specifications and <strong>MUST NOT</strong> be used with HTTP/2 or HTTP/3,
   where interim responses have different semantics.  Implementations
   that do not receive a 102 response MUST NOT assume that a failure has
   occurred solely because no interim status was returned. They SHOULD
   continue waiting for the final status response for at least the duration
   of their configured HTTP read timeout or any timeout agreed upon between
   trading partners.</t>
        <t>To minimize the risk of network timeouts during lengthy message
   processing, receivers SHOULD return an appropriate transfer-layer
   response as quickly as possible after receiving the full message
   content. For asynchronous message exchanges, the preferred response is
   <tt>204 No Content</tt>, which indicates that the message has been received
   successfully and that an asynchronous MDN will follow once processing has
   completed. This convention is maintained for interoperability with
   existing AS2 products and certification profiles.</t>
        <t>Some implementations MAY instead use <tt>202 Accepted</tt> to indicate
   successful receipt and deferred processing; however, <tt>204 No Content</tt>
   remains the recommended and most widely deployed response for asynchronous workflows.</t>
        <t>Implementations MAY close the connection immediately after sending this
   response if persistent connections are not required by configuration.</t>
        <t>After processing completes, the receiver MUST return a final HTTP
   status code indicating the success or failure of the message transfer.
   The sender MUST use this final response to determine whether retry is appropriate.</t>
        <t>Retry <strong>MUST NOT</strong> be attempted when:</t>
        <artwork><![CDATA[
     o  the final HTTP response indicates successful receipt (e.g., `200 OK` or
        `204 No Content` for asynchronous transfers, or `202 Accepted` for
        implementations that use deferred processing semantics) **and** a
        valid MDN has been received confirming the message disposition; or
     o  a permanent-failure status code is returned (4xx other than 408), or
]]></artwork>
        <t>Retry <strong>MAY</strong> be attempted when:</t>
        <artwork><![CDATA[
     o  the HTTP connection fails before the final status is received,
     o  a transient error such as 408 (Request Timeout) or 5xx (Server Error)
        occurs, or
     o  no response is received within the configured timeout.
]]></artwork>
        <t>Implementations SHOULD refer to Section 5.5 for additional guidance on
   retry logic, back-off behavior, and use of partial-transfer recovery.
   The 102 (Processing) status code, if used, MUST NOT be treated as a
   trigger for retry.</t>
      </section>
      <section anchor="http-error-recovery-and-reliability">
        <name>HTTP Error Recovery and Reliability</name>
        <t>When an AS2 message transfer fails due to a transient transport-layer
   condition (for example, an HTTP 408 Request Timeout, 425 Too Early,
   500 Internal Server Error, 503 Service Unavailable or network interruption
   before the final response), the sending system SHOULD attempt an automatic retry.</t>
        <t>Each retry attempt MUST reuse the same Message-ID value so that the
   receiving system can identify duplicate transmissions and prevent
   double-processing.  A receiving system detecting a duplicate
   Message-ID MUST NOT treat the message as new and SHOULD return the
   previously generated MDN, if available.</t>
        <t>Implementations SHOULD permit configuration of retry behavior rather
   than enforcing fixed intervals or limits.  The following guidelines
   are RECOMMENDED but not required:</t>
        <artwork><![CDATA[
     o  **Retry intervals** SHOULD increase exponentially (e.g., 5 min,
        10 min, 20 min, 40 min, …) to reduce congestion.
     o  **Retry duration** SHOULD be configurable based on business
        requirements; some environments may continue for several days, while
        others may terminate after one or two attempts.
     o  **Maximum attempts** SHOULD be limited to prevent indefinite
        retries when persistent errors occur.
]]></artwork>
        <t>Implementations SHOULD NOT retry when:</t>
        <artwork><![CDATA[
     o  A final 2xx response and/or valid MDN has been received;
     o  The HTTP response indicates a permanent failure (e.g., 400, 401,
        403, 404);
     o  The partner has explicitly rejected the message by sending a signed
        MDN with a "failed" disposition.
]]></artwork>
        <t>The HTTP 102 (Processing) interim status MAY be used under
   HTTP/1.1 to indicate progress on long-running synchronous operations.
   It MUST NOT be used as a signal to initiate or suppress retries.
   Implementations MUST ignore 102 responses when determining whether a
   retry is required.  The 102 response MUST NOT be used with HTTP/2 or
   HTTP/3.</t>
        <t>Implementations MAY also support <strong>AS2 Restart</strong>, which allows a
   partially uploaded message to resume from the point of interruption
   rather than retransmitting the entire payload.  This optional feature
   is defined in <xref target="I-D.draft-harding-as2-restart-02"/>.  Implementations supporting
   Restart MUST ensure message integrity through signature or checksum
   validation of all resumed segments.</t>
        <t>Additional guidance for retry management, error classification, and
   duplicate detection is described in <xref target="I-D.draft-duker-as2-reliability-16"/>.
   While both of these drafts are expired, they remain widely referenced
   in AS2 interoperability testing and provide a useful operational baseline
   for error-recovery behavior.</t>
        <t>The objective of error recovery is reliability, not speed.  Systems
   SHOULD favor successful delivery over strict timing, provided that
   duplicate protection and security requirements are preserved.</t>
      </section>
    </section>
    <section anchor="additional-as2-specific-http-headers">
      <name>Additional AS2-Specific HTTP Headers</name>
      <t>The following headers are to be included in all AS2 messages and all
AS2 MDNs. <xref target="RFC3335"/>.</t>
      <section anchor="as2-version-header">
        <name>AS2 Version Header</name>
        <t>To promote backward compatibility, AS2 includes a version header. The
   major version digit indicates wire-level compatibility; minor version
   digits designate feature sets, clarifications, or extensions that
   remain compatible within the same major version. Thus, all values in
   the "1.x" range are compatible with AS2-Version 1.0, while a potential
   future "2.0" version would indicate a non-backward-compatible revision.</t>
        <t>Receiving systems MUST NOT fail due to the absence of the AS2-Version
   header. Its absence MUST be assumed to be equivalent to the default
   AS2-Version value of 1.0.</t>
        <sourcecode type="text"><![CDATA[
   AS2-Version: 1.0  - All implementations of this specification MUST
                       support and advertise "AS2-Version: 1.0".
                       Versions in the range "1.0" through "1.9" MAY be
                       used. All implementations MUST interpret any value
                       in that range as conforming to this specification,
                       with no differences in baseline behavior. In other
                       words, only the major version digit ("1") defines
                       compatibility for implementations that do not
                       support additional, non-AS2-specified
                       functionality.

                       Implementations MAY use "1.1" through "1.9" to
                       signal extensions of this specification. Any such
                       extensions MUST be fully transparent to
                       implementations that recognize only
                       "AS2-Version: 1.0".

   AS2-Version: 1.1  - Designates those implementations that MUST support
                       compression as defined by RFC 3274.

   AS2-Version: 1.2  - Indicates those implementations that include an
                       EDIINT-Features header as defined in RFC 6017. The
                       values in an EDIINT-Features header specify the
                       features supported by the AS2 implementation.
                       Examples may include CEM, AS2-Reliability and
                       multiple-attachments, however others may also be
                       included. A receiving implementation MUST NOT fail
                       if it does not support or understand any of the
                       supported values contained within an
                       EDIINT-Features header.

   AS2-Version: 1.3  - Indicates those implementations that support the
                       modernization defined by this specification,
                       including updated algorithm requirements (e.g.,
                       SHA-256 for MIC/signatures; AES as the encryption
                       baseline per RFC 8551), alignment with MDN
                       handling as specified in RFC 8098, and support for
                       multiple-recipient encryption as described in
                       Section 7.2 of this specification.

                       When both partners are configured for AS2 version
                       1.3, weak algorithms (e.g., SHA-1, 3DES, RC2, MD5)
                       MUST NOT be generated by conformant implementations.
                       When interoperating with a legacy partner that operates
                       at AS2 version 1.2 or lower, implementations SHOULD
                       apply the legacy interoperability clarifications described
                       in {{backward-compatibility-and-interoperability}}.1 (non-normative).

                       Future minor versions (1.x) may designate
                       additional extensions or clarifications that remain
                       backward-compatible with AS2 version 1.0. A major
                       version update (2.0 or higher) would indicate a
                       non-backward-compatible revision and may come later.
]]></sourcecode>
      </section>
      <section anchor="as2-product-header">
        <name>AS2 Product header</name>
        <t>The <tt>AS2-Product</tt> header value identifies the AS2 product and version
   used by the sender.  This information enables interoperability testing,
   certification, and troubleshooting by allowing trading partners to
   detect known product-specific behaviors or version-related quirks.</t>
        <t>The <tt>AS2-Product</tt> header value is OPTIONAL for AS2-Version 1.x systems
   but MUST be included in messages generated by implementations
   declaring <strong>AS2-Version: 1.3</strong> (or later).</t>
        <t>The header field value MUST follow the format:</t>
        <sourcecode type="text"><![CDATA[
     * <product-name>: lowercase alphanumeric and hyphen characters (a–z,
        0–9, "-") without spaces.
     * <major.minor[.patch]>: version string consistent with the product’s
        release version, with one or more numeric components separated by dots.

   Examples:

      AS2-Product: biztalk:2025.1
      AS2-Product: example.com-connect:4.2.3
]]></sourcecode>
        <t>Implementations <strong>MUST NOT</strong> use arbitrary identifiers or vendor aliases
   that do not reflect the actual product in use.  The value is static and
   determined at build time.  If a product supports multiple AS2 variants,
   the version portion MAY include an implementation-specific suffix
   (e.g., "1.2-drummond").</t>
        <t>Implementations MAY use the <tt>AS2-Product</tt> value for automated
   interoperability tuning or to apply compatibility workarounds for known
   product versions.  However, this field is not intended for
   feature-negotiation purposes; supported feature tokens belong in the
   <tt>EDIINT-Features</tt> header, as defined in RFC 6017.</t>
      </section>
      <section anchor="as2-system-identifiers">
        <name>AS2 System Identifiers</name>
        <t>To aid the receiving system in identifying the sending system,
   AS2-From and AS2-To headers are used.</t>
        <artwork><![CDATA[
      AS2-From: < AS2-name >
      AS2-To: < AS2-name >
]]></artwork>
        <t>These AS2 headers contain textual values, as described below,
   identifying the sender/receiver of a data exchange. Their values may
   be company specific, such as Data Universal Numbering System (DUNS)
   numbers, or they may be simply identification strings agreed upon
   between the trading partners.</t>
        <artwork><![CDATA[
  AS2-text = "!" /           ; printable ASCII characters
             %d35-91 /       ; except double-quote (%d34)
             %d93-126        ; or backslash (%d92)

  AS2-qtext = AS2-text / SP  ; allow space only in quoted text

  AS2-quoted-pair = "\" DQUOTE /  ; \" or
                    "\" "\"       ; \\

  AS2-quoted-name = DQUOTE 1*128( AS2-qtext /
                                  AS2-quoted-pair) DQUOTE

  AS2-atomic-name = 1*128AS2-text

  AS2-name = AS2-atomic-name / AS2-quoted-name
]]></artwork>
        <t>The AS2-From header value and the AS2-To header value:</t>
        <artwork><![CDATA[
     o  MUST each be an AS2-name,
     o  MUST each be comprised of from 1 to 128 printable ASCII characters, and
     o  MUST NOT be folded
     o  The value in each of these headers is **case-sensitive**.
]]></artwork>
        <t>The string definitions given above are in ABNF format <xref target="RFC2234"/>.</t>
        <t>The AS2-quoted-name SHOULD be used only if the AS2-name does not
   conform to AS2-atomic-name. This explicitly includes situations where
   embedded spaces are part of the AS2-name.</t>
        <t>The AS2-To and AS2-From header fields MUST be present in all AS2
   messages and AS2 MDNs whether they are synchronous or asynchronous in nature.</t>
        <t>The AS2-name for the AS2-To header in a response or MDN MUST match
   the AS2-name of the AS2-From header in the corresponding request
   message. Likewise, the AS2-name for the AS2-From header in a
   response or MDN MUST match the AS2-name of the AS2-To header in the
   corresponding AS2 request message.</t>
        <t>The sending system may choose to limit the possible AS2-To/AS2-From
   textual values but MUST not exceed them. The receiving system MUST
   make no restrictions on the textual values and SHOULD handle all
   possible implementations. However, implementers must be aware that
   older AS2 products may not adhere to this convention. Trading
   partner agreements should be made to ensure that older products can
   support the system identifiers that are used.</t>
        <t>There is no required response to a client request containing invalid
   or unknown AS2-From or AS2-To header values. The receiving AS2
   system MAY return an unsigned MDN with an explanation of the error,
   such as an MDN error disposition value of "unknown-trading-relationship",
   if the sending system requested an MDN.</t>
      </section>
    </section>
    <section anchor="algorithm-requirements">
      <name>Algorithm Requirements</name>
      <t>This section defines the normative requirements for cryptographic
   algorithms used in AS2. These requirements apply to all conformant
   implementations. Guidance on interoperability with legacy AS2 systems
   that continue to use older algorithms is provided separately in
   Section 1.2.1.</t>
      <section anchor="hash-algorithms">
        <name>Hash Algorithms</name>
        <t>Implementations MUST support SHA-256 for message integrity check (MIC)
   calculations and digital signatures. Implementations SHOULD support
   SHA-384 or stronger algorithms. SHA-1 and MD5 are deprecated due to
   known weaknesses and SHOULD NOT be generated by conformant implementations.</t>
        <t>See Section 1.2.1 for clarifications on handling legacy algorithms when
   interoperating with RFC 4130 systems.</t>
      </section>
      <section anchor="encryption-algorithms">
        <name>Encryption Algorithms</name>
        <t>Implementations MUST support AES encryption algorithms as defined in
   S/MIME Version 4.0 <xref target="RFC8551"/>. At a minimum, AES-128-CBC and AES-256-CBC
   MUST be supported. Implementations are also RECOMMENDED to support
   AES-128-GCM and AES-256-GCM. Support for AES-CCM is also RECOMMENDED
   for environments requiring authenticated encryption.</t>
        <t>Triple DES (3DES) and RC2 are deprecated and SHOULD NOT be generated by
   conformant implementations.</t>
        <section anchor="envelopeddata-vs-authenvelopeddata">
          <name>EnvelopedData vs AuthEnvelopedData</name>
          <t>The choice between EnvelopedData and AuthEnvelopedData depends on the
   content encryption algorithm selected:</t>
          <artwork><![CDATA[
     o  **AuthEnvelopedData** MUST be used when employing authenticated
        encryption algorithms such as AES-GCM or AES-CCM. These algorithms
        provide both confidentiality and integrity protection in a single
        cryptographic operation. AuthEnvelopedData was introduced in
        S/MIME 4.0 [RFC8551] specifically to support these modes.

     o  **EnvelopedData** MUST be used when employing non-authenticated
        encryption algorithms such as AES-CBC or when maintaining backward
        compatibility with S/MIME 3.2 implementations [RFC5751]. When using
        EnvelopedData, integrity protection MUST be provided separately
        through digital signatures (multipart/signed).
]]></artwork>
          <t>Implementations MUST NOT mix content encryption algorithms for
   different recipients of the same message. A single content encryption
   algorithm MUST be selected and used for all recipients. For example,
   if a message is encrypted with AES-128-GCM, all recipient information
   MUST use AES-128-GCM; it is not permitted to encrypt the content-
   encryption key with AES-CBC for some recipients and AES-GCM for
   others.</t>
        </section>
        <section anchor="multiple-recipient-encryption">
          <name>Multiple-Recipient Encryption</name>
          <t>To support recoverable decryption and regulatory requirements,
   implementations SHOULD support multiple-recipient encryption of the
   content-encryption key (CEK), consistent with <xref target="RFC8551"/> Section 3.3.
   A copy of the CEK encrypted for the originator SHOULD also be included in
   the EnvelopedData, and the same principle applies to AuthEnvelopedData
   when using AES-CCM or AES-GCM.</t>
          <t>See Section 1.2.1 for guidance on handling 3DES and other weak algorithms
   when interoperating with legacy AS2 systems.</t>
        </section>
      </section>
    </section>
    <section anchor="structure-and-processing-of-an-mdn-message">
      <name>Structure and Processing of an MDN Message</name>
      <t>This document aligns MDN behavior with RFC 8098, clarifying semantics
for interoperability. It does not redefine the MDN format.
Implementations MUST be able to parse historic MDN forms as described in
RFC 3798 for backward compatibility.</t>
      <section anchor="introduction-2">
        <name>Introduction</name>
        <t>In order to support non-repudiation of receipt, a signed receipt,
   based on digitally signing a message disposition notification, is to
   be implemented by a receiving trading partner's UA. The message
   disposition notification, specified by RFC 3798, is digitally signed
   by a receiving trading partner as part of a multipart/signed MIME
   message.</t>
        <t>The requirements in this section update but do not alter the compatibility
   of MDN formats with existing AS2 implementations (see <xref target="backward-compatibility-and-interoperability"/>).
   This ensures interoperability with both RFC 3798 and RFC 8098 implementations.</t>
        <t>The following support for signed receipts is REQUIRED:</t>
        <artwork><![CDATA[
  1. The ability to create a multipart/report; where the
     report-type = disposition-notification.

  2. The ability to calculate a message integrity check (MIC) on the
     received message. The calculated MIC value will be returned to
     the sender of the message inside the signed receipt.

  3. The ability to create a multipart/signed content with the
     message disposition notification as the first body part, and
     the signature as the second body part.

  4. The ability to return the signed receipt to the sending trading
     partner.

  5. The ability to return either a synchronous or an asynchronous
     receipt as the sending party requests.
]]></artwork>
        <t>The signed receipt is used to notify a sending trading partner that
   requested the signed receipt that:</t>
        <artwork><![CDATA[
  1. The receiving trading partner acknowledges receipt of the sent
     EC Interchange.

  2. If the sent message was signed, then the receiving trading
     partner has authenticated the sender of the EC Interchange.

  3. If the sent message was signed, then the receiving trading
     partner has verified the integrity of the sent EC Interchange.
]]></artwork>
        <t>Regardless of whether the EDI/EC Interchange was sent in S/MIME
   format, the receiving trading partner's UA MUST provide the following
   basic processing:</t>
        <artwork><![CDATA[
  1. If the sent EDI/EC Interchange is encrypted, then the encrypted
     symmetric key and initialization vector (if applicable) is
     decrypted using the receiver's private key.

  2. The decrypted symmetric encryption key is then used to decrypt
     the EDI/EC Interchange.

  3. The receiving trading partner authenticates signatures in a
     message using the sender's public key. The authentication
     algorithm performs the following:

     a. The message integrity check (MIC or Message Digest), is
        decrypted using the sender's public key.

     b. A MIC on the signed contents (the MIME header and encoded
        EDI object, as per RFC 1767) in the message received is
        calculated using the same one-way hash function that the
        sending trading partner used.

     c. The MIC extracted from the message that was sent and the MIC
        calculated using the same one-way hash function that the
        sending trading partner used are compared for equality.

  4. The receiving trading partner formats the MDN and sets the
     calculated MIC into the "Received-content-MIC" extension field.

  5. The receiving trading partner creates a multipart/signed MIME
     message according to RFC 1847.

  6. The MDN is the first part of the multipart/signed message, and
     the digital signature is created over this MDN, including its
     MIME headers.

  7. The second part of the multipart/signed message contains the
     digital signature. The "protocol" option specified in the
     second part of the multipart/signed is as follows:

           S/MIME: protocol = "application/pkcs7-signature"

  8. The signature information is formatted according to S/MIME
     specifications.
]]></artwork>
        <t>The EC Interchange and the RFC 1767 MIME EDI content header can
   actually be part of a multi-part MIME content-type. When the EDI
   Interchange is part of a multi-part MIME content-type, the MIC MUST
   be calculated across the entire multi-part content, including the
   MIME headers contained within the multi-part MIME content.</t>
        <t>The signed MDN, when received by the sender of the EDI Interchange,
   can be used by the sender as follows:</t>
        <artwork><![CDATA[
    o  As an acknowledgement that the EDI Interchange sent was
       delivered and acknowledged by the receiving trading partner.
       The receiver does this by returning the original-message-id
       of the sent message in the MDN portion of the signed receipt.

    o  As an acknowledgement that the integrity of the EDI
       Interchange was verified by the receiving trading partner.
       The receiver does this by returning the calculated MIC of the
       received EC Interchange (and 1767 MIME headers) in the
       "Received-content-MIC" field of the signed MDN.

    o  As an acknowledgement that the receiving trading partner has
       authenticated the sender of the EDI Interchange.

    o  As a non-repudiation of receipt when the signed MDN is
       successfully verified by the sender with the receiving
       trading partner's public key and the returned MIC value
       inside the MDN is the same as the digest of the original
       message.
]]></artwork>
      </section>
      <section anchor="synchronous-and-asynchronous-mdns">
        <name>Synchronous and Asynchronous MDNs</name>
        <t>The AS2-MDN exists in two varieties: synchronous and asynchronous.</t>
        <t>The synchronous AS2-MDN is sent as an HTTP response to an HTTP POST
   or as an HTTPS response to an HTTPS POST. This form of AS2-MDN is
   called synchronous because the AS2-MDN is returned to the originator
   of the POST on the same TCP/IP connection.</t>
        <t>The synchronous response MUST indicate transfer-layer success or
   failure, such as <tt>200 OK</tt> or <tt>202 Accepted</tt>.  The format of this
   response MAY be identical to that used when no AS2-MDN is requested.</t>
        <t>The asynchronous AS2-MDN is sent on a separate HTTP or HTTPS
   TCP/IP connection. Logically, the asynchronous AS2-MDN is a response
   to an AS2 message. However, at the transfer-protocol layer, assuming
   that no HTTP pipelining is utilized, the asynchronous AS2-MDN is
   delivered on a unique TCP/IP connection, distinct from that used to
   deliver the original AS2 message.</t>
        <t>When handling an asynchronous request, the receiving system <strong>SHOULD</strong>
   return a transfer-layer response (typically <tt>202 Accepted</tt> or <tt>204 No Content</tt>)
   as soon as the last byte of the inbound message has been received, without waiting
   for decryption, signature verification, or message persistence.  This
   minimizes the risk of network timeouts and ensures that the sender can
   begin awaiting the asynchronous MDN promptly. The asynchronous MDN MUST be
   transmitted as an independent HTTP message, separate from the original
   connection used to submit the AS2 message.</t>
        <t>Implementations <strong>MAY</strong> use persistent (keep-alive) HTTP connections.
   Closing the TCP connection immediately after sending the response is
   <strong>RECOMMENDED</strong> for simplicity, but not required.  Some application
   servers and frameworks manage connection lifecycles automatically and
   may keep the socket open.  The AS2 specification does not mandate that
   the AS2 layer explicitly close the connection.</t>
        <t>The following diagram illustrates the synchronous versus asynchronous
   varieties of AS2-MDN delivery using HTTP:</t>
        <sourcecode type="text"><![CDATA[
   Synchronous AS2-MDN

   {Peer1} ----( connect )----> {Peer2}
   {Peer1} -----( send )------> {Peer2}   HTTP Request {AS2-Message}
   {Peer1} <---( receive )----- {Peer2}   HTTP Response {AS2-MDN}

   Asynchronous AS2-MDN

   {Peer1} ----( connect )----> {Peer2}
   {Peer1} -----( send )------> {Peer2}   HTTP Request {AS2-Message}
   {Peer1} <---( receive )----- {Peer2}   HTTP Response (e.g., "200 OK" or "204 No Content")
   {Peer1}*<---( connect )----- {Peer2}
   {Peer1} <--- ( send )------- {Peer2}   HTTP Request {AS2-MDN}
   {Peer1} ----( receive )----> {Peer2}   HTTP Response
]]></sourcecode>
        <ul spacing="normal">
          <li>
            <t>Note: An AS2-MDN may be directed to a host different from that of
   the sender of the AS2 message. It may also utilize a transfer protocol
   different from that used to send the original AS2 message.</t>
          </li>
        </ul>
        <t>The advantage of the synchronous MDN is that it provides the
   sender of the AS2 message with a verifiable confirmation of
   delivery within a single synchronous logic flow. However, if the
   message is large, the time required to process it and return the
   AS2-MDN on the same connection may exceed the maximum configured
   time permitted for maintaining an open connection.</t>
        <t>The advantage of the asynchronous MDN is that it provides for the
   rapid return of a transfer-layer acknowledgment from the receiver,
   confirming receipt of data, while allowing full processing to occur
   later. This reduces connection duration and timeout risk.  However,
   the asynchronous AS2-MDN MUST include sufficient identifying
   information (for example, <tt>Original-Message-ID</tt> and <tt>Final-Recipient</tt>)
   so that the message originator can correlate the MDN with its original
   message and update the processing status accordingly.</t>
        <t>Synchronous and asynchronous HTTP or HTTPS MDNs are both valid under
   this specification.  Implementations MUST support receiving both
   types and SHOULD support sending both.</t>
      </section>
      <section anchor="requesting-a-signed-receipt">
        <name>Requesting a Signed Receipt</name>
        <t>Message disposition notifications are requested as per RFC 3798. A
   request that the receiving user agent issue a message disposition
   notification is made by placing the following header into the message
   to be sent:</t>
        <artwork><![CDATA[
    MDN-request-header = "Disposition-notification-to"
                        ":"  mail-address
]]></artwork>
        <t>The following example is for requesting an MDN:</t>
        <artwork><![CDATA[
    Disposition-notification-to: xxx@example.com
]]></artwork>
        <t>The "Disposition-notification-to" header field is retained for compatibility
   with the MDN specification <xref target="RFC3798"/>, but its value is not used by AS2 implementations
   to determine where to return the MDN. Its presence just indicates that an MDN receipt is
   to be returned to the originator. In AS2, the field value may be an email address, a URL,
   a fully qualified domain name, an AS2 identifier, or any other implementation-specific string.
   Implementations MUST NOT reject a message based on the syntax of this field. This document
   relaxes the original requirement from RFC 4130, which mandated an email address, in order to
   reflect current AS2 practice while maintaining backward compatibility (see <xref target="backward-compatibility-and-interoperability"/>).</t>
        <t>When requesting MDN-based receipts, the originator supplies
   additional extension headers that precede the message body.  These
   header "tags" are as follows:</t>
        <t>A Message-ID header is added to support message reconciliation, so
   that an Original-Message-Id value can be returned in the body part of
   MDN. Other headers, especially "Subject" and "Date", SHOULD be
   supplied; the values of these headers are often mentioned in the
   human-readable portion of a MDN to aid in identifying the original
   message.</t>
        <t>MDNs will be returned in the HTTP response when requested, unless an
   asynchronous MDN is requested.</t>
        <t>To request an asynchronous message disposition notification, the
   following header is placed into the message that is sent:</t>
        <artwork><![CDATA[
    Receipt-Delivery-Option: return-URL
]]></artwork>
        <t>This is an example requesting that the MDN be asynchronous:</t>
        <artwork><![CDATA[
    Receipt-Delivery-Option: http://www.example.com/Path
]]></artwork>
        <t>Receipt-delivery-option syntax allows the return-url to use some schemes
   other than HTTP using the POST method.</t>
        <t>The "receipt-delivery-option: return-url" string indicates the URL to
   use for an asynchronous MDN. This header is NOT present if the
   receipt is to be synchronous. The email value in Disposition-
   notification-to is not used in this specification because it was
   limited to RFC 2822 addresses (now replaced by <xref target="RFC5322"/>); the extension
   header "Receipt-delivery-option" has been introduced to provide a
   URL for the MDN return by several transfer options.</t>
        <t>The receipt-delivery-option's value MUST be a URL indicating the
   delivery transport destination for the receipt.</t>
        <t>An example request for an asynchronous MDN via an HTTP transport:</t>
        <artwork><![CDATA[
    Receipt-delivery-option: http://www.example.com
]]></artwork>
        <t>An example request for an asynchronous MDN via an HTTP/S transport:</t>
        <artwork><![CDATA[
    Receipt-delivery-option: https://www.example.com
]]></artwork>
        <t>Finally, the header, Disposition-notification-options, identifies
   characteristics of message disposition notification as in <xref target="RFC3798"/>. The
   most important of these options is for indicating the signing options
   for the MDN, as in the following example:</t>
        <artwork><![CDATA[
    Disposition-notification-options:
         signed-receipt-protocol=optional,pkcs7-signature;
         signed-receipt-micalg=optional,sha-256,sha1
]]></artwork>
        <t>For signing options, consider the disposition-notification-options
   syntax:</t>
        <artwork><![CDATA[
    Disposition-notification-options =
             "Disposition-Notification-Options" ":"
              disposition-notification-parameters
where
         disposition-notification-parameters =
                           parameter *(";" parameter)

where
         parameter = attribute "=" importance ", " 1#value"

where
         importance = "required" | "optional"
]]></artwork>
        <t>So the Disposition-notification-options string could be:</t>
        <artwork><![CDATA[
    signed-receipt-protocol=optional, <protocol symbol>;
    signed-receipt-micalg=optional, <micalg1>, <micalg2>,...;
]]></artwork>
        <t>The currently used value for &lt;protocol symbol&gt; is "pkcs7-signature"
   for the S/MIME detached signature format.</t>
        <t>The currently supported values for MIC algorithm &lt;micalg&gt; values are:</t>
        <artwork><![CDATA[
     Algorithm   Value Used
     ---------    ---------
      SHA-256      sha-256
      SHA-384      sha-384
      SHA-512      sha-512
      SHA-1        sha-1 or sha1 (should *only* be used in legacy deployments that
                                  cannot support SHA-256 or greater)
]]></artwork>
        <t>The semantics of the "signed-receipt-protocol" and the "signed-receipt-micalg"
   parameters are as follows:</t>
        <ol spacing="normal" type="1"><li>
            <t>The "signed-receipt-protocol" parameter is used to request a
signed receipt from the recipient trading partner. The "signed-receipt-protocol"
parameter also specifies the format in which the signed receipt SHOULD be returned
to the requester.  </t>
            <t>
The "signed-receipt-micalg" parameter identifies one or more message
integrity check (MIC) algorithms, in order of preference, that the
requester supports for signing the returned receipt. Although multiple
values MAY be listed to indicate fallback options, only a single MIC
algorithm is used in the returned MDN because the "Received-content-MIC"
field conveys exactly one digest value.  </t>
            <t>
Recipients MUST select the first algorithm in the list that they also
support and MUST compute the Received-content-MIC using that algorithm.
Senders SHOULD list the strongest algorithm first. Modern
implementations SHOULD include only a single value unless multiple
values are needed to support phased migration away from weaker
algorithms. Implementations MUST accept messages that contain multiple
values and MUST ignore unsupported values.  </t>
            <t>
When a sender lists multiple algorithms, recipients MUST NOT fall back
to an algorithm that is not explicitly listed by the sender.
Trading partners typically pre-configure acceptable MIC algorithms
through bilateral agreement, and runtime negotiation is not needed.
If none of the algorithms listed is supported, the recipient SHOULD
reject the message and MAY return an unsigned MDN indicating
"unsupported-mic-algorithm" rather than silently selecting a weaker
algorithm.  When the header is absent (e.g., unsigned messages), an
implementation MUST use a locally configured default algorithm; SHA-256
SHOULD be preferred, but SHA-1 MAY be used when required for legacy partners.</t>
          </li>
        </ol>
        <t><strong>The following algorithm requirements apply to all implementations:</strong></t>
        <artwork><![CDATA[
     o  Implementations **MUST** support SHA-256.

     o  Implementations **SHOULD** support SHA-384 or stronger.

     o  SHA-1 **MAY** be accepted only when required for interoperability
        with legacy partners and SHOULD NOT be generated for modern
        implementations once both parties support stronger algorithms.

     o  MD5 is obsolete and MUST NOT be generated.

  See Section 10 for additional algorithm requirements
  and deprecation timelines.

  Both the "signed-receipt-protocol" and the "signed-receipt-micalg"
  option parameters are REQUIRED when requesting a signed receipt.

  The lack of the presence of the "Receipt-Delivery-Option"
  indicates that a receipt is synchronous in nature. The presence
  of the "Receipt-Delivery-Option: return-url" indicates that an
  asynchronous receipt is requested and SHOULD be sent to the
  "return-url".
]]></artwork>
        <ol spacing="normal" type="1"><li>
            <t>The "importance" attribute of "Optional" is defined in RFC 3798,
Section 2.2, and has the following meaning:  </t>
            <t>
Parameters with an importance of "Optional" permit a UA that does
not understand the particular options parameter to still generate
an MDN in response to a request for a MDN.  </t>
            <t>
A UA that does not understand the "signed-receipt-protocol"
parameter or the "signed-receipt-micalg" will obviously not return
a signed receipt.  </t>
            <t>
The importance of "Optional" is used for the signed receipt
parameters because it is RECOMMENDED that an MDN be returned to
the requesting trading partner even if the recipient could not
sign it.  </t>
            <t>
The returned MDN will contain information on the disposition of
the message and on why the MDN could not be signed. See the
Disposition field in <xref target="structure-and-processing-of-an-mdn-message"/>.5
for more information.  </t>
            <t>
Within an EDI trading relationship, if a signed receipt is
expected and is not returned, then the validity of the transaction
is up to the trading partners to resolve.  </t>
            <t>
In general, if a signed receipt is required in the trading
relationship and is not received, the transaction will likely
be considered invalid.</t>
          </li>
        </ol>
        <section anchor="signed-receipt-considerations">
          <name>Signed Receipt Considerations</name>
          <t>The method used to request a receipt or a signed receipt is defined
   in RFC 3798, "An Extensible Message Format for Message Disposition
   Notifications".</t>
          <t>The "rules" are as follows:</t>
          <ol spacing="normal" type="1"><li>
              <t>When a receipt is requested, explicitly specifying that the
receipt be signed, then the receipt MUST be returned with a
signature.</t>
            </li>
            <li>
              <t>When a receipt is requested, explicitly specifying that the
receipt be signed, but the recipient cannot support either the
requested protocol format or the requested MIC algorithms, then
either a signed or unsigned receipt SHOULD be returned.</t>
            </li>
            <li>
              <t>When a signature is not explicitly requested, or if the signed
receipt request parameter is not recognized by the UA, then no
receipt, an unsigned receipt, or a signed receipt MAY be returned
by the recipient.</t>
            </li>
          </ol>
          <t>NOTE: For Internet EDI, it is RECOMMENDED that when a signature is
   not explicitly requested, or if parameters are not recognized, the UA
   send back, at a minimum, an unsigned receipt. If, however, a signed
   receipt was always returned as a policy, whether requested or not,
   then any false unsigned receipts can be repudiated.</t>
          <t>When a request for a signed receipt is made, but there is an error in
   processing the contents of the message, a signed receipt MUST still
   be returned. The request for a signed receipt SHALL still be
   honored, though the transaction itself may not be valid. The reason
   why the contents could not be processed MUST be set in the
   "disposition-field".</t>
          <t>When a signed receipt request is made, the "Received-content-MIC"
   MUST always be returned to the requester (except when corruption
   prevents computation of the digest in accordance with the following
   specification). The "Received-content-MIC" MUST be calculated as
   follows:</t>
          <artwork><![CDATA[
     o  For any signed messages, the MIC to be returned is calculated
        on the RFC1767/RFC3023 MIME header and content.
        Canonicalization on the MIME headers MUST be performed before
        the MIC is calculated, since the sender requesting the signed
        receipt was also REQUIRED to canonicalize.

     o  For encrypted, unsigned messages, the MIC to be returned is
        calculated on the decrypted RFC 1767/RFC3023 MIME header and
        content. The content after decryption MUST be canonicalized
        before the MIC is calculated.

     o  For unsigned, unencrypted messages, the MIC MUST be calculated
        over the message contents without the outer MIME or any other RFC
        5322 headers, since these may sometimes be altered or reordered by
        intermediary user agents or proxies.
]]></artwork>
        </section>
      </section>
      <section anchor="mdn-format-and-values">
        <name>MDN Format and Values</name>
        <t>This section defines the format of the AS2 Message Disposition
   Notification (AS2-MDN).</t>
        <section anchor="as2-mdn-general-formats">
          <name>AS2-MDN General Formats</name>
          <sourcecode type="abnf"><![CDATA[
AS2-MDN = AS2-sync-MDN | AS2-async-http-MDN

AS2-sync-MDN =
   Status-Line
   *(( general-header | response-header | entity-header )
     CRLF )
   CRLF
   AS2-MDN-body

Status-Line =
   HTTP-Version SP Status-Code SP Reason-Phrase CRLF

AS2-async-http-MDN =
   Request-Line
   *(( general-header | request-header | entity-header )
     CRLF )
   CRLF
   AS2-MDN-body

Request-Line =
   Method SP Request-URI SP HTTP-Version CRLF

AS2-MDN-body =
   AS2-signed-MDN-body | AS2-unsigned-MDN-body
]]></sourcecode>
        </section>
        <section anchor="as2-mdn-construction">
          <name>AS2-MDN Construction</name>
          <t>The AS2-MDN-body is formatted as a MIME multipart/report with a
   report-type of "disposition-notification". When the message is
   unsigned, the transfer-layer ("outermost") entity-headers of the
   AS2-MDN contain the content-type header that specifies a content-type
   of "multipart/report" and parameters indicating the report-type, and
   the value of the outermost multipart boundary.</t>
          <t>When the AS2-MDN is signed, the transfer-layer ("outermost") entity-
   headers of the AS2-MDN contain a content-type header that specifies a
   content-type of "multipart/signed" and parameters indicating the
   algorithm used to compute the message digest, the signature-
   formatting protocol (e.g., pkcs7-signature), and the value of the
   outermost multipart boundary. The first part of the MIME
   multipart/signed message is an embedded MIME multipart/report of type
   "disposition-notification". The second part of the multipart/signed
   message contains a MIME application/pkcs7-signature message.</t>
          <t>The first part of the MIME multipart/report is a "human-readable"
   portion containing a general description of the message
   disposition. The second part of the MIME multipart/report is a
   "machine-readable" portion that is defined as:</t>
          <sourcecode type="abnf"><![CDATA[
AS2-disposition-notification-content =
    reporting-ua-field CRLF
    mdn-gateway-field CRLF
    final-recipient-field CRLF
    original-message-id-field CRLF
    AS2-disposition-field CRLF
    *( failure-field CRLF )
    *( error-field CRLF )
    *( warning-field CRLF )
    *( extension-field CRLF )
    AS2-received-content-MIC-field CRLF
]]></sourcecode>
        </section>
        <section anchor="as2-mdn-fields">
          <name>AS2-MDN Fields</name>
          <t>The rules for constructing the AS2-disposition-notification content
   are identical to the disposition-notification-content rules provided
   in <xref target="algorithm-requirements"/> of RFC 3798 <xref target="RFC3798"/>, except that the RFC 3798 disposition-
   field has been replaced with the AS2-disposition-field and that the
   AS2-received-content-MIC field has been added. The differences
   between the RFC 3798 disposition-field and the AS2-disposition-field
   are described below. Where there are differences between this
   document and RFC 3798, those entity names have been changed by
   pre-pending "AS2-". Entities that do not differ from RFC 3798 are not
   necessarily further defined in this document; refer to RFC 3798,
   Section 7, "Collected Grammar", for the original grammar.</t>
          <sourcecode type="abnf"><![CDATA[
AS2-disposition-field =
    "Disposition" ":" disposition-mode ";"
    AS2-disposition-type "/" AS2-disposition-modifier

disposition-mode =
    action-mode "/" sending-mode

action-mode =
    "manual-action" | "automatic-action"

sending-mode =
    "MDN-sent-manually" | "MDN-sent-automatically"

AS2-disposition-type =
    "processed" | "failed"

AS2-disposition-modifier =
    ( "error" | "warning" ) | AS2-disposition-modifier-extension

AS2-disposition-modifier-extension =
    "error: authentication-failed" |
    "error: decompression-failed" |
    "error: decryption-failed" |
    "error: duplicate-filename" |
    "error: illegal-filename" |
    "error: insufficient-message-security" |
    "error: integrity-check-failed" |
    "error: invalid-message-id" |
    "error: unexpected-processing-error" |
    "error: unknown-trading-relationship" |
    "warning: " AS2-MDN-warning-description |
    "failure: " AS2-MDN-failure-description

AS2-MDN-warning-description = *( TEXT )

AS2-MDN-failure-description = *( TEXT )

AS2-received-content-MIC-field =
    "Received-content-MIC" ":" encoded-message-digest ","
    digest-alg-id CRLF

encoded-message-digest =
    1*( 'A'-'Z' | 'a'-'z' | '0'-'9' | '/' | '+' | '=' )
    ; i.e., base64(message-digest)

digest-alg-id = "sha-256" | "sha-384" | "sha-512" | "sha-1" | "sha1"
                 ; The "sha1" is a legacy representation of the "sha-1"
                 ; defined hash in the IANA Textual Names Registry.
                 ; It should be maintained for backwards compatibility;
                 ; sha1 | sha-1 should only be used by legacy deployments
                 ; that cannot support sha-256 or greater
]]></sourcecode>
          <t>To improve error reporting and interoperability, this specification
   introduces additional standardized disposition modifiers beyond those
   defined in <xref target="RFC4130"/> and <xref target="RFC8098"/>.</t>
          <t>These modifiers are used to indicate specific failure conditions that
   cannot be adequately represented by the existing error codes and may
   not be compatible with earlier implementations of AS2.
   Implementations MUST include a human-readable explanation in the MDN
   <tt>Explanation</tt> field when returning these modifiers.</t>
          <t>Future modifiers may be registered through the IANA registry for
   AS2 Disposition Values and Modifiers (see <xref target="iana-considerations"/>).</t>
          <t>The "Received-content-MIC" extension field is set when the integrity
   of the received message is verified. The MIC value is the base64-encoded
   message-digest computed over the received message using a hash
   function. This field is required for signed receipts but optional
   for unsigned receipts. For details defining the specific content
   over which the message digest is to be computed, see <xref target="structure-and-processing-of-an-mdn-message"/>.3.1
   of this document.</t>
          <t>For signed messages, the algorithm used to calculate the MIC MUST be
   the same as that used on the message that was signed. If the message
   is not signed, then the SHA-256 algorithm SHOULD be used. SHA-1 MAY be
   used only for legacy interoperability (see <xref target="backward-compatibility-and-interoperability"/>.1). This field
   is set only when the content of the message is processed
   successfully. This field is used in conjunction with the recipient's
   signature on the MDN so that the sender can verify non-repudiation of
   receipt.</t>
          <t>AS2-MDN field names (e.g., "Disposition:", "Final-Recipient:") are
   case insensitive (cf. RFC 3798, Section 3.1.1). AS2-MDN action-
   modes, sending-modes, AS2-disposition-types, and AS2-disposition-
   modifier values, which are defined above, and user-supplied *( TEXT )
   values are also case-insensitive. AS2 implementations MUST NOT make
   assumptions regarding the values supplied for AS2-MDN-warning-
   description or AS2-MDN-failure-description, or for the values of any
   (optional) error, warning, or failure fields.</t>
        </section>
        <section anchor="as2-mdn-field-requirements">
          <name>AS2-MDN Field Requirements</name>
          <t>The following fields have clarified requirements for interoperability:</t>
          <artwork><![CDATA[
     o  **Final-Recipient** — This field **MUST** always be present in an MDN
         and MUST identify the AS2-To value of the original message.

     o  **Original-Message-ID** — This field is **REQUIRED** and MUST exactly
         match the `Message-ID` of the original message as transmitted.
        `Message-ID` in the MDN itself is optional.

     o  **Disposition-Notification-To** — Implementations **MAY** include this
         field using an email address, URL, hostname, or other identifier as
         appropriate to the system.  However, as specified in [RFC4130], receiving
         applications **MUST** ignore this field and **MUST NOT** reject a message
         due to syntax or address format violations. The field is retained for
         compatibility with prior implementations.
]]></artwork>
        </section>
        <section anchor="additional-as2-mdn-programming-notes">
          <name>Additional AS2-MDN Programming Notes</name>
          <artwork><![CDATA[
     o  For HTTP transactions, Original-Recipient and Final-Recipient
        SHOULD not be different.  The value in Original-Message-ID SHOULD
        match the original Message-ID header value.

     o  Refer to RFC 3798 for the formatting of the MDN, except for the
        specific deviations mentioned above.

     o  Refer to RFC 3462 and RFC 3798 for the formatting of the content-
        type entity-headers for the MDN.

     o  Use an action-mode of "automatic-action" when the disposition
        described by the disposition type was a result of an automatic
        action rather than that of an explicit instruction by the user for
        this message.

     o  Use an action-mode of "manual-action" when the disposition
        described by the disposition type was a result of an explicit
        instruction by the user rather than some sort of automatically
        performed action.

     o  Use a sending-mode of "MDN-sent-automatically" when the MDN is
        sent because the UA had previously been configured to do so.

     o  Use a sending-mode of "MDN-sent-manually" when the user explicitly
        gave permission for this particular MDN to be sent.

     o  The sending-mode "MDN-sent-manually" is meaningful ONLY with
        "manual-action", not with "automatic-action".

     o  The "failed" disposition type MUST NOT be used for the situation
        in which there is some problem in processing the message other
        than interpreting the request for an MDN. The "processed" or
        other disposition type with appropriate disposition modifiers is
        to be used in such situations.
]]></artwork>
        </section>
      </section>
      <section anchor="disposition-mode-type-and-modifier">
        <name>Disposition Mode, Type, and Modifier</name>
        <section anchor="disposition-mode-overview">
          <name>Disposition Mode Overview</name>
          <t>This section provides a brief overview of how "processed", "error",
   "failure", and "warning" are used.</t>
        </section>
        <section anchor="successful-processing-status-indication">
          <name>Successful Processing Status Indication</name>
          <t>When the request for a receipt or signed receipt, and the received
   message contents are successfully processed by the receiving EDI UA,
   a receipt or MDN SHOULD be returned with the disposition-type set to
   "processed". When the MDN is sent automatically by the EDI UA, and
   there is no explicit way for a user to control the sending of the
   MDN, then the first part of the "disposition-mode" SHOULD be set to
   "automatic-action". When the MDN is being sent under user-
   configurable control, then the first part of the "disposition-mode"
   SHOULD be set to "manual-action". Since a request for a signed
   receipt should always be honored, the user MUST not be allowed to
   configure the UA to disallow sending of a signed receipt when the sender
   requests one.</t>
          <t>The second part of the disposition-mode is set to "MDN-sent-manually"
   if the user gave explicit permission for the MDN to be sent. Again,
   the user MUST not be allowed to explicitly refuse to send a signed
   receipt when the sender requests one. The second part of the
   "disposition-mode" is set to "MDN-sent-automatically" whenever the
   EDI UA sends the MDN automatically, regardless of whether the sending
   was under the control of a user, administrator, or the software.</t>
          <t>Because EDI content is generally handled automatically by the EDI UA,
   a request for a receipt or signed receipt will generally return the
   following in the "disposition-field":</t>
          <artwork><![CDATA[
   Disposition: automatic-action/MDN-sent-automatically; processed
]]></artwork>
          <t>Note that this specification does not restrict the use of the
   "disposition-mode" just to automatic actions. Manual actions are
   valid as long as it is kept in mind that a request for a signed
   receipt MUST be honored.</t>
        </section>
        <section anchor="unsuccessful-processed-content">
          <name>Unsuccessful Processed Content</name>
          <t>The request for a signed receipt requires the use of two
   "disposition-notification-options", which specify the protocol format
   of the returned signed receipt, and the MIC algorithm used to
   calculate the MIC over the message content. The "disposition-field"
   values that should be used if the message content is being rejected
   or ignored (for instance, if the EDI UA determines that a signed
   receipt cannot be returned because it does not support the requested
   protocol format, the EDI UA chooses not to process the message
   contents itself) MUST be specified in the MDN "disposition-field" as
   follows:</t>
          <artwork><![CDATA[
   Disposition: "disposition-mode";  failed/Failure: unsupported format
]]></artwork>
          <t>The "failed" AS2-disposition-type MUST be used when a failure occurs
   that prevents the proper generation of an MDN. For example, this
   disposition-type would apply if the sender of the message requested
   the application of an unsupported message-integrity-check (MIC)
   algorithm.</t>
          <t>The "failure:" AS2-disposition-modifier-extension SHOULD be used with
   an implementation-defined description of the failure. Further
   information about the failure may be contained in a failure-field.</t>
          <t>The syntax of the "failed" disposition-type is general, allowing the
   sending of any textual information along with the "failed"
   disposition-type. Implementations MUST support any printable textual
   characters after the Failure disposition-type. For use in Internet
   EDI, the following "failed" values are pre-defined and MUST be
   supported:</t>
          <artwork><![CDATA[
   "Failure: unsupported format"
   "Failure: unsupported MIC-algorithms"
]]></artwork>
        </section>
        <section anchor="unsuccessful-non-content-processing">
          <name>Unsuccessful Non-Content Processing</name>
          <t>When errors occur in processing the received message (other than
   content), the "disposition-field" MUST be set to the "processed"
   value for disposition-type and the "error" value for disposition-
   modifier.</t>
          <t>The "error" AS2-disposition-modifier with the "processed"
   disposition-type MUST be used to indicate that an error of some sort
   occurred that prevented successful processing of the message.
   Further information may be contained in an error-field.</t>
          <t>An "error:" AS2-disposition-modifier-extension SHOULD be used to
   combine the indication of an error with a predefined description of a
   specific, well-known error. Further information about the error may
   be contained in an error field.</t>
          <t>For Internet EDI use, the following "error" AS2-disposition-modifier
   values are defined:</t>
          <sourcecode type="text"><![CDATA[
   o "Error: authentication-failed"         - the receiver could not
                                              authenticate the sender.

   o "Error: decompression-failed"          - the receiver could not
                                              decompress the message
                                              contents.

   o "Error: decryption-failed"             - the receiver could not
                                              decrypt the message
                                              contents.
   o "Error: duplicate-filename"            - the message payload contained
                                              a filename already received
                                              by the backend server.

   o "Error: illegal-filename"              - the message payload contained
                                              a filename that could nor be
                                              processed by the backend server.

   o "Error: insufficient-message-security" - the content of the message
                                              was not appropriately enveloped
                                              according to the agreed-upon
                                              message security.

   o "Error: integrity-check-failed"        - the receiver could not
                                              verify content integrity.

   o "Error: invalid-message-id"            - the receiver could not
                                              parse the value of the
                                              Message-ID header because it
                                              was not syntactically correct.

   o "Error: unexpected-processing-error"   - a catch-all for any
                                              additional processing
                                              errors.

   o "Error: unknown-trading-relationship"   - the receiver could not
                                              correlate the AS2-To/AS2-From
                                              header values to values known
                                              to the system.
]]></sourcecode>
          <t>An example of how the "disposition-field" would look when errors
   other than those in content processing are detected is as follows:</t>
          <artwork><![CDATA[
   Disposition: "disposition-mode"; processed/Error: decryption-failed
]]></artwork>
        </section>
        <section anchor="processing-warnings">
          <name>Processing Warnings</name>
          <t>Situations arise in EDI when, even if a trading partner cannot be
   authenticated correctly, the trading partners still agree to continue
   processing the EDI transactions. Transaction reconciliation is done
   between the trading partners at a later time. In the content
   processing warning situations as described above, the "disposition-
   field" MUST be set to the "processed" disposition-type value, and the
   "warning" to the "disposition-modifier" value.</t>
          <t>The "warning" AS2-disposition-modifier MUST be used with the
   "processed" disposition-type to indicate that the message was
   successfully processed but that an exceptional condition occurred.
   Further information may be contained in a warning-field.</t>
          <t>A "warning:" AS2-disposition-modifier-extension SHOULD be used to
   combine the indication of a warning with an implementation-defined
   description of the warning.  Further information about the warning
   may be contained in a warning-field.</t>
          <t>For use in Internet EDI, the following "warning"
   disposition-modifier-extension value is defined:</t>
          <artwork><![CDATA[
   "Warning: authentication-failed, processing continued"
]]></artwork>
          <t>An example of how the "disposition-field" would look when warning
   other than those for content processing are detected is as follows:</t>
          <t>Example:</t>
          <artwork><![CDATA[
   Disposition: "disposition-mode"; processed/warning:
     authentication-failed, processing continued
]]></artwork>
        </section>
        <section anchor="backward-compatibility-with-disposition-type-modifier-and-extension">
          <name>Backward Compatibility with Disposition Type, Modifier, and Extension</name>
          <t>The following set of examples represents typical constructions of the
   Disposition field that have been in use by AS2 implementations.  This
   is NOT an exhaustive list of possible constructions. However, AS2
   implementations MUST accept constructions of this type to be backward
   compatible with earlier AS2 versions.</t>
          <artwork><![CDATA[
  Disposition: automatic-action/MDN-sent-automatically; processed

  Disposition: automatic-action/MDN-sent-automatically;
    processed/error: authentication-failed

  Disposition: automatic-action/MDN-sent-automatically;
    processed/warning: duplicate-document

  Disposition: automatic-action/MDN-sent-automatically;
    failed/failure: sender-equals-receiver
]]></artwork>
          <t>The following set of examples represents allowable constructions of
   the Disposition field that combine the historic constructions above
   with optional RFC 3798 error, warning, and failure fields. AS2
   implementations MAY produce these constructions. However, AS2
   servers are not required to recognize or process optional error,
   warning, or failure fields at this time. Note that the use of the
   multiple error fields in the second example below provides for the
   indication of multiple error conditions.</t>
          <artwork><![CDATA[
     Disposition: automatic-action/MDN-sent-automatically; processed

     Disposition: automatic-action/MDN-sent-automatically;
       processed/error: decryption-failed
     Error: The signature did not decrypt into a valid PKCS#1 Type-2 block.
     Error: The length of the decrypted key does not equal the octet length of the modulus.

     Disposition: automatic-action/MDN-sent-automatically;
       processed/warning: duplicate-document
     Warning: An identical message already exists at the destination server.

     Disposition: automatic-action/MDN-sent-automatically;
          failed/failure: sender-equals-receiver
     Failure: The AS2-To name is identical to the AS2-From name.
]]></artwork>
          <t>The following set of examples represents allowable constructions of
   the Disposition field that employ pure RFC 3798 Disposition-modifiers
   with optional error, warning, and failure fields. These examples are
   provided as informational only. These constructions are not
   guaranteed to be backward compatible with AS2 implementations prior
   to version 1.1.</t>
          <artwork><![CDATA[
     Disposition: automatic-action/MDN-sent-automatically; processed

     Disposition: automatic-action/MDN-sent-automatically; processed/error
     Error: authentication-failed
     Error: The signature did not decrypt into a valid PKCS#1 Type-2 block.
     Error: The length of the decrypted key does not equal the octet length of the modulus.

     Disposition: automatic-action/MDN-sent-automatically; processed/warning
     Warning: duplicate-document

     Disposition: automatic-action/MDN-sent-automatically; failed
     Failure: sender-equals-receiver
]]></artwork>
        </section>
      </section>
      <section anchor="receipt-reply-considerations-in-an-http-post">
        <name>Receipt Reply Considerations in an HTTP POST</name>
        <t>The details of the response to the POST command vary depending upon
   whether a receipt has been requested.</t>
        <t>With no extended header requesting a receipt, and with no errors
   accessing the request-URI specified processing, the status line in
   the Response to the POST request SHOULD be in the 200 range. Status
   codes in the 200 range SHOULD also be used when an entity is returned
   (a signed receipt in a multipart/signed content type or an unsigned
   receipt in a multipart/report). Even when the disposition of the
   data was an error condition at the authentication, decryption or
   other higher level, the HTTP status code SHOULD indicate success at
   the HTTP level.</t>
        <t>The HTTP server application may respond with an unsolicited
   multipart/report as a message body that the HTTP client might not
   have solicited, but the client may discard this. Applications SHOULD
   avoid emitting unsolicited receipt replies because bandwidth or
   processing limitations might have led administrators to suspend
   asking for acknowledgements.</t>
        <t>Message Disposition Notifications, when used in the HTTP reply context,
   follow the same semantics as those defined in <xref target="RFC3798"/>. For example, the
   disposition field is a required element in the machine-readable
   second part of a multipart/report for a MDN. The final-recipient-
   field (<xref target="RFC3798"/>, Section 3.1) value SHOULD be derived from the entity
   headers of the request.</t>
        <t>In an MDN, the first part of the multipart/report (the human-readable
   portion) SHOULD include items such as the subject, the date, and other
   information when those fields are present in entity header fields
   following the POST request. An application MUST report the Message-
   ID of the request in the second part of the multipart/report (the
   machine-readable portion). Also, an MDN SHOULD have its own unique
   Message-ID HTTP header. The HTTP reply SHOULD normally omit the
   third optional part of the multipart/report (this was historically
   used to return the original message or its headers within the SMTP context).</t>
      </section>
    </section>
    <section anchor="public-key-certificate-handling">
      <name>Public Key Certificate Handling</name>
      <t>The initial exchange and certification of public keys are essential
   steps in establishing a secure trading partnership.  This process MAY
   occur manually during partner onboarding or automatically through
   supported mechanisms such as the <strong>AS2 GET</strong> method (see <xref target="certificate-exchange-and-renewal"/>).
   Implementations MUST maintain a database of public keys used for encryption
   and signature verification, together with the mapping between the EDI
   trading partner identifier and its associated RFC 5322 <xref target="RFC5322"/> email
   address and HTTP URL/URI. The exact procedures for establishing and
   configuring secure AS2 messaging can vary among trading partners and
   software implementations.</t>
      <t>X.509 certificates are REQUIRED. It is RECOMMENDED that trading
   partners self-certify each other if an agreed-upon certification
   authority is not used. This applicability statement does NOT require
   the use of a certification authority (CA) and the use of a CA
   is therefore OPTIONAL. Certificates MAY be self-signed.</t>
      <t>It is RECOMMENDED that when trading partners are using S/MIME they
   also exchange public key certificates, considering the advice provided in
   <xref target="RFC3850"/>.</t>
      <t>The message formats useful for certificate exchange are found in <xref target="RFC5751"/>
   and <xref target="RFC5652"/>.</t>
      <section anchor="certificate-roles-and-requirements">
        <name>Certificate Roles and Requirements</name>
        <t>While TLS certificates and AS2 message-signing certificates both use the
   X.509 standard, they serve distinct purposes and MUST be managed
   separately:</t>
        <artwork><![CDATA[
     o  **TLS Certificates** are used solely to secure the HTTPS transport
        channel. They establish session-level confidentiality and integrity and
        SHOULD be issued by a trusted certification authority (CA) in production
        environments. For public-facing servers, TLS certificates SHOULD comply
        with the CA/Browser Forum Baseline Requirements
       (https://cabforum.org/baseline-requirements-documents/). Self-signed
        TLS certificates MAY be used for testing or by explicit agreement
        between trading partners, provided they include a **Subject Alternative
        Name (SAN)** extension containing the DNS name and/or IP address. The
        SAN extension MUST be marked as non-critical.

     o  **AS2 Certificates** are used for signing and encrypting AS2 messages
        and MUST NOT be the same as the TLS certificate. Separation ensures that
        a compromise of the transport layer does not affect message-level
        security, and vice versa. Using the same certificate for both purposes
        creates security dependencies and operational risks that MUST be avoided.
        AS2 certificates MAY be CA-issued or self-signed, depending on
        organizational policy and trading-partner agreements.

        AS2 certificates MUST use a key length of at least **2048 bits for RSA
        keys**.  For elliptic-curve certificates, the selected curve MUST provide
        equivalent or stronger security (e.g., P-256 or higher).
]]></artwork>
        <t>Although short certificate lifetimes are now common in the TLS ecosystem
   due to CA/Browser Forum requirements and industry regulations, AS2 certificates
   generally do not require the same frequency of renewal. AS2 systems handle far fewer
   encrypted transactions than high-volume web servers, and certificate
   rollover can be operationally complex.  Implementations SHOULD allow
   independent lifetime policies for AS2 and TLS certificates.</t>
      </section>
      <section anchor="certificate-exchange-and-renewal">
        <name>Certificate Exchange and Renewal</name>
        <t>Automated certificate management significantly reduces operational risk.
   Implementations SHOULD support <strong>Certificate Exchange Messaging (CEM)</strong>
          <xref target="I-D.draft-meadors-certificate-exchange-14"/> to enable secure, automated
   exchange of AS2 certificates between trading partners. When CEM is not
   available, manual exchange processes MUST ensure integrity and authentication
   of keys prior to activation.</t>
        <t>The <strong>AS2 GET</strong> method MAY be used for initial retrieval of partner
   certificates. Implementations using AS2 GET MUST ensure that certificate
   retrieval is authenticated (to verify the requester's identity) and
   authorized (to ensure only legitimate trading partners can access
   certificates). While certificates themselves are digitally signed by their
   issuer and thus tamper-evident, authentication and authorization are
   required to prevent unauthorized parties from obtaining certificates and
   using them to identify legitimate trading partners or map relationships.
   For self-signed certificates, additional out-of-band verification (such as
   fingerprint confirmation via secure channel) is REQUIRED to establish
   initial trust before use in production.</t>
      </section>
      <section anchor="operational-guidance">
        <name>Operational Guidance</name>
        <artwork><![CDATA[
     o  TLS and AS2 certificates MUST be managed separately and MUST NOT be
        the same certificate.
     o  CEM SHOULD be supported to reduce manual errors and configuration drift.
     o  Self-signed certificates SHOULD include SAN extensions for clarity and
        validation consistency.
     o  Implementations SHOULD support configurable expiration and notification
        mechanisms for certificate renewal.
     o  Administrators MUST NOT reuse TLS certificates as AS2 certificates to
        maintain separation of security domains.
]]></artwork>
        <t>For security and algorithm lifecycle considerations, see <xref target="algorithm-requirements"/> and
   Section 10.</t>
      </section>
    </section>
    <section anchor="security-considerations">
      <name>Security Considerations</name>
      <t>This entire document is concerned with secure transport of business data,
   covering confidentiality, authentication, and non-repudiation.</t>
      <t>Cryptographic algorithms used for signatures, MIC calculations, and
   encryption are subject to modernization and deprecation guidance.
   The definitive algorithm requirements (for hash functions and
   encryption) are specified in <xref target="algorithm-requirements"/>.
   This section provides security rationale and additional guidance.</t>
      <t>Legacy algorithms such as SHA-1, MD5, 3DES, and RC2 are deprecated
   due to known weaknesses. Implementations SHOULD NOT generate these
   algorithms in modern implementations. However, legacy use cases may still be
   encountered when interoperating with older systems conforming to
   <xref target="RFC4130"/>. See Section 1.2.1 for clarifications on legacy interoperability.</t>
      <t>Modern implementations are expected to support strong algorithms such
   as SHA-256 or stronger for MIC calculations, and AES (128-bit or
   greater) for encryption. Implementations SHOULD also support advanced
   AES modes such as AES-GCM and AES-CCM for improved efficiency and
   authenticated encryption. See <xref target="RFC8551"/> for details.</t>
      <t>Implementations must ensure robust handling of all cryptographic
   failures. Administrators are encouraged to monitor IETF and NIST
   publications for algorithm lifecycle updates and to update deployed
   systems accordingly. These compatibility allowances are described in
   more detail in Section 1.2 and Section 1.2.1.</t>
      <t>When processing certificates, failures such as expired, revoked, or
   untrusted certificates MUST result in immediate and noticeable error
   reporting. See <xref target="RFC3280"/> and <xref target="RFC8551"/> for guidance on certificate
   path validation. For guidance on certificate management, key exchange,
   and renewal, including use of Certificate Exchange Messaging (CEM) and
   AS2 GET, see <xref target="public-key-certificate-handling"/> and <xref target="certificate-exchange-and-renewal"/>.</t>
      <section anchor="https-tls-reqs">
        <name>HTTPS and TLS Requirements</name>
        <t><strong>Consensus Update:</strong>
   Implementations <strong>MUST</strong> support TLS 1.2 or higher and <strong>SHOULD</strong> support TLS 1.3.
   TLS 1.3 is strongly encouraged as the default where platform support allows, but TLS 1.2
   remains the mandatory baseline to ensure interoperability with older environments (e.g., legacy JVMs).
   Products SHOULD allow administrators to configure which TLS versions are enabled, so that TLS 1.3 can be
   mandated by policy where required. Future revisions of this specification are expected to mandate TLS 1.3
   as the minimum required version once deployment is widespread.</t>
        <t>Administrators SHOULD use only cipher suites listed as “Recommended (Y)” in the
   <eref target="https://www.iana.org/assignments/tls-parameters">IANA TLS Parameters</eref> registry.
   Implementations SHOULD provide configurable cipher selection rather than hardcoding cipher lists.</t>
        <t>New implementations of AS2 <strong>SHOULD</strong> use HTTPS as the default transport
   protocol to provide confidentiality and integrity in transit. Plain HTTP
   remains permitted to support message-level encryption and backward
   compatibility with existing deployments.</t>
        <t>This guidance promotes strong encryption, aligns with current best practices,
   and ensures that AS2 remains interoperable with existing deployments while
   allowing administrators to phase out weaker protocols and cipher suites over time.</t>
        <t><strong>Future Considerations</strong>
   Per BCP 195/RFC 7525bis, new IETF protocols and major revisions are expected to mandate TLS 1.3.
   AS2-bis is a backward-compatible revision, and therefore specifies MUST support of TLS 1.2 and SHOULD
   support of TLS 1.3 to preserve interoperability with existing implementations. At the same time, implementers
   are strongly encouraged to deploy TLS 1.3 as the default for all new products and configurations.
   Future versions of AS2 (for example, a potential AS2-Version 1.3 or subsequent update) are expected to raise
   the baseline to MUST support TLS 1.3 or higher, and may deprecate TLS 1.2 once widespread deployment
   makes this feasible. Implementers are encouraged to prepare for a future revision of this specification
   that will mandate TLS 1.3 as the minimum required version.</t>
      </section>
      <section anchor="tls-server-certificates">
        <name>TLS Server Certificates</name>
        <t>The following certificate types MUST be supported for TLS server
   certificates:</t>
        <artwork><![CDATA[
  o  with URL in the Distinguished Name Common Name attribute

  o  without URL in the Distinguished Name Common Name attribute

  o  self-signed (self-issued)

  o  issued by a certification authority (CA)
]]></artwork>
        <t>The URL, which matches the source server identity, SHOULD be carried
   in the certificate. However, it is not required that DNS checks or
   reverse lookups to vouch for the accuracy of the URL or server value.</t>
        <t>The complete certification chain MUST be included in all
   certificates.  All certificate verifications MUST "chain to root" or
   to an accepted trust anchor. Additionally, the certificate hash
   SHOULD match the hash recomputed by the receiver.</t>
        <t>Because server certificates are exchanged, and also trust is
   established during the configuration of the trading partner
   relationship, runtime validation (including hostname matching and
   certificate path validation) SHOULD be performed unless an out-of-band
   trust model has been explicitly agreed upon by trading partners.
   If a self-signed TLS certificate is used, it SHOULD contain a Subject Alternative Name (SAN)
   extension that includes the DNS name and/or IP address of the sender.
   If included, this certificate extension MUST be marked as non-critical.</t>
        <t><strong>Note:</strong> Although not restricted by this specification, self-signed TLS certificates should
   be used with great care, especially in production environments.</t>
      </section>
      <section anchor="nrr-cautions">
        <name>NRR Cautions</name>
        <t>This specification seeks to provide multiple mechanisms that can be
   combined in accordance with local policies to achieve a wide range of
   security needs as determined by threat and risk analyses of the
   business peers. It is required that all these mechanisms be
   implemented by AS2 software so that the software has capabilities
   that promote strong interoperability, no matter what policies are
   adopted.</t>
        <t>One strong cluster of mechanisms (the secure transmission loop) can
   provide good support for meeting the evidentiary needs of non-
   repudiation of receipt by the original sender and by a third party
   supplied with all stated evidence. However, this specification does
   not itself define non-repudiation of receipt nor enumerate its
   essential properties because NRR is a business analysis and/or legal
   requirement, and not relevantly defined by a technical applicability
   statement.</t>
        <t>Some analyses observe that non-repudiation of receipt presupposes
   that non-repudiation of the sender of the original message is
   obtained, and further that non-repudiation should be implemented by
   means of digital signature on the original message. To satisfy
   strict NRR evidence, authentication and integrity MUST be provided by
   some mechanism, and the RECOMMENDED mechanism is digital signatures
   on both the original message and the receipt message.</t>
        <t>Given that this specification has selected several mechanisms that
   can be combined in several ways, it is important to realize that if a
   digital signature is omitted from the original message, in order to
   satisfy the preceding analysis of NRR requirements, some
   authentication mechanism MUST accompany the request for a signed
   receipt and its included Received-content-MIC value. This
   authentication might come from using client-side SSL, authentication
   via IPsec, or HTTP authentication (while using SSL). In any case,
   records of the message content, its security basis, and the digest
   value need to be retained for the NRR process.</t>
        <t>Therefore, if NRR is one of the goals of the policy that is adopted,
   by using the mechanisms of the secure transmission loop mentioned
   above and by retaining appropriate records of authentication at the
   original message sender site, strong evidentiary requirements
   proposed for NRR can be fulfilled.</t>
        <t>Other ways of proceeding may fall short of fulfilling the most
   stringent sets of evidence required for NRR to obtain, but may
   nevertheless be part of a commercial trading agreement and, as such,
   are good enough for the parties involved. However, if MDNs are
   returned unsigned, evidentiary requirements for NRR are weak; some
   authentication of the identity of the receiver is needed.</t>
        <t>If TLS is used for transport, the guidance in <xref target="https-tls-reqs"/> applies.</t>
      </section>
      <section anchor="replay-remark">
        <name>Replay Remark</name>
        <t>Because business data documents normally contain transaction ids,
   replays (such as resends of not-yet-acknowledged messages) are
   discarded as part of the normal process of duplicate detection.
   Detection of duplicates by Message-Id or by business transaction
   identifiers is recommended.</t>
      </section>
    </section>
    <section anchor="iana-considerations">
      <name>IANA Considerations</name>
      <t>IANA is requested to update the following registries:</t>
      <artwork><![CDATA[
     o  MDN Disposition Modifier Names
        https://www.iana.org/assignments/mdn/mdn.xhtml#disposition-modifier

     o  Message Disposition Notification Parameters
        https://www.iana.org/assignments/mdn/mdn.xhtml#parameters
]]></artwork>
      <section anchor="registration">
        <name>Registration</name>
        <t>RFC 4130 originally defined an extension to the Message Disposition Notification (MDN)
   protocol for a disposition-modifier in the Disposition field of a body of
   content-type "message/disposition-notification".</t>
        <t>This document updates that definition, and IANA is requested to replace RFC 4130 with this
   document as the reference for the MDN Disposition Modifier Names registry.</t>
        <section anchor="disposition-modifier-warning">
          <name>Disposition Modifier 'warning'</name>
          <sourcecode type="text"><![CDATA[
   Parameter-name:  warning
   Semantics: See (#as2-mdn-fields) and
   (#processing-warnings) in this document.
]]></sourcecode>
        </section>
      </section>
    </section>
    <section anchor="acknowledgments">
      <name>Acknowledgments</name>
      <t>Carl Hage, Karen Rosenfeld, Chuck Fenton, Russ Housley, Marc Blanchet,
   Erik Wrammer, and many others provided valuable suggestions during both
   the initial review of RFC 4130 that improved that applicability statement
   and this bis specification. The authors would also like to thank the past
   and current vendors who have participated in the Drummond AS2 interoperability
   testing. Their contributions have ultimately led to great improvement in the
   clarity of this document.</t>
    </section>
  </middle>
  <back>
    <references anchor="sec-combined-references">
      <name>References</name>
      <references anchor="sec-normative-references">
        <name>Normative References</name>
        <reference anchor="RFC4130">
          <front>
            <title>MIME-Based Secure Peer-to-Peer Business Data Interchange Using HTTP, Applicability Statement 2 (AS2)</title>
            <author fullname="D. Moberg" initials="D." surname="Moberg"/>
            <author fullname="R. Drummond" initials="R." surname="Drummond"/>
            <date month="July" year="2005"/>
            <abstract>
              <t>This document provides an applicability statement (RFC 2026, Section 3.2) that describes how to exchange structured business data securely using the HTTP transfer protocol, instead of SMTP; the applicability statement for SMTP is found in RFC 3335. Structured business data may be XML; Electronic Data Interchange (EDI) in either the American National Standards Committee (ANSI) X12 format or the UN Electronic Data Interchange for Administration, Commerce, and Transport (UN/EDIFACT) format; or other structured data formats. The data is packaged using standard MIME structures. Authentication and data confidentiality are obtained by using Cryptographic Message Syntax with S/MIME security body parts. Authenticated acknowledgements make use of multipart/signed Message Disposition Notification (MDN) responses to the original HTTP message. This applicability statement is informally referred to as "AS2" because it is the second applicability statement, produced after "AS1", RFC 3335. [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="4130"/>
          <seriesInfo name="DOI" value="10.17487/RFC4130"/>
        </reference>
        <reference anchor="RFC2045">
          <front>
            <title>Multipurpose Internet Mail Extensions (MIME) Part One: Format of Internet Message Bodies</title>
            <author fullname="N. Freed" initials="N." surname="Freed"/>
            <author fullname="N. Borenstein" initials="N." surname="Borenstein"/>
            <date month="November" year="1996"/>
            <abstract>
              <t>This initial document specifies the various headers used to describe the structure of MIME messages. [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="2045"/>
          <seriesInfo name="DOI" value="10.17487/RFC2045"/>
        </reference>
        <reference anchor="RFC2046">
          <front>
            <title>Multipurpose Internet Mail Extensions (MIME) Part Two: Media Types</title>
            <author fullname="N. Freed" initials="N." surname="Freed"/>
            <author fullname="N. Borenstein" initials="N." surname="Borenstein"/>
            <date month="November" year="1996"/>
            <abstract>
              <t>This second document defines the general structure of the MIME media typing system and defines an initial set of media types. [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="2046"/>
          <seriesInfo name="DOI" value="10.17487/RFC2046"/>
        </reference>
        <reference anchor="RFC2049">
          <front>
            <title>Multipurpose Internet Mail Extensions (MIME) Part Five: Conformance Criteria and Examples</title>
            <author fullname="N. Freed" initials="N." surname="Freed"/>
            <author fullname="N. Borenstein" initials="N." surname="Borenstein"/>
            <date month="November" year="1996"/>
            <abstract>
              <t>This set of documents, collectively called the Multipurpose Internet Mail Extensions, or MIME, redefines the format of messages. This fifth and final document describes MIME conformance criteria as well as providing some illustrative examples of MIME message formats, acknowledgements, and the bibliography. [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="2049"/>
          <seriesInfo name="DOI" value="10.17487/RFC2049"/>
        </reference>
        <reference anchor="RFC1767">
          <front>
            <title>MIME Encapsulation of EDI Objects</title>
            <author fullname="D. Crocker" initials="D." surname="Crocker"/>
            <date month="March" year="1995"/>
            <abstract>
              <t>Since there are many different EDI specifications, the current document defines three distinct categories as three different MIME content-types. [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="1767"/>
          <seriesInfo name="DOI" value="10.17487/RFC1767"/>
        </reference>
        <reference anchor="RFC2616">
          <front>
            <title>Hypertext Transfer Protocol -- HTTP/1.1</title>
            <author fullname="R. Fielding" initials="R." surname="Fielding"/>
            <author fullname="J. Gettys" initials="J." surname="Gettys"/>
            <author fullname="J. Mogul" initials="J." surname="Mogul"/>
            <author fullname="H. Frystyk" initials="H." surname="Frystyk"/>
            <author fullname="L. Masinter" initials="L." surname="Masinter"/>
            <author fullname="P. Leach" initials="P." surname="Leach"/>
            <author fullname="T. Berners-Lee" initials="T." surname="Berners-Lee"/>
            <date month="June" year="1999"/>
            <abstract>
              <t>HTTP has been in use by the World-Wide Web global information initiative since 1990. This specification defines the protocol referred to as "HTTP/1.1", and is an update to RFC 2068. [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="2616"/>
          <seriesInfo name="DOI" value="10.17487/RFC2616"/>
        </reference>
        <reference anchor="RFC3335">
          <front>
            <title>MIME-based Secure Peer-to-Peer Business Data Interchange over the Internet</title>
            <author fullname="T. Harding" initials="T." surname="Harding"/>
            <author fullname="R. Drummond" initials="R." surname="Drummond"/>
            <author fullname="C. Shih" initials="C." surname="Shih"/>
            <date month="September" year="2002"/>
          </front>
          <seriesInfo name="RFC" value="3335"/>
          <seriesInfo name="DOI" value="10.17487/RFC3335"/>
        </reference>
        <reference anchor="RFC3798">
          <front>
            <title>Message Disposition Notification</title>
            <author fullname="T. Hansen" initials="T." role="editor" surname="Hansen"/>
            <author fullname="G. Vaudreuil" initials="G." role="editor" surname="Vaudreuil"/>
            <date month="May" year="2004"/>
            <abstract>
              <t>This memo defines a MIME content-type that may be used by a mail user agent (MUA) or electronic mail gateway to report the disposition of a message after it has been successfully delivered to a recipient. This content-type is intended to be machine-processable. Additional message headers are also defined to permit Message Disposition Notifications (MDNs) to be requested by the sender of a message. The purpose is to extend Internet Mail to support functionality often found in other messaging systems, such as X.400 and the proprietary "LAN-based" systems, and often referred to as "read receipts," "acknowledgements", or "receipt notifications." The intention is to do this while respecting privacy concerns, which have often been expressed when such functions have been discussed in the past. Because many messages are sent between the Internet and other messaging systems (such as X.400 or the proprietary "LAN-based" systems), the MDN protocol is designed to be useful in a multi-protocol messaging environment. To this end, the protocol described in this memo provides for the carriage of "foreign" addresses, in addition to those normally used in Internet Mail. Additional attributes may also be defined to support "tunneling" of foreign notifications through Internet Mail. [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="3798"/>
          <seriesInfo name="DOI" value="10.17487/RFC3798"/>
        </reference>
        <reference anchor="RFC8098">
          <front>
            <title>Message Disposition Notification</title>
            <author fullname="T. Hansen" initials="T." role="editor" surname="Hansen"/>
            <author fullname="A. Melnikov" initials="A." role="editor" surname="Melnikov"/>
            <date month="February" year="2017"/>
            <abstract>
              <t>This memo defines a MIME content type that may be used by a Mail User Agent (MUA) or electronic mail gateway to report the disposition of a message after it has been successfully delivered to a recipient. This content type is intended to be machine processable. Additional message header fields are also defined to permit Message Disposition Notifications (MDNs) to be requested by the sender of a message. The purpose is to extend Internet Mail to support functionality often found in other messaging systems, such as X.400 and the proprietary "LAN-based" systems, and are often referred to as "read receipts," "acknowledgements," or "receipt notifications." The intention is to do this while respecting privacy concerns, which have often been expressed when such functions have been discussed in the past.</t>
              <t>Because many messages are sent between the Internet and other messaging systems (such as X.400 or the proprietary "LAN-based" systems), the MDN protocol is designed to be useful in a multiprotocol messaging environment. To this end, the protocol described in this memo provides for the carriage of "foreign" addresses, in addition to those normally used in Internet Mail. Additional attributes may also be defined to support "tunneling" of foreign notifications through Internet Mail.</t>
              <t>This document is an Internet Standard. It obsoletes RFC 3798 and updates RFC 2046 (message/partial media type handling) and RFC 3461 (Original-Recipient header field generation requirement).</t>
            </abstract>
          </front>
          <seriesInfo name="STD" value="85"/>
          <seriesInfo name="RFC" value="8098"/>
          <seriesInfo name="DOI" value="10.17487/RFC8098"/>
        </reference>
        <reference anchor="RFC1847">
          <front>
            <title>Security Multiparts for MIME: Multipart/Signed and Multipart/Encrypted</title>
            <author fullname="J. Galvin" initials="J." surname="Galvin"/>
            <author fullname="S. Murphy" initials="S." surname="Murphy"/>
            <author fullname="S. Crocker" initials="S." surname="Crocker"/>
            <author fullname="N. Freed" initials="N." surname="Freed"/>
            <date month="October" year="1995"/>
            <abstract>
              <t>This document defines a framework within which security services may be applied to MIME body parts. [STANDARDS-TRACK] This memo defines a new Simple Mail Transfer Protocol (SMTP) [1] reply code, 521, which one may use to indicate that an Internet host does not accept incoming mail. This memo defines an Experimental Protocol for the Internet community. This memo defines an extension to the SMTP service whereby an interrupted SMTP transaction can be restarted at a later time without having to repeat all of the commands and message content sent prior to the interruption. This memo defines an Experimental Protocol for the Internet community.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="1847"/>
          <seriesInfo name="DOI" value="10.17487/RFC1847"/>
        </reference>
        <reference anchor="RFC5751">
          <front>
            <title>Secure/Multipurpose Internet Mail Extensions (S/MIME) Version 3.2 Message Specification</title>
            <author fullname="B. Ramsdell" initials="B." surname="Ramsdell"/>
            <author fullname="S. Turner" initials="S." surname="Turner"/>
            <date month="January" year="2010"/>
            <abstract>
              <t>This document defines Secure/Multipurpose Internet Mail Extensions (S/MIME) version 3.2. S/MIME provides a consistent way to send and receive secure MIME data. Digital signatures provide authentication, message integrity, and non-repudiation with proof of origin. Encryption provides data confidentiality. Compression can be used to reduce data size. This document obsoletes RFC 3851. [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="5751"/>
          <seriesInfo name="DOI" value="10.17487/RFC5751"/>
        </reference>
        <reference anchor="RFC5652">
          <front>
            <title>Cryptographic Message Syntax (CMS)</title>
            <author fullname="R. Housley" initials="R." surname="Housley"/>
            <date month="September" year="2009"/>
            <abstract>
              <t>This document describes the Cryptographic Message Syntax (CMS). This syntax is used to digitally sign, digest, authenticate, or encrypt arbitrary message content. [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="STD" value="70"/>
          <seriesInfo name="RFC" value="5652"/>
          <seriesInfo name="DOI" value="10.17487/RFC5652"/>
        </reference>
        <reference anchor="RFC3462">
          <front>
            <title>The Multipart/Report Content Type for the Reporting of Mail System Administrative Messages</title>
            <author fullname="G. Vaudreuil" initials="G." surname="Vaudreuil"/>
            <date month="January" year="2003"/>
            <abstract>
              <t>The Multipart/Report Multipurpose Internet Mail Extensions (MIME) content-type is a general "family" or "container" type for electronic mail reports of any kind. Although this memo defines only the use of the Multipart/Report content-type with respect to delivery status reports, mail processing programs will benefit if a single content-type is used to for all kinds of reports. This document is part of a four document set describing the delivery status report service. This collection includes the Simple Mail Transfer Protocol (SMTP) extensions to request delivery status reports, a MIME content for the reporting of delivery reports, an enumeration of extended status codes, and a multipart container for the delivery report, the original message, and a human-friendly summary of the failure. [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="3462"/>
          <seriesInfo name="DOI" value="10.17487/RFC3462"/>
        </reference>
        <reference anchor="RFC3023">
          <front>
            <title>XML Media Types</title>
            <author fullname="M. Murata" initials="M." surname="Murata"/>
            <author fullname="S. St. Laurent" initials="S." surname="St. Laurent"/>
            <author fullname="D. Kohn" initials="D." surname="Kohn"/>
            <date month="January" year="2001"/>
            <abstract>
              <t>This document standardizes five new media types -- text/xml, application/xml, text/xml-external-parsed-entity, application/xml- external-parsed-entity, and application/xml-dtd -- for use in exchanging network entities that are related to the Extensible Markup Language (XML). This document also standardizes a convention (using the suffix '+xml') for naming media types outside of these five types when those media types represent XML MIME (Multipurpose Internet Mail Extensions) entities. [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="3023"/>
          <seriesInfo name="DOI" value="10.17487/RFC3023"/>
        </reference>
        <reference anchor="RFC2026">
          <front>
            <title>The Internet Standards Process -- Revision 3</title>
            <author fullname="S. Bradner" initials="S." surname="Bradner"/>
            <date month="October" year="1996"/>
            <abstract>
              <t>This memo documents the process used by the Internet community for the standardization of protocols and procedures. It defines the stages in the standardization process, the requirements for moving a document between stages and the types of documents used during this process. 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="9"/>
          <seriesInfo name="RFC" value="2026"/>
          <seriesInfo name="DOI" value="10.17487/RFC2026"/>
        </reference>
        <reference anchor="RFC3850">
          <front>
            <title>Secure/Multipurpose Internet Mail Extensions (S/MIME) Version 3.1 Certificate Handling</title>
            <author fullname="B. Ramsdell" initials="B." role="editor" surname="Ramsdell"/>
            <date month="July" year="2004"/>
            <abstract>
              <t>This document specifies conventions for X.509 certificate usage by Secure/Multipurpose Internet Mail Extensions (S/MIME) agents. S/MIME provides a method to send and receive secure MIME messages, and certificates are an integral part of S/MIME agent processing. S/MIME agents validate certificates as described in RFC 3280, the Internet X.509 Public Key Infrastructure Certificate and CRL Profile. S/MIME agents must meet the certificate processing requirements in this document as well as those in RFC 3280. [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="3850"/>
          <seriesInfo name="DOI" value="10.17487/RFC3850"/>
        </reference>
        <reference anchor="RFC2234">
          <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="November" year="1997"/>
            <abstract>
              <t>In the early days of the Arpanet, each specification contained its own definition of ABNF. This included the email specifications, RFC733 and then RFC822 which have come to be the common citations for defining ABNF. The current document separates out that definition, to permit selective reference. Predictably, it also provides some modifications and enhancements. [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="2234"/>
          <seriesInfo name="DOI" value="10.17487/RFC2234"/>
        </reference>
        <reference anchor="RFC2119">
          <front>
            <title>Key words for use in RFCs to Indicate Requirement Levels</title>
            <author fullname="S. Bradner" initials="S." surname="Bradner"/>
            <date month="March" year="1997"/>
            <abstract>
              <t>In many standards track documents several words are used to signify the requirements in the specification. These words are often capitalized. This document defines these words as they should be interpreted in IETF documents. This document specifies an Internet Best Current Practices for the Internet Community, and requests discussion and suggestions for improvements.</t>
            </abstract>
          </front>
          <seriesInfo name="BCP" value="14"/>
          <seriesInfo name="RFC" value="2119"/>
          <seriesInfo name="DOI" value="10.17487/RFC2119"/>
        </reference>
        <reference anchor="RFC8174">
          <front>
            <title>Ambiguity of Uppercase vs Lowercase in RFC 2119 Key Words</title>
            <author fullname="B. Leiba" initials="B." surname="Leiba"/>
            <date month="May" year="2017"/>
            <abstract>
              <t>RFC 2119 specifies common key words that may be used in protocol specifications. This document aims to reduce the ambiguity by clarifying that only UPPERCASE usage of the key words have the defined special meanings.</t>
            </abstract>
          </front>
          <seriesInfo name="BCP" value="14"/>
          <seriesInfo name="RFC" value="8174"/>
          <seriesInfo name="DOI" value="10.17487/RFC8174"/>
        </reference>
        <reference anchor="RFC3274">
          <front>
            <title>Compressed Data Content Type for Cryptographic Message Syntax (CMS)</title>
            <author fullname="P. Gutmann" initials="P." surname="Gutmann"/>
            <date month="June" year="2002"/>
            <abstract>
              <t>This document defines a format for using compressed data as a Cryptographic Message Syntax (CMS) content type. Compressing data before transmission provides a number of advantages, including the elimination of data redundancy which could help an attacker, speeding up processing by reducing the amount of data to be processed by later steps (such as signing or encryption), and reducing overall message size. Although there have been proposals for adding compression at other levels (for example at the MIME or SSL level), these don't address the problem of compression of CMS content unless the compression is supplied by an external means (for example by intermixing MIME and CMS). [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="3274"/>
          <seriesInfo name="DOI" value="10.17487/RFC3274"/>
        </reference>
        <reference anchor="RFC3280">
          <front>
            <title>Internet X.509 Public Key Infrastructure Certificate and Certificate Revocation List (CRL) Profile</title>
            <author fullname="R. Housley" initials="R." surname="Housley"/>
            <author fullname="W. Polk" initials="W." surname="Polk"/>
            <author fullname="W. Ford" initials="W." surname="Ford"/>
            <author fullname="D. Solo" initials="D." surname="Solo"/>
            <date month="April" year="2002"/>
            <abstract>
              <t>This memo profiles the X.509 v3 certificate and X.509 v2 Certificate Revocation List (CRL) for use in the Internet. [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="3280"/>
          <seriesInfo name="DOI" value="10.17487/RFC3280"/>
        </reference>
        <reference anchor="RFC8551">
          <front>
            <title>Secure/Multipurpose Internet Mail Extensions (S/MIME) Version 4.0 Message Specification</title>
            <author fullname="J. Schaad" initials="J." surname="Schaad"/>
            <author fullname="B. Ramsdell" initials="B." surname="Ramsdell"/>
            <author fullname="S. Turner" initials="S." surname="Turner"/>
            <date month="April" year="2019"/>
            <abstract>
              <t>This document defines Secure/Multipurpose Internet Mail Extensions (S/MIME) version 4.0. S/MIME provides a consistent way to send and receive secure MIME data. Digital signatures provide authentication, message integrity, and non-repudiation with proof of origin. Encryption provides data confidentiality. Compression can be used to reduce data size. This document obsoletes RFC 5751.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="8551"/>
          <seriesInfo name="DOI" value="10.17487/RFC8551"/>
        </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="RFC6017">
          <front>
            <title>Electronic Data Interchange - Internet Integration (EDIINT) Features Header Field</title>
            <author fullname="K. Meadors" initials="K." role="editor" surname="Meadors"/>
            <date month="September" year="2010"/>
            <abstract>
              <t>With the maturity of the Electronic Data Interchange - Internet Integration (EDIINT) standards of AS1, AS2, and AS3, applications and additional features are being built upon the basic secure transport functionality. These features are not necessarily supported by all EDIINT applications and could cause potential problems with implementations. The EDIINT-Features header field provides a means to resolve these problems and support new functionality. This document is not an Internet Standards Track specification; it is published for informational purposes.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="6017"/>
          <seriesInfo name="DOI" value="10.17487/RFC6017"/>
        </reference>
      </references>
      <references anchor="sec-informative-references">
        <name>Informative References</name>
        <reference anchor="RFC2246">
          <front>
            <title>The TLS Protocol Version 1.0</title>
            <author fullname="T. Dierks" initials="T." surname="Dierks"/>
            <author fullname="C. Allen" initials="C." surname="Allen"/>
            <date month="January" year="1999"/>
            <abstract>
              <t>This document specifies Version 1.0 of the Transport Layer Security (TLS) protocol. The TLS protocol provides communications privacy over the Internet. The protocol allows client/server applications to communicate in a way that is designed to prevent eavesdropping, tampering, or message forgery.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="2246"/>
          <seriesInfo name="DOI" value="10.17487/RFC2246"/>
        </reference>
        <reference anchor="RFC4918">
          <front>
            <title>HTTP Extensions for Web Distributed Authoring and Versioning (WebDAV)</title>
            <author fullname="L. Dusseault" initials="L." role="editor" surname="Dusseault"/>
            <date month="June" year="2007"/>
            <abstract>
              <t>Web Distributed Authoring and Versioning (WebDAV) consists of a set of methods, headers, and content-types ancillary to HTTP/1.1 for the management of resource properties, creation and management of resource collections, URL namespace manipulation, and resource locking (collision avoidance).</t>
              <t>RFC 2518 was published in February 1999, and this specification obsoletes RFC 2518 with minor revisions mostly due to interoperability experience. [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="4918"/>
          <seriesInfo name="DOI" value="10.17487/RFC4918"/>
        </reference>
        <reference anchor="RFC5753">
          <front>
            <title>Use of Elliptic Curve Cryptography (ECC) Algorithms in Cryptographic Message Syntax (CMS)</title>
            <author fullname="S. Turner" initials="S." surname="Turner"/>
            <author fullname="D. Brown" initials="D." surname="Brown"/>
            <date month="January" year="2010"/>
            <abstract>
              <t>This document describes how to use Elliptic Curve Cryptography (ECC) public key algorithms in the Cryptographic Message Syntax (CMS). The ECC algorithms support the creation of digital signatures and the exchange of keys to encrypt or authenticate content. The definition of the algorithm processing is based on the NIST FIPS 186-3 for digital signature, NIST SP800-56A and SEC1 for key agreement, RFC 3370 and RFC 3565 for key wrap and content encryption, NIST FIPS 180-3 for message digest, SEC1 for key derivation, and RFC 2104 and RFC 4231 for message authentication code standards. This document obsoletes RFC 3278. This document is not an Internet Standards Track specification; it is published for informational purposes.</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="5753"/>
          <seriesInfo name="DOI" value="10.17487/RFC5753"/>
        </reference>
        <reference anchor="I-D.draft-duker-as2-reliability-16">
          <front>
            <title>Operational Reliability for EDIINT AS2</title>
            <author fullname="John Duker" initials="J." surname="Duker">
              <organization>Procter &amp; Gamble</organization>
            </author>
            <author fullname="dale.moberg@gmail.com" initials="" surname="dale.moberg@gmail.com">
              <organization>Orion Health</organization>
            </author>
            <date day="21" month="October" year="2014"/>
            <abstract>
              <t>One goal of this document is to define approaches to achieve a "once
and only once" delivery of messages. The EDIINT AS2 protocol is
implemented by a number of software tools on a variety of platforms
with varying capabilities and with varying network service quality.
Although the AS2 protocol defines a unique "Message-ID", current
implementations of AS2 do not provide a standard method to prevent
the same message (re-transmitted by the initial sender) from reaching
back-end business applications at the initial receiver.

A second goal is to reduce retransmissions and failures when AS2 is used
in a synchronous mode for transmitting MDNs.  There can be a large
latency between receipt of the POSTed entity body and the MDN response
caused by the operations of decompressing, decrypting, and signature
checks. Uncoordinated timeout policies and intermediate devices dropping
connections have interfered with reliable data exchange. The use of an
HTTP 102(Processing) status code is described to mitigate these
difficulties. Use of these reliability features is indicated by
presence of the "AS2-Reliability" value in the EDIINT-Features header.

Intended Status

The intent of this document is to be placed on the RFC track as an
Informational RFC.

Feedback Instructions:
NOTE TO RFC EDITOR:  This section should be removed by the RFC editor
prior to publication.

If you want to provide feedback on this draft, follow these
guidelines:

-Send feedback via e-mail to the ietf-ediint list for discussion,
with "AS2 Reliability" in the Subject field. To enter or follow the
discussion, you need to subscribe to ietf-ediint@imc.org.

-Be specific as to what section you are referring to, preferably
quoting the portion that needs modification, after which you state
your comments.

-If you are recommending some text to be replaced with your suggested
text, again, quote the section to be replaced, and be clear on the
section in question.

              </t>
            </abstract>
          </front>
          <seriesInfo name="Internet-Draft" value="draft-duker-as2-reliability-16"/>
        </reference>
        <reference anchor="I-D.draft-harding-as2-restart-02">
          <front>
            <title>AS2 Restart for Very Large Messages</title>
            <author fullname="Terry Harding" initials="T." surname="Harding">
         </author>
            <date day="26" month="January" year="2011"/>
            <abstract>
              <t>AS2 Restart provides a method for AS2 clients and servers to restart
payload transfers from the point of failure without requiring the
entire document to be resent.

Keywords

The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT",
"SHOULD", "SHOULD NOT", "RECOMMENDED", "MAY", and "OPTIONAL" in this
document are to be interpreted as described in RFC 2119.
              </t>
            </abstract>
          </front>
          <seriesInfo name="Internet-Draft" value="draft-harding-as2-restart-02"/>
        </reference>
        <reference anchor="I-D.draft-meadors-certificate-exchange-14">
          <front>
            <title>Certificate Exchange Messaging for EDIINT draft-meadors-certificate-exchange-14.txt Abstract</title>
            <author fullname="Kyle Meadors" initials="K." surname="Meadors">
              <organization>Drummond Group Inc.</organization>
            </author>
            <author fullname="Dale Moberg" initials="D." surname="Moberg">
              <organization>Axway, Inc.</organization>
            </author>
            <date day="22" month="December" year="2011"/>
            <abstract>
              <t>   The EDIINT AS1, AS2 and AS3 message formats do not currently contain
   any neutral provisions for transporting and exchanging trading
   partner profiles or digital certificates. EDIINT Certificate Exchange
   Messaging provides the format and means to effectively exchange
   certificates for use within trading partner relationships. The
   messaging consists of two types of messages, Request and Response,
   which allow trading partners to communicate certificates, their
   intended usage and their acceptance through XML. Certificates can be
   specified for use in digital signatures, data encryption or SSL/TLS
   over HTTP (HTTPS).

              </t>
            </abstract>
          </front>
          <seriesInfo name="Internet-Draft" value="draft-meadors-certificate-exchange-14"/>
        </reference>
      </references>
    </references>
    <?line 2550?>

<section anchor="message-examples">
      <name>Message Examples</name>
      <t>Note to Readers: All examples are provided for illustration only, and are not
   part of the protocol specification. If an example conflicts with the
   protocol definitions, the example is wrong. Email addresses in the
   examples (e.g., in the <tt>Disposition-Notification-To</tt> field) reflect
   one valid option but are not required. In AS2, this field may also
   contain a URL, a fully qualified host name, an AS2 identifier, or
   another implementation-specific string, as described in <xref target="structure-and-processing-of-an-mdn-message"/>.3.</t>
      <section anchor="signed-message-requesting-a-signed-synchronous-receipt">
        <name>Signed Message Requesting a Signed, Synchronous Receipt</name>
        <sourcecode type="text"><![CDATA[
   POST /receive HTTP/1.1
   Host: 10.234.160.12:80
   User-Agent: AS2 Company Server
   Date: Wed, 31 Jul 2025 13:34:50 GMT
   AS2-Version: 1.3
   AS2-From: "as2 Name"
   AS2-To: 0123456780000
   Subject: Test Case
   Message-Id: <200207310834482A70BF63@\"~~foo~~\">
   Disposition-Notification-To: mrAS2@example.com
   Disposition-Notification-Options: signed-receipt-protocol=optional,
        pkcs7-signature; signed-receipt-micalg=optional,sha-256
   Content-Type: multipart/signed; boundary="as2BouNdary1as2";
        protocol="application/pkcs7-signature"; micalg=sha-256
   Content-Length: 2464

   --as2BouNdary1as2
   Content-Type: application/edi-x12
   Content-Disposition: attachment; filename=rfc1767.dat

     {ISA ...EDI transaction data...IEA...}

   --as2BouNdary1as2
   Content-Type: application/pkcs7-signature

     {omitted binary pkcs7 signature data}

   --as2BouNdary1as2--
]]></sourcecode>
      </section>
      <section anchor="mdn-for-message-in-a1-above">
        <name>MDN for Message in A.1, Above</name>
        <sourcecode type="text"><![CDATA[
   HTTP/1.1 200 OK
   AS2-From: 0123456780000
   AS2-To: "as2 Name"
   AS2-Version: 1.3
   Message-ID: <709700825.1028122454671.JavaMail@ediXchange>
   Content-Type: multipart/signed; micalg=sha-256;
        protocol="application/pkcs7-signature";
        boundary="----=_Part_57_648441049.1028122454671"
   Connection: Close
   Content-Length: 1980

   ------=_Part_57_648441049.1028122454671

   & Content-Type: multipart/report;
   &    report-type=disposition-notification;
   &    boundary="----=_Part_56_1672293592.1028122454656"
   &
   &------=_Part_56_1672293592.1028122454656
   &Content-Type: text/plain
   &Content-Transfer-Encoding: 7bit
   &
   &MDN for -
   & Message ID: <200207310834482A70BF63@\"~~foo~~\">
   &  From: "as2 Name"
   &  To: 0123456780000
   &  Received on: 2025-07-31 at 09:34:14 (EDT)
   & Status: processed
   & Comment: This is not a guarantee that the message has
   &  been completely processed or &understood by the receiving
   &  translator
   &
   &------=_Part_56_1672293592.1028122454656
   &Content-Type: message/disposition-notification
   &Content-Transfer-Encoding: 7bit
   &
   &Reporting-UA: AS2 Server
   &Original-Recipient: rfc822; 0123456780000
   &Final-Recipient: rfc822; 0123456780000
   &Original-Message-ID: <200207310834482A70BF63@\"~~foo~~\">
   &Received-content-MIC: 43d9tGY3gNSGuFaut4PAGvuc+48VgW6USgXLDPTxsBU=, sha-256
   &Disposition: automatic-action/MDN-sent-automatically; processed
   &
   &------=_Part_56_1672293592.1028122454656--

   ------=_Part_57_648441049.1028122454671
   Content-Type: application/pkcs7-signature; name=smime.p7s
   Content-Transfer-Encoding: base64
   Content-Disposition: attachment; filename=smime.p7s

   MIAGCSqGSIb3DQEHAqCAMIACAQExCzAJBgUrDgMCGgUAMIAGCSqGSIb3DQ
   cp24hMJNbxDKHnlB9jTiQzLwSwo+/90Pc87x+Sc6EpFSUYWGAAAAAAAA
   ------=_Part_57_648441049.1028122454671--

   Notes:

   1. The lines proceeded with "&" are what the signature is calculated
      over.

   2. For details on how to prepare the multipart/signed with protocol =
      "application/pkcs7-signature", see the "S/MIME Message
      Specification, PKCS Security Services for MIME".

   3. Note that the textual first body part of the multipart/report can
      be used to include a more detailed explanation of the error
      conditions reported by the disposition headers. The first body
      part of the multipart/report, when used in this way, allows a
      person to better diagnose a problem in detail.

   4. As specified by RFC 3462 [RFC3462], returning the original or portions
      of the original message in the third body part of the
      multipart/report is not required.  This is an optional body part.
      However, it is RECOMMENDED that this body part be omitted or left
      blank.
]]></sourcecode>
      </section>
      <section anchor="signed-encrypted-message-requesting-a-signed-asynchronous-receipt">
        <name>Signed, Encrypted Message Requesting a Signed, Asynchronous Receipt</name>
        <sourcecode type="text"><![CDATA[
   POST /trading_partner HTTP/1.1
   Host: 10.240.1.2:58101
   User-Agent: AS2 Company Server
   Message-ID: <#as2_company#01#a4260as2_companyout#>
   Date: Thu, 19 Dec 2024 15:04:18 GMT
   Subject: Signed and encrypted message with async MDN request
   Mime-Version: 1.0
   Content-Type: application/pkcs7-mime;
       smime-type=enveloped-data; name=smime.p7m
   Content-Transfer-Encoding: binary
   Content-Disposition: attachment; filename=smime.p7m
   Recipient-Address: 10.240.1.2//
   Disposition-Notification-To: http://10.240.1.2:58201/exchange/as2_company
   Disposition-Notification-Options: signed-receipt-protocol=optional,
        pkcs7-signature; signed-receipt-micalg=optional,sha-256
   Receipt-Delivery-Option: http://10.240.1.2:58201/exchange/as2_company
   AS2-From: as2_company
   AS2-To: "AS2 Test"
   AS2-Version: 1.3
   Connection: close
   Content-Length: 3428

     {omitted binary encrypted data}
]]></sourcecode>
      </section>
      <section anchor="asynchronous-mdn-for-message-in-a3-above">
        <name>Asynchronous MDN for Message in A.3, Above</name>
        <sourcecode type="text"><![CDATA[
   POST / HTTP/1.1
   Host: 10.234.160.12:80
   Connection: close, TE
   TE: trailers, deflate, gzip, compress
   User-Agent: AS2 Company Server
   Date: Thu, 19 Dec 2024 15:05:38 GMT
   Message-ID: <AS2-20021219_030338@as2_company.dgi_th>
   AS2-Version: 1.3
   Mime-Version: 1.0
   Recipient-Address: http://10.240.1.2:58201/exchange/as2_company
   AS2-To: as2_company
   AS2-From: "AS2 Test"
   Subject: Your Requested MDN Response
   From: as2debug@example.com
   Accept-Encoding: deflate, gzip, x-gzip, compress, x-compress
   Content-Type: multipart/signed; micalg=sha-256;
        protocol="application/pkcs7-signature";
        boundary="----=_Part_337_6452266.1040310218750"
   Content-Length: 3103

   ------=_Part_337_6452266.1040310218750
   Content-Type: multipart/report;
        report-type=disposition-notification;
        boundary="----=_Part_336_6069110.1040310218718"

   ------=_Part_336_6069110.1040310218718
   Content-Type: text/plain; charset=us-ascii
   Content-Transfer-Encoding: 7bit

   The message <x12.edi> sent to Recipient <AS2 Test> on Thu, 19 Dec
   2024 15:04:18 GMT with Subject <Signed and encrypted message with async
   MDN request> has been received. The EDI Interchange was successfully
   decrypted, and its integrity was verified. In addition, the sender of
   the message, Sender <as2_company> at Location http://10.240.1.2:58201/exchange/as2_company
   was authenticated as the originator of the message. There is no
   guarantee, however, that the EDI interchange was syntactically
   correct, or that it was received by the EDI application/translator.

   ------=_Part_336_6069110.1040310218718
   Content-Type: message/disposition-notification
   Content-Transfer-Encoding: 7bit

   Reporting-UA: AS2@test:8101
   Original-Recipient: rfc822; "AS2 Test"
   Final-Recipient: rfc822; "AS2 Test"
   Original-Message-ID: <#as2_company#01#a4260as2_companyout#>
   Disposition: automatic-action/MDN-sent-automatically; processed
   Received-Content-MIC: Hes6my+vIxIYxmvsA+MNpEOTPAc=, sha1

   ------=_Part_336_6069110.1040310218718--

   ------=_Part_337_6452266.1040310218750
   Content-Type: application/pkcs7-signature; name=smime.p7s
   Content-Transfer-Encoding: base64
   Content-Disposition: attachment; filename=smime.p7s

   BhbWjEfbyXoTAS/H0zpnEqLqbaBh29y2v82b8bdeGw8pipBQWmf53hIcqHGM
   4ZBF3CHw5Wrf1JIE+8TwOzdbal30zeChw88WfRfD7c/j1fIA8sxsujvf2d9j
   UxCUga8BVdVB9kH0Geexytyt0KvWQXfaEEcgZGUAAAAAAAA=

   ------=_Part_337_6452266.1040310218750-
]]></sourcecode>
      </section>
    </section>
    <section anchor="change-log-non-normative">
      <name>Change Log (Non-Normative)</name>
      <t>This appendix records the substantive changes made during the revision
from the original RFC 4130 draft toward the current version of this document.</t>
      <section anchor="general">
        <name>General</name>
        <ul spacing="normal">
          <li>
            <t>Removed all references to AS1/SMTP throughout the draft.</t>
          </li>
          <li>
            <t>Included descriptions and references for compressed content, which was previously supported since AS2 version 1.1.</t>
          </li>
          <li>
            <t>This draft explicitly allows negotiation of newer RFCs while retaining legacy support, where necessary.</t>
          </li>
          <li>
            <t>Updated formatting and cross-references so that all internal "Section X.Y"
references are properly linked in HTML and XML output.</t>
          </li>
          <li>
            <t>Moved legacy interoperability clarifications to Section 1.2.1
to avoid confusion with normative text.</t>
          </li>
          <li>
            <t>Clarified that appendices are non-normative unless otherwise indicated.</t>
          </li>
          <li>
            <t>Replaced all references to RFC 3851 with RFC 5751.</t>
          </li>
          <li>
            <t>Replaced all references to RFC 3852 with RFC 5652.</t>
          </li>
        </ul>
      </section>
      <section anchor="changes-affecting-section-12-backward-compatibility-and-interoperability">
        <name>Changes affecting Section 1.2 - Backward Compatibility and Interoperability</name>
        <ul spacing="normal">
          <li>
            <t>Expanded to explicitly state the dual-reference policy:
            </t>
            <ul spacing="normal">
              <li>
                <t>Implementations MAY interoperate with S/MIME v3.2 (RFC 5751, which
obsoletes RFC 3851/3852).</t>
              </li>
              <li>
                <t>Conformant implementations MUST also support S/MIME v4.0 (RFC 8551,
which obsoletes RFC 5751).</t>
              </li>
            </ul>
          </li>
          <li>
            <t><strong>UPDATED (Technical Review)</strong>: Clarified that S/MIME 4.0 is the baseline
for conformant implementations, with explicit guidance on when to use
AuthEnvelopedData (S/MIME 4.0 with AES-GCM/AES-CCM) versus EnvelopedData
(S/MIME 3.2 with AES-CBC or for backward compatibility).</t>
          </li>
          <li>
            <t>Added explicit pointer to Section 1.2.1 for legacy interoperability
clarifications.</t>
          </li>
          <li>
            <t>Clarified that RFC 8551 forms the baseline for new implementations.</t>
          </li>
          <li>
            <t>Added new <strong>Section 1.2.1</strong>: Legacy Interoperability (non-normative clarifications):
            </t>
            <ul spacing="normal">
              <li>
                <t>Captures behavior when interoperating with RFC 4130 systems.</t>
              </li>
              <li>
                <t>Explicit note: 3DES withdrawn by NIST in 2024; MAY only be accepted for
backward compatibility, SHOULD NOT be generated.</t>
              </li>
            </ul>
          </li>
        </ul>
      </section>
      <section anchor="changes-affecting-section-51-as2-version-header">
        <name>Changes affecting Section 5.1 - AS2-Version Header</name>
        <ul spacing="normal">
          <li>
            <t>Retained definitions for AS2-Version 1.0, 1.1, and included the previously supported version 1.2.</t>
          </li>
          <li>
            <t>Added <strong>AS2-Version: 1.3</strong>:
            </t>
            <ul spacing="normal">
              <li>
                <t>Defines modernization requirements (SHA-256, AES baseline per RFC 8551).</t>
              </li>
              <li>
                <t>Aligns MDN behavior with RFC 8098.</t>
              </li>
              <li>
                <t>Requires support for multiple-recipient encryption (Section 7.2).</t>
              </li>
              <li>
                <t>States weak algorithms (SHA-1, MD5, 3DES, RC2) SHOULD NOT be generated
by conformant 1.3 implementations.</t>
              </li>
              <li>
                <t>Points to Section 1.2.1 for legacy interoperability when communicating
with 1.2 or earlier partners.</t>
              </li>
            </ul>
          </li>
          <li>
            <t>Added note about future versioning: minor versions (1.x) remain backward
compatible; major version (2.0+) would indicate non-backward-compatible
revisions.</t>
          </li>
        </ul>
      </section>
      <section anchor="changes-affecting-section-533-message-id-and-original-message-id">
        <name>Changes affecting Section 5.3.3 — Message-Id and Original-Message-Id</name>
        <ul spacing="normal">
          <li>
            <t>Prohibit spaces and control characters in newly generated <tt>Message-Id</tt>
values; recommend removal (not substitution) when constructing from
other attributes.</t>
          </li>
          <li>
            <t>Clarify receiver behavior: implementations are not required to accept
malformed <tt>Message-Id</tt> values; they SHOULD return an MDN with
<tt>processed/error</tt> and a human-readable explanation (per <xref target="RFC8098"/>).</t>
          </li>
          <li>
            <t>Keep angle-bracket guidance; brackets are required on send and are not
part of the identifier value. Receivers SHOULD NOT reject solely for
missing brackets.</t>
          </li>
          <li>
            <t>Update normative reference to <xref target="RFC5322"/>.</t>
          </li>
        </ul>
      </section>
      <section anchor="changes-affecting-sections-54-and-55-reliability-and-restart">
        <name>Changes affecting Sections 5.4 and 5.5 — Reliability and Restart</name>
        <ul spacing="normal">
          <li>
            <t>Expanded Section 5.4 to clarify that HTTP 102 (Processing) MAY be used
under HTTP/1.1 for progress indication but MUST NOT be used under
HTTP/2 or HTTP/3.</t>
          </li>
          <li>
            <t>Changed previous requirement to close connections before retry to
optional behavior; clarified that 102 is deprecated but still
permitted for backward compatibility.</t>
          </li>
          <li>
            <t>Expanded Section 5.5 to reference the AS2 Reliability
(<xref target="I-D.draft-duker-as2-reliability-16"/>) and AS2 Restart (<xref target="I-D.draft-harding-as2-restart-02"/>) drafts.</t>
          </li>
          <li>
            <t>Clarified that implementations SHOULD support configurable retry logic
and MAY implement restart for large or interrupted transfers.</t>
          </li>
          <li>
            <t>Added explicit normative language about duplicate detection using
Message-ID.</t>
          </li>
        </ul>
      </section>
      <section anchor="changes-affecting-section-6-additional-as2-specific-http-headers">
        <name>Changes affecting Section 6 — Additional AS2-Specific HTTP Headers</name>
        <ul spacing="normal">
          <li>
            <t>Added new <tt>AS2-Product</tt> header to identify the sending product and version.</t>
          </li>
          <li>
            <t>Defined header format as <tt>&lt;product-name&gt;:&lt;major.minor[.patch]&gt;</tt>.</t>
          </li>
          <li>
            <t>Required inclusion for AS2-Version 1.3 and possibly 2.0 later.</t>
          </li>
          <li>
            <t>Clarified that the header enables interoperability diagnostics and
implementation-specific workarounds, not capability negotiation.</t>
          </li>
          <li>
            <t>Explicitly stated that arbitrary or misleading product names MUST NOT be used.</t>
          </li>
        </ul>
      </section>
      <section anchor="changes-affecting-section-7-algorithm-requirements">
        <name>Changes affecting Section 7 - Algorithm Requirements</name>
        <ul spacing="normal">
          <li>
            <t>Introduced a new dedicated section consolidating algorithm requirements.</t>
          </li>
          <li>
            <t><strong>Hash Algorithms</strong>:
            </t>
            <ul spacing="normal">
              <li>
                <t>MUST support SHA-256.</t>
              </li>
              <li>
                <t>SHOULD support SHA-384 or stronger.</t>
              </li>
              <li>
                <t>SHA-1 and MD5 deprecated; SHOULD NOT be generated by conformant implementations.</t>
              </li>
            </ul>
          </li>
          <li>
            <t><strong>Encryption Algorithms</strong>:
            </t>
            <ul spacing="normal">
              <li>
                <t>MUST support AES-128-CBC; SHOULD support AES-256-CBC.</t>
              </li>
              <li>
                <t>RECOMMENDED to support AES-GCM and AES-CCM modes.</t>
              </li>
              <li>
                <t>3DES and RC2 deprecated; SHOULD NOT be generated.</t>
              </li>
              <li>
                <t>SHOULD support multiple-recipient encryption (per RFC 8551 §3.3).</t>
              </li>
            </ul>
          </li>
          <li>
            <t><strong>UPDATED (Technical Review)</strong>: Added comprehensive key management algorithm
requirements:
            </t>
            <ul spacing="normal">
              <li>
                <t>MUST support RSA with minimum 2048-bit key length</t>
              </li>
              <li>
                <t>MAY support ECDH and Diffie-Hellman (RFC 5753)</t>
              </li>
              <li>
                <t>For elliptic curves, SHOULD support NIST P-256 or stronger</t>
              </li>
            </ul>
          </li>
          <li>
            <t><strong>UPDATED (Technical Review)</strong>: Added new Section 7.2 subsections:
            </t>
            <ul spacing="normal">
              <li>
                <t>"EnvelopedData vs AuthEnvelopedData" - Explicit rules for when to use each:
                </t>
                <ul spacing="normal">
                  <li>
                    <t>AuthEnvelopedData MUST be used with AES-GCM and AES-CCM</t>
                  </li>
                  <li>
                    <t>EnvelopedData MUST be used with AES-CBC and for S/MIME 3.2 compatibility</t>
                  </li>
                  <li>
                    <t>Single content encryption algorithm MUST be used for all recipients</t>
                  </li>
                </ul>
              </li>
              <li>
                <t>"Multiple-Recipient Encryption" - Explains support for multiple recipients
of the same content-encryption key</t>
              </li>
            </ul>
          </li>
          <li>
            <t>Added explicit cross-references to Section 1.2.1 for legacy interoperability.</t>
          </li>
        </ul>
      </section>
      <section anchor="changes-affecting-section-8-mdn-processing">
        <name>Changes affecting Section 8 - MDN Processing</name>
        <ul spacing="normal">
          <li>
            <t>Updated to align MDN behavior with RFC 8098 (superseding RFC 3798).</t>
          </li>
          <li>
            <t>Clarified semantics for signed-receipt-micalg:
            </t>
            <ul spacing="normal">
              <li>
                <t>Allow multiple algorithms in header for backward compatibility.</t>
              </li>
              <li>
                <t>Conformance requires selecting one algorithm in Received-content-MIC.</t>
              </li>
              <li>
                <t>SHA-256 set as the default minimum; SHA-1 only permitted for legacy use.</t>
              </li>
            </ul>
          </li>
          <li>
            <t>Relaxed constraints on the content of the Disposition-notification-to header.</t>
          </li>
          <li>
            <t>Definitions have been included for additional supported error dispositions.0</t>
          </li>
          <li>
            <t>Clarified required MDN fields:
            </t>
            <ul spacing="normal">
              <li>
                <t><tt>Final-Recipient</tt> — MUST always be present.</t>
              </li>
              <li>
                <t><tt>Original-Message-ID</tt> — REQUIRED and must match the original message exactly.</t>
              </li>
              <li>
                <t><tt>Message-ID</tt> in the MDN — optional.</t>
              </li>
              <li>
                <t><tt>Disposition-Notification-To</tt> — MAY use any format (email, URL, hostname);
receiving systems MUST ignore syntax issues per RFC 4130.</t>
              </li>
            </ul>
          </li>
          <li>
            <t>Updated asynchronous MDN handling to reflect practical implementation realities:
            </t>
            <ul spacing="normal">
              <li>
                <t>HTTP 200-level responses SHOULD be sent immediately after receiving the last byte,
before full decryption or validation, to minimize timeout risk.</t>
              </li>
              <li>
                <t>Persistent (keep-alive) connections MAY be used; closing is optional and
implementation-dependent.</t>
              </li>
              <li>
                <t>Receipt of a 200-level response only acknowledges receipt, not successful processing.</t>
              </li>
            </ul>
          </li>
          <li>
            <t>Emphasized that asynchronous MDNs are sent as independent HTTP messages per
Section 7.3, and clarified that connection handling should not be mandated at
the application layer.</t>
          </li>
          <li>
            <t>Added standardized <tt>disposition-modifier</tt> extensions to improve error
reporting.</t>
          </li>
          <li>
            <t>New recommended modifiers:
            </t>
            <ul spacing="normal">
              <li>
                <t><tt>error: decompression-failed</tt></t>
              </li>
              <li>
                <t><tt>error/duplicate-filename</tt></t>
              </li>
              <li>
                <t><tt>error/illegal-filename</tt></t>
              </li>
              <li>
                <t><tt>error: insufficient-message-security</tt></t>
              </li>
              <li>
                <t><tt>error/invalid-message-id</tt></t>
              </li>
              <li>
                <t><tt>error/unknown-trading-relationship</tt></t>
              </li>
            </ul>
          </li>
          <li>
            <t>Clarified that implementations returning these modifiers MUST include a
human-readable explanation in the MDN <tt>Explanation</tt> field.</t>
          </li>
        </ul>
      </section>
      <section anchor="changes-affecting-section-9-public-key-certificate-handling">
        <name>Changes affecting Section 9 — Public Key Certificate Handling</name>
        <ul spacing="normal">
          <li>
            <t>Revised the opening paragraph to reference the optional <strong>AS2 GET</strong> method,
in addition to manual partner onboarding.</t>
          </li>
          <li>
            <t>Expanded the section to clarify separate roles and lifecycle management
for <strong>TLS certificates</strong> (transport security) and <strong>AS2 certificates</strong>
(message signing and encryption).</t>
          </li>
          <li>
            <t><strong>UPDATED (Technical Review)</strong>: Strengthened requirement that TLS and AS2
certificates <strong>MUST NOT</strong> be the same certificate (changed from SHOULD NOT).
Using the same certificate for both purposes creates security dependencies
and operational risks that must be avoided.</t>
          </li>
          <li>
            <t>Required a <strong>minimum RSA key length of 2048 bits</strong> (or equivalent elliptic-curve
strength such as P-256).</t>
          </li>
          <li>
            <t>Clarified that:
            </t>
            <ul spacing="normal">
              <li>
                <t><strong>TLS certificates</strong> SHOULD be CA-signed in production; self-signed
certificates MAY be used in test environments or by partner agreement,
provided they include a <strong>Subject Alternative Name (SAN)</strong> extension
with hostname and/or IP address.</t>
              </li>
              <li>
                <t><strong>UPDATED (Technical Review)</strong>: Added reference to CA/Browser Forum
Baseline Requirements (https://cabforum.org/baseline-requirements-documents/)
for public-facing TLS certificates.</t>
              </li>
              <li>
                <t><strong>AS2 certificates</strong> MAY be CA-issued or self-signed per partner policy.</t>
              </li>
            </ul>
          </li>
          <li>
            <t>Added guidance that <strong>AS2 certificate lifetimes</strong> need not mirror the
short renewal cycles of TLS certificates; renewal policies SHOULD be
independent.</t>
          </li>
          <li>
            <t>Recommended <strong>CEM</strong> for automated certificate exchange between partners
to reduce manual errors and downtime.</t>
          </li>
          <li>
            <t><strong>UPDATED (Technical Review)</strong>: Clarified AS2 GET certificate retrieval
requirements to focus on authentication (verify requester identity) and
authorization (ensure only legitimate partners can access certificates)
rather than just integrity protection. While certificates are digitally
signed and thus tamper-evident, authentication and authorization prevent
unauthorized parties from obtaining certificates and mapping trading
partner relationships. For self-signed certificates, added requirement
for out-of-band fingerprint verification before production use.</t>
          </li>
          <li>
            <t>Added operational recommendations:
            </t>
            <ul spacing="normal">
              <li>
                <t>Maintain separate TLS / AS2 certificates.</t>
              </li>
              <li>
                <t>Include SAN extensions in all self-signed certificates.</t>
              </li>
              <li>
                <t>Support configurable expiry-notification mechanisms.</t>
              </li>
              <li>
                <t><strong>UPDATED (Technical Review)</strong>: Administrators MUST NOT (strengthened
from SHOULD NOT) reuse TLS certificates for AS2 message security.</t>
              </li>
            </ul>
          </li>
        </ul>
      </section>
      <section anchor="changes-affecting-section-10-security-considerations">
        <name>Changes affecting Section 10 - Security Considerations</name>
        <ul spacing="normal">
          <li>
            <t>Provided guidance for the usgae of HTTPS and the minimum and recommended usage of TLS versions.</t>
          </li>
          <li>
            <t>Expanded discussion of algorithm lifecycle:
            </t>
            <ul spacing="normal">
              <li>
                <t>SHA-1 and MD5 deprecated; 3DES formally withdrawn by NIST (2024).</t>
              </li>
              <li>
                <t>Implementations SHOULD NOT generate deprecated algorithms.</t>
              </li>
              <li>
                <t>Migration guidance provided for interoperability.</t>
              </li>
            </ul>
          </li>
          <li>
            <t>Added explicit references back to Section 7 (Algorithm Requirements) and
Section 1.2.1 (Legacy Interoperability).</t>
          </li>
        </ul>
      </section>
      <section anchor="changes-affecting-section-11-iana-considerations">
        <name>Changes affecting Section 11 - IANA Considerations</name>
        <ul spacing="normal">
          <li>
            <t>Clarified that IANA must update existing MDN registries to reference this
specification (replacing RFC 4130).</t>
          </li>
          <li>
            <t>Added direct links to IANA registry pages for clarity.</t>
          </li>
        </ul>
      </section>
      <section anchor="updated-message-examples">
        <name>Updated Message Examples</name>
        <ul spacing="normal">
          <li>
            <t><strong>Appendix A</strong>: Updated Message Examples with newer algorithms.</t>
          </li>
        </ul>
      </section>
      <section anchor="formatting-and-editorial-updates-technical-review">
        <name>Formatting and Editorial Updates (Technical Review)</name>
        <t>The following formatting and editorial improvements were made based on
technical review feedback:</t>
        <ul spacing="normal">
          <li>
            <t><strong>Section 1.1 (Applicable RFCs)</strong>:
            </t>
            <ul spacing="normal">
              <li>
                <t>Updated RFC references to reflect proper obsolescence chain (RFC 3851 -&gt;
RFC 5751 -&gt; RFC 8551)</t>
              </li>
              <li>
                <t>Added RFC 5751 and RFC 5652 to normative references</t>
              </li>
              <li>
                <t>Added explicit explanation of when to use AuthEnvelopedData vs
EnvelopedData based on encryption algorithm choice</t>
              </li>
            </ul>
          </li>
          <li>
            <t><strong>Section 1.3 (Algorithm Coverage)</strong>:
            </t>
            <ul spacing="normal">
              <li>
                <t>Expanded hash function section to include encryption algorithms</t>
              </li>
              <li>
                <t>Added key management algorithm requirements for ECDH</t>
              </li>
              <li>
                <t>Added RFC 5753 to informative references</t>
              </li>
            </ul>
          </li>
          <li>
            <t><strong>Section 6 (AS2-Specific HTTP Headers)</strong>:
            </t>
            <ul spacing="normal">
              <li>
                <t>Reformatted AS2-Version header descriptions to comply with RFC
formatting requirements (72-character line limit)</t>
              </li>
              <li>
                <t>Removed markdown artifacts <tt>{:format="none"}</tt> from all cross-references
throughout the document (24 instances)</t>
              </li>
            </ul>
          </li>
          <li>
            <t><strong>RFC Reference Sections</strong>:
            </t>
            <ul spacing="normal">
              <li>
                <t>Moved RFC citations from section titles to first sentence of each
section (9 sections in "Referenced RFCs and Their Contributions")</t>
              </li>
              <li>
                <t>Example: "## RFC 2616 HTTP v1.1 <xref target="RFC2616"/>" became
"## RFC 2616 HTTP v1.1" with "<xref target="RFC2616"/> specifies..." in text</t>
              </li>
            </ul>
          </li>
          <li>
            <t><strong>Capitalization</strong>:
            </t>
            <ul spacing="normal">
              <li>
                <t>Corrected "internet" to "Internet" (2 instances)</t>
              </li>
              <li>
                <t>Ensured consistent capitalization throughout document</t>
              </li>
            </ul>
          </li>
          <li>
            <t><strong>Cross-References</strong>:
            </t>
            <ul spacing="normal">
              <li>
                <t>Standardized all internal section references to use plain markdown
format without formatting directives</t>
              </li>
            </ul>
          </li>
          <li>
            <t><strong>Bullet Formatting</strong>:
            </t>
            <ul spacing="normal">
              <li>
                <t>Standardized all sections requiring bullets to use the same type and
and same spacing and margins.</t>
              </li>
            </ul>
          </li>
        </ul>
        <t>These updates improve RFC formatting compliance and document clarity while
maintaining all technical content and backward compatibility requirements.</t>
      </section>
    </section>
  </back>
  <!-- ##markdown-source:
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
/6jn4O1Tl4EFfmZfI+hm9v54fHB8eHSk4PDQyjRfVAzGADwBy4LSLdZ6CNNy
0QOa4on96zuU5AnED08HcsPDnRsqirnrA+cKQZ9E+oyCIEcF3uLYanldd5Jp
X9bA2KY2Ed0OWl/Nrsg1MTuubBCOjPyld/WLMiu8HfXBloh9sEqp7IXV24dW
THqe5jVVYISXsx8oyrPx29JXwcl2Ab78NYce2uuc90+Xc38qUcDwMTTk2fGF
pqiheywHSyw61jwJIDMJAcP11YkkjvrbOxmF8y0EdIbYuZZGmG3yRq/1QpNt
5Kh1l1juVuS51F0L68whrhzowNmtVtlGFnFZl4xseFpI6k8QukN8qKYkM64Z
S6B/4ZvFJf0bFnCwdiMwcBB5XDgVwSFojk0nfjik85/emBQaSaC0Eqkw6apZ
ingSWfuXiogWlT1U0hoxQp3Y76MkEexLolMrLkjKUOW+eYwRjT0HzS2uAwEH
vMUBECP5i9DoUMNPodXrctaiH1cD7bXyh5ewsCuQ/djniBWECd4cIRhqybGH
39zgSfSyssmS4IDjE2rncxnXWc3YecCXXtPzrq6QAHbSDeVL4HHKAtHHIiqr
q/63s+Laew4MmxQbl0DkkKQSUsI5vTqueHlRFjVWepeihXiyEVGPyi7QudUa
cSTnBx+RokOGzq0jLiYmxatCggFdh7DBomNRUampTmk+FxDLxVU1v8IbytIL
ok6oBg8RPdaDEZyzULSrl3TIQ00ic41+rQV+yipZVK+xVCw0qQxKqyWMN6WA
qAAlbZ3RgyIRYvtvqkhbxHjkkAO5qPzJEfVgrEXgH6BsZTrDWCvFP5DLpSPA
fYIf5A10XfR1/pt6RrF/KxXIXbbEvQeYvEk3f/TG8uO0+Xpsg+Ypvfh8i7mu
x8vystg8sc0zy7bsvuiO+T9vwP0b5sfm1dHfNMlOQ7dvZrpGG85JtsWhrD3R
vtt3WDWSltas2rNEaNjO/qTdfPgNpL3p7GVb/rIkvHJMrdMrEg0MVLxc7spb
Z2gDDnNN51QGr/GYu6GN6M7w1jP+Kzqk2XT6+20M4x50tpFp3IGy1i38/U7k
nZYtWZ97Ls/duM7npr57caXPQ6qbiXUtX/p/k3Q3DupOZNzZXVTIreJzTNV3
4YloUNgSkfKBAxQY+/j+3p7u082tDOVeg7nvmjGoWLbRIWDqdJcQugVSVNKM
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
HUXRI8cHOqe4XZUr/vVdo1kLx9HLAPGcMU3Cko8bC+XzJZjcak+iTZ49a+kI
lTLor5942uIGdAfuS80xQJ4o2aAQiEQuOm62vaWiD8sRCM+xlBIVVUklFXVw
A1X1cxpDYBIEIY0LCuFBKlYBmN/4m6/VNn4JEZJ3sVS9PVMvIAa/1//OiVo2
RBdxkqmfqlF5E9mY8AgbW6mAJyT1puxewFRF2anSPLXoHBLLJtZ6UeZxgRfK
rItTAA/TO9oFXGp/So6fEml5iiznYizfQOqxI7bnQ1EWX/2ujLD4lxVHV55u
s/75cIiN0PR0hOZNmO5c33918/bu7c931zdp96uj9/P+96fH3RFFZBrPWK6i
GMoz9Or/pxDKweX5x1/7k/P7n+LT7mDzTf3zfNb/7d1v58ODy+beffOm3Txv
n4/D17fteTQ/+OHj9WS7dfl29Nub10foc/714FWr9+Z2+2MyaXz7tv9V+/T2
+8/j8+G0Vf8c9i5v2+2Pk5PJ4e5o89fG5G23nd6ly19vJs3x3q9o8dz1PlwM
2wc/jn882Lt6U38dhnf3i/tF/bubjz/8NBn2+6OLv77+ILGXF8+YeMl7BD3a
5+/ii6D0Hk1tBMy6CctrawIXDdiWd7bqcEEkAIAQjI0qpCkAVWUc6m4g6fZb
y9fS2roFhNIzB8ct0WKEqpIg8ToFVc7eGKyvCY5xrQp1aVjyAIWGtlYFOy66
g8YmotUzHrtwmuIra+bWt1IoqwhSU8ZusA8iPk8ycRzVinTDgdIDKLUIakDu
VedgGkHJjOJ0JKanKlfv4FfrDiMKb8zCC6PFbPhlBiiRMFfcd6yqQRlmgF9Y
4TZ/Y2CDYoHimyojNIwZl3ohYLKjJE6h0s9+oTR4wAyi5ocFWhfQj59qP4Pq
UtdzzcM8TKD6IppdUazmzenRO3zBT+b/zVzPlzjJR7g6K5Buspg4ZtU8sJE1
apFDQhSogljiTDL9D4spGjXwph49S5W/gNjKiGd4RMg93AqGlQK3xDxNXDPj
GsoUVkgVCRWGjNrbDRoEotbvbjeedlNT3bSz3WTATN48hJ6LtdEKfqW6ipgV
q7uypTPVoH9nDowxxfiUeGHxDwn/EolKpKaLapmBOXYjTyTQ/VnjILHdxZHN
m5YZXUm+n7cD2rTxOaB4Q0mazNUmfDuCYWyAJkZ5nC1WMKpq4CB511atTu8C
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
bHcZqju/kGHtfwBiUYwdCiwCAA==

-->

</rfc>
