Skip to main content

Appendix D. Scenarios

This appendix presents typical SMTP transaction scenarios to illustrate protocol operation.

D.1. A Typical SMTP Transaction Scenario

Scenario: [email protected] sends mail to [email protected]

# Connection establishment
C: `<establishes TCP connection to server.example port 25>`
S: 220 server.example ESMTP Postfix

# Client greeting
C: EHLO client.example
S: 250-server.example
S: 250-SIZE 52428800
S: 250-8BITMIME
S: 250-STARTTLS
S: 250 HELP

# Mail transaction
C: MAIL FROM:``<[email protected]>``
S: 250 2.1.0 Ok

C: RCPT TO:``<[email protected]>``
S: 250 2.1.5 Ok

# Message content
C: DATA
S: 354 End data with <CR><LF>.<CR><LF>

C: From: Alice ``<[email protected]>``
C: To: Bob ``<[email protected]>``
C: Subject: Hello
C: Date: Wed, 24 Dec 2024 10:00:00 +0000
C:
C: Hi Bob,
C:
C: This is a test message.
C:
C: Best regards,
C: Alice
C: .

S: 250 2.0.0 Ok: queued as A1B2C3D4E5

# Session termination
C: QUIT
S: 221 2.0.0 Bye

D.2. Aborted SMTP Transaction Scenario

Scenario: Sender aborts transaction mid-way

S: 220 server.example ESMTP

C: EHLO client.example
S: 250 server.example

C: MAIL FROM:``<[email protected]>``
S: 250 Ok

C: RCPT TO:``<[email protected]>``
S: 250 Ok

C: RCPT TO:``<[email protected]>``
S: 550 5.1.1 User unknown

# Sender decides to abort and start over
C: RSET
S: 250 Ok

# Start new transaction
C: MAIL FROM:``<[email protected]>``
S: 250 Ok

C: RCPT TO:``<[email protected]>``
S: 250 Ok

C: DATA
S: 354 Start mail input

C: (message content)
C: .
S: 250 Ok: queued as XYZ123

C: QUIT
S: 221 Bye

D.3. Relayed Mail Scenario

Scenario: Mail from [email protected] to [email protected] via relay.example

Step 1: origin.example → relay.example

C: EHLO origin.example
S: 250 relay.example

C: MAIL FROM:``<[email protected]>``
S: 250 Ok

C: RCPT TO:``<[email protected]>``
S: 250 Ok (relay accepts to forward)

C: DATA
S: 354 Start mail input
C: (message)
C: .
S: 250 Ok: queued for relay

Step 2: relay.example → final.example

# relay.example now acts as client
C: EHLO relay.example
S: 250 final.example

C: MAIL FROM:``<[email protected]>``
S: 250 Ok

C: RCPT TO:``<[email protected]>``
S: 250 Ok

C: DATA
S: 354 Start mail input
C: Received: from origin.example by relay.example; ...
C: (original message)
C: .
S: 250 Ok: delivered to bob

C: QUIT
S: 221 Bye

D.4. Verifying and Sending Scenario

Scenario: Client verifies address before sending

S: 220 server.example ESMTP

C: EHLO client.example
S: 250 server.example

# Verify recipient exists
C: VRFY bob
S: 250 Bob Smith ``<[email protected]>``

# Now send mail
C: MAIL FROM:``<[email protected]>``
S: 250 Ok

C: RCPT TO:``<[email protected]>``
S: 250 Ok

C: DATA
S: 354 Start mail input
C: (message)
C: .
S: 250 Ok

C: QUIT
S: 221 Bye

Alternative: VRFY disabled for security

C: VRFY bob
S: 252 2.5.2 Cannot VRFY user, but will accept message

# Client proceeds anyway
C: MAIL FROM:``<[email protected]>``
S: 250 Ok
...