faqs.org - Internet FAQ Archives

RFC 3458 - Message Context for Internet Mail


Or Display the document by number




Network Working Group                                          E. Burger
Request for Comments: 3458                            SnowShore Networks
Category: Standards Track                                     E. Candell
                                                                Comverse
                                                                C. Eliot
                                                   Microsoft Corporation
                                                                G. Klyne
                                                            Nine by Nine
                                                            January 2003

                   Message Context for Internet Mail

Status of this Memo

   This document specifies an Internet standards track protocol for the
   Internet community, and requests discussion and suggestions for
   improvements.  Please refer to the current edition of the "Internet
   Official Protocol Standards" (STD 1) for the standardization state
   and status of this protocol.  Distribution of this memo is unlimited.

Copyright Notice

   Copyright (C) The Internet Society (2003).  All Rights Reserved.

Abstract

   This memo describes a new RFC 2822 message header, "Message-Context".
   This header provides information about the context and presentation
   characteristics of a message.

   A receiving user agent (UA) may use this information as a hint to
   optimally present the message.

Table of Contents

   1. Introduction....................................................2
   2. Conventions used in this document...............................3
   3. Motivation......................................................3
   4. Functional Requirements.........................................5
   5. Determining the Message Context.................................6
   6. Message-Context Reference Field.................................7
     6.1. Message-Context Syntax......................................7
     6.2. message-context-class Syntax................................7
       6.2.1. voice-message...........................................8
       6.2.2. fax-message.............................................8
       6.2.3. pager-message...........................................8
       6.2.4. multimedia-message......................................8
       6.2.5. text-message............................................8
       6.2.6. none....................................................8
   7. Security Considerations.........................................9
   8. IANA Considerations.............................................9
     8.1. Message Content Type Registrations..........................9
     8.2. Registration Template......................................10
     8.3. Message-Context Registration...............................11
   9. APPENDIX: Some messaging scenarios.............................12
     9.1. Internet e-mail............................................12
     9.2. Pager service..............................................12
     9.3. Facsimile..................................................13
     9.4. Voice mail.................................................14
     9.5. Multimedia message.........................................14
   10. References....................................................15
     10.1 Normative References.......................................15
     10.2 Informative References.....................................15
   11. Acknowledgments...............................................15
   12. Authors' Addresses............................................16
   13. Full Copyright Statement......................................17

1. Introduction

   This document describes a mechanism to allow senders of an Internet
   mail message to convey the message's contextual information.  Taking
   account of this information, the receiving user agent (UA) can make
   decisions that improve message presentation for the user in the
   context the sender and receiver expects.

   In this document, the "message context" conveys information about the
   way the user expects to interact with the message.  For example, a
   message may be e-mail, voice mail, fax mail, etc.  A smart UA may
   have specialized behavior based on the context of the message.

   This document specifies a RFC 2822 header called "Message-Context".

   The mechanism is in some ways similar to the use of the Content-
   Disposition MIME entity described in [6].  Content-Disposition gives
   clues to the receiving User Agent (UA) for how to display a given
   body part.  Message-Context can give clues to the receiving UA for
   the presentation of the message.  This allows the receiving UA to
   present the message to the recipient, in a meaningful and helpful
   way.

   Typical uses for this mechanism include:

   o  Selecting a special viewer for a given message.

   o  Selecting an icon indicating the kind of message in a displayed
      list of messages.

   o  Arranging messages in an inbox display.

   o  Filtering messages the UA presents when the user has limited
      access.

2. Conventions used in this document

   This document refers generically to the sender of a message in the
   masculine (he/him/his) and the recipient of the message in the
   feminine (she/her/hers).  This convention is purely for convenience
   and makes no assumption about the gender of a message sender or
   recipient.

   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 BCP 14, RFC 2119 [2].

   FORMATTING NOTE: Notes, such at this one, provide additional
   nonessential information that the reader may skip without missing
   anything essential.  The primary purpose of these non-essential notes
   is to convey information about the rationale of this document, or to
   place this document in the proper historical or evolutionary context.
   Readers whose sole purpose is to construct a conformant
   implementation may skip such information.  However, it may be of use
   to those who wish to understand why we made certain design choices.

