Skip to main content

Strong, Simple, and Precise security for Flask APIs (using jwt)

Project description

Latest Published Version Build Status 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 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.6+

  • 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


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

flask-praetorian-1.4.0.tar.gz (18.8 kB view details)

Uploaded Source

Built Distribution

flask_praetorian-1.4.0-py3-none-any.whl (21.3 kB view details)

Uploaded Python 3

File details

Details for the file flask-praetorian-1.4.0.tar.gz.

File metadata

  • Download URL: flask-praetorian-1.4.0.tar.gz
  • Upload date:
  • Size: 18.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.6 CPython/3.8.9 Linux/5.15.0-1019-azure

File hashes

Hashes for flask-praetorian-1.4.0.tar.gz
Algorithm Hash digest
SHA256 fdf7163194d8e6cba0c00584675ed17125f2eb2346087f9c7d10100a8f03cfad
MD5 85e2d3bff0bc4fa5ecc2d9b5a2c8e1c1
BLAKE2b-256 1527c7579df433f6c0ec82ed3f6cb097b3b8ea9ca29d869bbfd0a9856af13509

See more details on using hashes here.

File details

Details for the file flask_praetorian-1.4.0-py3-none-any.whl.

File metadata

  • Download URL: flask_praetorian-1.4.0-py3-none-any.whl
  • Upload date:
  • Size: 21.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.6 CPython/3.8.9 Linux/5.15.0-1019-azure

File hashes

Hashes for flask_praetorian-1.4.0-py3-none-any.whl
Algorithm Hash digest
SHA256 6600988c823baaa2a6c19533c4505bb11b02747389425d0d05d8bb430f466d27
MD5 3a02cc9e3ef3721a629fa32bd4f60a31
BLAKE2b-256 f20c0bcc29d0c6d71122c7923f6aa0abbaff47898cd4cab09509bdb86e1f8a50

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page