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-body
const toaBody = require('toa-body')
It will add parseBody
method to context
.
options.encoding
: requested encoding. Default isutf8
.options.formLimit
: limit of theurlencoded
body. If the body ends up being larger than this limit, a 413 error code is returned. Default is56kb
options.jsonLimit
: limit of thejson
body. Default is1mb
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)