Skip to main content

Simple authentication, authorization and parameters for Flask, emphasizing configurability

Project description

FlaskSimpleAuth: The Secure Flask Framework

FlaskSimpleAuth is a Flask wrapper to add a declarative security layer to routes with authentification, authorization and parameter management.

Status Tests Coverage Issues Python Version Badges License

With FlaskSimpleAuth, application and security concerns are separated:

  • the application focusses on what to do, and declares its security requirements.
  • the configuration declares how the authentification and authorization constraints are checked and provides necessary hook functions.
  • the framework implements and enforces the security on the application routes, with safe defaults so that security cannot be overlooked.

The following Flask application provides two routes:

  • GET /store allows any authenticated user in group employee to access the store list.
  • POST /store/<sid> allows an authenticated user who is a manager of store number sid to add a quantity of product to the store inventory.
# file "app.py"
from FlaskSimpleAuth import Flask

app = Flask("acme")
app.config.from_envvar("ACME_CONFIG")

@app.get("/store", authorize="employee")
def get_store(pattern: str = "%"):
    # return the list of stores matching optional parameter pattern
    return ..., 200

@app.post("/store/<sid>", authorize=("store", "sid", "manager"))
def post_store_sid(sid: int, product: str, quantity: int):
    # product is added in quantity to store sid
    return ..., 201

In this code, there is no clue about how users are authenticated, as this is set from the configuration. Only authorizations are declared on the route with the mandatory authorize parameter. How these are checked is also set from the configuration. HTTP or JSON parameters are automatically converted to the expected type, with features on par with FastAPI.

Authentication and authorizations are provided to the framework with callback functions. For our example, we will need to retrieve the salted hashed password for a user, to check whether a user belongs to a group, and to tell whether a user can access a given store in a particular role:

# file "auth.py"

def get_user_pass(user: str) -> str|None:
    return ...  # hashed password retrieved from somewhere

def user_is_employee(user: str) -> bool:
    return ...  # whether user belongs to group employee

def store_perms(user: str, sid: int, role: str) -> bool|None:
    return ...  # whether user can access store sid in role

Here is an example of configuration for the above application: Users are identified either with a JWT token or with a basic authentification.

# acme configuration
import os
import auth

FSA_MODE = "dev"
FSA_AUTH = ["token", "basic"]
FSA_TOKEN_TYPE = "jwt"
FSA_TOKEN_SECRET = os.environ["ACME_SECRET"]
FSA_GET_USER_PASS = auth.get_user_pass
FSA_GROUP_CHECK = { "employee": auth.user_is_employee }
FSA_OBJECT_PERMS = { "store": auth.store_perms }

The framework will ensure that routes are only called by authenticated users who have the right authorizations. Secure and reasonable defaults are provided. Most features can be adjusted or extended to particular needs through numerous directives and hooks. Authentication and authorization callback invocations are cached for efficiency. Also, pydantic, dataclass and generic type parameters are supported out of the box.

More

License

This code is Public Domain.

All software has bug, this is software, hence… Beware that you may lose your hairs or your friends because of it. If you like it, feel free to send a postcard to the author.

Project details


Release history Release notifications | RSS feed

This version

30.0

Download files

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

Source Distribution

FlaskSimpleAuth-30.0.tar.gz (43.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

FlaskSimpleAuth-30.0-py3-none-any.whl (41.0 kB view details)

Uploaded Python 3

File details

Details for the file FlaskSimpleAuth-30.0.tar.gz.

File metadata

  • Download URL: FlaskSimpleAuth-30.0.tar.gz
  • Upload date:
  • Size: 43.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.12.2

File hashes

Hashes for FlaskSimpleAuth-30.0.tar.gz
Algorithm Hash digest
SHA256 9b558d3bf8c377462471502f3892f070d3dd7c33f86c473a17e162592dc025f9
MD5 4275b36a08109bddcf96f2010c91d55c
BLAKE2b-256 9ca036d9365dba05db891fc7ffefcbc65d9637fe9af29f581dd6f16052797746

See more details on using hashes here.

File details

Details for the file FlaskSimpleAuth-30.0-py3-none-any.whl.

File metadata

  • Download URL: FlaskSimpleAuth-30.0-py3-none-any.whl
  • Upload date:
  • Size: 41.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.0.0 CPython/3.12.2

File hashes

Hashes for FlaskSimpleAuth-30.0-py3-none-any.whl
Algorithm Hash digest
SHA256 cdc86bb828b362b09fb347d2d4ef8d2ca8c8e3bc9ec8aa571a6b1bdca80538b0
MD5 f2cc312afbd37cf70fa163e5b57a3e1d
BLAKE2b-256 70230477bb3f697d410145dcdd1103adf03bbe8467879be8cf1bf4dbcc208f86

See more details on using hashes here.

Supported by

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