-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathapp.js
More file actions
108 lines (95 loc) · 3.14 KB
/
app.js
File metadata and controls
108 lines (95 loc) · 3.14 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
//Importing modules or libraries
const path = require("path");
const nodeEnv = process.env.NODE_ENV || "development";
require("dotenv").config({
path: path.resolve(process.cwd(), `.env.${nodeEnv}`),
});
const express = require("express");
const cookieParser = require("cookie-parser");
const app = express();
const connectDB = require("./utils/mongoose-connection");
const ownerRouter = require("./routes/ownerRouter");
const productRouter = require("./routes/productRouter");
const userRouter = require("./routes/userRouter");
const orderRouter = require("./routes/orderRouter");
const indexRouter = require("./routes/index");
const chatRoute = require("./routes/chatBot.js");
const session = require("express-session");
const methodOverride = require("method-override");
const MongoStore = require("connect-mongo");
const logger = require("./utils/logger.js");
const startSelfPing = require("./utils/selfPing.js");
const cors = require("cors");
const PORT = process.env.PORT || 5000;
// ---------------- DATABASE CONNECTION ----------------
connectDB();
//Session - Cookies Setup
app.use(
session({
secret: process.env.EXPRESS_SESSION_SECRET,
resave: false,
saveUninitialized: false,
cookie: {
httpOnly: true,
secure: process.env.NODE_ENV === "production",
sameSite: process.env.NODE_ENV === "production" ? "None" : "Lax",
maxAge: 1000 * 60 * 60, // 1 hour
},
store: MongoStore.create({
mongoUrl: process.env.MONGODB_URI,
ttl: 14 * 24 * 60 * 60, // 14 days
}),
})
);
logger.info("Session middleware configured");
// ---------------- MIDDLEWARE ----------------
app.use(express.json());
app.use(express.urlencoded({ extended: true }));
app.use(cookieParser());
app.use(methodOverride("_method"));
logger.info("Express middlewares applied");
// ---------------- CORS SETUP ----------------
const allowedOrigins = [
"http://localhost:5173",
"https://scatch-mart.netlify.app",
"https://hoppscotch.io",
process.env.CLIENT_URL,
];
app.use(
cors({
origin: (origin, callback) => {
if (!origin || allowedOrigins.includes(origin)) {
callback(null, true);
} else {
const msg = `Blocked CORS request from origin: ${origin}`;
logger.error(msg);
callback(new Error(msg));
}
},
credentials: true,
})
);
logger.info("CORS configured");
// ---------------- API ROUTES ----------------
app.use("/api/owners", ownerRouter);
app.use("/api/users", userRouter);
app.use("/api/products", productRouter);
app.use("/api/orders", orderRouter);
app.use("/", indexRouter);
app.use("/api", chatRoute);
logger.info("API routes configured");
// ---------------- BASE ROUTE ----------------
app.get("/", (req, res) => {
logger.info("Base route visited");
res.send("Please visit:- /api/scatch-products");
});
// ---------------- FRONTEND LOGS ENDPOINT (COMMENTED) ----------------
// app.post("/api/frontend-logs", (req, res) => {
// logger.info("Frontend log", { body: req.body });
// res.sendStatus(200);
// });
// ---------------- SERVER START ----------------
app.listen(PORT, () => {
logger.info(`Server started on port ${PORT} 📡🚀🚀🚀`);
startSelfPing();
});