gancio-upstream/server/api/mail.js

82 lines
2.5 KiB
JavaScript
Raw Normal View History

2019-04-03 00:25:12 +02:00
const Email = require('email-templates')
const path = require('path')
const { DateTime } = require('luxon')
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 = {
send (addresses, template, locals, locale, bcc) {
2022-02-26 21:27:40 +01:00
locale = locale || settingsController.settings.instance_locale
2022-06-23 16:32:42 +02:00
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, bcc]
})
TaskManager.add(task)
},
_send (addresses, template, locals, locale, bcc=false) {
2022-02-26 21:27:40 +01:00
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: {
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,
retryInDefaultLocale: true,
2019-07-03 16:33:03 +02:00
updateFiles: false,
defaultLocale: 'en',
locale: settings.instance_locale,
2020-02-20 18:37:10 +01:00
locales: Object.keys(locales)
2019-04-03 00:25:12 +02:00
},
2023-12-05 18:28:59 +01:00
transport: settings.smtp || {}
2019-04-03 00:25:12 +02:00
})
2020-02-20 18:37:10 +01:00
const opt = {
zone: settings.instance_timezone,
locale
}
2019-06-08 13:18:47 +02:00
const msg = {
2019-04-03 00:25:12 +02:00
template,
message: {
[bcc ? 'bcc' : '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 },
datetime: timestamp => DateTime.fromSeconds(timestamp, opt).toFormat('EEEE, 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