https://github.com/pycasbin/redis-adapter
Redis adapter for PyCasbin
https://github.com/pycasbin/redis-adapter
abac acl adapter auth authorization authz casbin py pycasbin python rbac redis
Last synced: 12 months ago
JSON representation
Redis adapter for PyCasbin
- Host: GitHub
- URL: https://github.com/pycasbin/redis-adapter
- Owner: pycasbin
- License: apache-2.0
- Created: 2022-12-08T14:44:42.000Z (over 3 years ago)
- Default Branch: master
- Last Pushed: 2024-03-29T11:20:22.000Z (about 2 years ago)
- Last Synced: 2025-05-25T12:02:31.250Z (about 1 year ago)
- Topics: abac, acl, adapter, auth, authorization, authz, casbin, py, pycasbin, python, rbac, redis
- Language: Python
- Homepage: https://github.com/casbin/pycasbin
- Size: 23.4 KB
- Stars: 4
- Watchers: 2
- Forks: 3
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
Redis Adapter for PyCasbin
====
[](https://github.com/pycasbin/redis-adapter/actions)
[](https://coveralls.io/github/pycasbin/redis-adapter)
[](https://pypi.org/project/casbin_redis_adapter/)
[](https://pypi.org/project/casbin_redis_adapter/)
[](https://pypi.org/project/casbin_redis_adapter/)
[](https://pypi.org/project/casbin_redis_adapter/)
[](https://discord.gg/S5UjpzGZjN)
Redis Adapter is the [redis](https://redis.io/) adapter for [PyCasbin](https://github.com/casbin/pycasbin). With this
library, Casbin can load policy from redis or save policy to it.
## Installation
```
pip install casbin_redis_adapter
```
## Simple Example
```python
import casbin_redis_adapter
import casbin
adapter = casbin_redis_adapter.Adapter('localhost', 6379)
e = casbin.Enforcer('path/to/model.conf', adapter, True)
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 data1casbin_sqlalchemy_adapter
pass
else:
# deny the request, show an error
pass
```
## Configuration
`Adapter()` enable decode_responses by default and supports any Redis parameter configuration.
To use casbin_redis_adapter, you must provide the following parameter configuration
- `host`: address of the redis service
- `port`: redis service port
The following parameters are provided by default
- `db`: redis database, default is `0`
- `username`: redis username, default is `None`
- `password`: redis password, default is `None`
- `key`: casbin rule to store key, default is `casbin_rules`
For more parameters, please follow [redis-py](https://redis.readthedocs.io/en/stable/connections.html#redis.Redis)
### Getting Help
- [PyCasbin](https://github.com/casbin/pycasbin)
### License
This project is licensed under the [Apache 2.0 license](LICENSE).