2020-02-03 22:24:25 +13:00
|
|
|
const Koa = require("koa")
|
2020-05-07 21:53:34 +12:00
|
|
|
const logger = require("koa-logger")
|
2020-05-08 01:04:32 +12:00
|
|
|
const api = require("./api")
|
2020-02-03 22:24:25 +13:00
|
|
|
const koaBody = require("koa-body")
|
2020-05-15 02:12:30 +12:00
|
|
|
const env = require("./environment")
|
|
|
|
const http = require("http")
|
2020-05-08 01:04:32 +12:00
|
|
|
|
2020-02-03 22:24:25 +13:00
|
|
|
const app = new Koa()
|
2019-06-14 21:05:46 +12:00
|
|
|
|
2020-05-08 01:04:32 +12:00
|
|
|
// set up top level koa middleware
|
|
|
|
app.use(koaBody({ multipart: true }))
|
2020-05-15 02:12:30 +12:00
|
|
|
|
|
|
|
if (env.LOGGER !== "off") app.use(logger())
|
2020-05-05 04:13:57 +12:00
|
|
|
|
2020-05-08 01:04:32 +12:00
|
|
|
// api routes
|
|
|
|
app.use(api.routes())
|
2020-05-05 04:13:57 +12:00
|
|
|
|
2020-05-15 02:12:30 +12:00
|
|
|
module.exports = async port => {
|
2020-05-15 03:26:14 +12:00
|
|
|
port = port || env.PORT || 4001
|
2020-05-15 02:12:30 +12:00
|
|
|
const server = http.createServer(app.callback())
|
|
|
|
return new Promise((resolve, reject) => {
|
|
|
|
server.on("error", e => {
|
|
|
|
if (e.code === "EADDRINUSE") {
|
|
|
|
reject(e)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
server.listen({ port }, () => {
|
|
|
|
resolve(server)
|
|
|
|
})
|
|
|
|
})
|
2020-05-15 03:26:14 +12:00
|
|
|
}
|