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

<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 format="none" target="https-tls-reqs">Section 10.1</xref>).
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 84?>

<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 format="none" target="iana-considerations">Section 11</xref>.</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"/>. This document expands on RFC 1767 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 3851, 3852 S/MIME v3.1 Specification
 o  RFC 8551 S/MIME v4.0 (updated algorithm requirements including AES,
    AES-GCM, AES-CCM)
]]></artwork>
        <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>Implementations MAY interoperate using S/MIME Version 3.1 <xref target="RFC3852">RFC3851</xref>
with legacy trading partners, but conformant implementations MUST also
support S/MIME Version 4.0 <xref target="RFC8551"/> to meet the algorithm requirements
of this specification and ensure forward compatibility. These provisions ensure
smooth migration for existing deployments while establishing RFC 8551 as
the baseline for new implementations.</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 Appendix B (Legacy
Interoperability). Appendix B is non-normative and does not alter the
algorithm requirements defined in Section 7, but records expected
behavior when communicating with legacy systems.</t>
      </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 new implementations (see <xref format="none" target="https-tls-reqs">Section 10.1</xref>).</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 format="none" target="backward-compatibility-and-interoperability">Section 1.2</xref>).</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 <xref format="none" target="structure-and-processing-of-an-mdn-message">Section 8</xref>.</t>
        </section>
      </section>
      <section anchor="assumptions">
        <name>Assumptions</name>
        <section anchor="ediec-process-assumptions">
          <name>EDI/EC Process Assumptions</name>
          <t>o  Encrypted object is an EDI/EC Interchange.</t>
          <t>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.</t>
          <t>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.</t>
          <t>o  EDI envelope headers are encrypted.</t>
          <t>Congruent with the above statement, EDI envelope headers are NOT
   visible in the MIME package.</t>
          <t>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.</t>
          <t>o  X12.58 and UN/EDIFACT Security Considerations</t>
          <t>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.</t>
        </section>
        <section anchor="flexibility-assumptions">
          <name>Flexibility Assumptions</name>
          <t>o  Encrypted or Unencrypted Data</t>
          <t>This specification allows for EDI/EC message exchange in which the
   EDI/EC data can be either unprotected or protected by means of
   encryption.</t>
          <t>o  Signed or Unsigned Data</t>
          <t>This specification allows for EDI/EC message exchange with or without
   digital signature of the original EDI transmission.</t>
          <t>o  Compressed or Uncompressed Data</t>
          <t>This specification allows for optional compression and MAY be applied alone
  or in combination with signing and/or encryption, as defined in <xref target="RFC3274"/>.
  It is supported by AS2-Version: 1.1 and higher.</t>
          <t>o  Optional Use of Receipt</t>
          <t>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.</t>
          <t>o  Use of Synchronous or Asynchronous Receipts</t>
          <t>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 Section 8 of this document.</t>
          <t>o  Security Formatting</t>
          <t>This specification relies on the guidelines set forth in RFC
   3851/3852  <xref target="RFC3851"/> / <xref target="RFC3852"/> "S/MIME Version 3.1 Message Specification;
   Cryptographic Message Syntax" as well as RFC 8551 <xref target="RFC8551"/> "Secure/Multipurpose Internet
   Mail Extensions (S/MIME) Version 4.0" for modern implementations.</t>
          <t>o  Hash Function, Message Digest Choices</t>
          <t>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.</t>
          <t>o  Permutation Summary</t>
          <t>The optional use of compression, as defined in <xref target="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.</t>
          <t>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.</t>
          <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>
          <t>o Compression MAY be applied alone or in combination with signing and/or encryption, as defined in <xref target="RFC3274"/> and is supported
     by AS2-Version 1.1 and higher.</t>
          <t>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
    <xref format="none" target="the-secure-transmission-loop">Section 2.3.1</xref>, “The Secure Transmission Loop.”</t>
          <t>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.</t>
        </section>
      </section>
    </section>
    <section anchor="referenced-rfcs-and-their-contributions">
      <name>Referenced RFCs and Their Contributions</name>
      <section anchor="rfc-2616-http-v11-rfc2616">
        <name>RFC 2616 HTTP v1.1 <xref target="RFC2616"/></name>
        <t>This document specifies how data is transferred using HTTP.</t>
      </section>
      <section anchor="rfc-1847-mime-security-multiparts-rfc1847">
        <name>RFC 1847 MIME Security Multiparts <xref target="RFC1847"/></name>
        <t>This document defines security multipart for MIME:
   multipart/encrypted and multipart/signed.</t>
      </section>
      <section anchor="rfc-3462-multipartreport-rfc3462">
        <name>RFC 3462 Multipart/Report <xref target="RFC3462"/></name>
        <t>This RFC 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-rfc1767">
        <name>RFC 1767 EDI Content <xref target="RFC1767"/></name>
        <t>This RFC 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-rfc2045-rfc2046-and-rfc2049">
        <name>RFC 2045, 2046, and 2049 MIME   <xref target="RFC2045"/>, <xref target="RFC2046"/>, and <xref target="RFC2049"/></name>
        <t>These 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-rfc3798">
        <name>RFC 3798 Message Disposition Notification <xref target="RFC3798"/></name>
        <t>This Internet RFC 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-3851-and-3852-smime-version-31-message-specifications-and-cryptographic-message-syntax-cms-rfc3851-rfc3852">
        <name>RFC 3851 and 3852 S/MIME Version 3.1 Message Specifications and Cryptographic Message Syntax (CMS) <xref target="RFC3851"/> / <xref target="RFC3852"/></name>
        <t>This specification describes how S/MIME will carry CMS Objects.</t>
      </section>
      <section anchor="rfc-3023-xml-media-types-rfc3023">
        <name>RFC 3023 XML Media Types <xref target="RFC3023"/></name>
        <t>This RFC 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-rfc3274">
        <name>RFC 3274 Compressed Data Content Type for Cryptographic Message Syntax (CMS) <xref target="RFC3274"/></name>
        <t>This RFC 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)
          - RFC3851 (application/pkcs7-signature)

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

   Encryption, signature, no compression
      - RFC2616/2045
        - RFC3851 (application/pkcs7-mime)
          - RFC1847 (multipart/signed)(encrypted)
            - RFC1767/RFC3023  (application/EDIxxxx or /xml) (encrypted)
            - RFC3851 (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)
              - RFC3851 (application/pkcs7-signature)

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

   Encryption, signature (compression may occur before or after signing)
      - RFC2616/2045
        - RFC3851 (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)
              - RFC3851 (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)
         - RFC3851 (application/pkcs7-signature)
]]></sourcecode>
        <t><strong>Key Notes</strong></t>
        <t>o RFC 3274 (CompressedData) is the normative reference for compression.</t>
        <t>o Compression MAY be combined with signing and/or encryption in either order,
    but the choice affects what the digital signature covers.</t>
        <t>o Many implementations compress before signing and encrypting to maximize size
    reduction, but compression after signing and before encrypting MUST also be supported.</t>
        <t>o Although all MIME content types SHOULD be supported, the following
    MIME content types MUST be supported:</t>
        <artwork><![CDATA[
         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 format="none" target="https-tls-reqs">Section 10.1</xref>.
   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 format="none" target="backward-compatibility-and-interoperability">Section 1.2</xref>).</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
   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 future
   "2.0" 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 [RFC8551]),
                       alignment with MDN handling as specified in [RFC8098], and support for
                       multiple-recipient encryption as described in [Section 7.2](#encryption-algorithms){:format="none"}
                       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 MAY apply
                       the legacy interoperability clarifications described in Appendix B (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.
]]></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 or 2.0</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: drummond-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.</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
   Appendix B.</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 MUST NOT be generated by conformant implementations.</t>
        <t>See Appendix B 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 MUST be
   supported, and AES-256-CBC SHOULD 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 MUST NOT be generated by
   conformant implementations.</t>
        <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 Appendix B for guidance on handling 3DES and other weak algorithms
   when interoperating with legacy AS2 systems.</t>
      </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 format="none" target="backward-compatibility-and-interoperability">Section 1.2</xref>).
   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 format="none" target="backward-compatibility-and-interoperability">Section 1.2</xref>).</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 section 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>
            <t><strong>The following algorithm requirements apply to all implementations:</strong>  </t>
            <t>
