SQLAlchemy async backend for varco — runtime ORM generation, repository, schema guard, and Alembic helpers
Project description
varco-sa
SQLAlchemy async backend for varco.
Generates SQLAlchemy ORM classes at runtime from your DomainModel subclasses — no hand-written ORM models needed. Requires varco-core.
Install
pip install varco-sa
# With PostgreSQL async driver:
pip install "varco-sa[postgresql]"
# With SQLite (tests / local dev):
pip install "varco-sa[sqlite]"
Features
- Zero-boilerplate ORM —
SAModelFactorygeneratesDeclarativeBasesubclasses at runtime; no duplication between domain and ORM layers - Full async repository —
AsyncSQLAlchemyRepositoryimplementsAsyncRepository(CRUD,exists(),stream_by_query()with server-side cursor) - Unit of Work —
SQLAlchemyUnitOfWorkmanagesAsyncSessionlifecycle and atomic commits - One-liner bootstrap —
SAFastrestApp+SAConfigwire engine, session factory, ORM generation, and table creation - Alembic integration —
get_target_metadata()andprint_create_ddl()helpers for migration scripts - Schema Guard —
SchemaGuarddetects drift between ORM metadata and the live database schema - Query integration — accepts
varco-coreQueryParams/QueryBuilderAST natively; translates to SQLAlchemywhere()clauses
What's in the package
| Module | Purpose |
|---|---|
factory.py |
SAModelFactory — generates DeclarativeBase subclasses at runtime; SAModelRegistry — escape hatch |
repository.py |
AsyncSQLAlchemyRepository — AsyncSession-backed CRUD + exists() + stream_by_query() |
uow.py |
SQLAlchemyUnitOfWork — session lifecycle + atomic commits |
provider.py |
SQLAlchemyRepositoryProvider — wires factory + repos + UoW |
bootstrap.py |
SAConfig, SAFastrestApp — one-liner app setup |
alembic_helpers.py |
get_target_metadata, print_create_ddl — Alembic integration |
schema_guard.py |
SchemaGuard — drift detection between ORM metadata and live DB |
Quick start
Bootstrap (one-liner)
from sqlalchemy.ext.asyncio import create_async_engine
from sqlalchemy.orm import DeclarativeBase
from varco_sa import SAConfig, SAFastrestApp
class Base(DeclarativeBase): pass
engine = create_async_engine("postgresql+asyncpg://user:pass@localhost/mydb")
app = SAFastrestApp(SAConfig(
engine=engine,
base=Base,
entity_classes=(User, Post),
))
await app.create_all() # CREATE TABLE IF NOT EXISTS ...
uow_provider = app.uow_provider # ready to inject as IUoWProvider
Manual setup
from sqlalchemy.ext.asyncio import async_sessionmaker
from varco_sa import SQLAlchemyRepositoryProvider
sessions = async_sessionmaker(engine, expire_on_commit=False)
provider = SQLAlchemyRepositoryProvider(engine=engine, session_factory=sessions)
provider.register(User, Post)
await provider.create_all()
async with provider.make_uow() as uow:
user = await uow.users.save(User(name="Edo", email="edo@example.com"))
print(user.pk)
Query integration
from varco_core import QueryBuilder, QueryParams
async with provider.make_uow() as uow:
# exists() — uses SA identity-map cache, no full ORM load when cached
if await uow.posts.exists(post_id):
...
# stream_by_query() — server-side cursor, constant memory regardless of result size
params = QueryParams(node=QueryBuilder().eq("active", True).build())
async for post in uow.posts.stream_by_query(params):
await process(post)
Alembic integration
# alembic/env.py
from varco_sa import get_target_metadata
from myapp.models import User, Post
target_metadata = get_target_metadata(User, Post)
Preview the DDL before running a migration:
from varco_sa import print_create_ddl
print(print_create_ddl(User, Post, dialect="postgresql"))
Schema Guard — detect drift
from varco_sa import SchemaGuard
guard = SchemaGuard(engine, User, Post)
differences = await guard.check()
if differences:
print("Schema drift detected:", differences)
Access the generated SA model (escape hatch)
from varco_sa import SAModelRegistry
from sqlalchemy.orm import relationship
UserORM = SAModelRegistry.get(User)
UserORM.posts = relationship("PostORM", back_populates="author")
Related packages
| Package | Description |
|---|---|
varco-core |
Domain model, service layer, query AST, JWT — required dependency |
varco-beanie |
Beanie / Motor MongoDB backend (alternative to this package) |
Links
- Repository: https://github.com/edoardoscarpaci/varco
- Full docs: https://github.com/edoardoscarpaci/varco#sqlalchemy-backend
- Issue tracker: https://github.com/edoardoscarpaci/varco/issues
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
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 varco_sa-0.0.1.tar.gz.
File metadata
- Download URL: varco_sa-0.0.1.tar.gz
- Upload date:
- Size: 25.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/2.2.1 CPython/3.11.11 Linux/6.6.87.2-microsoft-standard-WSL2
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a9024904232fae1e7b72dac431d252f85dbe47533caab15e21d51c756d714a5f
|
|
| MD5 |
a4ce2a0b1d6046e980343b448ac5df47
|
|
| BLAKE2b-256 |
d6f1f1a21b3e41cdd5b2e7a1f853a1c50b584c1f3154dea32c5f4c9c023b67c3
|
File details
Details for the file varco_sa-0.0.1-py3-none-any.whl.
File metadata
- Download URL: varco_sa-0.0.1-py3-none-any.whl
- Upload date:
- Size: 30.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/2.2.1 CPython/3.11.11 Linux/6.6.87.2-microsoft-standard-WSL2
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
5212e8fe3c3cbd162c19914b74d01f3dd018f433ddfa9d977f4c14d07314d3bc
|
|
| MD5 |
c50c46f49cc7b63931e610070da852f4
|
|
| BLAKE2b-256 |
55fc8a0f84f657e3697cd60194b085dd7a1660897be8d391245f765f4f96fa85
|