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.1.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.1-py3-none-any.whl (39.4 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: fastapi_myauth-1.1.1.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.1.tar.gz
Algorithm Hash digest
SHA256 883c8d9c31ad009806c2465b439a0ee1ead9c3df571c782f312175d1c8e884c0
MD5 26ff8d1d5dd3c4dd9a6850c2c3f00d86
BLAKE2b-256 e4e0f7afdaa2d9c25f563e73975b3ca7c452fd341aaf1ef6b2cdd9ecf896b3dc

See more details on using hashes here.

Provenance

The following attestation bundles were made for fastapi_myauth-1.1.1.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.1-py3-none-any.whl.

File metadata

  • Download URL: fastapi_myauth-1.1.1-py3-none-any.whl
  • Upload date:
  • Size: 39.4 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.1-py3-none-any.whl
Algorithm Hash digest
SHA256 cd032c3d63f1c2805f74b6f1877fdc40cb05ef027b8a17a133b9bdaa41b7f04f
MD5 1a8d68cf837de21aecf426e5cf3b4951
BLAKE2b-256 8239951f2bbc6ec5fac22eb180755203835efc4d68a51d1476bff60f3a1f534c

See more details on using hashes here.

Provenance

The following attestation bundles were made for fastapi_myauth-1.1.1-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