Added catch block to main route
This commit is contained in:
@@ -17,45 +17,50 @@ router.post("/send", async (req, res) => {
|
|||||||
});
|
});
|
||||||
|
|
||||||
router.post("/template/:template", async (req, res) => {
|
router.post("/template/:template", async (req, res) => {
|
||||||
const { template } = req.params;
|
try {
|
||||||
const { to, data } = req.body;
|
const { template } = req.params;
|
||||||
if (!to || !data) {
|
const { to, data } = req.body;
|
||||||
res.status(400).json({ error: "Missing required fields" });
|
if (!to || !data) {
|
||||||
|
res.status(400).json({ error: "Missing required fields" });
|
||||||
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!data.user) {
|
|
||||||
res.status(400).json({ error: "Missing user data" });
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
console.log("template", template);
|
|
||||||
switch (template) {
|
|
||||||
case "password-change":
|
|
||||||
if (!data.password) {
|
|
||||||
res.status(400).json({ error: "Missing password data" });
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
await sendPasswordChanged(to, data.user, data.password);
|
|
||||||
break;
|
|
||||||
case "course-completed":
|
|
||||||
if (!data.event) {
|
|
||||||
res.status(400).json({ error: "Missing event data" });
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
await sendCourseCompletedEmail(to, data.user, data.event);
|
|
||||||
break;
|
|
||||||
case "email-verification":
|
|
||||||
if (!data.code) {
|
|
||||||
res.status(400).json({ error: "Missing verification code" });
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
await sendEmailVerification(to, data.user, data.code);
|
|
||||||
default:
|
|
||||||
res.status(400).json({ error: "Invalid template" });
|
|
||||||
return;
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!data.user) {
|
||||||
|
res.status(400).json({ error: "Missing user data" });
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
console.log("template", template);
|
||||||
|
switch (template) {
|
||||||
|
case "password-change":
|
||||||
|
if (!data.password) {
|
||||||
|
res.status(400).json({ error: "Missing password data" });
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
await sendPasswordChanged(to, data.user, data.password);
|
||||||
|
break;
|
||||||
|
case "course-completed":
|
||||||
|
if (!data.event) {
|
||||||
|
res.status(400).json({ error: "Missing event data" });
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
await sendCourseCompletedEmail(to, data.user, data.event);
|
||||||
|
break;
|
||||||
|
case "email-verification":
|
||||||
|
if (!data.code) {
|
||||||
|
res.status(400).json({ error: "Missing verification code" });
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
await sendEmailVerification(to, data.user, data.code);
|
||||||
|
default:
|
||||||
|
res.status(400).json({ error: "Invalid template" });
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
res.status(200).json({ message: "Email sent successfully" });
|
||||||
|
} catch (error) {
|
||||||
|
console.error("Error sending email:", error);
|
||||||
|
res.status(500).json({ error: "Failed to send email" });
|
||||||
}
|
}
|
||||||
res.status(200).json({ message: "Email sent successfully" });
|
|
||||||
});
|
});
|
||||||
|
|
||||||
export default router;
|
export default router;
|
||||||
|
|||||||
Reference in New Issue
Block a user