Skip to main content

base-repository

Project description

Base Repository

Python License Release Coverage

A repository library that wraps SQLAlchemy and provides built-in CRUD and a query DSL.
Once you inherit from BaseRepository, you can use create/read/update/delete right away.

  • No need to re-implement simple CRUD over and over.
  • If you need custom repo methods, you can add them in your project and extend freely.
  • Supports introducing a Mapper for conversions between Pydantic schemas and SQLAlchemy ORM models.

Supported Dependency Versions

The table below lists the minimum required versions for each supported dependency.

To see more about how to test and the result.

python_version sqlalchemy pydantic
3.10 >= 1.4 >= 1.10
>= 3.13 >= 1.4 >= 2.8, 1.7-1.10

Links


Installation

# Before publishing to PyPI
pip install -U "base-repository @ git+https://github.com/4jades/base-repository.git"

# After publishing to PyPI
pip install -U fastapi-base-repository

Quick Start

1) Define Filter and Repo

from dataclasses import dataclass
from pydantic import BaseModel
from base_repository import BaseRepoFilter
from base_repository.repository import BaseRepository

# Example: existing SQLAlchemy ORM model and Pydantic schema in your project
class Base(DeclarativeBase):
    pass

class UserModel(Base):
    __tablename__ = "users"

    id: Mapped[int] = mapped_column(primary_key=True)
    name: Mapped[str] = mapped_column(nullable=False)

class UserSchema(BaseModel):
    id: int
    name: str
    model_config = ConfigDict(from_attributes=True)


# What you need to add for Base Repository: Filter + Repo
@dataclass
class UserFilter(BaseRepoFilter):
    id: int | iterable[int] | None = None
    name: str | iterable[str] | None = None

class UserRepo(BaseRepository[UserModel]):
    filter_class = UserFilter
    mapping_schema = UserSchema  # Optional: return Pydantic objects by default

2) Plug in a SessionProvider

Decide how the repository should obtain an AsyncSession.
Recommended: inject a SessionProvider once, so the repo can fetch sessions when needed.

from typing import Protocol
from base_repository import SessionProvider, BaseRepository

# Example SessionProvider implementation
class MysqlSessionProvider(SessionProvider):
    def get_session(self) -> AsyncSession:
        return Mysql.current_session()

BaseRepository.configure_session_provider(MysqlSessionProvider())

Alternatively, you can pass a session directly when creating the repo.

async with AsyncSession(engine) as session:
    repo = UserRepo(session)

3) Use CRUD immediately

repo = UserRepo()

# Create
created = await repo.create({"name": "Alice", "email": "a@test.com"})

# Get one
user = await repo.get(UserFilter(name=["Alice", "Bob"]))
user_orm = await repo.get(UserFilter(name="Alice"), convert_domain=False)

# List (OFFSET paging)
q = (
    repo.list()
        .where(UserFilter(name="A"))
        .order_by(["id"])
        .paging(page=1, size=20)
)
users = await repo.execute(q)

# List (CURSOR paging)
q1 = (
    repo.list()
        .order_by(["id"])
        .with_cursor(None)
        .limit(20)
)
users1 = await repo.execute(q1)

# Update / Delete / Count
cnt = await repo.count(UserFilter(name="Alice"))
updated_rows = await repo.update(UserFilter(name="Bob"), {"email": "bob@new"})
deleted_rows = await repo.delete(UserFilter(name="Alice"))

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

base_repository-1.0.0.tar.gz (33.1 kB view details)

Uploaded Source

Built Distribution

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

base_repository-1.0.0-py3-none-any.whl (14.5 kB view details)

Uploaded Python 3

File details

Details for the file base_repository-1.0.0.tar.gz.

File metadata

  • Download URL: base_repository-1.0.0.tar.gz
  • Upload date:
  • Size: 33.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.0

File hashes

Hashes for base_repository-1.0.0.tar.gz
Algorithm Hash digest
SHA256 b89a41ea3ae8609ad55503296f2b4eca88c6b648cd8d4209b709f6893359bbab
MD5 b0837460e0f9e7e0534a6c8608758fa1
BLAKE2b-256 ac3c7ba9608e80b9af028a39a54b8d3197eb97ac999b2176db7ca24120df6c09

See more details on using hashes here.

File details

Details for the file base_repository-1.0.0-py3-none-any.whl.

File metadata

File hashes

Hashes for base_repository-1.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 aef2636dd9d5b46378e5af407a231139c567e1255df861f4ed675adb3a149960
MD5 ae00f11d9db4dc5872f4421a535b1e05
BLAKE2b-256 dab5a307a3e86ae3e54475f8f581b5852a77d1f9ab4dce736c304c43a1ebce39

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