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, authmodels/: User, OAuth, email verification, blob storage modelsservices/: Email (Mailjet), blob storage (S3)tasks/: Background job infrastructurecli/: CLI framework with scaffold, run, db commandsconfig.py: Pydantic settings managementmongo.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 send_email
# 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:
Package Ecosystem
Vibetuner consists of three packages that work together:
- vibetuner (this package): Python framework and dependencies
- @alltuner/vibetuner: JavaScript/CSS build dependencies
- 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:
License
MIT License - Copyright (c) 2025 All Tuner Labs, S.L.
See LICENSE for details.
Links
- Main Repository: https://github.com/alltuner/vibetuner
- Documentation: https://vibetuner.alltuner.com/
- Issues: https://github.com/alltuner/vibetuner/issues
- PyPI: https://pypi.org/project/vibetuner/
- npm Package: https://www.npmjs.com/package/@alltuner/vibetuner
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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file vibetuner-8.2.0.tar.gz.
File metadata
- Download URL: vibetuner-8.2.0.tar.gz
- Upload date:
- Size: 105.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.10.2 {"installer":{"name":"uv","version":"0.10.2","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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f47299fa449453b59ed4924eddf7853fbe4cf829b29d1d28d0bf5ffbacf6763c
|
|
| MD5 |
46ade2c465d0fa736aa9a17461a93d04
|
|
| BLAKE2b-256 |
e26acdfd753f6707ed0cda9e340641a153e65744e10190af4ae1fa529c1733a4
|
File details
Details for the file vibetuner-8.2.0-py3-none-any.whl.
File metadata
- Download URL: vibetuner-8.2.0-py3-none-any.whl
- Upload date:
- Size: 136.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.10.2 {"installer":{"name":"uv","version":"0.10.2","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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
dc030946d91c66cf20aae1ebc228de375961e71eef478115fa3ef042cb631204
|
|
| MD5 |
e99c95cac992757727291a62b100b6f2
|
|
| BLAKE2b-256 |
8ac4c37778330e0d81289d172909c8880c937022820c859ebc5b46b183833483
|