Fix redundant warnings imports in tests Co-authored-by: nomeguy <85475922+nomeguy@users.noreply.github.com>
Asynchronous SQLAlchemy Adapter is the SQLAlchemy adapter for PyCasbin. With this library, Casbin can load policy from SQLAlchemy supported database or save policy to it.
Based on Officially Supported Databases, The current supported databases are:
pip install casbin_async_sqlalchemy_adapter
import casbin_async_sqlalchemy_adapter import casbin adapter = casbin_async_sqlalchemy_adapter.Adapter('sqlite+aiosqlite:///test.db') # or mysql example # adapter = casbin_async_sqlalchemy_adapter.Adapter('mysql+aiomysql://user:pwd@127.0.0.1:3306/exampledb') e = casbin.AsyncEnforcer('path/to/model.conf', adapter) sub = "alice" # the user that wants to access a resource. obj = "data1" # the resource that is going to be accessed. act = "read" # the operation that the user performs on the resource. if e.enforce(sub, obj, act): # permit alice to read data1 pass else: # deny the request, show an error pass
Note that AsyncAdaper must be used for AynscEnforcer.
By default, when using the default CasbinRule table, the adapter will show a warning to remind you to call create_table(). If you want to suppress this warning, you have two options:
Option 1: Use the warning parameter
adapter = casbin_async_sqlalchemy_adapter.Adapter( 'sqlite+aiosqlite:///test.db', warning=False # Suppress the warning )
Option 2: Explicitly pass the db_class parameter
from casbin_async_sqlalchemy_adapter import CasbinRule adapter = casbin_async_sqlalchemy_adapter.Adapter( 'sqlite+aiosqlite:///test.db', db_class=CasbinRule # Explicitly use default class )
The adapter supports using externally managed SQLAlchemy sessions. This feature is useful for:
import casbin_async_sqlalchemy_adapter import casbin from sqlalchemy.ext.asyncio import create_async_engine, AsyncSession from sqlalchemy.orm import sessionmaker # Create your own database session engine = create_async_engine('sqlite+aiosqlite:///test.db') async_session = sessionmaker(engine, class_=AsyncSession, expire_on_commit=False) # Create adapter with external session session = async_session() adapter = casbin_async_sqlalchemy_adapter.Adapter( 'sqlite+aiosqlite:///test.db', db_session=session ) e = casbin.AsyncEnforcer('path/to/model.conf', adapter) # Now you have full control over the session # The adapter will not auto-commit or auto-rollback when using external sessions
# Example: Manual transaction control async with async_session() as session: adapter = casbin_async_sqlalchemy_adapter.Adapter( 'sqlite+aiosqlite:///test.db', db_session=session ) e = casbin.AsyncEnforcer('path/to/model.conf', adapter) # Add multiple policies in a single transaction await e.add_policy("alice", "data1", "read") await e.add_policy("bob", "data2", "write") # Commit or rollback as needed await session.commit()
# Example: Efficient batch operations async with async_session() as session: adapter = casbin_async_sqlalchemy_adapter.Adapter( 'sqlite+aiosqlite:///test.db', db_session=session ) e = casbin.AsyncEnforcer('path/to/model.conf', adapter) # Batch add multiple policies efficiently policies = [ ["alice", "data1", "read"], ["bob", "data2", "write"], ["carol", "data3", "read"] ] await e.add_policies(policies) # Commit the transaction await session.commit()
This project is licensed under the Apache 2.0 license.