-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathserver.js
More file actions
57 lines (51 loc) · 1.92 KB
/
server.js
File metadata and controls
57 lines (51 loc) · 1.92 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
require("dotenv").config();
// Packages
const express = require("express");
const cookieParser = require("cookie-parser");
const csrf = require("csurf");
// Init
const app = express();
const PORT = process.env.PORT;
/* A determiner variable that will help the server to know where the API requests will come from */
const isProduction = process.env.PRODUCTION || false;
const origin = isProduction
? "https://co-merce.netlify.app"
: "http://localhost:3000";
// Database
require("./config/database");
// Middlewares
app.use(cookieParser());
/*
* Applying this middleware sets cookie in res with the cookie, on the first request and updates it once the token expires,
* token which will be use to verify every request (GET, POST, etc.) made to the server.
*/
app.use(csrf({ cookie: true }));
app.set("trust proxy", 1); // ref: https://stackoverflow.com/questions/66503751/cross-domain-session-cookie-express-api-on-heroku-react-app-on-netlify
app.use(express.json());
app.use((req, res, next) => {
res.setHeader("Access-Control-Allow-Origin", origin);
res.setHeader("Access-Control-Allow-Methods", "GET, POST, PUT, PATCH");
res.setHeader(
"Access-Control-Allow-Headers",
"Origin, X-Requested-With, Content-Type, Accept"
);
res.setHeader("Access-Control-Allow-Credentials", true);
next();
});
// Route Middleware
app.use("/api", require("./routes/index"));
app.use("/api/user", require("./routes/user"));
app.use("/api/product", require("./routes/product"));
app.use("/api/cart", require("./routes/cart"));
app.use("/api/order", require("./routes/order"));
app.use("/api/rate", require("./routes/rate"));
app.use("/api/seller", require("./routes/seller"));
app.use("/api/logistics", require("./routes/logistics"));
app.use("/test", require("./routes/test"));
app.use("/m", require("./routes/migrate"));
// Listener
app.listen(PORT, () =>
console.log(
`Server runinng and listening to port ${PORT}. http://localhost:${PORT}/`
)
);