@oscharko-dev/keiko 0.2.0-beta.4 → 0.2.0-beta.6
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/README.md +39 -14
- package/dist/ui/csp-hashes.json +16 -21
- package/dist/ui/static/404.html +1 -1
- package/dist/ui/static/__next.__PAGE__.txt +2 -2
- package/dist/ui/static/__next._full.txt +3 -3
- package/dist/ui/static/__next._head.txt +1 -1
- package/dist/ui/static/__next._index.txt +2 -2
- package/dist/ui/static/__next._tree.txt +2 -2
- package/dist/ui/static/_next/static/chunks/0-qhhdvxg2j_y.js +1 -0
- package/dist/ui/static/_next/static/chunks/0ke4ratkgvcxo.css +1 -0
- package/dist/ui/static/_next/static/chunks/0xhu-pfsyvbmx.js +5 -0
- package/dist/ui/static/_next/static/chunks/3vf3oh2-sl2nc.js +1 -0
- package/dist/ui/static/_next/static/chunks/3wmd4-2vznp2g.js +106 -0
- package/dist/ui/static/_next/static/chunks/turbopack-18q50fp2-1qbt.js +1 -0
- package/dist/ui/static/_not-found/__next._full.txt +2 -2
- package/dist/ui/static/_not-found/__next._head.txt +1 -1
- package/dist/ui/static/_not-found/__next._index.txt +2 -2
- package/dist/ui/static/_not-found/__next._not-found.__PAGE__.txt +1 -1
- package/dist/ui/static/_not-found/__next._not-found.txt +1 -1
- package/dist/ui/static/_not-found/__next._tree.txt +2 -2
- package/dist/ui/static/_not-found.html +1 -1
- package/dist/ui/static/_not-found.txt +2 -2
- package/dist/ui/static/index.html +1 -1
- package/dist/ui/static/index.txt +3 -3
- package/dist/ui/static/launch/__next._full.txt +3 -3
- package/dist/ui/static/launch/__next._head.txt +1 -1
- package/dist/ui/static/launch/__next._index.txt +2 -2
- package/dist/ui/static/launch/__next._tree.txt +2 -2
- package/dist/ui/static/launch/__next.launch.__PAGE__.txt +2 -2
- package/dist/ui/static/launch/__next.launch.txt +1 -1
- package/dist/ui/static/launch.html +1 -1
- package/dist/ui/static/launch.txt +3 -3
- package/dist/ui/static/local-knowledge/__next._full.txt +3 -3
- package/dist/ui/static/local-knowledge/__next._head.txt +1 -1
- package/dist/ui/static/local-knowledge/__next._index.txt +2 -2
- package/dist/ui/static/local-knowledge/__next._tree.txt +2 -2
- package/dist/ui/static/local-knowledge/__next.local-knowledge.__PAGE__.txt +2 -2
- package/dist/ui/static/local-knowledge/__next.local-knowledge.txt +1 -1
- package/dist/ui/static/local-knowledge/capsule/__next._full.txt +3 -3
- package/dist/ui/static/local-knowledge/capsule/__next._head.txt +1 -1
- package/dist/ui/static/local-knowledge/capsule/__next._index.txt +2 -2
- package/dist/ui/static/local-knowledge/capsule/__next._tree.txt +2 -2
- package/dist/ui/static/local-knowledge/capsule/__next.local-knowledge.capsule.__PAGE__.txt +2 -2
- package/dist/ui/static/local-knowledge/capsule/__next.local-knowledge.capsule.txt +1 -1
- package/dist/ui/static/local-knowledge/capsule/__next.local-knowledge.txt +1 -1
- package/dist/ui/static/local-knowledge/capsule.html +1 -1
- package/dist/ui/static/local-knowledge/capsule.txt +3 -3
- package/dist/ui/static/local-knowledge.html +1 -1
- package/dist/ui/static/local-knowledge.txt +3 -3
- package/dist/ui/static/memoriaviva/__next._full.txt +6 -6
- package/dist/ui/static/memoriaviva/__next._head.txt +1 -1
- package/dist/ui/static/memoriaviva/__next._index.txt +2 -2
- package/dist/ui/static/memoriaviva/__next._tree.txt +2 -2
- package/dist/ui/static/memoriaviva/__next.memoriaviva.__PAGE__.txt +4 -4
- package/dist/ui/static/memoriaviva/__next.memoriaviva.txt +1 -1
- package/dist/ui/static/memoriaviva/consolidation/__next._full.txt +4 -4
- package/dist/ui/static/memoriaviva/consolidation/__next._head.txt +1 -1
- package/dist/ui/static/memoriaviva/consolidation/__next._index.txt +2 -2
- package/dist/ui/static/memoriaviva/consolidation/__next._tree.txt +2 -2
- package/dist/ui/static/memoriaviva/consolidation/__next.memoriaviva.consolidation.__PAGE__.txt +2 -2
- package/dist/ui/static/memoriaviva/consolidation/__next.memoriaviva.consolidation.txt +1 -1
- package/dist/ui/static/memoriaviva/consolidation/__next.memoriaviva.txt +1 -1
- package/dist/ui/static/memoriaviva/consolidation.html +1 -1
- package/dist/ui/static/memoriaviva/consolidation.txt +4 -4
- package/dist/ui/static/memoriaviva/detail/__next._full.txt +6 -6
- package/dist/ui/static/memoriaviva/detail/__next._head.txt +1 -1
- package/dist/ui/static/memoriaviva/detail/__next._index.txt +2 -2
- package/dist/ui/static/memoriaviva/detail/__next._tree.txt +2 -2
- package/dist/ui/static/memoriaviva/detail/__next.memoriaviva.detail.__PAGE__.txt +4 -4
- package/dist/ui/static/memoriaviva/detail/__next.memoriaviva.detail.txt +1 -1
- package/dist/ui/static/memoriaviva/detail/__next.memoriaviva.txt +1 -1
- package/dist/ui/static/memoriaviva/detail.html +1 -1
- package/dist/ui/static/memoriaviva/detail.txt +6 -6
- package/dist/ui/static/memoriaviva/review-queue/__next._full.txt +4 -4
- package/dist/ui/static/memoriaviva/review-queue/__next._head.txt +1 -1
- package/dist/ui/static/memoriaviva/review-queue/__next._index.txt +2 -2
- package/dist/ui/static/memoriaviva/review-queue/__next._tree.txt +2 -2
- package/dist/ui/static/memoriaviva/review-queue/__next.memoriaviva.review-queue.__PAGE__.txt +2 -2
- package/dist/ui/static/memoriaviva/review-queue/__next.memoriaviva.review-queue.txt +1 -1
- package/dist/ui/static/memoriaviva/review-queue/__next.memoriaviva.txt +1 -1
- package/dist/ui/static/memoriaviva/review-queue.html +1 -1
- package/dist/ui/static/memoriaviva/review-queue.txt +4 -4
- package/dist/ui/static/memoriaviva.html +1 -1
- package/dist/ui/static/memoriaviva.txt +6 -6
- package/node_modules/@oscharko-dev/keiko-cli/dist/.tsbuildinfo +1 -1
- package/node_modules/@oscharko-dev/keiko-cli/dist/doctor.d.ts +24 -0
- package/node_modules/@oscharko-dev/keiko-cli/dist/doctor.d.ts.map +1 -0
- package/node_modules/@oscharko-dev/keiko-cli/dist/doctor.js +108 -0
- package/node_modules/@oscharko-dev/keiko-cli/dist/evaluate.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-cli/dist/evaluate.js +7 -4
- package/node_modules/@oscharko-dev/keiko-cli/dist/index.d.ts +1 -0
- package/node_modules/@oscharko-dev/keiko-cli/dist/index.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-cli/dist/index.js +1 -0
- package/node_modules/@oscharko-dev/keiko-cli/dist/init.d.ts +2 -2
- package/node_modules/@oscharko-dev/keiko-cli/dist/init.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-cli/dist/init.js +4 -4
- package/node_modules/@oscharko-dev/keiko-cli/dist/install-layout.d.ts +6 -0
- package/node_modules/@oscharko-dev/keiko-cli/dist/install-layout.d.ts.map +1 -0
- package/node_modules/@oscharko-dev/keiko-cli/dist/install-layout.js +24 -0
- package/node_modules/@oscharko-dev/keiko-cli/dist/launcher.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-cli/dist/launcher.js +5 -7
- package/node_modules/@oscharko-dev/keiko-cli/dist/lifecycle.d.ts +1 -0
- package/node_modules/@oscharko-dev/keiko-cli/dist/lifecycle.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-cli/dist/lifecycle.js +75 -30
- package/node_modules/@oscharko-dev/keiko-cli/dist/memory.d.ts +3 -0
- package/node_modules/@oscharko-dev/keiko-cli/dist/memory.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-cli/dist/memory.js +76 -7
- package/node_modules/@oscharko-dev/keiko-cli/dist/run.d.ts +3 -1
- package/node_modules/@oscharko-dev/keiko-cli/dist/run.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-cli/dist/run.js +123 -43
- package/node_modules/@oscharko-dev/keiko-cli/dist/runner.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-cli/dist/runner.js +20 -4
- package/node_modules/@oscharko-dev/keiko-cli/dist/ui.d.ts +1 -1
- package/node_modules/@oscharko-dev/keiko-cli/dist/ui.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-cli/dist/ui.js +17 -14
- package/node_modules/@oscharko-dev/keiko-cli/package.json +1 -1
- package/node_modules/@oscharko-dev/keiko-contracts/dist/.tsbuildinfo +1 -1
- package/node_modules/@oscharko-dev/keiko-contracts/dist/bff-wire.d.ts +7 -0
- package/node_modules/@oscharko-dev/keiko-contracts/dist/bff-wire.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-contracts/dist/connected-context.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-contracts/dist/connected-context.js +1 -2
- package/node_modules/@oscharko-dev/keiko-contracts/dist/evidence.d.ts +1 -0
- package/node_modules/@oscharko-dev/keiko-contracts/dist/evidence.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-contracts/dist/gateway.d.ts +12 -0
- package/node_modules/@oscharko-dev/keiko-contracts/dist/gateway.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-contracts/dist/index.d.ts +4 -2
- package/node_modules/@oscharko-dev/keiko-contracts/dist/index.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-contracts/dist/index.js +4 -1
- package/node_modules/@oscharko-dev/keiko-contracts/dist/local-knowledge-validation.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-contracts/dist/memory-audit-events.d.ts +13 -1
- package/node_modules/@oscharko-dev/keiko-contracts/dist/memory-audit-events.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-contracts/dist/memory-audit-events.js +7 -6
- package/node_modules/@oscharko-dev/keiko-contracts/dist/memory-internal.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-contracts/dist/memory-internal.js +1 -1
- package/node_modules/@oscharko-dev/keiko-contracts/dist/memory-operations.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-contracts/dist/memory-workflow-port.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-contracts/dist/memory-workflow-port.js +1 -1
- package/node_modules/@oscharko-dev/keiko-contracts/dist/qualityIntelligence/bffWire.d.ts +23 -4
- package/node_modules/@oscharko-dev/keiko-contracts/dist/qualityIntelligence/bffWire.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-contracts/dist/qualityIntelligence/index.d.ts +1 -0
- package/node_modules/@oscharko-dev/keiko-contracts/dist/qualityIntelligence/index.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-contracts/dist/qualityIntelligence/index.js +1 -0
- package/node_modules/@oscharko-dev/keiko-contracts/dist/qualityIntelligence/sourceEnvelope.d.ts +1 -0
- package/node_modules/@oscharko-dev/keiko-contracts/dist/qualityIntelligence/sourceEnvelope.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-contracts/dist/qualityIntelligence/sourceEnvelope.js +26 -0
- package/node_modules/@oscharko-dev/keiko-contracts/dist/qualityIntelligence/testQualityRubric.d.ts +5 -3
- package/node_modules/@oscharko-dev/keiko-contracts/dist/qualityIntelligence/testQualityRubric.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-contracts/dist/qualityIntelligence/testQualityRubric.js +29 -3
- package/node_modules/@oscharko-dev/keiko-contracts/dist/text-safety.d.ts +7 -0
- package/node_modules/@oscharko-dev/keiko-contracts/dist/text-safety.d.ts.map +1 -0
- package/node_modules/@oscharko-dev/keiko-contracts/dist/text-safety.js +58 -0
- package/node_modules/@oscharko-dev/keiko-contracts/package.json +5 -1
- package/node_modules/@oscharko-dev/keiko-evaluations/dist/.tsbuildinfo +1 -1
- package/node_modules/@oscharko-dev/keiko-evaluations/dist/surface-parity.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-evaluations/package.json +1 -1
- package/node_modules/@oscharko-dev/keiko-evidence/dist/.tsbuildinfo +1 -1
- package/node_modules/@oscharko-dev/keiko-evidence/dist/index.d.ts +1 -1
- package/node_modules/@oscharko-dev/keiko-evidence/dist/index.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-evidence/dist/index.js +1 -1
- package/node_modules/@oscharko-dev/keiko-evidence/dist/qualityIntelligence/candidatesArtifact.d.ts +7 -0
- package/node_modules/@oscharko-dev/keiko-evidence/dist/qualityIntelligence/candidatesArtifact.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-evidence/dist/qualityIntelligence/candidatesArtifact.js +62 -13
- package/node_modules/@oscharko-dev/keiko-evidence/dist/qualityIntelligence/companionStore.d.ts +3 -3
- package/node_modules/@oscharko-dev/keiko-evidence/dist/qualityIntelligence/companionStore.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-evidence/dist/qualityIntelligence/companionStore.js +31 -11
- package/node_modules/@oscharko-dev/keiko-evidence/dist/qualityIntelligence/figmaSnapshot/schema.d.ts +35 -3
- package/node_modules/@oscharko-dev/keiko-evidence/dist/qualityIntelligence/figmaSnapshot/schema.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-evidence/dist/qualityIntelligence/figmaSnapshot/schema.js +107 -3
- package/node_modules/@oscharko-dev/keiko-evidence/dist/qualityIntelligence/figmaSnapshot/store.d.ts +15 -1
- package/node_modules/@oscharko-dev/keiko-evidence/dist/qualityIntelligence/figmaSnapshot/store.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-evidence/dist/qualityIntelligence/figmaSnapshot/store.js +248 -36
- package/node_modules/@oscharko-dev/keiko-evidence/dist/qualityIntelligence/index.d.ts +4 -4
- package/node_modules/@oscharko-dev/keiko-evidence/dist/qualityIntelligence/index.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-evidence/dist/qualityIntelligence/index.js +1 -1
- package/node_modules/@oscharko-dev/keiko-evidence/dist/qualityIntelligence/manifestSchema.d.ts +33 -2
- package/node_modules/@oscharko-dev/keiko-evidence/dist/qualityIntelligence/manifestSchema.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-evidence/dist/qualityIntelligence/store.d.ts +34 -1
- package/node_modules/@oscharko-dev/keiko-evidence/dist/qualityIntelligence/store.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-evidence/dist/qualityIntelligence/store.js +95 -22
- package/node_modules/@oscharko-dev/keiko-evidence/dist/side-file.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-evidence/dist/side-file.js +17 -5
- package/node_modules/@oscharko-dev/keiko-evidence/dist/store.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-evidence/dist/store.js +128 -12
- package/node_modules/@oscharko-dev/keiko-evidence/dist/workflow-evidence.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-evidence/dist/workflow-evidence.js +1 -3
- package/node_modules/@oscharko-dev/keiko-evidence/package.json +1 -1
- package/node_modules/@oscharko-dev/keiko-harness/dist/.tsbuildinfo +1 -1
- package/node_modules/@oscharko-dev/keiko-harness/package.json +1 -1
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/.tsbuildinfo +1 -1
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/capsule-set-lifecycle.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/capsule-set-lifecycle.js +1 -2
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/composition.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/composition.js +1 -1
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/conversation/index.d.ts +0 -1
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/conversation/index.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/conversation/index.js +0 -1
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/conversation/model-gateway-answer-generator.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/conversation/model-gateway-answer-generator.js +7 -1
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/conversation/types.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/conversation/types.js +2 -3
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/discovery/extract.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/discovery/extract.js +45 -21
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/discovery/media-type.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/discovery/media-type.js +1 -0
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/discovery/walk.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/discovery/walk.js +11 -3
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/evaluations/dimensions.d.ts +2 -0
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/evaluations/dimensions.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/evaluations/dimensions.js +42 -0
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/evaluations/fixtures.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/evaluations/fixtures.js +34 -0
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/evaluations/index.d.ts +1 -1
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/evaluations/index.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/evaluations/index.js +1 -1
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/evaluations/report.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/evaluations/report.js +7 -6
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/evaluations/runner.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/evaluations/runner.js +7 -1
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/evaluations/types.d.ts +4 -0
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/evaluations/types.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/evaluations/types.js +2 -0
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/index.d.ts +1 -1
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/index.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/index.js +1 -1
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/indexing/embedding-batcher.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/indexing/embedding-batcher.js +121 -3
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/indexing/orchestrator.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/indexing/orchestrator.js +34 -4
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/parsers/_internal.d.ts +1 -0
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/parsers/_internal.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/parsers/_internal.js +63 -0
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/parsers/docx-parser.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/parsers/docx-parser.js +4 -7
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/parsers/html-parser.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/parsers/html-parser.js +67 -11
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/parsers/index.d.ts +1 -0
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/parsers/index.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/parsers/index.js +3 -0
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/parsers/json-parser.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/parsers/json-parser.js +39 -3
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/parsers/ocr/null-ocr-adapter.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/parsers/ocr/ocr-pipeline-parser.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/parsers/ocr/ocr-pipeline-parser.js +46 -11
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/parsers/parser-test-fixtures.d.ts +2 -0
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/parsers/parser-test-fixtures.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/parsers/parser-test-fixtures.js +2 -0
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/parsers/pdf-parser.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/parsers/pdf-parser.js +114 -0
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/parsers/xlsx-parser.d.ts +3 -0
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/parsers/xlsx-parser.d.ts.map +1 -0
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/parsers/xlsx-parser.js +425 -0
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/privacy/retention-applier.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/qualityIntelligence/capsuleCorpus.d.ts +9 -4
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/qualityIntelligence/capsuleCorpus.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/qualityIntelligence/capsuleCorpus.js +11 -6
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/retrieval/retrieval-runner.js +15 -2
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/retrieval/scoped-vector-search.d.ts +1 -0
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/retrieval/scoped-vector-search.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/retrieval/scoped-vector-search.js +220 -7
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/retrieval/types.d.ts +2 -1
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/retrieval/types.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/source-lifecycle.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/source-lifecycle.js +3 -1
- package/node_modules/@oscharko-dev/keiko-local-knowledge/package.json +4 -2
- package/node_modules/@oscharko-dev/keiko-memory-capture/dist/.tsbuildinfo +1 -1
- package/node_modules/@oscharko-dev/keiko-memory-capture/dist/capture-safety.d.ts +4 -0
- package/node_modules/@oscharko-dev/keiko-memory-capture/dist/capture-safety.d.ts.map +1 -0
- package/node_modules/@oscharko-dev/keiko-memory-capture/dist/capture-safety.js +17 -0
- package/node_modules/@oscharko-dev/keiko-memory-capture/dist/errors.d.ts +1 -1
- package/node_modules/@oscharko-dev/keiko-memory-capture/dist/errors.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-memory-capture/dist/index.d.ts +1 -0
- package/node_modules/@oscharko-dev/keiko-memory-capture/dist/index.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-memory-capture/dist/index.js +1 -0
- package/node_modules/@oscharko-dev/keiko-memory-capture/dist/salience.js +1 -1
- package/node_modules/@oscharko-dev/keiko-memory-capture/package.json +1 -1
- package/node_modules/@oscharko-dev/keiko-memory-consolidation/dist/.tsbuildinfo +1 -1
- package/node_modules/@oscharko-dev/keiko-memory-consolidation/dist/_constants.d.ts +3 -0
- package/node_modules/@oscharko-dev/keiko-memory-consolidation/dist/_constants.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-memory-consolidation/dist/_constants.js +5 -0
- package/node_modules/@oscharko-dev/keiko-memory-consolidation/dist/consolidate.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-memory-consolidation/dist/consolidate.js +93 -30
- package/node_modules/@oscharko-dev/keiko-memory-consolidation/dist/stale.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-memory-consolidation/dist/stale.js +3 -1
- package/node_modules/@oscharko-dev/keiko-memory-consolidation/dist/types.d.ts +5 -0
- package/node_modules/@oscharko-dev/keiko-memory-consolidation/dist/types.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-memory-consolidation/dist/types.js +1 -1
- package/node_modules/@oscharko-dev/keiko-memory-consolidation/package.json +2 -2
- package/node_modules/@oscharko-dev/keiko-memory-governance/dist/.tsbuildinfo +1 -1
- package/node_modules/@oscharko-dev/keiko-memory-governance/dist/forget.js +1 -1
- package/node_modules/@oscharko-dev/keiko-memory-governance/dist/types.js +1 -1
- package/node_modules/@oscharko-dev/keiko-memory-governance/package.json +2 -2
- package/node_modules/@oscharko-dev/keiko-memory-retrieval/dist/.tsbuildinfo +1 -1
- package/node_modules/@oscharko-dev/keiko-memory-retrieval/dist/context.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-memory-retrieval/dist/context.js +61 -18
- package/node_modules/@oscharko-dev/keiko-memory-retrieval/dist/ranking.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-memory-retrieval/dist/ranking.js +3 -1
- package/node_modules/@oscharko-dev/keiko-memory-retrieval/dist/retrieve.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-memory-retrieval/dist/retrieve.js +26 -4
- package/node_modules/@oscharko-dev/keiko-memory-retrieval/dist/types.d.ts +9 -1
- package/node_modules/@oscharko-dev/keiko-memory-retrieval/dist/types.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-memory-retrieval/package.json +1 -1
- package/node_modules/@oscharko-dev/keiko-memory-vault/dist/.tsbuildinfo +1 -1
- package/node_modules/@oscharko-dev/keiko-memory-vault/dist/embeddings.d.ts +1 -0
- package/node_modules/@oscharko-dev/keiko-memory-vault/dist/embeddings.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-memory-vault/dist/embeddings.js +21 -0
- package/node_modules/@oscharko-dev/keiko-memory-vault/dist/index.d.ts +1 -1
- package/node_modules/@oscharko-dev/keiko-memory-vault/dist/index.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-memory-vault/dist/migrate-encrypt.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-memory-vault/dist/migrate-encrypt.js +24 -4
- package/node_modules/@oscharko-dev/keiko-memory-vault/dist/schema.d.ts +1 -1
- package/node_modules/@oscharko-dev/keiko-memory-vault/dist/schema.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-memory-vault/dist/schema.js +27 -4
- package/node_modules/@oscharko-dev/keiko-memory-vault/dist/tombstones.d.ts +1 -0
- package/node_modules/@oscharko-dev/keiko-memory-vault/dist/tombstones.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-memory-vault/dist/tombstones.js +21 -4
- package/node_modules/@oscharko-dev/keiko-memory-vault/dist/types.d.ts +22 -1
- package/node_modules/@oscharko-dev/keiko-memory-vault/dist/types.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-memory-vault/dist/validate.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-memory-vault/dist/validate.js +3 -0
- package/node_modules/@oscharko-dev/keiko-memory-vault/dist/vault.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-memory-vault/dist/vault.js +105 -28
- package/node_modules/@oscharko-dev/keiko-memory-vault/package.json +1 -1
- package/node_modules/@oscharko-dev/keiko-model-gateway/dist/.tsbuildinfo +1 -1
- package/node_modules/@oscharko-dev/keiko-model-gateway/dist/config.d.ts +2 -0
- package/node_modules/@oscharko-dev/keiko-model-gateway/dist/config.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-model-gateway/dist/config.js +83 -69
- package/node_modules/@oscharko-dev/keiko-model-gateway/dist/embedding.d.ts +3 -2
- package/node_modules/@oscharko-dev/keiko-model-gateway/dist/embedding.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-model-gateway/dist/embedding.js +20 -16
- package/node_modules/@oscharko-dev/keiko-model-gateway/dist/gateway.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-model-gateway/dist/gateway.js +9 -3
- package/node_modules/@oscharko-dev/keiko-model-gateway/dist/http.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-model-gateway/dist/http.js +29 -3
- package/node_modules/@oscharko-dev/keiko-model-gateway/dist/index.d.ts +4 -4
- package/node_modules/@oscharko-dev/keiko-model-gateway/dist/index.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-model-gateway/dist/index.js +3 -3
- package/node_modules/@oscharko-dev/keiko-model-gateway/dist/normalize.d.ts +1 -0
- package/node_modules/@oscharko-dev/keiko-model-gateway/dist/normalize.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-model-gateway/dist/normalize.js +22 -1
- package/node_modules/@oscharko-dev/keiko-model-gateway/dist/openai-adapter.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-model-gateway/dist/openai-adapter.js +69 -10
- package/node_modules/@oscharko-dev/keiko-model-gateway/dist/openai-embedding-adapter.d.ts +20 -1
- package/node_modules/@oscharko-dev/keiko-model-gateway/dist/openai-embedding-adapter.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-model-gateway/dist/openai-embedding-adapter.js +122 -7
- package/node_modules/@oscharko-dev/keiko-model-gateway/dist/qualityIntelligence/capabilityGate.d.ts +10 -1
- package/node_modules/@oscharko-dev/keiko-model-gateway/dist/qualityIntelligence/capabilityGate.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-model-gateway/dist/qualityIntelligence/capabilityGate.js +33 -11
- package/node_modules/@oscharko-dev/keiko-model-gateway/dist/qualityIntelligence/capabilityMapping.d.ts +4 -0
- package/node_modules/@oscharko-dev/keiko-model-gateway/dist/qualityIntelligence/capabilityMapping.d.ts.map +1 -0
- package/node_modules/@oscharko-dev/keiko-model-gateway/dist/qualityIntelligence/capabilityMapping.js +21 -0
- package/node_modules/@oscharko-dev/keiko-model-gateway/dist/qualityIntelligence/index.d.ts +1 -1
- package/node_modules/@oscharko-dev/keiko-model-gateway/dist/qualityIntelligence/index.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-model-gateway/dist/qualityIntelligence/index.js +1 -1
- package/node_modules/@oscharko-dev/keiko-model-gateway/dist/qualityIntelligence/routing.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-model-gateway/dist/qualityIntelligence/routing.js +2 -13
- package/node_modules/@oscharko-dev/keiko-model-gateway/dist/resilience.d.ts +1 -0
- package/node_modules/@oscharko-dev/keiko-model-gateway/dist/resilience.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-model-gateway/dist/resilience.js +18 -2
- package/node_modules/@oscharko-dev/keiko-model-gateway/dist/types.d.ts +5 -1
- package/node_modules/@oscharko-dev/keiko-model-gateway/dist/types.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-model-gateway/package.json +1 -1
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/.tsbuildinfo +1 -1
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/domain/assertions.d.ts +35 -0
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/domain/assertions.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/domain/assertions.js +74 -0
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/domain/deduplication.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/domain/deduplication.js +6 -2
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/domain/figma/a11yBaseline.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/domain/figma/a11yBaseline.js +64 -19
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/domain/figma/cleanToScreenIr.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/domain/figma/cleanToScreenIr.js +3 -0
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/domain/figma/color.d.ts +6 -1
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/domain/figma/color.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/domain/figma/color.js +22 -9
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/domain/figma/emissionPlan.d.ts +4 -1
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/domain/figma/emissionPlan.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/domain/figma/emissionPlan.js +28 -12
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/domain/figma/htmlCssAdapter.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/domain/figma/htmlCssAdapter.js +123 -33
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/domain/figma/index.d.ts +2 -2
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/domain/figma/index.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/domain/figma/irTypes.d.ts +7 -4
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/domain/figma/irTypes.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/domain/figma/links.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/domain/figma/links.js +13 -17
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/domain/figma/navGraph.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/domain/figma/navGraph.js +35 -12
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/domain/figma/normalize.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/domain/figma/normalize.js +54 -6
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/domain/figma/screenIrTestBaseline.d.ts +4 -0
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/domain/figma/screenIrTestBaseline.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/domain/figma/screenIrTestBaseline.js +29 -10
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/domain/figma/tokens.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/domain/figma/tokens.js +10 -4
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/domain/requirementExcerpt.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/domain/requirementExcerpt.js +15 -6
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/domain/staleness.d.ts +4 -0
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/domain/staleness.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/domain/staleness.js +162 -6
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/domain/testDesignModel.d.ts +14 -2
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/domain/testDesignModel.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/domain/testDesignModel.js +50 -12
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/domain/validation.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/domain/validation.js +4 -2
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/export/adapters/alm.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/export/adapters/alm.js +29 -30
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/export/adapters/markdown.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/export/adapters/markdown.js +34 -5
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/export/adapters/qtest.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/export/adapters/qtest.js +29 -29
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/export/adapters/spreadsheetSafeCsv.d.ts +2 -1
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/export/adapters/spreadsheetSafeCsv.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/export/adapters/spreadsheetSafeCsv.js +40 -2
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/export/adapters/traceability.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/export/adapters/traceability.js +12 -9
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/export/adapters/xray.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/export/adapters/xray.js +6 -2
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/export/textSafety.d.ts +7 -0
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/export/textSafety.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/export/textSafety.js +7 -0
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/generation/candidateBounds.d.ts +10 -0
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/generation/candidateBounds.d.ts.map +1 -0
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/generation/candidateBounds.js +14 -0
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/generation/index.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/generation/index.js +3 -2
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/generation/parseGeneratedCandidates.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/generation/parseGeneratedCandidates.js +97 -50
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/generation/prompt.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/generation/prompt.js +35 -7
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/index.d.ts +2 -2
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/index.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/dist/index.js +2 -2
- package/node_modules/@oscharko-dev/keiko-quality-intelligence/package.json +1 -1
- package/node_modules/@oscharko-dev/keiko-sdk/dist/.tsbuildinfo +1 -1
- package/node_modules/@oscharko-dev/keiko-sdk/package.json +1 -1
- package/node_modules/@oscharko-dev/keiko-security/dist/.tsbuildinfo +1 -1
- package/node_modules/@oscharko-dev/keiko-security/dist/errors/gateway.d.ts +11 -0
- package/node_modules/@oscharko-dev/keiko-security/dist/errors/gateway.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-security/dist/errors/gateway.js +13 -0
- package/node_modules/@oscharko-dev/keiko-security/package.json +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/.tsbuildinfo +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/assistant-response.d.ts +6 -0
- package/node_modules/@oscharko-dev/keiko-server/dist/assistant-response.d.ts.map +1 -0
- package/node_modules/@oscharko-dev/keiko-server/dist/assistant-response.js +12 -0
- package/node_modules/@oscharko-dev/keiko-server/dist/chat-handlers.d.ts +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/chat-handlers.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/chat-handlers.js +61 -16
- package/node_modules/@oscharko-dev/keiko-server/dist/chat-stream-handlers.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/chat-stream-handlers.js +11 -9
- package/node_modules/@oscharko-dev/keiko-server/dist/conversation-prompt.d.ts +1 -0
- package/node_modules/@oscharko-dev/keiko-server/dist/conversation-prompt.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/conversation-prompt.js +3 -0
- package/node_modules/@oscharko-dev/keiko-server/dist/deps.d.ts +4 -2
- package/node_modules/@oscharko-dev/keiko-server/dist/deps.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/deps.js +44 -69
- package/node_modules/@oscharko-dev/keiko-server/dist/gateway-setup.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/gateway-setup.js +120 -28
- package/node_modules/@oscharko-dev/keiko-server/dist/governed-workflow.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/governed-workflow.js +4 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/grounded-handoff.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/grounded-handoff.js +2 -0
- package/node_modules/@oscharko-dev/keiko-server/dist/grounded-orchestrator.d.ts +0 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/grounded-orchestrator.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/grounded-orchestrator.js +222 -18
- package/node_modules/@oscharko-dev/keiko-server/dist/grounded-qa-hybrid.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/grounded-qa-hybrid.js +118 -23
- package/node_modules/@oscharko-dev/keiko-server/dist/grounded-qa-multi-source.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/grounded-qa-multi-source.js +57 -22
- package/node_modules/@oscharko-dev/keiko-server/dist/grounded-qa.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/grounded-qa.js +14 -5
- package/node_modules/@oscharko-dev/keiko-server/dist/index.d.ts +1 -0
- package/node_modules/@oscharko-dev/keiko-server/dist/index.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/index.js +1 -0
- package/node_modules/@oscharko-dev/keiko-server/dist/local-knowledge-grounded-qa.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/local-knowledge-grounded-qa.js +11 -4
- package/node_modules/@oscharko-dev/keiko-server/dist/local-knowledge-handlers.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/local-knowledge-handlers.js +26 -14
- package/node_modules/@oscharko-dev/keiko-server/dist/memory-audit-handler.d.ts +1 -0
- package/node_modules/@oscharko-dev/keiko-server/dist/memory-audit-handler.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/memory-audit-handler.js +52 -27
- package/node_modules/@oscharko-dev/keiko-server/dist/memory-capture-policy.d.ts +10 -0
- package/node_modules/@oscharko-dev/keiko-server/dist/memory-capture-policy.d.ts.map +1 -0
- package/node_modules/@oscharko-dev/keiko-server/dist/memory-capture-policy.js +44 -0
- package/node_modules/@oscharko-dev/keiko-server/dist/memory-consolidation-handlers.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/memory-consolidation-handlers.js +79 -57
- package/node_modules/@oscharko-dev/keiko-server/dist/memory-consolidation-registry.d.ts +1 -0
- package/node_modules/@oscharko-dev/keiko-server/dist/memory-consolidation-registry.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/memory-conv-handlers.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/memory-conv-handlers.js +6 -4
- package/node_modules/@oscharko-dev/keiko-server/dist/memory-conversation-context.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/memory-diagnostics.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/memory-diagnostics.js +16 -9
- package/node_modules/@oscharko-dev/keiko-server/dist/memory-handlers.d.ts +3 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/memory-handlers.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/memory-handlers.js +538 -87
- package/node_modules/@oscharko-dev/keiko-server/dist/memory-maintenance-handlers.d.ts +6 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/memory-maintenance-handlers.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/memory-maintenance-handlers.js +17 -38
- package/node_modules/@oscharko-dev/keiko-server/dist/memory-retention.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/memory-retention.js +7 -15
- package/node_modules/@oscharko-dev/keiko-server/dist/memory-salience.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/memory-salience.js +17 -2
- package/node_modules/@oscharko-dev/keiko-server/dist/memory-scope-sanitizer.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/memory-scope-sanitizer.js +19 -0
- package/node_modules/@oscharko-dev/keiko-server/dist/memory-target-resolver.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/memory-target-resolver.js +4 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/memory-workflow-port.d.ts +1 -0
- package/node_modules/@oscharko-dev/keiko-server/dist/memory-workflow-port.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/memory-workflow-port.js +108 -27
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/capsuleAdapter.d.ts +4 -0
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/capsuleAdapter.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/capsuleAdapter.js +3 -0
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/connectorErrors.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/connectorErrors.js +11 -8
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/editRoutes.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/editRoutes.js +62 -7
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/exportRoutes.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/exportRoutes.js +98 -33
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/figma/figmaConcurrency.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/figma/figmaConcurrency.js +2 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/figma/figmaConnector.d.ts +6 -0
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/figma/figmaConnector.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/figma/figmaConnector.js +16 -3
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/figma/figmaConnectorAudit.d.ts +7 -0
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/figma/figmaConnectorAudit.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/figma/figmaConnectorErrors.d.ts +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/figma/figmaConnectorErrors.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/figma/figmaConnectorErrors.js +3 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/figma/figmaConsent.d.ts +2 -2
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/figma/figmaConsent.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/figma/figmaConsent.js +3 -3
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/figma/figmaObservedActions.d.ts +5 -0
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/figma/figmaObservedActions.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/figma/figmaObservedActions.js +10 -8
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/figma/figmaReadiness.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/figma/figmaReadiness.js +11 -5
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/figma/figmaRenderPort.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/figma/figmaRenderPort.js +1 -0
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/figma/figmaScopedPagination.d.ts +3 -0
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/figma/figmaScopedPagination.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/figma/figmaScopedPagination.js +71 -10
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/figma/figmaSnapshotBuilder.d.ts +2 -0
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/figma/figmaSnapshotBuilder.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/figma/figmaSnapshotBuilder.js +86 -23
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/figma/figmaSnapshotTypes.d.ts +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/figma/figmaSnapshotTypes.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/figma/figmaTokenSource.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/figma/figmaTokenSource.js +4 -3
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/figma/figmaUrl.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/figma/figmaUrl.js +2 -0
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/figma/index.d.ts +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/figma/index.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/figma/index.js +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/figmaCodegenRoutes.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/figmaCodegenRoutes.js +60 -20
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/figmaSnapshotAdapter.d.ts +11 -6
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/figmaSnapshotAdapter.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/figmaSnapshotAdapter.js +144 -6
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/figmaSnapshotOrchestration.d.ts +9 -0
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/figmaSnapshotOrchestration.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/figmaSnapshotOrchestration.js +84 -15
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/figmaSnapshotRoutes.d.ts +9 -7
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/figmaSnapshotRoutes.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/figmaSnapshotRoutes.js +206 -42
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/generationPort.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/generationPort.js +12 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/handoffErrors.d.ts +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/handoffErrors.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/handoffErrors.js +1 -0
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/handoffRoutes.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/handoffRoutes.js +41 -9
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/index.d.ts +1 -0
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/index.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/index.js +2 -0
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/judgePort.d.ts +3 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/judgePort.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/judgePort.js +86 -68
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/modelSelection.d.ts +15 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/modelSelection.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/modelSelection.js +56 -39
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/reCheckRoutes.d.ts +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/reCheckRoutes.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/reCheckRoutes.js +382 -75
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/retentionRoutes.d.ts +5 -0
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/retentionRoutes.d.ts.map +1 -0
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/retentionRoutes.js +70 -0
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/reviewRoutes.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/reviewRoutes.js +20 -8
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/reviewStore.d.ts +25 -4
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/reviewStore.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/reviewStore.js +72 -9
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/runExecution.d.ts +3 -2
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/runExecution.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/runExecution.js +44 -16
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/runIngestion.d.ts +7 -0
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/runIngestion.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/runIngestion.js +370 -38
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/runRegistry.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/runRegistry.js +2 -0
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/runRoutes.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/runRoutes.js +15 -5
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/traceabilityRoutes.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/traceabilityRoutes.js +36 -4
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/uiRoutes.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/qualityIntelligence/uiRoutes.js +73 -8
- package/node_modules/@oscharko-dev/keiko-server/dist/routes.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/routes.js +20 -6
- package/node_modules/@oscharko-dev/keiko-server/dist/run-engine.d.ts +1 -0
- package/node_modules/@oscharko-dev/keiko-server/dist/run-engine.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/run-engine.js +3 -0
- package/node_modules/@oscharko-dev/keiko-server/dist/run-handlers.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/run-handlers.js +2 -0
- package/node_modules/@oscharko-dev/keiko-server/dist/sse-write.d.ts +9 -0
- package/node_modules/@oscharko-dev/keiko-server/dist/sse-write.d.ts.map +1 -0
- package/node_modules/@oscharko-dev/keiko-server/dist/sse-write.js +26 -0
- package/node_modules/@oscharko-dev/keiko-server/dist/store/chats.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/store/chats.js +16 -8
- package/node_modules/@oscharko-dev/keiko-server/dist/store/messages.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/store-handlers.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/store-handlers.js +4 -1
- package/node_modules/@oscharko-dev/keiko-server/dist/terminal.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-server/package.json +1 -1
- package/node_modules/@oscharko-dev/keiko-tools/dist/.tsbuildinfo +1 -1
- package/node_modules/@oscharko-dev/keiko-tools/dist/patch-normalize.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-tools/dist/patch-normalize.js +13 -7
- package/node_modules/@oscharko-dev/keiko-tools/package.json +1 -1
- package/node_modules/@oscharko-dev/keiko-verification/dist/.tsbuildinfo +1 -1
- package/node_modules/@oscharko-dev/keiko-verification/package.json +1 -1
- package/node_modules/@oscharko-dev/keiko-workflows/dist/.tsbuildinfo +1 -1
- package/node_modules/@oscharko-dev/keiko-workflows/dist/bug-investigation/memory.d.ts +2 -2
- package/node_modules/@oscharko-dev/keiko-workflows/dist/bug-investigation/memory.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-workflows/dist/bug-investigation/memory.js +16 -18
- package/node_modules/@oscharko-dev/keiko-workflows/dist/bug-investigation/prompt.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-workflows/dist/bug-investigation/prompt.js +6 -1
- package/node_modules/@oscharko-dev/keiko-workflows/dist/bug-investigation/workflow.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-workflows/dist/bug-investigation/workflow.js +3 -3
- package/node_modules/@oscharko-dev/keiko-workflows/dist/governed-handoff.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-workflows/dist/planner/anchors.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-workflows/dist/planner/anchors.js +68 -0
- package/node_modules/@oscharko-dev/keiko-workflows/dist/qualityIntelligence/descriptors.d.ts +2 -2
- package/node_modules/@oscharko-dev/keiko-workflows/dist/qualityIntelligence/modelRoutedTestDesign.d.ts +18 -2
- package/node_modules/@oscharko-dev/keiko-workflows/dist/qualityIntelligence/modelRoutedTestDesign.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-workflows/dist/qualityIntelligence/modelRoutedTestDesign.js +209 -54
- package/node_modules/@oscharko-dev/keiko-workflows/dist/qualityIntelligence/runtimeCommon.d.ts +4 -4
- package/node_modules/@oscharko-dev/keiko-workflows/dist/qualityIntelligence/runtimeCommon.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-workflows/dist/qualityIntelligence/runtimeCommon.js +4 -1
- package/node_modules/@oscharko-dev/keiko-workflows/dist/unit-tests/target-guard.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-workflows/package.json +1 -1
- package/node_modules/@oscharko-dev/keiko-workspace/dist/.tsbuildinfo +1 -1
- package/node_modules/@oscharko-dev/keiko-workspace/dist/discovery.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-workspace/dist/discovery.js +34 -2
- package/node_modules/@oscharko-dev/keiko-workspace/dist/realpath.d.ts +1 -0
- package/node_modules/@oscharko-dev/keiko-workspace/dist/realpath.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-workspace/dist/realpath.js +2 -2
- package/node_modules/@oscharko-dev/keiko-workspace/dist/repoSearchEntries.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-workspace/dist/repoSearchEntries.js +1 -2
- package/node_modules/@oscharko-dev/keiko-workspace/dist/repoSearchLineSelection.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-workspace/dist/repoSearchLineSelection.js +2 -1
- package/node_modules/@oscharko-dev/keiko-workspace/dist/repoSearchMatchers.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-workspace/dist/repoSearchMatchers.js +74 -2
- package/node_modules/@oscharko-dev/keiko-workspace/dist/repoSearchRegexSafety.d.ts.map +1 -1
- package/node_modules/@oscharko-dev/keiko-workspace/package.json +1 -1
- package/package.json +23 -6
- package/dist/ui/static/_next/static/chunks/082obv3v03b-9.js +0 -2
- package/dist/ui/static/_next/static/chunks/0uifns067thv8.js +0 -1
- package/dist/ui/static/_next/static/chunks/0x31-j53ab1tt.js +0 -1
- package/dist/ui/static/_next/static/chunks/1t04tfgin0v_g.js +0 -106
- package/dist/ui/static/_next/static/chunks/1v4hrxrm_6_rw.js +0 -1
- package/dist/ui/static/_next/static/chunks/27jktro2p5rq9.js +0 -4
- package/dist/ui/static/_next/static/chunks/2lypy3ewh0r04.js +0 -1
- package/dist/ui/static/_next/static/chunks/32573pyyglqxl.js +0 -1
- package/dist/ui/static/_next/static/chunks/3_t_pzet29qtn.js +0 -1
- package/dist/ui/static/_next/static/chunks/3jgg_oe0iok0l.js +0 -1
- package/dist/ui/static/_next/static/chunks/3o_oia3vsam60.js +0 -1
- package/dist/ui/static/_next/static/chunks/3wr_35f2vg6sd.css +0 -1
- package/dist/ui/static/_next/static/chunks/turbopack-2lg1g6kbsfm0x.js +0 -1
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/conversation/scripted-answer-generator.d.ts +0 -6
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/conversation/scripted-answer-generator.d.ts.map +0 -1
- package/node_modules/@oscharko-dev/keiko-local-knowledge/dist/conversation/scripted-answer-generator.js +0 -49
- /package/dist/ui/static/_next/static/{Hb6brrvZY2nZtizQlYhVt → fQMXe8UmV01bh25WOoIt3}/_buildManifest.js +0 -0
- /package/dist/ui/static/_next/static/{Hb6brrvZY2nZtizQlYhVt → fQMXe8UmV01bh25WOoIt3}/_clientMiddlewareManifest.js +0 -0
- /package/dist/ui/static/_next/static/{Hb6brrvZY2nZtizQlYhVt → fQMXe8UmV01bh25WOoIt3}/_ssgManifest.js +0 -0
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
//
|
|
1
|
+
// MemoriaViva BFF route handlers (Issue #211 / Epic #204).
|
|
2
2
|
//
|
|
3
3
|
// These handlers wire the /api/memory/* routes to the three memory packages:
|
|
4
4
|
// - @oscharko-dev/keiko-memory-vault → persistence (list / get / update / delete)
|
|
@@ -15,15 +15,16 @@
|
|
|
15
15
|
// Every response is redacted through `deps.redactor` before serialisation to honour D9.
|
|
16
16
|
import { randomUUID } from "node:crypto";
|
|
17
17
|
import { createMemoryVault, MemoryStorageError, } from "@oscharko-dev/keiko-memory-vault";
|
|
18
|
-
import { GovernanceError, buildArchiveOperation, buildForgetOperations, buildPinOperation, buildUnpinOperation, selectMemoriesForForget, } from "@oscharko-dev/keiko-memory-governance";
|
|
19
|
-
import { MEMORY_SCOPE_KINDS, MEMORY_STATUSES, MEMORY_TYPES, MEMORY_SENSITIVITIES, } from "@oscharko-dev/keiko-contracts";
|
|
18
|
+
import { GovernanceError, buildArchiveOperation, buildConflictTransitions, buildCorrection, buildForgetOperations, buildPinOperation, buildUnpinOperation, detectConflictPair, selectMemoriesForForget, } from "@oscharko-dev/keiko-memory-governance";
|
|
19
|
+
import { checkStatusTransition, MEMORY_SCOPE_KINDS, MEMORY_STATUSES, MEMORY_TYPES, MEMORY_SENSITIVITIES, validateMemoryScope, } from "@oscharko-dev/keiko-contracts";
|
|
20
20
|
import { errorBody } from "./routes.js";
|
|
21
|
+
import { auditRunIdFor, recordMemoryAudit } from "./memory-audit-handler.js";
|
|
21
22
|
// ─── Constants ────────────────────────────────────────────────────────────────
|
|
22
23
|
const MAX_MEMORY_BODY_BYTES = 64_000;
|
|
23
|
-
const DEFAULT_REVIEWER_ID = "
|
|
24
|
+
const DEFAULT_REVIEWER_ID = "memoriaviva-ui";
|
|
24
25
|
const MAX_LIST_LIMIT = 200;
|
|
25
26
|
const DEFAULT_LIST_LIMIT = 50;
|
|
26
|
-
const REVIEW_QUEUE_STATUSES = ["proposed", "conflicted"];
|
|
27
|
+
const REVIEW_QUEUE_STATUSES = ["proposed", "conflicted", "expired"];
|
|
27
28
|
// ─── Type guards / helpers ─────────────────────────────────────────────────────
|
|
28
29
|
// Sanitise GovernanceError into a code-keyed safe response body. GovernanceError.message
|
|
29
30
|
// is composed as `GovernanceError(${code}): ${detail}` and can embed memory UUIDs from
|
|
@@ -74,6 +75,18 @@ function splitComma(raw) {
|
|
|
74
75
|
.map((s) => s.trim())
|
|
75
76
|
.filter((s) => s.length > 0);
|
|
76
77
|
}
|
|
78
|
+
function parseScope(raw) {
|
|
79
|
+
if (!isRecord(raw)) {
|
|
80
|
+
return { status: 400, body: errorBody("BAD_REQUEST", "selector.scope must be an object.") };
|
|
81
|
+
}
|
|
82
|
+
if (!validateMemoryScope(raw).ok) {
|
|
83
|
+
return {
|
|
84
|
+
status: 400,
|
|
85
|
+
body: errorBody("BAD_REQUEST", "selector.scope must be a valid memory scope."),
|
|
86
|
+
};
|
|
87
|
+
}
|
|
88
|
+
return raw;
|
|
89
|
+
}
|
|
77
90
|
// ─── Body reading ──────────────────────────────────────────────────────────────
|
|
78
91
|
class BodyTooLargeError extends Error {
|
|
79
92
|
constructor() {
|
|
@@ -185,6 +198,26 @@ function listMemoriesAcrossScopes(vault, options) {
|
|
|
185
198
|
});
|
|
186
199
|
return sortMemories(filtered);
|
|
187
200
|
}
|
|
201
|
+
function isStaleReviewCandidate(record) {
|
|
202
|
+
return (record.staleReason !== undefined &&
|
|
203
|
+
record.status !== "proposed" &&
|
|
204
|
+
record.status !== "conflicted" &&
|
|
205
|
+
record.status !== "expired" &&
|
|
206
|
+
record.status !== "rejected" &&
|
|
207
|
+
record.status !== "archived" &&
|
|
208
|
+
record.status !== "forgotten");
|
|
209
|
+
}
|
|
210
|
+
function listReviewQueueMemories(vault) {
|
|
211
|
+
const byStatus = listMemoriesAcrossScopes(vault, {
|
|
212
|
+
statuses: REVIEW_QUEUE_STATUSES,
|
|
213
|
+
});
|
|
214
|
+
const stale = listMemoriesAcrossScopes(vault, {}).filter(isStaleReviewCandidate);
|
|
215
|
+
const byId = new Map();
|
|
216
|
+
for (const record of [...byStatus, ...stale]) {
|
|
217
|
+
byId.set(record.id, record);
|
|
218
|
+
}
|
|
219
|
+
return sortMemories([...byId.values()]);
|
|
220
|
+
}
|
|
188
221
|
function parseListParams(ctx) {
|
|
189
222
|
const scopeKinds = splitComma(ctx.url.searchParams.get("scope"));
|
|
190
223
|
const types = splitComma(ctx.url.searchParams.get("type"));
|
|
@@ -259,9 +292,7 @@ export function handleMemoryReviewQueue(_ctx, deps) {
|
|
|
259
292
|
if (isRouteResult(vault))
|
|
260
293
|
return vault;
|
|
261
294
|
try {
|
|
262
|
-
const proposed =
|
|
263
|
-
statuses: REVIEW_QUEUE_STATUSES,
|
|
264
|
-
});
|
|
295
|
+
const proposed = listReviewQueueMemories(vault);
|
|
265
296
|
return {
|
|
266
297
|
status: 200,
|
|
267
298
|
body: {
|
|
@@ -466,7 +497,7 @@ export async function handleArchiveMemory(ctx, deps) {
|
|
|
466
497
|
throw err;
|
|
467
498
|
}
|
|
468
499
|
}
|
|
469
|
-
function
|
|
500
|
+
function parseDestructiveInput(raw, defaultReason) {
|
|
470
501
|
if (raw.acknowledged !== true) {
|
|
471
502
|
return {
|
|
472
503
|
status: 400,
|
|
@@ -475,30 +506,152 @@ function parseForgetInput(raw) {
|
|
|
475
506
|
}
|
|
476
507
|
const reason = typeof raw.reason === "string" && raw.reason.trim().length > 0
|
|
477
508
|
? raw.reason.trim()
|
|
478
|
-
:
|
|
509
|
+
: defaultReason;
|
|
479
510
|
return { reason };
|
|
480
511
|
}
|
|
481
|
-
function
|
|
482
|
-
|
|
483
|
-
|
|
484
|
-
|
|
512
|
+
function parseByIdForgetSelector(raw) {
|
|
513
|
+
if (typeof raw.memoryId !== "string" || raw.memoryId.trim().length === 0) {
|
|
514
|
+
return {
|
|
515
|
+
status: 400,
|
|
516
|
+
body: errorBody("BAD_REQUEST", "selector.memoryId must be a non-empty string."),
|
|
517
|
+
};
|
|
518
|
+
}
|
|
519
|
+
return { kind: "by-id", memoryId: raw.memoryId };
|
|
520
|
+
}
|
|
521
|
+
function parseByScopeForgetSelector(raw) {
|
|
522
|
+
const scope = parseScope(raw.scope);
|
|
523
|
+
if (isRouteResult(scope))
|
|
524
|
+
return scope;
|
|
525
|
+
return { kind: "by-scope", scope };
|
|
526
|
+
}
|
|
527
|
+
function parseByTypeForgetSelector(raw) {
|
|
528
|
+
const scope = parseScope(raw.scope);
|
|
529
|
+
if (isRouteResult(scope))
|
|
530
|
+
return scope;
|
|
531
|
+
if (!isMemoryType(raw.type)) {
|
|
532
|
+
return {
|
|
533
|
+
status: 400,
|
|
534
|
+
body: errorBody("BAD_REQUEST", "selector.type must be a valid memory type."),
|
|
535
|
+
};
|
|
536
|
+
}
|
|
537
|
+
return { kind: "by-type", scope, type: raw.type };
|
|
538
|
+
}
|
|
539
|
+
function parseBySourceConversationForgetSelector(raw) {
|
|
540
|
+
const scope = parseScope(raw.scope);
|
|
541
|
+
if (isRouteResult(scope))
|
|
542
|
+
return scope;
|
|
543
|
+
if (typeof raw.sourceConversationId !== "string" ||
|
|
544
|
+
raw.sourceConversationId.trim().length === 0) {
|
|
545
|
+
return {
|
|
546
|
+
status: 400,
|
|
547
|
+
body: errorBody("BAD_REQUEST", "selector.sourceConversationId must be a non-empty string."),
|
|
548
|
+
};
|
|
485
549
|
}
|
|
550
|
+
return {
|
|
551
|
+
kind: "by-source-conversation",
|
|
552
|
+
scope,
|
|
553
|
+
sourceConversationId: raw.sourceConversationId,
|
|
554
|
+
};
|
|
555
|
+
}
|
|
556
|
+
function parseByTimeWindowForgetSelector(raw) {
|
|
557
|
+
const scope = parseScope(raw.scope);
|
|
558
|
+
if (isRouteResult(scope))
|
|
559
|
+
return scope;
|
|
560
|
+
if (typeof raw.olderThanMs !== "number" ||
|
|
561
|
+
!Number.isFinite(raw.olderThanMs) ||
|
|
562
|
+
raw.olderThanMs < 0) {
|
|
563
|
+
return {
|
|
564
|
+
status: 400,
|
|
565
|
+
body: errorBody("BAD_REQUEST", "selector.olderThanMs must be a finite non-negative number."),
|
|
566
|
+
};
|
|
567
|
+
}
|
|
568
|
+
return { kind: "by-time-window", scope, olderThanMs: raw.olderThanMs };
|
|
569
|
+
}
|
|
570
|
+
function parseForgetSelector(raw) {
|
|
571
|
+
if (!isRecord(raw)) {
|
|
572
|
+
return { status: 400, body: errorBody("BAD_REQUEST", "selector must be an object.") };
|
|
573
|
+
}
|
|
574
|
+
switch (raw.kind) {
|
|
575
|
+
case "by-id":
|
|
576
|
+
return parseByIdForgetSelector(raw);
|
|
577
|
+
case "by-scope":
|
|
578
|
+
return parseByScopeForgetSelector(raw);
|
|
579
|
+
case "by-type":
|
|
580
|
+
return parseByTypeForgetSelector(raw);
|
|
581
|
+
case "by-source-conversation":
|
|
582
|
+
return parseBySourceConversationForgetSelector(raw);
|
|
583
|
+
case "by-time-window":
|
|
584
|
+
return parseByTimeWindowForgetSelector(raw);
|
|
585
|
+
default:
|
|
586
|
+
return {
|
|
587
|
+
status: 400,
|
|
588
|
+
body: errorBody("BAD_REQUEST", "selector.kind is not supported."),
|
|
589
|
+
};
|
|
590
|
+
}
|
|
591
|
+
}
|
|
592
|
+
function parseForgetSelectionInput(raw) {
|
|
593
|
+
const destructive = parseDestructiveInput(raw, "user-initiated selective forget from MemoriaViva");
|
|
594
|
+
if (isRouteResult(destructive))
|
|
595
|
+
return destructive;
|
|
596
|
+
const selector = parseForgetSelector(raw.selector);
|
|
597
|
+
if (isRouteResult(selector))
|
|
598
|
+
return selector;
|
|
599
|
+
return { ...destructive, selector };
|
|
600
|
+
}
|
|
601
|
+
function listForgetCandidates(vault, selector) {
|
|
602
|
+
if (selector.kind === "by-id") {
|
|
603
|
+
const record = vault.getMemory(selector.memoryId);
|
|
604
|
+
if (record === undefined) {
|
|
605
|
+
return { status: 404, body: errorBody("NOT_FOUND", "Memory not found.") };
|
|
606
|
+
}
|
|
607
|
+
return [record];
|
|
608
|
+
}
|
|
609
|
+
return sortMemories(vault.listMemoriesByScope(selector.scope, { includeExpired: true }));
|
|
610
|
+
}
|
|
611
|
+
function executeForgetSelection(vault, selector, reason) {
|
|
486
612
|
const nowMs = Date.now();
|
|
487
|
-
const
|
|
613
|
+
const records = listForgetCandidates(vault, selector);
|
|
614
|
+
if (isRouteResult(records))
|
|
615
|
+
return records;
|
|
616
|
+
const candidates = selectMemoriesForForget(records, selector, { nowMs });
|
|
488
617
|
if (candidates.length === 0) {
|
|
489
618
|
return {
|
|
490
619
|
status: 409,
|
|
491
|
-
body: errorBody("GOVERNANCE_ERROR", "
|
|
620
|
+
body: errorBody("GOVERNANCE_ERROR", "No matching memories can be forgotten."),
|
|
492
621
|
};
|
|
493
622
|
}
|
|
494
|
-
buildForgetOperations(candidates, { reviewerId: DEFAULT_REVIEWER_ID, nowMs }, { reason, writeTombstone: true });
|
|
495
|
-
vault.
|
|
496
|
-
|
|
497
|
-
|
|
498
|
-
|
|
499
|
-
|
|
500
|
-
|
|
501
|
-
|
|
623
|
+
const operations = buildForgetOperations(candidates, { reviewerId: DEFAULT_REVIEWER_ID, nowMs }, { reason, writeTombstone: true });
|
|
624
|
+
vault.deleteMemories(operations.map((operation) => ({
|
|
625
|
+
id: operation.memoryId,
|
|
626
|
+
options: {
|
|
627
|
+
tombstone: true,
|
|
628
|
+
reviewerId: operation.reviewerId,
|
|
629
|
+
reason: operation.reason,
|
|
630
|
+
forgetterSurface: "memory-center",
|
|
631
|
+
nowMs: operation.forgottenAt,
|
|
632
|
+
},
|
|
633
|
+
})));
|
|
634
|
+
return { memoryIds: operations.map((operation) => operation.memoryId) };
|
|
635
|
+
}
|
|
636
|
+
function formatForgetBody(memoryIds) {
|
|
637
|
+
return {
|
|
638
|
+
forgotten: true,
|
|
639
|
+
memoryIds,
|
|
640
|
+
count: memoryIds.length,
|
|
641
|
+
...(memoryIds.length === 1 ? { memoryId: memoryIds[0] } : {}),
|
|
642
|
+
};
|
|
643
|
+
}
|
|
644
|
+
function memoryMutationErrorBody(err, fallbackMessage) {
|
|
645
|
+
if (err instanceof GovernanceError) {
|
|
646
|
+
return { status: 400, body: governanceErrorBody(err) };
|
|
647
|
+
}
|
|
648
|
+
if (err instanceof MemoryStorageError) {
|
|
649
|
+
return {
|
|
650
|
+
status: err.code === "not-found" ? 404 : 500,
|
|
651
|
+
body: errorBody("MEMORY_ERROR", fallbackMessage),
|
|
652
|
+
};
|
|
653
|
+
}
|
|
654
|
+
throw err;
|
|
502
655
|
}
|
|
503
656
|
export async function handleForgetMemory(ctx, deps) {
|
|
504
657
|
const vault = resolveVault(deps);
|
|
@@ -511,28 +664,42 @@ export async function handleForgetMemory(ctx, deps) {
|
|
|
511
664
|
const body = await readJsonBody(ctx.req);
|
|
512
665
|
if (isRouteResult(body))
|
|
513
666
|
return body;
|
|
514
|
-
const input =
|
|
667
|
+
const input = parseDestructiveInput(body, "user-initiated forget from MemoriaViva");
|
|
515
668
|
if (isRouteResult(input))
|
|
516
669
|
return input;
|
|
517
670
|
try {
|
|
518
|
-
|
|
671
|
+
const result = executeForgetSelection(vault, { kind: "by-id", memoryId: id }, input.reason);
|
|
672
|
+
if (isRouteResult(result))
|
|
673
|
+
return result;
|
|
674
|
+
return { status: 200, body: formatForgetBody(result.memoryIds) };
|
|
519
675
|
}
|
|
520
676
|
catch (err) {
|
|
521
|
-
|
|
522
|
-
|
|
523
|
-
|
|
524
|
-
|
|
525
|
-
|
|
526
|
-
|
|
527
|
-
|
|
528
|
-
|
|
529
|
-
|
|
530
|
-
|
|
677
|
+
return memoryMutationErrorBody(err, "Failed to forget memory.");
|
|
678
|
+
}
|
|
679
|
+
}
|
|
680
|
+
export async function handleForgetMemories(ctx, deps) {
|
|
681
|
+
const vault = resolveVault(deps);
|
|
682
|
+
if (isRouteResult(vault))
|
|
683
|
+
return vault;
|
|
684
|
+
const body = await readJsonBody(ctx.req);
|
|
685
|
+
if (isRouteResult(body))
|
|
686
|
+
return body;
|
|
687
|
+
const input = parseForgetSelectionInput(body);
|
|
688
|
+
if (isRouteResult(input))
|
|
689
|
+
return input;
|
|
690
|
+
try {
|
|
691
|
+
const result = executeForgetSelection(vault, input.selector, input.reason);
|
|
692
|
+
if (isRouteResult(result))
|
|
693
|
+
return result;
|
|
694
|
+
return { status: 200, body: formatForgetBody(result.memoryIds) };
|
|
695
|
+
}
|
|
696
|
+
catch (err) {
|
|
697
|
+
return memoryMutationErrorBody(err, "Failed to forget memories.");
|
|
531
698
|
}
|
|
532
699
|
}
|
|
533
700
|
// ─── Handler: DELETE /api/memory/:id ──────────────────────────────────────────
|
|
534
|
-
//
|
|
535
|
-
export function handleDeleteMemory(ctx, deps) {
|
|
701
|
+
// DELETE is a convenience alias for governed, tombstoned deletion. It does not expose hard delete.
|
|
702
|
+
export async function handleDeleteMemory(ctx, deps) {
|
|
536
703
|
const vault = resolveVault(deps);
|
|
537
704
|
if (isRouteResult(vault))
|
|
538
705
|
return vault;
|
|
@@ -540,26 +707,176 @@ export function handleDeleteMemory(ctx, deps) {
|
|
|
540
707
|
if (id === undefined || id.length === 0) {
|
|
541
708
|
return { status: 400, body: errorBody("BAD_REQUEST", "Memory id is required.") };
|
|
542
709
|
}
|
|
710
|
+
const body = await readJsonBody(ctx.req);
|
|
711
|
+
if (isRouteResult(body))
|
|
712
|
+
return body;
|
|
713
|
+
const input = parseDestructiveInput(body, "user-initiated delete from MemoriaViva");
|
|
714
|
+
if (isRouteResult(input))
|
|
715
|
+
return input;
|
|
543
716
|
try {
|
|
544
|
-
const
|
|
545
|
-
if (
|
|
717
|
+
const result = executeForgetSelection(vault, { kind: "by-id", memoryId: id }, input.reason);
|
|
718
|
+
if (isRouteResult(result))
|
|
719
|
+
return result;
|
|
720
|
+
return {
|
|
721
|
+
status: 200,
|
|
722
|
+
body: {
|
|
723
|
+
deleted: true,
|
|
724
|
+
memoryId: id,
|
|
725
|
+
memoryIds: result.memoryIds,
|
|
726
|
+
count: result.memoryIds.length,
|
|
727
|
+
},
|
|
728
|
+
};
|
|
729
|
+
}
|
|
730
|
+
catch (err) {
|
|
731
|
+
return memoryMutationErrorBody(err, "Failed to delete memory.");
|
|
732
|
+
}
|
|
733
|
+
}
|
|
734
|
+
function uniqueIds(ids) {
|
|
735
|
+
return ids.filter((id, index) => ids.indexOf(id) === index);
|
|
736
|
+
}
|
|
737
|
+
function parseConflictResolutionInput(raw) {
|
|
738
|
+
if (typeof raw.winner !== "string" || raw.winner.trim().length === 0) {
|
|
739
|
+
return { status: 400, body: errorBody("BAD_REQUEST", "winner must be a non-empty string.") };
|
|
740
|
+
}
|
|
741
|
+
if (!Array.isArray(raw.losers) ||
|
|
742
|
+
raw.losers.length === 0 ||
|
|
743
|
+
!raw.losers.every((id) => typeof id === "string" && id.trim().length > 0)) {
|
|
744
|
+
return {
|
|
745
|
+
status: 400,
|
|
746
|
+
body: errorBody("BAD_REQUEST", "losers must be a non-empty string array."),
|
|
747
|
+
};
|
|
748
|
+
}
|
|
749
|
+
const reason = typeof raw.reason === "string" && raw.reason.trim().length > 0
|
|
750
|
+
? raw.reason.trim()
|
|
751
|
+
: "conflict resolved from MemoriaViva";
|
|
752
|
+
const winner = raw.winner;
|
|
753
|
+
const losers = raw.losers.map((id) => id);
|
|
754
|
+
if (uniqueIds([winner, ...losers]).length !== 1 + losers.length) {
|
|
755
|
+
return {
|
|
756
|
+
status: 400,
|
|
757
|
+
body: errorBody("BAD_REQUEST", "winner and losers must be unique memory ids."),
|
|
758
|
+
};
|
|
759
|
+
}
|
|
760
|
+
return {
|
|
761
|
+
winner,
|
|
762
|
+
losers,
|
|
763
|
+
reason,
|
|
764
|
+
};
|
|
765
|
+
}
|
|
766
|
+
function loadConflictMemories(vault, input) {
|
|
767
|
+
const records = [];
|
|
768
|
+
for (const id of uniqueIds([input.winner, ...input.losers])) {
|
|
769
|
+
const record = vault.getMemory(id);
|
|
770
|
+
if (record === undefined) {
|
|
546
771
|
return { status: 404, body: errorBody("NOT_FOUND", "Memory not found.") };
|
|
547
772
|
}
|
|
548
|
-
|
|
549
|
-
tombstone: false,
|
|
550
|
-
forgetterSurface: "memory-center",
|
|
551
|
-
nowMs: Date.now(),
|
|
552
|
-
});
|
|
553
|
-
return { status: 200, body: { deleted: true, memoryId: id } };
|
|
773
|
+
records.push(record);
|
|
554
774
|
}
|
|
555
|
-
|
|
556
|
-
|
|
557
|
-
|
|
558
|
-
|
|
559
|
-
|
|
560
|
-
}
|
|
775
|
+
return records;
|
|
776
|
+
}
|
|
777
|
+
function scopeKey(scope) {
|
|
778
|
+
switch (scope.kind) {
|
|
779
|
+
case "user":
|
|
780
|
+
return `user:${scope.userId}`;
|
|
781
|
+
case "workspace":
|
|
782
|
+
return `workspace:${scope.workspaceId}`;
|
|
783
|
+
case "project":
|
|
784
|
+
return `project:${scope.projectId}`;
|
|
785
|
+
case "workflow":
|
|
786
|
+
return `workflow:${scope.workflowDefinitionId}`;
|
|
787
|
+
case "global":
|
|
788
|
+
return "global";
|
|
789
|
+
}
|
|
790
|
+
}
|
|
791
|
+
function validateConflictPairForResolution(winner, loser) {
|
|
792
|
+
if (winner.type !== loser.type || scopeKey(winner.scope) !== scopeKey(loser.scope)) {
|
|
793
|
+
throw new GovernanceError("invalid-resolution", "conflict resolution requires memories with the same scope and type");
|
|
794
|
+
}
|
|
795
|
+
const conflict = detectConflictPair(winner, loser);
|
|
796
|
+
if (!conflict.hasConflict) {
|
|
797
|
+
throw new GovernanceError("invalid-resolution", "conflict resolution requires an actual detected conflict");
|
|
798
|
+
}
|
|
799
|
+
}
|
|
800
|
+
function validateConflictResolutionMemories(memories, input) {
|
|
801
|
+
const winner = findMemoryById(memories, input.winner);
|
|
802
|
+
if (winner === undefined) {
|
|
803
|
+
throw new GovernanceError("invalid-resolution", "winner is not loaded");
|
|
804
|
+
}
|
|
805
|
+
for (const loserId of input.losers) {
|
|
806
|
+
const loser = findMemoryById(memories, loserId);
|
|
807
|
+
if (loser === undefined) {
|
|
808
|
+
throw new GovernanceError("invalid-resolution", "loser is not loaded");
|
|
561
809
|
}
|
|
562
|
-
|
|
810
|
+
validateConflictPairForResolution(winner, loser);
|
|
811
|
+
}
|
|
812
|
+
}
|
|
813
|
+
function buildEdgeFromSupersession(supersession) {
|
|
814
|
+
return {
|
|
815
|
+
id: randomUUID(),
|
|
816
|
+
schemaVersion: "1",
|
|
817
|
+
fromMemoryId: supersession.oldMemoryId,
|
|
818
|
+
toMemoryId: supersession.newMemoryId,
|
|
819
|
+
kind: supersession.edgeKind,
|
|
820
|
+
createdAt: supersession.supersededAt,
|
|
821
|
+
provenanceSummary: supersession.reason,
|
|
822
|
+
};
|
|
823
|
+
}
|
|
824
|
+
function findMemoryById(memories, id) {
|
|
825
|
+
return memories.find((memory) => memory.id === id);
|
|
826
|
+
}
|
|
827
|
+
function persistConflictTransitions(vault, resolution, reason) {
|
|
828
|
+
for (const transition of resolution.statusTransitions) {
|
|
829
|
+
vault.updateMemory(transition.memoryId, { status: transition.to, staleReason: reason }, transition.transitionedAt);
|
|
830
|
+
}
|
|
831
|
+
}
|
|
832
|
+
function persistConflictSupersessions(vault, deps, memories, supersessions, nowMs) {
|
|
833
|
+
const edgeIds = [];
|
|
834
|
+
for (const supersession of supersessions) {
|
|
835
|
+
const edge = vault.insertEdge(buildEdgeFromSupersession(supersession));
|
|
836
|
+
edgeIds.push(edge.id);
|
|
837
|
+
const loser = findMemoryById(memories, supersession.oldMemoryId);
|
|
838
|
+
const winner = findMemoryById(memories, supersession.newMemoryId);
|
|
839
|
+
if (loser === undefined || winner === undefined)
|
|
840
|
+
continue;
|
|
841
|
+
recordSupersessionAudit(deps, loser, winner, nowMs, "Conflict resolution linked losing memory to the selected winner.");
|
|
842
|
+
}
|
|
843
|
+
return edgeIds;
|
|
844
|
+
}
|
|
845
|
+
function executeConflictResolution(vault, deps, input) {
|
|
846
|
+
const memories = loadConflictMemories(vault, input);
|
|
847
|
+
if (isRouteResult(memories))
|
|
848
|
+
return memories;
|
|
849
|
+
validateConflictResolutionMemories(memories, input);
|
|
850
|
+
const nowMs = Date.now();
|
|
851
|
+
const resolution = buildConflictTransitions(memories, { winner: input.winner, losers: input.losers }, { reviewerId: DEFAULT_REVIEWER_ID, nowMs });
|
|
852
|
+
persistConflictTransitions(vault, resolution, input.reason);
|
|
853
|
+
const edgeIds = persistConflictSupersessions(vault, deps, memories, resolution.supersessions, nowMs);
|
|
854
|
+
return {
|
|
855
|
+
resolved: true,
|
|
856
|
+
winner: input.winner,
|
|
857
|
+
losers: input.losers,
|
|
858
|
+
supersessionEdgeIds: edgeIds,
|
|
859
|
+
transitions: resolution.statusTransitions,
|
|
860
|
+
};
|
|
861
|
+
}
|
|
862
|
+
export async function handleResolveMemoryConflict(ctx, deps) {
|
|
863
|
+
const vault = resolveVault(deps);
|
|
864
|
+
if (isRouteResult(vault))
|
|
865
|
+
return vault;
|
|
866
|
+
const body = await readJsonBody(ctx.req);
|
|
867
|
+
if (isRouteResult(body))
|
|
868
|
+
return body;
|
|
869
|
+
const input = parseConflictResolutionInput(body);
|
|
870
|
+
if (isRouteResult(input))
|
|
871
|
+
return input;
|
|
872
|
+
try {
|
|
873
|
+
const result = executeConflictResolution(vault, deps, input);
|
|
874
|
+
if (isRouteResult(result))
|
|
875
|
+
return result;
|
|
876
|
+
return { status: 200, body: result };
|
|
877
|
+
}
|
|
878
|
+
catch (err) {
|
|
879
|
+
return memoryMutationErrorBody(err, "Failed to resolve conflict.");
|
|
563
880
|
}
|
|
564
881
|
}
|
|
565
882
|
// ─── Handler: POST /api/memory/:id/correct ────────────────────────────────────
|
|
@@ -574,26 +891,74 @@ function parseCorrectInput(raw) {
|
|
|
574
891
|
}
|
|
575
892
|
return { correctedBody };
|
|
576
893
|
}
|
|
577
|
-
function buildCorrectionRecord(
|
|
894
|
+
function buildCorrectionRecord(proposal, id, nowMs) {
|
|
578
895
|
// Note: exactOptionalPropertyTypes is on — omit staleReason rather than assigning undefined.
|
|
579
|
-
|
|
580
|
-
id
|
|
896
|
+
const base = {
|
|
897
|
+
id,
|
|
581
898
|
schemaVersion: "1",
|
|
582
|
-
scope:
|
|
583
|
-
type:
|
|
584
|
-
body:
|
|
585
|
-
provenance:
|
|
586
|
-
|
|
587
|
-
|
|
588
|
-
capturedAt: nowMs,
|
|
589
|
-
},
|
|
590
|
-
validity: existing.validity,
|
|
591
|
-
status: "proposed",
|
|
899
|
+
scope: proposal.scope,
|
|
900
|
+
type: proposal.type,
|
|
901
|
+
body: proposal.body,
|
|
902
|
+
provenance: proposal.provenance,
|
|
903
|
+
validity: proposal.validity,
|
|
904
|
+
status: proposal.initialStatus,
|
|
592
905
|
pinned: false,
|
|
593
|
-
tags:
|
|
906
|
+
tags: proposal.tags,
|
|
594
907
|
createdAt: nowMs,
|
|
595
908
|
updatedAt: nowMs,
|
|
596
909
|
};
|
|
910
|
+
return {
|
|
911
|
+
...base,
|
|
912
|
+
...(proposal.payload === undefined ? {} : { payload: proposal.payload }),
|
|
913
|
+
...(proposal.retentionHint === undefined ? {} : { retentionHint: proposal.retentionHint }),
|
|
914
|
+
};
|
|
915
|
+
}
|
|
916
|
+
function redactString(deps, value) {
|
|
917
|
+
const redacted = deps.redactor(value);
|
|
918
|
+
return typeof redacted === "string" ? redacted : value;
|
|
919
|
+
}
|
|
920
|
+
function recordSupersessionAudit(deps, oldMemory, newMemory, nowMs, summary) {
|
|
921
|
+
const event = {
|
|
922
|
+
schemaVersion: "1",
|
|
923
|
+
kind: "memory:superseded",
|
|
924
|
+
eventId: randomUUID(),
|
|
925
|
+
occurredAt: nowMs,
|
|
926
|
+
initiatorSurface: "memory-center",
|
|
927
|
+
summary,
|
|
928
|
+
oldMemoryId: oldMemory.id,
|
|
929
|
+
newMemoryId: newMemory.id,
|
|
930
|
+
scope: oldMemory.scope,
|
|
931
|
+
};
|
|
932
|
+
recordMemoryAudit({ evidenceStore: deps.evidenceStore, redactString: (value) => redactString(deps, value) }, event);
|
|
933
|
+
}
|
|
934
|
+
function auditEventCountForDay(deps, nowMs) {
|
|
935
|
+
const json = deps.evidenceStore.get(auditRunIdFor(nowMs));
|
|
936
|
+
if (json === undefined) {
|
|
937
|
+
return 0;
|
|
938
|
+
}
|
|
939
|
+
try {
|
|
940
|
+
const parsed = JSON.parse(json);
|
|
941
|
+
return Array.isArray(parsed) ? parsed.length : 0;
|
|
942
|
+
}
|
|
943
|
+
catch {
|
|
944
|
+
return 0;
|
|
945
|
+
}
|
|
946
|
+
}
|
|
947
|
+
function recordCorrectionProposalAuditIfNeeded(deps, inserted, nowMs, countBeforeInsert) {
|
|
948
|
+
if (auditEventCountForDay(deps, nowMs) > countBeforeInsert) {
|
|
949
|
+
return;
|
|
950
|
+
}
|
|
951
|
+
const event = {
|
|
952
|
+
schemaVersion: "1",
|
|
953
|
+
kind: "memory:proposed",
|
|
954
|
+
eventId: randomUUID(),
|
|
955
|
+
occurredAt: nowMs,
|
|
956
|
+
initiatorSurface: "memory-center",
|
|
957
|
+
summary: `memory ${inserted.id} correction proposed`,
|
|
958
|
+
memoryId: inserted.id,
|
|
959
|
+
scope: inserted.scope,
|
|
960
|
+
};
|
|
961
|
+
recordMemoryAudit({ evidenceStore: deps.evidenceStore, redactString: (value) => redactString(deps, value) }, event);
|
|
597
962
|
}
|
|
598
963
|
export async function handleCorrectMemory(ctx, deps) {
|
|
599
964
|
const vault = resolveVault(deps);
|
|
@@ -614,13 +979,28 @@ export async function handleCorrectMemory(ctx, deps) {
|
|
|
614
979
|
if (existing === undefined) {
|
|
615
980
|
return { status: 404, body: errorBody("NOT_FOUND", "Memory not found.") };
|
|
616
981
|
}
|
|
617
|
-
const
|
|
982
|
+
const nowMs = Date.now();
|
|
983
|
+
const correctionId = randomUUID();
|
|
984
|
+
const { proposal, supersession } = buildCorrection({
|
|
985
|
+
olderMemory: existing,
|
|
986
|
+
correctedBody: input.correctedBody,
|
|
987
|
+
context: { reviewerId: DEFAULT_REVIEWER_ID, nowMs },
|
|
988
|
+
newProposalId: randomUUID(),
|
|
989
|
+
newMemoryId: correctionId,
|
|
990
|
+
});
|
|
991
|
+
const auditCountBeforeInsert = auditEventCountForDay(deps, nowMs);
|
|
992
|
+
const inserted = vault.insertMemory(buildCorrectionRecord(proposal, correctionId, nowMs));
|
|
993
|
+
recordCorrectionProposalAuditIfNeeded(deps, inserted, nowMs, auditCountBeforeInsert);
|
|
994
|
+
vault.insertEdge(buildEdgeFromSupersession(supersession));
|
|
618
995
|
return {
|
|
619
996
|
status: 201,
|
|
620
997
|
body: { correction: redactMemory(deps, inserted), originalMemoryId: id },
|
|
621
998
|
};
|
|
622
999
|
}
|
|
623
1000
|
catch (err) {
|
|
1001
|
+
if (err instanceof GovernanceError) {
|
|
1002
|
+
return { status: 400, body: governanceErrorBody(err) };
|
|
1003
|
+
}
|
|
624
1004
|
if (err instanceof MemoryStorageError) {
|
|
625
1005
|
return { status: 500, body: errorBody("MEMORY_ERROR", "Failed to create correction.") };
|
|
626
1006
|
}
|
|
@@ -628,6 +1008,94 @@ export async function handleCorrectMemory(ctx, deps) {
|
|
|
628
1008
|
}
|
|
629
1009
|
}
|
|
630
1010
|
// ─── Handler: POST /api/memory/proposals/:id/accept ───────────────────────────
|
|
1011
|
+
function assertSupersedable(memory) {
|
|
1012
|
+
const check = checkStatusTransition(memory.status, "superseded");
|
|
1013
|
+
if (!check.ok) {
|
|
1014
|
+
throw new GovernanceError("illegal-status-transition", check.reason ?? `illegal transition: ${memory.status} -> superseded`);
|
|
1015
|
+
}
|
|
1016
|
+
}
|
|
1017
|
+
function loadCorrectionSupersessionOrigins(vault, proposal) {
|
|
1018
|
+
if (proposal.type !== "correction")
|
|
1019
|
+
return [];
|
|
1020
|
+
const incomingSupersessions = vault
|
|
1021
|
+
.listIncomingEdges(proposal.id)
|
|
1022
|
+
.filter((edge) => edge.kind === "supersedes");
|
|
1023
|
+
if (incomingSupersessions.length === 0) {
|
|
1024
|
+
throw new GovernanceError("invalid-resolution", "correction proposal requires a supersession origin");
|
|
1025
|
+
}
|
|
1026
|
+
return incomingSupersessions.map((edge) => {
|
|
1027
|
+
const original = vault.getMemory(edge.fromMemoryId);
|
|
1028
|
+
if (original === undefined) {
|
|
1029
|
+
throw new GovernanceError("invalid-resolution", "correction origin memory is missing");
|
|
1030
|
+
}
|
|
1031
|
+
return { edge, original };
|
|
1032
|
+
});
|
|
1033
|
+
}
|
|
1034
|
+
function acceptedCorrectionType(origins) {
|
|
1035
|
+
if (origins.length === 0)
|
|
1036
|
+
return undefined;
|
|
1037
|
+
const first = origins[0]?.original.type;
|
|
1038
|
+
if (first === undefined)
|
|
1039
|
+
return undefined;
|
|
1040
|
+
for (const origin of origins) {
|
|
1041
|
+
if (origin.original.type !== first) {
|
|
1042
|
+
throw new GovernanceError("invalid-resolution", "correction origins must have the same memory type");
|
|
1043
|
+
}
|
|
1044
|
+
assertSupersedable(origin.original);
|
|
1045
|
+
}
|
|
1046
|
+
return first;
|
|
1047
|
+
}
|
|
1048
|
+
function buildAcceptProposalPatch(origins) {
|
|
1049
|
+
const correctionType = acceptedCorrectionType(origins);
|
|
1050
|
+
return correctionType === undefined
|
|
1051
|
+
? { status: "accepted" }
|
|
1052
|
+
: { status: "accepted", type: correctionType };
|
|
1053
|
+
}
|
|
1054
|
+
function buildCorrectionAcceptanceUpdates(proposalId, acceptPatch, origins, nowMs) {
|
|
1055
|
+
return [
|
|
1056
|
+
{ id: proposalId, patch: acceptPatch, nowMs },
|
|
1057
|
+
...origins.map(({ edge, original }) => ({
|
|
1058
|
+
id: original.id,
|
|
1059
|
+
patch: {
|
|
1060
|
+
status: "superseded",
|
|
1061
|
+
staleReason: edge.provenanceSummary ?? "accepted correction",
|
|
1062
|
+
},
|
|
1063
|
+
nowMs,
|
|
1064
|
+
})),
|
|
1065
|
+
];
|
|
1066
|
+
}
|
|
1067
|
+
function recordCorrectionSupersessionAudits(deps, acceptedCorrection, origins, nowMs) {
|
|
1068
|
+
for (const { original } of origins) {
|
|
1069
|
+
recordSupersessionAudit(deps, original, acceptedCorrection, nowMs, "Accepted correction superseded the original memory.");
|
|
1070
|
+
}
|
|
1071
|
+
}
|
|
1072
|
+
function ensureProposedMemory(existing) {
|
|
1073
|
+
if (existing === undefined) {
|
|
1074
|
+
return { status: 404, body: errorBody("NOT_FOUND", "Memory proposal not found.") };
|
|
1075
|
+
}
|
|
1076
|
+
if (existing.status !== "proposed") {
|
|
1077
|
+
return {
|
|
1078
|
+
status: 409,
|
|
1079
|
+
body: errorBody("CONFLICT", "Memory is not in proposed status."),
|
|
1080
|
+
};
|
|
1081
|
+
}
|
|
1082
|
+
return existing;
|
|
1083
|
+
}
|
|
1084
|
+
function acceptMemoryProposal(vault, deps, id) {
|
|
1085
|
+
const existing = ensureProposedMemory(vault.getMemory(id));
|
|
1086
|
+
if (isRouteResult(existing))
|
|
1087
|
+
return existing;
|
|
1088
|
+
const nowMs = Date.now();
|
|
1089
|
+
const origins = loadCorrectionSupersessionOrigins(vault, existing);
|
|
1090
|
+
const acceptPatch = buildAcceptProposalPatch(origins);
|
|
1091
|
+
const updates = buildCorrectionAcceptanceUpdates(id, acceptPatch, origins, nowMs);
|
|
1092
|
+
const [updated] = vault.updateMemories(updates);
|
|
1093
|
+
if (updated === undefined) {
|
|
1094
|
+
throw new GovernanceError("invalid-resolution", "acceptance update produced no records");
|
|
1095
|
+
}
|
|
1096
|
+
recordCorrectionSupersessionAudits(deps, updated, origins, nowMs);
|
|
1097
|
+
return { status: 200, body: { memory: redactMemory(deps, updated) } };
|
|
1098
|
+
}
|
|
631
1099
|
export function handleAcceptMemoryProposal(ctx, deps) {
|
|
632
1100
|
const vault = resolveVault(deps);
|
|
633
1101
|
if (isRouteResult(vault))
|
|
@@ -637,27 +1105,10 @@ export function handleAcceptMemoryProposal(ctx, deps) {
|
|
|
637
1105
|
return { status: 400, body: errorBody("BAD_REQUEST", "Memory id is required.") };
|
|
638
1106
|
}
|
|
639
1107
|
try {
|
|
640
|
-
|
|
641
|
-
if (existing === undefined) {
|
|
642
|
-
return { status: 404, body: errorBody("NOT_FOUND", "Memory proposal not found.") };
|
|
643
|
-
}
|
|
644
|
-
if (existing.status !== "proposed") {
|
|
645
|
-
return {
|
|
646
|
-
status: 409,
|
|
647
|
-
body: errorBody("CONFLICT", "Memory is not in proposed status."),
|
|
648
|
-
};
|
|
649
|
-
}
|
|
650
|
-
const updated = vault.updateMemory(id, { status: "accepted" }, Date.now());
|
|
651
|
-
return { status: 200, body: { memory: redactMemory(deps, updated) } };
|
|
1108
|
+
return acceptMemoryProposal(vault, deps, id);
|
|
652
1109
|
}
|
|
653
1110
|
catch (err) {
|
|
654
|
-
|
|
655
|
-
return {
|
|
656
|
-
status: err.code === "not-found" ? 404 : 500,
|
|
657
|
-
body: errorBody("MEMORY_ERROR", "Failed to accept proposal."),
|
|
658
|
-
};
|
|
659
|
-
}
|
|
660
|
-
throw err;
|
|
1111
|
+
return memoryMutationErrorBody(err, "Failed to accept proposal.");
|
|
661
1112
|
}
|
|
662
1113
|
}
|
|
663
1114
|
// ─── Handler: POST /api/memory/proposals/:id/reject ───────────────────────────
|