Skip to main content

OpenFrame Microservice Suite — PostgreSQL database adapter.

Project description

openframe-adapters-db-postgres

PostgreSQL database adapter for the OpenFrame Microservice Suite.

Part of the openframe-adapters monorepo. Implements BaseRepository[T] and HealthCheck from openframe-core using asyncpg.


Installation

pip install openframe-adapters-db-postgres

Required env var:

DATABASE_URL=postgresql://user:password@host:5432/dbname

Quick start

Raw dict mode

from openframe.adapters.db.postgres import PostgresSettings, PostgresRepository

settings = PostgresSettings()  # reads DATABASE_URL from env
repo = PostgresRepository(settings, table="items", id_column="id")

item = await repo.get("abc-123")          # dict | None
items, total = await repo.list(10, 0)     # ([dict, ...], int)
created = await repo.create({"name": "x"})
updated = await repo.update({"id": "abc-123", "name": "y"})
deleted = await repo.delete("abc-123")    # bool

Typed domain mode

from dataclasses import dataclass
from openframe.adapters.db.postgres import PostgresSettings, PostgresRepository

@dataclass
class Item:
    id: str
    name: str

class ItemRepository(PostgresRepository[Item]):
    _table = "items"
    _id_column = "id"

    def _row_to_entity(self, row) -> Item:
        return Item(**dict(row))

    def _entity_to_row(self, entity: Item) -> dict:
        return {"id": entity.id, "name": entity.name}

settings = PostgresSettings()
repo = ItemRepository(settings)
item: Item | None = await repo.get("abc-123")

Configuration

All settings are read from environment variables.

Env var Type Default Description
DATABASE_URL str required Full asyncpg DSN
POOL_SIZE int 10 Pool min/max size
POOL_MAX_INACTIVE_CONN_LIFETIME float 300.0 Idle connection TTL (s)
POOL_COMMAND_TIMEOUT float 60.0 Per-statement timeout (s)
POOL_MAX_QUERIES int 50000 Queries per connection before recycle
CONNECTION_TIMEOUT float 30.0 Pool creation timeout (s)
OPERATION_TIMEOUT float 10.0 Per-operation timeout (s)
MAX_RETRIES int 3 Max retry attempts

Health checks

PostgresRepository implements the HealthCheck protocol from openframe-core.

alive = await repo.ping()       # SELECT 1 — fast liveness check
ready = await repo.is_ready()   # pg_tables query — full readiness check

Both methods return False on any failure and never raise.


Exception hierarchy

All exceptions are AdapterError subclasses from openframe.core.exceptions. Raw asyncpg exceptions never escape the adapter.

Situation Exception
Cannot connect to Postgres AdapterConnectionError
Invalid DATABASE_URL catalog AdapterConfigurationError
Query failed (constraint, syntax, etc.) AdapterQueryError
Entity not found AdapterNotFoundError
Operation exceeded timeout AdapterTimeoutError

Development

# from the package directory
pip install -e ".[dev]"
pytest tests/ -v

Protocol conformance

from openframe.core.ports import BaseRepository
from openframe.core.health import HealthCheck

repo = PostgresRepository(settings, table="items", id_column="id")
assert isinstance(repo, BaseRepository)   # True — structural check
assert isinstance(repo, HealthCheck)      # True — structural check

No inheritance from either Protocol is required or used.


License

MIT

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

openframe_adapters_db_postgres-1.0.0.tar.gz (12.2 kB view details)

Uploaded Source

Built Distribution

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

File details

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

File metadata

File hashes

Hashes for openframe_adapters_db_postgres-1.0.0.tar.gz
Algorithm Hash digest
SHA256 9db99a2ffee94299e77997b0eff42190fdd880452008dadac1d2409538ddc81b
MD5 b04d344881fe0ac5ad8aaefe2014d455
BLAKE2b-256 645ab7a3d67789e62eb65fcfc00945e530f81f08ec133ed733601aeee71975eb

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for openframe_adapters_db_postgres-1.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 a9ca1578a6a272a65249641753e0ed15ffd7d650a3c539fda3873ac0e7dfd24c
MD5 b4cfdf7c28435b8a38ba9206c8c9a488
BLAKE2b-256 fc24413be5aa435b601929543e080f788f4a4b8811bf937dde17edd7f30a2c32

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