use Taskmanager to send email with correct locale
This commit is contained in:
@@ -209,7 +209,7 @@ const userController = {
|
|||||||
if (!req.body.password) { delete req.body.password }
|
if (!req.body.password) { delete req.body.password }
|
||||||
|
|
||||||
if (!user.is_active && req.body.is_active && user.recover_code) {
|
if (!user.is_active && req.body.is_active && user.recover_code) {
|
||||||
mail.send(user.email, 'confirm', { user, config })
|
mail.send(user.email, 'confirm', { user, config }, req.settings.locale)
|
||||||
}
|
}
|
||||||
|
|
||||||
await user.update(req.body)
|
await user.update(req.body)
|
||||||
@@ -230,20 +230,10 @@ const userController = {
|
|||||||
req.body.recover_code = crypto.randomBytes(16).toString('hex')
|
req.body.recover_code = crypto.randomBytes(16).toString('hex')
|
||||||
debug('Register user ', req.body.email)
|
debug('Register user ', req.body.email)
|
||||||
const user = await User.create(req.body)
|
const user = await User.create(req.body)
|
||||||
try {
|
debug(`Sending registration email to ${user.email}`)
|
||||||
debug(`Sending registration email to ${user.email}`)
|
mail.send(user.email, 'register', { user, config }, req.settings.locale)
|
||||||
mail.send(user.email, 'register', { user, config })
|
mail.send(config.admin_email, 'admin_register', { user, config }, req.settings.locale)
|
||||||
mail.send(config.admin_email, 'admin_register', { user, config })
|
res.sendStatus(200)
|
||||||
} catch (e) {
|
|
||||||
return res.status(400).json(e)
|
|
||||||
}
|
|
||||||
const payload = {
|
|
||||||
id: user.id,
|
|
||||||
email: user.email,
|
|
||||||
scope: [user.is_admin ? 'admin' : 'user']
|
|
||||||
}
|
|
||||||
const token = jwt.sign(payload, config.secret)
|
|
||||||
res.json({ token, user })
|
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
res.status(404).json(e)
|
res.status(404).json(e)
|
||||||
}
|
}
|
||||||
@@ -254,7 +244,7 @@ const userController = {
|
|||||||
req.body.is_active = true
|
req.body.is_active = true
|
||||||
req.body.recover_code = crypto.randomBytes(16).toString('hex')
|
req.body.recover_code = crypto.randomBytes(16).toString('hex')
|
||||||
const user = await User.create(req.body)
|
const user = await User.create(req.body)
|
||||||
mail.send(user.email, 'user_confirm', { user, config })
|
mail.send(user.email, 'user_confirm', { user, config }, req.settings.locale)
|
||||||
res.json(user)
|
res.json(user)
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
res.status(404).json(e)
|
res.status(404).json(e)
|
||||||
|
|||||||
@@ -4,12 +4,20 @@ const moment = require('moment')
|
|||||||
const config = require('config')
|
const config = require('config')
|
||||||
const settings = require('./controller/settings')
|
const settings = require('./controller/settings')
|
||||||
const debug = require('debug')('email')
|
const debug = require('debug')('email')
|
||||||
|
const { Task, TaskManager } = require('../taskManager')
|
||||||
// TOFIX
|
|
||||||
moment.locale('it')
|
|
||||||
|
|
||||||
const mail = {
|
const mail = {
|
||||||
send (addresses, template, locals) {
|
send (addresses, template, locals, locale) {
|
||||||
|
const task = new Task({
|
||||||
|
name: 'MAIL',
|
||||||
|
removable: true,
|
||||||
|
method: mail._send,
|
||||||
|
args: [addresses, template, locals, locale]
|
||||||
|
})
|
||||||
|
TaskManager.add(task)
|
||||||
|
},
|
||||||
|
|
||||||
|
_send (addresses, template, locales, locale) {
|
||||||
debug(`Send ${template} email to ${addresses}`)
|
debug(`Send ${template} email to ${addresses}`)
|
||||||
const email = new Email({
|
const email = new Email({
|
||||||
views: { root: path.join(__dirname, '..', 'emails') },
|
views: { root: path.join(__dirname, '..', 'emails') },
|
||||||
@@ -43,8 +51,8 @@ const mail = {
|
|||||||
bcc: config.admin_email
|
bcc: config.admin_email
|
||||||
},
|
},
|
||||||
locals: {
|
locals: {
|
||||||
...locals,
|
...locales,
|
||||||
locale: 'it', // TOFIX
|
locale,
|
||||||
config: { title: config.title, baseurl: config.baseurl, description: config.description },
|
config: { title: config.title, baseurl: config.baseurl, description: config.description },
|
||||||
datetime: datetime => moment.unix(datetime).format('ddd, D MMMM HH:mm')
|
datetime: datetime => moment.unix(datetime).format('ddd, D MMMM HH:mm')
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user