Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/pycasbin/casbin-databases-adapter
Async Databases Adapter for PyCasbin
https://github.com/pycasbin/casbin-databases-adapter
abac acl auth authorization authz casbin databases orm pycasbin python rbac
Last synced: 4 months ago
JSON representation
Async Databases Adapter for PyCasbin
- Host: GitHub
- URL: https://github.com/pycasbin/casbin-databases-adapter
- Owner: pycasbin
- License: apache-2.0
- Created: 2023-06-06T11:15:55.000Z (over 1 year ago)
- Default Branch: master
- Last Pushed: 2024-04-24T12:57:03.000Z (10 months ago)
- Last Synced: 2024-04-25T13:28:20.483Z (10 months ago)
- Topics: abac, acl, auth, authorization, authz, casbin, databases, orm, pycasbin, python, rbac
- Language: Python
- Homepage: https://github.com/casbin/pycasbin
- Size: 47.9 KB
- Stars: 2
- Watchers: 2
- Forks: 3
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
# Databases Casbin Adapter
[](https://github.com/pycasbin/casbin-databases-adapter/actions)
[](https://coveralls.io/github/pycasbin/casbin-databases-adapter?branch=master)
[](https://pypi.org/project/casbin_databases_adapter/)
[](https://pypi.org/project/casbin_databases_adapter/)
[](https://pypi.org/project/casbin_databases_adapter/)
[](https://pypi.org/project/casbin_databases_adapter/)
[](https://pypi.org/project/casbin_databases_adapter/)This is an Adapter for [PyCasbin](https://github.com/casbin/pycasbin) that implemented using [Databases](https://www.encode.io/databases) connection to achieve async process
## Installation
```
pip install casbin_databases_adapter
```## Simple Example
```python
import casbin_databases_adapter
import casbin
from databases import Database
import sqlalchemy
from sqlalchemy import Table, Column, String, Integer
from sqlalchemy.sql.ddl import CreateTable
import asyncioDATABASE_URL = "sqlite+aiosqlite:///example.db"
async def create_casbin_rule_table(db: Database):
metadata = sqlalchemy.MetaData()
table = Table(
"casbin_rules",
metadata,
Column("id", Integer, primary_key=True),
Column("ptype", String(255)),
Column("v0", String(255)),
Column("v1", String(255)),
Column("v2", String(255)),
Column("v3", String(255)),
Column("v4", String(255)),
Column("v5", String(255)),
)
q = CreateTable(table)
await db.execute(query=str(q))
return tableasync def main():
database = Database(DATABASE_URL)
await database.connect()
casbin_rule_table = await create_casbin_rule_table(database)
adapter = casbin_databases_adapter.DatabasesAdapter(db=database, table=casbin_rule_table)
e = casbin.Enforcer('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# run the main function
asyncio.run(main())
```### Getting Help
- [PyCasbin](https://github.com/casbin/pycasbin)
### License
This project is licensed under the [Apache 2.0 license](LICENSE).