Sequelize adapter for Casbin

Clone this repo:
  1. 55287df fix: security vulnerability in sequelize-typescript <2.1.6 (#83) by Amine Roukh · 2 years, 3 months ago master v2.7.1
  2. 3867825 docs: replace gitter links with discord (#81) by YunShu · 2 years, 8 months ago
  3. 4dccf8d feat: create new CasbinRule instance every time sequelize Adapter opens connection (#80) by tsoultanopoulos · 2 years, 9 months ago v2.7.0
  4. 1724f2e fix: append schema as parameter for updateCasbinRule() (#76) by Shubhanshu · 3 years ago v2.6.1
  5. 0ae1c9d feat: fix security vulnerability in sequelize and typing errors (#77) by Amine Roukh · 3 years ago v2.6.0

Sequelize Adapter

NPM version NPM download codebeat badge ci Coverage Status Discord

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

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

  • PostgreSQL
  • MySQL
  • SQLite
  • MSSQL

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

Installation

NPM Install

npm install casbin-sequelize-adapter --save

Yarn Install

yarn add casbin-sequelize-adapter

Testing Locally

Start mysql for tests:

docker compose up -d
yarn test

Simple Example

import casbin from 'casbin';
import { SequelizeAdapter } from 'casbin-sequelize-adapter';

async function myFunction() {
  // Initialize a Sequelize adapter and use it in a Node-Casbin enforcer:
  // The adapter can not automatically create database.
  // But the adapter will automatically and use the table named "casbin_rule".
  // The second boolean argument: autoCreateTable determines whether the adapter will automatically create the "casbin_rule" table.
  // ORM should not create databases automatically.
  const a = await SequelizeAdapter.newAdapter(
    {
      username: 'root',
      password: '',
      database: 'casbin',
      dialect: 'mysql',
    },
    true,
  );

  const e = await casbin.newEnforcer('examples/rbac_model.conf', a);

  // Check the permission.
  e.enforce('alice', 'data1', 'read');

  // Modify the policy.
  // await e.addPolicy(...);
  // await e.removePolicy(...);

  // Save the policy back to DB.
  await e.savePolicy();
}

Getting Help

License

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