refactor(sendmail): updated the smtp per alpla needs
This commit is contained in:
@@ -1,13 +1,13 @@
|
|||||||
import type { Address } from "nodemailer/lib/mailer/index.js";
|
|
||||||
import type { Transporter } from "nodemailer";
|
import type { Transporter } from "nodemailer";
|
||||||
import type SMTPTransport from "nodemailer/lib/smtp-transport/index.js";
|
|
||||||
import type Mail from "nodemailer/lib/mailer/index.js";
|
|
||||||
import os from "os";
|
|
||||||
import nodemailer from "nodemailer";
|
import nodemailer from "nodemailer";
|
||||||
|
import type Mail from "nodemailer/lib/mailer/index.js";
|
||||||
|
import type { Address } from "nodemailer/lib/mailer/index.js";
|
||||||
|
import type SMTPTransport from "nodemailer/lib/smtp-transport/index.js";
|
||||||
|
import hbs from "nodemailer-express-handlebars";
|
||||||
|
import os from "os";
|
||||||
import path from "path";
|
import path from "path";
|
||||||
import { fileURLToPath } from "url";
|
import { fileURLToPath } from "url";
|
||||||
import { promisify } from "util";
|
import { promisify } from "util";
|
||||||
import hbs from "nodemailer-express-handlebars";
|
|
||||||
import { createLogger } from "../../logger/logger.js";
|
import { createLogger } from "../../logger/logger.js";
|
||||||
|
|
||||||
interface HandlebarsMailOptions extends Mail.Options {
|
interface HandlebarsMailOptions extends Mail.Options {
|
||||||
@@ -27,57 +27,59 @@ export const sendEmail = async (data: EmailData): Promise<any> => {
|
|||||||
let transporter: Transporter;
|
let transporter: Transporter;
|
||||||
let fromEmail: string | Address;
|
let fromEmail: string | Address;
|
||||||
|
|
||||||
if (
|
// if (
|
||||||
os.hostname().includes("OLP") &&
|
// os.hostname().includes("OLP") &&
|
||||||
process.env.EMAIL_USER &&
|
// process.env.EMAIL_USER &&
|
||||||
process.env.EMAIL_PASSWORD
|
// process.env.EMAIL_PASSWORD
|
||||||
) {
|
// ) {
|
||||||
transporter = nodemailer.createTransport({
|
// transporter = nodemailer.createTransport({
|
||||||
service: "gmail",
|
// service: "gmail",
|
||||||
auth: {
|
// auth: {
|
||||||
user: process.env.EMAIL_USER,
|
// user: process.env.EMAIL_USER,
|
||||||
pass: process.env.EMAIL_PASSWORD,
|
// pass: process.env.EMAIL_PASSWORD,
|
||||||
},
|
// },
|
||||||
//debug: true,
|
// //debug: true,
|
||||||
});
|
// });
|
||||||
|
|
||||||
// update the from email
|
// // update the from email
|
||||||
fromEmail = process.env.EMAIL_USER;
|
// fromEmail = process.env.EMAIL_USER;
|
||||||
} else {
|
// } else {
|
||||||
// convert to the correct plant token.
|
// // convert to the correct plant token.
|
||||||
|
|
||||||
let host = `${os.hostname().replace("VMS006", "")}-smtp.alpla.net`;
|
//let host = `${os.hostname().replace("VMS006", "")}-smtp.alpla.net`;
|
||||||
|
|
||||||
//const testServers = ["vms036", "VMS036"];
|
//const testServers = ["vms036", "VMS036"];
|
||||||
|
|
||||||
if (os.hostname().includes("VMS036")) {
|
// if (os.hostname().includes("VMS036")) {
|
||||||
host = "USMCD1-smtp.alpla.net";
|
// host = "USMCD1-smtp.alpla.net";
|
||||||
}
|
// }
|
||||||
|
|
||||||
// if (plantToken[0].value === "usiow2") {
|
// if (plantToken[0].value === "usiow2") {
|
||||||
// host = "USIOW1-smtp.alpla.net";
|
// host = "USIOW1-smtp.alpla.net";
|
||||||
// }
|
// }
|
||||||
|
|
||||||
transporter = nodemailer.createTransport({
|
transporter = nodemailer.createTransport({
|
||||||
host: host,
|
host: "smtp.azurecomm.net",
|
||||||
port: 25,
|
port: 587,
|
||||||
rejectUnauthorized: false,
|
//rejectUnauthorized: false,
|
||||||
//secure: false,
|
tls: {
|
||||||
// auth: {
|
minVersion: "TLSv1.2",
|
||||||
// user: "alplaprod",
|
},
|
||||||
// pass: "obelix",
|
auth: {
|
||||||
// },
|
user: "donotreply@mail.alpla.com",
|
||||||
|
pass: process.env.SMTP_PASSWORD,
|
||||||
|
},
|
||||||
debug: true,
|
debug: true,
|
||||||
} as SMTPTransport.Options);
|
} as SMTPTransport.Options);
|
||||||
|
|
||||||
// update the from email
|
// update the from email
|
||||||
fromEmail = `noreply@alpla.com`;
|
fromEmail = `DoNotReply@mail.alpla.com`;
|
||||||
}
|
//}
|
||||||
|
|
||||||
// creating the handlbar options
|
// creating the handlbar options
|
||||||
const viewPath = path.resolve(
|
const viewPath = path.resolve(
|
||||||
path.dirname(fileURLToPath(import.meta.url)),
|
path.dirname(fileURLToPath(import.meta.url)),
|
||||||
"./views/"
|
"./views/",
|
||||||
);
|
);
|
||||||
|
|
||||||
const handlebarOptions = {
|
const handlebarOptions = {
|
||||||
@@ -116,7 +118,7 @@ export const sendEmail = async (data: EmailData): Promise<any> => {
|
|||||||
log.error(
|
log.error(
|
||||||
{ error: err },
|
{ error: err },
|
||||||
|
|
||||||
`Error sending Email to : ${data.email}`
|
`Error sending Email to : ${data.email}`,
|
||||||
);
|
);
|
||||||
return { success: false, message: "Error sending email.", error: err };
|
return { success: false, message: "Error sending email.", error: err };
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -67,34 +67,34 @@ export const sendEmail = async (data: any): Promise<any> => {
|
|||||||
fromEmail = process.env.EMAIL_USER;
|
fromEmail = process.env.EMAIL_USER;
|
||||||
} else {
|
} else {
|
||||||
// convert to the correct plant token.
|
// convert to the correct plant token.
|
||||||
const plantToken = settingData.filter((s) => s.name === "plantToken");
|
//const plantToken = settingData.filter((s) => s.name === "plantToken");
|
||||||
|
|
||||||
let host = `${plantToken[0].value}-smtp.alpla.net`;
|
// let host = `${plantToken[0].value}-smtp.alpla.net`;
|
||||||
|
|
||||||
const testServers = ["test1", "test2", "test3"];
|
// const testServers = ["test1", "test2", "test3"];
|
||||||
|
|
||||||
if (testServers.includes(plantToken[0].value)) {
|
// if (testServers.includes(plantToken[0].value)) {
|
||||||
host = "USMCD1-smtp.alpla.net";
|
// host = "USMCD1-smtp.alpla.net";
|
||||||
}
|
// }
|
||||||
|
|
||||||
if (plantToken[0].value === "usiow2") {
|
// if (plantToken[0].value === "usiow2") {
|
||||||
host = "USIOW1-smtp.alpla.net";
|
// host = "USIOW1-smtp.alpla.net";
|
||||||
}
|
// }
|
||||||
|
|
||||||
transporter = nodemailer.createTransport({
|
transporter = nodemailer.createTransport({
|
||||||
host: host,
|
host: "smtp.azurecomm.net",
|
||||||
port: 25,
|
port: 587,
|
||||||
rejectUnauthorized: false,
|
//rejectUnauthorized: false,
|
||||||
//secure: false,
|
tls: {
|
||||||
// auth: {
|
minVersion: "TLSv1.2",
|
||||||
// user: "alplaprod",
|
},
|
||||||
// pass: "obelix",
|
auth: {
|
||||||
// },
|
user: "donotreply@mail.alpla.com",
|
||||||
|
pass: process.env.SMTP_PASSWORD,
|
||||||
|
},
|
||||||
debug: true,
|
debug: true,
|
||||||
} as SMTPTransport.Options);
|
});
|
||||||
|
fromEmail = `DoNotReply@mail.alpla.com`;
|
||||||
// update the from email
|
|
||||||
fromEmail = `donotreply@alpla.com`;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// creating the handlbar options
|
// creating the handlbar options
|
||||||
|
|||||||
Reference in New Issue
Block a user