-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathapp.js
85 lines (73 loc) · 2.06 KB
/
app.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
// Init
let inTest = false
if (process.argv[2] === '--test') {
inTest = true
setTimeout(() => {
process.exitCode = 0
process.exit()
}, 5000)
}
// Dependencies
const Koa = require('koa')
const KoaStatic = require('koa-static')
const KoaRouter = require('koa-router')
const koaBody = require('koa-body')
// Local Packages
const Log = require('./src/util/log')
const Global = require('./src/util/global')
const Init = require('./init')
const routers = require('./src/route/router')
let config = undefined
try {
config = require('./config.json')
}
catch(e) {
Log.fatal(e)
let err = new Error('请先根据 config.json.example 创建 config.json 文件')
err.name = 'Configuration Error'
throw err
}
Init()
let app = new Koa()
app.proxy = true
app.use(koaBody({ multipart: true }));
Global.Add('config', config)
// to Log
app.use(async (ctx, next) => {
await next();
const rt = ctx.response.get('X-Response-Time');
Log.info(`${ctx.request.ips} ${ctx.method} ${ctx.url} - ${rt}`);
});
app.use(async (ctx, next) => {
ctx.set("Access-Control-Allow-Origin", ctx.headers['origin']);
ctx.set("Access-Control-Allow-Credentials", true);
ctx.set("Access-Control-Request-Method", "PUT,POST,GET,DELETE,OPTIONS");
ctx.set(
"Access-Control-Allow-Headers",
"Origin, X-Requested-With, Content-Type, Accept, cc"
);
if (ctx.method === "OPTIONS") {
ctx.status = 204;
return;
}
await next();
});
let test = new KoaRouter()
test.get('/ping', async (ctx, next) => {
ctx.body = "pong!"
await next()
})
// x-response-time
app.use(async (ctx, next) => {
const start = Date.now();
await next();
const ms = Date.now() - start;
ctx.set('X-Response-Time', `${ms}ms`);
});
// Merge all routes
app.use(test.routes()).use(test.allowedMethods())
app.use(routers.routes()).use(routers.allowedMethods())
app.use(KoaStatic('./public'))
app.listen(config.port)
Log.info("App 已经开始运行在 http://127.0.0.1:" + config.port)
if (inTest) Log.info("App 运行正常,测试成功")