casequelize
TypeScript icon, indicating that this package has built-in type declarations

1.1.0 • Public • Published

Casbin Sequelize Adapter

Casbin Sequelize Adapter is the Sequelize adapter for Casbin. With this library, Casbin can load policy from Sequelize supported database or save policy to it.

Based on Officially Supported Databases, The current supported databases are:

  • MySQL
  • PostgreSQL
  • Sqlite3
  • Mssql

You may find other 3rd-party supported DBs in Sequelize website or other places.

Installation

npm install casequelize

Simple Example

const Adapter = require('casequelize');
const { Enforcer } = require('casbin');
 
module.exports = () => {
    // Initialize a Sequelize adapter and use it in a Casbin enforcer:
    // The adapter will use the MySQL database named "casbin".
    // If it doesn't exist, the adapter will create it automatically.
  
  const adapter = await Adapter.newAdapter('mysql://root:123456@localhost:3306/casbin', {}); // Your driver and data source.
  const enforcer = await Enforcer.newEnforcer('examples/rbac_model.conf', adapter);
    
    // Or you can use an existing DB "abc" like this:
    // The adapter will use the table named "casbin_rule".
    // If it doesn't exist, the adapter will create it automatically.
    // adapter = sequelizeadapter.newAdapter("mysql", "mysql_username:mysql_password@tcp(127.0.0.1:3306)/abc", true)
 
    // Load the policy from DB.
    await enforcer.loadPolicy()
    
    // Check the permission.
    await enforcer.enforce('alice', 'data1', 'read')
    
    // Modify the policy.
    // e.addPolicy(...)
    // e.removePolicy(...)
    
    // Save the policy back to DB.
    await enforcer.savePolicy()
}

Getting Help

License

This project is under Apache 2.0 License. See the LICENSE file for the full license text.

Package Sidebar

Install

npm i casequelize

Homepage

casbin.org

Weekly Downloads

0

Version

1.1.0

License

none

Unpacked Size

26.3 kB

Total Files

11

Last publish

Collaborators

  • chalin