-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathserver.js
111 lines (85 loc) · 3.12 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
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
// 1.setup env
require("rootpath")();
const path = require("path");
const fs = require('fs');
const dotenv = require('dotenv');
process.env.NODE_ENV = process.env.NODE_ENV || 'development';
const envFilePath = path.join(__dirname, 'utils', `.env.${process.env.NODE_ENV}`);
if (fs.existsSync(envFilePath)) {
dotenv.config({ path: envFilePath });
console.info(`1. Environment file ${envFilePath}`);
} else {
dotenv.config({ path: path.join(__dirname, '.env') });
console.info(`1. Environment file ${envFilePath} Not found, Loading from process.env`);
}
// 2.setup system logger
const { systemLogger } = require('./www/initServer/initSysLogger')
// 3.create directory
const { createDirectory } = require('./www/initServer/initDirectory')
createDirectory()
const { mongoBackup } = require("./utils/dbBackup");
const { dbConnect, closeDB, listCollections } = require("./www/initServer/initDB");
const { redisConnect, redisClient } = require("./www/initServer/initRedis");
// */5 * * * * *
// 0 0 * * *
const cron = require("node-cron");
cron.schedule('0 0 * * *', async () => {
try {
const collections = await listCollections()
await mongoBackup(collections);
} catch (error) {
systemLogger.error(`Hi Failed to perform backup: ${error}`);
}
});
if (process.env.NODE_ENV === "production") {
process.on("uncaughtException", (err) => {
systemLogger.error(`${err.name} : ${err.message} : ${err.stack}`);
systemLogger.info("Uncaught Exception occurred! Shutting down...");
process.exit(0); // clean exit
});
}
// await dbConnect();
// await connectRedis();
// await mongoBackup() //test backup is working or not
let server
(async () => {
try {
systemLogger.info("4. Initializing Server Setup......")
await redisConnect()
const collections = await dbConnect()
// await mongoBackup(collections)
const app = require("./app");
process.env.NODE_PORT = process.env.NODE_PORT || 5000;
// process.env.NODE_ENV = process.env.NODE_ENV || "development"
server = app.listen(process.env.NODE_PORT)
server.on("listening", () => {
systemLogger.info(`Server PORT ==> ${process.env.NODE_PORT}`);
systemLogger.info(`Node ENV ==> ${process.env.NODE_ENV}`);
systemLogger.info(`Node Version ==>${process.version}`);
});
// Event handler for server error
server.on("error", async (error) => {
systemLogger.error("Express Server Error");
await closeDB()
await redisClient.disconnect()
systemLogger.error(error.message)
server.close();
});
// Event handler for server close
server.on("close", async () => {
systemLogger.info("Server closed");
process.exit(0)
});
process.on("SIGINT", () => {
server.close();
});
} catch (error) {
systemLogger.error(error.stack);
process.exit(1)
}
})()
process.on("unhandledRejection", async (err) => {
systemLogger.error(`${err.name}: ${err.message} : ${err.stack}`);
systemLogger.info("Unhandled rejection occurred! Shutting down...");
process.exit(0)
});