Skip to main content

Core Python framework and blessed dependencies for production-ready FastAPI + MongoDB + HTMX projects

Project description

vibetuner

Core Python framework and blessed dependencies for Vibetuner projects

This package provides the complete Python framework and curated dependency set for building modern web applications with Vibetuner. It includes everything from FastAPI and MongoDB integration to authentication, background jobs, and CLI tools.

What is Vibetuner?

Vibetuner is a production-ready scaffolding tool for FastAPI web applications. This package (vibetuner) is the Python component that provides:

  • Complete web application framework built on FastAPI
  • Flexible database support: MongoDB (Beanie ODM) or SQL (SQLModel/SQLAlchemy)
  • OAuth and magic link authentication out of the box
  • Background job processing with Redis + Streaq (optional)
  • CLI framework with Typer
  • Email services, blob storage, and more

This package is designed to be used within projects generated by the Vibetuner scaffolding tool. For standalone use, you'll need to set up the project structure manually.

Installation

# In a Vibetuner-generated project (automatic)
uv sync

# Add to an existing project
uv add vibetuner

# With development dependencies
uv add vibetuner[dev]

Quick Start

The recommended way to use Vibetuner is via the scaffolding tool:

# Create a new project with all the framework code
uvx vibetuner scaffold new my-project
cd my-project
just dev

This will generate a complete project with:

  • Pre-configured FastAPI application
  • Authentication system (OAuth + magic links)
  • MongoDB models and configuration
  • Frontend templates and asset pipeline
  • Docker setup for development and production
  • CLI commands and background job infrastructure

What's Included

Core Framework (src/vibetuner/)

  • frontend/: FastAPI app, routes, middleware, auth
  • models/: User, OAuth, email verification, blob storage models
  • services/: Email (Mailjet), blob storage (S3)
  • tasks/: Background job infrastructure
  • cli/: CLI framework with scaffold, run, db commands
  • config.py: Pydantic settings management
  • mongo.py: MongoDB/Beanie setup (optional)
  • sqlmodel.py: SQLModel/SQLAlchemy setup (optional)
  • logging.py: Structured logging configuration

Blessed Dependencies

  • FastAPI (0.121+): Modern, fast web framework
  • Beanie: Async MongoDB ODM with Pydantic (optional)
  • SQLModel + SQLAlchemy: SQL databases - PostgreSQL, MySQL, SQLite (optional)
  • Authlib: OAuth 1.0/2.0 client
  • Granian: High-performance ASGI server
  • Redis + Streaq: Background task processing (optional)
  • Typer: CLI framework
  • Rich: Beautiful terminal output
  • Loguru: Structured logging
  • Pydantic: Data validation and settings

See pyproject.toml for the complete dependency list.

CLI Tools

When installed, provides the vibetuner command:

# Create new project from template
vibetuner scaffold new my-project
vibetuner scaffold new my-project --defaults

# Update existing project
vibetuner scaffold update

# Database management (SQLModel)
vibetuner db create-schema    # Create SQL database tables

# Run development server (in generated projects)
vibetuner run dev frontend
vibetuner run dev worker

# Run production server (in generated projects)
vibetuner run prod frontend
vibetuner run prod worker

Development Dependencies

The [dev] extra includes all tools needed for development:

  • Ruff: Fast linting and formatting
  • Babel: i18n message extraction
  • pre-commit: Git hooks (prek is a fast pre-commit drop-in replacement)
  • Type stubs: For aioboto3, authlib, PyYAML
  • And more...

Usage in Generated Projects

In a Vibetuner-generated project, import from vibetuner:

# Use core models
from vibetuner.models import UserModel, OAuthAccountModel

# Use services
from vibetuner.services.email import EmailService

# Use configuration
from vibetuner.config import settings

# Extend core routes
from vibetuner.frontend import app

# Add your routes
@app.get("/api/hello")
async def hello():
    return {"message": "Hello World"}

Documentation

For complete documentation, guides, and examples, see the main Vibetuner repository:

📖 Vibetuner Documentation

Package Ecosystem

Vibetuner consists of three packages that work together:

  1. vibetuner (this package): Python framework and dependencies
  2. @alltuner/vibetuner: JavaScript/CSS build dependencies
  3. Scaffolding template: Copier template for project generation

All three are version-locked and tested together to ensure compatibility.

Contributing

Contributions welcome! See the main repository for contribution guidelines:

🤝 Contributing to Vibetuner

License

MIT License - Copyright (c) 2025 All Tuner Labs, S.L.

See LICENSE for details.

Links

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

vibetuner-10.8.0.tar.gz (182.6 kB view details)

Uploaded Source

Built Distribution

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

vibetuner-10.8.0-py3-none-any.whl (222.4 kB view details)

Uploaded Python 3

File details

Details for the file vibetuner-10.8.0.tar.gz.

File metadata

  • Download URL: vibetuner-10.8.0.tar.gz
  • Upload date:
  • Size: 182.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.11.8 {"installer":{"name":"uv","version":"0.11.8","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for vibetuner-10.8.0.tar.gz
Algorithm Hash digest
SHA256 806a8b4c2ed09475380baaf2f0fb9485db28647f08e81900f2ce2bcfb027f898
MD5 6105417e531a2064f6ff664dd24b3895
BLAKE2b-256 b13ae2977859e627988a29ab01410dbb295b22eeddafa6f6c5449ca50a60547d

See more details on using hashes here.

File details

Details for the file vibetuner-10.8.0-py3-none-any.whl.

File metadata

  • Download URL: vibetuner-10.8.0-py3-none-any.whl
  • Upload date:
  • Size: 222.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.11.8 {"installer":{"name":"uv","version":"0.11.8","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for vibetuner-10.8.0-py3-none-any.whl
Algorithm Hash digest
SHA256 6407a5905b419cc6c1de3ab6b8aae3f78959ee51eb08f2a640c051166b5abfae
MD5 a3029c96246d33cbec71bc9a6bbdd58d
BLAKE2b-256 6dae67fe280e8627f1e5d99c5f502a90f8d44ace23813c643058cab8e9d184d5

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