Skip to main content

Shared protocol interfaces for Belgie

Project description

Belgie Proto: Shared Protocol Interfaces for Belgie Packages

[!WARNING] belgie-proto is intentionally low-level. It defines the contracts that other Belgie packages depend on, so changes here can ripple across adapters, plugins, and app code that implements these protocols directly.

belgie-proto is the contract layer for the Belgie workspace. It defines the runtime-checkable protocols for accounts, individuals, OAuth accounts, sessions, OAuth state, adapters, organizations, invitations, teams, and database connections so the rest of the stack can stay typed without hard-coding a particular ORM or persistence model.

Use it when you are implementing your own adapter, building custom integrations on top of belgie-core, or depending on shared interfaces across multiple Belgie packages. If you want a working SQLAlchemy implementation, start with belgie-alchemy.

Installation

uv add belgie-proto

[!NOTE] Most applications do not need to install belgie-proto directly. It is already pulled in by higher-level Belgie packages such as belgie-core and belgie-alchemy.

What It Defines

  • Core protocols for Account, Individual, OAuthAccount, Session, and OAuthState.
  • DBConnection for the async database/session object passed through Belgie.
  • AdapterProtocol for core auth persistence operations.
  • OrganizationAdapterProtocol and OrganizationTeamAdapterProtocol for org-aware adapters.
  • TeamAdapterProtocol for team-aware adapters.
  • Shared organization and team model protocols plus error types such as PendingInvitationConflictError.

Quick Start

Here is a minimal adapter surface using the core protocols:

from belgie_proto.core import AdapterProtocol, DBConnection, IndividualProtocol


class MyIndividual(IndividualProtocol):
    ...


class MyAdapter(AdapterProtocol):
    async def get_individual_by_email(self, session: DBConnection, email: str) -> MyIndividual | None:
        ...

    async def create_individual(
        self,
        session: DBConnection,
        email: str,
        name: str | None = None,
        image: str | None = None,
        *,
        email_verified_at=None,
    ) -> MyIndividual:
        ...

    # implement the rest of AdapterProtocol

The important constraint is not inheritance from a base class. It is satisfying the protocol shape that Belgie expects. That keeps the integration flexible while preserving type checking across packages.

Namespaces

  • Import core auth contracts from belgie_proto.core.
  • Import organization contracts from belgie_proto.organization.
  • Import team contracts from belgie_proto.team.

When To Reach For It

  • You are writing a custom adapter instead of using belgie-alchemy.
  • You want package boundaries enforced by protocols instead of concrete ORM models.
  • You are extending Belgie with org or team support and need the shared adapter contracts.

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

belgie_proto-0.19.3.tar.gz (9.4 kB view details)

Uploaded Source

Built Distribution

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

belgie_proto-0.19.3-py3-none-any.whl (24.4 kB view details)

Uploaded Python 3

File details

Details for the file belgie_proto-0.19.3.tar.gz.

File metadata

  • Download URL: belgie_proto-0.19.3.tar.gz
  • Upload date:
  • Size: 9.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.11.8 {"installer":{"name":"uv","version":"0.11.8","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

Hashes for belgie_proto-0.19.3.tar.gz
Algorithm Hash digest
SHA256 ceca33374da29b3a86379023eda422cb92904bef3beb867afcda610e1d5ff090
MD5 c5e129c9445b1d7602a6114dbe9798bb
BLAKE2b-256 00fd87f373f8ab795349f4401d2d211afa6ab116b2b6c5ede2443835e5b7e584

See more details on using hashes here.

File details

Details for the file belgie_proto-0.19.3-py3-none-any.whl.

File metadata

  • Download URL: belgie_proto-0.19.3-py3-none-any.whl
  • Upload date:
  • Size: 24.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.11.8 {"installer":{"name":"uv","version":"0.11.8","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

Hashes for belgie_proto-0.19.3-py3-none-any.whl
Algorithm Hash digest
SHA256 259ed955fb1c6131b691c0671033f4b7308f9b20c3f5ae7fd739a6de7d273a1b
MD5 6b6ee62fcb745cd71bf0dc0fcc15f8e2
BLAKE2b-256 9e9dccd2bc3f178b11080d1c49553c5a98608677400b9ce6e6350f5c969313dc

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