Skip to main content

No project description provided

Project description

๐Ÿ” FastSecForge

FastSecForge is a robust, pluggable Python security boilerplate generator built on top of FastAPI, SQLAlchemy, and MongoDB. It provides JWT authentication, user management, and a powerful CLI (typer) to scaffold fully functional, secure project templates in one command.


๐Ÿš€ Features

  • ๐Ÿ”‘ JWT Authentication with secure password hashing (passlib[bcrypt])
  • ๐Ÿงฉ Supports SQL (SQLAlchemy) & MongoDB (Motor)
  • ๐Ÿ“ฆ Pydantic v2+ for type-safe data validation and settings
  • ๐Ÿ”ง Typer-based CLI for instant FastAPI boilerplate creation
  • โ™ป๏ธ Async-ready architecture optimized for performance
  • ๐Ÿ” Security best practices out of the box (OAuth2 flows, CORS, rate limiting)

๐Ÿ“ฆ Installation

Install FastSecForge from PyPI:

pip install fastsecforge

Or install in editable mode from source:

git clone https://github.com/your-org/fastsecforge.git
cd fastsecforge
python -m venv venv
source venv/bin/activate    # Windows: venv\\Scripts\\activate
pip install -e .            # editable mode

๐Ÿ› ๏ธ CLI Usage

FastSecForge exposes one primary command: new_project. This will scaffold a complete FastAPI project for you.

fastsecforge new_project <project_name>
  • <project_name>: Name of the new project (also used as package name).

After running this, you will have:

<project_name>/
โ””โ”€โ”€ src/
    โ””โ”€โ”€ <project_name>/
        โ”œโ”€โ”€ __init__.py
        โ”œโ”€โ”€ main.py          # FastAPI app entrypoint
        โ”œโ”€โ”€ config.py        # Settings loader
        โ”œโ”€โ”€ database.py      # DB session & models
        โ”œโ”€โ”€ core/
        โ”‚   โ”œโ”€โ”€ __init__.py
        โ”‚   โ””โ”€โ”€ security.py  # Auth, password hashing, JWT utilities
        โ”œโ”€โ”€ models/
        โ”‚   โ”œโ”€โ”€ __init__.py
        โ”‚   โ””โ”€โ”€ user.py      # User ORM models
        โ”œโ”€โ”€ routers/
        โ”‚   โ”œโ”€โ”€ __init__.py
        โ”‚   โ”œโ”€โ”€ auth.py      # Authentication routes
        โ”‚   โ””โ”€โ”€ users.py     # User management routes
        โ”œโ”€โ”€ schemas/
        โ”‚   โ”œโ”€โ”€ __init__.py
        โ”‚   โ””โ”€โ”€ user.py      # Pydantic schemas
        โ””โ”€โ”€ templates/      # Additional template assets

๐Ÿš€ Running the Generated Project

  1. Navigate into the new project

    cd <project_name>
    
  2. Create & activate a virtual environment

    python -m venv venv
    source venv/bin/activate    # Windows: venv\\Scripts\\activate
    
  3. Install dependencies

    pip install -r requirements.txt
    
  4. Configure environment variables

    • Rename .env.example to .env
    • Fill in your database URIs, JWT secret key, and other settings
  5. Start the development server

    uvicorn src.<project_name>.main:app --reload
    

    Your API will be available at http://127.0.0.1:8000 with interactive docs at http://127.0.0.1:8000/docs.


๐Ÿงช Tests (Optional)

If you scaffold tests, run:

pytest

๐Ÿ“œ License

This project is licensed under the MIT License.


๐Ÿค Contributing

Contributions welcome! Open an issue or submit a pull request against main.

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

fastsecforge-0.1.0.tar.gz (12.7 kB view details)

Uploaded Source

Built Distribution

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

fastsecforge-0.1.0-py3-none-any.whl (17.8 kB view details)

Uploaded Python 3

File details

Details for the file fastsecforge-0.1.0.tar.gz.

File metadata

  • Download URL: fastsecforge-0.1.0.tar.gz
  • Upload date:
  • Size: 12.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.11.4

File hashes

Hashes for fastsecforge-0.1.0.tar.gz
Algorithm Hash digest
SHA256 8f6081beca99ae362c6855c688043467f939d38e44cecba87777ccf7e06635eb
MD5 d852f9d6139be851d3cc29c299236187
BLAKE2b-256 8b3cf094a8ac78100b263a4c65d862086477e20552e3ab7cd72db8a42a186195

See more details on using hashes here.

File details

Details for the file fastsecforge-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: fastsecforge-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 17.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.11.4

File hashes

Hashes for fastsecforge-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 f4570e2d596472dabe2731b0509b57689e841b6866ed53556bd2f66bab3a9977
MD5 ed94944f31ce96faf62fe1e38a4237cc
BLAKE2b-256 3c39df227fc0eedfc0da92a037a169379e64ca888da1d28b05b754ab4b22b095

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