Casbin.js
Casbin.js is a frontend port of a backend Casbin service, which facilitates the manipulation, management and storage of the user permission in a frontend application.
Example
You can set the permission manually.
const casbinjs = require('casbin.js');
const authorizer = new casbinjs.Authorizer();
const permission = {
"read": ['data1', 'data2'],
"write": ['data1']
}
authorizer.setPermission(permission);
console.log(authorizer.can("read", "data1"));
console.log(authorizer.cannot("write", "data2"));
You can also specify an casbin backend service endpoint when initialize the Casbin.js authorizer, and set the subject when the frontend user identity changes. Casbin.js will automatically fetch the permission from the endpoint. (A pre-configurated casbin service API is required at the backend.)
const casbinjs = require('casbin.js');
const authorizer = new casbinjs.Authorizer('http://Domain_name/casbin/api');
authorizer.setUser("Tom");
authorizer.can("read", "data1");
More functionalities of Casbin.js are still under development. Feel free to raise issues to share your features suggestions!
TODO MAP