From b1263384fdf0bd4d5227428d7fe31b7b8473449f Mon Sep 17 00:00:00 2001 From: Chris Brame Date: Wed, 1 Jan 2020 23:53:26 -0500 Subject: [PATCH] fix(events): #294 server crash on sending mail Mailer respects MAILER_ENABLED flag during ticket creation/comment added. --- src/emitter/events.js | 31 +++++++++++++++++++------------ 1 file changed, 19 insertions(+), 12 deletions(-) diff --git a/src/emitter/events.js b/src/emitter/events.js index a5d778c6a..4386eebe5 100644 --- a/src/emitter/events.js +++ b/src/emitter/events.js @@ -44,15 +44,17 @@ var notifications = require('../notifications') // Load Push Events if (err) return false settingsSchema.getSettingsByName( - ['tps:enable', 'tps:username', 'tps:apikey', 'gen:siteurl', 'beta:email'], + ['tps:enable', 'tps:username', 'tps:apikey', 'gen:siteurl', 'mailer:enable', 'beta:email'], function (err, tpsSettings) { if (err) return false var tpsEnabled = _.head(_.filter(tpsSettings, ['name', 'tps:enable'])) var tpsUsername = _.head(_.filter(tpsSettings, ['name', 'tps:username'])) var tpsApiKey = _.head(_.filter(tpsSettings, ['name', 'tps:apikey'])) var baseUrl = _.head(_.filter(tpsSettings, ['name', 'gen:siteurl'])).value - var betaEnabled = _.head(_.filter(tpsSettings, ['name', 'beta:email'])) + var mailerEnabled = _.head(_.filter(tpsSettings, ['name', 'mailer:enable'])) + mailerEnabled = !mailerEnabled ? false : mailerEnabled.value + var betaEnabled = _.head(_.filter(tpsSettings, ['name', 'beta:email'])) betaEnabled = !betaEnabled ? false : betaEnabled.value if (!tpsEnabled || !tpsUsername || !tpsApiKey) { @@ -118,6 +120,7 @@ var notifications = require('../notifications') // Load Push Events }, function (err) { if (err) return c(err) + if (!mailerEnabled) return c() emails = _.uniq(emails) @@ -165,15 +168,15 @@ var notifications = require('../notifications') // Load Push Events mailer.sendMail(mailOptions, function (err) { if (err) winston.warn('[trudesk:events:ticket:created] - ' + err) + + winston.debug('SentMail') + return c() }) }) .catch(function (err) { winston.warn('[trudesk:events:ticket:created] - ' + err) return c(err) }) - .finally(function () { - return c() - }) }) } ) @@ -389,12 +392,17 @@ var notifications = require('../notifications') // Load Push Events // Goes to client io.sockets.emit('updateComments', ticket) - settingsSchema.getSettingsByName(['tps:enable', 'tps:username', 'tps:apikey'], function (err, tpsSettings) { + settingsSchema.getSettingsByName(['tps:enable', 'tps:username', 'tps:apikey', 'mailer:enable'], function ( + err, + tpsSettings + ) { if (err) return false var tpsEnabled = _.head(_.filter(tpsSettings, ['name', 'tps:enable'])) var tpsUsername = _.head(_.filter(tpsSettings, ['name', 'tps:username'])) var tpsApiKey = _.head(_.filter(tpsSettings), ['name', 'tps:apikey']) + var mailerEnabled = _.head(_.filter(tpsSettings), ['name', 'mailer:enable']) + mailerEnabled = !mailerEnabled ? false : mailerEnabled.value if (!tpsEnabled || !tpsUsername || !tpsApiKey) { tpsEnabled = false @@ -456,6 +464,8 @@ var notifications = require('../notifications') // Load Push Events }, // Send email to subscribed users function (c) { + if (!mailerEnabled) return c() + var mailer = require('../mailer') var emails = [] async.each( @@ -505,18 +515,15 @@ var notifications = require('../notifications') // Load Push Events } mailer.sendMail(mailOptions, function (err) { - if (err) { - winston.warn('[trudesk:events:sendSubscriberEmail] - ' + err) - } + if (err) winston.warn('[trudesk:events:sendSubscriberEmail] - ' + err) + winston.debug('SentMail') + return c() }) }) .catch(function (err) { winston.warn('[trudesk:events:sendSubscriberEmail] - ' + err) return c(err) }) - .finally(function () { - return c() - }) }) } )