Strong, Simple, and Precise security for Flask APIs (using jwt)
Project description
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 verification
All 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
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file flask_praetorian-1.6.1.tar.gz
.
File metadata
- Download URL: flask_praetorian-1.6.1.tar.gz
- Upload date:
- Size: 18.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.4.1 CPython/3.8.18 Linux/6.5.0-1025-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | a4cbbac830f2138059001d8028cc9504a8c1920928e36d56436fb2c7b22d4ed2 |
|
MD5 | 4de90be89da6dfc8795a3052bd008254 |
|
BLAKE2b-256 | 86f3fb82c8893433c7c15ff6b74e0940c4da6c4c13813a01d357447898eb70dd |
File details
Details for the file flask_praetorian-1.6.1-py3-none-any.whl
.
File metadata
- Download URL: flask_praetorian-1.6.1-py3-none-any.whl
- Upload date:
- Size: 20.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.4.1 CPython/3.8.18 Linux/6.5.0-1025-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 0842b1045fb3380f7d1583d3d6525b3df64157396c752f5552a4b90d23426b67 |
|
MD5 | d128365d458411c4a608354c22ec7a3a |
|
BLAKE2b-256 | 7058e1d863ca6ecf90b6a2bd03580b327624fb6ed1888fb0d9a253ad6376f6d6 |