Request body parser for toa.
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)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)npm install toa-bodyconst toaBody = require('toa-body')It will add parseBody method to context.
- options.encoding: requested encoding. Default is- utf8.
- options.formLimit: limit of the- urlencodedbody. If the body ends up being larger than this limit, a 413 error code is returned. Default is- 56kb
- options.jsonLimit: limit of the- jsonbody. Default is- 1mb
- options.extendTypes: support extend types:
toaBody(app, {
  extendTypes: {
    json: ['application/x-javascript'] // will parse application/x-javascript type body as a JSON string
  }
}))- options.parse: support custom parse:
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.
this.body = yield this.parseBody()this.parseBody()(function (err, body) {
  // this.request.body === body
  this.body = body
})Toa >= v2.x required.
(The MIT License)