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


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

]>


<rfc ipr="trust200902" docName="draft-ietf-lamps-e2e-mail-guidance-14" category="info" submissionType="IETF">
  <front>
    <title>Guidance on End-to-End E-mail Security</title>

    <author initials="D. K." surname="Gillmor" fullname="Daniel Kahn Gillmor" role="editor">
      <organization abbrev="ACLU">American Civil Liberties Union</organization>
      <address>
        <postal>
          <street>125 Broad St.</street>
          <city>New York, NY</city>
          <code>10004</code>
          <country>USA</country>
        </postal>
        <email>dkg@fifthhorseman.net</email>
      </address>
    </author>
    <author initials="B." surname="Hoeneisen" fullname="Bernie Hoeneisen" role="editor">
      <organization>pEp Foundation</organization>
      <address>
        <postal>
          <street>Oberer Graben 4</street>
          <city>CH-8400 Winterthur</city>
          <country>Switzerland</country>
        </postal>
        <email>bernie.hoeneisen@pep.foundation</email>
        <uri>https://pep.foundation/</uri>
      </address>
    </author>
    <author initials="A." surname="Melnikov" fullname="Alexey Melnikov" role="editor">
      <organization>Isode Ltd</organization>
      <address>
        <postal>
          <street>14 Castle Mews</street>
          <city>Hampton, Middlesex</city>
          <code>TW12 2NP</code>
          <country>UK</country>
        </postal>
        <email>alexey.melnikov@isode.com</email>
      </address>
    </author>

    <date year="2024" month="February" day="01"/>

    <area>int</area>
    <workgroup>lamps</workgroup>
    <keyword>Internet-Draft</keyword>

    <abstract>


<t>End-to-end cryptographic protections for e-mail messages can provide useful security.
However, the standards for providing cryptographic protection are extremely flexible.
That flexibility can trap users and cause surprising failures.
This document offers guidance for mail user agent implementers to help mitigate those risks, and to make end-to-end e-mail simple and secure for the end user.
It provides a useful set of vocabulary as well as recommendations to avoid common failures.
It also identifies a number of currently unsolved usability and interoperability problems.</t>



    </abstract>

    <note title="About This Document" removeInRFC="true">
      <t>
        The latest revision of this draft can be found at <eref target="https://dkg.gitlab.io/e2e-mail-guidance/"/>.
        Status information for this document may be found at <eref target="https://datatracker.ietf.org/doc/draft-ietf-lamps-e2e-mail-guidance/"/>.
      </t>
      <t>
        Discussion of this document takes place on the
        LAMPS Working Group mailing list (<eref target="mailto:spasm@ietf.org"/>),
        which is archived at <eref target="https://mailarchive.ietf.org/arch/browse/spasm/"/>.
        Subscribe at <eref target="https://www.ietf.org/mailman/listinfo/spasm/"/>.
      </t>
      <t>Source for this draft and an issue tracker can be found at
        <eref target="https://gitlab.com/dkg/e2e-mail-guidance"/>.</t>
    </note>


  </front>

  <middle>


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

<t>E-mail end-to-end security using S/MIME (<xref target="RFC8551"/>) and PGP/MIME (<xref target="RFC3156"/>) cryptographic standards can provide integrity, authentication and confidentiality to MIME (<xref target="RFC4289"/>) e-mail messages.</t>

<t>However, there are many ways that a receiving mail user agent can misinterpret or accidentally break these security guarantees.
For example, <xref target="EFAIL"></xref>'s "Direct Exfiltration" attacks leak cleartext due to attacks that splice existing ciphertext into novel messages, which then are handled optimistically (and wrongly) by many mail user agents.</t>

<t>A mail user agent that interprets a message with end-to-end cryptographic protections needs to do so defensively, staying alert to different ways that these protections can be bypassed by mangling (either malicious or accidental) or a failed user experience.</t>

<t>A mail user agent that generates a message with end-to-end cryptographic protections should be aware of these defensive interpretation strategies, and should compose any new outbound message conservatively if they want the protections to remain intact.</t>

<t>This document offers guidance to the implementer of a mail user agent that provides these cryptographic protections, whether for sending or receiving mail.
An implementation that follows this guidance will provide its users with stronger and easier-to-understand security properties, and will also offer more reliable interoperability for messages exchanged with other implementations.</t>

<t>In <xref target="future-work"/>, this document also identifies a number of interoperability and usability concerns for end-to-end cryptographic e-mail which have no current broadly accepted technical standard for resolution.
One major area not covered in this document is the acquisition and long-term maintenance of cryptographic identity information and metadata across multiple mail user agents controlled by the same user.</t>

<t>The key words "<bcp14>MUST</bcp14>", "<bcp14>MUST NOT</bcp14>", "<bcp14>REQUIRED</bcp14>", "<bcp14>SHALL</bcp14>", "<bcp14>SHALL
NOT</bcp14>", "<bcp14>SHOULD</bcp14>", "<bcp14>SHOULD NOT</bcp14>", "<bcp14>RECOMMENDED</bcp14>", "<bcp14>NOT RECOMMENDED</bcp14>",
"<bcp14>MAY</bcp14>", and "<bcp14>OPTIONAL</bcp14>" in this document are to be interpreted as
described in BCP 14 <xref target="RFC2119"/> <xref target="RFC8174"/> when, and only when, they
appear in all capitals, as shown here.</t>

<section anchor="terminology"><name>Terminology</name>

<t>For the purposes of this document, we define the following concepts:</t>

<t><list style="symbols">
  <t><em>MUA</em> is short for Mail User Agent; an e-mail client.</t>
  <t><em>Protection</em> of message data refers to cryptographic encryption and/or signatures, providing confidentiality, authenticity, and/or integrity.</t>
  <t><em>Cryptographic Layer</em>, <em>Cryptographic Envelope</em>, <em>Cryptographic Payload</em>, <em>Cryptographic Summary</em>, and <em>Errant Cryptographic Layer</em> are defined in <xref target="cryptographic-structure"/></t>
  <t>A <em>well-formed</em> e-mail message with cryptographic protection has both a <em>Cryptographic Envelope</em> and a <em>Cryptographic Payload</em>.</t>
  <t><em>Structural Header Fields</em> are documented in <xref target="structural-header-fields"/>.</t>
  <t><em>User-Facing Header Fields</em> are documented in <xref target="user-facing-header-fields"/>.</t>
  <t><em>Main Body Part</em> is the part (or parts) that are typically rendered to the user as the message itself (not "as an attachment").  See <xref target="main-body-part"/>.</t>
</list></t>

<t>This document contains extensive discussion about end-to-end cryptographic protections in e-mail, while acknowledging that many MUAs have no capabilities for end-to-end cryptographic protections at all.
We divide MUAs into three distinct profiles:</t>

<t><list style="symbols">
  <t>A <em>Non-cryptographic</em> MUA has no capabilities for end-to-end cryptographic protections.</t>
  <t>A <em>Conformant</em> MUA follows the guidance in this document when dealing with end-to-end cryptographic protections.</t>
  <t>A <em>Legacy</em> MUA has capabilities for end-to-end cryptographic protections, but does not adhere to the the guidance in this document.</t>
</list></t>

<t>At the time of the writing of this document, most MUAs with cryptographic protections are legacy MUAs.</t>

<section anchor="structural-header-fields"><name>Structural Header Fields</name>

<t>A message header field named <spanx style="verb">MIME-Version</spanx>, or whose name begins with <spanx style="verb">Content-</spanx> is referred to in this document as a "structural" header field.
This is a less-ambiguous name for what <xref target="RFC2045"/> calls "MIME Header Fields".</t>

<t>These header fields indicate something about the specific MIME part they are attached to, and cannot be transferred or copied to other parts without endangering the readability of the message.</t>

<t>This includes:</t>

<t><list style="symbols">
  <t><spanx style="verb">MIME-Version</spanx></t>
  <t><spanx style="verb">Content-Type</spanx></t>
  <t><spanx style="verb">Content-Transfer-Encoding</spanx></t>
  <t><spanx style="verb">Content-Disposition</spanx></t>
</list></t>

</section>
<section anchor="user-facing-header-fields"><name>User-Facing Header Fields</name>

<t>Of all the header fields that an e-mail message may contain, only a handful are typically presented directly to the user.
This document refers to them as "user-facing" header fields.
Typically, user-facing header fields are:</t>

<t><list style="symbols">
  <t><spanx style="verb">Subject</spanx></t>
  <t><spanx style="verb">From</spanx></t>
  <t><spanx style="verb">To</spanx></t>
  <t><spanx style="verb">Cc</spanx></t>
  <t><spanx style="verb">Date</spanx></t>
  <t><spanx style="verb">Reply-To</spanx></t>
  <t><spanx style="verb">Followup-To</spanx></t>
  <t><spanx style="verb">Sender</spanx></t>
  <t><spanx style="verb">Resent-From</spanx></t>
  <t><spanx style="verb">Resent-To</spanx></t>
  <t><spanx style="verb">Resent-Cc</spanx></t>
  <t><spanx style="verb">Resent-Date</spanx></t>
  <t><spanx style="verb">Resent-Sender</spanx></t>
</list></t>

<t>The above list are the header fields most often presented directly to the user who views a message, though an MUA may also decide to treat any other header field as "user-facing".
Of course, many of these header fields are entirely absent from any given message, and an absent header field is not presented to the user at all.</t>

<t>Note that the resending header fields (those beginning with <spanx style="verb">Resent-</spanx>) are typically only added by an intervening MUA (see <xref section="3.6.6" sectionFormat="of" target="RFC5322"/> and <xref target="intervening-mua"/> of this document).
As such, though they may in some cases be presented to the user, they will typically not bear any end-to-end cryptographic protection (even if the original header fields of a message are protected, see <xref target="message-header-fields"/>), because they are unknown to the original sender.</t>

<t>Other header fields may affect the visible rendering of the message (e.g., <spanx style="verb">References</spanx> and <spanx style="verb">In-Reply-To</spanx> may affect the placement of a message in a threaded discussion; or the <spanx style="verb">List-*</spanx> and <spanx style="verb">Archived-At</spanx> header fields added by mailing lists may cause additional buttons to be displayed during rendering), but they are not directly displayed to the user and so are not considered "user-facing".</t>

</section>
</section>
</section>
<section anchor="usability"><name>Usability</name>

<t>Any MUA that enables its user to transition from unprotected messages to messages with end-to-end cryptographic protection needs to consider how the user understands this transition.
That said, the primary goal of the user of an MUA is communication -- so interface elements that get in the way of communication should be avoided where possible.</t>

<t>Furthermore, it is a near certainty that the user will continue to encounter unprotected messages, and may need to send unprotected messages (for example, if a given recipient cannot handle cryptographic protections).
This means that the MUA needs to provide the user with some guidance, so that they understand what protections any given message or conversation has.
But the user should not be overwhelmed with choices or presented with unactionable information.</t>

<section anchor="simplicity"><name>Simplicity</name>

<t>The end user (the operator of the MUA) is unlikely to understand complex end-to-end cryptographic protections on any e-mail message, so keep it simple.</t>

<t>For clarity to the user, any cryptographic protections should apply to the message as a whole, not just to some subparts.</t>

<t>This is true for message composition: the standard message composition user interface of an MUA should offer minimal controls which indicate which types of protection to apply to the new message as a whole.</t>

<t>This is also true for message interpretation: the standard message rendering user interface of an MUA should offer a minimal, clear indicator about the end-to-end cryptographic status of the message as a whole.</t>

<t>See <xref target="types-of-protection"/> for more detail about mental models and cryptographic status.</t>

<t>(It is of course possible that a message forwarded as a MIME attachment could have its own cryptographic status while still being a message subpart; but that status should be distinct from the status of the enclosing message.)</t>

</section>
<section anchor="similar-ux"><name>E-mail Users Want a Familiar Experience</name>

<t>A person communicating over the Internet today often has many options for reaching their desired correspondent, including web-based bulletin boards, contact forms, and instant messaging services.</t>

<t>E-mail offers a few distinctions from these other systems, most notably features like:</t>

<t><list style="symbols">
  <t>Ubiquity: Most correspondents will have an e-mail address, while not everyone is present on every alternate messaging service, particularly those that have reliable end-to-end cryptographic protections,</t>
  <t>Federation: interaction between users on distinct domains who have not agreed on a common communications provider is still possible, and</t>
  <t>User Control: the user can interact with the e-mail system using an MUA of their choosing, including automation and other control over their preferred and/or customized workflow.</t>
</list></t>

<t>Other systems (like some popular instant messaging applications, such as WhatsApp and Signal Private Messenger) offer built-in end-to-end cryptographic protections by default, which are simpler for the user to understand.
("All the messages I see on Signal are confidential and integrity-protected" is a clean user story)</t>

<t>A user of e-mail is likely using e-mail instead of other systems because of the distinctions outlined above.
When adding end-to-end cryptographic protection to an e-mail endpoint, care should be taken not to negate any of the distinct features of e-mail as a whole.
If these features are violated to provide end-to-end crypto, the user may just as well choose one of the other systems that don't have the drawbacks that e-mail has.
Implmenters should try to provide end-to-end protections that retain the familiar experience of e-mail itself.</t>

<t>Furthermore, an e-mail user is likely to regularly interact with other e-mail correspondents who <em>cannot</em> handle or produce end-to-end cryptographic protections.
Care should be taken that enabling cryptography in an MUA does not inadvertently limit the ability of the user to interact with correspondents who use legacy or non-cryptographic MUAs.</t>

</section>
<section anchor="security-indicators"><name>Warning About Failure vs. Announcing Success</name>

<t>Moving the web from http to https offers useful historical similarities to adding end-to-end encryption to e-mail.</t>

<t>In particular, the indicators of what is "secure" vs. "insecure" for web browsers have changed over time.
For example, years ago the default experience was http, and https sites were flagged with "secure" indicators like a lock icon.
Starting in 2018, some browsers reversed that process by downplaying https, and instead visibly marking http as "not secure" (see <xref target="chrome-indicators"></xref>).</t>

<t>By analogy, when the user of an MUA first enables end-to-end cryptographic protection, it's likely that they will want to see which messages <em>have</em> protection (that is, the security indicators amenable to a conformant MUA as of 2024 are most likely to be comparable to those of a pre-2018 web browser).
But a user whose private e-mail communications with a given correspondent, or within a given domain are known to be entirely end-to-end protected might instead want to know which messages do <em>not</em> have the expected protections.</t>

<t>Note also that some messages may be expected to be confidential, but other messages are expected to be public -- the types of protection (see <xref target="types-of-protection"/>) that apply to each particular message will be different.
And the types of protection that are <em>expected</em> to be present in any context might differ (for example, by sender, by thread, or by date).</t>

<t>It is out of scope for this document to define expectations about protections for any given message, but an implementer who cares about usable experience should be deliberate and judicious about the expectations their interface assumes that the user has in a given context.
See also <xref target="expect-e2e"/> for future work.</t>

</section>
</section>
<section anchor="types-of-protection"><name>Types of Protection</name>

<t>A given message might be:</t>

<t><list style="symbols">
  <t>signed,</t>
  <t>encrypted,</t>
  <t>both signed and encrypted, or</t>
  <t>none of the above.</t>
</list></t>

<t>Given that many e-mail messages offer no cryptographic protections, the user needs to be able to detect which protections are present for any given message.</t>

<section anchor="simple-mental-model"><name>Simplified Mental Model</name>

<t>To the extent that an e-mail message actually does have end-to-end cryptographic protections, those protections need to be visible and comprehensible to the end users: both the sending user and the receiving user.
If either user is unaware of the protections, then they do not effectively extend all the way to the "end".</t>

<t>However, most users do not have (or want to have) a sophisticated mental model of what kinds of protections can be associated with a given message.
Even the four states above approach the limits of complexity for an interface for normal users.</t>

<t>While <xref target="no-encrypted-only"/> recommends avoiding deliberate creation of encrypted-only messages, some messages may end up in the encrypted-only state due to signature failure or certificate revocation.</t>

<t>A simple model for the receiving user could be that a message is in one of three normal states, which align with the only reasonable choices for message composition:</t>

<t><list style="symbols">
  <t>Unprotected</t>
  <t>Verified (has a valid signature from the apparent sender of the message)</t>
  <t>Confidential (meaning, encrypted, with a valid signature from the apparent sender of the message)</t>
</list></t>

<t>However, one error state exists for received mail that does not correspond to a reasonable choice for message composition:</t>

<t><list style="symbols">
  <t>Encrypted But Unverified (meaning, encrypted without a valid signature from the apparent sender of the message)</t>
</list></t>

<t>Note that this last state is not "Confidential" (a secret shared exclusively between the participants in the communication) because the recipient does not know for sure who sent it.</t>

<t>In an ecosystem where encrypted-only messages are never deliberately sent (see <xref target="no-encrypted-only"/>), representing an Encrypted But Unverified message as a type of user-visible error is not unreasonable.
However, this is not the state of the global e-mail ecosystem when this document was written, since some legacy MUAs permit sending encrypted-but-unsigned mail (see <xref target="expect-e2e"/> for possible future guidance).</t>

<t>Alternately, an MUA may prefer to represent the state of a Encrypted but Unverified message to the user as though it was Unprotected, since no verification is possible.
However the MUA represents the message to the user, though, it <bcp14>MUST NOT</bcp14> leak cleartext of an encrypted message (even an Encrypted but Unverified message) in subsequent replies (see <xref target="composing-reply"/>) or similar replications of the message.</t>

<t>Note that a cleartext message with an invalid signature <bcp14>SHOULD NOT</bcp14> be represented to the user as anything other than Unprotected (see <xref target="signature-failures"/>), unless the MUA is providing the user with debugging information.</t>

<t>At the time this document was written, the global e-mail ecosystem contains a heterogeneous mix of legacy and non-cryptographic MUAs.
In such an ecosystem, a conformant MUA may prefer instead to represent "Verified" and "Encrypted" as orthogonal states of any given received message.
While this model does not precisely match the choice a user makes when composing a message, it may align more with the reality of the range of messages they receive.</t>

</section>
<section anchor="one-cryptographic-status-per-message"><name>One Cryptographic Status Per Message</name>

<t>Some MUAs may attempt to generate multiple copies of a given e-mail message, with different copies offering different types of protection (for example, opportunistically encrypting on a per-recipient basis).
A message resulting from this approach will have a cryptographic state that few users will understand.
Even if the sender understands the different statuses of the different copies, the recipients of the messages may not understand (each recipient might not even know about the other copies).
See for example the discussion in <xref target="mixed-recipients"/> for how this can go wrong.</t>

<t>For comprehensibility, a conformant MUA <bcp14>SHOULD NOT</bcp14> create multiple copies of a given message that differ in the types of end-to-end cryptographic protections afforded.</t>

<t>For opportunistic cryptographic protections that are not surfaced to the user (that is, that are not end-to-end), other mechanisms like transport encryption (<xref target="RFC3207"/>) or domain-based signing (<xref target="RFC6376"/>) may be preferable due to ease of implementation and deployment.
These opportunistic transport protections are orthogonal to the end-to-end protections described in this document.</t>

