-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathapp.js
More file actions
58 lines (48 loc) · 1.5 KB
/
app.js
File metadata and controls
58 lines (48 loc) · 1.5 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
const express = require("express");
const app = express();
const errorMiddleware = require("./middlewares/errors");
const cookieParser = require("cookie-parser");
const bodyParser = require("body-parser");
const fileUpload = require("express-fileupload");
const rateLimit = require("express-rate-limit");
const helmet = require("helmet");
const mongoSanitize = require("express-mongo-sanitize");
const xssClean = require("xss-clean");
const cors = require("cors");
app.use(express.json());
app.use(bodyParser.urlencoded({ extended: true }));
app.use(cookieParser());
app.use(
fileUpload({
useTempFiles: true,
})
);
// Setup security headers
app.use(helmet());
// Sanitize data
app.use(mongoSanitize());
/* Prevent XSS attacks(prevent users to add html css js tags in database),
make sure this comes before any routes*/
app.use(xssClean());
// Setup CORS - accessible by other domains
app.use(cors());
// Rate Limiting
const limiter = rateLimit({
windowMs: 10 * 60 * 1000, // 10 mins
max: 50, // limit each IP to 100 requests per windowMs
});
app.use(limiter);
// Import all routes
const products = require("./routes/product");
const auth = require("./routes/auth");
const order = require("./routes/order");
const payment = require("./routes/payment");
const user = require("./routes/user");
app.use("/api/v1", products);
app.use("/api/v1", auth);
app.use("/api/v1", order);
app.use("/api/v1", payment);
app.use("/api/v1", user);
// Middleware to handle errors
app.use(errorMiddleware);
module.exports = app;