module changes, fixed missing interval

v1.18.x
barisusakli 10 years ago
parent f9405c0423
commit 83ab462ff5

@ -11,52 +11,56 @@ var fs = require('fs'),
meta = require('./meta'), meta = require('./meta'),
translator = require('../public/src/translator'), translator = require('../public/src/translator'),
app = {}, app;
Emailer = {};
(function(Emailer) {
Emailer.registerApp = function(expressApp) {
Emailer.registerApp = function(expressApp) { app = expressApp;
app = expressApp; return Emailer;
return Emailer; };
};
Emailer.send = function(template, uid, params) {
Emailer.send = function(template, uid, params) { if (!app) {
async.parallel({ winston.warn('[emailer] App not ready!');
html: function(next) { return;
app.render('emails/' + template, params, next); }
},
plaintext: function(next) { async.parallel({
app.render('emails/' + template + '_plaintext', params, next); html: function(next) {
}, app.render('emails/' + template, params, next);
email: async.apply(User.getUserField, uid, 'email'), },
settings: async.apply(User.getSettings, uid) plaintext: function(next) {
}, function(err, results) { app.render('emails/' + template + '_plaintext', params, next);
async.map([results.html, results.plaintext, params.subject], function(raw, next) { },
translator.translate(raw, results.settings.language || meta.config.defaultLang || 'en_GB', function(translated) { email: async.apply(User.getUserField, uid, 'email'),
next(undefined, translated); settings: async.apply(User.getSettings, uid)
}); }, function(err, results) {
}, function(err, translated) { async.map([results.html, results.plaintext, params.subject], function(raw, next) {
if (err) { translator.translate(raw, results.settings.language || meta.config.defaultLang || 'en_GB', function(translated) {
return winston.error(err.message); next(undefined, translated);
} else if (!results.email) {
return winston.warn('uid : ' + uid + ' has no email, not sending.');
}
if (Plugins.hasListeners('action:email.send')) {
Plugins.fireHook('action:email.send', {
to: results.email,
from: meta.config['email:from'] || 'no-reply@localhost.lan',
subject: translated[2],
html: translated[0],
plaintext: translated[1],
template: template,
uid: uid
}); });
} else { }, function(err, translated) {
winston.warn('[emailer] No active email plugin found!'); if (err) {
} return winston.error(err.message);
} else if (!results.email) {
return winston.warn('uid : ' + uid + ' has no email, not sending.');
}
if (Plugins.hasListeners('action:email.send')) {
Plugins.fireHook('action:email.send', {
to: results.email,
from: meta.config['email:from'] || 'no-reply@localhost.lan',
subject: translated[2],
html: translated[0],
plaintext: translated[1],
template: template,
uid: uid
});
} else {
winston.warn('[emailer] No active email plugin found!');
}
});
}); });
}); };
}; }(module.exports));
module.exports = Emailer;

@ -11,7 +11,7 @@ var async = require('async'),
batch = require('../batch'), batch = require('../batch'),
emailer = require('../emailer'); emailer = require('../emailer');
module.exports = (function(Digest) { (function(Digest) {
Digest.execute = function(interval) { Digest.execute = function(interval) {
var digestsDisabled = meta.config.disableEmailSubscriptions !== undefined && parseInt(meta.config.disableEmailSubscriptions, 10) === 1; var digestsDisabled = meta.config.disableEmailSubscriptions !== undefined && parseInt(meta.config.disableEmailSubscriptions, 10) === 1;
if (digestsDisabled) { if (digestsDisabled) {
@ -71,14 +71,14 @@ module.exports = (function(Digest) {
user.getMultipleUserFields(data.subscribers, ['uid', 'username', 'lastonline'], function(err, users) { user.getMultipleUserFields(data.subscribers, ['uid', 'username', 'lastonline'], function(err, users) {
if (err) { if (err) {
winston.error('[user/jobs] Could not send digests (' + interval + '): ' + err.message); winston.error('[user/jobs] Could not send digests (' + data.interval + '): ' + err.message);
return callback(err); return callback(err);
} }
async.eachLimit(users, 100, function(userObj, next) { async.eachLimit(users, 100, function(userObj, next) {
user.notifications.getDailyUnread(userObj.uid, function(err, notifications) { user.notifications.getDailyUnread(userObj.uid, function(err, notifications) {
if (err) { if (err) {
winston.error('[user/jobs] Could not send digests (' + interval + '): ' + err.message); winston.error('[user/jobs] Could not send digests (' + data.interval + '): ' + err.message);
return next(err); return next(err);
} }
@ -109,7 +109,6 @@ module.exports = (function(Digest) {
}); });
}, callback); }, callback);
}); });
} };
return Digest; }(module.exports));
})({});

Loading…
Cancel
Save