3. Motivation

   Multimedia messaging systems receive messages that a UA may present
   in variety of ways.  For example, traditional e-mail uses simple text
   messages that the recipient displays and edits.  One UA may
   automatically print Fax images.  Another UA may play voice messages
   through a telephone handset.  Likewise, a receiving desktop computer

   may process or present documents transferred over e-mail using a
   local application.  Emerging and future developments may deliver
   other forms of information that have their own characteristics for
   user presentation, such as video messages and pager messages.

   An often-requested characteristic for multimedia messaging systems is
   to collect received messages in a "universal inbox", and to offer
   them to the user as a combined list.

   In the context of "unified messaging", different message contexts may
   have different implied semantics.  For example, some users may
   perceive voicemail to have an implicit assumption of urgency.  Thus
   they may wish to gather them together and process them before other
   messages.  This results in the end-user receiving agent needing to be
   able to identify voicemail and distinguish it from other messages.

   The uses of this kind of presentation characteristic for each message
   are multi-fold:

   o  Display an indication to the user (e.g., by a suitably evocative
      icon along with other summary fields),

   o  Auto-forward a given message type into another messaging
      environment (e.g., a page to a mobile short message service),

   o  Prioritize and group messages in an inbox display list,

   o  Suggest appropriate default handling for presentation,

   o  Suggest appropriate default handling for reply, forward, etc.

   A problem faced by multimedia messaging systems is that it is not
   always easy to decide the context of a received message.  For
   example, consider the following scenarios.

   o  A message that contains audio and image data:  Is this a fax
      message that happens to have some voice commentary?  Is it a voice
      message that is accompanied by some supplementary diagrams?  Is it
      a fully multimedia message, in which all parts are expected to
      carry equal significance?

   o  A message containing text and audio data:  Is this e-mail with an
      MP3 music attachment?  Is it a voice message that happens to have
      been generated with an initial text header for the benefit of
      non-voice-enabled e-mail receivers?

   The message context does relate to the message media content.
   However, it is not the same thing.  As shown above, the media type
   used in a message is not sufficient to indicate the message context.
   One cannot determine a priori which media types to use in alternative
   (gateway) messages.  Also, what if the user cares about
   distinguishing traditional e-mail text from SMS messages?  They are
   both the same media type, text, but they have different user
   contexts.

4. Functional Requirements

   The goals stated above lead to the following functional requirements.

   For receivers:

   o  Identify a message as belonging to a message class.

   o  Incorrect or invalid message classification must not result in
      failure to transfer or inability to present a message.

   For senders:

   o  Specify message classes by the originating user's choice of
      authoring tool or simple user interaction.

   For both:

   o  Specify a well-defined set of message classes to make
      interoperability between mail user agents (UAs) possible.

   o  Message classification information has to be interpretable in
      reasonable fashion by many different user agent systems.

   o  The mechanism should be extensible to allow for the introduction
      of new kinds of messages.

   NOTE: We specifically do not specify user agent behavior when the
   user agent forwards a message.  Clearly, the user agent, being
   message-context-aware, should provide a meaningful message-context.
   It is obvious what to do for the easy cases.  Messages that the user
   simply forwards will most likely keep the context unchanged.
   However, it is beyond the scope of this document to specify the user
   agent behavior for any other scenario.

