Independent Submission                                       A. Melnikov
Request for Comments: 7912                                     Isode Ltd
Category: Informational                                        June 2016
ISSN: 2070-1721


      Message Authorizing Email Header Field and Its Use for the
                     Draft and Release Procedure

Abstract

  This document describes a procedure for when a Military Message
  Handling System (MMHS) message is composed by one user and is only
  released to the mail transfer system when one or more Authorizing
  Users authorize release of the message by adding the
  MMHS-Authorizing-Users header field.  The resulting message can be
  optionally signed by the sender and/or reviewer, allowing recipients
  to verify both the original signature (if any) and the review
  signatures.

Status of This Memo

  This document is not an Internet Standards Track specification; it is
  published for informational purposes.

  This is a contribution to the RFC Series, independently of any other
  RFC stream.  The RFC Editor has chosen to publish this document at
  its discretion and makes no statement about its value for
  implementation or deployment.  Documents approved for publication by
  the RFC Editor are not a candidate for any level of Internet
  Standard; see Section 2 of RFC 7841.

  Information about the current status of this document, any errata,
  and how to provide feedback on it may be obtained at
  http://www.rfc-editor.org/info/rfc7912.

Copyright Notice

  Copyright (c) 2016 IETF Trust and the persons identified as the
  document authors.  All rights reserved.

  This document is subject to BCP 78 and the IETF Trust's Legal
  Provisions Relating to IETF Documents
  (http://trustee.ietf.org/license-info) in effect on the date of
  publication of this document.  Please review these documents
  carefully, as they describe your rights and restrictions with respect
  to this document.




Melnikov                      Informational                     [Page 1]

RFC 7912            Message Authorizing Header Field           June 2016


Table of Contents

  1.  Introduction  . . . . . . . . . . . . . . . . . . . . . . . .   2
  2.  Conventions Used in This Document . . . . . . . . . . . . . .   3
  3.  Draft and Release Procedure . . . . . . . . . . . . . . . . .   3
    3.1.  Terminology . . . . . . . . . . . . . . . . . . . . . . .   3
    3.2.  Handling of Initial Message Submission by the MSA . . . .   3
    3.3.  Review by Authorizing User(s) . . . . . . . . . . . . . .   4
      3.3.1.  Processing of Encrypted Messages  . . . . . . . . . .   5
      3.3.2.  Authorizing S/MIME Signatures . . . . . . . . . . . .   5
    3.4.  Role of Other Messaging Agents at the Sender's Domain . .   6
      3.4.1.  MDA at the Sender's Domain  . . . . . . . . . . . . .   6
      3.4.2.  Border MTA at the Sender's Domain . . . . . . . . . .   6
  4.  MMHS-Authorizing-Users Header Field . . . . . . . . . . . . .   6
  5.  Updated MIXER Mapping . . . . . . . . . . . . . . . . . . . .   7
    5.1.  Mapping from RFC 5322/MIME to X.400 . . . . . . . . . . .   7
    5.2.  Mapping from X.400 to RFC 5322/MIME . . . . . . . . . . .   7
  6.  IANA Considerations . . . . . . . . . . . . . . . . . . . . .   8
  7.  Security Considerations . . . . . . . . . . . . . . . . . . .   8
    7.1.  Forged Header Fields  . . . . . . . . . . . . . . . . . .   9
    7.2.  Intentionally Malformed Header Fields . . . . . . . . . .   9
  8.  References  . . . . . . . . . . . . . . . . . . . . . . . . .   9
    8.1.  Normative References  . . . . . . . . . . . . . . . . . .   9
    8.2.  Informative References  . . . . . . . . . . . . . . . . .  10
  Acknowledgements  . . . . . . . . . . . . . . . . . . . . . . . .  11
  Author's Address  . . . . . . . . . . . . . . . . . . . . . . . .  11

1.  Introduction

  In some secure environments, email messages can't be released to the
  Message Transfer System (MTS); thus, they can't be delivered to
  recipients unless they are authorized by one or more Authorizing
  Users (e.g., Releasing Officers or Release Authorities).  This
  document describes how this mechanism can be realized by an
  additional Internet Email [RFC5322] header field and optionally
  protected using S/MIME [RFC5750] [RFC5751] or DomainKeys Identified
  Mail (DKIM) [RFC6376].

  This document describes a procedure for how an email message composed
  by one user can be released to the MTS when one or more Authorizing
  Users authorize and optionally countersign the message.  The MMHS-
  Authorizing-Users header field (see Section 4) communicates which
  user(s) authorized the message.  If S/MIME signed, the resulting
  message allows recipients to verify both the original (if any) and
  counter signatures.  The original S/MIME signature generated by the
  sender (if any) is unaffected by additional S/MIME review signatures.





Melnikov                      Informational                     [Page 2]

RFC 7912            Message Authorizing Header Field           June 2016


2.  Conventions Used in This Document

  The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT",
  "SHOULD", "SHOULD NOT", "RECOMMENDED", "MAY", and "OPTIONAL" in this
  document are to be interpreted as described in [RFC2119].

  The formal syntax uses the Augmented Backus-Naur Form (ABNF)
  [RFC5234] notation, including the core rules defined in Appendix B of
  RFC 5234 [RFC5234].  Terms not defined in this document are taken
  from [RFC5322].

3.  Draft and Release Procedure

3.1.  Terminology

  Drafter: Any email user that composes a message (Draft Message)
  needing authorization before it is released to its intended
  recipients.

  Authorizing User (also Releaser or Authorizer): The mailbox of a user
  or a group of users that must inspect and authorize the release of a
  Draft Message before it can be sent.  An organization may require
  more than one Authorizing User to authorize the release of a Draft
  Message.

3.2.  Handling of Initial Message Submission by the MSA

  The original email message to be sent doesn't include the MMHS-
  Authorizing-Users header field.  It may or may not include the
  sender's S/MIME signature.

  The message to be sent is first submitted over SMTP [RFC6409].  The
  specific mechanism for how it arrives to the Authorizing User(s) is
  not specified in this document.  One possibility is for the Message
  Submission Agent (MSA) to redirect all email messages not addressed
  to Authorizing Users and not submitted by Authorizing Users to a
  preconfigured mailbox(es) that can be accessed by Authorizing
  User(s).  Another possibility is for the MSA to redirect all email
  messages without the MMHS-Authorizing-Users header field and/or
  corresponding S/MIME review signatures to a preconfigured mailbox(es)
  that can be accessed by Authorizing User(s).

  In order to prevent a malicious sender from bypassing or altering the
  Draft and Release procedure, the MSA MUST check that the MMHS-
  Authorizing-Users header field (if present) is syntactically valid,
  contains the email addresses of entities authorized to act as
  Authorizing Users, and, when review signatures are used, that every




Melnikov                      Informational                     [Page 3]

RFC 7912            Message Authorizing Header Field           June 2016


  entity listed has one or more matching review signature (or
  signature) that is valid.

3.3.  Review by Authorizing User(s)

  Each user agent (UA) that is used by an authorized user MUST perform
  the following steps (if there are multiple Authorizing Users, the
  whole sequence of steps below is repeated for each Authorizing User):

  1.  Verify the origination of the message (From/Sender header
      fields).  The exact mechanism to do that is out of scope for this
      document, but one example is by verifying the S/MIME signature,
      making sure that the signature protects all header fields (i.e.,
      wrapped by message/rfc822, as described in Section 3.1 of
      [RFC5751]) and that it matches the sender of the message, as
      described in [RFC5750].  Another example is by verifying a DKIM
      signature [RFC6376] (added by the Drafter's Mail User Agent (MUA)
      or MSA) that covers the From/Sender header fields.

  2.  Check if the message already contains the MMHS-Authorizing-Users
      header field with the email address of the Authorizing User.
      (This can happen, for example, if the email system is
      misconfigured and thus contains a loop, or if a malicious sender
      or attacker is trying to affect the authorization procedure.)  If
      the message doesn't contain the email address of the Authorizing
      User in the MMHS-Authorizing-Users header field, then go to the
      next step.  If the MMHS-Authorizing-Users header field contains
      the email address of the Authorizing User, verify the validity of
      the header field (for example, by checking for the S/MIME
      signature/review signature or for the DKIM signature) and also
      verify that the email address associated with the signature
      matches the email address of the Authorizing User.  If the
      validity of the MMHS-Authorizing-Users header field can be
      verified, go to step 5 below.  Otherwise, return the message to
      the sender (bounce) or redirect the message to a designated abuse
      mailbox.

  3.  Allow the Authorizing User to review the content of the message.
      Some of the checks can be automated (for example, search for
      keywords).  (See Section 3.3.1 for additional considerations.)
      If, based on the check, the Authorizing User is happy to release
      the message to the MTS (or to the next Authorizing User, if
      multiple authorizations are required), the UA SHOULD enable the
      Authorizing User to protect additions to the MMHS-Authorizing-
      Users header field, for example, by allowing the addition of the
      S/MIME review signature (if S/MIME is used for protecting the
      MMHS-Authorizing-Users header field.  See Section 3.3.2 for more
      details).  If the Authorizing User wants to reject the message,



Melnikov                      Informational                     [Page 4]

RFC 7912            Message Authorizing Header Field           June 2016


      it SHOULD be returned to the Drafter with an explanatory note or
      it MAY be discarded.  The Authorizing User can also choose to
      forward the message to another Authorizing User for additional
      approval or become a new Drafter of the message.  If the
      Authorizing User becomes the new Drafter, its UA MUST strip any
      existing email addresses from the MMHS-Authorizing-Users header
      field.

  4.  If there is an existing MMHS-Authorizing-Users header field
      containing the email address of the Authorizing User, skip this
      step.  Otherwise, insert a new MMHS-Authorizing-Users header
      field (if absent) containing the email address of the Authorizing
      User or append the email address of the Authorizing User to the
      end of the existing MMHS-Authorizing-Users header field.

  5.  The (possibly) updated email message is either released to the
      MTS or to the next Authorizing User, as per email system
      configuration.  Note that if the Authorizing User updates the
      message in a manner that invalidates existing S/MIME or DKIM
      signature(s), the Authorizing User becomes the Drafter and needs
      to reapply any protections.

3.3.1.  Processing of Encrypted Messages

  Any encrypted message sent in an environment where the Draft and
  Release procedure is in force also needs to be encrypted to all
  Authorizing Users, so that they can perform review of the message.
  If a User Agent used by an Authorizing User can't decrypt the
  message, it SHOULD notify the sender (which can be the Drafter or a
  previous Authorizing User) about the problem using a non-delivery
  Delivery Status Notification (DSN) or through some other means.  The
  ciphertext that cannot be decrypted by the Authorizing User MAY be
  included in the notification to aid debugging.  A possible reason not
  to notify the sender is to avoid Denial-of-Service attacks, for
  example, if an attacker discovers a way to inject fake messages with
  encryption that doesn't validate in order to overflow the sender's
  INBOX.

3.3.2.  Authorizing S/MIME Signatures

  If S/MIME were not used, the Authorizing User can become the original
  signer of the message.

  If a message is signed with multiple signatures (for example, using
  different cryptographic algorithms, as described in [RFC5752]), all
  of the signatures that can be verified by an Authorizing User SHOULD
  be signed with a review signature (authorizing signatures).  A
  recipient of the message can consider any chain of review signatures



Melnikov                      Informational                     [Page 5]

RFC 7912            Message Authorizing Header Field           June 2016


  that matches MMHS-Authorizing-Users header field values as valid,
  only if all signatures in the chain are verified.  All of the
  signatures that cannot be verified MUST be stripped by the
  Authorizing User Agent.

  When triple wrapping [RFC2634] is used, authorizing signatures are
  applied to the outer level, so that it can be verified by Message
  Transfer Agents (MTAs) without the need to decrypt content.

3.4.  Role of Other Messaging Agents at the Sender's Domain

3.4.1.  MDA at the Sender's Domain

  If a message being sent is to be delivered within the sender's
  domain, Message Delivery Agents (MDAs) are responsible for ensuring
  that the message was properly authorized by Authorizing User(s), as
  determined by the sender's domain email system configuration.  They
  verify the presence and validity of the MMHS-Authorizing-Users header
  field in the message, as well as the validity of associated
  signatures on the message.

  Note that the above requirements don't apply to direct delivery to
  any user designated as an Authorizing User.

3.4.2.  Border MTA at the Sender's Domain

  The sender's domain border MTAs are responsible for ensuring that all
  messages that leave the sender's domain were properly authorized by
  the Authorizing User(s), as determined by the sender's domain email
  system configuration.  They verify the presence and validity of the
  MMHS-Authorizing-Users header field in outgoing messages, as well as
  the validity of associated signatures on the message.

4.  MMHS-Authorizing-Users Header Field

  The MMHS-Authorizing-Users header field specifies the list of
  Authorizing Users (or entities(*)) that countersigned this email
  message (for example, using S/MIME) before it was authorized for
  release to the MTS.  Each user/entity is described by the email
  address.

  (*) Note that in some environments, identities of Authorizing Users
  are required to be hidden from recipients of email messages; so, upon
  receipt, MMHS-Authorizing-Users might contain an email address
  associated with a group of possible users.  Such email addresses need
  to have signatures that don't disclose group membership.





Melnikov                      Informational                     [Page 6]

RFC 7912            Message Authorizing Header Field           June 2016


  The MMHS-Authorizing-Users header field specified in this document
  MUST NOT appear more than once in message headers.  An email message
  that contains multiple MMHS-Authorizing-Users is malformed.  An agent
  processing such a malformed message SHOULD either return it to the
  sender (if possible) or fix the message so that it contains only one
  copy of the header field.

      MMHS-Authorizing-Users = "MMHS-Authorizing-Users:"
                         mailbox-list CRLF

      mailbox-list = <Defined in RFC 5322>

5.  Updated MIXER Mapping

  This section provides an updated version of the MIXER mapping
  specified in [RFC2156] for MMHS applications.

5.1.  Mapping from RFC 5322/MIME to X.400

  In the absence of the MMHS-Authorizing-Users header field, the From
  and Sender header fields are mapped to their X.400 equivalents as
  specified in [RFC2156].

  If the MMHS-Authorizing-Users header field is present:

  1.  If the Sender header field is present, it is mapped to
      IPMS.Heading.originator; otherwise, the first From header field
      address is mapped to IPMS.Heading.originator.

  2.  Map the From header field address(es) and the MMHS-Authorizing-
      Users header field address(es) to IPMS.Heading.authorizing-users,
      skipping the first From header field address if it was mapped to
      IPMS.Heading.originator.

5.2.  Mapping from X.400 to RFC 5322/MIME

  Mapping from X.400 to the Internet is controlled by whether or not a
  particular message is considered a military message.  A message is
  considered a military message (as defined by ACP 123 [ACP123] and
  also specified in STANAG 4406 [STANAG-4406]) if there are any MMHS
  heading extensions present.  Alternatively, this MAY be done by
  configuration (i.e., all messages can be considered military
  messages).

  For non-military messages, mapping from X.400 as specified in
  [RFC2156] is used.





Melnikov                      Informational                     [Page 7]

RFC 7912            Message Authorizing Header Field           June 2016


  For military messages, the following mapping is used:

  1.  IPMS.Heading.originator is mapped to the From header field.

  2.  The IPMS.Heading.authorizing-users is mapped to the MMHS-
      Authorizing-Users header field.

6.  IANA Considerations

  IANA has added the MMHS-Authorizing-Users header field specified in
  Section 4 to the "Provisional Message Header Field Names" registry,
  defined by "Registration Procedures for Message Header Fields"
  [RFC3864].  The registration template is as follows:

  Header field name: MMHS-Authorizing-Users

  Applicable protocol: mail ([RFC5322])

  Status: provisional

  Author/Change controller: Alexey Melnikov <[email protected]>

  Specification document(s): RFC 7912

  Related information:

7.  Security Considerations

  In some military environments, the identities of Authorizing Users
  are required to be hidden from recipients of email messages.  This
  can be accomplished by using a group address for the MMHS-
  Authorizing-Users.  In this way, the recipient will know that it was
  released by an Authorizing User in that group, but the recipient will
  not know which one of them took the action.

  For those organizations that do not wish to disclose the Authorizing
  Users' group membership, care must also be taken to ensure that the
  information included in the certificate used for signing email
  messages does not disclose individuals in the group.

  Further security considerations are described in subsections of this
  section.









Melnikov                      Informational                     [Page 8]

RFC 7912            Message Authorizing Header Field           June 2016


7.1.  Forged Header Fields

  A malicious sender may add/change an MMHS-Authorizing-Users header
  field to bypass or alter the message authorization procedure invoked
  for messages with no MMHS-Authorizing-Users header field.  For this
  reason, it is important for agents and clients that rely on the
  validity of the MMHS-Authorizing-Users header field to also verify
  the review signature (or a similar protection mechanism) that
  confirms that a particular person or entity authorized release of a
  message.

7.2.  Intentionally Malformed Header Fields

  It is possible for an attacker to add an MMHS-Authorizing-Users
  header field that is extraordinarily large or otherwise malformed in
  an attempt to discover or exploit weaknesses in the header field
  parsing code.  Implementations MUST thoroughly verify all such header
  fields received from MTAs and be robust against intentionally as well
  as unintentionally malformed header fields.

8.  References

8.1.  Normative References

  [ACP123]   CCEB, "Common Messaging strategy and procedures", ACP 123
             (B), May 2009.

  [RFC2119]  Bradner, S., "Key words for use in RFCs to Indicate
             Requirement Levels", BCP 14, RFC 2119,
             DOI 10.17487/RFC2119, March 1997,
             <http://www.rfc-editor.org/info/rfc2119>.

  [RFC2156]  Kille, S., "MIXER (Mime Internet X.400 Enhanced Relay):
             Mapping between X.400 and RFC 822/MIME", RFC 2156,
             DOI 10.17487/RFC2156, January 1998,
             <http://www.rfc-editor.org/info/rfc2156>.

  [RFC2634]  Hoffman, P., Ed., "Enhanced Security Services for S/MIME",
             RFC 2634, DOI 10.17487/RFC2634, June 1999,
             <http://www.rfc-editor.org/info/rfc2634>.

  [RFC5234]  Crocker, D., Ed. and P. Overell, "Augmented BNF for Syntax
             Specifications: ABNF", STD 68, RFC 5234,
             DOI 10.17487/RFC5234, January 2008,
             <http://www.rfc-editor.org/info/rfc5234>.






Melnikov                      Informational                     [Page 9]

RFC 7912            Message Authorizing Header Field           June 2016


  [RFC5322]  Resnick, P., Ed., "Internet Message Format", RFC 5322,
             DOI 10.17487/RFC5322, October 2008,
             <http://www.rfc-editor.org/info/rfc5322>.

  [RFC5750]  Ramsdell, B. and S. Turner, "Secure/Multipurpose Internet
             Mail Extensions (S/MIME) Version 3.2 Certificate
             Handling", RFC 5750, DOI 10.17487/RFC5750, January 2010,
             <http://www.rfc-editor.org/info/rfc5750>.

  [RFC5751]  Ramsdell, B. and S. Turner, "Secure/Multipurpose Internet
             Mail Extensions (S/MIME) Version 3.2 Message
             Specification", RFC 5751, DOI 10.17487/RFC5751, January
             2010, <http://www.rfc-editor.org/info/rfc5751>.

  [RFC6376]  Crocker, D., Ed., Hansen, T., Ed., and M. Kucherawy, Ed.,
             "DomainKeys Identified Mail (DKIM) Signatures", STD 76,
             RFC 6376, DOI 10.17487/RFC6376, September 2011,
             <http://www.rfc-editor.org/info/rfc6376>.

  [RFC6409]  Gellens, R. and J. Klensin, "Message Submission for Mail",
             STD 72, RFC 6409, DOI 10.17487/RFC6409, November 2011,
             <http://www.rfc-editor.org/info/rfc6409>.

8.2.  Informative References

  [RFC3864]  Klyne, G., Nottingham, M., and J. Mogul, "Registration
             Procedures for Message Header Fields", BCP 90, RFC 3864,
             DOI 10.17487/RFC3864, September 2004,
             <http://www.rfc-editor.org/info/rfc3864>.

  [RFC5752]  Turner, S. and J. Schaad, "Multiple Signatures in
             Cryptographic Message Syntax (CMS)", RFC 5752,
             DOI 10.17487/RFC5752, January 2010,
             <http://www.rfc-editor.org/info/rfc5752>.

  [STANAG-4406]
             NATO, "STANAG 4406 Edition 2: Military Message Handling
             System", STANAG 4406 Ed. 2, March 2005.













Melnikov                      Informational                    [Page 10]

RFC 7912            Message Authorizing Header Field           June 2016


Acknowledgements

  Many thanks for reviews and text provided by Steve Kille, Jim Schaad,
  Russ Housley, David Wilson, Chris Bonatti, and Sean Turner.

  Some text in this document was copied from RFC 7001.

Author's Address

  Alexey Melnikov
  Isode Ltd
  14 Castle Mews
  Hampton, Middlesex  TW12 2NP
  United Kingdom

  Email: [email protected]



































Melnikov                      Informational                    [Page 11]