Canonical control-plane schemas for the Relay agent reliability OS.
Project description
epochly-relay-schemas
Canonical control-plane schemas for the Relay agent reliability OS.
This package owns the canonical schema source-of-truth and the W1.5 codegen pipeline.
Source-of-truth file (W1.5)
raw/openapi.yaml is a single OpenAPI 3.1 document carrying every persisted
control-plane envelope under components.schemas. The W1.5 codegen pipeline
consumes this file via:
datamodel-code-generator->packages/sdk-python/relay/_generated/(Pydantic v2BaseModelsubclasses withextra='forbid')openapi-typescript->packages/sdk-typescript/src/_generated/(TypeScript type aliases + named re-exports)
Regenerate via:
uv run python packages/schemas/scripts/codegen.py
Drift check (VAL-W1-035):
uv run python scripts/check-codegen-drift.py
Two-layer architecture
The W1.5 generated layer carries the BASE canonical models (one Pydantic
class per envelope; one TS type alias per envelope) with the extra='forbid'
discipline. The hand-authored W1.1-W1.4 modules under
packages/schemas/python/relay_schemas/envelopes.py and
packages/schemas/typescript/src/envelopes.ts add the RICH validation layer:
- Cross-field invariants (
accepted_requires_evidence,raw_capture_requires_dpa_and_approver,dry_run_never_resolves). - RFC 3339 timezone-offset enforcement (
VAL-W1-017,VAL-W1-024). - StrictBool rejection of string coercion (
VAL-W1-023,VAL-W1-026). - Canonical-byte serializers for cross-language round-trip evidence.
- The discriminated-union
ScopeStatemetaclass adapter.
The generated layer and the hand-authored layer are independent: the generated classes are NOT subclassed by the hand-authored classes. Future W1.6 + cross-language fixtures consume both layers and verify them against the same JSON canonical form.
Two-layer convention (LOCKED post-W1.6, orchestrator decision 2026-05-13)
The two-layer architecture is the chosen convention for v0.1 and is not provisional. The hand-authored rich-validation layer addresses validation shapes that OpenAPI 3.1 cannot express directly (cross-field validators, StrictBool semantics, canonical-byte serializers). Folding rich validation into OpenAPI vendor extensions is OUT OF SCOPE for v0.1.
To prevent silent drift between raw/envelopes.yaml (rich-layer source) and
raw/openapi.yaml (generated-layer source), the CI cross-YAML alignment check
at packages/schemas/python/tests/test_yaml_alignment.py enforces:
- Both YAMLs enumerate exactly the same envelope names.
- Each shared envelope's
schema_versionLiteral is identical across the two sources. - Each shared envelope's closed enums (status, action, draft_kind, etc.) carry identical member sets across the two sources.
The alignment check runs under the tier-1 plumbing marker (-m plumbing)
on every commit. A failure means a drift has been introduced and one of the
two YAMLs needs amendment to restore parity.
When a new canonical envelope is introduced (W2+ milestones), it lands in BOTH YAMLs in the same commit, with the alignment check verifying parity before merge.
Layout
raw/openapi.yaml- canonical OpenAPI 3.1 source-of-truth (W1.5).raw/envelopes.yaml- W1.1-W1.4 custom-format YAML; lock-in documentation companion only (not a codegen source).raw/relay-error-codes.yaml- canonical RELAY-* error code registry.raw/owner-email-deny.yaml- canonical group-email deny prefixes (W1.4).python/relay_schemas/- W1.1-W1.4 hand-authored rich-validation envelopes.typescript/src/- W1.1-W1.4 hand-authored TS runtime guards.sql/- W1.1-W1.4 SQL DDL migrations (FK targets and CHECK constraints).scripts/codegen.py- W1.5 codegen orchestrator (this file's home).scripts/gen_error_codes.py- W1.4 error-codes generator (called by W1.5).python/tests/- W1 contract assertion tests (pytest, tier-1 plumbing).
Versioning
Per CLAUDE.md keystone invariant #10: every canonical envelope carries a
schema_version field pinned to a string literal. Engines refuse unknown
versions on write. The W1.5 codegen pipeline emits a
RelayUnknownSchemaVersionError helper (Python + TS) that callers use via
parse_envelope(...) / parseEnvelope(...) to surface forward-compat
failures with a stable error type (VAL-W1-036).
License
Apache 2.0. See repository root LICENSE.
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 Distribution
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 epochly_relay_schemas-0.1.16.tar.gz.
File metadata
- Download URL: epochly_relay_schemas-0.1.16.tar.gz
- Upload date:
- Size: 159.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
fd0dea0ba3161552273c4e669b9a05641ce848a4cf0c972e5723b9b0f87d3f71
|
|
| MD5 |
fd5155835f8f070188f0d0c1fcd76c74
|
|
| BLAKE2b-256 |
e4ef6585dc818076884fb4bc00a4174da8990cccce9053e25ea6c052ffcb3fdd
|
Provenance
The following attestation bundles were made for epochly_relay_schemas-0.1.16.tar.gz:
Publisher:
release-pypi.yml on epochly-inc/relay
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
epochly_relay_schemas-0.1.16.tar.gz -
Subject digest:
fd0dea0ba3161552273c4e669b9a05641ce848a4cf0c972e5723b9b0f87d3f71 - Sigstore transparency entry: 1656337079
- Sigstore integration time:
-
Permalink:
epochly-inc/relay@d5a9f87217b0b44478518b897f3d48ba24103ebf -
Branch / Tag:
refs/tags/v0.1.16 - Owner: https://github.com/epochly-inc
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release-pypi.yml@d5a9f87217b0b44478518b897f3d48ba24103ebf -
Trigger Event:
push
-
Statement type:
File details
Details for the file epochly_relay_schemas-0.1.16-py3-none-any.whl.
File metadata
- Download URL: epochly_relay_schemas-0.1.16-py3-none-any.whl
- Upload date:
- Size: 40.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b94658af0f0b976ce191b0270f3338c03ac09cfff561e124d90db935f827ca33
|
|
| MD5 |
e8ab798c4fde02e6d945bdfc64ce7479
|
|
| BLAKE2b-256 |
0fd9067d775df24a4912d0e675afc0ca5ca869bae59abe7b432463bb6922cf9a
|
Provenance
The following attestation bundles were made for epochly_relay_schemas-0.1.16-py3-none-any.whl:
Publisher:
release-pypi.yml on epochly-inc/relay
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
epochly_relay_schemas-0.1.16-py3-none-any.whl -
Subject digest:
b94658af0f0b976ce191b0270f3338c03ac09cfff561e124d90db935f827ca33 - Sigstore transparency entry: 1656337258
- Sigstore integration time:
-
Permalink:
epochly-inc/relay@d5a9f87217b0b44478518b897f3d48ba24103ebf -
Branch / Tag:
refs/tags/v0.1.16 - Owner: https://github.com/epochly-inc
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release-pypi.yml@d5a9f87217b0b44478518b897f3d48ba24103ebf -
Trigger Event:
push
-
Statement type: