Security News
Fluent Assertions Faces Backlash After Abandoning Open Source Licensing
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
mailgun-js
Advanced tools
Simple Node.js module for Mailgun.
npm install mailgun-js
Please see Mailgun Documentation for full Mailgun API reference.
Currently we implement the send message
(non-MIME) API and the Domains
, Routes
, Mailing Lists
, Unsubscribes
and Bounces
API's. These would be the most common
and practical API's to be programmatically used. Others would be easy to add if needed.
This module works by providing proxy objects for interacting with different resources through the Mailgun API.
Most methods take a data
parameter, which is a Javascript object that would contain the arguments for the Mailgun API.
All methods take a final parameter callback with two parameters: error
, and body
.
We try to parse the body
into a javascript object, and return it to the callback as such for easier use and inspection by the client.
If there was an error a new Error
object will be passed to the callback in the error
parameter.
See the /docs
folder for detailed documentation. For full usage examples see the /test
folder.
var api_key = 'key-XXXXXXXXXXXXXXXXXXXXXXX';
var domain = 'mydomain.mailgun.org';
var Mailgun = require('mailgun-js');
var mailgun = new Mailgun({apiKey: api_key, domain: domain});
var data = {
from: 'Excited User <me@samples.mailgun.org>',
to: 'serobnic@mail.ru',
subject: 'Hello',
text: 'Testing some Mailgun awesomness!'
};
mailgun.messages().send(data, function (error, body) {
console.log(body);
});
Something more elaborate. Get mailing list info, create a member and get mailing list members and update member. Notice that the proxy objects can be reused.
var list = mailgun.lists('mylist@mycompany.com');
list.info(function (err, data) {
// `data` is mailing list info
console.log(data);
});
var bob = {
subscribed: true,
address: 'bob@gmail.com',
name: 'Bob Bar',
vars: {age: 26}
};
list.members().create(bob, function (err, data) {
// `data` is the member details
console.log(data);
});
list.members().list(function (err, members) {
// `members` is the list of members
console.log(members);
});
list.members('bob@gmail.com').update({ name: 'Foo Bar' }, function (err, body) {
console.log(body);
});
Sending attachments can be done in a few ways. We can use the path to a file in the attachment
parameter. If the
attachment
parameter is of type string
it is assumed to be the path to a file.
var filepath = path.join(__dirname, '/mailgun_logo.png');
var data = {
from: 'Excited User <me@samples.mailgun.org>',
to: 'serobnic@mail.ru',
subject: 'Hello',
text: 'Testing some Mailgun awesomness!',
attachment: filepath
};
mailgun.messages().send(data, function (error, body) {
console.log(body);
});
We can pass a buffer (has to be a Buffer
object) of the data. If a buffer is used the data will be attached using a
generic filename "file".
var filepath = path.join(__dirname, '/mailgun_logo.png');
var file = fs.readFileSync(filepath);
var data = {
from: 'Excited User <me@samples.mailgun.org>',
to: 'serobnic@mail.ru',
subject: 'Hello',
text: 'Testing some Mailgun awesomness!',
attachment: file
};
mailgun.messages().send(data, function (error, body) {
console.log(body);
});
Finally we provide a Mailgun.Attachment
class to add attachment and specify both the buffer and filename data.
var filename = '/mailgun_logo.png';
var filepath = path.join(__dirname, filename);
var file = fs.readFileSync(filepath);
var attch = new Mailgun.Attachment(file, filename);
var data = {
from: 'Excited User <me@samples.mailgun.org>',
to: 'serobnic@mail.ru',
subject: 'Hello',
text: 'Testing some Mailgun awesomness!',
attachment: attch
};
mailgun.messages().send(data, function (error, body) {
console.log(body);
});
If an attachment object is not of type Buffer
or a string
or a Mailgun.Attachment
object with valid data it is
ignored. Multiple attachments can be sent by passing an array in the attachment
parameter. The array elements can
be of any one of the valid types and each one will be handled appropriately.
members().create({data})
will create a mailing list member with data
. Mailgun also offers a resource for creating
members in bulk. Doing a POST
to /lists/<address>/members.json
adds multiple members, up to 1,000 per call,
to a Mailing List. This can be accomplished using members().add()
.
var members = [
{
address: 'Alice <alice@example.com>',
vars: { age: 26 }
},
{
name: 'Bob',
address: 'bob@example.com',
vars: { age: 34 }
}
];
mailgun.lists('mylist@mycompany.com').members().add({ members: members, subscribed: true }, function (err, body) {
console.log(body);
});
Mailgun-js also provides helper methods to allow users to interact with parts of the api that are not exposed already.
mailgun.get(resource, data, callback)
- sends GET request to the specified resource on api.mailgun.post(resource, data, callback)
- sends POST request to the specified resource on api.mailgun.delete(resource, data, callback)
- sends DELETE request to the specified resource on api.mailgun.put(resource, data, callback)
- sends PUT request to the specified resource on api.Example: Get some stats
mailgun.get('/stats', { event: ['sent', 'delivered'] }, function (error, body) {
console.log(body);
});
Module works with Node-style callbacks, but also implements promises with the Q library.
mailgun.lists('mylist@mydomain.com').info().then(function (data) {
console.log(data);
}, function (err) {
console.log(err);
});
The function passed as 2nd argument is optional and not needed if you don't care about the fail case.
To run the test suite you must first have a Mailgun account with a domain setup. Then create a file named ./test/auth.json, which contains your credentials as JSON, for example:
{ "api_key": "key-XXXXXXXXXXXXXXXXXXXXXXX", "domain": "mydomain.mailgun.org" }
You should edit ./test/fixture.json and modify the data to match your context.
Then install the dev dependencies and execute the test suite:
$ npm install
$ npm test
The tests will call Mailgun API, and will send a test email, create route(s), mailing list and mailing list member.
This project is not endorsed by or affiliated with Mailgun. The general design and some code was heavily inspired by node-heroku-client.
Copyright 2012, 2013, 2014 OneLobby
Licensed under the MIT License.
FAQs
Simple Node.js helper module for Mailgun API
The npm package mailgun-js receives a total of 89,358 weekly downloads. As such, mailgun-js popularity was classified as popular.
We found that mailgun-js demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
Research
Security News
Socket researchers uncover the risks of a malicious Python package targeting Discord developers.
Security News
The UK is proposing a bold ban on ransomware payments by public entities to disrupt cybercrime, protect critical services, and lead global cybersecurity efforts.