1.1.0 • Published 12 years ago
koa-params v1.1.0
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-paramsAPI
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