o Implementations <strong>MUST</strong> support SHA-256.  </t>
            <t>
o Implementations <strong>SHOULD</strong> support SHA-384 or stronger.  </t>
            <t>
o SHA-1 <strong>MAY</strong> be accepted only when required for interoperability with
    legacy partners and MUST NOT be generated for new deployments once
    both parties support stronger algorithms.  </t>
            <t>
o MD5 is obsolete and MUST NOT be generated.  </t>
            <t>
See <xref format="none" target="security-considerations">Section 10</xref> for additional algorithm requirements
and deprecation timelines.  </t>
            <t>
Both the "signed-receipt-protocol" and the "signed-receipt-micalg"
option parameters are REQUIRED when requesting a signed receipt.  </t>
            <t>
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".</t>
          </li>
          <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 format="none" target="disposition-mode-type-and-modifier">Section 8.5</xref>
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 Section 7 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 spelling 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 Section 11).</t>
          <t>The "Received-content-MIC" extension field is set when the integrity
   of the received message is verified. The MIC 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 format="none" target="signed-receipt-considerations">Section 8.3.1</xref>
   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 Appendix B). This field
   is set only when the contents of the message are 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>
          <t>o <strong>Final-Recipient</strong> — This field <strong>MUST</strong> always be present in an MDN
     and MUST identify the AS2-To value of the original message.</t>
          <t>o <strong>Original-Message-ID</strong> — This field is <strong>REQUIRED</strong> and MUST exactly
     match the <tt>Message-ID</tt> of the original message as transmitted.
     <tt>Message-ID</tt> in the MDN itself is optional.</t>
          <t>o <strong>Disposition-Notification-To</strong> — Implementations <strong>MAY</strong> include this
     field using an email address, URL, hostname, or other identifier as
     appropriate to the system.  However, as specified in <xref target="RFC4130"/>, receiving
     applications <strong>MUST</strong> ignore this field and <strong>MUST NOT</strong> reject a message
     due to syntax or address format violations.  The field is retained for
     compatibility with prior implementations.</t>
        </section>
        <section anchor="additional-as2-mdn-programming-notes">
          <name>Additional AS2-MDN Programming Notes</name>
          <t>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.</t>
          <t>o  Refer to RFC 3798 for the formatting of the MDN, except for the
      specific deviations mentioned above.</t>
          <t>o  Refer to RFC 3462 and RFC 3798 for the formatting of the content-
      type entity-headers for the MDN.</t>
          <t>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.</t>
          <t>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.</t>
          <t>o  Use a sending-mode of "MDN-sent-automatically" when the MDN is
      sent because the UA had previously been configured to do so.</t>
          <t>o  Use a sending-mode of "MDN-sent-manually" when the user explicitly
      gave permission for this particular MDN to be sent.</t>
          <t>o  The sending-mode "MDN-sent-manually" is meaningful ONLY with
      "manual-action", not with "automatic-action".</t>
          <t>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.</t>
        </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 Section 9.2).
   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="RFC3851"/>
   and <xref target="RFC3852"/>.</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>
        <ul spacing="normal">
          <li>
            <t><strong>TLS Certificates</strong> 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. Self-signed TLS certificates MAY be used for testing or by
