-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathindex.js
95 lines (87 loc) · 3.04 KB
/
index.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
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
const express = require("express");
var cors_proxy = require("cors-anywhere");
const cors = require("cors");
const mongoose = require("mongoose");
const passport = require("passport");
const maintenance = require("@zrpaplicacoes/maintenance_mode");
const mongoSanitize = require("express-mongo-sanitize");
const xss = require("xss-clean");
const swaggerUi = require("swagger-ui-express");
const specs = require("./server_helpers/swagger");
const {
authLimiter,
postLimiter,
studentLimiter,
clubLimiter,
eventLimiter,
maintenance_options,
} = require("./server_helpers/security");
require("dotenv").config();
const app = express();
app.use(express.json());
app.use(cors());
app.use(express.urlencoded({ extended: true }));
app.use(passport.initialize());
app.use(maintenance(app, maintenance_options));
app.use(xss());
app.use(mongoSanitize());
app.set("secretKey", process.env.JWT_SECRET);
const host = "0.0.0.0";
// list all routes here, such as profileRoutes, messageRoutes, etc.
const authRoutes = require("./routes/auth");
const postRoutes = require("./routes/posts");
const studentRoutes = require("./routes/student");
const clubRoutes = require("./routes/club");
const eventRoutes = require("./routes/events");
const searchRoutes = require("./routes/search");
const getclubRoutes = require("./routes/getclubs");
const moderationRoutes = require("./routes/moderation");
// route them accordingly eg. app.use("/profile", profileRoutes)
app.use("/auth", authRoutes, authLimiter);
app.use("/posts", postRoutes, postLimiter);
app.use("/student", studentRoutes, studentLimiter);
app.use("/club", clubRoutes, clubLimiter);
app.use("/events", eventRoutes, eventLimiter);
app.use("/search", searchRoutes);
app.use("/getclubs", getclubRoutes); //returning the list of clubs
app.use("/docs", swaggerUi.serve, swaggerUi.setup(specs));
app.use("/moderation", moderationRoutes);
app.get("/health", (req, res) => {
res.setHeader("Access-Control-Allow-Origin", "*");
res.setHeader("Access-Control-Allow-Methods", "POST, GET");
res.setHeader("Access-Control-Allow-Headers", "Content-Type");
res.status(200).send({
message: `GET /health on Port ${process.env.PORT} successful`,
});
});
const connectToDB = async () => {
try {
await mongoose.connect(process.env.MONGO_URI, {
useNewUrlParser: true,
useUnifiedTopology: true,
useCreateIndex: true,
useFindAndModify: false,
});
console.log("Connected to database");
} catch (err) {
console.log(err);
console.log("Could not connect to database. Exiting...");
process.exit(1);
}
};
app.listen(process.env.PORT, () => {
console.log(`Listening on Port ${process.env.PORT}`);
});
cors_proxy
.createServer({
originWhitelist: [
"https://club-resources-embark.s3.amazonaws.com",
"https://embark-test.netlify.app/",
], // Allow all origins
//requireHeader: ['origin', 'x-requested-with'],
//removeHeaders: ['cookie', 'cookie2']
})
.listen(process.env.CORSPORT, host, function () {
console.log("Running CORS Anywhere on " + ":" + 9001);
});
connectToDB();