Skip to content

nachovoss/hatchback

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 

History

46 Commits
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Animated_Logo_GIF_Creation-ezgif com-video-to-gif-converter

The high-performance, drift-ready boilerplate for FastAPI.

Hatchback is a powerful CLI tool designed to bootstrap and manage production-ready FastAPI applications. It comes pre-loaded with best practices, security hardening, and a modular architecture that scales.

✨ Features

  • πŸš€ Production Ready: SQLAlchemy 2.0, Pydantic v2, and Alembic pre-configured.
  • πŸ›‘οΈ Secure by Default: Rate limiting (SlowAPI), hardened Auth (JWT), secure secret generation, and non-root Docker containers.
  • ⚑ Blazing Fast: Optional uv support for lightning-fast dependency management.
  • πŸ—οΈ Clean Architecture: Service-Repository pattern for maintainable code.
  • βœ… Testing Ready: Integrated pytest setup with hbk test.
  • 🐳 Dockerized: Ready-to-deploy docker-compose setup with healthchecks.
  • πŸ€– AI-Powered: Built-in Agent Skills for GitHub Copilot and VS Code agent mode.
  • 🏎️ Drift Mode: A CLI that drives as good as it looks.

πŸ“¦ Installation

pip install hatchback

Tip: Use hbk as a shortcut for hatchback β€” all commands work with either. For example, hbk make product is equivalent to hatchback make product.

🏁 Quick Start

1. Initialize a new project

hbk init my_project_name

You will be prompted for:

  • Database Name
  • Docker inclusion
  • uv usage (if installed, for faster setup)

Options:

  • --use-uv: Force usage of uv for virtualenv creation.
  • --no-docker: Skip Docker file generation.

2. Start the Engine

Before hitting the gas, ensure your database is running and the schema is initialized.

1. Start Database:

cd my_project_name
docker-compose up -d db

(Or configure a local Postgres instance in .env)

2. Initialize Database: Create and apply the first migration for the built-in models (User, Tenant).

hbk migrate create -m "initial_setup"
hbk migrate apply

3. Run Server: Start the development server with hot-reloading.

hbk run

πŸŽ‰ Success! Your API is now live.

3. Scaffold Resources

Don't write boilerplate. Generate Models, Schemas, Repositories, Services, and Routes in one go. Hatchback automatically registers your new routes and services, so they are ready to use immediately.

hbk make product

4. Remove Resources

Changed your mind? Remove a scaffolded resource and clean up all imports automatically.

hbk remove product          # asks for confirmation
hbk remove product --force  # skips confirmation

5. Manage Migrations

Wrapper around Alembic to keep your database in sync.

# Create a migration
hbk migrate create -m "add products table"

# Apply migrations
hbk migrate apply

# Rollback the last migration
hbk migrate downgrade

# Rollback multiple steps
hbk migrate downgrade -r -2

# Rollback everything
hbk migrate downgrade -r base

6. Seed Data

Populate your database with initial data (default tenant and admin user).

hbk seed

7. Import Existing Database

Have an existing database? Hatchback can inspect it and generate your entire project architecture automatically.

# Output models only to a file
hbk inspect --url postgresql://user:pass@localhost:5432/mydb --output app/models/legacy.py

# Full Scaffold Mode (Recommended)
# Generates Models, Services, Repositories, Schemas, and Routes for every table
hbk inspect --scaffold --url postgresql://user:pass@localhost:5432/mydb

8. Upgrade Existing Projects

After upgrading Hatchback, sync the latest agent skills and infrastructure files into your project.

pip install --upgrade hatchback
hbk upgrade

This syncs new files (like agent skills) without touching your Docker config, user code, or environment files.

9. Run Tests

Hatchback projects come with pytest configured.

hbk test

πŸ—οΈ Architecture Explained

Hatchback follows a Service-Repository pattern to keep your code modular and testable.

  1. Routes (app/routes/): Handle HTTP requests/responses and dependency injection. They delegate business logic to Services.
  2. Services (app/services/): Contain the business logic. They orchestrate data operations using Repositories.
  3. Repositories (app/repositories/): Handle direct database interactions (CRUD). They abstract the SQL/ORM details from the rest of the app.
  4. Models (app/models/): SQLAlchemy database definitions.
  5. Schemas (app/schemas/): Pydantic validation and serialization schemas.

πŸ€– Agent Skills

Hatchback projects ship with built-in Agent Skills in .github/skills/:

  • hatchback β€” Full project overview, CLI commands, database config, auth system, and conventions.
  • clean-architecture β€” Layered architecture rules, code examples, anti-patterns, and testing patterns.

These help AI coding assistants (GitHub Copilot, VS Code agent mode) understand your project structure and follow established patterns automatically.

πŸ“‚ Project Structure

my_project/
β”œβ”€β”€ .github/
β”‚   └── skills/       # Agent Skills for AI assistants
β”œβ”€β”€ app/
β”‚   β”œβ”€β”€ config/       # Database, Security, Limiter config
β”‚   β”œβ”€β”€ models/       # SQLAlchemy Database Models
β”‚   β”œβ”€β”€ schemas/      # Pydantic Data Schemas
β”‚   β”œβ”€β”€ repositories/ # Data Access Layer (CRUD)
β”‚   β”œβ”€β”€ services/     # Business Logic
β”‚   β”œβ”€β”€ routes/       # API Endpoints
β”‚   β”œβ”€β”€ dependencies.py
β”‚   └── main.py
β”œβ”€β”€ alembic/          # Database Migrations
β”œβ”€β”€ tests/            # Pytest Suite
β”œβ”€β”€ docker-compose.yml
└── requirements.txt

πŸ›‘οΈ Security Features

  • Rate Limiting: Built-in protection against brute-force attacks.
  • Secure Headers: Trusted host middleware configuration.
  • Password Hashing: Argon2/Bcrypt support via Passlib.
  • Docker Security: Runs as a non-root user to prevent container breakout.

πŸ”§ CLI Reference

Command Description
hbk init <name> Initialize a new project
hbk run Start dev server with hot-reload
hbk make <resource> Scaffold a new resource
hbk remove <resource> Remove a resource and clean up imports
hbk migrate create -m "msg" Create a new Alembic migration
hbk migrate apply Apply pending migrations
hbk migrate downgrade Rollback last migration (-r -2 for multiple)
hbk seed Seed database with initial data
hbk inspect --url <db_url> Inspect existing DB and generate models
hbk upgrade Sync latest skills and infra files
hbk test Run the test suite

Built with πŸ’– and 🏎️ by Ignacio Bares(nachovoss) and the Hatchback Team.

Support

Hatchback is an open-source project. If you'd like to support the development, you can donate via Bitcoin:

BTC Address: \bc1q9fznxyf0skq8ux5ysrggw3veuqf92xtr25cccq\

Bitcoin QR Code

Thank you for your support!

About

No description, website, or topics provided.

Resources

License

Code of conduct

Contributing

Security policy

Stars

Watchers

Forks

Packages

 
 
 

Contributors