koa-params
v1.1.0
Published
Add express style params support to koa
Downloads
5
Readme
koa-params
Add express style params support to koa-route.
Example
var koa = require('koa');
var route = require('koa-route')
var paramify = require('koa-params');
route = paramify(route);
var param = route.param;
var get = route.get;
var app = koa();
// fake db
var users = {
'julian': { name: 'Julian Gruber', fun: true },
'badguy': { name: 'Bad Guy', fun: false }
};
param('user', function*(id, next){
var user = users[id];
if (!user) return this.status = 404;
this.user = user;
yield next;
});
app.use(get('/', function*(){
this.body = Object.keys(users);
}));
app.use(get('/:user', function*(){
this.body = this.user;
}));
app.listen(3000);
Installation
$ npm install koa-params
API
paramify(route)
Return a cloned version of route
with http verbs patched and added .param
.
route.param(param, fn)
When a route contains :param
, call fn
with its value and next
. Wait for it to yield before continuing with the real route handler - unless you don't yield and the response ends.
You can register multiple fns
per param
, just as with express.
fn
can be koa middleware too, when fn
only takes one argument, next
will be supplied.
License
MIT