explicit agreement between trading partners, provided they include a
<strong>Subject Alternative Name (SAN)</strong> extension containing the hostname
and/or IP address. The SAN extension MUST be marked as non-critical.</t>
          </li>
          <li>
            <t><strong>AS2 Certificates</strong> are used for signing and encrypting AS2 messages
and SHOULD NOT be the same as the TLS certificate. Separation ensures that
a compromise of the transport layer does not affect message-level
security. AS2 certificates MAY be CA-issued or self-signed, depending on
organizational policy and trading-partner agreements.</t>
          </li>
        </ul>
        <t>AS2 certificates MUST use a key length of at least <strong>2048 bits for RSA
   keys</strong>.  For elliptic-curve certificates, the selected curve MUST provide
   equivalent or stronger security (e.g., P-256 or higher).</t>
        <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="RFC6017"/> 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 if protected by appropriate authentication (for example,
   Basic Authentication). Implementations using AS2 GET MUST ensure that
   certificate delivery is integrity-protected and that access is restricted
   to authorized partners.</t>
      </section>
      <section anchor="operational-guidance">
        <name>Operational Guidance</name>
        <ul spacing="normal">
          <li>
            <t>TLS and AS2 certificates MUST be managed separately.</t>
          </li>
          <li>
            <t>CEM SHOULD be supported to reduce manual errors and configuration drift.</t>
          </li>
          <li>
            <t>Self-signed certificates SHOULD include SAN extensions for clarity and
