Как устранить ошибку «invalid_grant» с помощью nodemailer и службы Gmail? - PullRequest
0 голосов
/ 11 марта 2020

Я запускаю приложение стека 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 отклоняет токены доступа, но я не уверен, почему это происходит так случайно.

Это критически важное приложение, и я был бы признателен любая помощь, которую я могу получить в этом.

...