mirror of
https://github.com/NodeBB/NodeBB.git
synced 2025-11-09 15:35:47 +01:00
new hook filter:email.send
This commit is contained in:
@@ -45,49 +45,64 @@ var fs = require('fs'),
|
|||||||
};
|
};
|
||||||
|
|
||||||
Emailer.sendToEmail = function(template, email, language, params, callback) {
|
Emailer.sendToEmail = function(template, email, language, params, callback) {
|
||||||
callback = callback || function() {};
|
function renderAndTranslate(tpl, params, callback) {
|
||||||
async.parallel({
|
async.waterfal([
|
||||||
html: function(next) {
|
function (next) {
|
||||||
app.render('emails/' + template, params, next);
|
app.render(template, params, next);
|
||||||
},
|
},
|
||||||
plaintext: function(next) {
|
function (html, next) {
|
||||||
app.render('emails/' + template + '_plaintext', params, next);
|
translator.translate(html, lang, function(translated) {
|
||||||
}
|
next(null, translated);
|
||||||
}, function(err, results) {
|
|
||||||
if (err) {
|
|
||||||
winston.error('[emailer] Error sending digest : ' + err.stack);
|
|
||||||
return callback(err);
|
|
||||||
}
|
|
||||||
async.map([results.html, results.plaintext, params.subject], function(raw, next) {
|
|
||||||
translator.translate(raw, language || meta.config.defaultLang || 'en_GB', function(translated) {
|
|
||||||
next(undefined, translated);
|
|
||||||
});
|
});
|
||||||
}, function(err, translated) {
|
}
|
||||||
if (err) {
|
], callback);
|
||||||
return callback(err);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (Plugins.hasListeners('action:email.send')) {
|
callback = callback || function() {};
|
||||||
Plugins.fireHook('action:email.send', {
|
|
||||||
|
if (!Plugins.hasListeners('action:email.send')) {
|
||||||
|
winston.warn('[emailer] No active email plugin found!');
|
||||||
|
return callback();
|
||||||
|
}
|
||||||
|
|
||||||
|
var lang = language || meta.config.defaultLang || 'en_GB';
|
||||||
|
|
||||||
|
async.waterfall([
|
||||||
|
function (next) {
|
||||||
|
async.parallel({
|
||||||
|
html: function(next) {
|
||||||
|
renderAndTranslate('emails/' + template, params, next);
|
||||||
|
},
|
||||||
|
plaintext: function(next) {
|
||||||
|
renderAndTranslate('emails/' + template + '_plaintext', params, next);
|
||||||
|
},
|
||||||
|
subject: function(next) {
|
||||||
|
translator.translate(params.subject, lang, function(translated) {
|
||||||
|
next(null, translated);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}, next);
|
||||||
|
},
|
||||||
|
function (results, next) {
|
||||||
|
var data = {
|
||||||
to: email,
|
to: email,
|
||||||
from: meta.config['email:from'] || 'no-reply@localhost.lan',
|
from: meta.config['email:from'] || 'no-reply@localhost.lan',
|
||||||
from_name: meta.config['email:from_name'] || 'NodeBB',
|
from_name: meta.config['email:from_name'] || 'NodeBB',
|
||||||
subject: translated[2],
|
subject: results.subject,
|
||||||
html: translated[0],
|
html: results.html,
|
||||||
plaintext: translated[1],
|
plaintext: results.plaintext,
|
||||||
template: template,
|
template: template,
|
||||||
uid: params.uid,
|
uid: params.uid,
|
||||||
pid: params.pid,
|
pid: params.pid,
|
||||||
fromUid: params.fromUid
|
fromUid: params.fromUid
|
||||||
});
|
};
|
||||||
callback();
|
Plugins.fireHook('filter:email.send', data, next);
|
||||||
} else {
|
},
|
||||||
winston.warn('[emailer] No active email plugin found!');
|
function (data, next) {
|
||||||
callback();
|
Plugins.fireHook('action:email.send', data);
|
||||||
|
next();
|
||||||
}
|
}
|
||||||
});
|
], callback);
|
||||||
});
|
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user