-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathtlapi.js
94 lines (80 loc) · 2.57 KB
/
tlapi.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
const { get_env_config, load_env_config } = require("./conf/env_config");
//加载环境变量
load_env_config();
//获取环境变量
const conf = get_env_config();
const {
tlConsoleApiIcon, tlConsole, tlConsoleError
} = require("./src/utils/utils");
//打印logo
tlConsoleApiIcon()
const express = require("express");
const bodyParser = require('body-parser');
const multer = require('multer');
const cookieParser = require('cookie-parser');
const apiRouters = require("./src/controller/router")();
const { dbInit } = require("./src/tables/db"); //db
const { redisInit } = require("./src/utils/cache/redis"); //redis
const fs = require('fs');
const https = require('https');
const loginAuthHandler = require("./src/middleware/loginAuth");
const { loginRoleHandler, loginChannelRoleHandler } = require("./src/middleware/loginRole");
const resRouter = {
"/": "dist/",
"/website/": "website-res/"
}
process.on('unhandledRejection', (reason, promise) => {
tlConsoleError('Unhandled Rejection reason:', reason);
})
async function start() {
let app = express();
// parse json
app.use(bodyParser.json());
// parse cookie
app.use(cookieParser());
// login auth
app.use(loginAuthHandler)
// role auth
app.use(loginRoleHandler)
// channel role auth
app.use(loginChannelRoleHandler)
tlConsole("db init start ...")
if (!conf.db_open) {// 没开db
tlConsole("db not open ...")
}else{
await dbInit();
}
tlConsole("db init done ...")
tlConsole("redis init start ...")
await redisInit();
tlConsole("redis init done ...")
tlConsole("api init start ...")
for (let key in apiRouters) {
let keyRouterCount = 0
apiRouters[key].stack.forEach(function (r) {
if (r.route && r.route.path) keyRouterCount++;
})
tlConsole(key, "router count", keyRouterCount)
}
// api
for (let key in apiRouters) app.use(key, apiRouters[key])
// res api
for (let key in resRouter) app.use(key, express.static(resRouter[key]));
tlConsole("api init done ...")
//start server
if(process.env.tl_rtc_app_env_mode === 'http'){
app.listen(conf.api_port);
}else {
let options = {
key: fs.readFileSync('./conf/keys/server.key'),
cert: fs.readFileSync('./conf/keys/server.crt')
}
https.createServer(options,app).listen(conf.api_port);
}
tlConsole(process.env.tl_rtc_app_env_mode, "api", " server running on", conf.api_port, "successful")
}
try{
start();
}catch(e){
tlConsoleError(e)
}