validation consistency.</t>
          </li>
          <li>
            <t>Implementations SHOULD support configurable expiration and notification
mechanisms for certificate renewal.</t>
          </li>
          <li>
            <t>Administrators SHOULD avoid reusing TLS certificates as AS2 certificates,
even when technically possible.</t>
          </li>
        </ul>
        <t>For security and algorithm lifecycle considerations, see
   <xref target="algorithm-requirements">Section 7</xref> and
   <xref target="security-considerations">Section 10</xref>.</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 format="none" target="algorithm-requirements">Section 7</xref>.
   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 MUST NOT generate these
   algorithms in new deployments. However, legacy use cases may still be
   encountered when interoperating with older systems conforming to
   <xref target="RFC4130"/>. See Appendix B 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
   <xref format="none" target="backward-compatibility-and-interoperability">Section 1.2</xref> and
   <xref format="none" target="legacy-interoperability-non-normative">Appendix B</xref>.</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">Section 9</xref>.</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 hostname 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 format="none" target="https-tls-reqs">Section 10.1</xref> 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>
      <t>o MDN Disposition Modifier Names
     https://www.iana.org/assignments/mdn/mdn.xhtml#disposition-modifier</t>
      <t>o Message Disposition Notification Parameters
     https://www.iana.org/assignments/mdn/mdn.xhtml#parameters</t>
      <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 [Section 8.4.3](#as2-mdn-fields){:format="none"} and
   [Section 8.5.5](#processing-warnings){:format="none"} in this document.
]]></sourcecode>
        </section>
      </section>
    </section>
    <section anchor="acknowledgments">
      <name>Acknowledgments</name>
      <t>Carl Hage, Karen Rosenfeld, Chuck Fenton, and many others
   provided valuable suggestions during 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="RFC3851">
          <front>
            <title>Secure/Multipurpose Internet Mail Extensions (S/MIME) Version 3.1 Message Specification</title>
            <author fullname="B. Ramsdell" initials="B." role="editor" surname="Ramsdell"/>
            <date month="July" year="2004"/>
            <abstract>
              <t>This document defines Secure/Multipurpose Internet Mail Extensions (S/MIME) version 3.1. 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 2633. [STANDARDS-TRACK]</t>
            </abstract>
          </front>
          <seriesInfo name="RFC" value="3851"/>
          <seriesInfo name="DOI" value="10.17487/RFC3851"/>
        </reference>
        <reference anchor="RFC3852">
          <front>
            <title>Cryptographic Message Syntax (CMS)</title>
            <author fullname="R. Housley" initials="R." surname="Housley"/>
            <date month="July" year="2004"/>
            <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="RFC" value="3852"/>
          <seriesInfo name="DOI" value="10.17487/RFC3852"/>
        </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="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>
      </references>
    </references>
    <?line 2395?>

