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
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distributions
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file lexigram_contracts-0.1.1-py3-none-any.whl.
File metadata
- Download URL: lexigram_contracts-0.1.1-py3-none-any.whl
- Upload date:
- Size: 328.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.8.14
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
1b9cabc39713eb17b3717c71dc5ad4129a976fb55cf858de5d7adb4411b7ca1c
|
|
| MD5 |
7ec63ee3d7dd3b31da27c313f5e4735d
|
|
| BLAKE2b-256 |
12543cdd7c2275ed122a9fa3670d85f702c1e2db5ac713f8da673c67faadc27b
|