2014-06-03 14:05:25 +01:00
|
|
|
// # Mail API
|
|
|
|
// API for sending Mail
|
2015-07-18 02:26:15 +02:00
|
|
|
var _ = require('lodash').runInContext(),
|
2014-08-17 06:17:23 +00:00
|
|
|
Promise = require('bluebird'),
|
2015-11-02 14:17:28 +01:00
|
|
|
pipeline = require('../utils/pipeline'),
|
2014-07-29 15:35:48 +02:00
|
|
|
config = require('../config'),
|
|
|
|
errors = require('../errors'),
|
2014-09-21 16:54:32 -04:00
|
|
|
mailer = require('../mail'),
|
2014-08-13 17:58:12 -04:00
|
|
|
Models = require('../models'),
|
2015-11-02 14:17:28 +01:00
|
|
|
utils = require('./utils'),
|
2014-07-29 15:35:48 +02:00
|
|
|
path = require('path'),
|
|
|
|
fs = require('fs'),
|
2015-08-12 10:24:34 +02:00
|
|
|
templatesDir = path.resolve(__dirname, '..', 'mail', 'templates'),
|
2014-07-29 15:35:48 +02:00
|
|
|
htmlToText = require('html-to-text'),
|
2015-11-02 14:17:28 +01:00
|
|
|
readFile = Promise.promisify(fs.readFile),
|
|
|
|
docName = 'mail',
|
2015-11-12 13:29:45 +01:00
|
|
|
i18n = require('../i18n'),
|
2014-04-04 03:59:09 +02:00
|
|
|
mail;
|
2014-05-09 00:12:18 +01:00
|
|
|
|
2015-11-02 14:17:28 +01:00
|
|
|
_.templateSettings.interpolate = /{{([\s\S]+?)}}/g;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Send mail helper
|
|
|
|
*/
|
|
|
|
|
|
|
|
function sendMail(object) {
|
|
|
|
return mailer.send(object.mail[0].message).catch(function (err) {
|
|
|
|
err = new errors.EmailError(err.message);
|
|
|
|
|
|
|
|
return Promise.reject(err);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2014-06-03 14:05:25 +01:00
|
|
|
/**
|
|
|
|
* ## Mail API Methods
|
|
|
|
*
|
|
|
|
* **See:** [API Methods](index.js.html#api%20methods)
|
|
|
|
* @typedef Mail
|
|
|
|
* @param mail
|
|
|
|
*/
|
2014-04-04 03:59:09 +02:00
|
|
|
mail = {
|
2014-06-03 14:05:25 +01:00
|
|
|
/**
|
|
|
|
* ### Send
|
|
|
|
* Send an email
|
|
|
|
*
|
|
|
|
* @public
|
|
|
|
* @param {Mail} object details of the email to send
|
|
|
|
* @returns {Promise}
|
|
|
|
*/
|
2014-07-17 09:48:39 +01:00
|
|
|
send: function (object, options) {
|
2015-11-02 14:17:28 +01:00
|
|
|
var tasks;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* ### Format Response
|
|
|
|
* @returns {Mail} mail
|
|
|
|
*/
|
|
|
|
|
|
|
|
function formatResponse(data) {
|
|
|
|
delete object.mail[0].options;
|
|
|
|
// Sendmail returns extra details we don't need and that don't convert to JSON
|
|
|
|
delete object.mail[0].message.transport;
|
|
|
|
object.mail[0].status = {
|
|
|
|
message: data.message
|
|
|
|
};
|
|
|
|
|
|
|
|
return object;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* ### Send Mail
|
|
|
|
*/
|
|
|
|
|
|
|
|
function send() {
|
|
|
|
return sendMail(object, options);
|
|
|
|
}
|
|
|
|
|
|
|
|
tasks = [
|
|
|
|
utils.handlePermissions(docName, 'send'),
|
|
|
|
send,
|
|
|
|
formatResponse
|
|
|
|
];
|
|
|
|
|
|
|
|
return pipeline(tasks, options || {});
|
2014-04-04 03:59:09 +02:00
|
|
|
},
|
2014-06-26 18:22:52 +00:00
|
|
|
|
2014-06-03 14:05:25 +01:00
|
|
|
/**
|
|
|
|
* ### SendTest
|
|
|
|
* Send a test email
|
|
|
|
*
|
|
|
|
* @public
|
2014-09-10 00:06:24 -04:00
|
|
|
* @param {Object} options required property 'to' which contains the recipient address
|
2014-06-03 14:05:25 +01:00
|
|
|
* @returns {Promise}
|
|
|
|
*/
|
2014-08-08 18:41:14 +01:00
|
|
|
sendTest: function (options) {
|
2015-11-02 14:17:28 +01:00
|
|
|
var tasks;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* ### Model Query
|
|
|
|
*/
|
|
|
|
|
|
|
|
function modelQuery() {
|
|
|
|
return Models.User.findOne({id: options.context.user});
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* ### Generate content
|
|
|
|
*/
|
|
|
|
|
|
|
|
function generateContent(result) {
|
|
|
|
return mail.generateContent({template: 'test'}).then(function (content) {
|
|
|
|
var payload = {
|
|
|
|
mail: [{
|
|
|
|
message: {
|
|
|
|
to: result.get('email'),
|
2015-11-12 13:29:45 +01:00
|
|
|
subject: i18n.t('common.api.mail.testGhostEmail'),
|
2015-11-02 14:17:28 +01:00
|
|
|
html: content.html,
|
|
|
|
text: content.text
|
|
|
|
}
|
|
|
|
}]
|
|
|
|
};
|
|
|
|
|
|
|
|
return payload;
|
2014-08-08 18:41:14 +01:00
|
|
|
});
|
2015-11-02 14:17:28 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* ### Send mail
|
|
|
|
*/
|
|
|
|
|
|
|
|
function send(payload) {
|
|
|
|
return sendMail(payload, options);
|
|
|
|
}
|
|
|
|
|
|
|
|
tasks = [
|
|
|
|
modelQuery,
|
|
|
|
generateContent,
|
|
|
|
send
|
|
|
|
];
|
|
|
|
|
|
|
|
return pipeline(tasks);
|
2014-07-22 21:22:13 -04:00
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
*
|
2014-09-10 00:06:24 -04:00
|
|
|
* @param {Object} options {
|
2014-07-22 21:22:13 -04:00
|
|
|
* data: JSON object representing the data that will go into the email
|
2015-08-12 10:24:34 +02:00
|
|
|
* template: which email template to load (files are stored in /core/server/mail/templates/)
|
2014-07-22 21:22:13 -04:00
|
|
|
* }
|
|
|
|
* @returns {*}
|
|
|
|
*/
|
|
|
|
generateContent: function (options) {
|
2015-11-02 14:17:28 +01:00
|
|
|
var defaults,
|
|
|
|
data;
|
2014-07-22 21:22:13 -04:00
|
|
|
|
2015-11-02 14:17:28 +01:00
|
|
|
defaults = {
|
|
|
|
siteUrl: config.forceAdminSSL ? (config.urlSSL || config.url) : config.url
|
|
|
|
};
|
|
|
|
|
|
|
|
data = _.defaults(defaults, options.data);
|
2014-07-22 21:22:13 -04:00
|
|
|
|
2014-09-10 00:06:24 -04:00
|
|
|
// read the proper email body template
|
2015-11-02 14:17:28 +01:00
|
|
|
return readFile(path.join(templatesDir, options.template + '.html'), 'utf8').then(function (content) {
|
|
|
|
var compiled,
|
|
|
|
htmlContent,
|
|
|
|
textContent;
|
|
|
|
|
|
|
|
// insert user-specific data into the email
|
|
|
|
compiled = _.template(content);
|
|
|
|
htmlContent = compiled(data);
|
|
|
|
|
|
|
|
// generate a plain-text version of the same email
|
|
|
|
textContent = htmlToText.fromString(htmlContent);
|
|
|
|
|
|
|
|
return {
|
|
|
|
html: htmlContent,
|
|
|
|
text: textContent
|
|
|
|
};
|
2014-07-22 21:22:13 -04:00
|
|
|
});
|
2014-04-04 03:59:09 +02:00
|
|
|
}
|
|
|
|
};
|
2014-06-26 18:22:52 +00:00
|
|
|
|
2014-07-22 21:22:13 -04:00
|
|
|
module.exports = mail;
|