<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 format="none" target="requesting-a-signed-receipt">Section 8.3</xref>.</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="legacy-interoperability-non-normative">
      <name>Legacy Interoperability (Non-Normative)</name>
      <t>This appendix records clarifications 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 Section 7, nor do they extend the use of
   deprecated algorithms.</t>
      <t>Examples of legacy considerations include:</t>
      <t>o  <strong>Message Integrity Checks (MICs):</strong> Implementations may continue
      to accept SHA-1 for MIC calculations when required by legacy
      partners. SHA-1 MUST NOT be generated by conformant modern
      implementations, but inbound SHA-1 values may be tolerated to
      maintain compatibility.</t>
      <t>o  <strong>Encryption Algorithms:</strong> Implementations may accept inbound
      messages encrypted with 3DES from legacy partners. However, 3DES
      MUST NOT be generated by conformant implementations. AES (128-bit
      or stronger) remains the normative requirement in
      <xref format="none" target="encryption-algorithms">Section 7.2</xref>.</t>
      <artwork><![CDATA[
  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 MUST NOT be generated by
  conformant implementations.
]]></artwork>
      <t>o  <strong>Multiple-Recipient Encryption:</strong> 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.</t>
      <t>o  <strong>Error Handling:</strong> 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.</t>
      <t>o  <strong>Profile Selection:</strong> Implementations may provide administrators
      the ability to select profiles (e.g., "AS2-1.2 legacy mode" versus
      "AS2-2.0 modern mode") for specific trading partner agreements,
      ensuring predictable behavior without runtime handshakes.</t>
      <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. see <xref format="none" target="backward-compatibility-and-interoperability">Section 1.2</xref>
   for discussion of backward compatibility principles, and Section 7
   for normative algorithm requirements.</t>
    </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 Appendix B
to avoid confusion with normative text.</t>
          </li>
          <li>
            <t>Clarified that appendices are non-normative unless otherwise indicated.</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.1 (RFC 3851/3852).</t>
              </li>
              <li>
                <t>Conformant implementations MUST also support S/MIME v4.0 (RFC 8551).</t>
              </li>
            </ul>
          </li>
          <li>
            <t>Added explicit pointer to Appendix B for legacy interoperability
clarifications.</t>
          </li>
          <li>
            <t>Clarified that RFC 8551 forms the baseline for new implementations.</t>
          </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) MUST NOT be generated
by conformant 1.3 implementations.</t>
              </li>
              <li>
                <t>Points to Appendix B 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 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 or 2.0 and 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; MUST 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; MUST NOT be generated.</t>
              </li>
              <li>
                <t>SHOULD support multiple-recipient encryption (per RFC 8551 §3.3).</t>
              </li>
            </ul>
          </li>
          <li>
            <t>Added explicit cross-references to Appendix B 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>Stated that TLS and AS2 certificates <strong>SHOULD NOT</strong> be reused or shared to
