@sigfox/koa-acl
v1.0.3
Published
Koa middleware for ACL handling.
Downloads
1
Readme
koa-acl
Koa middleware for ACL handling.
When use it?
This module can be used if you need to handle authorizations on your koa app.
Features
- Returns boom error if the user doesn't have the right roles.
Install
npm install @sigfox/koa-acl
Usage
roles
(Array[String]
): These are the roles that the middleware will search for inctx.state
(ctx.state.user.roles
or directlyctx.state.roles
)query
(Function
): A function taking ctx as a parameter. If falsy, the middleware will deny access.
const Koa = require('koa');
const Router = require('koa-router');
const aclMiddleware = require('@sigfox/koa-acl');
const controller = require('hypothetical-controller');
const ADMIN_ROLE = 'admin';
// ctx.state must be populated by user or roles
const addUser = (ctx, next) => {
// Both of those are working, user.roles has priority though.
ctx.state.user = {
roles: [ADMIN_ROLE]
};
ctx.state.roles = [ADMIN_ROLE];
return next();
};
const addAdmin = (ctx, next) => {
ctx.state.user = {
isAdmin: true
};
return next();
};
// Just provide the allowed roles and/or a query, this will generate middlewares that you can use together or separately
const { roles: hasAdminRole, query: isAdmin } = aclMiddleware({
roles: [ADMIN_ROLE],
query: ctx => !!(ctx.state.user && ctx.state.user.isAdmin)
});
const getRoutes = () => {
const router = new Router();
// This will reach the controller
router.get('/data/1', controller);
// This will reach the controller
router.get('/data/2', addUser, hasAdminRole, controller);
// This will return 403 because no user is provided
router.get('/data/3', hasAdminRole, controller);
// This will return 403 because no user is provided
router.get('/data/4', isAdmin, controller);
// This will reach the controller
router.get('/data/5', addAdmin, isAdmin, controller);
return router.routes();
};
const app = new Koa().use(getRoutes()).listen();
Test
npm test
Licence
This project is licensed under the MIT License - see the LICENSE file for details.