1 / 27

Email Protocols and Structure

Learn about Email structure, MIME, Email transport, User agents, Servers, Push and Pull email, SMTP, POP3, IMAP4, RFC822 Headers, and more.

wayneconn
Download Presentation

Email Protocols and Structure

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. Internet and Intranet Protocols and Applications Lecture 8: EMAIL 2/21/2000 Vernal equinox + 1 Arthur P. Goldberg Computer Science Department New York University artg@cs.nyu.edu

  2. Outline • Email structure • RFC822 • MIME • Email transport • User agents, Servers, Gateways • Push • SMTP • Pull • POP3, IMAP4

  3. RFC822 Headers <Blank line> [Body] Key headers As we’ve discussed … Multipurpose Internet Mail Extensions (MIME) N. Borenstein, N. Freed, RFC1521, 1993 Email body Self-describing, typed object Key Headers MIME-Version Content-Transfer-Encoding – how binary is mapped to ASCII Content-Type Email structure

  4. MIME Content-Types • Hierarchical • Examples Text/Plain Image/Gif Image/Jpeg Application/Octet-stream Application/Postscript Multipart/Mixed • Multipart/Mixed • Multipart separation • boundary="------------C725BD4EC548463C“ • Potentially recursive • Each part described by a MIME type

  5. Mail transport:User agents (UA), Servers, Gateways • Draw a diagram • Multiple UAs may access one mailbox concurrently • Remember IBM’S VM – only ONE login! • Proxies and gateways for security and addressing • Firewall digression and diagram? • Visible in Received: headers

  6. Example Received: headers

  7. SMTP +----------+ +----------+ +------+ | | | | | User |<-->| | SMTP | | +------+ | Sender- |Commands/Replies| Receiver-| +------+ | SMTP |<-------------->| SMTP | +------+ | File |<-->| | and Mail | |<-->| File | |System| | | | | |System| +------+ +----------+ +----------+ +------+ Sender-SMTP Receiver-SMTP Model for SMTP Use

  8. SMTP • Push email • Goals • Work reliably • Implement easily • Minimum Implementation Commands HELO <SP> <domain> <CRLF> MAIL <SP> FROM:<reverse-path> <CRLF> RCPT <SP> TO:<forward-path> <CRLF> DATA QUIT RSET NOOP

  9. SMTP Data Transmission C: DATA S: 354 Enter mail, end with "." on a line by itself C: Message-ID: <3895F196.816A8F98@cs.nyu.edu> C: Date: Mon, 31 Jan 2000 15:33:26 -0500 C: From: Arthur Goldberg <artg@cs.nyu.edu> C: X-Mailer: Mozilla 4.51 [en] (WinNT; I) C: MIME-Version: 1.0 C: To: me <artg@cs>, Meira Goldberg <lameira@juno.com> C: Subject: testing C: Content-Type: text/plain; charset=us-ascii C: C: a test message C: . S: 250 PAA22834 Message accepted for delivery C: QUIT S: 221 griffin.cs.nyu.edu closing connection

  10. Selected SMTP REPLY CODES (by function groups) 500 Syntax error, command unrecognized 501 Syntax error in parameters or arguments 503 Bad sequence of commands 211 System status, or system help reply 214 Help message 220 <domain> Service ready 221 <domain> Service closing transmission channel 421 <domain> Service t available, closing transmission channel 250 Requested mail action okay, completed 251 User t local; will forward to <forward-path> 450 Requested mail action t taken: mailbox unavailable 451 Requested action aborted: error in processing 452 Requested action t taken: insufficient system storage 552 Requested mail action aborted: exceeded storage allocation 354 Start mail input; end with <CRLF>.<CRLF> 554 Transaction failed

  11. Email Pull Models • RFC 1733, M Crispin, 94 • POP - Offline, IMAP - All Feature Offline Online Dis- ------- connected Can use multiple clients Y Y Minimum use of server connect time Y Y Minimum use of server resources Y Minimum use of client disk resources Y Multiple remote mailboxes Y Y Fast startup Y Mail processing when not online Y Y

  12. Post Office Protocol - Version 3 (POP3) • Pull email • Permit a workstation to dynamically access a maildrop on a server

  13. POP3 States • AUTHORIZATION: TCP connection has been opened • TRANSACTION: client has successfully identified itself and POP3 server has locked and opened the appropriate maildrop • UPDATE: client has issued QUIT from the TRANSACTION state

  14. POP3 Commands, by State • AUTHORIZATION USER name PASS password APOP name digest - ‘digest' is MD5 of the server’s timestamp and a shared SECRET known only to the client and server

  15. POP3 Commands, by State, continued • TRANSACTION STAT - status LIST – list messages UIDL [msg] - unique-id listing RETR msg – retrieve msg DELE msg – delete msg QUIT – enter UPDATE state • UPDATE QUIT – remove messages marked as deleted; release any lock on the maildrop and close the connection

  16. POP3 Scaling • the combination of UIDL not issuing DELE command - provides a weak "maildrop as semi-permanent repository" normally associated with IMAP • Overloads the server • Suggested resolutions • Impose a per-user maildrop storage quota or the like • Enforce a policy limiting mail retention on the server

  17. Internet Message Access Protocol - Version 4rev1 (IMAP) • Supports • manipulation of remote message folders (mailboxes) in a way that is functionally equivalent to local mailboxes • Offline client can resynchronize with the server • Operations • create, delete, and rename mailboxes • check for new messages; remove messages • Parse, search, selectively fetch message attributes, texts, and portions thereof • Access • message sequence numbers or unique identifiers

  18. IMAP4 Message Attributes • Message Sequence Number • Relative position from 1 to the number of messages in the mailbox • Size • Envelope Structure • the [RFC-822] envelope information • Body Structure • parsed representation of the MIME body structure

  19. IMAP4 UIDs • unique identifier validity value (UIVV) • associated with every mailbox • unique identifier validity value MUST increase across sessions • non-persistence problems • mailbox X deleted and a new mailbox X is created later • good value: a 32-bit representation of the mailbox creation date/time • Unique Identifier (UID) • Combination of 32-bit number and UIVV • permanently guaranteed not to refer to any other message in the mailbox

  20. IMAP4 Flag Message Attributes

  21. IMAP4 Server States • Non-Authenticated • client MUST supply authentication credentials • avoided if the connection has been pre-authenticated • Authenticated • client MUST select a mailbox • Selected • a mailbox has been selected for access • Logout • the server will close the connection

  22. +--------------------------------------+ |initial connection and server greeting| +--------------------------------------+ || (1) || (2) || (3) VV || || +-----------------+ || || |non-authenticated| || || +-----------------+ || || || (7) || (4) || || || VV VV || || +----------------+ || || | authenticated |<=++ || || +----------------+ || || || || (7) || (5) || (6) || || || VV || || || || +--------+ || || || || |selected|==++ || || || +--------+ || || || || (7) || VV VV VV VV +--------------------------------------+ | logout and close connection | +--------------------------------------+ IMAP4 Server State Transition Diagram (1) connection without pre-authentication (OK greeting) (2) pre-authenticated connection (PREAUTH greeting) (3) rejected connection (BYE greeting) (4) successful LOGIN or AUTHENTICATE command (5) successful SELECT or EXAMINE command (6) CLOSE command, or failed SELECT or EXAMINE command (7) LOGOUT command, server shutdown, or connection closed

  23. IMAP4 Client Commands, by State • Any State • LOGOUT • Non-Authenticated • AUTHENTICATE “authentication mechanism name” • LOGIN username password • Authenticated • SELECT mailbox_name • CREATE mailbox_name • DELETE mailbox_name • SUBSCRIBE mailbox_name • STATUS mailbox_name

  24. IMAP4 Authentication Example S: * OK KerberosV4 IMAP4rev1 Server C: A001 AUTHENTICATE KERBEROS_V4 S: + AmFYig== C: BAcAQU5EUkVXLkNNVS5FRFUAOCAsho84kLN3/IJmrMG+25a4DT +nZImJjnTNHJUtxAA+o0KPKfHEcAFs9a3CL5Oebe/ydHJUwYFd WwuQ1MWiy6IesKvjL5rL9WjXUb9MwT9bpObYLGOKi1Qh S: + or//EoAADZI= C: DiAF5A4gA+oOIALuBkAAmw== S: A001 OK Kerberos V4 authentication successful

  25. IMAP4 Client Commands in Selected State • CHECK - checkpoint the mailbox • CLOSE – remove \Deleted messages, and return to authenticated state • EXPUNGE - remove \Deleted messages • FETCH message_set message_data_item names - get message parts • SEARCH arguments • COPY message_set mailbox_name • STORE arguments – alter message data

  26. cs.nyu.edu Subject: email Date: Mon, 20 Mar 2000 12:55:12 -0500 From: Arthur Goldberg artg@cs.nyu.edu To: "comment@cims" <comment@cims.nyu.edu> Andy It would be handy to have an IMAP4 server manage our email. Have we/you considered that? A From: CIMS Systems Support <comment@cims.nyu.edu> To: artg@cs.nyu.edu, comment@cims.nyu.edu We’ll consider it. Last time we considered it it had serious security problems -andy

  27. Later • SMTP undeliverable mail notification • Software Design • Reliability, Standards compliance, Performance • Deployed system design • Addressing • Manageability • Security • Encryption • PEM • SPAM • Open relays

More Related