Skip to main content

Schema-agnostic structural diagnostics engine for governed research artifacts.

Project description


title: "Stamp" filetype: "documentation" type: "specification" domain: "methodology" version: "0.1.0" doi: "10.5281/zenodo.18436622" status: "Active" created: "2026-01-16" updated: "2026-01-31"

author: name: "Shawn C. Wright" email: "swright@waveframelabs.org" orcid: "https://orcid.org/0009-0006-6043-9295"

maintainer: name: "Waveframe Labs" url: "https://waveframelabs.org"

license: "Apache-2.0"

copyright: holder: "Waveframe Labs" year: "2026"

ai_assisted: "partial" ai_assistance_details: "AI-assisted drafting and structural refinement under direct human authorship, review, and final approval."

dependencies: []

anchors: []

Waveframe Stamp Banner

Stamp

Stamp is a deterministic metadata validation and remediation tool for governed research artifacts.

It validates artifact metadata against a formal schema, emits structured diagnostics, proposes safe mechanical fixes, and produces human-action remediation summaries when automation ends.

Stamp is designed to be:

  • schema-agnostic
  • policy-neutral
  • reproducible
  • machine- and human-readable

It is a front door to governed research workflows — not an enforcement engine.

Stamp does not embed or assume any specific governance policy. All schemas are supplied explicitly at runtime.


Getting Started

If you’re new to Stamp and want to understand how to install it, run it, and interpret its output, start here:

Getting Started with Waveframe-Stamp

This guide walks through installation, common workflows, and understanding the JSON output. It is written for users with no prior knowledge of Waveframe Labs or ARI.

Installation

Standard Install (Recommended)

pip install waveframe-stamp

Local Development

git clone [https://github.com/Waveframe-Labs/Waveframe-Stamp.git](https://github.com/Waveframe-Labs/Waveframe-Stamp.git)
cd Waveframe-Stamp
pip install -e .

Quick Usage

Stamp commands emit explicit JSON to stdout for deterministic tooling and automation.

Validate a single artifact:

stamp validate run artifact.md --schema ari-metadata.schema.v3.0.2.json

Validate an entire repository (or directory):

stamp validate repo . --schema ari-metadata.schema.v3.0.2.json

Note: Only artifacts that explicitly declare metadata are governed and validated. Execution traces generated via --trace-out are immutable and excluded from validation.


Shell Compatibility

Stamp is shell-agnostic. All CLI commands emit explicit JSON and do not rely on shell-specific behavior.

  • Linux / macOS: Pipe output to tools like jq if desired.
  • Windows (PowerShell): Use ConvertFrom-Json | ConvertTo-Json -Depth 10.
  • CI systems: Consume raw JSON directly.

No external shell tooling is required to run Stamp itself.


What Stamp Is (and Is Not)

Stamp is

  • A metadata extractor
  • A schema validator
  • A diagnostic normalizer (Canonical Diagnostic Objects / CDOs)
  • A safe auto-fix engine (conservative by design)
  • A human-action explainer (remediation summaries)

Stamp is not

  • A policy engine
  • A governance authority
  • A content validator
  • An opinionated formatter
  • An enforcement mechanism (that’s CRI-CORE)

Stamp explains what is wrong, what can be fixed automatically, and what requires human judgment — nothing more, nothing less.


High-Level Architecture

Artifact
  ↓
[ Extraction ]
  ↓
[ Schema Resolution ]
  ↓
[ Validation ]
  ↓
[ Diagnostics (CDOs) ]
  ↓
┌───────────────┬───────────────────┐
│ Auto Fix      │ Human Remediation │
│ (safe only)   │ Summary           │
└───────────────┴───────────────────┘

Each layer is deterministic and independently testable.


Design Principles

  • Determinism over convenience
  • Traceability over magic
  • No self-approval
  • Separation of validation, fixing, and judgment
  • Format-agnostic governance

Stamp should always be boring, predictable, and explainable.


Status

Architecture stable Core contracts frozen UX and packaging hardening in progress


Governance Semantics

Stamp distinguishes between discovered artifacts and governed artifacts.

An artifact is considered governed if and only if it explicitly declares a metadata block (YAML frontmatter or HTML-comment metadata).

During repository validation:

  • files without metadata are discovered
  • but are intentionally ignored
  • and are not treated as failures

This is a deliberate governance boundary.

Stamp never guesses intent and never infers governance.


Execution Traces

Stamp can emit an immutable execution trace artifact using:

--trace-out traces/stamp-validation-trace.json

Trace artifacts record:

  • tool identity and version
  • command executed
  • schema used
  • timestamps
  • per-artifact validation results

Execution traces are:

  • machine-validated
  • immutable audit records
  • intentionally excluded from metadata governance

They exist to support auditability and downstream enforcement tooling.


License

Stamp is released under the Apache License, Version 2.0.

See the LICENSE file for the full text.


Citation

If you use Stamp in academic work, tooling research, or technical documentation, please cite it as follows.

BibTeX

@software{stamp_2026,
  title        = {Stamp: A Schema-Agnostic Structural Diagnostics Engine},
  author       = {Wright, Shawn C.},
  orcid        = {0009-0006-6043-9295},
  year         = {2026},
  version      = {0.1.1},
  publisher    = {Waveframe Labs},
  url          = {https://github.com/Waveframe-Labs/Waveframe-Stamp},
  doi          = {10.5281/zenodo.18436622}
}  

© 2026 Waveframe Labs

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

waveframe_stamp-0.1.1.tar.gz (21.8 kB view details)

Uploaded Source

Built Distribution

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

waveframe_stamp-0.1.1-py3-none-any.whl (27.8 kB view details)

Uploaded Python 3

File details

Details for the file waveframe_stamp-0.1.1.tar.gz.

File metadata

  • Download URL: waveframe_stamp-0.1.1.tar.gz
  • Upload date:
  • Size: 21.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.0

File hashes

Hashes for waveframe_stamp-0.1.1.tar.gz
Algorithm Hash digest
SHA256 a8120359c071c6c2529bdbe50322e2739c6f6f69e73fa19bb3d80a5f125245b3
MD5 5b58d0e1f99405be6f326fb16d57f044
BLAKE2b-256 e75cb8999f63a50e8b851fc7fb5231e047235a60af2d6e6d74041fcd25edf8d3

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for waveframe_stamp-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 d169ad7b6fe15b34df3da654d2d10c5474c3668b3733e357d9d95f6dd4c4f22d
MD5 1adf1340f3217b6533287f12a7fdfd35
BLAKE2b-256 f87c419efb9d021ba1917ff43b39f57ac01cc0945a306b803d62daeb0d798f7f

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