From 672c34d6bcca2216bbc8db34b10fe542ec550d1d Mon Sep 17 00:00:00 2001 From: Manas Date: Sat, 14 Dec 2024 21:24:59 +0530 Subject: [PATCH] Fix CORS --- Website/Backend/index.ts | 24 ++++++++++++++------ Website/Frontend/app/ui/universal/Navbar.tsx | 2 -- 2 files changed, 17 insertions(+), 9 deletions(-) diff --git a/Website/Backend/index.ts b/Website/Backend/index.ts index a78303f..f74f3dd 100644 --- a/Website/Backend/index.ts +++ b/Website/Backend/index.ts @@ -21,13 +21,28 @@ const app: Express = express(); const PORT: string = process.env.PORT || "5000"; // CORS configuration: Manually handle origins and preflight requests -const allowedOrigins = ["https://certimailer.xyz"]; +const allowedOrigins = [ + "https://certimailer.xyz", + "https://www.certimailer.xyz", +]; +const allowedOriginsHitPoint = [ + "https://certimailer.xyz", + "https://www.certimailer.xyz", + "https://cron-job.org", + "https://www.cron-job.org", + "http://localhost:3000", +]; const allowedMethods = ["GET", "POST", "PUT", "DELETE"]; const allowedHeaders = ["Content-Type", "Authorization"]; app.use((req: Request, res: Response, next) => { const origin = req.headers.origin as string | undefined; + if (req.url === "/") { + if (origin && allowedOriginsHitPoint.includes(origin)) + return res.status(200).json({ message: "200 OK Hello guys :)" }).end(); + } + if (origin && allowedOrigins.includes(origin)) { // Allow the origin if it's in the allowedOrigins list res.setHeader("Access-Control-Allow-Origin", origin); @@ -39,7 +54,7 @@ app.use((req: Request, res: Response, next) => { if (req.method === "OPTIONS") { return res.status(200).end(); } - } else { + } else { // If origin doesn't match, send a 403 error return res.status(403).json({ message: "Access denied: Not allowed" }); } @@ -58,11 +73,6 @@ app.use("/api/send-email", sendEmailsRoute); app.use("/user", userRoute); app.use("/api/utils", utilsRoute); -// Landing endpoint -app.get("/", (req: Request, res: Response) => { - res.status(200).json({ message: "200 OK Hello guys :)" }); -}); - // Start server app.listen(PORT, () => { console.log(`Server active at port: ${PORT}`); diff --git a/Website/Frontend/app/ui/universal/Navbar.tsx b/Website/Frontend/app/ui/universal/Navbar.tsx index afc77f1..ac55538 100644 --- a/Website/Frontend/app/ui/universal/Navbar.tsx +++ b/Website/Frontend/app/ui/universal/Navbar.tsx @@ -31,11 +31,9 @@ export function Navbar(): JSX.Element { hasMounted.current = true; setMounted(true); if (theme === "system") { - console.log(theme); setWebsiteTheme("light"); setTheme("light"); } else if (theme === "dark" || theme === "light") { - console.log(theme); setWebsiteTheme(theme); // Set the website theme based on next-themes } }