Skip to main content

A flexible and secure authentication library for FastAPI.

Project description

FastAPI MyAuth

PyPI version Python Version License: MIT Ruff codecov

A flexible and secure authentication library for FastAPI, designed to integrate seamlessly with your existing SQLModel ORM. FastAPI MyAuth provides robust features including:

  • User Management: CRUD operations for users, including activation/deactivation.
  • Authentication Methods:
    • Traditional email/password login.
    • Magic link based login for a passwordless experience.
    • Refresh token mechanism for extended sessions without re-authenticating.
  • Security Features:
    • Password hashing with Argon2.
    • JSON Web Token (JWT) based authentication.
    • Two-Factor Authentication (TOTP) support.
    • Password recovery flows.
  • Email Integration: Templates and functions for sending various authentication-related emails (e.g., password reset, magic links).
  • Role-Based Access Control (RBAC): Easily add roles to users and protect endpoints based on these roles.
  • Extensible: Designed with generics to allow customization of the User model and integration with existing database sessions.

🚀 Getting Started

To quickly integrate FastAPI MyAuth into your FastAPI application, install it via pip:

pip install fastapi_myauth

Then, you can typically set up the authentication router in your FastAPI application like this:

from fastapi import FastAPI
from sqlmodel import Session, create_engine, SQLModel

from fastapi_myauth import models
from fastapi_myauth.auth import FastAuth
from fastapi_myauth.config import settings

app = FastAPI()

# Your database engine setup (example for SQLite)
sqlite_file_name = "database.db"
sqlite_url = f"sqlite:///{sqlite_file_name}"
engine = create_engine(sqlite_url, echo=True)

def create_db_and_tables():
    SQLModel.metadata.create_all(engine)

# Dependency to get a database session
def get_db():
    with Session(engine) as session:
        yield session

# Initialize FastAuth with your custom User model (or use default)
# You can extend models.User, models.UserCreate, models.UserRead, models.UserUpdate
# to add custom fields. For example, if you want a `language` field:
class MyUser(models.User, table=True): # Important: table=True on your concrete user model
    language: str = "en"

class MyUserRead(models.UserRead):
    language: str

class MyUserCreate(models.UserCreate):
    language: str | None = None

class MyUserUpdate(models.UserUpdate):
    language: str | None = None


fast_auth = FastAuth(
    get_db=get_db,
    user_model=MyUser,
    user_read=MyUserRead,
    user_create=MyUserCreate,
    user_update=MyUserUpdate,
)

# Call this once your app starts, e.g., in a startup event or directly
create_db_and_tables()

# Include the authentication router
app.include_router(fast_auth.get_router())

@app.on_event("startup")
def on_startup():
    # Initialize the first superuser if not exists
    with Session(engine) as session:
        crud_user = fast_auth.crud_user()
        user = crud_user.get_by_email(session, email=settings.FIRST_SUPERUSER)
        if not user:
            user_in = MyUserCreate(
                email=settings.FIRST_SUPERUSER,
                password=settings.FIRST_SUPERUSER_PASSWORD,
                is_superuser=True,
                language="en" # Set default for custom field
            )
            crud_user.create(session, obj_in=user_in)

# Example protected endpoint
from fastapi import Depends
from fastapi_myauth.api.deps import APIDependencies

# Get dependency instance from your fast_auth object
deps_instance = fast_auth.deps()

@app.get("/protected-route")
def read_protected_route(
    current_user: MyUserRead = Depends(deps_instance.get_current_active_user)
):
    return {"message": f"Hello, {current_user.email}! This is a protected route."}

For more detailed usage instructions, configuration options, and advanced customization, please refer to the Usage Documentation.

🌳 Project Structure

fastapi_myauth/
├── api/                  # FastAPI routers and dependencies for REST API endpoints
│   ├── v1/               # Versioned API endpoints (e.g., login, users)
│   └── deps.py           # FastAPI dependency injection for auth components
├── crud/                 # CRUD operations for database models
│   ├── base.py           # Generic CRUD base class
│   ├── crud_token.py     # CRUD for refresh tokens
│   └── crud_user.py      # CRUD for user operations
├── email/                # Email sending utilities and templates
├── models/               # Pydantic/SQLModel definitions for data structures
├── security.py           # Password hashing, JWT handling, TOTP
├── config.py             # Application settings
├── auth.py               # Main FastAuth class for setup and router inclusion
└── test_main.py          # Example FastAPI app for testing and demonstration

📚 Documentation

Detailed documentation is available in the docs directory:

  • Usage Documentation: Learn how to install, configure, and use the fastapi_myauth library in your projects.
  • Development & Contributing: Information for developers interested in contributing to the project, including setup instructions and coding standards.

✨ Features at a Glance

  • FastAPI Integration: Designed exclusively for FastAPI.
  • SQLModel Native: Works seamlessly with SQLModel for ORM operations.
  • Secure Authentication: Built with modern security practices (Argon2 for passwords, JWTs).
  • Email Management: Integrated email sending for common auth flows.
  • Customizable User Model: Easily extendable User model to fit specific application needs.
  • Dependency Injection: Leverages FastAPI's dependency injection system for robust and testable code.

🤝 Contributing

Contributions are welcome! Please see our Contributing Guide for details on how to get started.

📄 License

This project is licensed under the MIT License - see the LICENSE file for details.

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

fastapi_myauth-1.1.2.tar.gz (106.4 kB view details)

Uploaded Source

Built Distribution

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

fastapi_myauth-1.1.2-py3-none-any.whl (39.3 kB view details)

Uploaded Python 3

File details

Details for the file fastapi_myauth-1.1.2.tar.gz.

File metadata

  • Download URL: fastapi_myauth-1.1.2.tar.gz
  • Upload date:
  • Size: 106.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for fastapi_myauth-1.1.2.tar.gz
Algorithm Hash digest
SHA256 56478855edef3576717be338c1ced8d32b332157db252561b3360263e205225e
MD5 46feb75428e268eca3230d6f70ccb209
BLAKE2b-256 5dee8dabdf24c407f4d51ed806e04472a21ef7e7b18c5012317d69a38a1f2b8c

See more details on using hashes here.

Provenance

The following attestation bundles were made for fastapi_myauth-1.1.2.tar.gz:

Publisher: cd.yml on zonistefano/fastapi_auth

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

File details

Details for the file fastapi_myauth-1.1.2-py3-none-any.whl.

File metadata

  • Download URL: fastapi_myauth-1.1.2-py3-none-any.whl
  • Upload date:
  • Size: 39.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for fastapi_myauth-1.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 469d5cea8e6431b24cbe89fe89d4abc11f67c327c394ee2900dae24ee2172da6
MD5 6fee023d3c7cd18dae0f9b73f1cf96d1
BLAKE2b-256 627b8531784299afcbb04ac8c7595973b543a45690550aa6b3bc9d0c3a57e25e

See more details on using hashes here.

Provenance

The following attestation bundles were made for fastapi_myauth-1.1.2-py3-none-any.whl:

Publisher: cd.yml on zonistefano/fastapi_auth

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