examples/errors/app.js
dongyu 50bcadf73e migrate to koa@2 (#108)
* support async/await

* change nodejs version 4 or 6 to 5.6

* eslint

* remove jade
2017-05-30 20:44:57 +08:00

40 lines
911 B
JavaScript

const Koa = require('koa');
const app = module.exports = new Koa();
// look ma, error propagation!
app.use(async function(ctx, next) {
try {
await next();
} catch (err) {
// some errors will have .status
// however this is not a guarantee
ctx.status = err.status || 500;
ctx.type = 'html';
ctx.body = '<p>Something <em>exploded</em>, please contact Maru.</p>';
// since we handled this manually we'll
// want to delegate to the regular app
// level error handling as well so that
// centralized still functions correctly.
ctx.app.emit('error', err, ctx);
}
});
// response
app.use(async function() {
throw new Error('boom boom');
});
// error handler
app.on('error', function(err) {
if (process.env.NODE_ENV != 'test') {
console.log('sent error %s to the cloud', err.message);
console.log(err);
}
});
if (!module.parent) app.listen(3000);