Ghost/core/server/services/invites/invites.js
Sam Lord 76f06fae3c
Revert "Revert "Extract logging from DI patterns, only use @tryghost/logging package"" (#13884)
This reverts commit fa8c3ebe99.

Reverting the revert, which will allow us to fully switch to @tryghost/logging v2.
2021-12-14 11:22:39 +00:00

92 lines
3.2 KiB
JavaScript

const security = require('@tryghost/security');
const tpl = require('@tryghost/tpl');
const logging = require('@tryghost/logging');
const messages = {
invitedByName: '{invitedByName} has invited you to join {blogName}',
errorSendingEmail: {
error: 'Error sending email: {message}',
help: 'Please check your email settings and resend the invitation.'
}
};
class Invites {
constructor({settingsCache, mailService, urlUtils}) {
this.settingsCache = settingsCache;
this.mailService = mailService;
this.urlUtils = urlUtils;
}
add({api, InviteModel, invites, options, user}) {
let invite;
let emailData;
return InviteModel.findOne({email: invites[0].email}, options)
.then((existingInvite) => {
if (!existingInvite) {
return;
}
return existingInvite.destroy(options);
})
.then(() => {
return InviteModel.add(invites[0], options);
})
.then((createdInvite) => {
invite = createdInvite;
const adminUrl = this.urlUtils.urlFor('admin', true);
emailData = {
blogName: this.settingsCache.get('title'),
invitedByName: user.name,
invitedByEmail: user.email,
resetLink: this.urlUtils.urlJoin(adminUrl, 'signup', security.url.encodeBase64(invite.get('token')), '/'),
recipientEmail: invite.get('email')
};
return this.mailService.utils.generateContent({data: emailData, template: 'invite-user'});
})
.then((emailContent) => {
const payload = {
mail: [{
message: {
to: invite.get('email'),
subject: tpl(messages.invitedByName, {
invitedByName: emailData.invitedByName,
blogName: emailData.blogName
}),
html: emailContent.html,
text: emailContent.text
},
options: {}
}]
};
return api.mail.send(payload, {context: {internal: true}});
})
.then(() => {
return InviteModel.edit({
status: 'sent'
}, Object.assign({id: invite.id}, options));
})
.then((editedInvite) => {
return editedInvite;
})
.catch((err) => {
if (err && err.errorType === 'EmailError') {
const errorMessage = tpl(messages.errorSendingEmail.error, {
message: err.message
});
const helpText = tpl(messages.errorSendingEmail.help);
err.message = `${errorMessage} ${helpText}`;
logging.warn(err.message);
}
return Promise.reject(err);
});
}
}
module.exports = Invites;