https://github.com/Inist-CNRS/lodex
Tip revision: 57e06f42920cb74a1da885ba5b5db1b30635d82a authored by Nicolas Thouvenin on 08 March 2018, 10:58:10 UTC
8.18.2
8.18.2
Tip revision: 57e06f4
index.js
import Koa from 'koa';
import config from 'config';
import mount from 'koa-mount';
import cors from 'kcors';
import koaQs from 'koa-qs';
import logger from './services/logger';
import controller from './controller';
const env = process.env.NODE_ENV;
const app = koaQs(new Koa());
app.use(cors({ credentials: true }));
// server logs
app.use(async (ctx, next) => {
ctx.httpLog = {
method: ctx.request.method,
remoteIP: ctx.request.ip,
userAgent: ctx.request.headers['user-agent'],
};
const authorization = ctx.get('authorization');
if (authorization) {
ctx.httpLog.authorization = authorization;
}
await next();
ctx.httpLog.status = ctx.status;
logger.info(ctx.request.url, ctx.httpLog);
});
app.use(mount('/', controller));
// Error catching - override koa's undocumented error handler
app.context.onerror = function onError(err) {
if (!err) return;
this.status = err.status || 500;
this.app.emit('error', err, this);
if (this.headerSent || !this.writable) {
err.headerSent = true; // eslint-disable-line no-param-reassign
return;
}
if (env === 'development') {
// respond with the error details
this.body = JSON.stringify({
error: err.message,
stack: err.stack,
code: err.code,
});
this.type = 'json';
} else {
// just send the error message
this.body = { error: err.message };
}
this.res.end(this.body);
};
if (!module.parent) {
global.console.log(`Server listening on port ${config.port}`);
global.console.log('Press CTRL+C to stop server');
app.listen(config.port);
}
export default app;