-
Notifications
You must be signed in to change notification settings - Fork 38
/
server.js
92 lines (77 loc) 路 2.32 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
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
const express = require("express");
const app = express();
const session = require("express-session");
const MongoDBStore = require("connect-mongodb-session")(session);
const router = express.Router();
const morgan = require("morgan");
const mongoose = require("mongoose");
const path = require("path");
const helmet = require('helmet');
const cors = require('cors');
// Constants
const {
HOST,
PORT,
SESS_SECRET,
NODE_ENV,
IS_PROD,
COOKIE_NAME
} = require("./config/config");
const { MongoURI } = require("./config/database");
const MAX_AGE = 1000 * 60 * 60 * 3; // Three hours
// const IS_PROD = NODE_ENV === "production";
// Connecting to Database
mongoose
.connect(MongoURI, {
useNewUrlParser: true,
useCreateIndex: true
})
.then(() => console.log("MongoDB connected..."))
.catch((err) => console.log(err));
// setting up connect-mongodb-session store
const mongoDBstore = new MongoDBStore({
uri: MongoURI,
collection: "mySessions"
});
// Express Bodyparser
app.use(express.urlencoded({ extended: false }));
app.use(express.json());
//Morgan setup
app.use(morgan("dev"));
// Express-Session
app.use(
session({
name: COOKIE_NAME, //name to be put in "key" field in postman etc
secret: SESS_SECRET,
resave: true,
saveUninitialized: false,
store: mongoDBstore,
cookie: {
maxAge: MAX_AGE,
sameSite: false,
secure: IS_PROD
}
})
);
app.use(helmet())
// Below corsOptions are for Local development
const corsOptions = {
origin: 'http://localhost:3000',
credentials: true,
optionsSuccessStatus: 200 // some legacy browsers (IE11, various SmartTVs) choke on 204
}
// Below corsOptions work in deployment as Docker containers
const corsOptionsProd = {
origin: 'http://localhost',
credentials: true,
optionsSuccessStatus: 200 // some legacy browsers (IE11, various SmartTVs) choke on 204
}
app.use(cors(corsOptions));
router.get("/", (req, res) => res.send("HELLO FRIEND"));
// API / Routes;
// Uncomment Below for Development
app.use("/api/users", require("./routes/users"));
//Uncomment Below for Production, routes mounted at /sessions-auth-app and not root domain
//app.use("/sessions-auth-app/api/users", require("./routes/users"));
// app.use("/api/auth", require("./routes/auth"));
app.listen(PORT, () => console.log(`Server started on http://${HOST}:${PORT}`));