Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/koajs/error

Error response middleware (text, json, html)
https://github.com/koajs/error

Last synced: 3 days ago
JSON representation

Error response middleware (text, json, html)

Awesome Lists containing this project

README

        

# koa-error

Error response middleware for koa supporting:

- text
- json
- html

## Installation

```js
$ npm install koa-error
```

## Options

- `template` path to template written with your template engine, default: `./error.html`
- `engine` template engine name passed to [consolidate](https://github.com/tj/consolidate.js), default: `lodash`
- `cache` cached compiled functions, default: `NODE_ENV != 'development'`
- `env` force a NODE_ENV, default: `development`
- `accepts` mimetypes passed to [ctx.accepts](https://github.com/koajs/koa/blob/master/docs/api/request.md#requestacceptstypes), default: `[ 'html', 'text', 'json' ]`

## Custom templates

By using the `template` option you can override the bland default template,
with the following available local variables:

- `env`
- `ctx`
- `request`
- `response`
- `error`
- `stack`
- `status`
- `code`

Here are some examples:

### Pug (formerly jade)

```js
app.use(error({
engine: 'pug',
template: __dirname + '/error.pug'
}));
```

```jade
doctype html
html
head
title= 'Error - ' + status
body
#error
h1 Error
p Looks like something broke!
if env == 'development'
h2 Message:
pre: code= error
h2 Stack:
pre: code= stack
```

### Nunjucks

```js
app.use(error({
engine: 'nunjucks',
template: __dirname + '/error.njk'
}));
```

```html


Error - {{status}}



Error


Looks like something broke!


{% if env == 'development' %}

Message:




{{error}}


Stack:




{{stack}}


{% endif %}

```

## License

MIT