-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathserver.js
62 lines (52 loc) · 1.47 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
const debug = require("debug")("wapper:server");
const http = require("http");
const Koa = require("koa");
const bodyParser = require("koa-bodyparser");
const logger = require("koa-logger");
const json = require("koa-json");
const responseTime = require("koa-response-time");
const Router = require("@koa/router");
const koaStatic = require("koa-static");
const path = require("path");
const controllers = require("./controllers");
const { saveRequestLog } = require("./utilities/mongo");
const app = new Koa();
app.use(async function (ctx, next) {
try {
await next();
} catch (e) {
debug(e);
ctx.status = e.statusCode || e.status || 500;
ctx.body = {
success: false,
message: e.message || "Unknown server error occurred.",
};
}
if (ctx.state?.user?.sub) {
await saveRequestLog(
ctx.state.user.sub,
ctx.method,
ctx.originalUrl,
ctx.status
);
}
});
app
.use(responseTime({ hrtime: true }))
.use(koaStatic(path.join(__dirname, "public")))
.use(bodyParser())
.use(logger())
.use(json({ pretty: false, param: "pretty" }));
const router = new Router();
router.use(
controllers.admin.routes(),
controllers.admin.allowedMethods(),
controllers.wapi.routes(),
controllers.wapi.allowedMethods()
);
app.use(router.routes()).use(router.allowedMethods());
const server = http.createServer(app.callback());
const port = process.env.PORT || 3000;
server.listen(port, () => {
debug(`Listening on *:${port}`);
});