Internet Draft Greg Vaudreuil Expires in six months Lucent Technologies July 13, 2000 SMTP Service Extensions for Transmission of Large and Binary MIME Messages of the BDAT command line. Once the receiver-SMTP receives the specified number of octets, it will return a 250 reply code. The optional LAST parameter on the BDAT command indicates that this is the last chunk of message data to be sent. Any BDAT command sent after the BDAT LAST is illegal and must be replied to with a 503 "Bad sequence of commands" reply code. The state resulting from this error is indeterminate. A RSET command must be sent to clear the transaction before continuing. A 250 response should be sent to each BDAT data block. If a failure occurs after a BDAT command is received, the receiver-SMTP must accept and discard the associated message data before sending the 5XX code. If a 5XX code is received by the sender-SMTP in response to a BDAT chunk, the message should be considered failed and the sender SMTP Vaudreuil Expires 5/1/00 [Page 3] Internet Draft Binary ESMTP July 13, 2000 must not send any additional BDAT segments. If the receiver-SMTP has declared support for streaming, the receiver SMTP must be prepared to accept and discard additional BDAT chunks already in the pipeline after the failed BDAT. Note: An error on the receiver-SMTP such as disk full or imminent shutdown can only be reported after the BDAT segment has been received. It is therefore important to choose a reasonable chunk size given the expected end-to-end bandwidth. Note: Because the receiver-SMTP does not acknowledge the BDAT command before the message data is sent, it is important to send the BDAT only to systems that have declared their capability to accept BDAT commands. Illegally sending a BDAT command and associated message data to a non-chunking capable system will result in the receiver-SMTP parsing the associated message data as if it were a potentially very long, binary-data containing ESMTP command line. The resulting state from a failed BDAT command is indeterminate. A RSET command must be issued to clear the transaction before additional commands may be sent. The RSET command, when issued after the first BDAT and before the BDAT LAST, clears all segments sent during that transaction and resets the session. DATA and BDAT commands cannot be used in the same transaction. If a DATA statement is issued after a BDAT for the current transaction, a 503 "Bad sequence of commands" must be issued. The state resulting from this error is indeterminate. A RSET command must be sent to clear the transaction before continuing. There is no prohibition on using DATA and BDAT in the same session, so long as they are not mixed in the same transaction. The local storage size of a message may not accurately reflect the actual size of the message sent due to local storage conventions. In particular, text messages sent with the BDAT command MUST be sent in the canonical MIME format with lines delimited with a . It may not be possible to convert the entire message to the canonical format at once. Chunking provides a mechanism to convert the message to canonical form, accurately count the bytes, and send the message a single chunk at a time. Note that correct byte counting is essential. If the sender SMTP indicates a chunk-size larger than the actual chunk-size, the receiver SMTP will continue to wait for the remainder of the data or when using streaming, will read the subsequent command as additional message data. In the case where a portion of the previous command was read as data, the parser will return a syntax error when the incomplete command is read. If the sender SMTP indicates a chunk-size smaller than the actual chunk-size, the receiver SMTP will interpret the remainder of the message data as invalid commands. Note that the remainder of the message data may be binary and as such Vaudreuil Expires 5/1/00 [Page 4] Internet Draft Binary ESMTP July 13, 2000 lexicographical parsers must be prepared to receive, process, and reject lines of arbitrary octets. Vaudreuil Expires 5/1/00 [Page 5] Internet Draft Binary ESMTP July 13, 2000 3. Framework for the Binary Service Extension The following service extension is hereby defined: 1) The name of the binary service extension is "BINARYMIME". 2) The EHLO keyword value associated with this extension is "BINARYMIME". 3) The BINARYMIME service extension can only be used with the "CHUNKING" service extension. 4) No parameter is used with the BINARYMIME keyword. 5) [8BIT] defines the BODY parameter for the MAIL command. This extension defines an additional value for the BODY parameter, "BINARYMIME". The value "BINARYMIME" associated with this parameter indicates that this message is a Binary MIME message (in strict compliance with [MIME]) with arbitrary octet content being sent. The revised syntax of the value is as follows, using the ABNF notation of [RFC822]: body-value ::= "7BIT" / "8BITMIME" / "BINARYMIME" 6) No new verbs are defined for the BINARYMIME extension. 7) This extension may be used for SMTP message submission. [Submit] A sender SMTP may request that a binary MIME message be sent without transport encoding by sending a BINARYMIME parameter with the MAIL command. When the receiver SMTP accepts a MAIL FROM command with the BINARYMIME body type requested, it agrees to preserve all bits in each octet passed using the BDAT command. A receiver-SMTP MUST NOT advertise the BINARYMIME service extension unless it relays the MIME encoded message bodies octet-for-octet intact. BINARYMIME cannot be used with the DATA command. If a DATA command is issued after a MAIL command containing the body-value of "BINARYMIME", a 501 response should be sent. The resulting state from this error condition is indeterminate and the transaction should be reset with the RSET command. It is important to note that when using BINARYMIME, it is especially important to ensure that the MIME message itself is properly formed. In particular, it is essential that text be canonically encoded with each line properly terminated with . Any transformation of text into non-canonical MIME to observe local storage conventions must be reversed before sending as BINARYMIME. Some line-oriented shortcuts will break if used with BINARYMIME. A sender-SMTP MUST use the canonical encoding for a given MIME content-type. In particular, text/* MUST be sent with terminated lines. Note: Although CR and LF do not represent SMTP command line endings in BDAT chunks, and the 7-bit and 8-bit encodings are Vaudreuil Expires 5/1/00 [Page 6] Internet Draft Binary ESMTP July 13, 2000 not required with BINARYMIME, the RFC 2781 prohibition against using a UTF-16 charset within the text top-level media type or remains. The syntax of the extended MAIL command is identical to the MAIL command in [RFC821], except that a BODY parameter must appear after the address. The complete syntax of this extended command is defined in [ESMTP]. The ESMTP-keyword is BODY and the syntax for ESMTP-value is given by the syntax for body-value in [ESMTP]. If a receiver-SMTP does not indicate support the BINARYMIME message format then the client SMTP must not, under any circumstances, send binary data using the BDAT command. If the receiver-SMTP does not support BINARYMIME and the message content is a MIME object with a binary encoding, a client SMTP has two options with which to forward the message. First, it may implement a gateway transformation to convert the message into valid 7bit-encoded MIME. Second, it may treat this as a permanent error and handle it in the usual manner for delivery failures. The specifics of MIME content-transfer-encodings, including transformations from Binary MIME to 7bit MIME are not described by this RFC; the conversion is nevertheless constrained in the following ways: 1. The conversion must cause no loss of information; MIME transport encodings must be employed as needed to insure this is the case. 2. The resulting message must be valid 7bit MIME. In particular, the transformation may not result in nested Base-64 or Quoted-Printable content-transfer-encodings. As of present there are no mechanisms for converting a binary MIME object into an 8-bit MIME object. Such a transformation will require the specification of a new MIME content-transfer-encoding, the standardization of which is discouraged by [MIME]. Vaudreuil Expires 5/1/00 [Page 7] Internet Draft Binary ESMTP July 13, 2000 4. Examples 4.1 Simple Chunking The following simple dialogue illustrates the use of the large message extension to send a short psudo-RFC822 message to one recipient using the CHUNKING extension: R: S: R: 220 cnri.reston.va.us SMTP service ready S: EHLO ymir.claremont.edu R: 250-cnri.reston.va.us says hello R: 250 CHUNKING S: MAIL FROM: R: 250 Sender ok S: RCPT TO: R: 250 Recipient ok S: BDAT 86 LAST S: To: Susan@random.com S: From: Sam@random.com S: Subject: This is a bodyless test message R: 250 Message OK, 86 octets received S: QUIT R: 221 Goodbye Vaudreuil Expires 5/1/00 [Page 8] Internet Draft Binary ESMTP July 13, 2000 4.2 Pipelining BINARYMIME The following dialogue illustrates the use of the large message extension to send a BINARYMIME object to two recipients using the CHUNKING and PIPELINING extensions: R: R: 220 cnri.reston.va.us SMTP service ready S: EHLO ymir.claremont.edu R: 250-cnri.reston.va.us says hello R: 250-PIPELINING R: 250-BINARYMIME R: 250 CHUNKING S: MAIL FROM: BODY=BINARYMIME S: RCPT TO: S: RCPT TO: R: 250 ... Sender and BINARYMIME ok R: 250 ... Recipient ok R: 250 ... Recipient ok S: BDAT 100000 S: (First 10000 octets of canonical MIME message data) S: BDAT 324 LAST S: (Remaining 324 octets of canonical MIME message data) R: 250 100000 bytes received R: 250 Message OK, 100324 octets received S: QUIT R: 221 Goodbye Vaudreuil Expires 5/1/00 [Page 9] Internet Draft Binary ESMTP July 13, 2000 5. Security Considerations This extension is not known to present any additional security issues not already endemic to electronic mail and present in fully conforming implementations of [RFC821], or otherwise made possible by [MIME]. 6. Acknowledgments This protocol is the result of numerous discussions in the IETF SMTP Extensions Working Group and in particular due to the continued advocacy of "chunking" by Neil Katin. 7. References [BINARY] Vaudreuil, G, " SMTP Service Extensions for Transmission of Large and Binary MIME Messages", RFC 1830, August 1995. [RFC821] Postel, J., "Simple Mail Transfer Protocol", STD 10, RFC 821, USC/Information Sciences Institute, August 1982. [RFC822] Crocker, D., "Standard for the Format of ARPA Internet Text Messages", STD 11, RFC 822, UDEL, August 1982. [MIME] N. Borenstein, and N. Freed, "Multipurpose Internet Mail Extensions (MIME) Part One: Format of Internet Message Bodies", RFC 2045, Bellcore, Innosoft, November 1996. [SUBMIT] R. Gellens, and J. Klensin, "Message Submission", RFC 2476, Qualcomm, MCI, December 1998. [ESMTP] Klensin, J., WG Chair, Freed, N., Editor, Rose, M., Stefferud, E., and D. Crocker, "SMTP Service Extensions" RFC 1869, United Nations University, Innosoft International, Inc., Dover Beach Consulting, Inc., Network Management Associates, Inc., The Branch Office, November 1995. [8BIT] Klensin, J., WG Chair, Freed, N., Editor, Rose, M., Stefferud, E., and D. Crocker, "SMTP Service Extension for 8bit-MIMEtransport" RFC 1652, United Nations University, Innosoft International, Inc., Dover Beach Consulting, Inc., Network Management Associates, Inc., The Branch Office, July 1994. [PIPE] Freed, N., "SMTP Service Extensions for Command Pipelining", RFC 1854, Innosoft International, October 1995. 8. Copyright Notice "Copyright (C) The Internet Society (2000). 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 Vaudreuil Expires 5/1/00 [Page 10] Internet Draft Binary ESMTP July 13, 2000 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." 9. Author's Address Gregory M. Vaudreuil Lucent Technologies 17080 Dallas Parkway Dallas, TX 75248-1905 Voice/Fax: +1-972-733-2722 GregV@ieee.org Vaudreuil Expires 5/1/00 [Page 11] Internet Draft Binary ESMTP July 13, 2000 10. Appendix A - Changes from RFC1830 Numerous editorial changes including required intellectual property boilerplate and revised authors contact information Corrected the simple chunking example to use the correct number of bytes. Vaudreuil Expires 5/1/00 [Page 12]