Canonical schemas, templates, manifests, and generated Python contract artifacts for SSOT.
Project description
🔷 ssot-contracts
Canonical schemas, templates, manifests, and generated contract metadata for SSOT.
ssot-contracts is the canonical artifact package for SSOT.
It ships machine-readable schemas, registry templates, upstream-derived packaged ADR/spec manifests, and generated Python metadata that other SSOT packages consume at runtime.
What this package owns
- JSON Schemas for registries, reports, graph exports, and snapshots
- Packaged registry templates such as
registry.minimal.jsonandregistry.full.json - Immutable packaged ADR and spec document manifests derived from the upstream
.ssot/registry.jsonssot-origininventory - Generated Python contract metadata used by CLI and TUI packages
When to use this package
Use ssot-contracts when you want:
- packaged schemas and templates without the full CLI
- a stable place to load SSOT manifests and contract metadata from Python
- the artifact layer consumed by ssot-registry, ssot-cli, ssot-tui, ssot-views, and ssot-codegen
Use another package when you want:
- ssot-registry for core runtime APIs and registry mutation/validation flows
- ssot-cli for command-line workflows
- ssot-tui for terminal UI browsing
- ssot-views for reusable derived report and graph builders
- ssot-codegen to regenerate contract-side metadata outputs
Install
python -m pip install ssot-contracts
For local development from this repository:
python -m pip install -e pkgs/ssot-contracts
Shipped artifacts
This package currently includes:
- schemas under
ssot_contracts.schema - registry templates under
ssot_contracts.templates - packaged ADR manifests and YAML files under
ssot_contracts.templates.adr - packaged spec manifests and YAML files under
ssot_contracts.templates.specs - generated Python metadata under
ssot_contracts.generated.python
Representative schemas include:
registry.schema.jsonvalidation.report.schema.jsoncertification.report.schema.jsongraph.export.schema.jsonboundary.snapshot.schema.jsonrelease.snapshot.schema.jsonpublished.snapshot.schema.json
Programmatic usage
Load contract metadata:
from ssot_contracts import CONTRACT_DATA
print(CONTRACT_DATA["schema_version"])
print(CONTRACT_DATA["output_formats"])
Load a packaged document manifest:
from ssot_contracts import load_document_manifest
adr_manifest = load_document_manifest("adr")
spec_manifest = load_document_manifest("spec")
print(adr_manifest[0]["id"])
print(spec_manifest[0]["id"])
List available schema files or load one as text:
from ssot_contracts import list_schema_names, load_schema_text
print(list_schema_names())
schema_text = load_schema_text("registry.schema.json")
Read packaged document bodies:
from ssot_contracts import read_packaged_document_text
text = read_packaged_document_text("adr", "ADR-0600-canonical-json-registry.yaml")
print(text.splitlines()[0])
Generated metadata
Generated Python modules currently include:
generated.python.cli_metadatagenerated.python.tui_metadatagenerated.python.idsgenerated.python.enums
These modules provide shared constants such as output formats, entity section labels, and identifier prefixes. They are intended to be imported by other SSOT packages rather than edited by hand.
Package relationships
- Package type: artifact and contract package
- Depends on: standard library only, plus
tomlion Python earlier than 3.11 - Consumed by: ssot-registry, ssot-cli, ssot-tui, ssot-views, ssot-codegen
If you need the canonical packaged schemas and manifests, install this package. It is the lowest-level reusable contract layer in the workspace.
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 ssot_contracts-0.2.9.tar.gz.
File metadata
- Download URL: ssot_contracts-0.2.9.tar.gz
- Upload date:
- Size: 23.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.11.7 {"installer":{"name":"uv","version":"0.11.7","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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f3116f1a09faa2551ff7f6a4d0e8b5c5c1a4ce453b3c48a8f5ab4551da1276fd
|
|
| MD5 |
a2d77ba174a389a8373d949ce26f6a37
|
|
| BLAKE2b-256 |
7fdb71ca07b4df29fc08fd25c07a0e1b4b4d6207e5966694c17b1c3542020541
|
File details
Details for the file ssot_contracts-0.2.9-py3-none-any.whl.
File metadata
- Download URL: ssot_contracts-0.2.9-py3-none-any.whl
- Upload date:
- Size: 39.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.11.7 {"installer":{"name":"uv","version":"0.11.7","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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
422fffea7017b2265608903efb84a5f3a69f996dc334e8f832491dc500f6447a
|
|
| MD5 |
69af97db3a72d312c24ed0f06dbab132
|
|
| BLAKE2b-256 |
99e78ae592edc152427bd5e4d2c5c51938f8894b016398a5998ab7af67c59d87
|