toa-body
Version:
Request body parser for toa.
114 lines (81 loc) • 2.29 kB
Markdown
Request body parser for toa.
[![NPM version][npm-image]][npm-url]
[![Build Status][travis-image]][travis-url]
[![Downloads][downloads-image]][downloads-url]
```js
const Toa = require('toa')
const toaBody = require('toa-body')
const app = new Toa()
toaBody(app)
app.use(function * () {
this.body = yield this.parseBody()
})
app.listen(3000)
```
```js
const Toa = require('toa')
const toaBody = require('toa-body')
const app = new Toa()
app.use(toaBody()) // It will try to parse body for every request.
app.use(function () {
this.body = this.request.body
})
app.listen(3000)
```
```bash
npm install toa-body
```
```js
const toaBody = require('toa-body')
```
It will add `parseBody` method to `context`.
- `options.encoding`: requested encoding. Default is `utf8`.
- `options.formLimit`: limit of the `urlencoded` body. If the body ends up being larger than this limit, a 413 error code is returned. Default is `56kb`
- `options.jsonLimit`: limit of the `json` body. Default is `1mb`
- `options.extendTypes`: support extend types:
```js
toaBody(app, {
extendTypes: {
json: ['application/x-javascript'] // will parse application/x-javascript type body as a JSON string
}
}))
```
- `options.parse`: support custom parse:
```js
const parseXml = require('xml2js').parseString
toaBody(app, {
parse: function (buf) {
var str = buf.toString('utf8')
if (!this.is('text/xml')) return str
// return promise or thunk function for async task
return function (done) { parseXml(str, done) }
}
}))
```
return thunk function.
```js
this.body = yield this.parseBody()
```
```js
this.parseBody()(function (err, body) {
// this.request.body === body
this.body = body
})
```
Toa >= v2.x required.
(The MIT License)
[]: https://npmjs.org/package/toa-body
[]: http://img.shields.io/npm/v/toa-body.svg
[]: https://travis-ci.org/toajs/toa-body
[]: http://img.shields.io/travis/toajs/toa-body.svg
[]: https://npmjs.org/package/toa-body
[]: http://img.shields.io/npm/dm/toa-body.svg?style=flat-square