Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/dusktreader/flask-praetorian
Strong, Simple, and Precise security for Flask APIs (using jwt)
https://github.com/dusktreader/flask-praetorian
Last synced: 5 days ago
JSON representation
Strong, Simple, and Precise security for Flask APIs (using jwt)
- Host: GitHub
- URL: https://github.com/dusktreader/flask-praetorian
- Owner: dusktreader
- License: mit
- Created: 2016-11-23T16:47:18.000Z (about 8 years ago)
- Default Branch: main
- Last Pushed: 2024-12-24T01:02:23.000Z (22 days ago)
- Last Synced: 2025-01-06T16:13:58.795Z (8 days ago)
- Language: Python
- Homepage: http://flask-praetorian.readthedocs.io/en/latest/
- Size: 3.19 MB
- Stars: 343
- Watchers: 15
- Forks: 46
- Open Issues: 3
-
Metadata Files:
- Readme: README.rst
- Changelog: CHANGELOG.rst
- Contributing: CONTRIBUTING.rst
- License: LICENSE.rst
Awesome Lists containing this project
- awesome-flask - Flask-Praetorian - Strong, Simple, and Precise security for Flask APIs (using jwt) (Authentication)
- awesome-flask - Flask-Praetorian - Strong, Simple, and Precise security for Flask APIs (using jwt) (Authentication)
- awesome-flask - Flask-Praetorian - Strong, Simple, and Precise security for Flask APIs (using jwt) (Authentication)
- jimsghstars - dusktreader/flask-praetorian - Strong, Simple, and Precise security for Flask APIs (using jwt) (Python)
- best-of-web-python - GitHub - 0% open · ⏱️ 11.03.2024): (Authorization & Authentication)
README
.. image:: https://badge.fury.io/py/flask-praetorian.svg
:target: https://badge.fury.io/py/flask-praetorian
:alt: Latest Published Version.. image:: https://travis-ci.org/dusktreader/flask-praetorian.svg?branch=master
:target: https://travis-ci.org/dusktreader/flask-praetorian
:alt: Build Status.. image:: https://readthedocs.org/projects/flask-praetorian/badge/?version=latest
:target: http://flask-praetorian.readthedocs.io/en/latest/?badge=latest
:alt: Documentation Build Status******************
flask-praetorian
******************---------------------------------------------------
Strong, Simple, and Precise security for Flask APIs
---------------------------------------------------API security should be strong, simple, and precise like a Roman Legionary.
This package aims to provide that. Using `JWT `_ tokens as
implemented by `PyJWT `_,
*flask_praetorian* uses a very simple interface to make sure that the users
accessing your API's endpoints are provisioned with the correct roles for
access.This project was heavily influenced by
`Flask-Security `_, but intends
to supply only essential functionality. Instead of trying to anticipate the
needs of all users, *flask-praetorian* will provide a simple and secure mechanism
to provide security for APIs specifically.This extension offers a batteries-included approach to security for your API.
For essential security concerns for Flask-based APIs,
`flask-praetorian `_ should
supply everything you need.The *flask-praetorian* package can be used to:
* Hash passwords for storing in your database
* Verify plaintext passwords against the hashed, stored versions
* Generate authorization tokens upon verification of passwords
* Check requests to secured endpoints for authorized tokens
* Supply expiration of tokens and mechanisms for refreshing them
* Ensure that the users associated with tokens have necessary roles for access
* Parse user information from request headers for use in client route handlers
* Support inclusion of custom user claims in tokens
* Register new users using email verificationAll of this is provided in a very simple to configure and initialize flask
extension. Though simple, the security provided by *flask-praetorian* is strong
due to the usage of the proven security technology of JWT
and python's `PassLib `_ package.Super-quick Start
-----------------
- requirements: `python` versions 3.8+
- install through pip: `$ pip install flask-praetorian`
- minimal usage example: `example/basic.py `_Documentation
-------------The complete documentation can be found at the
`flask-praetorian home page `_