mail.js 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  1. const nodemailer = require("nodemailer");
  2. const path = require("path");
  3. const fs = require("fs");
  4. const { resetMailText, verifyMailText, changeEmailText } = require("./text");
  5. const { CustomError } = require("../utils");
  6. const env = require("../env");
  7. const mailConfig = {
  8. host: env.MAIL_HOST,
  9. port: env.MAIL_PORT,
  10. secure: env.MAIL_SECURE,
  11. auth: env.MAIL_USER
  12. ? {
  13. user: env.MAIL_USER,
  14. pass: env.MAIL_PASSWORD
  15. }
  16. : undefined
  17. };
  18. const transporter = nodemailer.createTransport(mailConfig);
  19. // Read email templates
  20. const resetEmailTemplatePath = path.join(__dirname, "template-reset.html");
  21. const verifyEmailTemplatePath = path.join(__dirname, "template-verify.html");
  22. const changeEmailTemplatePath = path.join(
  23. __dirname,
  24. "template-change-email.html"
  25. );
  26. const resetEmailTemplate = fs
  27. .readFileSync(resetEmailTemplatePath, { encoding: "utf-8" })
  28. .replace(/{{domain}}/gm, env.DEFAULT_DOMAIN)
  29. .replace(/{{site_name}}/gm, env.SITE_NAME);
  30. const verifyEmailTemplate = fs
  31. .readFileSync(verifyEmailTemplatePath, { encoding: "utf-8" })
  32. .replace(/{{domain}}/gm, env.DEFAULT_DOMAIN)
  33. .replace(/{{site_name}}/gm, env.SITE_NAME);
  34. const changeEmailTemplate = fs
  35. .readFileSync(changeEmailTemplatePath, { encoding: "utf-8" })
  36. .replace(/{{domain}}/gm, env.DEFAULT_DOMAIN)
  37. .replace(/{{site_name}}/gm, env.SITE_NAME);
  38. async function verification(user) {
  39. const mail = await transporter.sendMail({
  40. from: env.MAIL_FROM || env.MAIL_USER,
  41. to: user.email,
  42. subject: "Verify your account",
  43. text: verifyMailText
  44. .replace(/{{verification}}/gim, user.verification_token)
  45. .replace(/{{domain}}/gm, env.DEFAULT_DOMAIN)
  46. .replace(/{{site_name}}/gm, env.SITE_NAME),
  47. html: verifyEmailTemplate
  48. .replace(/{{verification}}/gim, user.verification_token)
  49. .replace(/{{domain}}/gm, env.DEFAULT_DOMAIN)
  50. .replace(/{{site_name}}/gm, env.SITE_NAME)
  51. });
  52. if (!mail.accepted.length) {
  53. throw new CustomError("Couldn't send verification email. Try again later.");
  54. }
  55. }
  56. async function changeEmail(user) {
  57. const mail = await transporter.sendMail({
  58. from: env.MAIL_FROM || env.MAIL_USER,
  59. to: user.change_email_address,
  60. subject: "Verify your new email address",
  61. text: changeEmailText
  62. .replace(/{{verification}}/gim, user.change_email_token)
  63. .replace(/{{domain}}/gm, env.DEFAULT_DOMAIN)
  64. .replace(/{{site_name}}/gm, env.SITE_NAME),
  65. html: changeEmailTemplate
  66. .replace(/{{verification}}/gim, user.change_email_token)
  67. .replace(/{{domain}}/gm, env.DEFAULT_DOMAIN)
  68. .replace(/{{site_name}}/gm, env.SITE_NAME)
  69. });
  70. if (!mail.accepted.length) {
  71. throw new CustomError("Couldn't send verification email. Try again later.");
  72. }
  73. }
  74. async function resetPasswordToken(user) {
  75. const mail = await transporter.sendMail({
  76. from: env.MAIL_FROM || env.MAIL_USER,
  77. to: user.email,
  78. subject: "Reset your password",
  79. text: resetMailText
  80. .replace(/{{resetpassword}}/gm, user.reset_password_token)
  81. .replace(/{{domain}}/gm, env.DEFAULT_DOMAIN),
  82. html: resetEmailTemplate
  83. .replace(/{{resetpassword}}/gm, user.reset_password_token)
  84. .replace(/{{domain}}/gm, env.DEFAULT_DOMAIN)
  85. });
  86. if (!mail.accepted.length) {
  87. throw new CustomError(
  88. "Couldn't send reset password email. Try again later."
  89. );
  90. }
  91. }
  92. module.exports = {
  93. changeEmail,
  94. verification,
  95. resetPasswordToken,
  96. }