Skip to main content

Core types and protocols for the Lexigram Framework

Project description

lexigram-contracts

Core types and protocols for the Lexigram Framework.


Overview

lexigram-contracts defines all Protocols, base types, Result types, domain models, and exception hierarchies used across the Lexigram ecosystem. It has zero runtime dependencies so it can be imported into any package — including thin integrations — without pulling in the full framework.

This package is the single source of truth for every interface in Lexigram. All other packages depend on contracts; no implementation package defines its own protocol that another package depends on.

Install

uv add lexigram-contracts

Quick Start

Result type

from lexigram.result import Result, Ok, Err

async def find_user(user_id: str) -> Result[User, UserNotFound]:
    user = await db.get(user_id)
    if not user:
        return Err(UserNotFound(user_id))
    return Ok(user)

# Safe consumption
result = await find_user("u-123")
name = result.match(ok=lambda u: u.name, err=lambda e: "unknown")

Domain models

from lexigram.contracts.domain.base import Entity, ValueObject
from lexigram.contracts.domain.aggregates import AggregateRoot
from lexigram.contracts.domain.events import DomainEvent

class UserCreated(DomainEvent):
    user_id: str
    email: str

class User(AggregateRoot):
    email: str

Protocols

from lexigram.contracts.cache import CacheBackend
from lexigram.contracts.data import DatabaseProviderProtocol
from lexigram.contracts.security.secrets import SecretStoreProtocol

Key Modules

Module What it contains
lexigram.result Result[T, E], Ok, Err, ok(), err()
lexigram.contracts.core.container ContainerRegistrarImpl, ContainerResolverImpl
lexigram.contracts.core.provider Provider, ProviderPriority
lexigram.contracts.core.registry Registry for type-keyed dispatch
lexigram.contracts.domain.base Entity, ValueObject
lexigram.contracts.domain.aggregates AggregateRoot
lexigram.contracts.domain.events DomainEvent
lexigram.contracts.cache CacheBackend protocol
lexigram.contracts.data DatabaseProviderProtocol
lexigram.contracts.security.secrets SecretStoreProtocol
lexigram.contracts.exceptions LexigramError, full error hierarchy

Key Source Files

File What it contains
src/lexigram/contracts/__init__.py Lazy-loading re-exports of all public types
src/lexigram/result/ Result type and Ok/Err helpers
src/lexigram/contracts/domain/ Entity, ValueObject, AggregateRoot, DomainEvent
src/lexigram/contracts/core/ Container, Provider, Registry protocols
src/lexigram/contracts/exceptions/ LexigramError and domain error hierarchies

Design Principles

  • Zero dependencies — no third-party runtime imports
  • Protocol-only — defines interfaces, never implementations
  • Stable contract — all other Lexigram packages depend on this one; breaking changes are versioned

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

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

lexigram_contracts-0.1.1-py3-none-any.whl (328.0 kB view details)

Uploaded Python 3

File details

Details for the file lexigram_contracts-0.1.1-py3-none-any.whl.

File metadata

File hashes

Hashes for lexigram_contracts-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 1b9cabc39713eb17b3717c71dc5ad4129a976fb55cf858de5d7adb4411b7ca1c
MD5 7ec63ee3d7dd3b31da27c313f5e4735d
BLAKE2b-256 12543cdd7c2275ed122a9fa3670d85f702c1e2db5ac713f8da673c67faadc27b

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