prevent cross-impact if one certificate is compromised.</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>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>Introduced optional support for <strong>AS2 GET</strong> to retrieve partner
certificates, provided retrieval is authenticated (for example, Basic Auth
or mutual TLS) and integrity-protected.</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>Avoid reusing 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 MUST 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
Appendix B (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="appendices">
        <name>Appendices</name>
        <ul spacing="normal">
          <li>
            <t><strong>Appendix A</strong>: Updated Message Examples with newer algorithms.</t>
          </li>
          <li>
            <t><strong>Appendix B</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, MUST NOT be generated.</t>
              </li>
            </ul>
          </li>
          <li>
            <t><strong>Appendix C</strong>: This Change Log.</t>
          </li>
        </ul>
      </section>
    </section>
  </back>
  <!-- ##markdown-source:
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
Cd8lulVRJ2HLMbl+cjJjc/c2S/FOHmnItpUZ0aVcUoGA55EUM0mEPlNicHcN
AzNH3ArG9AzyYA64LgMkuhwGDiFRvihZabNMBjS69C+MqfAXB5FbS0UZwhkd
z8ZX60vfcIeS+Ibdu1lpQIFVXC8rASGktiy9lSi4a1dalRYkytOYlOmbcUEd
InBE8HzmdbUW0udmz1/OvDdoKb5T2mjunatTdD5Woyp5vel6eOV9py6VFboG
CwhbwuTQJZMdrBiqR15PwLJB3WCF2kzBrjDEyXJq70cX55D7n9MxRgYUsLQk
LXJdIkdR4ViIOiAYOAuvGEXBn1/xGRnTwyQFp2z9Ed41RTMZO2eJMjFcoNsr
u2S5hpA2VdGmMj/cVSNjCQlTD8PeOCX4WAjWXBPw8oxknIJFPAN2SzjXu6Ka
SrO7l8tlzHvB0opKYEC+2KJFipTCwebZDsZ+bbQZs4JYHzWDuIXEQ+cQyMV4
qoGWsc8mrVrcZcDYooEohCCrWslV7CBl6nuNCuAeDrkP8u9g9FW8Y5uOWKNZ
UJSRv4SrGXjSLu/hRr4k1Qbp8jE4b+QicjSX+5nRVkvihKH9r9acgx2kIMFo
BAET5UjhUcw/QBYJ1DgAoVCNJcQ9PeJQ9uckPvq8lRoif879li4opibDJeOz
5MKp2mZRG7WLwSsp+xy4LLPjlVUDpfRen6KbIkXnNuBJn03D/mY+nKo1idax
YLk46hA643fYzEOnaqdWQUiuN+rLO2Cx1RvNSm1XWW71Tht3/icg9uuCNd3B
GemxB9nXKawjqNvxPsP7GzXv7Xrm1av1lldrdBrNTqvqnXy4kFww5yY7UvIh
iFEdb1upW9T32/Lzi6jjVWtqPK3dvXZV/UGlTXHtjncBnmvPj91u+VHH+6Ze
rdare41atd1oNtv17l718Lvdxrd/3/7993EU/f7737df46jzJbDjXS/VCL5l
4a0MCek5947viXqr47nrWJYt9Eqa8LleHHbX1TDeK+tAwUHy1msIbE3MjfHU
h1pOPA74iAfYo04K3uVAWQNraNLcvIIpPYzWH+EfNfX3bQfEjEa2bWEj7CQG
tX3g8TAy3v4eG8Q6Xr2520RFVi4nXpceq/0u5dKV72rORS7I0WrlD6ewvw40
5v+r5XhY29vdq4x8QUb6x2m/61UqlQSkMjoJ6senx13133/7IwNMTIa8T8I5
A2UDKv8Lr7LxqtR7c15XLvMZ/wwNHqzElQChUjaVWsnrIhqjvWNljyIy0Pfv
3D2T2h2ybdKbKbnxDL6E2jF71f29arVdb1Vq1Xq7Vq83W83dvVrlrX/jf1Ca
/Vu1WD9R/u71YyTQlZonS52+3kiyOkbLr74oa271pbX3ZbfZbjZr1ea+O95t
HtucFG3H680i0g9Joa3tK91Gi/SoJ+O1z3O/m8pBD+giT8pD0QZ/lWd6m6uz
v3L3S213r17fb7T26/ZgWrv4mc/xP+7w82/Bi93Rg4DtLKAmy/0l7CFln5eP
51RT1vH2BsRCQK8U0S3T+EWCUY4eqXnVV2fpfPXjTJX/3NOBRw9WFQ6XcnWv
rM4aZZFV9+GUqTW9wvHRRZGuJ3CtjoVox8sHrjKcHVMqScIGOoPFZ9JSEuGa
Eub3c0/YwSm77yB/q7l4jvSg8QoCPUnKYb4fddMMKrr+V1bvIcfuaWt6LuXM
5U9dOuTN4f78e/Z3y+cCWNTxlB5u1+sHGWv13eMv1Q92dNFjZSgrFt3xmo3R
/urk58bkY/9k/Z1yM5pn3ZOb9fBls/3j5PPup/7kp/dHZxd38eGnVyXPOtae
/1nMxCevqjoOnqKBnnJWHaAN+yq+hirAxV7s3JwWBqj4Uof4k05i82w8TU67
J73+byf900Hj6IfjN93fel31s173h+O73tfu28PJp+XR5EPvZPKp616LZvmi
3px+ePtxcHf07s18drj/60X4w9f3t/3b6OXOfvVs2N67e9kf7h4vvut/+vnz
SZf/PGH6eLLB2eIAVo1QCmZIBcpBZsmkbj8novNbnaa2Ezqa+FSQFSNdBVOn
Gn4NiDgn7HdTvOaCL3G9Ar5Tu1uv+Kn3npFUnw9P22Zgkw8O11DfrY4AoEzT
7gebG4pYuRnowzGHgRpJVGThZSScMIwy3Ysixelxz9RZIKMC407YPSfYBK1O
n7kTj7YBQw1AMh+npvLIxmxjzCkBVpNx8kPuG20KcA4BsDZMVhkLTgaU+8QU
1hsEWGYwCv3JPEKkBLVoA+UEwv30XTSRzYrXja3WPTVuRKZt7hKUEfzllxKH
9iX+otMrAHBNkGGxCFheXpmpQLAqILk8fG9qkRJlcYJnFVIdk6CF6acJoGqi
si4NVYQRHz0GwA9gSxkT/GOBRB6oRb+qaEtYHNdjDWJwr3/bjTMc3LSHy5mZ
L4J+ke3pNpWXW6l3Wu1atfY4T9c5qSBA+IXzqc+qtWd+s75btX4WrVfPXhv/
+GK6LinD0zsKhmDCNL1aq1NVlktb/GPt2rKjb0GcmIQEl3rANKAXwWEEHJzS
yLadX33MmQFqXBvcqNTJbNV0Y2XwaBIHyvVDBwr6Rn/sQMFna/uh3KWYkr1g
OzsPuu8Q/O/s7DiLXK/WdqQKccdapv9Hnj0LdPmI0Qf49U//HuMiZvwCHUSQ
bwih5DqIth81zPOjGs16O8cxNpJLLrFseGcHZ/rBjSw/mPb1I0NWqbGXvItj
jPced8ASVzIHGCijYDxDQMrJV6gaFfrKpwS9Mjd1q9PQm9rRGDDPYN/W6rX9
L9VGtdFof2stUGU0Cb+spq9zffasDZ6xVf6ItIBQ5AqRKy1aT/0crZeipkFx
q8UUPGS4TgvgKBisJ8lgWhdrlC2lkViNu7K7KvATe4X+T2MQjQZYmq16fXdX
2ZnNqnJX6rX2Xqu6nblLatVG2tbPfcZ9X2dFGvDPoyMN933L7pfd6u5+DdL1
Zhy19nbWmHOuTY/ZxBcOkGg7Dlav1nHZj4dh+MDxgc4pblfLFf/mrlavBKPw
tYdgsJgxYcnHjYXy+RpMbmtPok2ePGvpCJUC6W8eedriBjQH7msboJw8UbJB
IRCJ3FTcZ3tL5SCaMwyeozHoS1aNldTawQ1U788ZDcFjEAAtLjWEB1mxCgAM
xt98Y23j1xAheR9JPdwT9QICeDtN95zBZUN0FS0TlVUVKnwiGxMeoWMrJfCE
pBKV3QuYqjA5VTZvJTqHxLqHVWCUhFzhhZqEnJ0CeJi9o03ApfKn5PgxkZbH
yHIqxvItJCI7YnveF2Vx1W9uhMW9LDu68nib9c+HQ3SEpmdHaN4E8e715uXN
6d3pz3fXN3H35YePi+PvL866Q4rI1J6wXFkxlCfo1f9PIZTD6eDzr8fjwean
6KLb33lT/bqYH//2/reBfzit72/qN+36oD0YBSe37UW4OPzh8/W41ZieDn97
c/IBfc6/Hn7X6L25bX1ejmtvT49fti9uv/86GvizRvVr0Jvettufx+fjo73h
zq+18Wm3Hd/F619vxvXR/q9o8dz1Pk389uGPox8P96/eVE+C4G6z2qyq724+
//DT2D8+Hk7+evJJYi+vnjDxkvcQAJnTZEq+8BHtboGA8P7xOKwIC47IF6AJ
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

-->

</rfc>
