gancio-upstream/server/api/mail.js

76 lines
2.3 KiB
JavaScript
Raw Normal View History

2019-04-03 00:25:12 +02:00
const Email = require('email-templates')
const path = require('path')
2020-11-17 00:34:56 +01:00
const moment = require('dayjs')
2021-10-18 15:46:38 +02:00
const settingsController = require('./controller/settings')
2021-03-05 14:17:10 +01:00
const log = require('../log')
const { Task, TaskManager } = require('../taskManager')
2020-02-20 18:37:10 +01:00
const locales = require('../../locales')
2019-09-18 12:55:33 +02:00
2019-04-03 00:25:12 +02:00
const mail = {
2022-02-26 21:27:40 +01:00
send (addresses, template, locals, locale) {
locale = locale || settingsController.settings.instance_locale
if (process.env.NODE_ENV === 'production' && (!settingsController.settings.admin_email || !settingsController.settings.smtp)) {
log.error(`Cannot send any email: SMTP Email configuration not completed!`)
return
}
2021-10-20 14:14:26 +02:00
log.debug(`Enqueue new email ${template} ${locale}`)
const task = new Task({
name: 'MAIL',
method: mail._send,
args: [addresses, template, locals, locale]
})
TaskManager.add(task)
},
2022-02-26 21:27:40 +01:00
_send (addresses, template, locals, locale) {
locale = locale || settingsController.settings.instance_locale
2021-10-18 15:46:38 +02:00
const settings = settingsController.settings
2021-04-28 12:44:26 +02:00
log.info(`Send ${template} email to ${addresses} with locale ${locale}`)
2019-04-03 00:25:12 +02:00
const email = new Email({
2019-05-30 12:04:14 +02:00
views: { root: path.join(__dirname, '..', 'emails') },
2020-02-10 12:00:49 +01:00
htmlToText: true,
2019-04-03 00:25:12 +02:00
juice: true,
juiceResources: {
preserveImportant: true,
webResources: {
2019-05-30 12:04:14 +02:00
relativeTo: path.join(__dirname, '..', 'emails')
2019-04-03 00:25:12 +02:00
}
},
message: {
2021-09-27 10:42:17 +02:00
from: `📅 ${settings.title} <${settings.admin_email}>`
2019-04-03 00:25:12 +02:00
},
send: true,
i18n: {
2019-05-30 12:04:14 +02:00
directory: path.join(__dirname, '..', '..', 'locales', 'email'),
objectNotation: true,
2019-07-03 16:33:03 +02:00
syncFiles: false,
updateFiles: false,
2021-09-27 10:42:17 +02:00
defaultLocale: settings.instance_locale || 'en',
2020-02-20 18:37:10 +01:00
locale,
locales: Object.keys(locales)
2019-04-03 00:25:12 +02:00
},
transport: settings.smtp || {}
2019-04-03 00:25:12 +02:00
})
2020-02-20 18:37:10 +01:00
2019-06-08 13:18:47 +02:00
const msg = {
2019-04-03 00:25:12 +02:00
template,
message: {
2021-10-18 15:46:38 +02:00
to: addresses
2019-04-03 00:25:12 +02:00
},
locals: {
2020-02-20 18:37:10 +01:00
...locals,
locale,
2021-09-27 10:42:17 +02:00
config: { title: settings.title, baseurl: settings.baseurl, description: settings.description, admin_email: settings.admin_email },
2020-02-20 18:37:10 +01:00
datetime: datetime => moment.unix(datetime).locale(locale).format('ddd, D MMMM HH:mm')
2019-04-03 00:25:12 +02:00
}
2019-06-08 13:18:47 +02:00
}
return email.send(msg)
.catch(e => {
2021-07-08 20:41:56 +02:00
log.error('[MAIL]', e)
2021-10-18 15:46:38 +02:00
throw e
2019-06-08 13:18:47 +02:00
})
2019-04-03 00:25:12 +02:00
}
}
module.exports = mail