5. Determining the Message Context

   One method of indicating the interpretation context of a message is
   to examine the media types in the message.  However, this requires
   the UA to scan the entire message before it can make this
   determination.  This approach is particularly burdensome for the
   multi-media mail situation, as voice and especially video mail
   objects are quite large.

   We considered indicating the message context by registering a
   multipart/* MIME subtype (Content-Type).  For example, the VPIM Work
   Group has registered multipart/voice-message to indicate that a
   message is primarily voice mail [7].  However, multipart/voice-
   message is identical in syntax to multipart/mixed.  The only
   difference is that VPIM mail transfer agents and user agents
   recognize that they can perform special handling of the message based
   on it being a voice mail message.  Moreover, Content-Type refers to a
   given MIME body part, not to the message as a whole.

   We wish to avoid scanning the entire message.  In addition, we wish
   to avoid having to create multiple aliases for multipart/mixed every
   time someone identifies a new primary content type.  Multiple aliases
   for multipart/mixed are not desirable as they remove the possibility
   for specifying a message as multipart/alternate, multipart/parallel,
   or multipart/encrypted, for example.

   Since the message context is an attribute of the entire message, it
   is logical to define a new top-level (RFC 2822 [3]) message
   attribute.  To this end, this document introduces the message
   attribute "Message-Context".

   Message-Context only serves to identify the message context.  It does
   not provide any indication of content that the UA must be capable of
   delivering.  It does not imply any message disposition or delivery
   notification.  There is a related effort to define Critical Content
   of Internet Mail [8] that one might use to perform these tasks.

   Message-Context is only an indicator.  We do not intend for it to
   convey information that is critical for presentation of the message.
   One can conceive of goofy situations, such as a message marked
   "voice-message" but without an audio body part.  In this case, the
   fact that the contents of a message don't match its context does not
   mean the receiving system should generate an error report or fail to
   deliver or process the message.

6. Message-Context Reference Field

   The Message-Context reference field is a top-level header inserted by
   the sending UA to indicate the context of the message.

   A receiving user agent MUST NOT depend on the indicated message-
   context value in a way that prevents proper presentation of the
   message.  If the value is incorrect or does not match the message
   content, the receiving user agent MUST still be capable of displaying
   the message content at least as meaningfully as it would if no
   Message-Context value were present.

   One can envision situations where a well-formed message ends up not
   including a media type one would expect from the message-context.
   For example, consider a voice messaging system that records a voice
   message and also performs speech-to-text processing on the message.
   The message then passes through a content gateway, such as a
   firewall, that removes non-critical body parts over a certain length.
   The receiving user agent will receive a message in the voice-message
   context that has only a text part and no audio.  Even though the
   message does not have audio, it is still in the voice message
   context.

   Said differently, the receiving UA can use the message-context to
   determine whether, when, and possibly where to display a message.
   However, the message-context should not affect the actual rendering
   or presentation.  For example, if the message is in the voice-message
   context, then don't try to send it to a fax terminal.  Conversely,
   consider the case of a message in the voice-message context that gets
   delivered to a multimedia voice terminal with a printer.  However,
   this message only has fax content.  In this situation, the "voice-
   message" context should not stop the terminal from properly rendering
   the message.

6.1. Message-Context Syntax

   The syntax of the Message-Context field, described using the ABNF [4]
   is as follows.  Note that the Message-Context header field name and
   message-context-class values are not case sensitive.

      "Message-Context" ":" message-context-class CRLF

6.2. message-context-class Syntax

   The message-context-class indicates the context of the message.  This
   is an IANA registered value.  Current values for message-context-
   class are as follows.

      message-context-class =  (   "voice-message"
                                 / "fax-message"
                                 / "pager-message"
                                 / "multimedia-message"
                                 / "text-message"
                                 / "none"
                                )

   Note: The values for Message-Context MUST be IANA registered values
   following the directions in the IANA Considerations section below.

6.2.1. voice-message

   The voice-message class states the message is a voice mail message.

6.2.2. fax-message

   The fax-message class states the message is a facsimile mail message.

6.2.3. pager-message

   The pager-message class states the message is a page, such as a text
   or numeric pager message or a traditional short text message service
   (SMS) message.

6.2.4. multimedia-message

   The multimedia-message class states the message is an aggregate
   multimedia message, such as a message specified by [9].  This helps
   identify a message in a multimedia context.  For example, a MIME
   multipart/related [10] data part and resource part looks the same as
   a multimedia MHTML multipart/related.  However, the semantics are
   quite different.

6.2.5. text-message

   The text-message class states the message is a traditional internet
   mail message.  Such a message consists of text, possibly richly
   formatted, with or without attachments.

6.2.6. none

   The none class states there is no context information for this
   message.

   If a message has no Message-Context reference field, a receiving user
   agent MUST treat it the same as it would if the message has a "none"
   value.

7. Security Considerations

   The intention for this header is to be an indicator of message
   context only.  One can imagine someone creating an "Application"
   Message-Context.  A poorly designed user agent could blindly execute
   a mailed program based on the Message-Context.  Don't do that!

   One can envision a denial of service attack by bombing a receiver
   with a message that has a Message-Context that doesn't fit the
   profile of the actual body parts.  This is why the receiver considers
   the Message-Context to be a hint only.

8. IANA Considerations

   Section 8.3 is a registration for a new top-level RFC 2822 [3]
   message header, "Message-Context".

   This document creates an extensible set of context types.  To promote
   interoperability and coherent interpretations of different types, a
   central repository has been established for well-known context types.

   The IANA has created a repository for context types called "Internet
   Message Context Types".  Following the policies outlined in [5], this
   repository is "Specification Required" by RFC.  Section 8.1 describes
   the initial values for this registry.

   To create a new message context type, you MUST publish an RFC to
   document the type.  In the RFC, include a copy of the registration
   template found in Section 8.2 of this document.  Put the template in
   your IANA Considerations section, filling-in the appropriate fields.
   You MUST describe any interoperability and security issues in your
   document.

8.1. Message Content Type Registrations

   Internet Message Content Types
   ==============================

   Value              Description                           Reference
   -----              -----------                           ---------
   voice-message      Indicates a message whose primary     This RFC
                      content is a voice mail message.  The
                      primary content is audio data.  The
                      context is usually a message recorded
                      from a voice telephone call.

   fax-message        Indicates a message whose primary     This RFC
                      content is a fax mail message.  The
                      primary content is image data.  The
                      context is usually a message recorded
                      from a facsimile telephone call.

   pager-message      Indicates a message whose primary     This RFC
                      content is a page.  The primary
                      content is text data.  The context is
                      an urgent message usually of a
                      limited length.

   multimedia-message Indicates a message whose primary     This RFC
                      content is a multimedia message.  The
                      primary content is multimedia, most
                      likely MHTML.  The context is often
                      spam or newsletters.

   text-message       Indicates a classic, text-based,      This RFC
                      Internet message.

   None               Indicates an unknown message context. This RFC

8.2. Registration Template

   In the following template, a pipe symbol, "|", precedes instructions
   or other helpful material.  Be sure to replace "<classname>" with the
   class name you are defining.

   Message-Context class name:
   <classname>

   Summary of the message class:
       | Include a short (no longer than 4 lines) description or summary
       | Examples:
       |   "Palmtop devices have a 320x160 pixel display, so we can..."
       |   "Color fax is so different than black & white that..."
   Person & email address to contact for further information:
       | Name & e-mail

8.3. Message-Context Registration

   To: iana@iana.org
   Subject: Registration of New RFC 2822 Header

   RFC 2822 Header Name:
   Message-Context

   Allowable values for this parameter:
   Please create a new registry for Primary Context Class
   registrations.  See section 8.1 of this document for the initial
   values.

   RFC 2822 Section 3.6 Repeat Value:
   Field             Min Number   Max Number   Notes
   Message-Context       0            1

   Person & email address to contact for further information:
   Eric Burger
   e.burger@ieee.org

9. APPENDIX: Some messaging scenarios

   This section is not a normative part of this document.  We include it
   here as a historical perspective on the issue of multimedia message
   types.

   These scenarios are neither comprehensive nor fixed.  For example,
   e-mails being typically text-based do not mean that they cannot
   convey a voice-message.  This very mutability serves to underline the
   desirability of providing some explicit message context hint.

9.1. Internet e-mail

   Internet e-mail carries textual information.  Sometimes it conveys
   computer application data of arbitrary size.

   Typically, one uses e-mail for non-urgent messages, which the
   recipient will retrieve and process at a time convenient to her.

   The normal device for receiving and processing e-mail messages is
   some kind of personal computer.  Modern personal computers usually
   come with a reasonably large display and an alphanumeric keyboard.
   Audio, video, and printing capabilities are not necessarily
   available.

   One can use E-mail for communication between two parties (one-to-
   one), a small number of known parties (one-to-few) or, via an e-mail
   distribution list, between larger numbers of unknown parties (one-
   to-many).

   One of the endearing characteristics of e-mail is the way that it
   allows the recipient to forward all or part of the message to another
   party, with or without additional comments.  It is quite common for
   an e-mail to contain snippets of content from several previous
   messages.  Similar features apply when replying to e-mail.

9.2. Pager service

   One uses a pager message to convey notifications and alerts.  For the
   most part, these notifications are textual information of limited
   size.  The typical limit is 160 characters.  People use pages for
   relatively urgent messages, which the sender wishes the receiver to
   see and possibly respond to within a short time period.  Pager
   messages are often used as a way of alerting users to something
   needing their attention.  For example, a system can use a page to
   notify a subscriber there is a voicemail message requiring her
   attention.

   Example devices for sending and receiving a pager message are a
   mobile telephone with a small character display or a text pager.
   Personal computers and personal digital assistants (PDAs) can also
   participate in pager messaging.

   Currently, the most common use of pager messages are between just two
   parties (one-to-one).

   One delivery method for pager messages is the short text messaging
   service (SMS).  SMS is a facility that has evolved for use with
   mobile telephones, and has an associated per-message transmission
   charge.  Note that the focus here is on the notification aspect of
   SMS.  From the beginning, SMS was envisioned to be more than a simple
   pager service.  Operators can use SMS to provision the phone, for
   example.  From the subscriber point of view, SMS has evolved
   considerably from its origins as a pure pager replacement service.
   For example, with mobile originate service, people can have two-way
   text chat sessions using SMS and a mobile phone.  In addition, there
   are SMS-enabled handsets that can display pictures.  However, for the
   purposes of this document, there is still a need to capture the
   essence of a "highly urgent, short-text, notification or alert"
   service.

   Users often send pager messages in isolation, rather than as part of
   a longer exchange.  One use for them is as a prompt or invitation to
   communicate by some more convenient and content-rich method, such as
   a telephone call.

9.3. Facsimile

   People use facsimile to convey image information of moderate size,
   typically a small number of pages.  Sometimes people use facsimile
   for larger documents.

   Facsimile is a facility that usually uses circuit-switched telephone
   circuits, with connection-time charges.  Message transfer takes place
   in real-time.  Thus, people often use facsimile for urgent
   communication.

   The normal device for sending and receiving a facsimile is a self-
   contained scanning and printing device connected to a telephone line
   or a desktop computer.

   Most facsimiles are between just two parties (one-to-one).  However,
   a significant portion of facsimile service is broadcast between
   multiple parties (one-to-many).

   Most facsimile exchanges are in isolation, rather than as part of a
   longer exchange.  Facsimile data is typically not suitable for
   further processing by computer.

9.4. Voice mail

   People use voice mail to convey audio information, almost exclusively
   human speech.

   Voice mail is a facility that usually uses circuit-switched telephone
   circuits, with modest connection-time charges, often used for
   moderately urgent messages.  A common use for them is as a prompt or
   invitation to communicate by some more convenient method, such as a
   telephone call.  In most, but not all cases, the sender of a voice
   message does not want to send a message at all.  Rather, they wished
   to engage in a real-time conversation.

   The normal device for sending and receiving a voice mail is a
   telephone handset.

   Voice messages are usually sent between just two parties (one-to-
   one).

   Voice mail data is not generally suitable for further processing by
   computer.

9.5. Multimedia message

   We define a multimedia message as a message containing more than one
   basic media type (text, image, audio, video, model, application).

   The following are some characteristics of a multimedia message.

   In some cases, a multimedia message is just e-mail with an attachment
   that a multimedia display application presents.  For example, I can
   send you an MP3 of something I recorded in my garage today.

   In other cases, a multimedia message represents a convergence between
   two or more of the scenarios described above.  For example, a voice
   message with an accompanying diagram or a talking head video message
   is a multimedia message.

   The characteristics will vary somewhat with the intent of the sender.
   This in turn may affect the user agent or application used to render
   the message.

10. References

10.1 Normative References

   [1]  Bradner, S., "The Internet Standards Process -- Revision 3", BCP
        9, RFC 2026, October 1996.

   [2]  Bradner, S., "Key words for use in RFCs to Indicate Requirement
        Levels", BCP 14, RFC 2119, March 1997.

   [3]  Resnick, P., "Internet Message Format", RFC 2822, April 2001.

   [4]  Crocker, D. and P. Overell, Eds., "Augmented BNF for Syntax
        Specifications: ABNF", RFC 2234, November 1997.

   [5]  Alvestrand, H. and T. Narten, "Guidelines for Writing an IANA
        Considerations Section in RFCs", BCP 26, RFC 2434, October 1998.

10.2 Informative References

   [6]  Troost, R., Dorner, S. and K. Moore, "Communicating Presentation
        Information in Internet Messages: The Content-Disposition Header
        Field", RFC 2183, August 1997.

   [7]  Vaudreuil, G. and G. Parsons, "VPIM Voice Message MIME Sub-type
        Registration", RFC 2423, September 1998.

   [8]  Burger, E., "Critical Content of Internet Mail", RFC 3459,
        January 2003.

   [9]  Palme, J., Hopmann, A. and N. Shelness, "MIME Encapsulation of
        Aggregate Documents, such as HTML (MHTML)", RFC 2557, March
        1999.

   [10] Levinson, E., "The MIME Multipart/Related Content-type", RFC
        2387, August 1998.

11. Acknowledgments

   Many of the ideas here arose originally from a discussion with Jutta
   Degener.

   We'd also like to thank Keith Moore for helping us tighten-up our
   explanations.

   In the last round, we got some rather good advise from Caleb Clausen
   and Dave Aronson.

   Antti Vaha-Sipila pointed out advances in SMS, while Stuart McRae
   helped distil the essence of the pager service vis a vis SMS.

   We offer an extra special thanks to Greg Vaudreuil for pulling RFC
   2557 out of his hat.

12. Authors' Addresses

   Eric Burger
   SnowShore Networks, Inc.
   285 Billerica Rd.
   Chelmsford, MA  01824-4120
   USA

   Phone: +1 978 367 8403
   EMail: e.burger@ieee.org

   Emily Candell
   Comverse Network Systems
   200 Quannapowitt Pkwy.
   Wakefield, MA  01880
   USA

   Phone: +1 781 213 2324
   EMail: emily.candell@comverse.com

   Graham Klyne
   Nine by Nine
   United Kingdom

   EMail: GK-IETF@ninebynine.org

   Charles Eliot
   Microsoft Corporation
   One Microsoft Way
   Redmond WA 98052
   USA

   Phone: +1 425 706 9760
   EMail: charle@Microsoft.com

13.  Full Copyright Statement

   Copyright (C) The Internet Society (2003).  All Rights Reserved.

   This document and translations of it may be copied and furnished to
   others, and derivative works that comment on or otherwise explain it
   or assist in its implementation may be prepared, copied, published
   and distributed, in whole or in part, without restriction of any
   kind, provided that the above copyright notice and this paragraph are
   included on all such copies and derivative works.  However, this
   document itself may not be modified in any way, such as by removing
   the copyright notice or references to the Internet Society or other
   Internet organizations, except as needed for the purpose of
   developing Internet standards in which case the procedures for
   copyrights defined in the Internet Standards process must be
   followed, or as required to translate it into languages other than
   English.

   The limited permissions granted above are perpetual and will not be
   revoked by the Internet Society or its successors or assigns.

   This document and the information contained herein is provided on an
   "AS IS" basis and THE INTERNET SOCIETY AND THE INTERNET ENGINEERING
   TASK FORCE DISCLAIMS ALL WARRANTIES, EXPRESS OR IMPLIED, INCLUDING
   BUT NOT LIMITED TO ANY WARRANTY THAT THE USE OF THE INFORMATION
   HEREIN WILL NOT INFRINGE ANY RIGHTS OR ANY IMPLIED WARRANTIES OF
   MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE.

Acknowledgement

   Funding for the RFC Editor function is currently provided by the
   Internet Society.

 

User Contributions:

Comment about this RFC, ask questions, or add new information about this topic: