smtp-connection
SMTP client module. Connect to SMTP servers and send mail with it.
This module is the successor for the client part of the (now deprecated) SMTP module simplesmtp. For matching SMTP server see smtp-server.
Other similar packages you might be interested in
- nodemailer – all in one package to send email from Node.js
- smtp-server – add SMTP server interface to your application
- zone-mta – full featured outbound MTA built using smtp-connection and smtp-server modules
Usage
Install with npm
npm install smtp-connection
Require in your script
var SMTPConnection = require('smtp-connection');
Create SMTPConnection instance
var connection = new SMTPConnection(options);
Where
Events
SMTPConnection instances are event emitters with the following events
- 'error' (err) emitted when an error occurs. Connection is closed automatically in this case.
- 'connect' emitted when the connection is established
- 'end' when the instance is destroyed
connect
Establish the connection
connection.connect(callback)
Where
- callback is the function to run once the connection is established. The function is added as a listener to the 'connect' event.
After the connect event the connection
has the following properties:
- connection.secure - if
true
then the connection uses a TLS socket, otherwise it is using a cleartext socket. Connection can start out as cleartext but if available (or requireTLS
is set to true) connection upgrade is tried
login
If the server requires authentication you can login with
connection.login(auth, callback)
Where
If a XOAuth2 token generator is used as the value for auth.xoauth2
then you do not need to set auth.user
. XOAuth2 generator generates required accessToken itself if it is missing or expired. In this case if the authentication fails, a new token is requeested and the authentication is retried. If it still fails, an error is returned.
XOAuth2 Example
var generator = require('xoauth2').createXOAuth2Generator({
user: '{username}',
clientId: '{Client ID}',
clientSecret: '{Client Secret}',
refreshToken: '{refresh-token}'
});
generator.on('token', function(token){
console.log('New token for %s: %s', token.user, token.accessToken);
});
connection.login({
xoauth2: generator
}, callback);
Login using NTLM
smtp-connection
has experimental support for NTLM authentication. You can try it out like this:
connection.login({
domain: 'windows-domain',
workstation: 'windows-workstation',
user: 'user@somedomain.com',
pass: 'pass'
}, callback);
I do not have access to an actual server that supports NTLM authentication so this feature is untested and should be used carefully.
send
Once the connection is authenticated (or just after connection is established if authentication is not required), you can send mail with
connection.send(envelope, message, callback)
Where
-
envelope is the envelope object to use
-
envelope.from is the sender address
-
envelope.to is the recipient address or an array of addresses
-
envelope.size is an optional value of the predicted size of the message in bytes. This value is used if the server supports the SIZE extension (RFC1870)
-
envelope.use8BitMime if true
then inform the server that this message might contain bytes outside 7bit ascii range
-
envelope.dsn is the dsn options
- envelope.dsn.ret return either the full message 'FULL' or only headers 'HDRS'
- envelope.dsn.envid sender's 'envelope identifier' for tracking
- envelope.dsn.notify when to send a DSN. Multiple options are OK - array or comma delimited. NEVER must appear by itself. Available options: 'NEVER', 'SUCCESS', 'FAILURE', 'DELAY'
- envelope.dsn.orcpt original recipient
-
message is either a String, Buffer or a Stream. All newlines are converted to \r\n and all dots are escaped automatically, no need to convert anything before.
-
callback is the callback to run once the sending is finished or failed. Callback has the following arguments
quit
Use it for graceful disconnect
connection.quit();
close
Use it for less graceful disconnect
connection.close();
reset
Use it to reset current session (invokes RSET command)
connection.reset(callback);
License
MIT