Skip to main content

Ready to use and customizable Authentications and Oauth2 management for FastAPI

Project description

AuthX

AuthX

Ready-to-use and customizable Authentications and Oauth2 management for FastAPI ⚡


Project Status
CI CI pre-commit.ci status Codecov
Meta Package version Downloads Pydantic Version 2 Ruff Quality Gate Status

Source Code: https://github.com/yezz123/authx

Documentation: https://authx.yezz.me/


Add a fully featured authentication and authorization system to your FastAPI project. AuthX is designed to be simple, customizable, and secure.

Installation

pip install authx

Quick Start

from fastapi import FastAPI, Depends, HTTPException
from authx import AuthX, AuthXConfig

app = FastAPI()

config = AuthXConfig(
    JWT_SECRET_KEY="your-secret-key",  # Change this!
    JWT_TOKEN_LOCATION=["headers"],
)

auth = AuthX(config=config)
auth.handle_errors(app)

@app.post("/login")
def login(username: str, password: str):
    if username == "test" and password == "test":
        token = auth.create_access_token(uid=username)
        return {"access_token": token}
    raise HTTPException(401, detail="Invalid credentials")

@app.get("/protected", dependencies=[Depends(auth.access_token_required)])
def protected():
    return {"message": "Hello World"}

Test it:

# Get a token
curl -X POST "http://localhost:8000/login?username=test&password=test"

# Access protected route
curl -H "Authorization: Bearer <your-token>" http://localhost:8000/protected

Features

  • Support for Python 3.9+ and Pydantic 2
  • JWT authentication with multiple token locations:
    • Headers (Bearer token)
    • Cookies (with CSRF protection)
    • Query parameters
    • JSON body
  • Access and refresh token support
  • Token freshness for sensitive operations
  • Token blocklist/revocation
  • Extensible error handling

Extra Features

Install authx-extra for additional features:

pip install authx-extra
  • Redis session store and cache
  • HTTP caching
  • Performance profiling with pyinstrument
  • Prometheus metrics

Note: Check Release Notes.

Contributors and Sponsors

All Contributors

Thanks goes to these wonderful people (emoji key):

Yasser Tahiri
Yasser Tahiri

💻 📖 🚧 🚇
Abderrahim SOUBAI-ELIDRISI
Abderrahim SOUBAI-ELIDRISI

👀 📖
Ismail Ghallou
Ismail Ghallou

💻 🛡️
MojixCoder
MojixCoder

💻 🐛
Stéphane Raimbault
Stéphane Raimbault

💻 🔌
theoohoho
theoohoho

📖
Yogesh Upadhyay
Yogesh Upadhyay

🐛
Roman
Roman

🐛
Alvaro Lopez Ortega
Alvaro Lopez Ortega

📖
Devy Santo
Devy Santo

🚇
pg365
pg365

🚇
Jorrit
Jorrit

📦
Callam
Callam

💻
Maxim
Maxim

💻
Suyog Shimpi
Suyog Shimpi

💻
NeViNez
NeViNez

🐛
Antareske
Antareske

💻

This project follows the all-contributors specification. Contributions of any kind welcome!

License

This project is licensed under the terms of the MIT License.

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

authx-1.6.0.tar.gz (82.7 kB view details)

Uploaded Source

Built Distribution

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

authx-1.6.0-py3-none-any.whl (36.8 kB view details)

Uploaded Python 3

File details

Details for the file authx-1.6.0.tar.gz.

File metadata

  • Download URL: authx-1.6.0.tar.gz
  • Upload date:
  • Size: 82.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for authx-1.6.0.tar.gz
Algorithm Hash digest
SHA256 49a70580c7207b19ba9378a8938ede2686bb320ccddc003c90284b7c514d8193
MD5 8dc9e1f6b69a7112b1af4806c05f67e3
BLAKE2b-256 0fa7a3ffe518c03e39a487049cd6e7ede82651f2e17cf9255cfa387b47b674b3

See more details on using hashes here.

Provenance

The following attestation bundles were made for authx-1.6.0.tar.gz:

Publisher: release.yml on yezz123/authx

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file authx-1.6.0-py3-none-any.whl.

File metadata

  • Download URL: authx-1.6.0-py3-none-any.whl
  • Upload date:
  • Size: 36.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for authx-1.6.0-py3-none-any.whl
Algorithm Hash digest
SHA256 a4e50c9800ff49253954fce31b62ad471459d6ffdeed4baafa22ebd0826b111e
MD5 69207b17ccbe727460b980380e98093c
BLAKE2b-256 c30f91e1aea288b7fd9d31eccfb57e1a2eb702f87232b292d13fdf3533443b5f

See more details on using hashes here.

Provenance

The following attestation bundles were made for authx-1.6.0-py3-none-any.whl:

Publisher: release.yml on yezz123/authx

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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