@adammcarter/use-cases 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.agents/skills/migration/SKILL.md +85 -0
- package/.agents/skills/showcase/SKILL.md +60 -0
- package/.agents/skills/use-cases/SKILL.md +161 -0
- package/.agents/skills/walkthrough/SKILL.md +48 -0
- package/.claude-plugin/plugin.json +14 -0
- package/.codex-plugin/plugin.json +33 -0
- package/.mcp.json +8 -0
- package/.opencode/plugin/use-cases.js +32 -0
- package/CHANGELOG.md +125 -0
- package/LICENSE +21 -0
- package/README.md +112 -0
- package/bootstrap/use-cases.md +60 -0
- package/docs/README.md +51 -0
- package/docs/acceptance.md +16 -0
- package/docs/activation.md +89 -0
- package/docs/adr/0001-p0-bootstrap-decisions.md +107 -0
- package/docs/adr/0002-p1-schema-contracts.md +136 -0
- package/docs/adr/0003-p2-use-case-matrix-contracts.md +67 -0
- package/docs/adr/0004-p3-evidence-ledger-contracts.md +85 -0
- package/docs/adr/0005-p4-cli-contract.md +70 -0
- package/docs/adr/0006-trusted-user-approval-path.md +125 -0
- package/docs/cli.md +108 -0
- package/docs/data-model.md +56 -0
- package/docs/getting-started.md +296 -0
- package/docs/hosts.md +30 -0
- package/docs/markers-adoption.md +100 -0
- package/docs/mcp.md +114 -0
- package/docs/migration.md +90 -0
- package/docs/reference/error-codes.md +123 -0
- package/docs/reference/stability.md +123 -0
- package/docs/release.md +26 -0
- package/docs/security/ci-hardening.md +144 -0
- package/docs/security/key-management.md +158 -0
- package/docs/security.md +66 -0
- package/docs/showcase.md +39 -0
- package/docs/tutorials/python-pytest.md +188 -0
- package/examples/basic-product/demo-capsules/product-search.yml +23 -0
- package/examples/basic-product/evidence/by-id/ev/evidence-basic-search.jsonl +1 -0
- package/examples/basic-product/showcase-runs/run.basic.product.search/events.jsonl +4 -0
- package/examples/basic-product/use-cases/product.yml +85 -0
- package/examples/basic-product/use-cases.yml +9 -0
- package/examples/damaged-product/evidence/broken.jsonl +1 -0
- package/examples/damaged-product/use-cases/duplicate-a.yml +28 -0
- package/examples/damaged-product/use-cases/duplicate-b.yml +28 -0
- package/examples/damaged-product/use-cases/malformed.yml +14 -0
- package/examples/damaged-product/use-cases/valid-sibling.yml +28 -0
- package/examples/damaged-product/use-cases.yml +9 -0
- package/examples/host-projections/use-cases.yml +9 -0
- package/examples/python-pytest/README.md +39 -0
- package/examples/python-pytest/pytest.ini +8 -0
- package/examples/python-pytest/src/coupon.py +32 -0
- package/examples/python-pytest/tests/use_cases/example.checkout.apply_coupon_test.py +31 -0
- package/examples/python-pytest/use-cases/checkout.yml +47 -0
- package/examples/python-pytest/use-cases.yml +19 -0
- package/hooks/hooks-codex.json +16 -0
- package/hooks/hooks.json +16 -0
- package/hooks/session-start +42 -0
- package/hosts/claude.yml +29 -0
- package/hosts/codex.yml +29 -0
- package/hosts/copilot.yml +29 -0
- package/hosts/opencode.yml +29 -0
- package/package.json +81 -0
- package/packages/cli/README.md +37 -0
- package/packages/cli/dist/args/parse.d.ts +6 -0
- package/packages/cli/dist/args/parse.d.ts.map +1 -0
- package/packages/cli/dist/args/parse.js +55 -0
- package/packages/cli/dist/args/parse.js.map +1 -0
- package/packages/cli/dist/args/validate.d.ts +3 -0
- package/packages/cli/dist/args/validate.d.ts.map +1 -0
- package/packages/cli/dist/args/validate.js +80 -0
- package/packages/cli/dist/args/validate.js.map +1 -0
- package/packages/cli/dist/builtins.d.ts +2 -0
- package/packages/cli/dist/builtins.d.ts.map +1 -0
- package/packages/cli/dist/builtins.js +235 -0
- package/packages/cli/dist/builtins.js.map +1 -0
- package/packages/cli/dist/command/dispatch.d.ts +4 -0
- package/packages/cli/dist/command/dispatch.d.ts.map +1 -0
- package/packages/cli/dist/command/dispatch.js +45 -0
- package/packages/cli/dist/command/dispatch.js.map +1 -0
- package/packages/cli/dist/command/help-catalog.d.ts +13 -0
- package/packages/cli/dist/command/help-catalog.d.ts.map +1 -0
- package/packages/cli/dist/command/help-catalog.js +42 -0
- package/packages/cli/dist/command/help-catalog.js.map +1 -0
- package/packages/cli/dist/command/registry.d.ts +3 -0
- package/packages/cli/dist/command/registry.d.ts.map +1 -0
- package/packages/cli/dist/command/registry.js +33 -0
- package/packages/cli/dist/command/registry.js.map +1 -0
- package/packages/cli/dist/command/types.d.ts +32 -0
- package/packages/cli/dist/command/types.d.ts.map +1 -0
- package/packages/cli/dist/command/types.js +6 -0
- package/packages/cli/dist/command/types.js.map +1 -0
- package/packages/cli/dist/commands/capsule.d.ts +7 -0
- package/packages/cli/dist/commands/capsule.d.ts.map +1 -0
- package/packages/cli/dist/commands/capsule.js +178 -0
- package/packages/cli/dist/commands/capsule.js.map +1 -0
- package/packages/cli/dist/commands/common.d.ts +7 -0
- package/packages/cli/dist/commands/common.d.ts.map +1 -0
- package/packages/cli/dist/commands/common.js +32 -0
- package/packages/cli/dist/commands/common.js.map +1 -0
- package/packages/cli/dist/commands/doctor.d.ts +6 -0
- package/packages/cli/dist/commands/doctor.d.ts.map +1 -0
- package/packages/cli/dist/commands/doctor.js +133 -0
- package/packages/cli/dist/commands/doctor.js.map +1 -0
- package/packages/cli/dist/commands/evidence.d.ts +6 -0
- package/packages/cli/dist/commands/evidence.d.ts.map +1 -0
- package/packages/cli/dist/commands/evidence.js +191 -0
- package/packages/cli/dist/commands/evidence.js.map +1 -0
- package/packages/cli/dist/commands/host.d.ts +6 -0
- package/packages/cli/dist/commands/host.d.ts.map +1 -0
- package/packages/cli/dist/commands/host.js +180 -0
- package/packages/cli/dist/commands/host.js.map +1 -0
- package/packages/cli/dist/commands/keygen.d.ts +4 -0
- package/packages/cli/dist/commands/keygen.d.ts.map +1 -0
- package/packages/cli/dist/commands/keygen.js +132 -0
- package/packages/cli/dist/commands/keygen.js.map +1 -0
- package/packages/cli/dist/commands/markers.d.ts +8 -0
- package/packages/cli/dist/commands/markers.d.ts.map +1 -0
- package/packages/cli/dist/commands/markers.js +455 -0
- package/packages/cli/dist/commands/markers.js.map +1 -0
- package/packages/cli/dist/commands/matrix.d.ts +8 -0
- package/packages/cli/dist/commands/matrix.d.ts.map +1 -0
- package/packages/cli/dist/commands/matrix.js +237 -0
- package/packages/cli/dist/commands/matrix.js.map +1 -0
- package/packages/cli/dist/commands/migrate.d.ts +4 -0
- package/packages/cli/dist/commands/migrate.d.ts.map +1 -0
- package/packages/cli/dist/commands/migrate.js +82 -0
- package/packages/cli/dist/commands/migrate.js.map +1 -0
- package/packages/cli/dist/commands/plan.d.ts +6 -0
- package/packages/cli/dist/commands/plan.d.ts.map +1 -0
- package/packages/cli/dist/commands/plan.js +129 -0
- package/packages/cli/dist/commands/plan.js.map +1 -0
- package/packages/cli/dist/commands/recover.d.ts +4 -0
- package/packages/cli/dist/commands/recover.d.ts.map +1 -0
- package/packages/cli/dist/commands/recover.js +352 -0
- package/packages/cli/dist/commands/recover.js.map +1 -0
- package/packages/cli/dist/commands/schema.d.ts +5 -0
- package/packages/cli/dist/commands/schema.d.ts.map +1 -0
- package/packages/cli/dist/commands/schema.js +51 -0
- package/packages/cli/dist/commands/schema.js.map +1 -0
- package/packages/cli/dist/commands/showcase.d.ts +14 -0
- package/packages/cli/dist/commands/showcase.d.ts.map +1 -0
- package/packages/cli/dist/commands/showcase.js +638 -0
- package/packages/cli/dist/commands/showcase.js.map +1 -0
- package/packages/cli/dist/commands/workflow.d.ts +5 -0
- package/packages/cli/dist/commands/workflow.d.ts.map +1 -0
- package/packages/cli/dist/commands/workflow.js +107 -0
- package/packages/cli/dist/commands/workflow.js.map +1 -0
- package/packages/cli/dist/coreLoader.d.ts +6 -0
- package/packages/cli/dist/coreLoader.d.ts.map +1 -0
- package/packages/cli/dist/coreLoader.js +34 -0
- package/packages/cli/dist/coreLoader.js.map +1 -0
- package/packages/cli/dist/index.d.ts +5 -0
- package/packages/cli/dist/index.d.ts.map +1 -0
- package/packages/cli/dist/index.js +83 -0
- package/packages/cli/dist/index.js.map +1 -0
- package/packages/cli/dist/render.d.ts +2 -0
- package/packages/cli/dist/render.d.ts.map +1 -0
- package/packages/cli/dist/render.js +88 -0
- package/packages/cli/dist/render.js.map +1 -0
- package/packages/cli/dist/runtime.d.ts +25 -0
- package/packages/cli/dist/runtime.d.ts.map +1 -0
- package/packages/cli/dist/runtime.js +89 -0
- package/packages/cli/dist/runtime.js.map +1 -0
- package/packages/cli/package.json +38 -0
- package/packages/core/README.md +37 -0
- package/packages/core/dist/capsules/index.d.ts +4 -0
- package/packages/core/dist/capsules/index.d.ts.map +1 -0
- package/packages/core/dist/capsules/index.js +4 -0
- package/packages/core/dist/capsules/index.js.map +1 -0
- package/packages/core/dist/capsules/loadCapsule.d.ts +11 -0
- package/packages/core/dist/capsules/loadCapsule.d.ts.map +1 -0
- package/packages/core/dist/capsules/loadCapsule.js +167 -0
- package/packages/core/dist/capsules/loadCapsule.js.map +1 -0
- package/packages/core/dist/capsules/runCapsule.d.ts +3 -0
- package/packages/core/dist/capsules/runCapsule.d.ts.map +1 -0
- package/packages/core/dist/capsules/runCapsule.js +333 -0
- package/packages/core/dist/capsules/runCapsule.js.map +1 -0
- package/packages/core/dist/capsules/types.d.ts +106 -0
- package/packages/core/dist/capsules/types.d.ts.map +1 -0
- package/packages/core/dist/capsules/types.js +2 -0
- package/packages/core/dist/capsules/types.js.map +1 -0
- package/packages/core/dist/durableWrite.d.ts +2 -0
- package/packages/core/dist/durableWrite.d.ts.map +1 -0
- package/packages/core/dist/durableWrite.js +34 -0
- package/packages/core/dist/durableWrite.js.map +1 -0
- package/packages/core/dist/errors/registry.d.ts +122 -0
- package/packages/core/dist/errors/registry.d.ts.map +1 -0
- package/packages/core/dist/errors/registry.js +206 -0
- package/packages/core/dist/errors/registry.js.map +1 -0
- package/packages/core/dist/errors/render.d.ts +3 -0
- package/packages/core/dist/errors/render.d.ts.map +1 -0
- package/packages/core/dist/errors/render.js +64 -0
- package/packages/core/dist/errors/render.js.map +1 -0
- package/packages/core/dist/errors.d.ts +5 -0
- package/packages/core/dist/errors.d.ts.map +1 -0
- package/packages/core/dist/errors.js +9 -0
- package/packages/core/dist/errors.js.map +1 -0
- package/packages/core/dist/evidence/appendEvidenceEvent.d.ts +27 -0
- package/packages/core/dist/evidence/appendEvidenceEvent.d.ts.map +1 -0
- package/packages/core/dist/evidence/appendEvidenceEvent.js +218 -0
- package/packages/core/dist/evidence/appendEvidenceEvent.js.map +1 -0
- package/packages/core/dist/evidence/assurance.d.ts +18 -0
- package/packages/core/dist/evidence/assurance.d.ts.map +1 -0
- package/packages/core/dist/evidence/assurance.js +38 -0
- package/packages/core/dist/evidence/assurance.js.map +1 -0
- package/packages/core/dist/evidence/index.d.ts +8 -0
- package/packages/core/dist/evidence/index.d.ts.map +1 -0
- package/packages/core/dist/evidence/index.js +8 -0
- package/packages/core/dist/evidence/index.js.map +1 -0
- package/packages/core/dist/evidence/jsonlLedger.d.ts +13 -0
- package/packages/core/dist/evidence/jsonlLedger.d.ts.map +1 -0
- package/packages/core/dist/evidence/jsonlLedger.js +171 -0
- package/packages/core/dist/evidence/jsonlLedger.js.map +1 -0
- package/packages/core/dist/evidence/linkEvidence.d.ts +4 -0
- package/packages/core/dist/evidence/linkEvidence.d.ts.map +1 -0
- package/packages/core/dist/evidence/linkEvidence.js +53 -0
- package/packages/core/dist/evidence/linkEvidence.js.map +1 -0
- package/packages/core/dist/evidence/replayEvidence.d.ts +6 -0
- package/packages/core/dist/evidence/replayEvidence.d.ts.map +1 -0
- package/packages/core/dist/evidence/replayEvidence.js +216 -0
- package/packages/core/dist/evidence/replayEvidence.js.map +1 -0
- package/packages/core/dist/evidence/results.d.ts +4 -0
- package/packages/core/dist/evidence/results.d.ts.map +1 -0
- package/packages/core/dist/evidence/results.js +32 -0
- package/packages/core/dist/evidence/results.js.map +1 -0
- package/packages/core/dist/evidence/types.d.ts +149 -0
- package/packages/core/dist/evidence/types.d.ts.map +1 -0
- package/packages/core/dist/evidence/types.js +2 -0
- package/packages/core/dist/evidence/types.js.map +1 -0
- package/packages/core/dist/host-profiles/claude.yml +29 -0
- package/packages/core/dist/host-profiles/codex.yml +29 -0
- package/packages/core/dist/host-profiles/copilot.yml +29 -0
- package/packages/core/dist/host-profiles/opencode.yml +29 -0
- package/packages/core/dist/hosts/conformanceStatus.d.ts +16 -0
- package/packages/core/dist/hosts/conformanceStatus.d.ts.map +1 -0
- package/packages/core/dist/hosts/conformanceStatus.js +160 -0
- package/packages/core/dist/hosts/conformanceStatus.js.map +1 -0
- package/packages/core/dist/hosts/index.d.ts +5 -0
- package/packages/core/dist/hosts/index.d.ts.map +1 -0
- package/packages/core/dist/hosts/index.js +5 -0
- package/packages/core/dist/hosts/index.js.map +1 -0
- package/packages/core/dist/hosts/loadHostProfile.d.ts +6 -0
- package/packages/core/dist/hosts/loadHostProfile.d.ts.map +1 -0
- package/packages/core/dist/hosts/loadHostProfile.js +41 -0
- package/packages/core/dist/hosts/loadHostProfile.js.map +1 -0
- package/packages/core/dist/hosts/projectHostFiles.d.ts +16 -0
- package/packages/core/dist/hosts/projectHostFiles.d.ts.map +1 -0
- package/packages/core/dist/hosts/projectHostFiles.js +272 -0
- package/packages/core/dist/hosts/projectHostFiles.js.map +1 -0
- package/packages/core/dist/hosts/types.d.ts +122 -0
- package/packages/core/dist/hosts/types.d.ts.map +1 -0
- package/packages/core/dist/hosts/types.js +2 -0
- package/packages/core/dist/hosts/types.js.map +1 -0
- package/packages/core/dist/index.d.ts +26 -0
- package/packages/core/dist/index.d.ts.map +1 -0
- package/packages/core/dist/index.js +31 -0
- package/packages/core/dist/index.js.map +1 -0
- package/packages/core/dist/init/index.d.ts +2 -0
- package/packages/core/dist/init/index.d.ts.map +1 -0
- package/packages/core/dist/init/index.js +3 -0
- package/packages/core/dist/init/index.js.map +1 -0
- package/packages/core/dist/init/scaffold.d.ts +28 -0
- package/packages/core/dist/init/scaffold.d.ts.map +1 -0
- package/packages/core/dist/init/scaffold.js +293 -0
- package/packages/core/dist/init/scaffold.js.map +1 -0
- package/packages/core/dist/markers/appendOnly.d.ts +23 -0
- package/packages/core/dist/markers/appendOnly.d.ts.map +1 -0
- package/packages/core/dist/markers/appendOnly.js +75 -0
- package/packages/core/dist/markers/appendOnly.js.map +1 -0
- package/packages/core/dist/markers/bindingSetHash.d.ts +28 -0
- package/packages/core/dist/markers/bindingSetHash.d.ts.map +1 -0
- package/packages/core/dist/markers/bindingSetHash.js +33 -0
- package/packages/core/dist/markers/bindingSetHash.js.map +1 -0
- package/packages/core/dist/markers/canonicalJson.d.ts +4 -0
- package/packages/core/dist/markers/canonicalJson.d.ts.map +1 -0
- package/packages/core/dist/markers/canonicalJson.js +51 -0
- package/packages/core/dist/markers/canonicalJson.js.map +1 -0
- package/packages/core/dist/markers/ciAuthority.d.ts +17 -0
- package/packages/core/dist/markers/ciAuthority.d.ts.map +1 -0
- package/packages/core/dist/markers/ciAuthority.js +131 -0
- package/packages/core/dist/markers/ciAuthority.js.map +1 -0
- package/packages/core/dist/markers/cli/bind.d.ts +48 -0
- package/packages/core/dist/markers/cli/bind.d.ts.map +1 -0
- package/packages/core/dist/markers/cli/bind.js +198 -0
- package/packages/core/dist/markers/cli/bind.js.map +1 -0
- package/packages/core/dist/markers/cli/index.d.ts +9 -0
- package/packages/core/dist/markers/cli/index.d.ts.map +1 -0
- package/packages/core/dist/markers/cli/index.js +15 -0
- package/packages/core/dist/markers/cli/index.js.map +1 -0
- package/packages/core/dist/markers/cli/io.d.ts +18 -0
- package/packages/core/dist/markers/cli/io.d.ts.map +1 -0
- package/packages/core/dist/markers/cli/io.js +62 -0
- package/packages/core/dist/markers/cli/io.js.map +1 -0
- package/packages/core/dist/markers/cli/precommit.d.ts +32 -0
- package/packages/core/dist/markers/cli/precommit.d.ts.map +1 -0
- package/packages/core/dist/markers/cli/precommit.js +174 -0
- package/packages/core/dist/markers/cli/precommit.js.map +1 -0
- package/packages/core/dist/markers/cli/prove.d.ts +69 -0
- package/packages/core/dist/markers/cli/prove.d.ts.map +1 -0
- package/packages/core/dist/markers/cli/prove.js +381 -0
- package/packages/core/dist/markers/cli/prove.js.map +1 -0
- package/packages/core/dist/markers/cli/scan.d.ts +63 -0
- package/packages/core/dist/markers/cli/scan.d.ts.map +1 -0
- package/packages/core/dist/markers/cli/scan.js +233 -0
- package/packages/core/dist/markers/cli/scan.js.map +1 -0
- package/packages/core/dist/markers/cli/shared.d.ts +25 -0
- package/packages/core/dist/markers/cli/shared.d.ts.map +1 -0
- package/packages/core/dist/markers/cli/shared.js +123 -0
- package/packages/core/dist/markers/cli/shared.js.map +1 -0
- package/packages/core/dist/markers/cli/validateLedger.d.ts +38 -0
- package/packages/core/dist/markers/cli/validateLedger.d.ts.map +1 -0
- package/packages/core/dist/markers/cli/validateLedger.js +81 -0
- package/packages/core/dist/markers/cli/validateLedger.js.map +1 -0
- package/packages/core/dist/markers/cli/verify.d.ts +65 -0
- package/packages/core/dist/markers/cli/verify.d.ts.map +1 -0
- package/packages/core/dist/markers/cli/verify.js +245 -0
- package/packages/core/dist/markers/cli/verify.js.map +1 -0
- package/packages/core/dist/markers/commentPrefix.d.ts +7 -0
- package/packages/core/dist/markers/commentPrefix.d.ts.map +1 -0
- package/packages/core/dist/markers/commentPrefix.js +79 -0
- package/packages/core/dist/markers/commentPrefix.js.map +1 -0
- package/packages/core/dist/markers/constants.d.ts +10 -0
- package/packages/core/dist/markers/constants.d.ts.map +1 -0
- package/packages/core/dist/markers/constants.js +13 -0
- package/packages/core/dist/markers/constants.js.map +1 -0
- package/packages/core/dist/markers/evidenceLedger.d.ts +150 -0
- package/packages/core/dist/markers/evidenceLedger.d.ts.map +1 -0
- package/packages/core/dist/markers/evidenceLedger.js +391 -0
- package/packages/core/dist/markers/evidenceLedger.js.map +1 -0
- package/packages/core/dist/markers/freshness.d.ts +125 -0
- package/packages/core/dist/markers/freshness.d.ts.map +1 -0
- package/packages/core/dist/markers/freshness.js +605 -0
- package/packages/core/dist/markers/freshness.js.map +1 -0
- package/packages/core/dist/markers/index.d.ts +26 -0
- package/packages/core/dist/markers/index.d.ts.map +1 -0
- package/packages/core/dist/markers/index.js +38 -0
- package/packages/core/dist/markers/index.js.map +1 -0
- package/packages/core/dist/markers/keygen.d.ts +6 -0
- package/packages/core/dist/markers/keygen.d.ts.map +1 -0
- package/packages/core/dist/markers/keygen.js +18 -0
- package/packages/core/dist/markers/keygen.js.map +1 -0
- package/packages/core/dist/markers/keyring.d.ts +23 -0
- package/packages/core/dist/markers/keyring.d.ts.map +1 -0
- package/packages/core/dist/markers/keyring.js +93 -0
- package/packages/core/dist/markers/keyring.js.map +1 -0
- package/packages/core/dist/markers/markerLine.d.ts +35 -0
- package/packages/core/dist/markers/markerLine.d.ts.map +1 -0
- package/packages/core/dist/markers/markerLine.js +125 -0
- package/packages/core/dist/markers/markerLine.js.map +1 -0
- package/packages/core/dist/markers/physicalLines.d.ts +10 -0
- package/packages/core/dist/markers/physicalLines.d.ts.map +1 -0
- package/packages/core/dist/markers/physicalLines.js +48 -0
- package/packages/core/dist/markers/physicalLines.js.map +1 -0
- package/packages/core/dist/markers/policyHash.d.ts +4 -0
- package/packages/core/dist/markers/policyHash.d.ts.map +1 -0
- package/packages/core/dist/markers/policyHash.js +14 -0
- package/packages/core/dist/markers/policyHash.js.map +1 -0
- package/packages/core/dist/markers/proofSignature.d.ts +29 -0
- package/packages/core/dist/markers/proofSignature.d.ts.map +1 -0
- package/packages/core/dist/markers/proofSignature.js +106 -0
- package/packages/core/dist/markers/proofSignature.js.map +1 -0
- package/packages/core/dist/markers/reconcile.d.ts +26 -0
- package/packages/core/dist/markers/reconcile.d.ts.map +1 -0
- package/packages/core/dist/markers/reconcile.js +52 -0
- package/packages/core/dist/markers/reconcile.js.map +1 -0
- package/packages/core/dist/markers/registry.d.ts +53 -0
- package/packages/core/dist/markers/registry.d.ts.map +1 -0
- package/packages/core/dist/markers/registry.js +161 -0
- package/packages/core/dist/markers/registry.js.map +1 -0
- package/packages/core/dist/markers/rowHash.d.ts +2 -0
- package/packages/core/dist/markers/rowHash.d.ts.map +1 -0
- package/packages/core/dist/markers/rowHash.js +10 -0
- package/packages/core/dist/markers/rowHash.js.map +1 -0
- package/packages/core/dist/markers/scanner.d.ts +67 -0
- package/packages/core/dist/markers/scanner.d.ts.map +1 -0
- package/packages/core/dist/markers/scanner.js +292 -0
- package/packages/core/dist/markers/scanner.js.map +1 -0
- package/packages/core/dist/markers/schemas/binding-registry-event.schema.json +41 -0
- package/packages/core/dist/markers/schemas/freshness-status.schema.json +134 -0
- package/packages/core/dist/markers/schemas/proof-event.schema.json +170 -0
- package/packages/core/dist/markers/spanCanon.d.ts +4 -0
- package/packages/core/dist/markers/spanCanon.d.ts.map +1 -0
- package/packages/core/dist/markers/spanCanon.js +42 -0
- package/packages/core/dist/markers/spanCanon.js.map +1 -0
- package/packages/core/dist/markers/swiftFuncRecognizer.d.ts +36 -0
- package/packages/core/dist/markers/swiftFuncRecognizer.d.ts.map +1 -0
- package/packages/core/dist/markers/swiftFuncRecognizer.js +638 -0
- package/packages/core/dist/markers/swiftFuncRecognizer.js.map +1 -0
- package/packages/core/dist/markers/validators.d.ts +13 -0
- package/packages/core/dist/markers/validators.d.ts.map +1 -0
- package/packages/core/dist/markers/validators.js +64 -0
- package/packages/core/dist/markers/validators.js.map +1 -0
- package/packages/core/dist/markers/verificationContextHash.d.ts +23 -0
- package/packages/core/dist/markers/verificationContextHash.d.ts.map +1 -0
- package/packages/core/dist/markers/verificationContextHash.js +96 -0
- package/packages/core/dist/markers/verificationContextHash.js.map +1 -0
- package/packages/core/dist/markers/verifierPresets.d.ts +18 -0
- package/packages/core/dist/markers/verifierPresets.d.ts.map +1 -0
- package/packages/core/dist/markers/verifierPresets.js +71 -0
- package/packages/core/dist/markers/verifierPresets.js.map +1 -0
- package/packages/core/dist/markers/verifierResolver.d.ts +27 -0
- package/packages/core/dist/markers/verifierResolver.d.ts.map +1 -0
- package/packages/core/dist/markers/verifierResolver.js +151 -0
- package/packages/core/dist/markers/verifierResolver.js.map +1 -0
- package/packages/core/dist/migration/index.d.ts +2 -0
- package/packages/core/dist/migration/index.d.ts.map +1 -0
- package/packages/core/dist/migration/index.js +2 -0
- package/packages/core/dist/migration/index.js.map +1 -0
- package/packages/core/dist/migration/testMatrix.d.ts +42 -0
- package/packages/core/dist/migration/testMatrix.d.ts.map +1 -0
- package/packages/core/dist/migration/testMatrix.js +351 -0
- package/packages/core/dist/migration/testMatrix.js.map +1 -0
- package/packages/core/dist/package/index.d.ts +2 -0
- package/packages/core/dist/package/index.d.ts.map +1 -0
- package/packages/core/dist/package/index.js +2 -0
- package/packages/core/dist/package/index.js.map +1 -0
- package/packages/core/dist/package/inspectPackage.d.ts +67 -0
- package/packages/core/dist/package/inspectPackage.d.ts.map +1 -0
- package/packages/core/dist/package/inspectPackage.js +371 -0
- package/packages/core/dist/package/inspectPackage.js.map +1 -0
- package/packages/core/dist/presentation/candidates.d.ts +13 -0
- package/packages/core/dist/presentation/candidates.d.ts.map +1 -0
- package/packages/core/dist/presentation/candidates.js +86 -0
- package/packages/core/dist/presentation/candidates.js.map +1 -0
- package/packages/core/dist/presentation/index.d.ts +8 -0
- package/packages/core/dist/presentation/index.d.ts.map +1 -0
- package/packages/core/dist/presentation/index.js +8 -0
- package/packages/core/dist/presentation/index.js.map +1 -0
- package/packages/core/dist/presentation/items.d.ts +18 -0
- package/packages/core/dist/presentation/items.d.ts.map +1 -0
- package/packages/core/dist/presentation/items.js +228 -0
- package/packages/core/dist/presentation/items.js.map +1 -0
- package/packages/core/dist/presentation/ordering.d.ts +8 -0
- package/packages/core/dist/presentation/ordering.d.ts.map +1 -0
- package/packages/core/dist/presentation/ordering.js +31 -0
- package/packages/core/dist/presentation/ordering.js.map +1 -0
- package/packages/core/dist/presentation/planHelpers.d.ts +26 -0
- package/packages/core/dist/presentation/planHelpers.d.ts.map +1 -0
- package/packages/core/dist/presentation/planHelpers.js +62 -0
- package/packages/core/dist/presentation/planHelpers.js.map +1 -0
- package/packages/core/dist/presentation/presentationFormat.d.ts +39 -0
- package/packages/core/dist/presentation/presentationFormat.d.ts.map +1 -0
- package/packages/core/dist/presentation/presentationFormat.js +58 -0
- package/packages/core/dist/presentation/presentationFormat.js.map +1 -0
- package/packages/core/dist/presentation/renderCard.d.ts +37 -0
- package/packages/core/dist/presentation/renderCard.d.ts.map +1 -0
- package/packages/core/dist/presentation/renderCard.js +129 -0
- package/packages/core/dist/presentation/renderCard.js.map +1 -0
- package/packages/core/dist/presentation/scoring.d.ts +10 -0
- package/packages/core/dist/presentation/scoring.d.ts.map +1 -0
- package/packages/core/dist/presentation/scoring.js +82 -0
- package/packages/core/dist/presentation/scoring.js.map +1 -0
- package/packages/core/dist/presentation/selectPlan.d.ts +4 -0
- package/packages/core/dist/presentation/selectPlan.d.ts.map +1 -0
- package/packages/core/dist/presentation/selectPlan.js +122 -0
- package/packages/core/dist/presentation/selectPlan.js.map +1 -0
- package/packages/core/dist/presentation/selectShowcasePlan.d.ts +3 -0
- package/packages/core/dist/presentation/selectShowcasePlan.d.ts.map +1 -0
- package/packages/core/dist/presentation/selectShowcasePlan.js +6 -0
- package/packages/core/dist/presentation/selectShowcasePlan.js.map +1 -0
- package/packages/core/dist/presentation/selectWalkthroughPlan.d.ts +3 -0
- package/packages/core/dist/presentation/selectWalkthroughPlan.d.ts.map +1 -0
- package/packages/core/dist/presentation/selectWalkthroughPlan.js +6 -0
- package/packages/core/dist/presentation/selectWalkthroughPlan.js.map +1 -0
- package/packages/core/dist/presentation/selection.d.ts +7 -0
- package/packages/core/dist/presentation/selection.d.ts.map +1 -0
- package/packages/core/dist/presentation/selection.js +20 -0
- package/packages/core/dist/presentation/selection.js.map +1 -0
- package/packages/core/dist/presentation/snapshot.d.ts +12 -0
- package/packages/core/dist/presentation/snapshot.d.ts.map +1 -0
- package/packages/core/dist/presentation/snapshot.js +53 -0
- package/packages/core/dist/presentation/snapshot.js.map +1 -0
- package/packages/core/dist/presentation/types.d.ts +172 -0
- package/packages/core/dist/presentation/types.d.ts.map +1 -0
- package/packages/core/dist/presentation/types.js +2 -0
- package/packages/core/dist/presentation/types.js.map +1 -0
- package/packages/core/dist/redact.d.ts +11 -0
- package/packages/core/dist/redact.d.ts.map +1 -0
- package/packages/core/dist/redact.js +17 -0
- package/packages/core/dist/redact.js.map +1 -0
- package/packages/core/dist/roots.d.ts +81 -0
- package/packages/core/dist/roots.d.ts.map +1 -0
- package/packages/core/dist/roots.js +220 -0
- package/packages/core/dist/roots.js.map +1 -0
- package/packages/core/dist/schema/cliResult.d.ts +34 -0
- package/packages/core/dist/schema/cliResult.d.ts.map +1 -0
- package/packages/core/dist/schema/cliResult.js +35 -0
- package/packages/core/dist/schema/cliResult.js.map +1 -0
- package/packages/core/dist/schema/diagnostic.d.ts +26 -0
- package/packages/core/dist/schema/diagnostic.d.ts.map +1 -0
- package/packages/core/dist/schema/diagnostic.js +28 -0
- package/packages/core/dist/schema/diagnostic.js.map +1 -0
- package/packages/core/dist/schema/index.d.ts +8 -0
- package/packages/core/dist/schema/index.d.ts.map +1 -0
- package/packages/core/dist/schema/index.js +9 -0
- package/packages/core/dist/schema/index.js.map +1 -0
- package/packages/core/dist/schema/registry.d.ts +15 -0
- package/packages/core/dist/schema/registry.d.ts.map +1 -0
- package/packages/core/dist/schema/registry.js +206 -0
- package/packages/core/dist/schema/registry.js.map +1 -0
- package/packages/core/dist/schema/syntheticContracts.d.ts +3 -0
- package/packages/core/dist/schema/syntheticContracts.d.ts.map +1 -0
- package/packages/core/dist/schema/syntheticContracts.js +342 -0
- package/packages/core/dist/schema/syntheticContracts.js.map +1 -0
- package/packages/core/dist/schema/validate.d.ts +21 -0
- package/packages/core/dist/schema/validate.d.ts.map +1 -0
- package/packages/core/dist/schema/validate.js +210 -0
- package/packages/core/dist/schema/validate.js.map +1 -0
- package/packages/core/dist/schemas/v1/authority.schema.json +70 -0
- package/packages/core/dist/schemas/v1/cli-result.schema.json +30 -0
- package/packages/core/dist/schemas/v1/common.schema.json +274 -0
- package/packages/core/dist/schemas/v1/demo-capsule.schema.json +78 -0
- package/packages/core/dist/schemas/v1/evidence-append-result.schema.json +14 -0
- package/packages/core/dist/schemas/v1/evidence-event.schema.json +181 -0
- package/packages/core/dist/schemas/v1/evidence-status-result.schema.json +68 -0
- package/packages/core/dist/schemas/v1/host-profile.schema.json +94 -0
- package/packages/core/dist/schemas/v1/host-status-result.schema.json +49 -0
- package/packages/core/dist/schemas/v1/keyring.schema.json +77 -0
- package/packages/core/dist/schemas/v1/ledger.schema.json +99 -0
- package/packages/core/dist/schemas/v1/marker.schema.json +84 -0
- package/packages/core/dist/schemas/v1/matrix-list-result.schema.json +67 -0
- package/packages/core/dist/schemas/v1/matrix-mutation-result.schema.json +49 -0
- package/packages/core/dist/schemas/v1/matrix-validation-result.schema.json +77 -0
- package/packages/core/dist/schemas/v1/mcp-tool-results.schema.json +34 -0
- package/packages/core/dist/schemas/v1/migration-test-matrix-result.schema.json +76 -0
- package/packages/core/dist/schemas/v1/presentation-plan-result.schema.json +62 -0
- package/packages/core/dist/schemas/v1/presentation-plan.schema.json +259 -0
- package/packages/core/dist/schemas/v1/release-gate-result.schema.json +136 -0
- package/packages/core/dist/schemas/v1/showcase-approval-result.schema.json +5 -0
- package/packages/core/dist/schemas/v1/showcase-event-append-result.schema.json +17 -0
- package/packages/core/dist/schemas/v1/showcase-event.schema.json +235 -0
- package/packages/core/dist/schemas/v1/showcase-finish-result.schema.json +5 -0
- package/packages/core/dist/schemas/v1/showcase-run-status-result.schema.json +70 -0
- package/packages/core/dist/schemas/v1/showcase-start-result.schema.json +5 -0
- package/packages/core/dist/schemas/v1/use-case-file.schema.json +178 -0
- package/packages/core/dist/schemas/v1/workflow-mode.schema.json +16 -0
- package/packages/core/dist/schemas/v1/workspace-config.schema.json +58 -0
- package/packages/core/dist/showcase/appendShowcaseEvent.d.ts +116 -0
- package/packages/core/dist/showcase/appendShowcaseEvent.d.ts.map +1 -0
- package/packages/core/dist/showcase/appendShowcaseEvent.js +353 -0
- package/packages/core/dist/showcase/appendShowcaseEvent.js.map +1 -0
- package/packages/core/dist/showcase/approval.d.ts +2 -0
- package/packages/core/dist/showcase/approval.d.ts.map +1 -0
- package/packages/core/dist/showcase/approval.js +2 -0
- package/packages/core/dist/showcase/approval.js.map +1 -0
- package/packages/core/dist/showcase/approvalAuthority.d.ts +19 -0
- package/packages/core/dist/showcase/approvalAuthority.d.ts.map +1 -0
- package/packages/core/dist/showcase/approvalAuthority.js +46 -0
- package/packages/core/dist/showcase/approvalAuthority.js.map +1 -0
- package/packages/core/dist/showcase/index.d.ts +11 -0
- package/packages/core/dist/showcase/index.d.ts.map +1 -0
- package/packages/core/dist/showcase/index.js +11 -0
- package/packages/core/dist/showcase/index.js.map +1 -0
- package/packages/core/dist/showcase/jsonlLedger.d.ts +11 -0
- package/packages/core/dist/showcase/jsonlLedger.d.ts.map +1 -0
- package/packages/core/dist/showcase/jsonlLedger.js +50 -0
- package/packages/core/dist/showcase/jsonlLedger.js.map +1 -0
- package/packages/core/dist/showcase/planBinding.d.ts +5 -0
- package/packages/core/dist/showcase/planBinding.d.ts.map +1 -0
- package/packages/core/dist/showcase/planBinding.js +33 -0
- package/packages/core/dist/showcase/planBinding.js.map +1 -0
- package/packages/core/dist/showcase/replayRun.d.ts +5 -0
- package/packages/core/dist/showcase/replayRun.d.ts.map +1 -0
- package/packages/core/dist/showcase/replayRun.js +199 -0
- package/packages/core/dist/showcase/replayRun.js.map +1 -0
- package/packages/core/dist/showcase/results.d.ts +3 -0
- package/packages/core/dist/showcase/results.d.ts.map +1 -0
- package/packages/core/dist/showcase/results.js +4 -0
- package/packages/core/dist/showcase/results.js.map +1 -0
- package/packages/core/dist/showcase/revisionEpochs.d.ts +2 -0
- package/packages/core/dist/showcase/revisionEpochs.d.ts.map +1 -0
- package/packages/core/dist/showcase/revisionEpochs.js +2 -0
- package/packages/core/dist/showcase/revisionEpochs.js.map +1 -0
- package/packages/core/dist/showcase/startRun.d.ts +2 -0
- package/packages/core/dist/showcase/startRun.d.ts.map +1 -0
- package/packages/core/dist/showcase/startRun.js +2 -0
- package/packages/core/dist/showcase/startRun.js.map +1 -0
- package/packages/core/dist/showcase/types.d.ts +66 -0
- package/packages/core/dist/showcase/types.d.ts.map +1 -0
- package/packages/core/dist/showcase/types.js +2 -0
- package/packages/core/dist/showcase/types.js.map +1 -0
- package/packages/core/dist/skills/canonicalSkills.d.ts +3 -0
- package/packages/core/dist/skills/canonicalSkills.d.ts.map +1 -0
- package/packages/core/dist/skills/canonicalSkills.js +7 -0
- package/packages/core/dist/skills/canonicalSkills.js.map +1 -0
- package/packages/core/dist/skills/index.d.ts +4 -0
- package/packages/core/dist/skills/index.d.ts.map +1 -0
- package/packages/core/dist/skills/index.js +4 -0
- package/packages/core/dist/skills/index.js.map +1 -0
- package/packages/core/dist/skills/types.d.ts +26 -0
- package/packages/core/dist/skills/types.d.ts.map +1 -0
- package/packages/core/dist/skills/types.js +2 -0
- package/packages/core/dist/skills/types.js.map +1 -0
- package/packages/core/dist/skills/validateSkillAssets.d.ts +6 -0
- package/packages/core/dist/skills/validateSkillAssets.d.ts.map +1 -0
- package/packages/core/dist/skills/validateSkillAssets.js +218 -0
- package/packages/core/dist/skills/validateSkillAssets.js.map +1 -0
- package/packages/core/dist/useCases/integrity.d.ts +11 -0
- package/packages/core/dist/useCases/integrity.d.ts.map +1 -0
- package/packages/core/dist/useCases/integrity.js +178 -0
- package/packages/core/dist/useCases/integrity.js.map +1 -0
- package/packages/core/dist/useCases/loadUseCaseMatrix.d.ts +7 -0
- package/packages/core/dist/useCases/loadUseCaseMatrix.d.ts.map +1 -0
- package/packages/core/dist/useCases/loadUseCaseMatrix.js +74 -0
- package/packages/core/dist/useCases/loadUseCaseMatrix.js.map +1 -0
- package/packages/core/dist/useCases/mutateUseCaseMatrix.d.ts +25 -0
- package/packages/core/dist/useCases/mutateUseCaseMatrix.d.ts.map +1 -0
- package/packages/core/dist/useCases/mutateUseCaseMatrix.js +198 -0
- package/packages/core/dist/useCases/mutateUseCaseMatrix.js.map +1 -0
- package/packages/core/dist/useCases/query.d.ts +12 -0
- package/packages/core/dist/useCases/query.d.ts.map +1 -0
- package/packages/core/dist/useCases/query.js +47 -0
- package/packages/core/dist/useCases/query.js.map +1 -0
- package/packages/core/dist/useCases/types.d.ts +149 -0
- package/packages/core/dist/useCases/types.d.ts.map +1 -0
- package/packages/core/dist/useCases/types.js +2 -0
- package/packages/core/dist/useCases/types.js.map +1 -0
- package/packages/core/dist/useCases/validateUseCaseFile.d.ts +9 -0
- package/packages/core/dist/useCases/validateUseCaseFile.d.ts.map +1 -0
- package/packages/core/dist/useCases/validateUseCaseFile.js +107 -0
- package/packages/core/dist/useCases/validateUseCaseFile.js.map +1 -0
- package/packages/core/dist/version.d.ts +9 -0
- package/packages/core/dist/version.d.ts.map +1 -0
- package/packages/core/dist/version.js +17 -0
- package/packages/core/dist/version.js.map +1 -0
- package/packages/core/package.json +39 -0
- package/packages/mcp/README.md +48 -0
- package/packages/mcp/dist/index.d.ts +20 -0
- package/packages/mcp/dist/index.d.ts.map +1 -0
- package/packages/mcp/dist/index.js +180 -0
- package/packages/mcp/dist/index.js.map +1 -0
- package/packages/mcp/dist/prompts.d.ts +32 -0
- package/packages/mcp/dist/prompts.d.ts.map +1 -0
- package/packages/mcp/dist/prompts.js +199 -0
- package/packages/mcp/dist/prompts.js.map +1 -0
- package/packages/mcp/dist/resources.d.ts +22 -0
- package/packages/mcp/dist/resources.d.ts.map +1 -0
- package/packages/mcp/dist/resources.js +342 -0
- package/packages/mcp/dist/resources.js.map +1 -0
- package/packages/mcp/dist/toolHandlers.d.ts +28 -0
- package/packages/mcp/dist/toolHandlers.d.ts.map +1 -0
- package/packages/mcp/dist/toolHandlers.js +592 -0
- package/packages/mcp/dist/toolHandlers.js.map +1 -0
- package/packages/mcp/dist/toolSchemas.d.ts +23 -0
- package/packages/mcp/dist/toolSchemas.d.ts.map +1 -0
- package/packages/mcp/dist/toolSchemas.js +223 -0
- package/packages/mcp/dist/toolSchemas.js.map +1 -0
- package/packages/mcp/dist/tools.d.ts +22 -0
- package/packages/mcp/dist/tools.d.ts.map +1 -0
- package/packages/mcp/dist/tools.js +65 -0
- package/packages/mcp/dist/tools.js.map +1 -0
- package/packages/mcp/package.json +38 -0
- package/plugin.json +6 -0
- package/schemas/v1/authority.schema.json +70 -0
- package/schemas/v1/cli-result.schema.json +30 -0
- package/schemas/v1/common.schema.json +274 -0
- package/schemas/v1/demo-capsule.schema.json +78 -0
- package/schemas/v1/evidence-append-result.schema.json +14 -0
- package/schemas/v1/evidence-event.schema.json +181 -0
- package/schemas/v1/evidence-status-result.schema.json +68 -0
- package/schemas/v1/host-profile.schema.json +94 -0
- package/schemas/v1/host-status-result.schema.json +49 -0
- package/schemas/v1/keyring.schema.json +77 -0
- package/schemas/v1/ledger.schema.json +99 -0
- package/schemas/v1/marker.schema.json +84 -0
- package/schemas/v1/matrix-list-result.schema.json +67 -0
- package/schemas/v1/matrix-mutation-result.schema.json +49 -0
- package/schemas/v1/matrix-validation-result.schema.json +77 -0
- package/schemas/v1/mcp-tool-results.schema.json +34 -0
- package/schemas/v1/migration-test-matrix-result.schema.json +76 -0
- package/schemas/v1/presentation-plan-result.schema.json +62 -0
- package/schemas/v1/presentation-plan.schema.json +259 -0
- package/schemas/v1/release-gate-result.schema.json +136 -0
- package/schemas/v1/showcase-approval-result.schema.json +5 -0
- package/schemas/v1/showcase-event-append-result.schema.json +17 -0
- package/schemas/v1/showcase-event.schema.json +235 -0
- package/schemas/v1/showcase-finish-result.schema.json +5 -0
- package/schemas/v1/showcase-run-status-result.schema.json +70 -0
- package/schemas/v1/showcase-start-result.schema.json +5 -0
- package/schemas/v1/use-case-file.schema.json +178 -0
- package/schemas/v1/workflow-mode.schema.json +16 -0
- package/schemas/v1/workspace-config.schema.json +58 -0
- package/use-cases/capsule/demos.yml +212 -0
- package/use-cases/capsule/runner.yml +49 -0
- package/use-cases/diagnostics/contracts.yml +239 -0
- package/use-cases/evidence/core.yml +32 -0
- package/use-cases/evidence/ledger.yml +330 -0
- package/use-cases/hosts/profiles.yml +365 -0
- package/use-cases/hosts/projections.yml +96 -0
- package/use-cases/lifecycle/loop.yml +229 -0
- package/use-cases/matrix/core.yml +92 -0
- package/use-cases/matrix/product.yml +289 -0
- package/use-cases/mcp/surface.yml +257 -0
- package/use-cases/mcp/wrapper.yml +100 -0
- package/use-cases/migration/importer.yml +171 -0
- package/use-cases/migration/test-matrix.yml +32 -0
- package/use-cases/planning/cards.yml +215 -0
- package/use-cases/release/package.yml +80 -0
- package/use-cases/release/proof.yml +180 -0
- package/use-cases/roadmap/deferred.yml +184 -0
- package/use-cases/showcase/flow.yml +269 -0
- package/use-cases/showcase/live.yml +44 -0
- package/use-cases/skills/assets.yml +92 -0
- package/use-cases.yml +9 -0
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
export interface MarkerValidationError {
|
|
2
|
+
instance_path: string;
|
|
3
|
+
message: string;
|
|
4
|
+
}
|
|
5
|
+
export interface MarkerValidationResult {
|
|
6
|
+
ok: boolean;
|
|
7
|
+
errors: MarkerValidationError[];
|
|
8
|
+
}
|
|
9
|
+
export declare function validateMarkerSchema(schemaId: string, value: unknown): MarkerValidationResult;
|
|
10
|
+
export declare function validateBindingRegistryEvent(value: unknown): MarkerValidationResult;
|
|
11
|
+
export declare function validateProofEvent(value: unknown): MarkerValidationResult;
|
|
12
|
+
export declare function validateFreshnessStatus(value: unknown): MarkerValidationResult;
|
|
13
|
+
//# sourceMappingURL=validators.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"validators.d.ts","sourceRoot":"","sources":["../../src/markers/validators.ts"],"names":[],"mappings":"AAUA,MAAM,WAAW,qBAAqB;IACpC,aAAa,EAAE,MAAM,CAAC;IACtB,OAAO,EAAE,MAAM,CAAC;CACjB;AAED,MAAM,WAAW,sBAAsB;IACrC,EAAE,EAAE,OAAO,CAAC;IACZ,MAAM,EAAE,qBAAqB,EAAE,CAAC;CACjC;AA2CD,wBAAgB,oBAAoB,CAAC,QAAQ,EAAE,MAAM,EAAE,KAAK,EAAE,OAAO,GAAG,sBAAsB,CAkB7F;AAED,wBAAgB,4BAA4B,CAAC,KAAK,EAAE,OAAO,GAAG,sBAAsB,CAEnF;AAED,wBAAgB,kBAAkB,CAAC,KAAK,EAAE,OAAO,GAAG,sBAAsB,CAEzE;AAED,wBAAgB,uBAAuB,CAAC,KAAK,EAAE,OAAO,GAAG,sBAAsB,CAE9E"}
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
import Ajv2020Module, {} from "ajv/dist/2020.js";
|
|
2
|
+
import { existsSync, readFileSync } from "node:fs";
|
|
3
|
+
import { join } from "node:path";
|
|
4
|
+
import { fileURLToPath } from "node:url";
|
|
5
|
+
import { BINDING_REGISTRY_SCHEMA_ID, EVIDENCE_SCHEMA_ID, STATUS_SCHEMA_ID } from "./constants.js";
|
|
6
|
+
const SCHEMA_FILES = {
|
|
7
|
+
[BINDING_REGISTRY_SCHEMA_ID]: "binding-registry-event.schema.json",
|
|
8
|
+
[EVIDENCE_SCHEMA_ID]: "proof-event.schema.json",
|
|
9
|
+
[STATUS_SCHEMA_ID]: "freshness-status.schema.json"
|
|
10
|
+
};
|
|
11
|
+
let validatorCache;
|
|
12
|
+
function findSchemasDir() {
|
|
13
|
+
const candidates = [
|
|
14
|
+
fileURLToPath(new URL("./schemas/", import.meta.url)),
|
|
15
|
+
fileURLToPath(new URL("../../src/markers/schemas/", import.meta.url))
|
|
16
|
+
];
|
|
17
|
+
const found = candidates.find((candidate) => existsSync(join(candidate, "binding-registry-event.schema.json")));
|
|
18
|
+
if (!found) {
|
|
19
|
+
throw new Error(`unable to locate markers schemas from ${import.meta.url}`);
|
|
20
|
+
}
|
|
21
|
+
return found;
|
|
22
|
+
}
|
|
23
|
+
function buildValidators() {
|
|
24
|
+
if (validatorCache) {
|
|
25
|
+
return validatorCache;
|
|
26
|
+
}
|
|
27
|
+
const Ajv2020 = Ajv2020Module.default;
|
|
28
|
+
const ajv = new Ajv2020({ allErrors: true, strict: true });
|
|
29
|
+
const schemasDir = findSchemasDir();
|
|
30
|
+
validatorCache = new Map(Object.entries(SCHEMA_FILES).map(([schemaId, fileName]) => {
|
|
31
|
+
const schema = JSON.parse(readFileSync(join(schemasDir, fileName), "utf8"));
|
|
32
|
+
return [schemaId, ajv.compile(schema)];
|
|
33
|
+
}));
|
|
34
|
+
return validatorCache;
|
|
35
|
+
}
|
|
36
|
+
export function validateMarkerSchema(schemaId, value) {
|
|
37
|
+
const validator = buildValidators().get(schemaId);
|
|
38
|
+
if (!validator) {
|
|
39
|
+
return {
|
|
40
|
+
ok: false,
|
|
41
|
+
errors: [{ instance_path: "", message: `unknown schema: ${schemaId}` }]
|
|
42
|
+
};
|
|
43
|
+
}
|
|
44
|
+
const ok = validator(value);
|
|
45
|
+
return {
|
|
46
|
+
ok,
|
|
47
|
+
errors: ok
|
|
48
|
+
? []
|
|
49
|
+
: (validator.errors ?? []).map((error) => ({
|
|
50
|
+
instance_path: error.instancePath,
|
|
51
|
+
message: error.message ?? "schema validation failed"
|
|
52
|
+
}))
|
|
53
|
+
};
|
|
54
|
+
}
|
|
55
|
+
export function validateBindingRegistryEvent(value) {
|
|
56
|
+
return validateMarkerSchema(BINDING_REGISTRY_SCHEMA_ID, value);
|
|
57
|
+
}
|
|
58
|
+
export function validateProofEvent(value) {
|
|
59
|
+
return validateMarkerSchema(EVIDENCE_SCHEMA_ID, value);
|
|
60
|
+
}
|
|
61
|
+
export function validateFreshnessStatus(value) {
|
|
62
|
+
return validateMarkerSchema(STATUS_SCHEMA_ID, value);
|
|
63
|
+
}
|
|
64
|
+
//# sourceMappingURL=validators.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"validators.js","sourceRoot":"","sources":["../../src/markers/validators.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { type VerifierResolution, type WorkspaceVerifierContext } from "./verifierResolver.js";
|
|
2
|
+
export declare const VERIFICATION_CONTEXT_HASH_ID = "ucase-verification-context-hash-v1";
|
|
3
|
+
export interface VerificationContextFs {
|
|
4
|
+
readText(path: string): string | null;
|
|
5
|
+
}
|
|
6
|
+
export interface VerificationContextHashArgs {
|
|
7
|
+
verificationPolicy: unknown;
|
|
8
|
+
verifiers: ReadonlyArray<VerifierResolution>;
|
|
9
|
+
rootDir: string;
|
|
10
|
+
fs: VerificationContextFs;
|
|
11
|
+
lockfileName?: string;
|
|
12
|
+
}
|
|
13
|
+
export declare function computeVerificationContextHash(args: VerificationContextHashArgs): string;
|
|
14
|
+
export interface RowVerificationContextHashArgs {
|
|
15
|
+
slug: string;
|
|
16
|
+
verificationPolicy: unknown;
|
|
17
|
+
rootDir: string;
|
|
18
|
+
fs: VerificationContextFs;
|
|
19
|
+
lockfileName?: string;
|
|
20
|
+
workspaceVerifiers?: WorkspaceVerifierContext;
|
|
21
|
+
}
|
|
22
|
+
export declare function computeRowVerificationContextHash(args: RowVerificationContextHashArgs): string;
|
|
23
|
+
//# sourceMappingURL=verificationContextHash.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"verificationContextHash.d.ts","sourceRoot":"","sources":["../../src/markers/verificationContextHash.ts"],"names":[],"mappings":"AAqBA,OAAO,EAEL,KAAK,kBAAkB,EACvB,KAAK,wBAAwB,EAC9B,MAAM,uBAAuB,CAAC;AAG/B,eAAO,MAAM,4BAA4B,uCAAuC,CAAC;AAUjF,MAAM,WAAW,qBAAqB;IAEpC,QAAQ,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI,CAAC;CACvC;AAED,MAAM,WAAW,2BAA2B;IAE1C,kBAAkB,EAAE,OAAO,CAAC;IAE5B,SAAS,EAAE,aAAa,CAAC,kBAAkB,CAAC,CAAC;IAE7C,OAAO,EAAE,MAAM,CAAC;IAChB,EAAE,EAAE,qBAAqB,CAAC;IAE1B,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB;AA8BD,wBAAgB,8BAA8B,CAAC,IAAI,EAAE,2BAA2B,GAAG,MAAM,CA+BxF;AAED,MAAM,WAAW,8BAA8B;IAE7C,IAAI,EAAE,MAAM,CAAC;IACb,kBAAkB,EAAE,OAAO,CAAC;IAC5B,OAAO,EAAE,MAAM,CAAC;IAChB,EAAE,EAAE,qBAAqB,CAAC;IAC1B,YAAY,CAAC,EAAE,MAAM,CAAC;IAItB,kBAAkB,CAAC,EAAE,wBAAwB,CAAC;CAC/C;AAKD,wBAAgB,iCAAiC,CAAC,IAAI,EAAE,8BAA8B,GAAG,MAAM,CAY9F"}
|
|
@@ -0,0 +1,96 @@
|
|
|
1
|
+
// Verification context hash (closes the "weakened verifier" freshness hole).
|
|
2
|
+
//
|
|
3
|
+
// A proof event today certifies {row hash, policy hashes, binding-set hash, span
|
|
4
|
+
// hashes} — i.e. WHAT was verified and against WHICH code. It says nothing about
|
|
5
|
+
// HOW it was verified. So if someone later weakens or deletes the row's
|
|
6
|
+
// acceptance test while the production spans are untouched, the old proof stays
|
|
7
|
+
// FRESH even though the thing that proved it is gone.
|
|
8
|
+
//
|
|
9
|
+
// `computeVerificationContextHash` binds a proof to its verifier context: the
|
|
10
|
+
// row's verification_policy, the RESOLVED verifier(s) it demands (id, kind,
|
|
11
|
+
// evidence_kind, command argv, timeout), the byte contents of every declared
|
|
12
|
+
// input file (e.g. the acceptance test itself), and the repo lockfile. The hash
|
|
13
|
+
// is embedded in the proof and re-derived at scan time; if it drifts, the proof
|
|
14
|
+
// is no longer FRESH.
|
|
15
|
+
//
|
|
16
|
+
// Pure + deterministic: file reads go through an injected seam, a missing input
|
|
17
|
+
// is an explicit `absent` marker (never an error), inputs are sorted+deduped, and
|
|
18
|
+
// the result depends ONLY on the declared inputs + lockfile + policy + verifiers —
|
|
19
|
+
// never on unrelated files in the tree.
|
|
20
|
+
import { isAbsolute, join } from "node:path";
|
|
21
|
+
import { canonicalJsonSha256, sha256 } from "./canonicalJson.js";
|
|
22
|
+
import { resolveRowVerifiers } from "./verifierResolver.js";
|
|
23
|
+
// The id of this hashing algorithm, embedded alongside the hash in proof events.
|
|
24
|
+
export const VERIFICATION_CONTEXT_HASH_ID = "ucase-verification-context-hash-v1";
|
|
25
|
+
// Deterministic sentinel for a declared input (or lockfile) that does not exist.
|
|
26
|
+
// Distinct from any real `sha256:...` value, so absent != present-but-empty.
|
|
27
|
+
const ABSENT_CONTENT = "absent";
|
|
28
|
+
// The repo lockfile whose contents pin the toolchain a verifier would run under.
|
|
29
|
+
const DEFAULT_LOCKFILE = "pnpm-lock.yaml";
|
|
30
|
+
// sha256 of a file's bytes, or the ABSENT sentinel when it does not exist.
|
|
31
|
+
function contentMarker(fs, rootDir, relOrAbs) {
|
|
32
|
+
const path = isAbsolute(relOrAbs) ? relOrAbs : join(rootDir, relOrAbs);
|
|
33
|
+
const text = fs.readText(path);
|
|
34
|
+
return text === null ? ABSENT_CONTENT : sha256(text);
|
|
35
|
+
}
|
|
36
|
+
// Canonical, order-stable projection of one resolved/blocked verifier. Only the
|
|
37
|
+
// fields that define HOW verification runs are hashed (line/format independent).
|
|
38
|
+
function verifierToCanon(verifier) {
|
|
39
|
+
if (verifier.status === "resolved") {
|
|
40
|
+
const canon = {
|
|
41
|
+
verifier_id: verifier.verifier_id,
|
|
42
|
+
status: verifier.status,
|
|
43
|
+
kind: verifier.kind,
|
|
44
|
+
evidence_kind: verifier.evidence_kind,
|
|
45
|
+
command: verifier.command
|
|
46
|
+
};
|
|
47
|
+
if (verifier.timeout_seconds !== undefined) {
|
|
48
|
+
canon.timeout_seconds = verifier.timeout_seconds;
|
|
49
|
+
}
|
|
50
|
+
return canon;
|
|
51
|
+
}
|
|
52
|
+
return { verifier_id: verifier.verifier_id, status: verifier.status, reason: verifier.reason };
|
|
53
|
+
}
|
|
54
|
+
// Compute the verification context hash for a row given its already-resolved
|
|
55
|
+
// verifiers. Returns "sha256:<hex>".
|
|
56
|
+
export function computeVerificationContextHash(args) {
|
|
57
|
+
const lockfileName = args.lockfileName ?? DEFAULT_LOCKFILE;
|
|
58
|
+
// Verifiers sorted by id for stability (resolveRowVerifiers already sorts, but
|
|
59
|
+
// this keeps the hash independent of caller ordering).
|
|
60
|
+
const verifiers = [...args.verifiers]
|
|
61
|
+
.sort((left, right) => left.verifier_id < right.verifier_id ? -1 : left.verifier_id > right.verifier_id ? 1 : 0)
|
|
62
|
+
.map(verifierToCanon);
|
|
63
|
+
// Union of every resolved verifier's declared inputs, deduped + sorted, each
|
|
64
|
+
// paired with the sha256 of its current bytes (or the absent marker).
|
|
65
|
+
const inputPaths = new Set();
|
|
66
|
+
for (const verifier of args.verifiers) {
|
|
67
|
+
if (verifier.status === "resolved") {
|
|
68
|
+
for (const input of verifier.inputs) {
|
|
69
|
+
inputPaths.add(input);
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
const inputs = [...inputPaths]
|
|
74
|
+
.sort((left, right) => (left < right ? -1 : left > right ? 1 : 0))
|
|
75
|
+
.map((path) => ({ path, content_sha256: contentMarker(args.fs, args.rootDir, path) }));
|
|
76
|
+
return canonicalJsonSha256({
|
|
77
|
+
verification_policy: args.verificationPolicy ?? null,
|
|
78
|
+
verifiers,
|
|
79
|
+
inputs,
|
|
80
|
+
lockfile_sha256: contentMarker(args.fs, args.rootDir, lockfileName)
|
|
81
|
+
});
|
|
82
|
+
}
|
|
83
|
+
// Convenience: resolve a row's verifiers, then compute its context hash. This is
|
|
84
|
+
// the single entry point both `prove` (to embed) and `scan` (to re-derive) use,
|
|
85
|
+
// so the embedded and recomputed hashes are guaranteed to agree byte-for-byte.
|
|
86
|
+
export function computeRowVerificationContextHash(args) {
|
|
87
|
+
const verifiers = resolveRowVerifiers({ slug: args.slug, verification_policy: args.verificationPolicy }, args.workspaceVerifiers ?? {});
|
|
88
|
+
return computeVerificationContextHash({
|
|
89
|
+
verificationPolicy: args.verificationPolicy,
|
|
90
|
+
verifiers,
|
|
91
|
+
rootDir: args.rootDir,
|
|
92
|
+
fs: args.fs,
|
|
93
|
+
lockfileName: args.lockfileName
|
|
94
|
+
});
|
|
95
|
+
}
|
|
96
|
+
//# sourceMappingURL=verificationContextHash.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"verificationContextHash.js","sourceRoot":"","sources":["../../src/markers/verificationContextHash.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
export declare const VERIFIER_PRESET_IDS: readonly ["command.generic", "js.vitest", "js.npm-test", "python.pytest", "go.test", "make.target"];
|
|
2
|
+
export type VerifierPresetId = (typeof VERIFIER_PRESET_IDS)[number];
|
|
3
|
+
export interface ExpandedPreset {
|
|
4
|
+
kind: "script";
|
|
5
|
+
command: string[];
|
|
6
|
+
inputs: string[];
|
|
7
|
+
}
|
|
8
|
+
export type PresetExpansion = {
|
|
9
|
+
status: "resolved";
|
|
10
|
+
preset: VerifierPresetId;
|
|
11
|
+
expansion: ExpandedPreset;
|
|
12
|
+
} | {
|
|
13
|
+
status: "blocked";
|
|
14
|
+
reason: string;
|
|
15
|
+
};
|
|
16
|
+
export declare function isVerifierPresetId(value: unknown): value is VerifierPresetId;
|
|
17
|
+
export declare function expandPreset(presetId: string, slug: string): PresetExpansion;
|
|
18
|
+
//# sourceMappingURL=verifierPresets.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"verifierPresets.d.ts","sourceRoot":"","sources":["../../src/markers/verifierPresets.ts"],"names":[],"mappings":"AAiBA,eAAO,MAAM,mBAAmB,qGAOtB,CAAC;AAEX,MAAM,MAAM,gBAAgB,GAAG,CAAC,OAAO,mBAAmB,CAAC,CAAC,MAAM,CAAC,CAAC;AAEpE,MAAM,WAAW,cAAc;IAC7B,IAAI,EAAE,QAAQ,CAAC;IACf,OAAO,EAAE,MAAM,EAAE,CAAC;IAClB,MAAM,EAAE,MAAM,EAAE,CAAC;CAClB;AAED,MAAM,MAAM,eAAe,GACvB;IAAE,MAAM,EAAE,UAAU,CAAC;IAAC,MAAM,EAAE,gBAAgB,CAAC;IAAC,SAAS,EAAE,cAAc,CAAA;CAAE,GAC3E;IAAE,MAAM,EAAE,SAAS,CAAC;IAAC,MAAM,EAAE,MAAM,CAAA;CAAE,CAAC;AAwB1C,wBAAgB,kBAAkB,CAAC,KAAK,EAAE,OAAO,GAAG,KAAK,IAAI,gBAAgB,CAE5E;AAID,wBAAgB,YAAY,CAAC,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,GAAG,eAAe,CAiB5E"}
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
// Language-agnostic verifier presets.
|
|
2
|
+
//
|
|
3
|
+
// A preset is a named, reusable expansion of the "what command verifies this
|
|
4
|
+
// row" question. Each preset expands — with `{slug}` substituted everywhere it
|
|
5
|
+
// appears — to a `{ kind:"script", command, inputs }` triple. Presets let a
|
|
6
|
+
// workspace adopt the matrix WITHOUT inheriting the historical pnpm/vitest
|
|
7
|
+
// assumption: that convention now lives here as `js.vitest`, alongside npm,
|
|
8
|
+
// pytest, go, make, and a bring-your-own-argv `command.generic`.
|
|
9
|
+
//
|
|
10
|
+
// Pure + deterministic: `expandPreset` substitutes `{slug}` and returns either a
|
|
11
|
+
// resolved expansion or a BLOCKED result for an unknown preset id (never throws),
|
|
12
|
+
// mirroring the resolver's return-blocked contract so the two compose cleanly.
|
|
13
|
+
const SLUG_TOKEN = "{slug}";
|
|
14
|
+
// The canonical preset id union. Keep in sync with the `verifier_preset_id`
|
|
15
|
+
// enum in schemas/v1/common.schema.json.
|
|
16
|
+
export const VERIFIER_PRESET_IDS = [
|
|
17
|
+
"command.generic",
|
|
18
|
+
"js.vitest",
|
|
19
|
+
"js.npm-test",
|
|
20
|
+
"python.pytest",
|
|
21
|
+
"go.test",
|
|
22
|
+
"make.target"
|
|
23
|
+
];
|
|
24
|
+
// Raw (un-substituted) preset templates. `command.generic` ships an empty
|
|
25
|
+
// command on purpose: the caller supplies the argv, so there is no default.
|
|
26
|
+
const PRESET_TEMPLATES = {
|
|
27
|
+
"command.generic": { command: [], inputs: [] },
|
|
28
|
+
"js.vitest": {
|
|
29
|
+
// Resolve the locally-installed vitest via `npx --no-install` so an
|
|
30
|
+
// npm-only machine with no global pnpm still verifies. pnpm installs
|
|
31
|
+
// vitest into node_modules/.bin, which npx resolves too, so pnpm users
|
|
32
|
+
// are unaffected. `--no-install` forbids any network fetch — if vitest
|
|
33
|
+
// is not installed locally, the command fails fast rather than hanging.
|
|
34
|
+
command: ["npx", "--no-install", "vitest", "run", "tests/use-cases/{slug}.test.ts"],
|
|
35
|
+
inputs: ["tests/use-cases/{slug}.test.ts"]
|
|
36
|
+
},
|
|
37
|
+
"js.npm-test": { command: ["npm", "test"], inputs: [] },
|
|
38
|
+
"python.pytest": {
|
|
39
|
+
command: ["pytest", "tests/use_cases/{slug}_test.py"],
|
|
40
|
+
inputs: ["tests/use_cases/{slug}_test.py"]
|
|
41
|
+
},
|
|
42
|
+
"go.test": { command: ["go", "test", "./..."], inputs: [] },
|
|
43
|
+
"make.target": { command: ["make", "test-use-case", "SLUG={slug}"], inputs: [] }
|
|
44
|
+
};
|
|
45
|
+
export function isVerifierPresetId(value) {
|
|
46
|
+
return typeof value === "string" && VERIFIER_PRESET_IDS.includes(value);
|
|
47
|
+
}
|
|
48
|
+
// Expand a preset id into its concrete `{ kind, command, inputs }`, substituting
|
|
49
|
+
// `{slug}` throughout. Unknown ids return BLOCKED rather than throwing.
|
|
50
|
+
export function expandPreset(presetId, slug) {
|
|
51
|
+
if (!isVerifierPresetId(presetId)) {
|
|
52
|
+
return {
|
|
53
|
+
status: "blocked",
|
|
54
|
+
reason: `unknown verifier preset '${presetId}'; known presets: ${VERIFIER_PRESET_IDS.join(", ")}`
|
|
55
|
+
};
|
|
56
|
+
}
|
|
57
|
+
const template = PRESET_TEMPLATES[presetId];
|
|
58
|
+
return {
|
|
59
|
+
status: "resolved",
|
|
60
|
+
preset: presetId,
|
|
61
|
+
expansion: {
|
|
62
|
+
kind: "script",
|
|
63
|
+
command: template.command.map((part) => substituteSlug(part, slug)),
|
|
64
|
+
inputs: template.inputs.map((part) => substituteSlug(part, slug))
|
|
65
|
+
}
|
|
66
|
+
};
|
|
67
|
+
}
|
|
68
|
+
function substituteSlug(value, slug) {
|
|
69
|
+
return value.split(SLUG_TOKEN).join(slug);
|
|
70
|
+
}
|
|
71
|
+
//# sourceMappingURL=verifierPresets.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"verifierPresets.js","sourceRoot":"","sources":["../../src/markers/verifierPresets.ts"],"names":[],"mappings":"AAAA,sCAAsC;AACtC,EAAE;AACF,6EAA6E;AAC7E,+EAA+E;AAC/E,4EAA4E;AAC5E,2EAA2E;AAC3E,4EAA4E;AAC5E,iEAAiE;AACjE,EAAE;AACF,iFAAiF;AACjF,kFAAkF;AAClF,+EAA+E;AAE/E,MAAM,UAAU,GAAG,QAAQ,CAAC;AAE5B,4EAA4E;AAC5E,yCAAyC;AACzC,MAAM,CAAC,MAAM,mBAAmB,GAAG;IACjC,iBAAiB;IACjB,WAAW;IACX,aAAa;IACb,eAAe;IACf,SAAS;IACT,aAAa;CACL,CAAC;AAcX,0EAA0E;AAC1E,4EAA4E;AAC5E,MAAM,gBAAgB,GAAsE;IAC1F,iBAAiB,EAAE,EAAE,OAAO,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE;IAC9C,WAAW,EAAE;QACX,oEAAoE;QACpE,qEAAqE;QACrE,uEAAuE;QACvE,uEAAuE;QACvE,wEAAwE;QACxE,OAAO,EAAE,CAAC,KAAK,EAAE,cAAc,EAAE,QAAQ,EAAE,KAAK,EAAE,gCAAgC,CAAC;QACnF,MAAM,EAAE,CAAC,gCAAgC,CAAC;KAC3C;IACD,aAAa,EAAE,EAAE,OAAO,EAAE,CAAC,KAAK,EAAE,MAAM,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE;IACvD,eAAe,EAAE;QACf,OAAO,EAAE,CAAC,QAAQ,EAAE,gCAAgC,CAAC;QACrD,MAAM,EAAE,CAAC,gCAAgC,CAAC;KAC3C;IACD,SAAS,EAAE,EAAE,OAAO,EAAE,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE;IAC3D,aAAa,EAAE,EAAE,OAAO,EAAE,CAAC,MAAM,EAAE,eAAe,EAAE,aAAa,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE;CACjF,CAAC;AAEF,MAAM,UAAU,kBAAkB,CAAC,KAAc;IAC/C,OAAO,OAAO,KAAK,KAAK,QAAQ,IAAK,mBAAyC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;AACjG,CAAC;AAED,iFAAiF;AACjF,wEAAwE;AACxE,MAAM,UAAU,YAAY,CAAC,QAAgB,EAAE,IAAY;IACzD,IAAI,CAAC,kBAAkB,CAAC,QAAQ,CAAC,EAAE,CAAC;QAClC,OAAO;YACL,MAAM,EAAE,SAAS;YACjB,MAAM,EAAE,4BAA4B,QAAQ,qBAAqB,mBAAmB,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE;SAClG,CAAC;IACJ,CAAC;IACD,MAAM,QAAQ,GAAG,gBAAgB,CAAC,QAAQ,CAAC,CAAC;IAC5C,OAAO;QACL,MAAM,EAAE,UAAU;QAClB,MAAM,EAAE,QAAQ;QAChB,SAAS,EAAE;YACT,IAAI,EAAE,QAAQ;YACd,OAAO,EAAE,QAAQ,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,cAAc,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;YACnE,MAAM,EAAE,QAAQ,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,cAAc,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;SAClE;KACF,CAAC;AACJ,CAAC;AAED,SAAS,cAAc,CAAC,KAAa,EAAE,IAAY;IACjD,OAAO,KAAK,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;AAC5C,CAAC"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
export declare const DEFAULT_CONVENTION_VERIFIER_ID = "acceptance";
|
|
2
|
+
export interface VerifierResolverRow {
|
|
3
|
+
slug: string;
|
|
4
|
+
verification_policy: unknown;
|
|
5
|
+
}
|
|
6
|
+
export interface WorkspaceVerifierContext {
|
|
7
|
+
default?: string;
|
|
8
|
+
verifiers?: Record<string, unknown>;
|
|
9
|
+
}
|
|
10
|
+
export interface ResolvedVerifier {
|
|
11
|
+
verifier_id: string;
|
|
12
|
+
status: "resolved";
|
|
13
|
+
source: "policy" | "workspace_config" | "workspace_default";
|
|
14
|
+
kind: "script";
|
|
15
|
+
evidence_kind: string;
|
|
16
|
+
command: string[];
|
|
17
|
+
inputs: string[];
|
|
18
|
+
timeout_seconds?: number;
|
|
19
|
+
}
|
|
20
|
+
export interface BlockedVerifier {
|
|
21
|
+
verifier_id: string;
|
|
22
|
+
status: "blocked";
|
|
23
|
+
reason: string;
|
|
24
|
+
}
|
|
25
|
+
export type VerifierResolution = ResolvedVerifier | BlockedVerifier;
|
|
26
|
+
export declare function resolveRowVerifiers(row: VerifierResolverRow, workspace?: WorkspaceVerifierContext): VerifierResolution[];
|
|
27
|
+
//# sourceMappingURL=verifierResolver.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"verifierResolver.d.ts","sourceRoot":"","sources":["../../src/markers/verifierResolver.ts"],"names":[],"mappings":"AAyBA,eAAO,MAAM,8BAA8B,eAAe,CAAC;AAU3D,MAAM,WAAW,mBAAmB;IAClC,IAAI,EAAE,MAAM,CAAC;IACb,mBAAmB,EAAE,OAAO,CAAC;CAC9B;AAMD,MAAM,WAAW,wBAAwB;IACvC,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,SAAS,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CACrC;AAED,MAAM,WAAW,gBAAgB;IAC/B,WAAW,EAAE,MAAM,CAAC;IACpB,MAAM,EAAE,UAAU,CAAC;IACnB,MAAM,EAAE,QAAQ,GAAG,kBAAkB,GAAG,mBAAmB,CAAC;IAC5D,IAAI,EAAE,QAAQ,CAAC;IACf,aAAa,EAAE,MAAM,CAAC;IACtB,OAAO,EAAE,MAAM,EAAE,CAAC;IAClB,MAAM,EAAE,MAAM,EAAE,CAAC;IACjB,eAAe,CAAC,EAAE,MAAM,CAAC;CAC1B;AAED,MAAM,WAAW,eAAe;IAC9B,WAAW,EAAE,MAAM,CAAC;IACpB,MAAM,EAAE,SAAS,CAAC;IAClB,MAAM,EAAE,MAAM,CAAC;CAChB;AAED,MAAM,MAAM,kBAAkB,GAAG,gBAAgB,GAAG,eAAe,CAAC;AAIpE,wBAAgB,mBAAmB,CACjC,GAAG,EAAE,mBAAmB,EACxB,SAAS,GAAE,wBAA6B,GACvC,kBAAkB,EAAE,CAStB"}
|
|
@@ -0,0 +1,151 @@
|
|
|
1
|
+
// Resolve the concrete verifier(s) a marker row's verification_policy demands.
|
|
2
|
+
//
|
|
3
|
+
// A verification_policy in "requirements" mode lists `required_verifiers` ids per
|
|
4
|
+
// requirement. Each id resolves CONFIG-DRIVEN, in this order:
|
|
5
|
+
// 1. the row's own `verification_policy.verifiers[id]`;
|
|
6
|
+
// 2. the WORKSPACE CONFIG's `verifiers[id]`;
|
|
7
|
+
// 3. if `id` is the default-convention id ("acceptance") and the workspace
|
|
8
|
+
// config declares `verifiers.default`, the entry that default names;
|
|
9
|
+
// 4. otherwise BLOCKED — returned (never thrown) so callers can surface an
|
|
10
|
+
// actionable diagnostic instead of crashing.
|
|
11
|
+
//
|
|
12
|
+
// A verifier ENTRY (in either map) is either an explicit `{ kind:"script",
|
|
13
|
+
// command, ... }` or a preset reference `{ preset, ... }` that resolves via
|
|
14
|
+
// `expandPreset` (PIECE 1). There is NO hardcoded pnpm/vitest default any more —
|
|
15
|
+
// that convention now lives ONLY in the `js.vitest` preset.
|
|
16
|
+
//
|
|
17
|
+
// Pure + deterministic: given a row + workspace verifiers the result is sorted by
|
|
18
|
+
// verifier_id and deduped, and `{slug}` is substituted everywhere it appears in
|
|
19
|
+
// command/inputs.
|
|
20
|
+
import { expandPreset } from "./verifierPresets.js";
|
|
21
|
+
// The convention id rows reference when they want "the workspace default verifier".
|
|
22
|
+
// It carries no built-in command — it resolves ONLY via the workspace config's
|
|
23
|
+
// `verifiers.default`. Absent that, it is BLOCKED.
|
|
24
|
+
export const DEFAULT_CONVENTION_VERIFIER_ID = "acceptance";
|
|
25
|
+
const SLUG_TOKEN = "{slug}";
|
|
26
|
+
// The default evidence_kind for an entry that does not declare one (preset refs
|
|
27
|
+
// may omit it). Matches the historical default-convention evidence kind.
|
|
28
|
+
const DEFAULT_EVIDENCE_KIND = "test_result";
|
|
29
|
+
// Resolve every required_verifier id referenced by the row's verification_policy.
|
|
30
|
+
// The returned array is deduped by verifier_id and sorted ascending for stability.
|
|
31
|
+
export function resolveRowVerifiers(row, workspace = {}) {
|
|
32
|
+
const ids = collectRequiredVerifierIds(row.verification_policy);
|
|
33
|
+
const rowVerifiers = extractVerifiers(row.verification_policy);
|
|
34
|
+
const workspaceVerifiers = isRecord(workspace.verifiers) ? workspace.verifiers : {};
|
|
35
|
+
return ids
|
|
36
|
+
.map((id) => resolveOne(id, row.slug, rowVerifiers, workspaceVerifiers, workspace.default))
|
|
37
|
+
.sort((left, right) => left.verifier_id < right.verifier_id ? -1 : left.verifier_id > right.verifier_id ? 1 : 0);
|
|
38
|
+
}
|
|
39
|
+
function resolveOne(id, slug, rowVerifiers, workspaceVerifiers, workspaceDefault) {
|
|
40
|
+
// 1. The row's own declared verifier.
|
|
41
|
+
if (isRecord(rowVerifiers[id])) {
|
|
42
|
+
return resolveEntry(id, slug, rowVerifiers[id], "policy");
|
|
43
|
+
}
|
|
44
|
+
// 2. The workspace config's verifier of the same id.
|
|
45
|
+
if (isRecord(workspaceVerifiers[id])) {
|
|
46
|
+
return resolveEntry(id, slug, workspaceVerifiers[id], "workspace_config");
|
|
47
|
+
}
|
|
48
|
+
// 3. The default-convention id, backed by the workspace's `verifiers.default`.
|
|
49
|
+
if (id === DEFAULT_CONVENTION_VERIFIER_ID && typeof workspaceDefault === "string") {
|
|
50
|
+
const target = workspaceVerifiers[workspaceDefault];
|
|
51
|
+
if (isRecord(target)) {
|
|
52
|
+
return resolveEntry(id, slug, target, "workspace_default");
|
|
53
|
+
}
|
|
54
|
+
return {
|
|
55
|
+
verifier_id: id,
|
|
56
|
+
status: "blocked",
|
|
57
|
+
reason: `workspace verifiers.default '${workspaceDefault}' does not name a declared verifier`
|
|
58
|
+
};
|
|
59
|
+
}
|
|
60
|
+
// 4. Unresolvable: actionable, never thrown.
|
|
61
|
+
return {
|
|
62
|
+
verifier_id: id,
|
|
63
|
+
status: "blocked",
|
|
64
|
+
reason: `no verifier '${id}' configured; declare it in the row's verification_policy.verifiers ` +
|
|
65
|
+
`or the workspace verifiers map, or set verifiers.default`
|
|
66
|
+
};
|
|
67
|
+
}
|
|
68
|
+
// Resolve one verifier ENTRY (explicit script or preset reference) to a concrete
|
|
69
|
+
// ResolvedVerifier, substituting {slug}. A preset reference expands via PIECE 1's
|
|
70
|
+
// expandPreset; an unknown preset id surfaces as BLOCKED.
|
|
71
|
+
function resolveEntry(id, slug, entry, source) {
|
|
72
|
+
if (typeof entry.preset === "string") {
|
|
73
|
+
return resolvePresetEntry(id, slug, entry, source);
|
|
74
|
+
}
|
|
75
|
+
return resolveScriptEntry(id, slug, entry, source);
|
|
76
|
+
}
|
|
77
|
+
function resolvePresetEntry(id, slug, entry, source) {
|
|
78
|
+
const expansion = expandPreset(entry.preset, slug);
|
|
79
|
+
if (expansion.status === "blocked") {
|
|
80
|
+
return { verifier_id: id, status: "blocked", reason: expansion.reason };
|
|
81
|
+
}
|
|
82
|
+
// The entry may override inputs and supply evidence_kind / timeout_seconds.
|
|
83
|
+
const inputs = Array.isArray(entry.inputs)
|
|
84
|
+
? toStringArray(entry.inputs).map((part) => substituteSlug(part, slug))
|
|
85
|
+
: expansion.expansion.inputs;
|
|
86
|
+
const resolved = {
|
|
87
|
+
verifier_id: id,
|
|
88
|
+
status: "resolved",
|
|
89
|
+
source,
|
|
90
|
+
kind: "script",
|
|
91
|
+
evidence_kind: typeof entry.evidence_kind === "string" ? entry.evidence_kind : DEFAULT_EVIDENCE_KIND,
|
|
92
|
+
command: expansion.expansion.command,
|
|
93
|
+
inputs
|
|
94
|
+
};
|
|
95
|
+
if (typeof entry.timeout_seconds === "number") {
|
|
96
|
+
resolved.timeout_seconds = entry.timeout_seconds;
|
|
97
|
+
}
|
|
98
|
+
return resolved;
|
|
99
|
+
}
|
|
100
|
+
function resolveScriptEntry(id, slug, entry, source) {
|
|
101
|
+
const resolved = {
|
|
102
|
+
verifier_id: id,
|
|
103
|
+
status: "resolved",
|
|
104
|
+
source,
|
|
105
|
+
kind: "script",
|
|
106
|
+
evidence_kind: typeof entry.evidence_kind === "string" ? entry.evidence_kind : DEFAULT_EVIDENCE_KIND,
|
|
107
|
+
command: toStringArray(entry.command).map((part) => substituteSlug(part, slug)),
|
|
108
|
+
inputs: toStringArray(entry.inputs).map((part) => substituteSlug(part, slug))
|
|
109
|
+
};
|
|
110
|
+
if (typeof entry.timeout_seconds === "number") {
|
|
111
|
+
resolved.timeout_seconds = entry.timeout_seconds;
|
|
112
|
+
}
|
|
113
|
+
return resolved;
|
|
114
|
+
}
|
|
115
|
+
function collectRequiredVerifierIds(policy) {
|
|
116
|
+
if (!isRecord(policy) || policy.mode !== "requirements" || !Array.isArray(policy.requirements)) {
|
|
117
|
+
return [];
|
|
118
|
+
}
|
|
119
|
+
const seen = new Set();
|
|
120
|
+
const ids = [];
|
|
121
|
+
for (const requirement of policy.requirements) {
|
|
122
|
+
if (!isRecord(requirement) || !Array.isArray(requirement.required_verifiers)) {
|
|
123
|
+
continue;
|
|
124
|
+
}
|
|
125
|
+
for (const id of requirement.required_verifiers) {
|
|
126
|
+
if (typeof id === "string" && !seen.has(id)) {
|
|
127
|
+
seen.add(id);
|
|
128
|
+
ids.push(id);
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
return ids;
|
|
133
|
+
}
|
|
134
|
+
function extractVerifiers(policy) {
|
|
135
|
+
if (isRecord(policy) && isRecord(policy.verifiers)) {
|
|
136
|
+
return policy.verifiers;
|
|
137
|
+
}
|
|
138
|
+
return {};
|
|
139
|
+
}
|
|
140
|
+
function substituteSlug(value, slug) {
|
|
141
|
+
return value.split(SLUG_TOKEN).join(slug);
|
|
142
|
+
}
|
|
143
|
+
function toStringArray(value) {
|
|
144
|
+
return Array.isArray(value)
|
|
145
|
+
? value.filter((item) => typeof item === "string")
|
|
146
|
+
: [];
|
|
147
|
+
}
|
|
148
|
+
function isRecord(value) {
|
|
149
|
+
return typeof value === "object" && value !== null && !Array.isArray(value);
|
|
150
|
+
}
|
|
151
|
+
//# sourceMappingURL=verifierResolver.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"verifierResolver.js","sourceRoot":"","sources":["../../src/markers/verifierResolver.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/migration/index.ts"],"names":[],"mappings":"AAAA,cAAc,iBAAiB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/migration/index.ts"],"names":[],"mappings":"AAAA,cAAc,iBAAiB,CAAC"}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import type { ResolvedWorkspaceContext } from "../roots.js";
|
|
2
|
+
export type TestMatrixMigrationMode = "dry_run" | "write";
|
|
3
|
+
export type TestMatrixMigrationWarning = {
|
|
4
|
+
code: string;
|
|
5
|
+
row_ref: string | null;
|
|
6
|
+
message: string;
|
|
7
|
+
};
|
|
8
|
+
export type TestMatrixMigrationResult = {
|
|
9
|
+
schema_version: 1;
|
|
10
|
+
source: {
|
|
11
|
+
path: string;
|
|
12
|
+
digest: string;
|
|
13
|
+
parser: string;
|
|
14
|
+
};
|
|
15
|
+
mode: TestMatrixMigrationMode;
|
|
16
|
+
summary: {
|
|
17
|
+
tables_found: number;
|
|
18
|
+
rows_seen: number;
|
|
19
|
+
rows_importable: number;
|
|
20
|
+
rows_needing_review: number;
|
|
21
|
+
files_planned: number;
|
|
22
|
+
files_written: number;
|
|
23
|
+
};
|
|
24
|
+
drafts: Array<{
|
|
25
|
+
output_path: string;
|
|
26
|
+
feature_id: string;
|
|
27
|
+
use_case_ids: string[];
|
|
28
|
+
content: string;
|
|
29
|
+
}>;
|
|
30
|
+
warnings: TestMatrixMigrationWarning[];
|
|
31
|
+
would_write: Array<{
|
|
32
|
+
path: string;
|
|
33
|
+
action: "create" | "update_generated" | "skip_unchanged" | "conflict";
|
|
34
|
+
}>;
|
|
35
|
+
};
|
|
36
|
+
export declare function migrateTestMatrix(options: {
|
|
37
|
+
context: ResolvedWorkspaceContext;
|
|
38
|
+
sourcePath: string;
|
|
39
|
+
outDir?: string;
|
|
40
|
+
mode: TestMatrixMigrationMode;
|
|
41
|
+
}): TestMatrixMigrationResult;
|
|
42
|
+
//# sourceMappingURL=testMatrix.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"testMatrix.d.ts","sourceRoot":"","sources":["../../src/migration/testMatrix.ts"],"names":[],"mappings":"AAQA,OAAO,KAAK,EAAE,wBAAwB,EAAE,MAAM,aAAa,CAAC;AA4B5D,MAAM,MAAM,uBAAuB,GAAG,SAAS,GAAG,OAAO,CAAC;AAE1D,MAAM,MAAM,0BAA0B,GAAG;IACvC,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,MAAM,GAAG,IAAI,CAAC;IACvB,OAAO,EAAE,MAAM,CAAC;CACjB,CAAC;AAEF,MAAM,MAAM,yBAAyB,GAAG;IACtC,cAAc,EAAE,CAAC,CAAC;IAClB,MAAM,EAAE;QACN,IAAI,EAAE,MAAM,CAAC;QACb,MAAM,EAAE,MAAM,CAAC;QACf,MAAM,EAAE,MAAM,CAAC;KAChB,CAAC;IACF,IAAI,EAAE,uBAAuB,CAAC;IAC9B,OAAO,EAAE;QACP,YAAY,EAAE,MAAM,CAAC;QACrB,SAAS,EAAE,MAAM,CAAC;QAClB,eAAe,EAAE,MAAM,CAAC;QACxB,mBAAmB,EAAE,MAAM,CAAC;QAC5B,aAAa,EAAE,MAAM,CAAC;QACtB,aAAa,EAAE,MAAM,CAAC;KACvB,CAAC;IACF,MAAM,EAAE,KAAK,CAAC;QACZ,WAAW,EAAE,MAAM,CAAC;QACpB,UAAU,EAAE,MAAM,CAAC;QACnB,YAAY,EAAE,MAAM,EAAE,CAAC;QACvB,OAAO,EAAE,MAAM,CAAC;KACjB,CAAC,CAAC;IACH,QAAQ,EAAE,0BAA0B,EAAE,CAAC;IACvC,WAAW,EAAE,KAAK,CAAC;QACjB,IAAI,EAAE,MAAM,CAAC;QACb,MAAM,EAAE,QAAQ,GAAG,kBAAkB,GAAG,gBAAgB,GAAG,UAAU,CAAC;KACvE,CAAC,CAAC;CACJ,CAAC;AAEF,wBAAgB,iBAAiB,CAAC,OAAO,EAAE;IACzC,OAAO,EAAE,wBAAwB,CAAC;IAClC,UAAU,EAAE,MAAM,CAAC;IACnB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,IAAI,EAAE,uBAAuB,CAAC;CAC/B,GAAG,yBAAyB,CA2E5B"}
|