Skip to main content

SQLAlchemy async backend for varco — runtime ORM generation, repository, schema guard, and Alembic helpers

Project description

varco-sa

PyPI version Python License: Apache 2.0 GitHub

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 ORMSAModelFactory generates DeclarativeBase subclasses at runtime; no duplication between domain and ORM layers
  • Full async repositoryAsyncSQLAlchemyRepository implements AsyncRepository (CRUD, exists(), stream_by_query() with server-side cursor)
  • Unit of WorkSQLAlchemyUnitOfWork manages AsyncSession lifecycle and atomic commits
  • One-liner bootstrapSAFastrestApp + SAConfig wire engine, session factory, ORM generation, and table creation
  • Alembic integrationget_target_metadata() and print_create_ddl() helpers for migration scripts
  • Schema GuardSchemaGuard detects drift between ORM metadata and the live database schema
  • Query integration — accepts varco-core QueryParams / QueryBuilder AST natively; translates to SQLAlchemy where() clauses

What's in the package

Module Purpose
factory.py SAModelFactory — generates DeclarativeBase subclasses at runtime; SAModelRegistry — escape hatch
repository.py AsyncSQLAlchemyRepositoryAsyncSession-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

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

varco_sa-0.0.1.tar.gz (25.7 kB view details)

Uploaded Source

Built Distribution

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

varco_sa-0.0.1-py3-none-any.whl (30.0 kB view details)

Uploaded Python 3

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

Hashes for varco_sa-0.0.1.tar.gz
Algorithm Hash digest
SHA256 a9024904232fae1e7b72dac431d252f85dbe47533caab15e21d51c756d714a5f
MD5 a4ce2a0b1d6046e980343b448ac5df47
BLAKE2b-256 d6f1f1a21b3e41cdd5b2e7a1f853a1c50b584c1f3154dea32c5f4c9c023b67c3

See more details on using hashes here.

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

Hashes for varco_sa-0.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 5212e8fe3c3cbd162c19914b74d01f3dd018f433ddfa9d977f4c14d07314d3bc
MD5 c50c46f49cc7b63931e610070da852f4
BLAKE2b-256 55fc8a0f84f657e3697cd60194b085dd7a1660897be8d391245f765f4f96fa85

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