<t>To the extent that opportunistic message protections are made visible to the user for a given copy of a message, a conformant MUA will distinguish that status from the message's end-to-end cryptographic status.
But the potential confusion caused by rendering this complex, hybrid state may not be worth the value of additional knowledge gained by the user.
The benefits of opportunistic protections accrue (or don't) even without visibility to the user (see <xref target="RFC7435"/>).</t>

<t>The user needs a single clear, simple, and correct indication about the end-to-end cryptographic status of any given message.
See <xref target="cryptographic-summary"/> for more details.</t>

</section>
</section>
<section anchor="cryptographic-structure"><name>Cryptographic MIME Message Structure</name>

<t>Implementations use the structure of an e-mail message to establish (when sending) and understand (when receiving) the cryptographic status of the message.
This section establishes some conventions about how to think about message structure.</t>

<section anchor="cryptographic-layer"><name>Cryptographic Layers</name>

<t>"Cryptographic Layer" refers to a MIME substructure that supplies some cryptographic protections to an internal MIME subtree.
The internal subtree is known as the "protected part" though of course it may itself be a multipart object.</t>

<t>In the diagrams below, <u>↧</u> indicates "decrypts to", and <u>⇩</u> indicates "unwraps to".</t>

<section anchor="smime-cryptographic-layers"><name>S/MIME Cryptographic Layers</name>

<t>For S/MIME <xref target="RFC8551"></xref>, there are four forms of Cryptographic Layers: multipart/signed, PKCS#7 signed-data, PKCS7 enveloped-data, PKCS7 authEnveloped-data.</t>

<section anchor="smime-multipart-signed"><name>S/MIME Multipart Signed Cryptographic Layer</name>

<figure><artwork><![CDATA[
└┬╴multipart/signed; protocol="application/pkcs7-signature"
 ├─╴[protected part]
 └─╴application/pkcs7-signature
]]></artwork></figure>

<t>This MIME layer offers authentication and integrity.</t>

</section>
<section anchor="smime-pkcs7-signed-data"><name>S/MIME PKCS7 signed-data Cryptographic Layer</name>

<figure><artwork><![CDATA[
└─╴application/pkcs7-mime; smime-type="signed-data"
 ⇩ (unwraps to)
 └─╴[protected part]
]]></artwork></figure>

<t>This MIME layer offers authentication and integrity.</t>

</section>
<section anchor="smime-pkcs7-enveloped-data"><name>S/MIME PKCS7 enveloped-data Cryptographic Layer</name>

<figure><artwork><![CDATA[
└─╴application/pkcs7-mime; smime-type="enveloped-data"
 ↧ (decrypts to)
 └─╴[protected part]
]]></artwork></figure>

<t>This MIME layer offers confidentiality.</t>

</section>
<section anchor="smime-pkcs7-authenveloped-data"><name>S/MIME PKCS7 authEnveloped-data Cryptographic Layer</name>

<figure><artwork><![CDATA[
└─╴application/pkcs7-mime; smime-type="authEnveloped-data"
 ↧ (decrypts to)
 └─╴[protected part]
]]></artwork></figure>

<t>This MIME layer offers confidentiality and integrity.</t>

<t>Note that <spanx style="verb">enveloped-data</spanx> (<xref target="smime-pkcs7-enveloped-data"/>) and <spanx style="verb">authEnveloped-data</spanx> (<xref target="smime-pkcs7-authenveloped-data"/>) have identical message structure and very similar semantics.
The only difference between the two is ciphertext malleability.</t>

<t>The examples in this document only include <spanx style="verb">enveloped-data</spanx>, but the implications for that layer apply to <spanx style="verb">authEnveloped-data</spanx> as well.</t>

</section>
<section anchor="pkcs7-compression-is-not-a-cryptographic-layer"><name>PKCS7 Compression is NOT a Cryptographic Layer</name>

<t>The Cryptographic Message Syntax (CMS) provides a MIME compression layer (<spanx style="verb">smime-type="compressed-data"</spanx>), as defined in <xref target="RFC3274"/>.
While the compression layer is technically a part of CMS, it is not considered a Cryptographic Layer for the purposes of this document.</t>

</section>
</section>
<section anchor="pgpmime-cryptographic-layers"><name>PGP/MIME Cryptographic Layers</name>

<t>For PGP/MIME <xref target="RFC3156"></xref> there are two forms of Cryptographic Layers, signing and encryption.</t>

<section anchor="pgpmime-multipart-signed"><name>PGP/MIME Signing Cryptographic Layer (multipart/signed)</name>

<figure><artwork><![CDATA[
└┬╴multipart/signed; protocol="application/pgp-signature"
 ├─╴[protected part]
 └─╴application/pgp-signature
]]></artwork></figure>

<t>This MIME layer offers authenticity and integrity.</t>

</section>
<section anchor="pgpmime-multipart-encrypted"><name>PGP/MIME Encryption Cryptographic Layer (multipart/encrypted)</name>

<figure><artwork><![CDATA[
└┬╴multipart/encrypted
 ├─╴application/pgp-encrypted
 └─╴application/octet-stream
  ↧ (decrypts to)
  └─╴[protected part]
]]></artwork></figure>

<t>This MIME layer can offer any of:</t>

<t><list style="symbols">
  <t>confidentiality (via a Symmetrically Encrypted Data Packet, see <xref section="5.7" sectionFormat="of" target="I-D.ietf-openpgp-crypto-refresh-13"/>; an MUA <bcp14>MUST NOT</bcp14> generate this form due to ciphertext malleability)</t>
  <t>confidentiality and integrity (via a Symmetrically Encrypted Integrity Protected Data Packet (SEIPD), see <xref section="5.13" sectionFormat="of" target="I-D.ietf-openpgp-crypto-refresh-13"/>), or</t>
  <t>confidentiality, integrity, and authenticity all together (by including an OpenPGP Signature Packet within the SEIPD).</t>
</list></t>

</section>
</section>
</section>
<section anchor="cryptographic-envelope"><name>Cryptographic Envelope</name>

<t>The Cryptographic Envelope is the largest contiguous set of Cryptographic Layers of an e-mail message starting with the outermost MIME type (that is, with the Content-Type of the message itself).</t>

<t>If the Content-Type of the message itself is not a Cryptographic Layer, then the message has no cryptographic envelope.</t>

<t>"Contiguous" in the definition above indicates that if a Cryptographic Layer is the protected part of another Cryptographic Layer, the layers together comprise a single Cryptographic Envelope.</t>

<t>Note that if a non-Cryptographic Layer intervenes, all Cryptographic Layers within the non-Cryptographic Layer <em>are not</em> part of the Cryptographic Envelope.
They are Errant Cryptographic Layers (see <xref target="errant-cryptographic-layers"/>).</t>

<t>Note also that the ordering of the Cryptographic Layers implies different cryptographic properties.
A signed-then-encrypted message is different than an encrypted-then-signed message.
See <xref target="sign-then-encrypt"/>.</t>

</section>
<section anchor="cryptographic-payload"><name>Cryptographic Payload</name>

<t>The Cryptographic Payload of a message is the first non-Cryptographic Layer -- the "protected part" -- within the Cryptographic Envelope.</t>

</section>
<section anchor="types-of-cryptographic-envelope"><name>Types of Cryptographic Envelope</name>

<section anchor="simple-cryptographic-envelopes"><name>Simple Cryptographic Envelopes</name>

<t>As described above, if the "protected part" identified in the section above is not itself a Cryptographic Layer, that part <em>is</em> the Cryptographic Payload.</t>

<t>If the application wants to generate a message that is both encrypted and signed, it <bcp14>MAY</bcp14> use the simple MIME structure from <xref target="pgpmime-multipart-encrypted"/> by ensuring that the <xref target="I-D.ietf-openpgp-crypto-refresh-13"></xref> Encrypted Message within the <spanx style="verb">application/octet-stream</spanx> part contains an <xref target="I-D.ietf-openpgp-crypto-refresh-13"></xref> Signed Message (the final option described in <xref target="pgpmime-multipart-encrypted"/>).</t>

</section>
<section anchor="multilayer-cryptographic-envelopes"><name>Multilayer Cryptographic Envelopes</name>

<t>It is possible to construct a Cryptographic Envelope consisting of multiple layers with either S/MIME or PGP/MIME , for example using the following structure:</t>

<figure><artwork><![CDATA[
A └─╴application/pkcs7-mime; smime-type="enveloped-data"
B  ↧ (decrypts to)
C  └─╴application/pkcs7-mime; smime-type="signed-data"
D   ⇩ (unwraps to)
E   └─╴[protected part]
]]></artwork></figure>

<t>When handling such a message, the properties of the Cryptographic Envelope are derived from the series <spanx style="verb">A</spanx>, <spanx style="verb">C</spanx>.</t>

<t>As noted in <xref target="simple-cryptographic-envelopes"/>, PGP/MIME applications also have a simpler MIME construction available with the same cryptographic properties.</t>

</section>
</section>
<section anchor="errant-cryptographic-layers"><name>Errant Cryptographic Layers</name>

<t>Due to confusion, malice, or well-intentioned tampering, a message may contain a Cryptographic Layer that is not part of the Cryptographic Envelope.
Such a layer is an Errant Cryptographic Layer.</t>

<t>An Errant Cryptographic Layer <bcp14>MUST NOT</bcp14> contribute to the message's overall cryptographic state.</t>

<t>Guidance for dealing with Errant Cryptographic Layers can be found in <xref target="errant-layers"/>.</t>

<section anchor="mailing-list-wrapping"><name>Mailing List Wrapping</name>

<t>Some mailing list software will re-wrap a well-formed signed message before re-sending to add a footer, resulting in the following structure seen by recipients of the e-mail:</t>

<figure><artwork><![CDATA[
H └┬╴multipart/mixed
I  ├┬╴multipart/signed
J  │├─╴text/plain
K  │└─╴application/pgp-signature
L  └─╴text/plain
]]></artwork></figure>

<t>In this message, <spanx style="verb">L</spanx> is the footer added by the mailing list.  <spanx style="verb">I</spanx> is now an Errant Cryptographic Layer.</t>

<t>Note that this message has no Cryptographic Envelope at all.</t>

<t>It is <bcp14>NOT RECOMMENDED</bcp14> to produce e-mail messages with this structure, because a legacy MUA may present the data in part <spanx style="verb">L</spanx> as though it were part of <spanx style="verb">J</spanx>, though they have different cryptographic properties.
In particular, if the user believes that the entire message is signed, but cannot distinguish <spanx style="verb">L</spanx> from <spanx style="verb">J</spanx> then the author of <spanx style="verb">L</spanx> can effectively tamper with content of the signed message, breaking the user's expectation of integrity and authenticity.</t>

</section>
<section anchor="baroque-example"><name>A Baroque Example</name>

<t>Consider a message with the following overcomplicated structure:</t>

<figure><artwork><![CDATA[
M └┬╴multipart/encrypted
N  ├─╴application/pgp-encrypted
O  └─╴application/octet-stream
P   ↧ (decrypts to)
Q   └┬╴multipart/signed
R    ├┬╴multipart/mixed
S    │├┬╴multipart/signed
T    ││├─╴text/plain
U    ││└─╴application/pgp-signature
V    │└─╴text/plain
W    └─╴application/pgp-signature
]]></artwork></figure>

<t>The 3 Cryptographic Layers in such a message are rooted in parts <spanx style="verb">M</spanx>, <spanx style="verb">Q</spanx>, and <spanx style="verb">S</spanx>.
But the Cryptographic Envelope of the message consists only of the properties derived from the series <spanx style="verb">M</spanx>, <spanx style="verb">Q</spanx>.
The Cryptographic Payload of the message is part <spanx style="verb">R</spanx>.
Part <spanx style="verb">S</spanx> is an Errant Cryptographic Layer.</t>

<t>Note that this message has both a Cryptographic Envelope <em>and</em> an Errant Cryptographic Layer.</t>

<t>It is <bcp14>NOT RECOMMENDED</bcp14> to generate messages with such complicated structures.
Even if a receiving MUA can parse this structure properly, it is nearly impossible to render in a way that the user can reason about the cryptographic properties of part <spanx style="verb">T</spanx> compared to part <spanx style="verb">V</spanx>.</t>

</section>
</section>
<section anchor="cryptographic-summary"><name>Cryptographic Summary</name>

<t>The cryptographic status of an e-mail message with end-to-end cryptographic protections is known as the Cryptographic Summary.
A reasonable, simple Cryptographic Summary is derived from the aggregate properties of the layers in the Cryptographic Envelope.
This is a conceptual tool and a feature that an MUA can use to guide behavior and user experience, but it is not necessarily always directly exposed in any given user interface.
See <xref target="well-formed"/> for guidance and considerations about rendering the Cryptographic Summary to the user.</t>

</section>
</section>
<section anchor="message-composition"><name>Message Composition</name>

<t>This section describes the ideal composition of an e-mail message with end-to-end cryptographic protection.
A message composed with this form is most likely to achieve its end-to-end security goals.</t>

<section anchor="composition"><name>Message Composition Algorithm</name>

<t>This section roughly describes the steps that an MUA should use to compose a cryptographically-protected message that has a proper cryptographic envelope and payload.</t>

<t>The message composition algorithm takes three parameters:</t>

<t><list style="symbols">
  <t><spanx style="verb">origbody</spanx>: the traditional unprotected message body as a well-formed MIME tree (possibly just a single MIME leaf part).
As a well-formed MIME tree, <spanx style="verb">origbody</spanx> already has structural header fields present (see <xref target="structural-header-fields"/>).</t>
  <t><spanx style="verb">origheaders</spanx>: the intended non-structural header fields for the message, represented here as a list of <spanx style="verb">(h,v)</spanx> pairs, where <spanx style="verb">h</spanx> is a header field name and <spanx style="verb">v</spanx> is the associated value.</t>
  <t><spanx style="verb">crypto</spanx>: The series of cryptographic protections to apply (for example, "sign with the secret key corresponding to X.509 certificate X, then encrypt to X.509 certificates X and Y").
This is a routine that accepts a MIME tree as input (the Cryptographic Payload), wraps the input in the appropriate Cryptographic Envelope, and returns the resultant MIME tree as output.</t>
</list></t>

<t>The algorithm returns a MIME object that is ready to be injected into the mail system:</t>

<t><list style="symbols">
  <t>Apply <spanx style="verb">crypto</spanx> to <spanx style="verb">origbody</spanx>, yielding MIME tree <spanx style="verb">output</spanx></t>
  <t>For each header name and value <spanx style="verb">(h,v)</spanx> in <spanx style="verb">origheaders</spanx>:
  <list style="symbols">
      <t>Add header <spanx style="verb">h</spanx> to <spanx style="verb">output</spanx> with value <spanx style="verb">v</spanx></t>
    </list></t>
  <t>Return <spanx style="verb">output</spanx></t>
</list></t>

</section>
<section anchor="sign-then-encrypt"><name>Encryption Outside, Signature Inside</name>

<t>An e-mail message that is both signed and encrypted is signed <em>inside</em> the encryption, and not the other way around.
For example, when crafting an encrypted and signed message using a simple Cryptographic Envelope of a single layer (<xref target="simple-cryptographic-envelopes"/>) with PGP/MIME, the OpenPGP Encrypted Message object should contain an OpenPGP Signed Message.
Likewise, when using a multilayer Cryptographic Envelope (<xref target="multilayer-cryptographic-envelopes"/>), the outer layer should be an encryption layer and the inner layer should be a signing layer.</t>

<t>Putting the signature inside the encryption has two advantages:</t>

<t><list style="symbols">
  <t>The details of the signature remain confidential, visible only to the parties capable of decryption.</t>
  <t>Any mail transport agent that modifies the message is unlikely to be able to accidentally break the signature.</t>
</list></t>

<t>A conformant MUA <bcp14>MUST NOT</bcp14> generate an encrypted and signed message where the only signature is outside the encryption.</t>

</section>
<section anchor="no-encrypted-only"><name>Avoid Offering Encrypted-only Messages</name>

<t>When generating an e-mail, the user has options about what forms of end-to-end cryptographic protections to apply to it.</t>

<t>In some cases, offering any end-to-end cryptographic protection is harmful: it may confuse the recipient and offer no benefit.</t>

<t>In other cases, signing a message is useful (authenticity and integrity are desirable) but encryption is either impossible (for example, if the sender does not know how to encrypt to all recipients) or meaningless (for example, an e-mail message to a mailing list that is intended to be published to a public archive).</t>

<t>In other cases, full end-to-end confidentiality, authenticity, and integrity are desirable.</t>

<t>There is no common use case for generating an e-mail message with end-to-end confidentiality but without authenticity or integrity.</t>

<t>A conformant MUA will keep its message composition interface simple, so when presenting the user with a choice of cryptographic protection, it <bcp14>MUST</bcp14> offer no more than three choices:</t>

<t><list style="symbols">
  <t>no end-to-end cryptographic protection</t>
  <t>Verified (signed only)</t>
  <t>Confidential (signed and encrypted)</t>
</list></t>

<t>Note that these choices correspond to the simplified mental model in <xref target="simple-mental-model"/>.</t>

<t>The alternative approach, offering the user two boolean choices during message composition (one choice about signing, another choice about encryption) is a common anti-pattern among legacy MUAs, and creates additional usability hurdles for normal users:</t>

<t><list style="symbols">
  <t>A user who wants to send a signed and encrypted message will have to click two buttons instead of one.</t>
  <t>A user who clicks "Encrypt" but neglects to click "Signed" may not understand that they are creating a message which cannot be authenticated by the receiver.</t>
</list></t>

</section>
<section anchor="composing-reply"><name>Composing a Reply Message</name>

<t>When replying to a message, most MUAs compose an initial draft of the reply that contains quoted text from the original message.
A responsible MUA will take precautions to avoid leaking the cleartext of an encrypted message in such a reply.</t>

<t>If the original message was end-to-end encrypted, the replying MUA <bcp14>MUST</bcp14> either:</t>

<t><list style="symbols">
  <t>compose the reply with end-to-end encryption, or</t>
  <t>avoid including quoted text from the original message.</t>
</list></t>

<t>In general, MUAs <bcp14>SHOULD</bcp14> prefer the first option: to compose an encrypted reply.
This is what users expect.</t>

<t>However, in some circumstances, the replying MUA cannot compose an encrypted reply.
For example, the MUA might not have a valid, unexpired, encryption-capable certificate for all recipients.
This can also happen during composition when a user adds a new recipient into the reply, or manually toggles the cryptographic protections to remove encryption.</t>

<t>In this circumstance, the composing MUA <bcp14>SHOULD</bcp14> strip the quoted text from the original message.</t>

<t>Note additional nuance about replies to malformed messages that contain encryption in <xref target="reply-to-errant-encryption"/>.</t>

</section>
</section>
<section anchor="message-interpretation"><name>Message Interpretation</name>

<t>Despite the best efforts of well-intentioned senders to create e-mail messages with well-formed end-to-end cryptographic protection, receiving MUAs will inevitably encounter some messages with malformed end-to-end cryptographic protection.</t>

<t>This section offers guidance on dealing with both well-formed and malformed messages containing Cryptographic Layers.</t>

<section anchor="well-formed"><name>Rendering Well-formed Messages</name>

<t>A message is well-formed when it has a Cryptographic Envelope, a Cryptographic Payload, and no Errant Cryptographic Layers.
Rendering a well-formed message is straightforward.</t>

<t>The receiving MUA evaluates and assembles the cryptographic properties of the Cryptographic Envelope into a Cryptographic Summary and displays that status to the user in a secure, strictly-controlled part of the UI.
In particular, the part of the UI used to render the Cryptographic Summary of the message <bcp14>MUST NOT</bcp14> be spoofable, modifiable, or otherwise controllable by the received message itself.
By analogy, consider the "lock" icon in the address bar of the web browser: regardless of the content of the webpage, the lock icon will only be displayed when the transport to the web server is adequately secured.</t>

<t>Aside from this Cryptographic Summary, the message itself <bcp14>MUST</bcp14> be rendered as though the Cryptographic Payload is the body of the message.
The Cryptographic Layers themselves <bcp14>SHOULD NOT</bcp14> be rendered as distinct objects unless the MUA is providing the user with debugging information.</t>

</section>
<section anchor="errant-layers"><name>Errant Cryptographic Layers</name>

<t>If an incoming message has any Errant Cryptographic Layers, a conformant interpreting MUA <bcp14>MUST</bcp14> ignore those layers when rendering the Cryptographic Summary of the message to the user.</t>

<section anchor="errant-signing-layer"><name>Errant Signing Layer</name>

<t>When rendering a message with an Errant Cryptographic Layer that provides authenticity and integrity (via signatures), the message should be rendered by replacing the Cryptographic layer with the part it encloses.</t>

<t>For example, a message with this structure:</t>

<figure><artwork><![CDATA[
A └┬╴multipart/mixed
B  ├╴text/plain
C  ├┬╴multipart/signed
D  │├─╴image/jpeg
E  │└─╴application/pgp-signature
F  └─╴text/plain
]]></artwork></figure>

<t>Should be rendered identically to this:</t>

<figure><artwork><![CDATA[
A └┬╴multipart/mixed
B  ├─╴text/plain
D  ├─╴image/jpeg
F  └─╴text/plain
]]></artwork></figure>

<t>In such a situation, a conformant MUA <bcp14>MUST NOT</bcp14> indicate in the Cryptographic Summary that the message is signed.
It <bcp14>MUST</bcp14> indicate that the message is Unprotected.</t>

<section anchor="exception-mailing-list-footers"><name>Exception: Mailing List Footers</name>

<t>The use case described in <xref target="mailing-list-wrapping"/> is common enough in some contexts that a conformant MUA <bcp14>MAY</bcp14> decide to handle it as a special exception.</t>

<t>If the MUA determines that the message comes from a mailing list (for example, it has a <spanx style="verb">List-ID</spanx> header), and it has a structure that appends a footer to a signing-only Cryptographic Layer with a valid signature, such as:</t>

<figure><artwork><![CDATA[
H └┬╴multipart/mixed
I  ├┬╴multipart/signed
J  │├─╴[protected part, may be arbitrary MIME subtree]
K  │└─╴application/{pgp,pkcs7}-signature
L  └─╴[footer, typically text/plain]
]]></artwork></figure>

<t>or:</t>

<figure><artwork><![CDATA[
H └┬╴multipart/mixed
I  ├─╴application/pkcs7-mime; smime-type="signed-data"
   │⇩ (unwraps to)
J  │└─╴[protected part, may be an arbitrary MIME subtree]
L  └─╴[footer, typically text/plain]
]]></artwork></figure>

<t>Then, the MUA <bcp14>MAY</bcp14> indicate to the user that this is a Verified message that has been wrapped by the mailing list.</t>

<t>In this case, the MUA <bcp14>MUST</bcp14> distinguish the footer (part <spanx style="verb">L</spanx>) from the protected part (part <spanx style="verb">J</spanx>) when rendering any information about the signature.</t>

<t>One way to do this is to offer the user two different views of the message: the "mailing list" view, which hides any positive Cryptographic Summary but shows the footer:</t>

<figure><artwork><![CDATA[
Cryptographic Protections: Unprotected
H └┬╴multipart/mixed
J  ├─╴[protected part, may be arbitrary MIME subtree]
L  └─╴[footer, typically text/plain]
]]></artwork></figure>

<t>or the "sender's view", which shows the Cryptographic Summary as Verified, but hides the footer:</t>

<figure><artwork><![CDATA[
Cryptographic Protections: Verified [details from part I]
J └─╴[protected part, may be arbitrary MIME subtree]
]]></artwork></figure>

</section>
</section>
<section anchor="errant-encryption-layer"><name>Errant Encryption Layer</name>

<t>An MUA may encounter a message with an Errant Cryptographic Layer that offers confidentiality (encryption), and the MUA is capable of decrypting it.</t>

<t>The user wants to be able to see the contents of any message that they receive, so a conformant MUA in this situation <bcp14>SHOULD</bcp14> decrypt the part.</t>

<t>In this case, though, a conformant MUA <bcp14>MUST NOT</bcp14> indicate in the message's Cryptographic Summary that the message itself was encrypted.
Such an indication could be taken to mean that other (non-encrypted) parts of the message arrived with cryptographic confidentiality.</t>

<t>Furthermore, when decrypting an Errant Cryptographic Layer, the MUA <bcp14>MUST</bcp14> treat the decrypted cleartext as a distinct MIME subtree, and not attempt to merge or splice it together with any other part of the message.
This offers protection against the direct exfiltration (also known as EFAIL-DE) attacks described in <xref target="EFAIL"></xref> and so-called <spanx style="verb">multipart/oracle</spanx> attacks described in <xref target="ORACLE"></xref>.</t>

<section anchor="reply-to-errant-encryption"><name>Replying to a Message with an Errant Encryption Layer</name>

<t>Note that there is an asymmetry here between rendering and replying to a message with an Errant Encryption Layer.</t>

<t>When rendering, the MUA does not indicate that the message was encrypted, even if some subpart of it was decrypted for rendering.</t>

<t>When composing a reply to a message that has any encryption layer, even an errant one, the reply message <bcp14>SHOULD</bcp14> be marked for encryption, unless quoted and attributed text is not included in the reply, as noted in <xref target="composing-reply"/>.</t>

<t>When composing a reply to a message with an errant cryptographic layer, a conformant MUA <bcp14>MUST NOT</bcp14> decrypt any errant cryptographic layers when generating quoted or attributed text.
This will typically mean either leaving the ciphertext itself in the generated reply message, or simply not generating any quoted or attributed text at all.
This offers protection against the reply-based attacks described in <xref target="REPLY"></xref>.</t>

<t>In all circumstances, if the reply message cannot be encrypted (or if the user elects to not encrypt the reply), the composed reply <bcp14>MUST NOT</bcp14> include any material from the decrypted subpart.</t>

</section>
</section>
<section anchor="avoiding-non-mime-cryptographic-mechanisms"><name>Avoiding Non-MIME Cryptographic Mechanisms</name>

<t>In some cases, there may be a cryptographic signature or encryption that does not coincide with a MIME boundary.
For example so-called "PGP Inline" messages typically contain base64-encoded ("ASCII-armored", see <xref section="6" sectionFormat="of" target="I-D.ietf-openpgp-crypto-refresh-13"/>) ciphertext, or within the content of a MIME part.</t>

<section anchor="do-not-validate-non-mime-signatures"><name>Do Not Validate Non-MIME Signatures</name>

<t>When encountering cryptographic signatures in these positions, a conformant MUA <bcp14>MUST NOT</bcp14> attempt to validate any signature.
It is challenging to communicate to the user exactly which part of such a message is covered by the signature, so it is better to leave the message marked as Unprotected.
See <xref target="SPOOFING"></xref> for examples of spoofed message signatures that rely on permissive legacy clients that are willing to validate signatures in poorly-structured messages.</t>

</section>
<section anchor="skip-or-isolate-non-mime-decryption-when-rendering"><name>Skip or Isolate Non-MIME Decryption When Rendering</name>

<t>When encountering what appears to be encrypted data not at a MIME boundary, a conformant MUA <bcp14>MAY</bcp14> decline to decrypt the data at all.</t>

<t>During message rendering, if a conformant MUA attempts decryption of such a non-MIME encrypted section of an e-mail, it <bcp14>MUST</bcp14> synthesize a separate MIME part to contain only the decrypted data, and not attempt to merge or splice that part together with any other part of the message.
Keeping such a section distinct and isolated from any other part of the message offers protection against the direct exfiltration attacks (also known as EFAIL-DE) described in <xref target="EFAIL"></xref>.</t>

</section>
<section anchor="do-not-decrypt-non-mime-decryption-when-replying"><name>Do Not Decrypt Non-MIME Decryption when Replying</name>

<t>When composing a reply to a message with such a non-MIME encrypted section, a conformant MUA <bcp14>MUST NOT</bcp14> decrypt any non-MIME encrypted section when generating quoted or attributed text, similar to the guidance in <xref target="reply-to-errant-encryption"/>.</t>

<t>This offers protection against the reply-based attacks described in <xref target="REPLY"></xref>.</t>

</section>
</section>
</section>
<section anchor="forwarded-messages-with-cryptographic-protection"><name>Forwarded Messages with Cryptographic Protection</name>

<t>An incoming e-mail message may include an attached forwarded message, typically as a MIME subpart with <spanx style="verb">Content-Type: message/rfc822</spanx> (<xref target="RFC5322"/>) or <spanx style="verb">Content-Type: message/global</spanx> (<xref target="RFC5355"/>).</t>

<t>Regardless of the cryptographic protections and structure of the incoming message, the internal forwarded message may have its own Cryptographic Envelope.</t>

<t>The Cryptographic Layers that are part of the Cryptographic Envelope of the forwarded message are not Errant Cryptographic Layers of the surrounding message -- they are simply layers that apply to the forwarded message itself.</t>

<t>A conformant rendering MUA <bcp14>MUST NOT</bcp14> conflate the cryptographic protections of the forwarded message with the cryptographic protections of the incoming message.</t>

<t>A conformant rendering MUA <bcp14>MAY</bcp14> render a Cryptographic Summary of the protections afforded to the forwarded message by its own Cryptographic Envelope, as long as that rendering is unambiguously tied to the forwarded message itself, and cannot be spoofed either by the enclosing message or by the forwarded message.</t>

</section>
<section anchor="signature-failures"><name>Signature failures</name>

<t>A cryptographic signature may fail in multiple ways.
A conformant receiving MUA that discovers a failed signature treats the message as though the signature did not exist.
This is similar to the standard guidance for about failed DKIM signatures (see <xref section="6.1" sectionFormat="of" target="RFC6376"/>).</t>

<t>A conformant MUA <bcp14>MUST NOT</bcp14> render a message with a failed signature as more dangerous or more dubious than a comparable message without any signature at all.
In both cases, the Cryptographic Summary should be Unprotected.</t>

<t>A conformant MUA that encounters an encrypted-and-signed message where the signature is invalid <bcp14>SHOULD</bcp14> treat the message the same way that it would treat a message that is encryption-only, unless the MUA is providing the user with debugging information.</t>

<t>Some different ways that a signature may be invalid on a given message:</t>

<t><list style="symbols">
  <t>the signature is not cryptographically valid (the math fails).</t>
  <t>the signature relies on suspect cryptographic primitives (e.g. over a deprecated digest algorithm, or was made by a weak key, e.g., 1024-bit RSA); note that this requires the rendering MUA to have an explicit policy about what cryptographic primitives are acceptable.</t>
  <t>the signature is made by a certificate which the receiving MUA does not have access to.</t>
  <t>the certificate used to verify the signature was revoked.</t>
  <t>the certificate used to verify the signature was expired at the time that the signature was made.</t>
  <t>the certificate used to verify the signature does not correspond to the author of the message. (for X.509, there is no subjectAltName of type RFC822Name whose value matches an e-mail address found in <spanx style="verb">From:</spanx> or <spanx style="verb">Sender:</spanx>)</t>
  <t>the certificate used to verify the signature was not issued by an authority that the MUA user is willing to rely on for certifying the sender's e-mail address, and the user has no other reasonable indication that the certificate belongs to the sender's e-mail address.</t>
  <t>the signature indicates that it was made at a time much before or much after from the date of the message itself.</t>
  <t>The signature covers a message that depends on an external subresource that might change (see <xref target="external-subresources"/>).</t>
</list></t>

<t>A valid signature must pass all these tests, but of course invalid signatures may be invalid in more than one of the ways listed above.</t>

</section>
</section>
<section anchor="reasoning-about-message-parts"><name>Reasoning about Message Parts</name>

<t>When generating or rendering messages, it is useful to know what parts of the message are likely to be displayed, and how.
This section introduces some common terms that can be applied to parts within the Cryptographic Payload.</t>

<section anchor="main-body-part"><name>Main Body Part</name>

<t>When an e-mail message is composed or rendered to the user there is typically one main view that presents a (mostly textual) part of the message.</t>

<t>While the message itself may be constructed of several distinct MIME parts in a tree, the part that is rendered to the user is the "Main Body Part".</t>

<t>When rendering a message, one of the primary jobs of the receiving MUA is identifying which part (or parts) is the Main Body Part.
Typically, this is found by traversing the MIME tree of the message looking for a leaf node that has a primary content type of <spanx style="verb">text</spanx> (e.g. <spanx style="verb">text/plain</spanx> or <spanx style="verb">text/html</spanx>) and is not <spanx style="verb">Content-Disposition: attachment</spanx>.</t>

<t>MIME tree traversal follows the first child of every <spanx style="verb">multipart</spanx> node, with the exception of <spanx style="verb">multipart/alternative</spanx>.
When traversing a <spanx style="verb">multipart/alternative</spanx> node, all children should be scanned, with preference given to the last child node with a MIME type that the MUA is capable of rendering directly.</t>

<t>An MUA <bcp14>MAY</bcp14> offer the user a mechanism to prefer a particular MIME type within <spanx style="verb">multipart/alternative</spanx> instead of the last renderable child.
For example, a user may explicitly prefer a <spanx style="verb">text/plain</spanx> alternative part over <spanx style="verb">text/html</spanx>.
Note that due to uncertainty about the capabilities and configuration of the receiving MUA, a conformant composing MUA should consider that multiple parts might be rendered as the Main Body Part when the message is ultimately viewed.
In particular, the composing MUA should ensure that any part likely to be viewed as the Main Body Part has the same semantic content as any other such part.</t>

<t>When composing a message, an originating MUA operating on behalf of an active user can identify which part (or parts) are the "main" parts: these are the parts the MUA generates from the user's editor.
Tooling that automatically generates e-mail messages should also have a reasonable estimate of which part (or parts) are the "main" parts, as they can be programmatically identified by the message author.</t>

<t>For a filtering program that attempts to transform an outbound message without any special knowledge about which parts are Main Body Parts, it can identify the likely parts by following the same routine as a receiving MUA.</t>

</section>
<section anchor="attachments"><name>Attachments</name>

<t>A message may contain one or more separated MIME parts that are intended for download or extraction.
Such a part is commonly called an "attachment", and is commonly identified by having <spanx style="verb">Content-Disposition: attachment</spanx>.</t>

<t>An MUA <bcp14>MAY</bcp14> identify a subpart as an attachment, or permit extraction of a subpart even when the subpart does not have <spanx style="verb">Content-Disposition: attachment</spanx>.</t>

<t>When generating a message with end-to-end cryptographic protection, any attachment <bcp14>MUST</bcp14> be included within the Cryptographic Payload.
If an attachment is found outside the Cryptographic Payload, then the message is not well-formed (see <xref target="well-formed"/>), and will not be handled by other MUAs as intended.</t>

<t>Some MUAs have tried to compose messages where each attachment is placed in its own cryptographic envelope.
Such a message is problematic for several reasons:</t>

<t><list style="symbols">
  <t>The attachments can be stripped, replaced, or reordered without breaking any cryptographic integrity mechanism.</t>
  <t>The resulting message may have a mix of cryptographic statuses (e.g. if a signature on one part fails but another succeeds, or if one part is encrypted and another is not).
This mix of statuses is difficult to represent to the user in a comprehensible way.</t>
  <t>The divisions between the different attachments are visible to operators of any mail transport agent (MTA) that handles the message, potentially resulting in a metadata leak.
For example, the MTA operator may learn the number of attachments, and the size of each attachment.</t>
</list></t>

<t>These messages are unlikely to be usefully interoperable without additional standardization work (see <xref target="split-attachments"/>).</t>

</section>
<section anchor="mime-part-examples"><name>MIME Part Examples</name>

<t>Consider a common message with the following MIME structure:</t>

<figure><artwork><![CDATA[
M └─╴application/pkcs7-mime
   ↧ (decrypts to)
N  └─╴application/pkcs7-mime
    ⇩ (unwraps to)
O   └┬╴multipart/mixed
P    ├┬╴multipart/alternative
Q    │├─╴text/plain
R    │└─╴text/html
S    └─╴image/png
]]></artwork></figure>

<t>Parts <spanx style="verb">M</spanx> and <spanx style="verb">N</spanx> comprise the Cryptographic Envelope.</t>

<t>Parts <spanx style="verb">Q</spanx> and <spanx style="verb">R</spanx> are both Main Body Parts.</t>

<t>If part <spanx style="verb">S</spanx> is <spanx style="verb">Content-Disposition: attachment</spanx>, then it is an attachment.
If part <spanx style="verb">S</spanx> has no <spanx style="verb">Content-Disposition</spanx> header, it is potentially ambiguous whether it is an attachment or not.
If the sender prefers a specific behavior, it should explicitly set the <spanx style="verb">Content-Disposition</spanx> header on part <spanx style="verb">S</spanx> to either <spanx style="verb">inline</spanx> or <spanx style="verb">attachment</spanx> as guidance to the receiving MUA.</t>

<t>Consider also this alternate structure:</t>

<figure><artwork><![CDATA[
M └─╴application/pkcs7-mime
   ↧ (decrypts to)
N  └─╴application/pkcs7-mime
    ⇩ (unwraps to)
O   └┬╴multipart/alternative
P    ├─╴text/plain
Q    └┬╴multipart/related
R     ├─╴text/html
S     └─╴image/png
]]></artwork></figure>

<t>In this case, parts <spanx style="verb">M</spanx> and <spanx style="verb">N</spanx> are still the Cryptographic Envelope.</t>

<t>Parts <spanx style="verb">P</spanx> and <spanx style="verb">R</spanx> (the first two leaf nodes within each subtree of part <spanx style="verb">O</spanx>) are the Main Body Parts.</t>

<t>Part <spanx style="verb">S</spanx> is more likely not to be an attachment, as the subtree layout suggests that it is only relevant for the HTML version of the message.
For example, it might be rendered as an image within the HTML alternative.</t>

</section>
</section>
<section anchor="cert-management"><name>Certificate Management</name>

<t>A cryptographically-capable MUA typically maintains knowledge about certificates for the user's own account(s), as well as certificates for the peers that it communicates with.</t>

<section anchor="peer-certificates"><name>Peer Certificates</name>

<t>Most certificates that a cryptographically-capable MUA will use will be certificates belonging to the parties that the user communicates with through the MUA.
This section discusses how to manage the certificates that belong to such a peer.</t>

<t>The MUA will need to be able to discover X.509 certificates for each peer, cache them, and select among them when composing an encrypted message.</t>

<t>Detailed guidance about how to do this is beyond the scope of this document, but future revisions may bring it into scope (see <xref target="more-peer-certs"/>).</t>

<section anchor="peer-cert-selection"><name>Peer Certificate Selection</name>

<t>When composing an encrypted message, the MUA needs to select an encryption-capable certificate for each recipient.</t>

<t>To select such a certificate for a given destination e-mail address, the MUA should look through all of its known certificates and verify that <em>all</em> of the conditions below are met:</t>

<t><list style="symbols">
  <t>The certificate must be valid, not expired or revoked.</t>
  <t>It must have a subjectAltName of type rFC822Name whose contents match the destination address.
In particular, the local-part of the two addresses should be an exact bytewise match, and the domain parts of the two addresses should be matched by ensuring label equivalence across the full domain name, as described in <xref section="2.3.2.4" sectionFormat="of" target="RFC5890"/>.</t>
  <t>The algorithm OID in the certificate's SPKI is known to the MUA and capable of encryption.
Examples include:
  <list style="symbols">
      <t>rsaEncryption (OID 1.2.840.113549.1.1.1), with keyUsage (OID 2.5.29.15) extension present and the "key encipherment" bit (value 32) set.</t>
      <t>curveX25519 (OID 1.3.101.110) with keyUsage extension present and the "key agreement" bit (value 8) set.</t>
    </list></t>
  <t>If extendedKeyUsage (OID 2.5.29.37) is present, it contains at least one of the following OIDs: e-mail protection (OID 1.3.6.1.5.5.7.3.4), anyExtendedKeyUsage (OID 2.5.29.37.0).</t>
</list></t>

<t>A conformant MUA may include more considerations when selecting a peer certificate as well, see <xref target="more-peer-cert-selection"/> for examples.</t>

</section>
</section>
<section anchor="local-certificates"><name>Local Certificates</name>

<t>The MUA also needs to know about one or more certificates associated with the user's e-mail account.
It is typically expected to have access to the secret key material associated with the public keys in those certificates.</t>

<t>While some basic guidance is offered here, it is beyond the scope of this document to describe all possible relevant guidance for local certificate and key material handling.
See <xref target="more-local-certs"/> for suggestions of guidance that a future version might bring into scope.</t>

<section anchor="local-certificate-setup"><name>Getting Certificates for the User</name>

<t>If a conformant MUA does not have any certificate or secret key for the user, it should help the user to generate, acquire, or import them with a minimum of difficulty.</t>

<section anchor="local-cert-smime"><name>User Certificates for S/MIME</name>

<t>For S/MIME, the user <bcp14>SHOULD</bcp14> have both a signing-capable certificate and an encryption-capable certificate (and the corresponding secret keys).
Using the same cryptographic key material for multiple algorithms (i.e., for both encryption and signing) has been the source of vulnerabilities in other (non-e-mail) contexts (e.g., <xref target="DROWN"/> and <xref target="IKE"/>).
The simplest way to avoid any comparable risk is to use distinct key material for each cryptographic algorithm.
A conformant MUA that generates S/MIME certificates for the user <bcp14>MUST</bcp14> generate distinct S/MIME certificates: one for encryption and another for signing, to avoid possible cross-protocol key misuse.</t>

<t>The simplest option for an S/MIME-capable MUA is for the MUA to permit the user to import a PKCS #12 (<xref target="RFC7292"/>) object that is expected to contain secret key material, end entity certificates for the user, and intermediate certification authority certificates that permit chaining from the end entity certs to widely-accepted trust anchors.
A conformant MUA that imports such a PKCS #12 bundle <bcp14>SHOULD</bcp14> warn the user if the bundle contains an S/MIME certificate and corresponding secret key where the same secret key is used for both encryption and signing.</t>

<t>An S/MIME-capable MUA that has access to user certificates and their corresponding secret key material should also offer the ability to export those objects into a well-formed PKCS #12 object that could be imported into another MUA operated by the same user.</t>

<t>Manual handling of PKCS #12 objects is challenging for most users.
Producing the initial PKCS #12 object typically can only be done with the aid of a certification authority via non-standardized, labor-intensive, and error-prone procedures that most users do not understand.
Furthermore, manual export and import incurs ongoing labor (for example, before certificate expiration) by the user which most users are unprepared to do (see <xref target="local-cert-maintenance"/>).</t>

<t>A better approach is for the MUA to integrate some form of automated certificate issuance procedure, for example, by using the ACME protocol for end user S/MIME certificates (<xref target="RFC8823"/>).</t>

<t>Another possible approach is integration with a cryptographic hardware token or smartcard that can provide certificates and permit the use of isolated secret key material, for example <xref target="PKCS11"></xref>, though this approach delegates the complexity of acquiring and managing certificates to management of the hardware token itself (see <xref target="smartcards"/>).</t>

<t>See also <xref target="I-D.woodhouse-cert-best-practice"/> for more recommendations about managing user certificates.</t>

</section>
<section anchor="local-cert-pgp"><name>User Certificates for PGP/MIME</name>

<t>As distinct from S/MIME, OpenPGP (<xref target="I-D.ietf-openpgp-crypto-refresh-13"/>) has a different set of common practices.
For one thing, a single OpenPGP certificate can contain both a signing-capable key and a distinct encryption-capable key, so only one certificate is needed for an e-mail user of OpenPGP, as long as the certificate has distinct key material for the different purposes.</t>

<t>Furthermore, a single OpenPGP certificate <bcp14>MAY</bcp14> be only self-signed, so the MUA can generate such a certificate entirely on its own.</t>

<t>An OpenPGP-capable MUA should have the ability to import and export OpenPGP Tranferable Secret Keys (see <xref section="10.2" sectionFormat="of" target="I-D.ietf-openpgp-crypto-refresh-13"/>), to enable manual transfer of user certificates and secret key material between multiple MUAs controlled by the user.</t>

<t>Since an OpenPGP certificate <bcp14>MAY</bcp14> be certified by third parties (whether formal certification authorities or merely other well-connected peers) the MUA <bcp14>SHOULD</bcp14> offer affordances to help the user acquire and merge third party certifications on their certificate.
When doing this, the MUA should prioritize third-party certifications from entities that the user's peers are likely to know about and be willing to rely on.</t>

<t>Since an OpenPGP certificate can grow arbitrarily large with third-party certifications, the MUA should assist the user in pruning it to ensure that it remains a reasonable size when transmitting it to other parties.</t>

</section>
<section anchor="local-key-generation"><name>Generate Secret Key Material Locally</name>

<t>Regardless of protocol used (S/MIME or PGP), when producing certificates for the end user, the MUA <bcp14>SHOULD</bcp14> ensure that it has generated secret key material locally, and <bcp14>MUST NOT</bcp14> accept secret key material from an untrusted external party as the basis for the user's certificate.
For example, a user who trusts their system administrator not to compromise their MUA may accept secret key material generated by the sysdmin, but probably should not accept secret key material generated by an unaffiliated online web service.</t>

<t>An MUA that accepts secret key material from a third party cannot prevent that third party from retaining this material.
A third party with this level of access could decrypt messages intended to be confidential for the user, or could forge messages that would appear to come from the user.</t>

</section>
</section>
<section anchor="local-cert-maintenance"><name>Local Certificate Maintenance</name>

<t>In the context of a single e-mail account managed by an MUA, where that e-mail account is expected to be able to use end-to-end cryptographic protections, the MUA <bcp14>SHOULD</bcp14> warn the user (or proactively fix the problem) when/if:</t>

<t><list style="symbols">
  <t>For S/MIME, the user's own certificate set for the account does not include a valid, unexpired encryption-capable X.509 certificate, and a valid, unexpired signature-capable X.509 certificate.</t>
  <t>For PGP/MIME, the user's own certificate does not include a valid, unexpired signing-capable key/subkey and a valid, unexpired encryption-capable key/subkey.</t>
  <t>Any of the user's own certificates for the account:
  <list style="symbols">
      <t>is due to expire in the next month (or at some other reasonable cadence).</t>
      <t>not match the e-mail address associated with the account in question.</t>
    </list></t>
  <t>Any of the user's own S/MIME certificates for the account:
  <list style="symbols">
      <t>does not have a keyUsage extension.</t>
      <t>does not contain an extendedKeyUsage extension.</t>
      <t>would be considered invalid by the MUA for any other reason if it were a peer certificate.</t>
    </list></t>
</list></t>

<t>An MUA that takes active steps to fix any of these problems before they arise is even more usable than just warning, but guidance on how to do active certificate maintenance is beyond scope for this current document (see <xref target="more-local-cert-maintenance"/>).</t>

<t>If the MUA does find any of these issues and chooses to warn the user, it should use one aggregate warning with simple language that the certificates might not be acceptable for other people, and recommend a course of action that the user can take to remedy the problem.</t>

</section>
<section anchor="sending-certificates"><name>Shipping Certificates in Outbound Messages</name>

<t>When sending mail, a conformant MUA <bcp14>SHOULD</bcp14> include copies of the user's own certificates (and potentially other certificates) in each message to facilitate future communication, unless it has specific knowledge that the other parties involved already know the relevant keys (for example, if it is mail between members within a domain that has a synchronized and up-to-date certificate directory).</t>

<t>The mechanism for including these certificates, and which certificates to include in the message, are protocol specific.</t>

<section anchor="shipping-certificates-in-smime-messages"><name>Shipping Certificates in S/MIME Messages</name>

<t>In any S/MIME SignedData object, certificates can be shipped in the "certificates" member.
In S/MIME EnvelopedData object, certificates can be shipped in the "originatorInfo.certs" member.</t>

<t>When a single S/MIME-protected e-mail message is encrypted and signed, it is usually sufficient to ship all the relevant certificates in the inner SignedData object's "certificates" member.</t>

<t>The S/MIME certificates shipped in such a message <bcp14>SHOULD</bcp14> include:</t>

<t><list style="symbols">
  <t>The user's own S/MIME signing certificate, so that signature on the current message can be validated.</t>
  <t>The user's own S/MIME encryption-capable certificate, so that the recipient can reply in encrypted form.</t>
  <t>On an encrypted message to multiple recipients, the encryption-capable peer certificates of the other recipients, so that any recipient can easily "reply all" without needing to search for certificates.</t>
  <t>Any intermediate CA certificates needed to chain all of the above to a widely-trusted set of root authorities.</t>
</list></t>

</section>
<section anchor="shipping-certificates-in-pgpmime-messages"><name>Shipping Certificates in PGP/MIME Messages</name>

<t>PGP/MIME does not have a single specific standard location for shipping certificates.</t>

<t>Some MUAs ship relevant OpenPGP certificates in a single MIME leaf of Content-Type "application/pgp-keys".
When such a message has cryptographic protections, to ensure that the message is well-formed, this kind of MIME part <bcp14>SHOULD</bcp14> be a leaf of the Cryptographic Payload, and not outside of it.
One problem with this approach is that it appears to recipients with non-cryptographic MUAs as an "attachment", which can lead to confusion if the user does not know how to use it.</t>

<t>Other implementations ship relevant OpenPGP certificates in "Autocrypt" or "Autocrypt-Gossip" message header fields (see <xref target="AUTOCRYPT"/>).
To ensure that those header fields receive the same cryptographic authenticity as the rest of the message, these header fields <bcp14>SHOULD</bcp14> be protected as described in <xref target="I-D.ietf-lamps-header-protection"/>.</t>

<t>The OpenPGP certificates shipped in such a message <bcp14>SHOULD</bcp14> include:</t>

<t><list style="symbols">
  <t>The user's own OpenPGP certificate, capable of both signing and encryption, so that the user can validate the message's signature and can encrypt future messages</t>
  <t>On an encrypted message to multiple recipients, the OpenPGP certificates of the other recipients, so that any recipient can easily "reply all" without needing to search for certificates.</t>
</list></t>

</section>
</section>
</section>
</section>
<section anchor="common-pitfalls"><name>Common Pitfalls and Guidelines</name>

<t>This section highlights a few "pitfalls" and guidelines based on these discussions and lessons learned.</t>

<section anchor="reading-sent-messages"><name>Reading Sent Messages</name>

<t>When sending a message, a typical MUA will store a copy of the message sent in sender's Sent mail folder so that the sender can read it later.
If the message is an encrypted message, storing it encrypted requires some forethought to ensure that the sender can read it in the future.</t>

<t>It is a common and simple practice to encrypt the message not only to the recipients of the message, but also to the sender.
One advantage of doing this is that the message that is sent on the wire can be identical to the message stored in the sender's Sent mail folder.
This allows the sender to review and re-read the message even though it was encrypted.</t>

<t>There are at least three other approaches that are possible to ensure future readability by the sender of the message, but with different tradeoffs:</t>

<t><list style="symbols">
  <t>Encrypt two versions of the message: one to the recipients (this version is sent on the wire), and one to the sender only (this version is stored in the sender's Sent folder).
This approach means that the message stored in the Sent folder is not byte-for-byte identical to the message sent to the recipients.
In the event that message delivery has a transient failure, the MUA cannot simply re-submit the stored message into the SMTP system and expect it to be readable by the recipient.</t>
  <t>Store a cleartext version of the message in the Sent folder.
This presents a risk of information leakage: anyone with access to the Sent folder can read the contents of the message.
Furthermore, any attempt to re-send the message needs to also re-apply the cryptographic transformation before sending, or else the message contents will leak upon re-send.
A conformant MUA <bcp14>SHOULD NOT</bcp14> store a cleartext copy in the Sent folder unless it knows that the Sent folder cannot be read by an attacker.
For example, if end-to-end confidentiality is desired, then storing the cleartext in an IMAP folder where a potentially adversarial server can read it defeats the purpose.</t>
  <t>A final option is that the MUA can store a copy of the message's encryption session key.
Standard e-mail encryption mechanisms (e.g. S/MIME and PGP/MIME) are hybrid mechanisms: the asymmetric encryption steps simply encrypt a symmetric "session key", which is used to encrypt the message itself.
If the MUA stores the session key itself, it can use the session key to decrypt the Sent message without needing the Sent message to be decryptable by the user's own asymmetric key.
An MUA doing this must take care to store (and backup) its stash of session keys, because if it loses them it will not be able to read the sent messages; and if someone else gains access to them, they can decrypt the sent messages.
This has the additional consequence that any other MUA accessing the same Sent folder cannot decrypt the message unless it also has access to the stashed session key.</t>
</list></t>

</section>
<section anchor="reading-encrypted-messages-after-certificate-expiration"><name>Reading Encrypted Messages after Certificate Expiration</name>

<t>When encrypting a message, the sending MUA should decline to encrypt to an expired certificate (see <xref target="peer-cert-selection"/>).
But when decrypting a message, as long as the viewing MUA has access to the appropriate secret key material, it should permit decryption of the message, even if the associated certificate is expired.
That is, the viewing MUA should not prevent the user from reading a message that they have already received.</t>

<t>The viewing MUA may warn the user when decrypting a message that appears to have been encrypted to an encryption-capable certificate that was expired at the time of encryption (e.g., based on the <spanx style="verb">Date:</spanx> header field of the message, or the timestamp in the cryptographic signature), but otherwise should not complain.</t>

<t>The primary goal of certificate expiration is to facilitate rotation of secret key material, so that secret key material does not need to be retained indefinitely.
Certificate expiration permits the user to destroy an older secret key if access to the messages received under it is no longer necessary (see also <xref target="secure-deletion"/>).</t>

</section>
<section anchor="message-header-fields"><name>Unprotected Message Header Fields</name>

<t>Many legacy cryptographically-aware MUAs only apply cryptographic protections to the body of the message, but leave the header fields unprotected.
This gives rise to vulnerabilities like information leakage (e.g., the Subject line is visible to a passive intermediary) or message tampering (e.g., the Subject line is replaced, effectively changing the semantics of a signed message).
These are not only security vulnerabilities, but usability problems, because the distinction between what is a header and what is the body of a message is unclear to many end users, and requires a more complex mental model than is necessary.
Useful security comes from alignment between simple mental models and tooling.</t>

<t>To avoid these concerns, a conformant MUA <bcp14>MUST</bcp14> implement header protection as described in <xref target="I-D.ietf-lamps-header-protection"/>.</t>

<t>Note that some message header fields, like <spanx style="verb">List-*</spanx>, <spanx style="verb">Archived-At</spanx>, and <spanx style="verb">Resent-*</spanx> are typically added by an intervening MUA (see <xref target="intervening-mua"/>), not by one of the traditional "ends" of an end-to-end e-mail exchange.
A receiving MUA may choose to consider the contents of these header fields on an end-to-end protected message as markers added during message transit, even if they are not covered by the end-to-end cryptographic protection.</t>

</section>
<section anchor="bcc-variants"><name>Composing an Encrypted Message with Bcc</name>

<t>When composing an encrypted message containing at least one recipient address in the <spanx style="verb">Bcc</spanx> header field, there is a risk that the encrypted message itself could leak information about the actual recipients, even if the <spanx style="verb">Bcc</spanx> header field does not mention the recipient.
For example, if the message clearly indicates which certificates it is encrypted to, the set of certificates can identify the recipients even if they are not named in the message header fields.</t>

<t>Because of these complexities, there are several interacting factors that need to be taken into account when composing an encrypted message with Bcc'ed recipients.</t>

<t><list style="symbols">
  <t><xref section="3.6.3" sectionFormat="of" target="RFC5322"/> describes a set of choices about whether (and how) to populate the <spanx style="verb">Bcc</spanx> field explicitly on Bcc'ed copies of the message, and in the copy stored in the sender's <spanx style="verb">Sent</spanx> folder.</t>
  <t>When separate copies are made for <spanx style="verb">Bcc</spanx>ed recipients, should each separate copy <em>also</em> be encrypted to the named recipients, or just to the designated <spanx style="verb">Bcc</spanx> recipient?</t>
  <t>When a copy is stored in the <spanx style="verb">Sent</spanx> folder, should that copy also be encrypted to <spanx style="verb">Bcc</spanx>ed recipients? (see also <xref target="reading-sent-messages"/>)</t>
  <t>When a message is encrypted, if there is a mechanism to include the certificates of the recipients, whose certificates should be included?</t>
</list></t>

<section anchor="bcc-recommendation"><name>Simple Encryption with Bcc</name>

<t>Here is a simple approach that tries to minimize the total number of variants of the message created while leaving a coherent view of the message itself:</t>

<t><list style="symbols">
  <t>No cryptographic payload contains any <spanx style="verb">Bcc</spanx> header field.</t>
  <t>The main copy of the message is signed and encrypted to all named recipients and to the sender.
A copy of this message is also stored in the sender's <spanx style="verb">Sent</spanx> folder.</t>
  <t>Each <spanx style="verb">Bcc</spanx> recipient receives a distinct copy of the message, with an identical cryptographic payload, and the message is signed and encrypted to that specific recipient and all the named recipients.
These copies are not stored in the sender's <spanx style="verb">Sent</spanx> folder.</t>
  <t>To the extent that spare certificates are included in the message, each generated copy of the message should include certificates for the sender and for each named recipient.
Certificates for Bcc'ed recipients are not included in any message.</t>
</list></t>

<section anchor="rationale"><name>Rationale</name>

<t>The approach described in <xref target="bcc-recommendation"/>  aligns the list of cryptographic recipients as closely as possible with the set of named recipients, while still allowing a <spanx style="verb">Bcc</spanx>ed recipient to read their own copy, and to "Reply All" should they want to.</t>

<t>This should reduce user confusion on the receiving side: a recipient of such a message who naively looks at the user-facing header fields from their own mailbox will have a good sense of what cryptographic treatments have been applied to the message.
It also simplifies message composition and user experience: the message composer sees fields that match their expectations about what will happen to the message.
Additionally, it may preserve the ability for a Bcc'ed recipient to retain their anonymity, should they need to offer the signed cryptographic payload to an outside party as proof of the original sender's intent without revealing their own identity.</t>

</section>
</section>
</section>
<section anchor="draft-messages"><name>Draft Messages</name>

<t>When composing a message, most MUAs will save a copy of the as-yet-unsent message to a "Drafts" folder.
If that folder is itself stored somewhere not under the user's control (e.g. and IMAP mailbox), it would be a mistake to store the draft message in the clear, because its contents could leak.</t>

<t>This is the case even if the message is ultimately sent deliberately in the clear.
During message composition, the MUA does not know whether the message is intended to be sent encrypted or not.
For example, just before sending, the sender could decide to encrypt the message, and the MUA would have had no way of knowing.</t>

<t>The MUA <bcp14>SHOULD</bcp14> encrypt all draft messages, unless it has explicit knowledge that the message will not be encrypted when sent, or that the Drafts folder cannot be read by an attacker.
For example, if end-to-end confidentiality is desired, then storing a cleartext draft in an IMAP folder where a potentially adversarial server can read it defeats the purpose.</t>

<t>Furthermore, when encrypting a draft message, the message draft <bcp14>MUST</bcp14> only be encrypted to the user's own certificate, or to some equivalent secret key that only the user possesses.
A draft message encrypted in this way can be decrypted when the user wants to resume composing the message, but cannot be read by anyone else, including a potential intended recipient.
Note that a draft message encrypted in this way will only be resumable by another MUA attached to the same mailbox if that other MUA has access to the user's decryption-capable secret key.
This shared access to key material is also likely necessary for useful interoperability, but is beyond the scope of this document (see <xref target="cross-mua-local-keys"/>).</t>

<t>A conformant MUA <bcp14>MUST NOT</bcp14> sign a message draft with the user's normal signing key.
If draft signing is intended for cryptographic coordination between multiple MUAs of the same user, it should be negotiated with a different key (but see <xref target="cross-mua-local-keys"/>).</t>

<t>The message should only be encrypted to its recipients upon actually sending the message.
No reasonable user expects their message's intended recipients to be able to read a message that is not yet complete.</t>

</section>
<section anchor="mixed-recipients"><name>Composing a Message to Heterogeneous Recipients</name>

<t>When sending a message that the user intends to be encrypted, it's possible that some recipients will be unable to receive an encrypted copy.
For example, when Carol composes a message to Alice and Bob, Carol's MUA may be able to find a valid encryption-capable certificate for Alice, but none for Bob.</t>

<t>In this situation, there are four possible strategies, each of which has a negative impact on the experience of using encrypted mail.
Carol's MUA can:</t>

<t><list style="numbers">
  <t>send encrypted to Alice and Bob, knowing that Bob will be unable to read the message.</t>
  <t>send encrypted to Alice only, dropping Bob from the message recipient list.</t>
  <t>send the message in the clear to both Alice and Bob.</t>
  <t>send an encrypted copy of the message to Alice, and a cleartext copy to Bob.</t>
</list></t>

<t>Each of these strategies has different drawbacks.</t>

<t>The problem with approach 1 is that Bob will receive unreadable mail.</t>

<t>The problem with approach 2 is that Carol's MUA will not send the message to Bob, despite Carol asking it to.</t>

<t>The problem with approach 3 is that Carol's MUA will not encrypt the message, despite Carol asking it to.</t>

<t>Approach 4 has two problems:</t>

<t><list style="symbols">
  <t>Carol's MUA will release a cleartext copy of the message, despite Carol asking it to send the message encrypted.</t>
  <t>If Alice wants to "reply all" to the message, she may not be able to find an encryption-capable certificate for Bob either.
This puts Alice in an awkward and confusing position, one that users are unlikely to understand.
In particular, if Alice's MUA is following the guidance about replies to encrypted messages in <xref target="composing-reply"/>, having received an encrypted copy will make Alice's Reply buffer behave in an unusual fashion.</t>
</list></t>

<t>This is particularly problematic when the second recipient is not "Bob" but in fact a public mailing list or other visible archive, where messages are simply never encrypted.</t>

<t>Carol is unlikely to understand the subtleties and negative downstream interactions involved with approaches 1 and 4, so presenting the user with those choices is not advised.</t>

<t>The most understandable approach for an MUA with an active user is to ask the user (when they hit "send") to choose between approach 2 and approach 3.
If the user declines to choose between 2 and 3, the MUA can drop them back to their message composition window and let them make alternate adjustments.</t>

<t>See also further discussion of these scenarios in <xref target="I-D.dkg-mail-cleartext-copy"/>.</t>

</section>
<section anchor="proxy-dangers"><name>Message Transport Protocol Proxy: A Dangerous Implementation Choice</name>

<t>An implementer of end-to-end cryptographic protections may be tempted by a simple software design that piggybacks off of a mail protocol like SMTP Submission (<xref target="RFC6409"/>), IMAP (<xref target="RFC3501"/>), or JMAP (<xref target="RFC8621"/>) to handle message assembly and interpretation.
In such an architecture, a naive MUA speaks something like a "standard" protocol like SMTP, IMAP, or JMAP to a local proxy, and the proxy handles signing and encryption (outbound), and decryption and verification (inbound) internally on behalf of the user.
While such a "pluggable" architecture has the advantage that it is likely to be easy to apply to any mail user agent, it is problematic for the goals of end-to-end communication, especially in an existing cleartext ecosystem like e-mail, where any given message might be unsigned or signed, cleartext or encrypted.
In particular:</t>

<t><list style="symbols">
  <t>the user cannot easily and safely identify what protections any particular message has (including messages currently being composed), and</t>
  <t>the proxy itself is unaware of subtle nuances about the message that the MUA actually knows.</t>
</list></t>

<t>With a trustworthy and well-synchronized sidechannel or protocol extension between the MUA and the proxy, it is possible to deploy such an implementation safely, but the requirement for the sidechannel or extension eliminates the universal-deployability advantage of the scheme.</t>

<t>Similar concerns apply to any implementation bound by an API which operates on message objects alone, without any additional contextual parameters.</t>

<t>This section attempts to document some of the inherent risks involved with such an architecture.</t>

<section anchor="proxy-for-message-composition"><name>Dangers of a Submission Proxy for Message Composition</name>

<t>When composing and sending a message, the act of applying cryptographic protections has subtleties that cannot be directly expressed in the SMTP protocol used by Submission <xref target="RFC6409"/>, or in any other simple protocol that hands off a cleartext message for further processing.</t>

<t>For example, the sender cannot indicate via SMTP whether or not a given message <em>should</em> be encrypted (some messages, like those sent to a publicly archived mailing list, are pointless to encrypt), or select among multiple certificates for a recipient, if they exist (see <xref target="peer-cert-selection"/>).</t>

<t>Likewise, because such a proxy only interacts with the message when it is ready to be sent, it cannot indicate back to the user <em>during message composition</em> whether or not the message is able to be encrypted (that is, whether a valid certificate is available for each intended recipient).
A message author may write an entirely different message if they know that it will be protected end-to-end; but without this knowledge, the author is obliged either to write text that they presume will be intercepted, or to risk revealing sensitive content.</t>

<t>Even without encryption, deciding whether to sign or not (and which certificate to sign with, if more than one exists) is another choice that the proxy is ill-equipped to make.
The common message-signing techniques either render a message unreadable by any non-cryptographic MUA (i.e., PKCS7 signed-data), or appear as an attachment that can cause confusion to a naive recipient using a non-cryptographic MUA (i.e., multipart/signed).
If the sender knows that the recipient will not check signatures, they may prefer to leave a cleartext message without a cryptographic signature at all.</t>

<t>Furthermore, handling encryption properly depends on the context of any given message, which cannot be expressed by the MUA to the Submission proxy.
For example, decisions about how to handle encryption and quoted or attributed text may depend on the cryptographic status of the message that is being replied to (see <xref target="composing-reply"/>).</t>

<t>Additionally, such a proxy would need to be capable of managing the user's own key and certificate (see <xref target="local-certificates"/>).
How will the implementation indicate to the user when their own certificate is near expiry, for example?
How will any other error conditions be handled when communication with the user is needed?</t>

<t>While an extension to SMTP might be able to express all the necessary semantics that would allow a generic MUA to compose messages with standard cryptographic protections via a proxy, such an extension is beyond the scope of this document.
See <xref target="I-D.ietf-jmap-smime-sender-extensions"/> for an example of how an MUA using a proxy protocol might indicate signing and encryption instructions to its proxy.</t>

</section>
<section anchor="dangers-of-an-imap-proxy-for-message-rendering"><name>Dangers of an IMAP Proxy for Message Rendering</name>

<t>When receiving and rendering a message, the process of indicating to the user the cryptographic status of a message requires subtleties that are difficult to offer from a straightforwad IMAP (or POP <xref target="RFC1939"/>, or JMAP) proxy.</t>

<t>One approach such a proxy could take is to remove all the Cryptographic Layers from a well-formed message, and to package a description of those layers into a special header field that the MUA can read.
But this merely raises the question: what semantics need to be represented?
For example:</t>

<t><list style="symbols">
  <t>Was the message signed?  If so, by whom?  When?</t>
  <t>Should the details of the cryptographic algorithms used in any signatures found be indicated as well?</t>
  <t>Was the message encrypted?  if so, to whom?  What key was used to decrypt it?</t>
  <t>If both signed and encrypted, was the signing outside the encryption or inside?</t>
  <t>How should errant Cryptographic Layers (see <xref target="errant-cryptographic-layers"/>) be dealt with?</t>
  <t>What cryptographic protections do the header fields of the message have? (see <xref target="I-D.ietf-lamps-header-protection"/>)</t>
  <t>How are any errors or surprises communicated to the user?</t>
</list></t>

<t>If the proxy passes any of this cryptographic status to the client in an added header field, it must also ensure that no such header field is present on the messages it receives before processing it.
If it were to allow such a header field through unmodified to any client that is willing to trust its contents, an attacker could spoof the field to make the user believe lies about the cryptographic status of the message.
In order for an MUA to be confident in such a header field, then, it needs a guarantee from the proxy that any header it produces will be safe.
How does the MUA reliably negotiate this guarantee with the proxy?
If the proxy can no longer offer this guarantee, how will the MUA know that things have changed?</t>

<t>If such a proxy handles certificate discovery in inbound messages (see <xref target="peer-discovery-incoming"/>), it will also need to communicate the results of that discovery process to its corresponding proxy for message composition (see <xref target="proxy-for-message-composition"/>).</t>

<t>While an extension to IMAP (or POP, or JMAP) might be able to express all the necessary semantics that would allow a generic MUA to indicate standardized cryptographic message status, such an extension is beyond the scope of this document.
<xref target="RFC9219"/> describes S/MIME signature verification status over JMAP, which is a subset of the cryptographic status information described here.</t>

</section>
<section anchor="who-controls-the-proxy"><name>Who Controls the Proxy?</name>

<t>Finally, consider that the naive proxy deployment approach is risky precisely because of its opacity to the end user.
Such a deployment could be placed anywhere in the stack, including on a machine that is not ultimately controlled by the end user, making it effectively a form of transport protection, rather than end-to-end protection.</t>

<t>An MUA explicitly under the control of the end user with thoughtful integration can offer UI/UX and security guarantees that a simple proxy cannot provide.
See also <xref target="proxy-extensions"/> for suggestions of future work that might augment a proxy to make it safer.</t>

</section>
</section>
<section anchor="intervening-mua"><name>Intervening MUAs Do Not Handle End-to-End Cryptographic Protections</name>

<t>Some Mail User Agents (MUAs) will resend a message in identical form (or very similar form) to the way that they received it.
For example, consider the following use cases:</t>

<t><list style="symbols">
  <t>A mail expander or mailing list that receives a message and re-sends it to all subscribers.</t>
  <t>An individual user who reintroduces a message they received into the mail transport system (see <xref section="3.6.6" sectionFormat="of" target="RFC5322"/>).</t>
  <t>An automated e-mail intake system that forwards a report to the mailboxes of responsible staffers.</t>
</list></t>

<t>These MUAs intervene in message transport by receiving and then re-injecting messages into the mail transport system.
In some cases, the original sender or final recipient of a message that has passed through such an MUA may be unaware of the intervention.
(Note that an MUA that forwards a received message as a attachment (MIME subpart) of type <spanx style="verb">message/rfc822</spanx> or <spanx style="verb">message/global</spanx> or "inline" in the body of a message is <em>not</em> acting as an intervening MUA in this sense, because the forwarded message is encapsulated within a visible outer message that is clearly from the MUA itself.)</t>

<t>An intervening MUA should be aware of end-to-end cryptographic protections that might already exist on messages that they re-send.
In particular, it is unclear what the "end-to-end" properties are of a message that has been handled by an intervening MUA.
For signed-only messages, if the intervening MUA makes any substantive modifications to the message as it passes it along, it may break the signature from the original sender.
In many cases, breaking the original signature is the appropriate result, since the original message has been modified, and the original sender has no control over the modifications made by the intervening MUA.
For encrypted-and-signed messages, if the intervening MUA is capable of decrypting the message, it must be careful when re-transmitting the message.
Will the new recipient be able to decrypt it?
If not, will the message be useful to the recipient?
If not, it may not make sense to re-send the message.</t>

<t>Beyond the act of re-sending, an intervening MUA should not itself try to apply end-to-end cryptographic protections on a message that it is resending unless directed otherwise by some future specification.
Additional layers of cryptographic protection added in an ad-hoc way by an intervening MUA are more likely to confuse the recipient and will not be interpretable as end-to-end protections as they do not originate with the original sender of the message.</t>

</section>
<section anchor="external-subresources"><name>External Subresources in MIME Parts Break Cryptographic Protections</name>

<t>A MIME part with a content type that can refer to external resources (like <spanx style="verb">text/html</spanx>) may itself have some sort of end-to-end cryptographic protections.
However, retrieving or rendering these external resources may violate the properties that users expect from cryptographic protection.</t>

<t>As a baseline, retrieving the external resource at the time a message is read can be used as a "web bug", leaking the activity and network location of the receiving user to the server hosting the external resource.
This privacy risk is present, of course, even for messages with no cryptographic protections, but may be even more surprising to users who are shown some level of security indicator about a given message.</t>

<t>Other problems with external resources are more specifically bound to cryptographic protections.</t>

<t>For example, an signed e-mail message with at <spanx style="verb">text/html</spanx> part that refers to an external image (i.e. via <spanx style="verb">&lt;img src="https://example.com/img.png"&gt;</spanx>) may render differently if the hosting webserver decides to serve different content at the source URL for the image.
This effectively breaks the goals of integrity and authenticity that the user should be able to rely on for signed messages, unless the external subresource has strict integrity guarantees (e.g. via <xref target="SRI"/>).</t>

<t>Likewise, fetching an external subresource for an encrypted-and-signed message effectively breaks goals of privacy and confidentiality for the user.</t>

<t>This is loosely analogous to security indicator problems that arose for web browsers as described in <xref target="mixed-content"/>.
However, while fetching the external subresource over https is sufficient to avoid a "mixed content" warning from most browsers, it is insufficicent for an MUA that wants to offer its users true end-to-end guarantees for e-mail messages.</t>

<t>A conformant sending MUA that applies signing-only cryptographic protection to a new e-mail message with an external subresource should take one of the following options:</t>

<t><list style="symbols">
  <t>pre-fetch the external subresource and include it in the message itself,</t>
  <t>use a strong integrity mechanism like Subresource Integrity (<xref target="SRI"/>) to guarantee the content of the subresource (though this does not fix the "web bug" privacy risk described above), or</t>
  <t>prompt the composing user to remove the subresource from the message.</t>
</list></t>

<t>A conformant sending MUA that applies encryption to a new e-mail message with an external resource cannot depend on subresource integrity to protect the privacy and confidentiality of the message, so it should either pre-fetch the external resource to include it in the message, or prompt the composing user to remove it before sending.</t>

<t>A conformant receiving MUA that encounters a message with end-to-end cryptographic protections that contain a subresource <bcp14>MUST</bcp14> either refuse to retrieve and render the external subresource, or it should decline to treat the message as having cryptographic protections.
For example, it could indicate in the Cryptographic Summary that the message is Unprotected.</t>

<t>Note that when composing a message reply with quoted text from the original message, if the original message did contain an external resource, the composing MUA <bcp14>SHOULD NOT</bcp14> fetch the external resource solely to include it in the reply message, as doing so would trigger the "web bug" at reply composition time.
Instead, the safest way to deal with quoted text that contains an external resource in an end-to-end encrypted reply is to strip any reference to the external resource during initial composition of the reply.</t>

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

<t>This document does not require anything from IANA.</t>

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

<t>This entire document addresses security considerations about end-to-end cryptographic protections for e-mail messages.</t>

</section>
<section anchor="acknowledgements"><name>Acknowledgements</name>

<t>The set of constructs and recommendations in this document are derived from discussions with many different implementers, including
Bjarni Rúnar Einarsson,
Daniel Huigens,
David Bremner,
Deb Cooley,
Eliot Lear,
Fabian Ising,
Holger Krekel,
Jameson Rollins,
John Levine,
Jonathan Hammell,
juga,
Patrick Brunschwig,
Pete Resnick,
Roman Danyliw,
Santosh Chokhani,
Stephen Farrell, and
Vincent Breitmoser.</t>

</section>


  </middle>

  <back>


    <references title='Normative References'>



<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='RFC3156'>
  <front>
    <title>MIME Security with OpenPGP</title>
    <author fullname='M. Elkins' initials='M.' surname='Elkins'/>
    <author fullname='D. Del Torto' initials='D.' surname='Del Torto'/>
    <author fullname='R. Levien' initials='R.' surname='Levien'/>
    <author fullname='T. Roessler' initials='T.' surname='Roessler'/>
    <date month='August' year='2001'/>
    <abstract>
      <t>This document describes how the OpenPGP Message Format can be used to provide privacy and authentication using the Multipurpose Internet Mail Extensions (MIME) security content types described in RFC 1847. [STANDARDS-TRACK]</t>
    </abstract>
  </front>
  <seriesInfo name='RFC' value='3156'/>
  <seriesInfo name='DOI' value='10.17487/RFC3156'/>
</reference>

<reference anchor='RFC4289'>
  <front>
    <title>Multipurpose Internet Mail Extensions (MIME) Part Four: Registration Procedures</title>
    <author fullname='N. Freed' initials='N.' surname='Freed'/>
    <author fullname='J. Klensin' initials='J.' surname='Klensin'/>
    <date month='December' year='2005'/>
    <abstract>
      <t>This document specifies IANA registration procedures for MIME external body access types and content-transfer-encodings. 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='13'/>
  <seriesInfo name='RFC' value='4289'/>
  <seriesInfo name='DOI' value='10.17487/RFC4289'/>
</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='RFC5890'>
  <front>
    <title>Internationalized Domain Names for Applications (IDNA): Definitions and Document Framework</title>
    <author fullname='J. Klensin' initials='J.' surname='Klensin'/>
    <date month='August' year='2010'/>
    <abstract>
      <t>This document is one of a collection that, together, describe the protocol and usage context for a revision of Internationalized Domain Names for Applications (IDNA), superseding the earlier version. It describes the document collection and provides definitions and other material that are common to the set. [STANDARDS-TRACK]</t>
    </abstract>
  </front>
  <seriesInfo name='RFC' value='5890'/>
  <seriesInfo name='DOI' value='10.17487/RFC5890'/>
</reference>


<reference anchor='I-D.ietf-lamps-header-protection'>
   <front>
      <title>Header Protection for Cryptographically Protected E-mail</title>
      <author fullname='Daniel Kahn Gillmor' initials='D. K.' surname='Gillmor'>
         <organization>American Civil Liberties Union</organization>
      </author>
      <author fullname='Bernie Hoeneisen' initials='B.' surname='Hoeneisen'>
         <organization>pEp Foundation</organization>
      </author>
      <author fullname='Alexey Melnikov' initials='A.' surname='Melnikov'>
         <organization>Isode Ltd</organization>
      </author>
      <date day='30' month='November' year='2023'/>
      <abstract>
	 <t>   S/MIME version 3.1 introduced a mechanism to provide end-to-end
   cryptographic protection of e-mail message headers.  However, few
   implementations generate messages using this mechanism, and several
   legacy implementations have revealed rendering or security issues
   when handling such a message.

   This document updates the S/MIME specification to offer a different
   mechanism that provides the same cryptographic protections but with
   fewer downsides when handled by legacy clients.  The header
   protection schemes described here are also applicable to messages
   with PGP/MIME cryptographic protections.  Furthermore, this document
   offers more explicit guidance for clients when generating or handling
   e-mail messages with cryptographic protection of message headers.

	 </t>
      </abstract>
   </front>
   <seriesInfo name='Internet-Draft' value='draft-ietf-lamps-header-protection-18'/>
   
</reference>




    </references>

    <references title='Informative References'>

<reference anchor="AUTOCRYPT" target="https://autocrypt.org/">
  <front>
    <title>Autocrypt - Convenient End-to-End Encryption for E-Mail</title>
    <author initials="V." surname="Breitmoser" fullname="Vincent Breitmoser">
      <organization></organization>
    </author>
    <author initials="H." surname="Krekel" fullname="Holger Krekel">
      <organization></organization>
    </author>
    <author initials="D. K." surname="Gillmor" fullname="Daniel Kahn Gillmor">
      <organization></organization>
    </author>
    <date year="2018" month="July"/>
  </front>
</reference>
<reference anchor="chrome-indicators" target="https://blog.chromium.org/2018/05/evolving-chromes-security-indicators.html">
  <front>
    <title>Evolving Chrome's security indicators</title>
    <author initials="E." surname="Schechter" fullname="Emily Schechter">
      <organization></organization>
    </author>
    <date year="2018" month="May"/>
  </front>
</reference>
<reference anchor="EFAIL" target="https://efail.de">
  <front>
    <title>Efail: breaking S/MIME and OpenPGP email encryption using exfiltration channels</title>
    <author initials="D." surname="Poddebniak" fullname="Damian Poddebniak">
      <organization></organization>
    </author>
    <author initials="C." surname="Dresen" fullname="Christian Dresen">
      <organization></organization>
    </author>
    <author initials="J." surname="Müller" fullname="Jens Müller">
      <organization></organization>
    </author>
    <author initials="F." surname="Ising" fullname="Fabian Ising">
      <organization></organization>
    </author>
    <author initials="S." surname="Schinzel" fullname="Sebastian Schinzel">
      <organization></organization>
    </author>
    <author initials="S." surname="Friedberger" fullname="Simon Friedberger">
      <organization></organization>
    </author>
    <author initials="J." surname="Somorovsky" fullname="Juraj Somorovsky">
      <organization></organization>
    </author>
    <author initials="J." surname="Schwenk" fullname="Jörg Schwenk">
      <organization></organization>
    </author>
    <date year="2018" month="August"/>
  </front>
</reference>
<reference anchor="mixed-content" target="https://www.w3.org/TR/mixed-content/">
  <front>
    <title>Mixed Content</title>
    <author >
      <organization></organization>
    </author>
    <date year="2023" month="February"/>
  </front>
</reference>
<reference anchor="ORACLE" target="https://www.usenix.org/conference/usenixsecurity23/presentation/ising">
  <front>
    <title>Content-Type: multipart/oracle Tapping into Format Oracles in Email End-to-End Encryption</title>
    <author initials="F." surname="Ising" fullname="Fabian Ising">
      <organization></organization>
    </author>
    <author initials="D." surname="Poddebniak" fullname="Damian Poddebniak">
      <organization></organization>
    </author>
    <author initials="T." surname="Kappert" fullname="Tobias Kappert">
      <organization></organization>
    </author>
    <author initials="C." surname="Saatjohann" fullname="Christoph Saatjohann">
      <organization></organization>
    </author>
    <author initials="S." surname="Schinzel" fullname="Sebastian Schinzel">
      <organization></organization>
    </author>
    <date year="2023" month="August"/>
  </front>
</reference>
<reference anchor="SRI" target="https://www.w3.org/TR/SRI/">
  <front>
    <title>Subresource Integrity</title>
    <author >
      <organization></organization>
    </author>
    <date year="2016" month="June"/>
  </front>
</reference>
<reference anchor="PKCS11" target="https://docs.oasis-open.org/pkcs11/pkcs11-spec/v3.1/os/pkcs11-spec-v3.1-os.html">
  <front>
    <title>PKCS</title>
    <author initials="D." surname="Bong" fullname="Dieter Bong">
      <organization></organization>
    </author>
    <author initials="T." surname="Cox" fullname="Tony Cox">
      <organization></organization>
    </author>
    <date year="2023" month="July" day="23"/>
  </front>
</reference>
<reference anchor="DROWN" target="https://drownattack.com/">
  <front>
    <title>DROWN: Breaking TLS using SSLv2</title>
    <author initials="N." surname="Aviram" fullname="Nimrod Aviram">
      <organization></organization>
    </author>
    <author initials="S." surname="Schinzel" fullname="Sebastian Schinzel">
      <organization></organization>
    </author>
    <author initials="J." surname="Somorovsky" fullname="Juraj Somorovsky">
      <organization></organization>
    </author>
    <author initials="N." surname="Heninger" fullname="Nadia Heninger">
      <organization></organization>
    </author>
    <author initials="M." surname="Dankel" fullname="Maik Dankel">
      <organization></organization>
    </author>
    <author initials="J." surname="Steube" fullname="Jens Steube">
      <organization></organization>
    </author>
    <author initials="L." surname="Valenta" fullname="Luke Valenta">
      <organization></organization>
    </author>
    <author initials="D." surname="Adrian" fullname="David Adrian">
      <organization></organization>
    </author>
    <author initials="J. A." surname="Halderman" fullname="J. Alex Halderman">
      <organization></organization>
    </author>
    <author initials="V." surname="Dukhovni" fullname="Viktor Dukhovni">
      <organization></organization>
    </author>
    <author initials="E." surname="Käsper" fullname="Emilia Käsper">
      <organization></organization>
    </author>
    <author initials="S." surname="Cohney" fullname="Shaanan Cohney">
      <organization></organization>
    </author>
    <author initials="S." surname="Engels" fullname="Susanne Engels">
      <organization></organization>
    </author>
    <author initials="C." surname="Paar" fullname="Christof Paar">
      <organization></organization>
    </author>
    <author initials="Y." surname="Shavitt" fullname="Yuval Shavitt">
      <organization></organization>
    </author>
    <date year="2016" month="March"/>
  </front>
</reference>
<reference anchor="IKE" target="https://www.usenix.org/system/files/conference/usenixsecurity18/sec18-felsch.pdf">
  <front>
    <title>The Dangers of Key Reuse: Practical Attacks on IPsec IKE</title>
    <author initials="D." surname="Felsch" fullname="Dennis Felsch">
      <organization></organization>
    </author>
    <author initials="M." surname="Grothe" fullname="Martin Grothe">
      <organization></organization>
    </author>
    <author initials="J." surname="Schwenk" fullname="Jörg Schwenk">
      <organization></organization>
    </author>
    <author initials="A." surname="Czubak" fullname="Adam Czubak">
      <organization></organization>
    </author>
    <author initials="M." surname="Szymane" fullname="Marcin Szymane">
      <organization></organization>
    </author>
    <date year="2018" month="August"/>
  </front>
</reference>


<reference anchor='REPLY'>
  <front>
    <title>Re: What’s Up Johnny?: Covert Content Attacks on Email End-to-End Encryption</title>
    <author fullname='Jens Müller' initials='J.' surname='Müller'>
      <organization/>
    </author>
    <author fullname='Marcus Brinkmann' initials='M.' surname='Brinkmann'>
      <organization/>
    </author>
    <author fullname='Damian Poddebniak' initials='D.' surname='Poddebniak'>
      <organization/>
    </author>
    <author fullname='Sebastian Schinzel' initials='S.' surname='Schinzel'>
      <organization/>
    </author>
    <author fullname='Jörg Schwenk' initials='J.' surname='Schwenk'>
      <organization/>
    </author>
    <date year='2019'/>
  </front>
  <seriesInfo name='Applied Cryptography and Network Security' value='pp. 24-42'/>
  <seriesInfo name='DOI' value='10.1007/978-3-030-21568-2_2'/>
</reference>


<reference anchor="SPOOFING" target="https://www.usenix.org/system/files/sec19-muller.pdf">
  <front>
    <title>“Johnny, you are fired!” – Spoofing OpenPGP and S/MIME Signatures in Emails</title>
    <author initials="J." surname="Müller" fullname="Jens Müller">
      <organization></organization>
    </author>
    <author initials="M." surname="Brinkmann" fullname="Marcus Brinkmann">
      <organization></organization>
    </author>
    <author initials="D." surname="Poddebniak" fullname="Damian Poddebniak">
      <organization></organization>
    </author>
    <author initials="H." surname="Böck" fullname="Hanno Böck">
      <organization></organization>
    </author>
    <author initials="S." surname="Schinzel" fullname="Sebastian Schinzel">
      <organization></organization>
    </author>
    <author initials="J." surname="Somorovsky" fullname="Juraj Somorovsky">
      <organization></organization>
    </author>
    <author initials="J." surname="Schwenk" fullname="Jörg Schwenk">
      <organization></organization>
    </author>
    <date year="2019" month="August"/>
  </front>
</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='RFC3207'>
  <front>
    <title>SMTP Service Extension for Secure SMTP over Transport Layer Security</title>
    <author fullname='P. Hoffman' initials='P.' surname='Hoffman'/>
    <date month='February' year='2002'/>
    <abstract>
      <t>This document describes an extension to the SMTP (Simple Mail Transfer Protocol) service that allows an SMTP server and client to use TLS (Transport Layer Security) to provide private, authenticated communication over the Internet. This gives SMTP agents the ability to protect some or all of their communications from eavesdroppers and attackers. [STANDARDS-TRACK]</t>
    </abstract>
  </front>
  <seriesInfo name='RFC' value='3207'/>
  <seriesInfo name='DOI' value='10.17487/RFC3207'/>
</reference>

<reference anchor='RFC6376'>
  <front>
    <title>DomainKeys Identified Mail (DKIM) Signatures</title>
    <author fullname='D. Crocker' initials='D.' role='editor' surname='Crocker'/>
    <author fullname='T. Hansen' initials='T.' role='editor' surname='Hansen'/>
    <author fullname='M. Kucherawy' initials='M.' role='editor' surname='Kucherawy'/>
    <date month='September' year='2011'/>
    <abstract>
      <t>DomainKeys Identified Mail (DKIM) permits a person, role, or organization that owns the signing domain to claim some responsibility for a message by associating the domain with the message. This can be an author's organization, an operational relay, or one of their agents. DKIM separates the question of the identity of the Signer of the message from the purported author of the message. Assertion of responsibility is validated through a cryptographic signature and by querying the Signer's domain directly to retrieve the appropriate public key. Message transit from author to recipient is through relays that typically make no substantive change to the message content and thus preserve the DKIM signature.</t>
      <t>This memo obsoletes RFC 4871 and RFC 5672. [STANDARDS-TRACK]</t>
    </abstract>
  </front>
  <seriesInfo name='STD' value='76'/>
  <seriesInfo name='RFC' value='6376'/>
  <seriesInfo name='DOI' value='10.17487/RFC6376'/>
</reference>

<reference anchor='RFC7435'>
  <front>
    <title>Opportunistic Security: Some Protection Most of the Time</title>
    <author fullname='V. Dukhovni' initials='V.' surname='Dukhovni'/>
    <date month='December' year='2014'/>
    <abstract>
      <t>This document defines the concept "Opportunistic Security" in the context of communications protocols. Protocol designs based on Opportunistic Security use encryption even when authentication is not available, and use authentication when possible, thereby removing barriers to the widespread use of encryption on the Internet.</t>
    </abstract>
  </front>
  <seriesInfo name='RFC' value='7435'/>
  <seriesInfo name='DOI' value='10.17487/RFC7435'/>
</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='I-D.ietf-openpgp-crypto-refresh-13'>
   <front>
      <title>OpenPGP</title>
      <author fullname='Paul Wouters' initials='P.' surname='Wouters'>
         <organization>Aiven</organization>
      </author>
      <author fullname='Daniel Huigens' initials='D.' surname='Huigens'>
         <organization>Proton AG</organization>
      </author>
      <author fullname='Justus Winter' initials='J.' surname='Winter'>
         <organization>Sequoia-PGP</organization>
      </author>
      <author fullname='Niibe Yutaka' initials='N.' surname='Yutaka'>
         <organization>FSIJ</organization>
      </author>
      <date day='4' month='January' year='2024'/>
      <abstract>
	 <t>   This document specifies the message formats used in OpenPGP.  OpenPGP
   provides encryption with public-key or symmetric cryptographic
   algorithms, digital signatures, compression and key management.

   This document is maintained in order to publish all necessary
   information needed to develop interoperable applications based on the
   OpenPGP format.  It is not a step-by-step cookbook for writing an
   application.  It describes only the format and methods needed to
   read, check, generate, and write conforming packets crossing any
   network.  It does not deal with storage and implementation questions.
   It does, however, discuss implementation issues necessary to avoid
   security flaws.

   This document obsoletes: RFC 4880 (OpenPGP), RFC 5581 (Camellia in
   OpenPGP) and RFC 6637 (Elliptic Curves in OpenPGP).

	 </t>
      </abstract>
   </front>
   <seriesInfo name='Internet-Draft' value='draft-ietf-openpgp-crypto-refresh-13'/>
   
</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='RFC5355'>
  <front>
    <title>Threats Introduced by Reliable Server Pooling (RSerPool) and Requirements for Security in Response to Threats</title>
    <author fullname='M. Stillman' initials='M.' role='editor' surname='Stillman'/>
    <author fullname='R. Gopal' initials='R.' surname='Gopal'/>
    <author fullname='E. Guttman' initials='E.' surname='Guttman'/>
    <author fullname='S. Sengodan' initials='S.' surname='Sengodan'/>
    <author fullname='M. Holdrege' initials='M.' surname='Holdrege'/>
    <date month='September' year='2008'/>
    <abstract>
      <t>Reliable Server Pooling (RSerPool) is an architecture and set of protocols for the management and access to server pools supporting highly reliable applications and for client access mechanisms to a server pool. This document describes security threats to the RSerPool architecture and presents requirements for security to thwart these threats. This memo provides information for the Internet community.</t>
    </abstract>
  </front>
  <seriesInfo name='RFC' value='5355'/>
  <seriesInfo name='DOI' value='10.17487/RFC5355'/>
</reference>

<reference anchor='RFC7292'>
  <front>
    <title>PKCS #12: Personal Information Exchange Syntax v1.1</title>
    <author fullname='K. Moriarty' initials='K.' role='editor' surname='Moriarty'/>
    <author fullname='M. Nystrom' initials='M.' surname='Nystrom'/>
    <author fullname='S. Parkinson' initials='S.' surname='Parkinson'/>
    <author fullname='A. Rusch' initials='A.' surname='Rusch'/>
    <author fullname='M. Scott' initials='M.' surname='Scott'/>
    <date month='July' year='2014'/>
    <abstract>
      <t>PKCS #12 v1.1 describes a transfer syntax for personal identity information, including private keys, certificates, miscellaneous secrets, and extensions. Machines, applications, browsers, Internet kiosks, and so on, that support this standard will allow a user to import, export, and exercise a single set of personal identity information. This standard supports direct transfer of personal information under several privacy and integrity modes.</t>
      <t>This document represents a republication of PKCS #12 v1.1 from RSA Laboratories' Public Key Cryptography Standard (PKCS) series. By publishing this RFC, change control is transferred to the IETF.</t>
    </abstract>
  </front>
  <seriesInfo name='RFC' value='7292'/>
  <seriesInfo name='DOI' value='10.17487/RFC7292'/>
</reference>

<reference anchor='RFC8823'>
  <front>
    <title>Extensions to Automatic Certificate Management Environment for End-User S/MIME Certificates</title>
    <author fullname='A. Melnikov' initials='A.' surname='Melnikov'/>
    <date month='April' year='2021'/>
    <abstract>
      <t>This document specifies identifiers and challenges required to enable the Automated Certificate Management Environment (ACME) to issue certificates for use by email users that want to use S/MIME.</t>
    </abstract>
  </front>
  <seriesInfo name='RFC' value='8823'/>
  <seriesInfo name='DOI' value='10.17487/RFC8823'/>
</reference>


<reference anchor='I-D.woodhouse-cert-best-practice'>
   <front>
      <title>Recommendations for applications using X.509 client certificates</title>
      <author fullname='David Woodhouse' initials='D.' surname='Woodhouse'>
         <organization>Amazon Web Services</organization>
      </author>
      <author fullname='Nikos Mavrogiannopoulos' initials='N.' surname='Mavrogiannopoulos'>
         </author>
      <date day='25' month='July' year='2023'/>
      <abstract>
	 <t>   X.509 certificates are widely used for client authentication in many
   protocols, especially in conjunction with Transport Layer Security
   ([RFC5246]) and Datagram Transport Layer Security ([RFC6347].  There
   exist a multitude of forms in which certificates and especially their
   corresponding private keys may be stored or referenced.

   Applications have historically been massively inconsistent in which
   subset of these forms have been supported, and what knowledge is
   demanded of the user.  This memo sets out best practice for
   applications in the interest of usability and consistency.

	 </t>
      </abstract>
   </front>
   <seriesInfo name='Internet-Draft' value='draft-woodhouse-cert-best-practice-01'/>
   
</reference>


<reference anchor='I-D.dkg-mail-cleartext-copy'>
   <front>
      <title>Encrypted E-mail with Cleartext Copies</title>
      <author fullname='Daniel Kahn Gillmor' initials='D. K.' surname='Gillmor'>
         </author>
      <date day='21' month='February' year='2023'/>
      <abstract>
	 <t>   When an e-mail program generates an encrypted message to multiple
   recipients, it is possible that it has no encryption capability for
   at least one of the recipients.

   In this circumstance, an e-mail program may choose to send the
   message in cleartext to the recipient it cannot encrypt to.

   This draft currently offers several possible approaches when such a
   choice is made by the sender, so that the recipient can reason about
   and act on the cryptographic status of the message responsibly.

	 </t>
      </abstract>
   </front>
   <seriesInfo name='Internet-Draft' value='draft-dkg-mail-cleartext-copy-01'/>
   
</reference>

<reference anchor='RFC6409'>
  <front>
    <title>Message Submission for Mail</title>
    <author fullname='R. Gellens' initials='R.' surname='Gellens'/>
    <author fullname='J. Klensin' initials='J.' surname='Klensin'/>
    <date month='November' year='2011'/>
    <abstract>
      <t>This memo splits message submission from message relay, allowing each service to operate according to its own rules (for security, policy, etc.), and specifies what actions are to be taken by a submission server.</t>
      <t>Message relay is unaffected, and continues to use SMTP over port 25.</t>
      <t>When conforming to this document, message submission uses the protocol specified here, normally over port 587.</t>
      <t>This separation of function offers a number of benefits, including the ability to apply specific security or policy requirements. [STANDARDS-TRACK]</t>
    </abstract>
  </front>
  <seriesInfo name='STD' value='72'/>
  <seriesInfo name='RFC' value='6409'/>
  <seriesInfo name='DOI' value='10.17487/RFC6409'/>
</reference>

<reference anchor='RFC3501'>
  <front>
    <title>INTERNET MESSAGE ACCESS PROTOCOL - VERSION 4rev1</title>
    <author fullname='M. Crispin' initials='M.' surname='Crispin'/>
    <date month='March' year='2003'/>
    <abstract>
      <t>The Internet Message Access Protocol, Version 4rev1 (IMAP4rev1) allows a client to access and manipulate electronic mail messages on a server. IMAP4rev1 permits manipulation of mailboxes (remote message folders) in a way that is functionally equivalent to local folders. IMAP4rev1 also provides the capability for an offline client to resynchronize with the server. IMAP4rev1 includes operations for creating, deleting, and renaming mailboxes, checking for new messages, permanently removing messages, setting and clearing flags, RFC 2822 and RFC 2045 parsing, searching, and selective fetching of message attributes, texts, and portions thereof. Messages in IMAP4rev1 are accessed by the use of numbers. These numbers are either message sequence numbers or unique identifiers. IMAP4rev1 supports a single server. A mechanism for accessing configuration information to support multiple IMAP4rev1 servers is discussed in RFC 2244. IMAP4rev1 does not specify a means of posting mail; this function is handled by a mail transfer protocol such as RFC 2821. [STANDARDS-TRACK]</t>
    </abstract>
  </front>
  <seriesInfo name='RFC' value='3501'/>
  <seriesInfo name='DOI' value='10.17487/RFC3501'/>
</reference>

<reference anchor='RFC8621'>
  <front>
    <title>The JSON Meta Application Protocol (JMAP) for Mail</title>
    <author fullname='N. Jenkins' initials='N.' surname='Jenkins'/>
    <author fullname='C. Newman' initials='C.' surname='Newman'/>
    <date month='August' year='2019'/>
    <abstract>
      <t>This document specifies a data model for synchronising email data with a server using the JSON Meta Application Protocol (JMAP). Clients can use this to efficiently search, access, organise, and send messages, and to get push notifications for fast resynchronisation when new messages are delivered or a change is made in another client.</t>
    </abstract>
  </front>
  <seriesInfo name='RFC' value='8621'/>
  <seriesInfo name='DOI' value='10.17487/RFC8621'/>
</reference>


<reference anchor='I-D.ietf-jmap-smime-sender-extensions'>
   <front>
      <title>JMAP extension for S/MIME signing and encryption</title>
      <author fullname='Alexey Melnikov' initials='A.' surname='Melnikov'>
         <organization>Isode Ltd</organization>
      </author>
      <date day='3' month='August' year='2023'/>
      <abstract>
	 <t>   This document specifies an extension to JMAP for sending S/MIME
   signed and/or S/MIME encrypted messages, as well as automatic
   decryption of received S/MIME messages.

	 </t>
      </abstract>
   </front>
   <seriesInfo name='Internet-Draft' value='draft-ietf-jmap-smime-sender-extensions-04'/>
   
</reference>

<reference anchor='RFC1939'>
  <front>
    <title>Post Office Protocol - Version 3</title>
    <author fullname='J. Myers' initials='J.' surname='Myers'/>
    <author fullname='M. Rose' initials='M.' surname='Rose'/>
    <date month='May' year='1996'/>
    <abstract>
      <t>The Post Office Protocol - Version 3 (POP3) is intended to permit a workstation to dynamically access a maildrop on a server host in a useful fashion. [STANDARDS-TRACK]</t>
    </abstract>
  </front>
  <seriesInfo name='STD' value='53'/>
  <seriesInfo name='RFC' value='1939'/>
  <seriesInfo name='DOI' value='10.17487/RFC1939'/>
</reference>

<reference anchor='RFC9219'>
  <front>
    <title>S/MIME Signature Verification Extension to the JSON Meta Application Protocol (JMAP)</title>
    <author fullname='A. Melnikov' initials='A.' surname='Melnikov'/>
    <date month='April' year='2022'/>
    <abstract>
      <t>This document specifies an extension to "The JSON Meta Application Protocol (JMAP) for Mail" (RFC 8621) for returning the S/MIME signature verification status.</t>
    </abstract>
  </front>
  <seriesInfo name='RFC' value='9219'/>
  <seriesInfo name='DOI' value='10.17487/RFC9219'/>
</reference>


<reference anchor='I-D.ietf-openpgp-crypto-refresh'>
   <front>
      <title>OpenPGP</title>
      <author fullname='Paul Wouters' initials='P.' surname='Wouters'>
         <organization>Aiven</organization>
      </author>
      <author fullname='Daniel Huigens' initials='D.' surname='Huigens'>
         <organization>Proton AG</organization>
      </author>
      <author fullname='Justus Winter' initials='J.' surname='Winter'>
         <organization>Sequoia-PGP</organization>
      </author>
      <author fullname='Niibe Yutaka' initials='N.' surname='Yutaka'>
         <organization>FSIJ</organization>
      </author>
      <date day='4' month='January' year='2024'/>
      <abstract>
	 <t>   This document specifies the message formats used in OpenPGP.  OpenPGP
   provides encryption with public-key or symmetric cryptographic
   algorithms, digital signatures, compression and key management.

   This document is maintained in order to publish all necessary
   information needed to develop interoperable applications based on the
   OpenPGP format.  It is not a step-by-step cookbook for writing an
   application.  It describes only the format and methods needed to
   read, check, generate, and write conforming packets crossing any
   network.  It does not deal with storage and implementation questions.
   It does, however, discuss implementation issues necessary to avoid
   security flaws.

   This document obsoletes: RFC 4880 (OpenPGP), RFC 5581 (Camellia in
   OpenPGP) and RFC 6637 (Elliptic Curves in OpenPGP).

	 </t>
      </abstract>
   </front>
   <seriesInfo name='Internet-Draft' value='draft-ietf-openpgp-crypto-refresh-13'/>
   
</reference>

<reference anchor='RFC9216'>
  <front>
    <title>S/MIME Example Keys and Certificates</title>
    <author fullname='D. K. Gillmor' initials='D. K.' role='editor' surname='Gillmor'/>
    <date month='April' year='2022'/>
    <abstract>
      <t>The S/MIME development community benefits from sharing samples of signed or encrypted data. This document facilitates such collaboration by defining a small set of X.509v3 certificates and keys for use when generating such samples.</t>
    </abstract>
  </front>
  <seriesInfo name='RFC' value='9216'/>
  <seriesInfo name='DOI' value='10.17487/RFC9216'/>
</reference>

<reference anchor='RFC4511'>
  <front>
    <title>Lightweight Directory Access Protocol (LDAP): The Protocol</title>
    <author fullname='J. Sermersheim' initials='J.' role='editor' surname='Sermersheim'/>
    <date month='June' year='2006'/>
    <abstract>
      <t>This document describes the protocol elements, along with their semantics and encodings, of the Lightweight Directory Access Protocol (LDAP). LDAP provides access to distributed directory services that act in accordance with X.500 data and service models. These protocol elements are based on those described in the X.500 Directory Access Protocol (DAP). [STANDARDS-TRACK]</t>
    </abstract>
  </front>
  <seriesInfo name='RFC' value='4511'/>
  <seriesInfo name='DOI' value='10.17487/RFC4511'/>
</reference>


<reference anchor='I-D.koch-openpgp-webkey-service'>
   <front>
      <title>OpenPGP Web Key Directory</title>
      <author fullname='Werner Koch' initials='W.' surname='Koch'>
         <organization>g10 Code GmbH</organization>
      </author>
      <date day='18' month='December' year='2023'/>
      <abstract>
	 <t>   This specification describes a service to locate OpenPGP keys by mail
   address using a Web service and the HTTPS protocol.  It also provides
   a method for secure communication between the key owner and the mail
   provider to publish and revoke the public key.

	 </t>
      </abstract>
   </front>
   <seriesInfo name='Internet-Draft' value='draft-koch-openpgp-webkey-service-17'/>
   
</reference>

<reference anchor='RFC8162'>
  <front>
    <title>Using Secure DNS to Associate Certificates with Domain Names for S/MIME</title>
    <author fullname='P. Hoffman' initials='P.' surname='Hoffman'/>
    <author fullname='J. Schlyter' initials='J.' surname='Schlyter'/>
    <date month='May' year='2017'/>
    <abstract>
      <t>This document describes how to use secure DNS to associate an S/MIME user's certificate with the intended domain name, similar to the way that DNS-Based Authentication of Named Entities (DANE), RFC 6698, does for TLS.</t>
    </abstract>
  </front>
  <seriesInfo name='RFC' value='8162'/>
  <seriesInfo name='DOI' value='10.17487/RFC8162'/>
</reference>

<reference anchor='RFC7929'>
  <front>
    <title>DNS-Based Authentication of Named Entities (DANE) Bindings for OpenPGP</title>
    <author fullname='P. Wouters' initials='P.' surname='Wouters'/>
    <date month='August' year='2016'/>
    <abstract>
      <t>OpenPGP is a message format for email (and file) encryption that lacks a standardized lookup mechanism to securely obtain OpenPGP public keys. DNS-Based Authentication of Named Entities (DANE) is a method for publishing public keys in DNS. This document specifies a DANE method for publishing and locating OpenPGP public keys in DNS for a specific email address using a new OPENPGPKEY DNS resource record. Security is provided via Secure DNS, however the OPENPGPKEY record is not a replacement for verification of authenticity via the "web of trust" or manual verification. The OPENPGPKEY record can be used to encrypt an email that would otherwise have to be sent unencrypted.</t>
    </abstract>
  </front>
  <seriesInfo name='RFC' value='7929'/>
  <seriesInfo name='DOI' value='10.17487/RFC7929'/>
</reference>




    </references>


<section anchor="future-work"><name>Future Work</name>

<t>This document contains useful guidance for MUA implementers, but it cannot contain all possible guidance.
Future revisions to this document may want to further explore the following topics, which are out of scope for this version.</t>

<section anchor="test-vectors"><name>Test Vectors</name>

<t>A future version of this document (or a companion document) could contain examples of well-formed and malformed messages using cryptographic key material and certificates from <xref target="I-D.ietf-openpgp-crypto-refresh"/> and <xref target="RFC9216"/>.</t>

<t>It may also include example renderings of these messages.</t>

</section>
<section anchor="more-peer-certs"><name>Further Guidance on Peer Certificates</name>

<section anchor="peer-discovery-incoming"><name>Certificate Discovery from Incoming Messages</name>

<t>As described in <xref target="sending-certificates"/>, an incoming e-mail message may have one or more certificates embedded in it.
This document currently acknowledges that receiving MUA should assemble a cache of certificates for future use, but providing more detailed guidance for how to assemble and manage that cache is currently out of scope.</t>

<t>Existing recommendations like <xref target="AUTOCRYPT"/> provide some guidance for handling incoming certificates about peers, but only in certain contexts.
A future version of this document may describe in more detail how these incoming certs should be handled.</t>

</section>
<section anchor="peer-discovery--directory"><name>Certificate Directories</name>

<t>Some MUAs may have the capability to look up peer certificates in a directory, for example via LDAP <xref target="RFC4511"/>, WKD <xref target="I-D.koch-openpgp-webkey-service"/>, or the DNS (e.g. SMIMEA <xref target="RFC8162"/> or OPENPGPKEY <xref target="RFC7929"/> resource records).</t>

<t>A future version of this document may describe in more detail what sources an MUA should consider when searching for a peer's certificates, and what to do with the certificates found by various methods.</t>

</section>
<section anchor="cert-revocation"><name>Checking for Certificate Revocation</name>

<t>A future version of this document could discuss how/when to check for revocation of peer certificates, or of the user's own certificate.</t>

<t>Such discussion should address privacy concerns: what information leaks to whom when checking peer cert revocations?</t>

</section>
<section anchor="more-peer-cert-selection"><name>Further Peer Certificate Selection</name>

<t>A future version of this document may describe more prescriptions for deciding whether a peer certificate is acceptable for encrypting a message.
For example, if the SPKI is an EC Public Key and the keyUsage extension is absent, what should the encrypting MUA do?</t>

<t>A future version of this document might also provide guidance on what to do if multiple certificates are all acceptable for encrypting to a given recipient.
For example, the sender could select among them in some deterministic way; it could encrypt to all of them; or it could present them to the user to let the user select any or all of them.</t>

</section>
</section>
<section anchor="more-local-certs"><name>Further Guidance on Local Certificates and Secret Keys</name>

<section anchor="cross-mua-local-keys"><name>Cross-MUA sharing of Local Certificates and Secret Keys</name>

<t>Many users today use more than one MUA to access the same mailbox (for example, one MUA on a mobile device, and another MUA on a desktop computer).</t>

<t>A future version of this document might offer guidance on how multiple MUAs attached to the same mailbox can efficiently and securely share the user's own secret key material and certificates between each other.
This guidance should include suggestions on how to maintain the user's keys (e.g. avoiding certificate expiration) and safe secret key transmission.</t>

</section>
<section anchor="smartcards"><name>Use of Smartcards or Other Portable Secret Key Mechanisms</name>

<t>Rather than having to transfer secret key material between clients, some users may prefer to rely on portable hardware-backed secret keys in the form of smartcards, USB tokens or other comparable form factors.
These secret keys sometimes require direct user interaction for each use, which can complicate the usability of any MUA that uses them to decrypt a large number of messages.</t>

<t>Guidance on the use of this kind of secret key management are beyond the scope of this document, but future revisions may bring them into scope.</t>

</section>
<section anchor="more-local-cert-maintenance"><name>Active Local Certificate Maintenance</name>

<t><xref target="local-cert-maintenance"/> describes conditions where the MUA <bcp14>SHOULD</bcp14> warn the user that something is going wrong with their certificate.</t>

<t>A future version of this document might outline how an MUA could actively avoid these warning situations, for example, by automatically updating the certificate or prompting the user to take specific action.</t>

</section>
</section>
<section anchor="cert-authorities"><name>Certification Authorities</name>

<t>A future document could offer guidance on how an MUA should select and manage root certification authorities (CAs).</t>

<t>For example:</t>

<t><list style="symbols">
  <t>Should the MUA cache intermediate CAs?</t>
  <t>Should the MUA share such a cache with other PKI clients (e.g., web browsers)?</t>
  <t>What distinctions are there between a CA for S/MIME and a CA for the web?</t>
</list></t>

</section>
<section anchor="indexing-and-search"><name>Indexing and Search of Encrypted Messages</name>

<t>A common use case for MUAs is search of existing messages by keyword or topic.
This is done most efficiently for large mailboxes by assembling an index of message content, rather than by a linear scan of all message content.</t>

<t>When message contents and header fields are encrypted, search by index is complicated.
If the cleartext is not indexed, then messages cannot be found by search.
On the other hand, if the cleartext is indexed, then the index effectively contains the sensitive contents of the message, and needs to be protected.</t>

<t>Detailed guidance on the tradeoff here, including choices about remote search vs local search, are beyond the scope of this document, but a future version of the document may bring them into scope.</t>

</section>
<section anchor="cached-sigs"><name>Cached Signature Validation</name>

<t>Asymmetric signature validation can be computationally expensive, and the results can also potentially vary over time (e.g. if a signing certificate is discovered to be revoked).
In some cases, the user may care about the signature validation that they saw when they first read or received the message, not only about the status of the signature verification at the current time.</t>

<t>So, for both performance reasons and historical perspective, it may be useful for an MUA to cache signature validation results in a way that they can be easily retrieved and compared.
Documenting how and when to cache signature validation, as well as how to indicate it to the user, is beyond the scope of this document, but a future version of the document may bring these topics into scope.</t>

</section>
<section anchor="aggregate-cryptographic-status"><name>Aggregate Cryptographic Status</name>

<t>This document limits itself to consideration of the cryptographic status of single messages as a baseline concept that can be clearly and simply communicated to the user.
However, some users and some MUAs may find it useful to contemplate even higher-level views of cryptographic status which are not considered directly here.</t>

<t>For example, a future version of the document may also consider how to indicate a simple cryptographic status of message threads (groups of explicitly related messages), conversations (groups of messages with shared sets of participants), peers, or other perspectives that an MUA can provide.</t>

</section>
<section anchor="expect-e2e"><name>Expectations of Cryptographic Protection</name>

<t>As mentioned in <xref target="security-indicators"/>, the types of security indicators displayed to the user may well vary based on the expectations of the user for a given communication.
At present, there is no widely shared method for the MUA to establish and maintain reasonable expectations about whether a specific received message should have cryptographic protections.</t>

<t>If such a standard is developed, a future version of this document should reference it and encourage the deployment of clearer and simpler security indicators.</t>

</section>
<section anchor="secure-deletion"><name>Secure Deletion</name>

<t>One feature many users desire from a secure communications medium is the ability to reliably destroy a message such that it cannot be recovered even by a determined adversary.
In other contexts, a similar desired property is called "forward secrecy".
Doing this with standard e-mail mechanisms like S/MIME and PGP/MIME is challenging because of two interrelated factors:</t>

<t><list style="symbols">
  <t>A copy of of an e-mail message may be retained by any of the mail transport agents that handle it during delivery, and</t>
  <t>The secret key used to decrypt an encrypted e-mail message is typically retained indefinitely.</t>
</list></t>

<t>This means that an adversary aiming to recover the cleartext contents of a deleted message can do so by getting access to a copy of the encrypted message and the long-term secret key material.</t>

<t>Some mitigation measures may be available to make it possible to delete some encrypted messages securely, but this document considers this use case out of scope.
A future version of the document may elaborate on secure message deleton in more detail.</t>

</section>
<section anchor="interaction-with-opportunistic-encryption"><name>Interaction with Opportunistic Encryption</name>

<t>This document focuses on guidance for strong, user-comprehensible end-to-end cryptographic protections for e-mail.
Other approaches are possible, including various forms of opportunistic and transport encryption, which are out of scope for this document.</t>

<t>A future version of this document could describe the interaction between this guidance and more opportunistic forms of encryption, for example some of the scenarios contemplated in <xref target="I-D.dkg-mail-cleartext-copy"/>.</t>

</section>
<section anchor="split-attachments"><name>Split Attachments</name>

<t>As noted in <xref target="attachments"/>, the standard form for encrypted e-mail messages is a single cryptographic envelope.
In a scenario where multiple user agents are drafting a single encrypted message over low-bandwidth links, this can create a poor user experience, as each MUA has to retrieve the full message, including attachments, to modify the draft.
Similarly, when retrieving a message with a large attachment, the receiving MUA might want to only render the main body part, and will have a significant delay in doing so if required to process the full message before handling.</t>

<t>Future work might include an attempt to standardize a mechanism that eases this use case, potentially at the risk of additional metadata leakage about the message (e.g., the size and number of message parts).
Any such work should explicitly try to minimize the risks and concerns described in <xref target="attachments"/>.</t>

</section>
<section anchor="proxy-extensions"><name>Proxy Extensions</name>

<t>As noted in <xref target="proxy-dangers"/>, a proxy-based implementation can be a tempting approach.
But its naive form is likely to be insufficient to provide safe end-to-end encrypted e-mail.</t>

<t>A future version of this document, or a separate but related document, could try to outline the specific additional information, state, and network API surface that would be needed to allow an MUA to be safely integrated with an encryption provider.
Any such work should try to address the potential problems described in <xref target="proxy-dangers"/>.</t>

</section>
</section>
<section anchor="document-history"><name>Document History</name>

<section anchor="substantive-changes-from-draft-ietf-13-to-draft-ietf-14"><name>Substantive changes from draft-ietf-...-13 to draft-ietf-...-14</name>

<t><list style="symbols">
  <t>Responded to SEC AD Review, including:</t>
  <t>clarify "conformant" vs "legacy" vs "non-cryptographic" MUA categories</t>
  <t>tighten up MUSTs for conformant MUAs</t>
  <t>explicitly recommend encrypting drafts</t>
  <t>clarify debugging as a use case for showing invalid signatures</t>
  <t>clarify "Headers" to "Header Fields"</t>
  <t>3 states for sending, 4 for receiving</t>
</list></t>

</section>
<section anchor="substantive-changes-from-draft-ietf-12-to-draft-ietf-13"><name>Substantive changes from draft-ietf-...-12 to draft-ietf-...-13</name>

<t><list style="symbols">
  <t>clarify RFC 2119 guidance about not rendering cryptographic layers other than message cryptographic status</t>
</list></t>

</section>
<section anchor="substantive-changes-from-draft-ietf-11-to-draft-ietf-12"><name>Substantive changes from draft-ietf-...-11 to draft-ietf-...-12</name>

<t><list style="symbols">
  <t>More nuance (and future work) around split attachments</t>
  <t>More nuance (and future work) around proxy-style design</t>
  <t>Clearer caveats about external resources in text/html parts</t>
</list></t>

</section>
<section anchor="substantive-changes-from-draft-ietf-10-to-draft-ietf-11"><name>Substantive changes from draft-ietf-...-10 to draft-ietf-...-11</name>

<t><list style="symbols">
  <t>Mention List-* and Archived-At message header fields</t>
  <t>Add additional references to papers that describe flaws in e2e e-mail</t>
</list></t>

</section>
<section anchor="substantive-changes-from-draft-ietf-09-to-draft-ietf-10"><name>Substantive changes from draft-ietf-...-09 to draft-ietf-...-10</name>

<t><list style="symbols">
  <t>Introduction: describe one major theme of Future Work</t>
</list></t>

</section>
<section anchor="substantive-changes-from-draft-ietf-08-to-draft-ietf-09"><name>Substantive changes from draft-ietf-...-08 to draft-ietf-...-09</name>

<t><list style="symbols">
  <t>Clarify goals of document</t>
  <t>Identify cross-protocol attacks in more detail to justify prescription against key reuse</t>
  <t>Add informative references to Opportunistic Encryption RFC and Certificate Best Practice draft</t>
  <t>Add "Reading Encrypted Messages after Certificate Expiration" section to Common Pitfalls and Guidelines</t>
  <t>Clean up nits identified by Stephen Farrell and Eliot Lear</t>
</list></t>

</section>
<section anchor="substantive-changes-from-draft-ietf-07-to-draft-ietf-08"><name>Substantive changes from draft-ietf-...-07 to draft-ietf-...-08</name>

<t><list style="symbols">
  <t>Add guidance about importing and exporting secret key material</t>
  <t>More explanation about "encryption outside, signature inside"</t>
  <t>Guidance about Intervening (resending) MUAs</t>
  <t>Include Sender and Resent-* as user-facing header fields</t>
  <t>Guidance about external subresources for cryptographically protected messages</t>
  <t>Relax "user-facing" definition to be more advisory</t>
</list></t>

</section>
<section anchor="substantive-changes-from-draft-ietf-06-to-draft-ietf-07"><name>Substantive changes from draft-ietf-...-06 to draft-ietf-...-07</name>

<t><list style="symbols">
  <t>Add Bernie Hoeneisen and Alexey Melnikov as editors</t>
  <t>Explicitly avoid requiring anything from IANA</t>
  <t>Simplify description of "attachments"</t>
  <t>Add concrete detail on how to compare e-mail addresses</t>
  <t>Explicitly define "Cryptographic Summary"</t>
</list></t>

</section>
<section anchor="substantive-changes-from-draft-ietf-05-to-draft-ietf-06"><name>Substantive changes from draft-ietf-...-05 to draft-ietf-...-06</name>

<t><list style="symbols">
  <t>Expand proxy implementation warning to comparable APIs</t>
  <t>Move many marked TODO and FIXME items to "Future Work"</t>
  <t>More detailed guidance on local certificates</t>
  <t>Provide guidance on encrypting draft messages</t>
  <t>More detailed guidanc eon shipping certificates in outbound messages</t>
  <t>Recommend implementing header protection</t>
  <t>Added "Future Work" subsection about interactions with opportunistic approaches</t>
</list></t>

</section>
<section anchor="substantive-changes-from-draft-ietf-04-to-draft-ietf-05"><name>Substantive changes from draft-ietf-...-04 to draft-ietf-...-05</name>

<t><list style="symbols">
  <t>Adopt and update text about Bcc from draft-ietf-lamps-header-protection</t>
  <t>Add section about the dangers of an implementation based on a network protocol proxy</t>
</list></t>

</section>
<section anchor="substantive-changes-from-draft-ietf-03-to-draft-ietf-04"><name>Substantive changes from draft-ietf-...-03 to draft-ietf-...-04</name>

<t><list style="symbols">
  <t>Added reference to <spanx style="verb">multipart/oracle</spanx> attacks</t>
  <t>Clarified that "Structural Header fields" are the same as RFC2045's "MIME Headers"</t>
</list></t>

</section>
<section anchor="substantive-changes-from-draft-ietf-02-to-draft-ietf-03"><name>Substantive changes from draft-ietf-...-02 to draft-ietf-...-03</name>

<t><list style="symbols">
  <t>Added section about mixed recipients</t>
  <t>Noted SMIMEA and OPENPGPKEY DNS RR cert discovery mechanisms</t>
  <t>Added more notes about simplified mental models</t>
  <t>More clarification on one-status-per-message</t>
  <t>Added guidance to defend against EFAIL</t>
</list></t>

</section>
<section anchor="substantive-changes-from-draft-ietf-01-to-draft-ietf-02"><name>Substantive changes from draft-ietf-...-01 to draft-ietf-...-02</name>

<t><list style="symbols">
  <t>Added definition of "user-facing" header fields</t>
</list></t>

</section>
<section anchor="substantive-changes-from-draft-ietf-00-to-draft-ietf-01"><name>Substantive changes from draft-ietf-...-00 to draft-ietf-...-01</name>

<t><list style="symbols">
  <t>Added section about distinguishing Main Body Parts and Attachments</t>
  <t>Updated document considerations section, including reference to auto-built editor's copy</t>
</list></t>

</section>
<section anchor="substantive-changes-from-draft-dkg-01-to-draft-ietf-00"><name>Substantive changes from draft-dkg-...-01 to draft-ietf-...-00</name>

<t><list style="symbols">
  <t>WG adopted draft</t>
  <t>moved Document History and Document Considerations sections to end of appendix, to avoid section renumbering when removed</t>
</list></t>

</section>
<section anchor="substantive-changes-from-draft-dkg-00-to-draft-dkg-01"><name>Substantive changes from draft-dkg-...-00 to draft-dkg-...-01</name>

<t><list style="symbols">
  <t>consideration of success/failure indicators for usability</t>
  <t>clarify extendedKeyUsage and keyUsage algorithm-specific details</t>
  <t>initial section on certificate management</t>
  <t>added more TODO items</t>
</list></t>

</section>
</section>


  </back>

<!-- ##markdown-source:
H4sIAAAAAAAAA8y9W48b15Ym+J6/Iop6cKZAUsqUfNOpLldaStlp65JHKdll
GEZnkAyS4SQjeOKSKR5BhUI/dP+AqXnrAeZhgEYD8zjoh8E8Tf2T80tmXfde
Oy5M2udUY3Cq4FQwLvuy9rqvb41Go4MqrVbJk+ibOp3F2TSJ8iw6y2ajKh/B
f6Kz0TpOV9FlMq2LtNoezPJpFq/h/lkRz6tRmlTz0Speb8pRcpLQvaOFvGl0
/PhgGlfJIi+2T6I0m+cHB+mmeBJVRV1WJw8ffvnw5CAukhh/rA5u8+J6UeT1
5klELzy4TrZwbfYkOs+qpMiSavQMv3lQ1pN1WpZpnr3dbmAk52dvnx8clFWc
zf5jvMozuLRNyoObJKuTJwdRJC8dvDh9eXE5gAsVPTb4ET6YZovoG/wdr+Po
4Xq5icv1P+LMxnmxwB/iYrqEH5ZVtSmfPHiA9+Gl9CYZ620P8MKDSZHflskD
esMDfLJINrl5cgFrHU/G03z9YHa9eNBaMnxkBUtWVuYhuHMsD6Z5+xn4zkFc
V8u8wMmO4P8jWM/ySfRsHH0/jr5JV6t1XtBl3rlncZYmq+j7eJkFv8IsnkSn
66RIp3EWPU1vYN9fpJOkqNKkjN5lsOB0X1kVSQIDPD75NPq6yONZdFmN6Zcp
UMiT6FVyG/0EazuMXv3El/MZfPb44cOHj+XfdVYhTby7PKUL8WRSJDfw8acv
3tGFhLcCZv6P83ReLWFyJVzLxkAFdEORI80ms7SiwZtZfz2Ovs2TLEnLJDOT
/hooKE0aP9GMN2eb6DmMaBZXzRm+hsknBRBIPEmy6LGZ49NvR188fvgw+jFF
2qyWdRHO7PI2rf6cFCugSTuhCY1ivNRR/OMm2Yzn4cfhnD2JdO/D3x/cMffT
cfQyWWXpdX5jpn66St4n2/AXmvl5CRsTvahm4bY+jp7GJfAEeOK2NHP+Fk5l
lWfD6GU6m62SMnlvdvftj8cn0cmri8YGf29nH9NAxmsZyD+m+H08DO1pIbco
1jDpGzrCp+/evn765qeLt0/o1iouFjhUXSUg/3xabDcVnUS+hbnaqf4SjaKn
eQY8IU2yKmBwGf0OqxvBJ4HfvYSx0itgzeEN39WrbXTy8PgLplR30CJdeV3m
H1I4jPDur4skrdZ5mRRdd32brxZAUt8XyXWy6rqh73T2HOrpssjXySjNZnBq
YeXK7hWarPLFmO5N6zWtEk7pwcNPHyQ3+eoG2OCI31SOSmH15p3jZbVe2WU9
k4eip/TQJ2WkT0X+qfaCyRTP1ims6eV0mUyXlSwTL/bL2K312fPT8xfdk0nm
sEXjWWIePK0XIFP8Psk4B2dzPncgZYjXXz54ef7yLIJjGb3eJNnFNxdMnFHi
yaAu8c7k/TxdVQWdO1jlOMuSVTnomJNun9/AdQr88yKfzZJJlsbXPffB0qVl
hbc+KxLlSO3bvkuyMnr5b//PaqUE1brleTzB15zjuHtuuUwmMX8Mlj3N/qy0
174xXcN8nxdpMgNmtWh/U0ZVF/Gv0WUORJjflNfbvsH/2/8oFvjJ2yTDdVin
75PZaJoD08yq7s29vb0d3z4iEn375kHwwAOz4c+TSVHHBZLLySO75S/xCTzr
+AT88PoNSJWz/m/VsPTpe/oefGYODB9lKl9Voj559GBDe1QxG07dSiudyfdG
rJGs61WVbuKiepAX8RQ46dt4s0GiAmmRg7BBzha9pp9KuAYHAkmwkykNuohc
ZrybDvegin1J9W0OryqBJ202IOx20nO+WUaXcVz9muOR+S3UePnm/Ild08sa
Tm2Z1wXopKgBLkj/vJtk4D2WUL6rswT5wmdw7eL7p5fHx8FX8FJ07/g4utwk
03SOrAsP/A9JgQpm9Gh83M/3dRVBBwSW/nWu69z4/W2ebYEg35tB4RaOHn4+
UtJtTAiU7HKcx2VajnLgUjSzzfW0PD6W/4xKGO2DGxjdg7y010Z4bZQ7jv3s
zesfXwUTHvAlFFPMEt++uBSWd3n54uZk0D0iUGyzuKri6TVprwHPBs1XV/gu
onyVrot8Fp3epEW8/mt51Z5M6FU8S+PoWzjQWQc/k5tA6l+j7L3u/xoy4ssq
qSdJzx0v6usk+gG0HOATvSfuJoXpzwqYXt93xqSxgbq1miXAKfru+yG9Bikb
Pauvl/lNlvbchbIWZv/9v/0fQB59k79cxnGGOn++zJK+ZbysSxSCwJsWIAl3
M4F5dBHHfV/7qb6JV/jNm7RCZnL+/VlIoW+XCW4FbFYZwau+B+X1TQIcGU4r
8MwKzugqOiVaLNFaPb8APo1v6SbdBpMvt2WVrB+AcE/Kfo4PuhH8efzFaA5z
nS7Hm9l8h7Zxh0KQZFlagsTCN/WSH1hZGZqi1bKPvJrCtOue01m8jp7+uZ70
8nI8rvClyz9vgbTwU2/OLl78BKN8fT4+fgj/9/DzB19+/sUI+NOjh6OT408/
+2J08h9PkEFfvH79/PzVN+Fm/eVf/ut3QDbZdhht8xpM5SSap0Uy+7u//Mv/
Fv3lX/4XYKx5Pkf2ogoXKl+ih12mC+AqdWHEYPnbdxF36ssRCF1QkdxO7d6T
PbQqXKi6BD6ZZtfrflm2rwz9Fl6RR1//2/+Y9t3xt+Z7bXppUu+XB6PRCKxv
MP3gXB0ciAaSwAaR/pEvinizTKfRBugymaJkLMlKYhdEBOZCGS9g89BhAPcA
b0tAliTzeuUMgvHBt/ltcpMUwwhIOyI3TVzM+D38DBJH3/eIoJL3YJuC2biN
5sAZ08kqGR+8XYIOxf8EDgeGB44B5rHBAQDjQCqbxvB3VNbFpiCVLUJrAKkN
H4cjCXK2XqPNls/n+Iy6VGhsNEN8VwRThHvS9WaV4N14J6hxy2S1AYW2Shew
qjA3sPgi+Mx1OaRvwx3rGORB4tdUVq2kN9FNtEj8OVwcvAm/OD44r3Q9YSZ+
SXGk0U0+jSf1CpVfUMpuk9UK/1skIJdheOwpoBHGNzkIG7yMxq2bOrw7XpV5
BC/PKlB56BNZvQZ9H18PIwKOWMFi11kJZl6CY4plkXHQ5PIAvaTQizBS2JI1
vJroaU3ugYODe6i2gbSvaSOBukZiabkFcUaj6B/MFA4/fPi7N8+ffvHpp8cf
Px7RJ4FtBL89AraEv4VU42nL0mOquuOQeALOWZQ8IhGQALwQMc0Fls1+6PHJ
F1/ihxoEDzO1VA1biGQKXGIb3cZbWHwkzhj3JEnJTm4SEw5wjTQJSwmmBewr
/DKd0kjiFaw9Waz4biRgXaYFWDwxPIIDeI7H8H2MpDSMfiZr+RewwwfPgPlO
q+jMmK+DKBZpucKXgtUB0gbOVDSrE6IT+ZVGXW5W6RSPHBqneDDTDUyQbifr
JctvEr8Qw+gWVn6JA+WjClo/bP4sysF6WeMrpjSdQ1zr2wJU5NX2KJpsea0a
q4LLetpaKhqVWyikVfl4dJtWS0tO/TwrS5IZHYlZHgHlz5I58P8UJgJEAVSz
xYmC3lZUdE86J6WgMnvJG2FfiTs4SWAqm7gsYcI8p8UKX3WYpEgVcAHWMs1B
igTbe0T/pBOZ8IGH5YbzlKIi0r8G8BecuSr5fUtQLvN6NcMhx7e4UXDSeVJu
Mfwi8/FAqQBHJ02Eo8kbgJ9skNfhBmbJbZTX1QQ9lG5McKRg5DfkvIOtT+lD
eDBoIuEqwnIX6IDJ8OMgg2D2uzkzPIDvMMwYZxJ3r5hjoTzT3sVBKk5ox5AT
g5ZBIgn+DA/w+OA081/mRaLvzPPVKr/Fz6RmqLcpcGbHhYByWTDRlsHa5qjg
0sImYOklBW4hLCPcUsWWN26I11ZuG+i1xMBpbSLQAkDwJKDlAxNuM2cSZSqn
k/foyVokMx5FTnMOZ4SH8DyLPnyY16iYjTAs8/HjkOfmtmWXAGkNIc6sCAHy
mCaFKhJ9pCsMl7kLmAoJMB4VTcAc83gGpAVHKtlUMBvYyGVGdoHKAHo7+g9W
Nc5qfPA6Qwb9K548YK3wNmDCwMpAU0XVM5xdShQDr/9TDTzayYoVbNkI5rZG
akB/D8fL5o2h87KQK1Sc2PL8Gk4WiOcYXlzkZSluolXS4oO4RkAgqxXzFdKb
QKUT3eAA7aNrPFE5yrrBy3eXbwdD/m/06jX9/ebsj+/O35w9w78vvz198cL9
cSB3XH77+t2LZ/4v/+TT1y9fnr16xg/D1Si4dDB4efrTgElx8Pri7fnrV6cv
Bu01RB4Dh3Vi2ArMJi4P4DxOi3TC6/7104v/938/fhyxtD05PgZpK//44vjz
x/APOJkZfy3PYMv5n8hQDtAbFRf4FhAxwI83KfBWPCTE7G6zCAUzLNf9n3Fl
fnkS/f1kujl+/A9yASccXNQ1Cy7SmrWvtB7mRey41PEZt5rB9cZKh+M9/Sn4
t667uQj61r3oLRBnmuWrfLE9IA2B+C3ov8CwS2b5Zo+A7RH7T7OEbmQ2RkIf
z+imKp+ARhfdf/nu9D6eCVjVoqKDhTGS6B0S7CkS7B9gf/TETlcYYRnjcxeO
w97Hb6t8oCNQJHPRoxvn3vvhYc8fIDt2NuLQ2guh3mZ0O/4XP+t0PxrP0+BL
L+JtUtwfNi+fZSC1gHu1f7mItyvgO+0fLuv1GrTx+0ym988KVNKirq/RqeAV
J/L/8CGY/QjEAmjLMNePH2HAp9F91O5HyEWS2f2GEsosvNduWsIxmACDB9bc
N0MabutnnSYt2aUMCDjrt0kMwil6niarWSkzEULSyZTu7tGS7h7N6e6PH+ll
SDCj5/EU92+PtyG3G83p9s7XvUS14et8toUhF9V95drod48O0biEP8oj0cWR
G203oo2CEJkR5xdtglkvP66rCwI7Wc2jQxQUgxjtSdaTlzjEwdE4Ans9gVGi
KBhNYBQj/B4OraHBIC+He1D4VqJozdJyWlMGAxjfoD/tp8GlesZI6UYLcnqd
5bcgJBa4ojRPUqvhvJZeZsYblrwopneKXPstXLIVKDw/4mBJgaGXkgVQLYuE
5gD2wZSULHLDEK8Akn2VZ6PgxffxWaLH3zucMb/5ac4CNav4lV7tSrzW1RJE
KDHgzMWkme+tL8snXySLeLr1M/hdwx9GE9jjWZ6UpHbEM7IYhfZ2Dh6NAVaa
wZpSnR3sqJRMszY/X+dlxTu1kzmUdB5WNDe6fYzS417Ud9qjD/d6jzaZK3Jm
+JeIfiEn1Cy6Qmt6JOGUqyEq1bfkKsGfQTtY4MmgwV5pDO0KTzLJBzmibd0C
Fc6BH9Ig+LI4d1K8CeiyHMXrSbqo0Qyjj85pDEDhHz58hUrHw8efgp6BnAGV
KTT+g8kPWOMqw+mVGugG1SwHxW5JJiQdZlLXJJrEzgRiSWQE4bozG6GpDcVN
lSFdgKoEFldWysRhlNN8k/ISsKZOHI1WS5gGOcn58KMNANqlKNlCKbIxypPg
vK7qmRzVcGfwgg1ihhdkWKOzbJqj+A1+fZaWoF+QmnzFdNTL6IGQ+rn6wcHr
OalyOPJwrZmHZ00JuI63yl6HrB7G5IBAZ1nI8SV8C4s5I//Iamt5f9Md6JUT
uGON5DYwww6pDX2J+plhZG5rTAHGA8sewbpd1pNfYQhX9I/nRb7mv97m/N+n
U/7vM6At/utNslltR/r7c+J69cZduCRpprfiNEf+rXJB75V/6jfkn/ZTdEFf
SaYGUDWIkhXwe17U1u4Q18nnQAx3rDMe/egmTW6NCwOV+bxeLHF7kcvinpJ1
OUvQX0KPA2VX5G/gYxCwmebmjJGKpnldlPBqEofO09HakAgVxgKdFPEEhx3N
Yd3oQwsQ05kfIilKmd4VfD9lpu4nHugUIkYPXuXkI2ZPUkT3zto0csheZOKK
mRNXuilXRw2iZoqfzdhKjDO2tG4o0ElreViSinIpKuGj8Wfjz3A5gOt9+ujk
BLgeTuzDB/PcaF3HcL0pWo7GByBUynq6dPtF/Ax3C9gzskBgY2hkTJLutRiK
Fwi9F34KzPfighZ9D1kaHSa4MexTAhaZwkqBtAqXkR1CwiNwyeT5ZDaMeEXk
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

-->

</rfc>

