Skip to content

Latest commit

 

History

History
55 lines (41 loc) · 1.57 KB

README.md

File metadata and controls

55 lines (41 loc) · 1.57 KB

mailgun-mustache-mailer

This is a simple wrapper around mustache and mailgun.com's email API.

It is constructed by supplying the domain and API-key obtained from mailgun.com, as well as the email address that emails should appear to be sent from.

A second argument, log may is supplied, with a single method info, which is called when the mailer wants to log something. It defaults to { info: console.log }.

var MailgunMustacheMailer = require("mailgun-mustache-mailer");
var config = { domain: "example.com", apiKey: "secret-mailgun-key", from: "[email protected]" };

var mailgunMustacheMailer = new MailgunMustacheMailer(config);

After construction, the object can be used to send either single emails:

var template = {
    subject: "Hello {{name}}!",
    text: "Hello {{name}}!\n",
    html: "<p>Hello {{name}}!</p>"
};

var recipient = {
    email: "[email protected]",
    name: "Asbjørn Thegler"
};

mailgunMustacheMailer.send(template, recipient, (error, mailId) => {
    if(error) return console.log(error);
    console.log("New mail was send with id %s", mailId);
});

.. or batch jobs:

var template = {
    subject: "Hello {{name}}!",
    text: "Hello {{name}}!\n",
    html: "<p>Hello {{name}}!</p>"
};

var recipients = [{
    email: "[email protected]",
    name: "Asbjørn Thegler"
}];

mailgunMustacheMailer.sendBatch(template, recipients, callback);

The callback from the batch job will be passed either an error or a list of objects zipping email addresses with mailId from mailgun.com.