-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathserver.js
61 lines (52 loc) · 1.82 KB
/
server.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
// imports
const express = require("express");
const bodyParser = require("body-parser");
const session = require("express-session");
const dotenv = require("dotenv").config();
const rateLimit = require("express-rate-limit");
const database = require("./dbConfig.js");
// settings
const app = express();
app.set("view engine", "ejs");
app.set("views", __dirname + "/views");
app.use(express.static("public"));
app.use(bodyParser.urlencoded({limit: "10kb", extended: false}));
app.use(session({
secret: process.env.SESSION_SECRET,
resave: false,
saveUninitialized: false,
}));
// set response headers (needed to get around CORS policy when sending data)
app.use((req, res, next) => {
res.setHeader("Access-Control-Allow-Origin", "https://bookbot.org");
res.setHeader("Access-Control-Allow-Methods", "GET, POST, OPTIONS, PUT, PATCH, DELETE");
res.setHeader("Access-Control-Allow-Headers", "X-Requested-With,content-type");
res.setHeader("Access-Control-Allow-Credentials", true);
next();
});
// connect to mongodb, should be good to use .get() method in other routers
database.connect();
// using a proxy like nginx, should probably read into this more
//app.set("trust proxy", true);
//app.set("trust proxy", "loopback")
// limit user to 2 requests (all reqs to this server) per second at most
// NOTE it matters that this is here before routers in script
const limiter = rateLimit({
windowMs: 1000,
max: 2,
handler: (req, res) => {
console.log("rate limit exceeded");
res.render("rate.ejs");
}
});
app.use(limiter);
// routers
const indexRouter = require("./routes/index");
// use routers
app.use("/", indexRouter);
// 404 error on non-existing page
app.use((req, res) => {
res.render("error404.ejs");
});
// listen on port listed in .env
app.listen(process.env.NODE_PORT);