Email.js 1.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354
  1. const nodemailer = require('nodemailer')
  2. const config = require('../../config.json')
  3. const path = require('path')
  4. const Logger = require('../../lib/Logger')
  5. const logger = new Logger(path.join(__dirname, '../../logs/Email.log'), 'INFO')
  6. /**
  7. * 尝试用多个邮箱配置发送邮件
  8. * @param {string} email - 收件人邮箱
  9. * @param {string} subject - 邮件主题
  10. * @param {string} content - 邮件内容(支持 HTML)
  11. */
  12. async function sendEmail(email, subject, content) {
  13. return new Promise(async (resolve, reject) => {
  14. const mail = {
  15. to: email,
  16. subject: subject,
  17. html: content
  18. }
  19. // 遍历所有邮箱配置
  20. for (let i = 0; i < config.email.length; i++) {
  21. const currentConfig = config.email[i];
  22. const transporter = nodemailer.createTransport({
  23. host: currentConfig.host,
  24. port: currentConfig.port,
  25. auth: {
  26. user: currentConfig.user,
  27. pass: currentConfig.password
  28. }
  29. })
  30. mail.from = currentConfig.from
  31. try {
  32. await transporter.sendMail(mail)
  33. logger.info(`邮件发送成功,使用账号: ${currentConfig.user}`)
  34. return resolve()
  35. } catch (error) {
  36. logger.error(`邮件发送失败 (${currentConfig.user}),错误:`, error.stack)
  37. if (i === config.email.length - 1) {
  38. // 最后一个配置也失败了
  39. logger.error(`邮件发送失败,所有邮箱配置均不可用`)
  40. return
  41. }
  42. // 否则继续下一个配置
  43. }
  44. }
  45. })
  46. }
  47. module.exports = sendEmail