mirror of
https://github.com/danny-avila/LibreChat.git
synced 2025-09-22 08:12:00 +02:00

* fix: attempt to catch more errors, especially when generation started * fix: pass the right properties to getResponseSender * chore: Update .eslintrc.js and fix sendEmail.js linting errors
74 lines
2.3 KiB
JavaScript
74 lines
2.3 KiB
JavaScript
const nodemailer = require('nodemailer');
|
|
const handlebars = require('handlebars');
|
|
const fs = require('fs');
|
|
const path = require('path');
|
|
|
|
const sendEmail = async (email, subject, payload, template) => {
|
|
try {
|
|
const transporterOptions = {
|
|
// Use STARTTLS by default instead of obligatory TLS
|
|
secure: process.env.EMAIL_ENCRYPTION === 'tls',
|
|
// If explicit STARTTLS is set, require it when connecting
|
|
requireTls: process.env.EMAIL_ENCRYPTION === 'starttls',
|
|
tls: {
|
|
// Whether to accept unsigned certificates
|
|
rejectUnauthorized: process.env.EMAIL_ALLOW_SELFSIGNED === 'true',
|
|
},
|
|
auth: {
|
|
user: process.env.EMAIL_USERNAME,
|
|
pass: process.env.EMAIL_PASSWORD,
|
|
},
|
|
};
|
|
|
|
if (process.env.EMAIL_ENCRYPTION_HOSTNAME) {
|
|
// Check the certificate against this name explicitly
|
|
transporterOptions.tls.servername = process.env.EMAIL_ENCRYPTION_HOSTNAME;
|
|
}
|
|
|
|
// Mailer service definition has precedence
|
|
if (process.env.EMAIL_SERVICE) {
|
|
transporterOptions.service = process.env.EMAIL_SERVICE;
|
|
} else {
|
|
transporterOptions.host = process.env.EMAIL_HOST;
|
|
transporterOptions.port = process.env.EMAIL_PORT ?? 25;
|
|
}
|
|
|
|
const transporter = nodemailer.createTransport(transporterOptions);
|
|
|
|
const source = fs.readFileSync(path.join(__dirname, 'emails', template), 'utf8');
|
|
const compiledTemplate = handlebars.compile(source);
|
|
const options = () => {
|
|
return {
|
|
// Header address should contain name-addr
|
|
from:
|
|
`"${process.env.EMAIL_FROM_NAME || process.env.APP_TITLE}"` +
|
|
`<${process.env.EMAIL_FROM}>`,
|
|
to: `"${payload.name}" <${email}>`,
|
|
envelope: {
|
|
// Envelope from should contain addr-spec
|
|
// Mistake in the Nodemailer documentation?
|
|
from: process.env.EMAIL_FROM,
|
|
to: email,
|
|
},
|
|
subject: subject,
|
|
html: compiledTemplate(payload),
|
|
};
|
|
};
|
|
|
|
// Send email
|
|
transporter.sendMail(options(), (error, info) => {
|
|
if (error) {
|
|
console.log(error);
|
|
return error;
|
|
} else {
|
|
console.log(info);
|
|
return info;
|
|
}
|
|
});
|
|
} catch (error) {
|
|
console.log(error);
|
|
return error;
|
|
}
|
|
};
|
|
|
|
module.exports = sendEmail;
|