-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathapp.js
68 lines (57 loc) · 1.66 KB
/
app.js
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
const express = require("express");
const cors = require("cors");
const compression = require("compression");
const expressRateLimit = require("express-rate-limit");
const expressMongoSanitize = require("express-mongo-sanitize");
const helmet = require("helmet");
const hpp = require("hpp");
const xss = require("xss-clean");
const userRouters = require("./routers/userRouters");
const musicRouters = require("./routers/musicRouters");
const ErrorProvider = require("./classes/ErrorProvider");
const errorController = require("./controllers/errorController");
// * Express
const app = express();
// * Cors configuration
const allowedOrigins = ["https://spotifymern.vercel.app"];
app.use(
cors({
origin: function (origin, callback) {
if (allowedOrigins.includes(origin) || !origin) {
callback(null, true);
} else {
callback(new Error("Not allowed by CORS"));
}
},
credentials: true,
})
);
// * Compression for production
app.use(compression());
// * API Limit
const limit = expressRateLimit({
max: 100,
windowsMs: 60 * 60 * 1000,
message: "Too many requests.",
standartHeaders: true,
legacyHeaders: false,
});
// * Security
app.use(express.json({ limit }));
app.use(expressMongoSanitize());
app.use(helmet());
app.use(hpp());
app.use(xss());
// * Root Route
app.get("/", (req, res) => {
res.send("Welcome to the SpotifyMERN API!");
});
// * Routers
app.use("/spotifymern/users", userRouters);
app.use("/spotifymern/musics", musicRouters);
// * Unsupported URLs
app.all("*", (req, res, next) =>
next(new ErrorProvider(404, "fail", `Unsupported URL: ${req.originalUrl}`))
);
app.use(errorController);
module.exports = app;