-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathindex.js
More file actions
150 lines (134 loc) · 3.88 KB
/
index.js
File metadata and controls
150 lines (134 loc) · 3.88 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
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
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
//extra security packages(middlewares)
const helmet = require("helmet");
const cors = require("cors");
const xss = require("xss-clean");
const rateLimiter = require("express-rate-limit");
const session = require("express-session");
const MongoStore = require("connect-mongo");
const path = require('path');
// console related package
const logColor = require("cli-color");
// initialize express app
const express = require("express");
const app = express();
//db connection
const connectDB = require("./db/connect");
//middlewares
const middlewares = require("./middlewares");
//routers
const routers = require("./routes");
//models
const { User } = require("./models");
app.set("trust proxy", 1);
app.use(
rateLimiter({
windowMs: 15 * 60 * 1000,
max: 250,
})
);
app.use(express.json({ limit: "10mb" }));
app.use(express.static(path.join(__dirname, "public")));
app.use(
session({
name: process.env.SESS_NAME,
secret: process.env.SESS_SECRET,
resave: false,
saveUninitialized: false,
store: MongoStore.create({
mongoUrl: process.env.MONGO_URI,
}),
cookie: {
maxAge: 1000 * 60 * 60,
sameSite: true,
secure: process.env.IN_PROD || false,
},
})
);
// extra packages
app.use(helmet());
app.use(cors());
app.use(xss());
app.use(function(req, res, next) {
res.set("Access-Control-Allow-Origin", "*");
res.set("Access-Control-Allow-Headers", "*");
res.set("Access-Control-Allow-Credentials", "true");
next();
});
// base route
app.get("/", (req, res) => {
res.redirect("https://cipherbay.vercel.app");
});
// routers
app.use("/panel", routers.navigation);
app.use("/api/v1/auth", routers.auth);
app.get("/check-user-status", middlewares.auth, async (req, res) => {
const loggedInUser = await User.findOne({_id: req.user.userId}).select('firstName lastName username email');
if(loggedInUser) {
return res.status(200).json({
error: false,
auth: true,
loggedInUser: loggedInUser
})
}
res.status(401).json({
error: true,
auth: false,
msg: `No user found with id - ${req.user.userId}`
})
});
app.use("/api/v1/cipher", middlewares.apiKeyValidator, routers.cipher);
app.use(
"/api/v1/scheme",
middlewares.apiKeyValidator,
middlewares.adminCheck,
routers.scheme
);
app.use(
"/api/v1/admin",
middlewares.apiKeyValidator,
middlewares.adminCheck,
routers.admin
);
// Handling non existing requests from the client
app.use((req, res, next) => {
res.status(404).sendFile(__dirname + "/public/404.html");
});
const PORT = process.env.PORT || 5000;
const startServer = async () => {
try {
const mongoConn = await connectDB(process.env.MONGO_URI);
app.listen(PORT, () => {
if (process.env.IN_PROD) {
console.log(
`Server Live on machine -> ${require("os").hostname()}` + "\n",
`Listening requests on port -> ${PORT}` + "\n",
`MongoDB Host -> ${mongoConn.connections[0].host}` + "\n",
`DB Name -> ${mongoConn.connections[0].name}` + "\n"
);
return;
} else {
console.log(
// the detailed(colored) log
`________________________________________________________` + "\n\n",
logColor.blueBright.bold(`Server Live on machine -> `) +
logColor.yellow.bold(require("os").hostname()) +
"\n",
logColor.blueBright.bold(`Listening requests on port -> `) +
logColor.green.bold(PORT) +
"\n",
logColor.blueBright.bold(`MongoDB Host -> `) +
logColor.redBright.bold(mongoConn.connections[0].host) +
"\n",
logColor.blueBright.bold(`DB Name -> `) +
logColor.magentaBright.bold(mongoConn.connections[0].name) +
"\n",
`_______________________________________________________`
);
return;
}
});
} catch (error) {
console.log(logColor.red(error));
}
};
startServer();