Я запускаю приложение стека MERN, которое отправляет электронную почту с использованием Nodemailer и службы Gmail. Уведомления по электронной почте отправляются во время вызовов API. Система работает в течение полутора лет, и у них никогда не было проблем с отправкой электронной почты. Однако по состоянию на вчера я пытался диагностировать эту проблему. Вот сообщение об ошибке:
Transporter set up
[0] Error: invalid_grant
[0] at D:\Dev\Projects\pro-optics\pro-optics\node_modules\nodemailer\lib\xoauth2\index.js:259:33
[0] at PassThrough.<anonymous> (D:\Dev\Projects\pro-optics\pro-optics\node_modules\nodemailer\lib\xoauth2\index.js:328:20)
[0] at Object.onceWrapper (events.js:312:28)
[0] at PassThrough.emit (events.js:223:5)
[0] at endReadableNT (_stream_readable.js:1185:12)
[0] at processTicksAndRejections (internal/process/task_queues.js:81:21) {
[0] code: 'EAUTH',
[0] command: 'AUTH XOAUTH2'
[0] \}
Вот код, связанный с nodemailer и настройкой клиента и транспортера:
const nodemailer = require('nodemailer');
const { google } = require('googleapis');
// Setting up OAuth2
const OAuth2 = google.auth.OAuth2;
const oauth2Client = new OAuth2(
clientId,
clientSecret,
'https://developers.google.com/oauthplayground'
);
oauth2Client.setCredentials({
refresh_token: refreshToken
});
let accessToken;
oauth2Client
.refreshAccessToken()
.then(tokens => (accessToken = tokens.credentials.access_token));
let transporter = nodemailer.createTransport({
service: 'gmail',
auth: {
type: 'OAuth2',
user,
clientId,
clientSecret,
refreshToken,
accessToken
},
tls: {
rejectUnauthorized: false
}
});
Вот код для отправки почты внутри вызова API :
// Prepare email
const emailContent = getTicketTemplate(ticket, true, true);
console.log('Transporter set up');
let mailOptions = {
from: `"Pro Optics" <${user}>`,
to: recipients,
subject: `[OFFICIAL] Ticket Report: INTV ${ticket._id} ✔`,
html: emailContent
};
transporter
.sendMail(mailOptions)
.then(info => console.log(info))
.catch(error => console.log(error));
Я думаю, что это как-то связано с тем, что Google отклоняет токены доступа, но я не уверен, почему это происходит так случайно.
Это критически важное приложение, и я был бы признателен любая помощь, которую я могу получить в этом.