Skip to main content

No project description provided

Project description

๐Ÿ” FastSecForge

License: MIT

GitHub: https://github.com/reprompts/fastsecforge

Community: https://dev.to/repromptsquest

LinkedIn: https://www.linkedin.com/groups/14631875/

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/reprompts/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 <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.4.tar.gz (13.6 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.4-py3-none-any.whl (19.0 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: fastsecforge-0.1.4.tar.gz
  • Upload date:
  • Size: 13.6 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.4.tar.gz
Algorithm Hash digest
SHA256 c7952322ba7a6c669ef0cc687b9fd7b75fa4aaef325e7546abfe3ef69e4eaba3
MD5 d20cce03c421211945817066705c3000
BLAKE2b-256 98a8cf5409f83661551ae0c1539bfbc477e506c28d88af0057eaf3a615c75e39

See more details on using hashes here.

File details

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

File metadata

  • Download URL: fastsecforge-0.1.4-py3-none-any.whl
  • Upload date:
  • Size: 19.0 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.4-py3-none-any.whl
Algorithm Hash digest
SHA256 1cb5b7a54f4af82d3c8fae067fa3ac82416809cf8f241a3e5ac23d7ea4932007
MD5 f4b5908c693782eeda165bc29abd39bd
BLAKE2b-256 f9692ef8758650c15c86e22045f512a8111ecf9a25eca0cbe26468850d02b73a

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