Merge branch 'auto-plaintext-email'

v1.18.x
Julian Lam 10 years ago
commit 9a17e2a3e9

@ -30,6 +30,7 @@
"express-session": "^1.8.2", "express-session": "^1.8.2",
"gravatar": "^1.1.0", "gravatar": "^1.1.0",
"heapdump": "^0.3.0", "heapdump": "^0.3.0",
"html-to-text": "1.3.2",
"jimp": "^0.2.5", "jimp": "^0.2.5",
"less": "^2.0.0", "less": "^2.0.0",
"logrotate-stream": "^0.2.3", "logrotate-stream": "^0.2.3",

@ -2,14 +2,20 @@
var async = require('async'), var async = require('async'),
winston = require('winston'), winston = require('winston'),
nconf = require('nconf'),
templates = require('templates.js'), templates = require('templates.js'),
nodemailer = require('nodemailer'), nodemailer = require('nodemailer'),
htmlToText = require('html-to-text'),
url = require('url'),
User = require('./user'), User = require('./user'),
Plugins = require('./plugins'), Plugins = require('./plugins'),
meta = require('./meta'), meta = require('./meta'),
translator = require('../public/src/modules/translator'), translator = require('../public/src/modules/translator'),
transports = {
direct: nodemailer.createTransport('direct')
},
app; app;
(function(Emailer) { (function(Emailer) {
@ -54,9 +60,6 @@ var async = require('async'),
html: function(next) { html: function(next) {
renderAndTranslate('emails/' + template, params, lang, next); renderAndTranslate('emails/' + template, params, lang, next);
}, },
plaintext: function(next) {
renderAndTranslate('emails/' + template + '_plaintext', params, lang, next);
},
subject: function(next) { subject: function(next) {
translator.translate(params.subject, lang, function(translated) { translator.translate(params.subject, lang, function(translated) {
next(null, translated); next(null, translated);
@ -67,11 +70,13 @@ var async = require('async'),
function (results, next) { function (results, next) {
var data = { var data = {
to: email, to: email,
from: meta.config['email:from'] || 'no-reply@localhost.lan', from: meta.config['email:from'] || 'no-reply@' + getHostname(),
from_name: meta.config['email:from_name'] || 'NodeBB', from_name: meta.config['email:from_name'] || 'NodeBB',
subject: results.subject, subject: results.subject,
html: results.html, html: results.html,
plaintext: results.plaintext, plaintext: htmlToText.fromString(results.html, {
ignoreImage: true
}),
template: template, template: template,
uid: params.uid, uid: params.uid,
pid: params.pid, pid: params.pid,
@ -96,8 +101,7 @@ var async = require('async'),
data.text = data.plaintext; data.text = data.plaintext;
delete data.plaintext; delete data.plaintext;
nodemailer.mail(data); transports.direct.sendMail(data, callback);
callback(null);
}; };
function render(tpl, params, next) { function render(tpl, params, next) {
@ -126,5 +130,12 @@ var async = require('async'),
], callback); ], callback);
} }
function getHostname() {
var configUrl = nconf.get('url'),
parsed = url.parse(configUrl);
return parsed.hostname;
};
}(module.exports)); }(module.exports));

Loading…
Cancel
Save