@itservtechnology/mail-listener
v1.0.1
Published
Mail listener library for node.js. Get notification when new email arrived.
Downloads
2
Readme
Overview
Mail-listener library for node.js. Get notification when new email arrived to inbox or when message metadata (e.g. flags) changes externally. Uses IMAP protocol.
Use
Install
npm install @itservtechnology/mail-listener
JavaScript Code:
const MailListener = require("@itservtechnology/mail-listener");
const mailListener = new MailListener({
username: "imap-username",
password: "imap-password",
host: "imap-host",
port: 993, // imap port
tls: true,
connTimeout: 10000, // Default by node-imap
authTimeout: 5000, // Default by node-imap,
debug: console.log, // Or your custom function with only one incoming argument. Default: null
tlsOptions: { rejectUnauthorized: false },
mailbox: "INBOX", // mailbox to monitor
searchFilter: ["ALL"], // the search filter being used after an IDLE notification has been retrieved
markSeen: true, // all fetched email willbe marked as seen and not fetched next time
fetchUnreadOnStart: true, // use it only if you want to get all unread email on lib start. Default is `false`,
attachments: true, // download attachments as they are encountered to the project directory
attachmentOptions: { directory: "attachments/" } // specify a download directory for attachments
});
// start listening
mailListener.start();
// stop listening
// mailListener.stop();
mailListener.on("server:connected", function(){
console.log("imapConnected");
});
mailListener.on("mailbox", function(mailbox){
// this field in mailbox gives the total number of emails
console.log("Total number of mails: ", mailbox.messages.total);
});
mailListener.on("server:disconnected", function(){
console.log("imapDisconnected");
});
mailListener.on("error", function(err){
console.log(err);
});
mailListener.on("headers", function(headers, seqno){
// do something with mail headers
});
mailListener.on("body", function(body, seqno){
// do something with mail body
})
mailListener.on("attachment", function(attachment, path, seqno){
// do something with attachment
});
mailListener.on("mail", function(mail, seqno) {
// do something with the whole email as a single object
})
// it's possible to access imap object from node-imap library for performing additional actions. E.x.
mailListener.imap.move(:msguids, :mailboxes, function(){})
Attachments
Attachments in this version are buffered. This feature is based on how mailparser's simpleParser function handles attachments.
Setting attachments: true
will download attachments as buffer objects by default to the project directory.
A specific download directory may be specified by setting attachmentOptions: { directory: "attachments/"}
.
The "attachment"
event will be fired every time an attachment is encountered.