-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathserver.js
More file actions
81 lines (64 loc) · 1.99 KB
/
server.js
File metadata and controls
81 lines (64 loc) · 1.99 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
const express = require("express");
const app = express();
const mongoose = require("mongoose");
const passport = require("passport");
const session = require("express-session");
const MongoStore = require("connect-mongo");
const methodOverride = require("method-override");
const flash = require("express-flash");
const logger = require("morgan");
const connectDB = require("./config/database");
// const nodeCron = require("node-cron")
const mainRoutes = require("./routes/main");
const logRoutes = require("./routes/logs");
const dashRoutes = require("./routes/dashboard")
const cron = require("node-cron");
// npm install pm2
cron.schedule("59 59 23 * * *", () => {
logsController.createLog();
});
//Use .env file in config folder
require("dotenv").config({ path: "./config/.env" });
// Passport config
require("./config/passport")(passport);
//Connect To Database
connectDB();
//Using EJS for views
app.set("view engine", "ejs");
//Static Folder
app.use(express.static("public"));
//Body Parsing
app.use(express.urlencoded({ extended: true }));
app.use(express.json());
//Logging
app.use(logger("dev"));
//Use forms for put / delete
app.use(methodOverride("_method"));
// Setup Sessions - stored in MongoDB
app.use(
session({
secret: "keyboard cat",
resave: false,
saveUninitialized: false,
store: MongoStore.create({ mongoUrl: process.env.DB_STRING }),
})
);
// Passport middleware
app.use(passport.initialize());
app.use(passport.session());
//Use flash messages for errors, info, ect...
app.use(flash());
// node-cron for scheduling log upload
// https://www.youtube.com/watch?v=x8VIVR6ABHo - gotten from this vid
// nodeCron.schedule('*/2 * * * * *', () => {
// console.log("It's working");
// })
//Setup Routes For Which The Server Is Listening
app.use("/", mainRoutes);
// app.use("/post", postRoutes);
app.use("/logs", logRoutes);
app.use("/dashboard", dashRoutes);
//Server Running
app.listen(process.env.PORT, () => {
console.log("Server is running, you better catch it!");
});