Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/shawnmckinney/py-fortress
Role-Based Access Control System for Python implements ANSI INCITS 359
https://github.com/shawnmckinney/py-fortress
access-control apache-fortress authentication authorization fortress ldap rbac role-based-access-control
Last synced: about 2 months ago
JSON representation
Role-Based Access Control System for Python implements ANSI INCITS 359
- Host: GitHub
- URL: https://github.com/shawnmckinney/py-fortress
- Owner: shawnmckinney
- License: apache-2.0
- Created: 2018-02-10T19:24:21.000Z (almost 7 years ago)
- Default Branch: master
- Last Pushed: 2022-09-09T12:56:16.000Z (over 2 years ago)
- Last Synced: 2024-11-01T08:50:38.504Z (2 months ago)
- Topics: access-control, apache-fortress, authentication, authorization, fortress, ldap, rbac, role-based-access-control
- Language: Python
- Homepage: https://pypi.org/project/py-fortress/
- Size: 610 KB
- Stars: 15
- Watchers: 4
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# py-fortress README
_**Fortress Role-Based Access Control**_
![py-fortress](images/Fortressicon.png "fortress rbac")## Document Contents
* Links to Install and Setup Docs
* About py-fortress and Role-Based Access Control
________________________________
## Links to Install and Setup Docs
Located under the [doc](doc) folder and include:| | Link | Description |
|-----|:---------------------------------------------------------------------------------------------------------------|:---------------------------------|
| 1. | [README-BUILDING](https://github.com/shawnmckinney/py-fortress/blob/master/doc/README-BUILDING.md) | To build the package from source |
| 2. | [README-QUICKSTART](https://github.com/shawnmckinney/py-fortress/blob/master/doc/README-QUICKSTART.md) | Beginners start here |
| 3. | [README-LDAP-DOCKER](https://github.com/shawnmckinney/py-fortress/blob/master/doc/README-LDAP-DOCKER.md) | Run LDAP in Docker |
| 4. | [README-INSTALL](https://github.com/shawnmckinney/py-fortress/blob/master/doc/README-INSTALL.md) | Install with PyPI Package |
| 5. | [README-TESTING](https://github.com/shawnmckinney/py-fortress/blob/master/doc/README-TESTING.md) | Run the tests from source |
| 6. | [README-API](https://github.com/shawnmckinney/py-fortress/blob/master/doc/README-API.md) | API Usage Guide |
| 7. | [README-CLI](https://github.com/shawnmckinney/py-fortress/blob/master/doc/README-CLI.md) | CLI for RBAC Admin and Review |
| 8. | [README-CLI-AUTH](https://github.com/shawnmckinney/py-fortress/blob/master/doc/README-CLI-AUTH.md) | CLI for RBAC System Testing |
| 9. | [README-UPGRADE-PYTHON](https://github.com/shawnmckinney/py-fortress/blob/master/doc/README-UPGRADE-PYTHON.md) | python-ldap dependencies |
| 10. | [TROUBLESHOOTING-GUIDE](https://github.com/shawnmckinney/py-fortress/blob/master/doc/TROUBLESHOOTING-GUIDE.md) | Common errors |
_________________________________________________________________________________
## About py-fortress and Role-Based Access Control### About py-fortress
* [Why PY-Fortress?](https://github.com/shawnmckinney/py-fortress/wiki)
* Security access control APIs for the Python3 platform.
* Requires an *LDAP* server to store the policy data. Support for a *File* backend in the works.
* Published to PyPI as [py-fortress](https://pypi.org/project/py-fortress/).
* Compliant with *ANSI INCITS 359* RBAC0, a.k.a "Core RBAC".
* Sponsored by [SYMAS](https://symas.com/)
* Released under [Apache License 2.0](https://www.apache.org/licenses/LICENSE-2.0).#### Links to the API Modules
The following modules have inline code docs describing the API signatures, required attributes and usages.| | Link | Description |
|---|:----------------------------------------------------------------------------------|:-----------------------------------------------------|
|1. | [access](https://github.com/shawnmckinney/py-fortress/blob/master/rbac/access.py) |create session, check access, add, drop active roles |
|2. | [admin](https://github.com/shawnmckinney/py-fortress/blob/master/rbac/admin.py) |add, update, delete, assign, deassign entities |
|3. | [review](https://github.com/shawnmckinney/py-fortress/blob/master/rbac/review.py) |read and search entities and their relationships |
#### Related Project
We're related to the [Apache Fortress](http://directory.apache.org/fortress) Java implementation and share:
* Data Format:
* [Apache Fortress LDAP schema](https://github.com/apache/directory-fortress-core/blob/master/ldap/schema/fortress.schema)
* Exception Ids:
* [org.apache.directory.fortress.core.SecurityException](http://directory.apache.org/fortress/gen-docs/latest/apidocs/org/apache/directory/fortress/core/SecurityException.html)
* Method names and signatures:
* [Interface AccessMgr](http://directory.apache.org/fortress/gen-docs/latest/apidocs/org/apache/directory/fortress/core/AccessMgr.html)
* [Interface AdminMgr](http://directory.apache.org/fortress/gen-docs/latest/apidocs/org/apache/directory/fortress/core/AdminMgr.html)
* [Interface ReviewMgr](http://directory.apache.org/fortress/gen-docs/latest/apidocs/org/apache/directory/fortress/core/ReviewMgr.html)
* Management interfaces. Entries created by one can be processed by the other, and can be managed using Apache Fortress' Web and Rest interfaces:
* [Apache Fortress Web](https://github.com/apache/directory-fortress-commander)
* [Apache Fortress Rest](https://github.com/apache/directory-fortress-enmasse)
The Apache Fortress Core has capabilities that py-fortress doesn't, like Hierarchical Roles (RBAC1), Static Separation of Duties (RBAC2) and Dynamic Separation of Duties (RBAC3).
### About Role-Based Access Control
![RBAC Core](images/RbacCore.png "RBAC0 - The 'Core'")
* Many-to-many relationship between Users, Roles and Permissions. Selective Role activation into Sessions. API to
add, update, delete and search entity data; perform access control decisions during runtime.
* Link to [ANSI INCITS 359 Specification](http://profsandhu.com/journals/tissec/ANSI+INCITS+359-2004.pdf)#### More RBAC info
* [Intro to RBAC](http://directory.apache.org/fortress/user-guide/1-intro-rbac.html)
* [The Seven Steps of Role Engineering](https://iamfortress.net/2015/03/05/the-seven-steps-of-role-engineering/)