nodedex 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/adapters/claude-code-watcher.mjs +336 -0
- package/adapters/hermes-statedb-watcher.mjs +234 -0
- package/adapters/nodedex-capture-core.mjs +129 -0
- package/adapters/nodedex-capture.mjs +169 -0
- package/dist/agent-protocol.d.ts +7 -0
- package/dist/agent-protocol.d.ts.map +1 -0
- package/dist/agent-protocol.js +38 -0
- package/dist/agent-protocol.js.map +1 -0
- package/dist/api-server.d.ts +5 -0
- package/dist/api-server.d.ts.map +1 -0
- package/dist/api-server.js +351 -0
- package/dist/api-server.js.map +1 -0
- package/dist/boot-env.d.ts +2 -0
- package/dist/boot-env.d.ts.map +1 -0
- package/dist/boot-env.js +12 -0
- package/dist/boot-env.js.map +1 -0
- package/dist/engine/__tests__/search-core.test.d.ts +2 -0
- package/dist/engine/__tests__/search-core.test.d.ts.map +1 -0
- package/dist/engine/__tests__/search-core.test.js +139 -0
- package/dist/engine/__tests__/search-core.test.js.map +1 -0
- package/dist/engine/ai-provider.d.ts +45 -0
- package/dist/engine/ai-provider.d.ts.map +1 -0
- package/dist/engine/ai-provider.js +5 -0
- package/dist/engine/ai-provider.js.map +1 -0
- package/dist/engine/embeddings.d.ts +51 -0
- package/dist/engine/embeddings.d.ts.map +1 -0
- package/dist/engine/embeddings.js +89 -0
- package/dist/engine/embeddings.js.map +1 -0
- package/dist/engine/providers/__tests__/failure-policy.test.d.ts +2 -0
- package/dist/engine/providers/__tests__/failure-policy.test.d.ts.map +1 -0
- package/dist/engine/providers/__tests__/failure-policy.test.js +134 -0
- package/dist/engine/providers/__tests__/failure-policy.test.js.map +1 -0
- package/dist/engine/providers/__tests__/model-caps.test.d.ts +2 -0
- package/dist/engine/providers/__tests__/model-caps.test.d.ts.map +1 -0
- package/dist/engine/providers/__tests__/model-caps.test.js +38 -0
- package/dist/engine/providers/__tests__/model-caps.test.js.map +1 -0
- package/dist/engine/providers/__tests__/openai-structured.test.d.ts +2 -0
- package/dist/engine/providers/__tests__/openai-structured.test.d.ts.map +1 -0
- package/dist/engine/providers/__tests__/openai-structured.test.js +73 -0
- package/dist/engine/providers/__tests__/openai-structured.test.js.map +1 -0
- package/dist/engine/providers/__tests__/usage-ledger.test.d.ts +2 -0
- package/dist/engine/providers/__tests__/usage-ledger.test.d.ts.map +1 -0
- package/dist/engine/providers/__tests__/usage-ledger.test.js +108 -0
- package/dist/engine/providers/__tests__/usage-ledger.test.js.map +1 -0
- package/dist/engine/providers/anthropic.d.ts +17 -0
- package/dist/engine/providers/anthropic.d.ts.map +1 -0
- package/dist/engine/providers/anthropic.js +125 -0
- package/dist/engine/providers/anthropic.js.map +1 -0
- package/dist/engine/providers/failure-policy.d.ts +56 -0
- package/dist/engine/providers/failure-policy.d.ts.map +1 -0
- package/dist/engine/providers/failure-policy.js +120 -0
- package/dist/engine/providers/failure-policy.js.map +1 -0
- package/dist/engine/providers/gemini.d.ts +22 -0
- package/dist/engine/providers/gemini.d.ts.map +1 -0
- package/dist/engine/providers/gemini.js +180 -0
- package/dist/engine/providers/gemini.js.map +1 -0
- package/dist/engine/providers/index.d.ts +8 -0
- package/dist/engine/providers/index.d.ts.map +1 -0
- package/dist/engine/providers/index.js +67 -0
- package/dist/engine/providers/index.js.map +1 -0
- package/dist/engine/providers/local.d.ts +12 -0
- package/dist/engine/providers/local.d.ts.map +1 -0
- package/dist/engine/providers/local.js +46 -0
- package/dist/engine/providers/local.js.map +1 -0
- package/dist/engine/providers/model-caps.d.ts +6 -0
- package/dist/engine/providers/model-caps.d.ts.map +1 -0
- package/dist/engine/providers/model-caps.js +49 -0
- package/dist/engine/providers/model-caps.js.map +1 -0
- package/dist/engine/providers/openai.d.ts +30 -0
- package/dist/engine/providers/openai.d.ts.map +1 -0
- package/dist/engine/providers/openai.js +309 -0
- package/dist/engine/providers/openai.js.map +1 -0
- package/dist/engine/providers/usage-ledger.d.ts +69 -0
- package/dist/engine/providers/usage-ledger.d.ts.map +1 -0
- package/dist/engine/providers/usage-ledger.js +209 -0
- package/dist/engine/providers/usage-ledger.js.map +1 -0
- package/dist/engine/search-core.d.ts +40 -0
- package/dist/engine/search-core.d.ts.map +1 -0
- package/dist/engine/search-core.js +109 -0
- package/dist/engine/search-core.js.map +1 -0
- package/dist/engine/vector-math.d.ts +5 -0
- package/dist/engine/vector-math.d.ts.map +1 -0
- package/dist/engine/vector-math.js +25 -0
- package/dist/engine/vector-math.js.map +1 -0
- package/dist/home-env.d.ts +26 -0
- package/dist/home-env.d.ts.map +1 -0
- package/dist/home-env.js +87 -0
- package/dist/home-env.js.map +1 -0
- package/dist/mcp-server.d.ts +13 -0
- package/dist/mcp-server.d.ts.map +1 -0
- package/dist/mcp-server.js +79 -0
- package/dist/mcp-server.js.map +1 -0
- package/dist/middleware/auth.d.ts +23 -0
- package/dist/middleware/auth.d.ts.map +1 -0
- package/dist/middleware/auth.js +104 -0
- package/dist/middleware/auth.js.map +1 -0
- package/dist/middleware/auto-recall.d.ts +7 -0
- package/dist/middleware/auto-recall.d.ts.map +1 -0
- package/dist/middleware/auto-recall.js +257 -0
- package/dist/middleware/auto-recall.js.map +1 -0
- package/dist/middleware/auto-reflect.d.ts +4 -0
- package/dist/middleware/auto-reflect.d.ts.map +1 -0
- package/dist/middleware/auto-reflect.js +5 -0
- package/dist/middleware/auto-reflect.js.map +1 -0
- package/dist/middleware/reflect/apply-flag-verdict.d.ts +27 -0
- package/dist/middleware/reflect/apply-flag-verdict.d.ts.map +1 -0
- package/dist/middleware/reflect/apply-flag-verdict.js +57 -0
- package/dist/middleware/reflect/apply-flag-verdict.js.map +1 -0
- package/dist/middleware/reflect/arc-entity-resolve.d.ts +29 -0
- package/dist/middleware/reflect/arc-entity-resolve.d.ts.map +1 -0
- package/dist/middleware/reflect/arc-entity-resolve.js +356 -0
- package/dist/middleware/reflect/arc-entity-resolve.js.map +1 -0
- package/dist/middleware/reflect/arc-inactivity-timer.d.ts +47 -0
- package/dist/middleware/reflect/arc-inactivity-timer.d.ts.map +1 -0
- package/dist/middleware/reflect/arc-inactivity-timer.js +175 -0
- package/dist/middleware/reflect/arc-inactivity-timer.js.map +1 -0
- package/dist/middleware/reflect/arc-pipeline.d.ts +33 -0
- package/dist/middleware/reflect/arc-pipeline.d.ts.map +1 -0
- package/dist/middleware/reflect/arc-pipeline.js +498 -0
- package/dist/middleware/reflect/arc-pipeline.js.map +1 -0
- package/dist/middleware/reflect/comprehend-pergroup.d.ts +100 -0
- package/dist/middleware/reflect/comprehend-pergroup.d.ts.map +1 -0
- package/dist/middleware/reflect/comprehend-pergroup.js +610 -0
- package/dist/middleware/reflect/comprehend-pergroup.js.map +1 -0
- package/dist/middleware/reflect/comprehend.d.ts +237 -0
- package/dist/middleware/reflect/comprehend.d.ts.map +1 -0
- package/dist/middleware/reflect/comprehend.js +706 -0
- package/dist/middleware/reflect/comprehend.js.map +1 -0
- package/dist/middleware/reflect/config.d.ts +34 -0
- package/dist/middleware/reflect/config.d.ts.map +1 -0
- package/dist/middleware/reflect/config.js +131 -0
- package/dist/middleware/reflect/config.js.map +1 -0
- package/dist/middleware/reflect/context.d.ts +138 -0
- package/dist/middleware/reflect/context.d.ts.map +1 -0
- package/dist/middleware/reflect/context.js +619 -0
- package/dist/middleware/reflect/context.js.map +1 -0
- package/dist/middleware/reflect/cost-breakdown.d.ts +69 -0
- package/dist/middleware/reflect/cost-breakdown.d.ts.map +1 -0
- package/dist/middleware/reflect/cost-breakdown.js +63 -0
- package/dist/middleware/reflect/cost-breakdown.js.map +1 -0
- package/dist/middleware/reflect/cost-guard.d.ts +102 -0
- package/dist/middleware/reflect/cost-guard.d.ts.map +1 -0
- package/dist/middleware/reflect/cost-guard.js +243 -0
- package/dist/middleware/reflect/cost-guard.js.map +1 -0
- package/dist/middleware/reflect/cost-pricing.d.ts +54 -0
- package/dist/middleware/reflect/cost-pricing.d.ts.map +1 -0
- package/dist/middleware/reflect/cost-pricing.js +148 -0
- package/dist/middleware/reflect/cost-pricing.js.map +1 -0
- package/dist/middleware/reflect/cross-group-link.d.ts +61 -0
- package/dist/middleware/reflect/cross-group-link.d.ts.map +1 -0
- package/dist/middleware/reflect/cross-group-link.js +212 -0
- package/dist/middleware/reflect/cross-group-link.js.map +1 -0
- package/dist/middleware/reflect/dedup-by-source-and-value.d.ts +70 -0
- package/dist/middleware/reflect/dedup-by-source-and-value.d.ts.map +1 -0
- package/dist/middleware/reflect/dedup-by-source-and-value.js +0 -0
- package/dist/middleware/reflect/dedup-by-source-and-value.js.map +1 -0
- package/dist/middleware/reflect/describe-roots.d.ts +58 -0
- package/dist/middleware/reflect/describe-roots.d.ts.map +1 -0
- package/dist/middleware/reflect/describe-roots.js +266 -0
- package/dist/middleware/reflect/describe-roots.js.map +1 -0
- package/dist/middleware/reflect/flag-reviewer-startup.d.ts +16 -0
- package/dist/middleware/reflect/flag-reviewer-startup.d.ts.map +1 -0
- package/dist/middleware/reflect/flag-reviewer-startup.js +107 -0
- package/dist/middleware/reflect/flag-reviewer-startup.js.map +1 -0
- package/dist/middleware/reflect/flag-reviewer.d.ts +69 -0
- package/dist/middleware/reflect/flag-reviewer.d.ts.map +1 -0
- package/dist/middleware/reflect/flag-reviewer.js +520 -0
- package/dist/middleware/reflect/flag-reviewer.js.map +1 -0
- package/dist/middleware/reflect/inline-dedup.d.ts +26 -0
- package/dist/middleware/reflect/inline-dedup.d.ts.map +1 -0
- package/dist/middleware/reflect/inline-dedup.js +131 -0
- package/dist/middleware/reflect/inline-dedup.js.map +1 -0
- package/dist/middleware/reflect/justify-decisions.d.ts +37 -0
- package/dist/middleware/reflect/justify-decisions.d.ts.map +1 -0
- package/dist/middleware/reflect/justify-decisions.js +159 -0
- package/dist/middleware/reflect/justify-decisions.js.map +1 -0
- package/dist/middleware/reflect/nl-accept.d.ts +35 -0
- package/dist/middleware/reflect/nl-accept.d.ts.map +1 -0
- package/dist/middleware/reflect/nl-accept.js +167 -0
- package/dist/middleware/reflect/nl-accept.js.map +1 -0
- package/dist/middleware/reflect/pass0.d.ts +20 -0
- package/dist/middleware/reflect/pass0.d.ts.map +1 -0
- package/dist/middleware/reflect/pass0.js +423 -0
- package/dist/middleware/reflect/pass0.js.map +1 -0
- package/dist/middleware/reflect/pass1.d.ts +17 -0
- package/dist/middleware/reflect/pass1.d.ts.map +1 -0
- package/dist/middleware/reflect/pass1.js +241 -0
- package/dist/middleware/reflect/pass1.js.map +1 -0
- package/dist/middleware/reflect/pass2-quarantine.d.ts +129 -0
- package/dist/middleware/reflect/pass2-quarantine.d.ts.map +1 -0
- package/dist/middleware/reflect/pass2-quarantine.js +272 -0
- package/dist/middleware/reflect/pass2-quarantine.js.map +1 -0
- package/dist/middleware/reflect/pass2-seams.d.ts +205 -0
- package/dist/middleware/reflect/pass2-seams.d.ts.map +1 -0
- package/dist/middleware/reflect/pass2-seams.js +279 -0
- package/dist/middleware/reflect/pass2-seams.js.map +1 -0
- package/dist/middleware/reflect/pass2-split-orchestrator.d.ts +37 -0
- package/dist/middleware/reflect/pass2-split-orchestrator.d.ts.map +1 -0
- package/dist/middleware/reflect/pass2-split-orchestrator.js +531 -0
- package/dist/middleware/reflect/pass2-split-orchestrator.js.map +1 -0
- package/dist/middleware/reflect/pass2.d.ts +17 -0
- package/dist/middleware/reflect/pass2.d.ts.map +1 -0
- package/dist/middleware/reflect/pass2.js +324 -0
- package/dist/middleware/reflect/pass2.js.map +1 -0
- package/dist/middleware/reflect/pass2a.d.ts +141 -0
- package/dist/middleware/reflect/pass2a.d.ts.map +1 -0
- package/dist/middleware/reflect/pass2a.js +404 -0
- package/dist/middleware/reflect/pass2a.js.map +1 -0
- package/dist/middleware/reflect/pass2b.d.ts +108 -0
- package/dist/middleware/reflect/pass2b.d.ts.map +1 -0
- package/dist/middleware/reflect/pass2b.js +480 -0
- package/dist/middleware/reflect/pass2b.js.map +1 -0
- package/dist/middleware/reflect/pass2c.d.ts +113 -0
- package/dist/middleware/reflect/pass2c.d.ts.map +1 -0
- package/dist/middleware/reflect/pass2c.js +360 -0
- package/dist/middleware/reflect/pass2c.js.map +1 -0
- package/dist/middleware/reflect/pass3-batch.d.ts +62 -0
- package/dist/middleware/reflect/pass3-batch.d.ts.map +1 -0
- package/dist/middleware/reflect/pass3-batch.js +139 -0
- package/dist/middleware/reflect/pass3-batch.js.map +1 -0
- package/dist/middleware/reflect/pass3.d.ts +23 -0
- package/dist/middleware/reflect/pass3.d.ts.map +1 -0
- package/dist/middleware/reflect/pass3.js +371 -0
- package/dist/middleware/reflect/pass3.js.map +1 -0
- package/dist/middleware/reflect/pass4-slice.d.ts +25 -0
- package/dist/middleware/reflect/pass4-slice.d.ts.map +1 -0
- package/dist/middleware/reflect/pass4-slice.js +315 -0
- package/dist/middleware/reflect/pass4-slice.js.map +1 -0
- package/dist/middleware/reflect/pass4.d.ts +30 -0
- package/dist/middleware/reflect/pass4.d.ts.map +1 -0
- package/dist/middleware/reflect/pass4.js +193 -0
- package/dist/middleware/reflect/pass4.js.map +1 -0
- package/dist/middleware/reflect/pass5.d.ts +22 -0
- package/dist/middleware/reflect/pass5.d.ts.map +1 -0
- package/dist/middleware/reflect/pass5.js +178 -0
- package/dist/middleware/reflect/pass5.js.map +1 -0
- package/dist/middleware/reflect/pass_judge.d.ts +44 -0
- package/dist/middleware/reflect/pass_judge.d.ts.map +1 -0
- package/dist/middleware/reflect/pass_judge.js +263 -0
- package/dist/middleware/reflect/pass_judge.js.map +1 -0
- package/dist/middleware/reflect/pipeline-flags.d.ts +140 -0
- package/dist/middleware/reflect/pipeline-flags.d.ts.map +1 -0
- package/dist/middleware/reflect/pipeline-flags.js +314 -0
- package/dist/middleware/reflect/pipeline-flags.js.map +1 -0
- package/dist/middleware/reflect/pipeline.d.ts +237 -0
- package/dist/middleware/reflect/pipeline.d.ts.map +1 -0
- package/dist/middleware/reflect/pipeline.js +3114 -0
- package/dist/middleware/reflect/pipeline.js.map +1 -0
- package/dist/middleware/reflect/promptOverride.d.ts +14 -0
- package/dist/middleware/reflect/promptOverride.d.ts.map +1 -0
- package/dist/middleware/reflect/promptOverride.js +28 -0
- package/dist/middleware/reflect/promptOverride.js.map +1 -0
- package/dist/middleware/reflect/provenance-check.d.ts +48 -0
- package/dist/middleware/reflect/provenance-check.d.ts.map +1 -0
- package/dist/middleware/reflect/provenance-check.js +180 -0
- package/dist/middleware/reflect/provenance-check.js.map +1 -0
- package/dist/middleware/reflect/provenance-reviewer.d.ts +52 -0
- package/dist/middleware/reflect/provenance-reviewer.d.ts.map +1 -0
- package/dist/middleware/reflect/provenance-reviewer.js +253 -0
- package/dist/middleware/reflect/provenance-reviewer.js.map +1 -0
- package/dist/middleware/reflect/prune-collapsed-types.d.ts +11 -0
- package/dist/middleware/reflect/prune-collapsed-types.d.ts.map +1 -0
- package/dist/middleware/reflect/prune-collapsed-types.js +32 -0
- package/dist/middleware/reflect/prune-collapsed-types.js.map +1 -0
- package/dist/middleware/reflect/recognize-root.d.ts +75 -0
- package/dist/middleware/reflect/recognize-root.d.ts.map +1 -0
- package/dist/middleware/reflect/recognize-root.js +204 -0
- package/dist/middleware/reflect/recognize-root.js.map +1 -0
- package/dist/middleware/reflect/render-agent-flag.d.ts +25 -0
- package/dist/middleware/reflect/render-agent-flag.d.ts.map +1 -0
- package/dist/middleware/reflect/render-agent-flag.js +39 -0
- package/dist/middleware/reflect/render-agent-flag.js.map +1 -0
- package/dist/middleware/reflect/retrieve-graph-slice.d.ts +54 -0
- package/dist/middleware/reflect/retrieve-graph-slice.d.ts.map +1 -0
- package/dist/middleware/reflect/retrieve-graph-slice.js +173 -0
- package/dist/middleware/reflect/retrieve-graph-slice.js.map +1 -0
- package/dist/middleware/reflect/root-relatedness.d.ts +31 -0
- package/dist/middleware/reflect/root-relatedness.d.ts.map +1 -0
- package/dist/middleware/reflect/root-relatedness.js +92 -0
- package/dist/middleware/reflect/root-relatedness.js.map +1 -0
- package/dist/middleware/reflect/schema-heal.d.ts +22 -0
- package/dist/middleware/reflect/schema-heal.d.ts.map +1 -0
- package/dist/middleware/reflect/schema-heal.js +119 -0
- package/dist/middleware/reflect/schema-heal.js.map +1 -0
- package/dist/middleware/reflect/schema-validator.d.ts +85 -0
- package/dist/middleware/reflect/schema-validator.d.ts.map +1 -0
- package/dist/middleware/reflect/schema-validator.js +196 -0
- package/dist/middleware/reflect/schema-validator.js.map +1 -0
- package/dist/middleware/reflect/stage-audit-graph.d.ts +115 -0
- package/dist/middleware/reflect/stage-audit-graph.d.ts.map +1 -0
- package/dist/middleware/reflect/stage-audit-graph.js +563 -0
- package/dist/middleware/reflect/stage-audit-graph.js.map +1 -0
- package/dist/middleware/reflect/stage-d-resolve-graph.d.ts +87 -0
- package/dist/middleware/reflect/stage-d-resolve-graph.d.ts.map +1 -0
- package/dist/middleware/reflect/stage-d-resolve-graph.js +256 -0
- package/dist/middleware/reflect/stage-d-resolve-graph.js.map +1 -0
- package/dist/middleware/reflect/synthesizeFromSceneCard.d.ts +15 -0
- package/dist/middleware/reflect/synthesizeFromSceneCard.d.ts.map +1 -0
- package/dist/middleware/reflect/synthesizeFromSceneCard.js +91 -0
- package/dist/middleware/reflect/synthesizeFromSceneCard.js.map +1 -0
- package/dist/middleware/reflect/types.d.ts +261 -0
- package/dist/middleware/reflect/types.d.ts.map +1 -0
- package/dist/middleware/reflect/types.js +3 -0
- package/dist/middleware/reflect/types.js.map +1 -0
- package/dist/middleware/reflect/v2-integrate.d.ts +120 -0
- package/dist/middleware/reflect/v2-integrate.d.ts.map +1 -0
- package/dist/middleware/reflect/v2-integrate.js +388 -0
- package/dist/middleware/reflect/v2-integrate.js.map +1 -0
- package/dist/middleware/reflect/v2-judge.d.ts +44 -0
- package/dist/middleware/reflect/v2-judge.d.ts.map +1 -0
- package/dist/middleware/reflect/v2-judge.js +191 -0
- package/dist/middleware/reflect/v2-judge.js.map +1 -0
- package/dist/relation-sets.d.ts +2 -0
- package/dist/relation-sets.d.ts.map +1 -0
- package/dist/relation-sets.js +35 -0
- package/dist/relation-sets.js.map +1 -0
- package/dist/routes/__tests__/flags.test.d.ts +2 -0
- package/dist/routes/__tests__/flags.test.d.ts.map +1 -0
- package/dist/routes/__tests__/flags.test.js +257 -0
- package/dist/routes/__tests__/flags.test.js.map +1 -0
- package/dist/routes/__tests__/models-catalog.test.d.ts +2 -0
- package/dist/routes/__tests__/models-catalog.test.d.ts.map +1 -0
- package/dist/routes/__tests__/models-catalog.test.js +130 -0
- package/dist/routes/__tests__/models-catalog.test.js.map +1 -0
- package/dist/routes/__tests__/reflect-pause-drain.test.d.ts +2 -0
- package/dist/routes/__tests__/reflect-pause-drain.test.d.ts.map +1 -0
- package/dist/routes/__tests__/reflect-pause-drain.test.js +38 -0
- package/dist/routes/__tests__/reflect-pause-drain.test.js.map +1 -0
- package/dist/routes/__tests__/spend-pause-drain.test.d.ts +2 -0
- package/dist/routes/__tests__/spend-pause-drain.test.d.ts.map +1 -0
- package/dist/routes/__tests__/spend-pause-drain.test.js +38 -0
- package/dist/routes/__tests__/spend-pause-drain.test.js.map +1 -0
- package/dist/routes/admin.d.ts +49 -0
- package/dist/routes/admin.d.ts.map +1 -0
- package/dist/routes/admin.js +471 -0
- package/dist/routes/admin.js.map +1 -0
- package/dist/routes/blocks.d.ts +4 -0
- package/dist/routes/blocks.d.ts.map +1 -0
- package/dist/routes/blocks.js +893 -0
- package/dist/routes/blocks.js.map +1 -0
- package/dist/routes/chat-proxy.d.ts +5 -0
- package/dist/routes/chat-proxy.d.ts.map +1 -0
- package/dist/routes/chat-proxy.js +225 -0
- package/dist/routes/chat-proxy.js.map +1 -0
- package/dist/routes/conversations.d.ts +4 -0
- package/dist/routes/conversations.d.ts.map +1 -0
- package/dist/routes/conversations.js +139 -0
- package/dist/routes/conversations.js.map +1 -0
- package/dist/routes/flags.d.ts +4 -0
- package/dist/routes/flags.d.ts.map +1 -0
- package/dist/routes/flags.js +151 -0
- package/dist/routes/flags.js.map +1 -0
- package/dist/routes/inject.d.ts +4 -0
- package/dist/routes/inject.d.ts.map +1 -0
- package/dist/routes/inject.js +183 -0
- package/dist/routes/inject.js.map +1 -0
- package/dist/routes/mcp-http.d.ts +5 -0
- package/dist/routes/mcp-http.d.ts.map +1 -0
- package/dist/routes/mcp-http.js +94 -0
- package/dist/routes/mcp-http.js.map +1 -0
- package/dist/routes/quarantine.d.ts +4 -0
- package/dist/routes/quarantine.d.ts.map +1 -0
- package/dist/routes/quarantine.js +66 -0
- package/dist/routes/quarantine.js.map +1 -0
- package/dist/routes/recall.d.ts +5 -0
- package/dist/routes/recall.d.ts.map +1 -0
- package/dist/routes/recall.js +573 -0
- package/dist/routes/recall.js.map +1 -0
- package/dist/routes/reflect.d.ts +5 -0
- package/dist/routes/reflect.d.ts.map +1 -0
- package/dist/routes/reflect.js +231 -0
- package/dist/routes/reflect.js.map +1 -0
- package/dist/routes/session.d.ts +4 -0
- package/dist/routes/session.d.ts.map +1 -0
- package/dist/routes/session.js +418 -0
- package/dist/routes/session.js.map +1 -0
- package/dist/routes/state.d.ts +116 -0
- package/dist/routes/state.d.ts.map +1 -0
- package/dist/routes/state.js +621 -0
- package/dist/routes/state.js.map +1 -0
- package/dist/routes/usage.d.ts +3 -0
- package/dist/routes/usage.d.ts.map +1 -0
- package/dist/routes/usage.js +141 -0
- package/dist/routes/usage.js.map +1 -0
- package/dist/routes/workspace.d.ts +5 -0
- package/dist/routes/workspace.d.ts.map +1 -0
- package/dist/routes/workspace.js +435 -0
- package/dist/routes/workspace.js.map +1 -0
- package/dist/server.d.ts +13 -0
- package/dist/server.d.ts.map +1 -0
- package/dist/server.js +298 -0
- package/dist/server.js.map +1 -0
- package/dist/store/__tests__/backup.test.d.ts +2 -0
- package/dist/store/__tests__/backup.test.d.ts.map +1 -0
- package/dist/store/__tests__/backup.test.js +53 -0
- package/dist/store/__tests__/backup.test.js.map +1 -0
- package/dist/store/__tests__/quality.test.d.ts +2 -0
- package/dist/store/__tests__/quality.test.d.ts.map +1 -0
- package/dist/store/__tests__/quality.test.js +75 -0
- package/dist/store/__tests__/quality.test.js.map +1 -0
- package/dist/store/backup.d.ts +14 -0
- package/dist/store/backup.d.ts.map +1 -0
- package/dist/store/backup.js +95 -0
- package/dist/store/backup.js.map +1 -0
- package/dist/store/database.d.ts +407 -0
- package/dist/store/database.d.ts.map +1 -0
- package/dist/store/database.js +2004 -0
- package/dist/store/database.js.map +1 -0
- package/dist/store/quality.d.ts +25 -0
- package/dist/store/quality.d.ts.map +1 -0
- package/dist/store/quality.js +48 -0
- package/dist/store/quality.js.map +1 -0
- package/dist/tools/__tests__/assemble-block-chains.test.d.ts +2 -0
- package/dist/tools/__tests__/assemble-block-chains.test.d.ts.map +1 -0
- package/dist/tools/__tests__/assemble-block-chains.test.js +118 -0
- package/dist/tools/__tests__/assemble-block-chains.test.js.map +1 -0
- package/dist/tools/__tests__/filter-roots-by-concepts.test.d.ts +2 -0
- package/dist/tools/__tests__/filter-roots-by-concepts.test.d.ts.map +1 -0
- package/dist/tools/__tests__/filter-roots-by-concepts.test.js +68 -0
- package/dist/tools/__tests__/filter-roots-by-concepts.test.js.map +1 -0
- package/dist/tools/__tests__/flag-surface.test.d.ts +2 -0
- package/dist/tools/__tests__/flag-surface.test.d.ts.map +1 -0
- package/dist/tools/__tests__/flag-surface.test.js +130 -0
- package/dist/tools/__tests__/flag-surface.test.js.map +1 -0
- package/dist/tools/core.d.ts +5 -0
- package/dist/tools/core.d.ts.map +1 -0
- package/dist/tools/core.js +962 -0
- package/dist/tools/core.js.map +1 -0
- package/dist/tools/derive.d.ts +5 -0
- package/dist/tools/derive.d.ts.map +1 -0
- package/dist/tools/derive.js +182 -0
- package/dist/tools/derive.js.map +1 -0
- package/dist/tools/flag-surface.d.ts +26 -0
- package/dist/tools/flag-surface.d.ts.map +1 -0
- package/dist/tools/flag-surface.js +59 -0
- package/dist/tools/flag-surface.js.map +1 -0
- package/dist/tools/helpers.d.ts +99 -0
- package/dist/tools/helpers.d.ts.map +1 -0
- package/dist/tools/helpers.js +243 -0
- package/dist/tools/helpers.js.map +1 -0
- package/dist/tools/projects.d.ts +5 -0
- package/dist/tools/projects.d.ts.map +1 -0
- package/dist/tools/projects.js +175 -0
- package/dist/tools/projects.js.map +1 -0
- package/dist/tools/system.d.ts +5 -0
- package/dist/tools/system.d.ts.map +1 -0
- package/dist/tools/system.js +1361 -0
- package/dist/tools/system.js.map +1 -0
- package/dist/tools/tasks.d.ts +5 -0
- package/dist/tools/tasks.d.ts.map +1 -0
- package/dist/tools/tasks.js +289 -0
- package/dist/tools/tasks.js.map +1 -0
- package/package.json +69 -0
- package/scripts/nodedex-entry.mjs +396 -0
- package/tui-dist/App.js +185 -0
- package/tui-dist/api.js +197 -0
- package/tui-dist/cli.js +53 -0
- package/tui-dist/components.js +63 -0
- package/tui-dist/config.js +242 -0
- package/tui-dist/connect-snippets.js +98 -0
- package/tui-dist/feed.js +51 -0
- package/tui-dist/health.js +465 -0
- package/tui-dist/hooks.js +23 -0
- package/tui-dist/memory.js +220 -0
- package/tui-dist/onboarding.js +498 -0
- package/tui-dist/review.js +193 -0
- package/tui-dist/servers.js +556 -0
- package/tui-dist/smoke.js +15 -0
- package/tui-dist/theme.js +106 -0
|
@@ -0,0 +1,261 @@
|
|
|
1
|
+
export interface Pass0Result {
|
|
2
|
+
input_type: string;
|
|
3
|
+
projects: Array<{
|
|
4
|
+
name: string;
|
|
5
|
+
scope: string;
|
|
6
|
+
}>;
|
|
7
|
+
scope_project: {
|
|
8
|
+
name: string;
|
|
9
|
+
scope: string;
|
|
10
|
+
};
|
|
11
|
+
people: Array<{
|
|
12
|
+
name: string;
|
|
13
|
+
role: string;
|
|
14
|
+
signal_type: string;
|
|
15
|
+
}>;
|
|
16
|
+
actor_actions: Array<{
|
|
17
|
+
actor: string;
|
|
18
|
+
action: string;
|
|
19
|
+
object: string;
|
|
20
|
+
outcome?: string;
|
|
21
|
+
}>;
|
|
22
|
+
technologies: Array<{
|
|
23
|
+
name: string;
|
|
24
|
+
project?: string;
|
|
25
|
+
context?: string;
|
|
26
|
+
}>;
|
|
27
|
+
in_flight: string[];
|
|
28
|
+
causal_links: Array<{
|
|
29
|
+
cause: string;
|
|
30
|
+
effect: string;
|
|
31
|
+
}>;
|
|
32
|
+
replacements: Array<{
|
|
33
|
+
predecessor: string;
|
|
34
|
+
replacement: string;
|
|
35
|
+
function: string;
|
|
36
|
+
}>;
|
|
37
|
+
unchanged: string[];
|
|
38
|
+
scene_card_reasoning?: string;
|
|
39
|
+
}
|
|
40
|
+
export interface Pass1Item {
|
|
41
|
+
id: string;
|
|
42
|
+
text: string;
|
|
43
|
+
source: string;
|
|
44
|
+
excerpt: string;
|
|
45
|
+
provisional_type: string;
|
|
46
|
+
extends_id?: string;
|
|
47
|
+
uncertain?: boolean;
|
|
48
|
+
extraction_reasoning?: string;
|
|
49
|
+
}
|
|
50
|
+
export interface Pass1Result {
|
|
51
|
+
items: Pass1Item[];
|
|
52
|
+
}
|
|
53
|
+
export interface Pass2Item {
|
|
54
|
+
id: string;
|
|
55
|
+
text: string;
|
|
56
|
+
type: string;
|
|
57
|
+
project?: string;
|
|
58
|
+
unique?: Record<string, string>;
|
|
59
|
+
schema?: Record<string, string>;
|
|
60
|
+
triggered_by_items: string[];
|
|
61
|
+
based_on_items: string[];
|
|
62
|
+
extends_item?: string;
|
|
63
|
+
supersedes_ref?: string;
|
|
64
|
+
resolved_ref?: string;
|
|
65
|
+
relations?: Array<{
|
|
66
|
+
type: string;
|
|
67
|
+
target: string;
|
|
68
|
+
reasoning?: string;
|
|
69
|
+
}>;
|
|
70
|
+
note?: string;
|
|
71
|
+
review_reason?: string;
|
|
72
|
+
classification_reasoning?: string;
|
|
73
|
+
keep_reason?: string;
|
|
74
|
+
type_reasoning?: string;
|
|
75
|
+
source_type?: string;
|
|
76
|
+
excerpt?: string;
|
|
77
|
+
}
|
|
78
|
+
export interface Pass2CausalWiring {
|
|
79
|
+
item_id: string;
|
|
80
|
+
triggered_by: string[];
|
|
81
|
+
based_on: string[];
|
|
82
|
+
}
|
|
83
|
+
export interface Pass2Result {
|
|
84
|
+
skipped: Array<{
|
|
85
|
+
id: string;
|
|
86
|
+
reason: string;
|
|
87
|
+
}>;
|
|
88
|
+
classified: Pass2Item[];
|
|
89
|
+
causal_wiring?: Pass2CausalWiring[];
|
|
90
|
+
}
|
|
91
|
+
export interface Pass5Chain {
|
|
92
|
+
chain_label: string;
|
|
93
|
+
chain_essence: string;
|
|
94
|
+
arc: string;
|
|
95
|
+
conclusion: string;
|
|
96
|
+
members: string[];
|
|
97
|
+
reasoning: string;
|
|
98
|
+
}
|
|
99
|
+
export interface Pass5Result {
|
|
100
|
+
chains: Pass5Chain[];
|
|
101
|
+
}
|
|
102
|
+
export interface ArcEntityMention {
|
|
103
|
+
turn_id: string;
|
|
104
|
+
turn_number: number;
|
|
105
|
+
scope_project_name: string;
|
|
106
|
+
item_ids: string[];
|
|
107
|
+
}
|
|
108
|
+
export interface ArcEntityCluster {
|
|
109
|
+
canonical_name: string;
|
|
110
|
+
mentions: ArcEntityMention[];
|
|
111
|
+
evidence: {
|
|
112
|
+
shared_technologies: string[];
|
|
113
|
+
shared_entities: string[];
|
|
114
|
+
shared_concepts: string[];
|
|
115
|
+
};
|
|
116
|
+
reasoning: string;
|
|
117
|
+
}
|
|
118
|
+
export interface ArcEntityResolveResult {
|
|
119
|
+
clusters: ArcEntityCluster[];
|
|
120
|
+
unresolved_mentions?: ArcEntityMention[];
|
|
121
|
+
arc_resolve_reasoning?: string;
|
|
122
|
+
model?: string;
|
|
123
|
+
attempts?: Array<{
|
|
124
|
+
model: string;
|
|
125
|
+
outcome: string;
|
|
126
|
+
}>;
|
|
127
|
+
}
|
|
128
|
+
export type PipelineFlagType = 'project_dup_candidate' | 'atomic_dup_candidate' | 'scope_disagreement' | 'island_candidate' | 'block_dup_candidate' | 'cross_arc_dup_candidate' | 'entity_unresolved' | 'provenance_mismatch';
|
|
129
|
+
export type ScopeCheck = 'same' | 'different' | 'unknown';
|
|
130
|
+
export type PipelineFlagWriter = 'stage_flag_dedup' | 'stage_audit_islands' | 'stage_audit_scope' | 'stage_audit_project_dup' | 'stage_audit_block_dup' | 'inline_dedup' | 'stage_d_resolve' | 'stage_c_entity_resolve' | 'provenance_check';
|
|
131
|
+
export type ReviewVerdict = 'merge' | 'leave' | 'split' | 'pending_clarification' | 'corrected' | 'demoted' | null;
|
|
132
|
+
/** What the reviewer actually DID to the graph (audit trail). Per flag_type:
|
|
133
|
+
* dup → archived_loser… · provenance → corrected_excerpt | demoted_unprovenanced. */
|
|
134
|
+
export type FlagActionTaken = 'archived_loser_and_wired_superseded_by' | 'corrected_excerpt' | 'demoted_unprovenanced' | 'none' | null;
|
|
135
|
+
export interface PipelineFlag {
|
|
136
|
+
id: string;
|
|
137
|
+
flag_type: PipelineFlagType;
|
|
138
|
+
block_id_a: string;
|
|
139
|
+
block_id_b: string | null;
|
|
140
|
+
criteria: Record<string, unknown>;
|
|
141
|
+
scope_check: ScopeCheck;
|
|
142
|
+
origin_writer: PipelineFlagWriter;
|
|
143
|
+
origin_range_id: string | null;
|
|
144
|
+
created_at: string;
|
|
145
|
+
reviewed_at: string | null;
|
|
146
|
+
review_verdict: ReviewVerdict;
|
|
147
|
+
review_reason: string | null;
|
|
148
|
+
action_taken: FlagActionTaken;
|
|
149
|
+
action_at: string | null;
|
|
150
|
+
winning_block_id: string | null;
|
|
151
|
+
}
|
|
152
|
+
export interface PipelineCheckpoint {
|
|
153
|
+
resumeFrom: 'pass1' | 'pass2' | 'pass3' | 'pass4';
|
|
154
|
+
pass0?: {
|
|
155
|
+
sceneCard: string | undefined;
|
|
156
|
+
raw: any;
|
|
157
|
+
};
|
|
158
|
+
pass1Items?: Pass1Item[];
|
|
159
|
+
pass2Classified?: Pass2Item[];
|
|
160
|
+
p3PendingBlockIds?: string[];
|
|
161
|
+
v2WallMs?: Record<string, number>;
|
|
162
|
+
v2FrontCostUsd?: Record<string, number>;
|
|
163
|
+
arcEntityResolution?: ArcEntityResolveResult;
|
|
164
|
+
}
|
|
165
|
+
export interface ReflectCreatedBlock {
|
|
166
|
+
label: string;
|
|
167
|
+
type: string;
|
|
168
|
+
quality: number;
|
|
169
|
+
project: string;
|
|
170
|
+
}
|
|
171
|
+
export interface ReflectUpdatedBlock {
|
|
172
|
+
label: string;
|
|
173
|
+
type: string;
|
|
174
|
+
}
|
|
175
|
+
export interface ReflectResult {
|
|
176
|
+
saved: number;
|
|
177
|
+
updated: number;
|
|
178
|
+
skipped: number;
|
|
179
|
+
saved_labels: string[];
|
|
180
|
+
uncertain_count: number;
|
|
181
|
+
created_blocks: ReflectCreatedBlock[];
|
|
182
|
+
updated_blocks: ReflectUpdatedBlock[];
|
|
183
|
+
checkpoint?: PipelineCheckpoint;
|
|
184
|
+
}
|
|
185
|
+
export type ReviewerConfidence = 'high' | 'medium' | 'low';
|
|
186
|
+
/** Subset of database.ts Block that the reviewer prompt + merge action need.
|
|
187
|
+
* Kept lean so the reviewer's input surface is auditable — adding a field
|
|
188
|
+
* here means deliberately expanding what the LLM sees. */
|
|
189
|
+
export interface BlockReviewSnapshot {
|
|
190
|
+
id: string;
|
|
191
|
+
label: string;
|
|
192
|
+
type: string;
|
|
193
|
+
essence: string;
|
|
194
|
+
content: string;
|
|
195
|
+
concepts: string[];
|
|
196
|
+
project_id: string | null;
|
|
197
|
+
source: string | null;
|
|
198
|
+
primary_value: string;
|
|
199
|
+
}
|
|
200
|
+
export interface ReviewerContext {
|
|
201
|
+
flag: PipelineFlag;
|
|
202
|
+
block_a: BlockReviewSnapshot;
|
|
203
|
+
block_b: BlockReviewSnapshot | null;
|
|
204
|
+
scope_a_chain: string[];
|
|
205
|
+
scope_b_chain: string[] | null;
|
|
206
|
+
}
|
|
207
|
+
export interface ReviewerVerdictOutput {
|
|
208
|
+
verdict: ReviewVerdict;
|
|
209
|
+
reason: string;
|
|
210
|
+
winning_block_id?: string;
|
|
211
|
+
confidence: ReviewerConfidence;
|
|
212
|
+
}
|
|
213
|
+
export interface FlagReviewerTickResult {
|
|
214
|
+
reviewed: number;
|
|
215
|
+
verdicts: {
|
|
216
|
+
merge: number;
|
|
217
|
+
leave: number;
|
|
218
|
+
split: number;
|
|
219
|
+
};
|
|
220
|
+
actions_executed: number;
|
|
221
|
+
routed_to_agent: number;
|
|
222
|
+
errors: number;
|
|
223
|
+
cost_usd: number | null;
|
|
224
|
+
}
|
|
225
|
+
export interface StageAuditTickResult {
|
|
226
|
+
scanned_pairs: number;
|
|
227
|
+
flags_written: {
|
|
228
|
+
project_dup_candidate: number;
|
|
229
|
+
scope_disagreement: number;
|
|
230
|
+
island_candidate: number;
|
|
231
|
+
block_dup_candidate: number;
|
|
232
|
+
};
|
|
233
|
+
flags_skipped_already_pending: number;
|
|
234
|
+
errors: number;
|
|
235
|
+
wall_ms: number;
|
|
236
|
+
}
|
|
237
|
+
export interface FlagListFilters {
|
|
238
|
+
flag_type?: PipelineFlagType;
|
|
239
|
+
origin_writer?: PipelineFlagWriter;
|
|
240
|
+
reviewed?: boolean;
|
|
241
|
+
block_id?: string;
|
|
242
|
+
limit?: number;
|
|
243
|
+
}
|
|
244
|
+
/** Single-flag detail returned by GET /api/flags/:id — includes the two
|
|
245
|
+
* blocks' content so the operator can SEE what was flagged without a
|
|
246
|
+
* follow-up call. Mirrors quarantine.ts/single-entry shape. */
|
|
247
|
+
export interface FlagDetailWithBlocks {
|
|
248
|
+
flag: PipelineFlag;
|
|
249
|
+
block_a: BlockReviewSnapshot | null;
|
|
250
|
+
block_b: BlockReviewSnapshot | null;
|
|
251
|
+
}
|
|
252
|
+
/** Body of POST /api/flags/:id/review — manual operator override.
|
|
253
|
+
* When `execute=true` AND `verdict='merge'`, the route runs executeMerge
|
|
254
|
+
* synchronously (charter Rule 2: archive loser, write supersedes relation). */
|
|
255
|
+
export interface ManualReviewInput {
|
|
256
|
+
verdict: ReviewVerdict;
|
|
257
|
+
reason: string;
|
|
258
|
+
execute?: boolean;
|
|
259
|
+
winning_block_id?: string;
|
|
260
|
+
}
|
|
261
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/middleware/reflect/types.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/middleware/reflect/types.ts"],"names":[],"mappings":"AAAA,kFAAkF"}
|
|
@@ -0,0 +1,120 @@
|
|
|
1
|
+
import type { WorkspaceDB } from "../../store/database.js";
|
|
2
|
+
import type { LLMProvider } from "../../engine/ai-provider.js";
|
|
3
|
+
import type { Pass2Item, PipelineCheckpoint } from "./types.js";
|
|
4
|
+
import { type KnownRoot, type RecognizeRootsResult } from "./recognize-root.js";
|
|
5
|
+
import { type JustifyResult } from "./justify-decisions.js";
|
|
6
|
+
/** Existing project ROOTS as recognizer fuel: {label, essence}. essence is the
|
|
7
|
+
* root's surface description (domain + owner), maintained by the describer —
|
|
8
|
+
* the recognizer judges the new cluster against THIS, not the label string. */
|
|
9
|
+
export declare function loadKnownRoots(db: WorkspaceDB): KnownRoot[];
|
|
10
|
+
export interface IntegrateV2RootsResult {
|
|
11
|
+
/** items with .project remapped to an existing root label on a confident attach;
|
|
12
|
+
* otherwise the input items unchanged. */
|
|
13
|
+
items: Pass2Item[];
|
|
14
|
+
/** true ⇔ the recognizer actually ran (flag ON AND >=1 existing root to match). */
|
|
15
|
+
ran: boolean;
|
|
16
|
+
/** the recognizer's batch outcome (candidates/attached/llm_calls), or null when skipped. */
|
|
17
|
+
recognition: RecognizeRootsResult | null;
|
|
18
|
+
/** number of items whose .project was rewritten to an existing root. */
|
|
19
|
+
rewritten: number;
|
|
20
|
+
}
|
|
21
|
+
/**
|
|
22
|
+
* v2 INTEGRATE — STEP 1: root recognition.
|
|
23
|
+
*
|
|
24
|
+
* For each NEW-root candidate cluster in the v2 fragment (an item.project that is
|
|
25
|
+
* not already an existing root), ask the recognizer "does this belong to an
|
|
26
|
+
* EXISTING root — same domain AND same owner?" On a confident attach, rewrite the
|
|
27
|
+
* cluster's items' .project to that root's EXACT label. Pass 3 (downstream) then
|
|
28
|
+
* finds it in KNOWN PROJECT ROOTS and attaches — no fork. Anything short of a
|
|
29
|
+
* confident same-owner fit keeps the new root (a fork is the safe failure; the
|
|
30
|
+
* post-hoc AUDIT-heal pass surfaces fork-pairs for the agent/user).
|
|
31
|
+
*
|
|
32
|
+
* Reuses the validated recognizer wholesale: recognizeRootsForArc (LLM judgment +
|
|
33
|
+
* the 5 guards + bias-to-fork) and applyRootRemap (pure remap). This function is
|
|
34
|
+
* the thin v2-side glue (load roots → recognize → apply). Default OFF →
|
|
35
|
+
* passthrough.
|
|
36
|
+
*/
|
|
37
|
+
export declare function integrateV2Roots(db: WorkspaceDB, provider: LLMProvider, items: Pass2Item[]): Promise<IntegrateV2RootsResult>;
|
|
38
|
+
export interface V2FrontHalfResult {
|
|
39
|
+
/** resumeFrom:pass3 checkpoint, or NULL → the caller must fall back to the v1
|
|
40
|
+
* path (COMPREHEND failed, SEAM 1 invalid, or no residue worth saving). */
|
|
41
|
+
checkpoint: PipelineCheckpoint | null;
|
|
42
|
+
reason?: "comprehend_failed" | "seam1_invalid" | "empty" | "insufficient_credit";
|
|
43
|
+
groups: number;
|
|
44
|
+
blocks: number;
|
|
45
|
+
filled: number;
|
|
46
|
+
recognizer: {
|
|
47
|
+
ran: boolean;
|
|
48
|
+
attached: number;
|
|
49
|
+
rewritten: number;
|
|
50
|
+
};
|
|
51
|
+
crossLinks: number;
|
|
52
|
+
selector?: {
|
|
53
|
+
ran: boolean;
|
|
54
|
+
dropped: number;
|
|
55
|
+
rescued: number;
|
|
56
|
+
};
|
|
57
|
+
merged?: number;
|
|
58
|
+
justify?: JustifyResult;
|
|
59
|
+
}
|
|
60
|
+
/**
|
|
61
|
+
* Run the v2 TRANSFORM front-half over a raw arc transcript:
|
|
62
|
+
* COMPREHEND → SEAM 1 → convert → Pass 2b unique{}-fill (parallel) →
|
|
63
|
+
* INTEGRATE (recognizer, default-OFF passthrough) → resumeFrom:pass3 checkpoint.
|
|
64
|
+
*
|
|
65
|
+
* Graph-aware only via the recognizer (COMPREHEND itself is graph-blind — it reads
|
|
66
|
+
* the transcript only). Returns checkpoint=null on any path where v2 should not
|
|
67
|
+
* produce a graph, so the caller can degrade to v1 (mirrors the arc path's
|
|
68
|
+
* graceful-degrade contract). Never throws on a bad fragment.
|
|
69
|
+
*/
|
|
70
|
+
export declare function mergeCrossGroupDupsEnabled(): boolean;
|
|
71
|
+
/** Run the cross-group linker BEFORE the SELECTOR instead of after JUSTIFY (default OFF,
|
|
72
|
+
* NODEDEX_V2_CROSSLINK_FIRST). Cross-link needs only id/type/text (not the filled
|
|
73
|
+
* unique{}), so it can run right after convert — giving the judge each block's
|
|
74
|
+
* cross-thread role before it decides keep/drop (its rescue then protects cross-group
|
|
75
|
+
* deps, not just within-group), and pre-computing the cross-group links so they wire
|
|
76
|
+
* across Pass-3 batches. The expensive 2b fill still runs AFTER the judge, so dropped
|
|
77
|
+
* blocks never pay it. Off → cross-link runs in its original slot, byte-identical. */
|
|
78
|
+
export declare function v2CrossLinkFirstEnabled(): boolean;
|
|
79
|
+
/** Transcript size (chars) up to which ONE COMPREHEND call is the default.
|
|
80
|
+
* Per-group exists ONLY to survive output-truncation on a BIG arc (the 307s
|
|
81
|
+
* truncate-retry root cause); on input that fits one call it over-splits and
|
|
82
|
+
* its N blind parallel PRODUCE calls re-extract shared claims → cross-group
|
|
83
|
+
* dups + ~3× wall time (measured 2026-06-11: 1 group=175s vs 7 groups=554s on
|
|
84
|
+
* comparable single turns). Env-tunable: NODEDEX_V2_HOLISTIC_MAX_CHARS. */
|
|
85
|
+
export declare function holisticMaxChars(): number;
|
|
86
|
+
/** Which COMPREHEND mode for this input — the size discriminator is structural,
|
|
87
|
+
* so code decides (charter rule 3); `forced` (a caller's explicit opts.holistic)
|
|
88
|
+
* always wins. Pure / testable. */
|
|
89
|
+
export declare function chooseHolistic(transcriptLength: number, forced?: boolean): boolean;
|
|
90
|
+
/**
|
|
91
|
+
* Collapse CROSS-GROUP DUPLICATES — the same residue extracted by multiple PRODUCE
|
|
92
|
+
* groups (per-group PRODUCE runs each group in isolation, so a claim relevant to
|
|
93
|
+
* several threads gets written once PER group → N copies of one block; the dup we
|
|
94
|
+
* proved via provenance: 3 "Leaky Bucket" blocks citing the identical source line).
|
|
95
|
+
*
|
|
96
|
+
* Keep ONE survivor; re-point every reference (causal fields + relations[].target)
|
|
97
|
+
* from the dropped copies → the survivor, and UNION the survivor's links so it stays
|
|
98
|
+
* connected to all the threads its copies touched. (This is "one block, many threads"
|
|
99
|
+
* — realized by links, because v2 groups are an extraction scaffold, not persisted
|
|
100
|
+
* graph entities; final chains come from causal edges.)
|
|
101
|
+
*
|
|
102
|
+
* KEY = type + unique{} primary_value (via extractPrimaryValueFromUnique — the SAME
|
|
103
|
+
* identity the block-dedup layer uses). Essence AND even the source excerpt DRIFT
|
|
104
|
+
* across per-group PRODUCE calls (each phrases its own summary, "AGENT:"-prefix vs
|
|
105
|
+
* not), but the primary_value — the approach / choice / limit — is STABLE, so it's
|
|
106
|
+
* what actually catches the real dups (validated against the dup run: excerpt+essence
|
|
107
|
+
* caught 0; primary_value catches them). Within one extraction, same type + same
|
|
108
|
+
* primary_value = the same claim → safe to merge (the established identity rule).
|
|
109
|
+
* MUST run AFTER 2b fill (primary_value is empty before that). Default OFF
|
|
110
|
+
* (NODEDEX_V2_MERGE_DUPS).
|
|
111
|
+
*/
|
|
112
|
+
export declare function mergeCrossGroupDups(items: Pass2Item[]): {
|
|
113
|
+
items: Pass2Item[];
|
|
114
|
+
merged: number;
|
|
115
|
+
};
|
|
116
|
+
export declare function runComprehendFrontHalf(db: WorkspaceDB, provider: LLMProvider, transcript: string, opts?: {
|
|
117
|
+
fillConcurrency?: number;
|
|
118
|
+
holistic?: boolean;
|
|
119
|
+
}): Promise<V2FrontHalfResult>;
|
|
120
|
+
//# sourceMappingURL=v2-integrate.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"v2-integrate.d.ts","sourceRoot":"","sources":["../../../src/middleware/reflect/v2-integrate.ts"],"names":[],"mappings":"AAiCA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,yBAAyB,CAAC;AAE3D,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,6BAA6B,CAAC;AAC/D,OAAO,KAAK,EAAE,SAAS,EAAa,kBAAkB,EAAE,MAAM,YAAY,CAAC;AAC3E,OAAO,EAIL,KAAK,SAAS,EACd,KAAK,oBAAoB,EAC1B,MAAM,qBAAqB,CAAC;AAS7B,OAAO,EAAyB,KAAK,aAAa,EAAE,MAAM,wBAAwB,CAAC;AAMnF;;gFAEgF;AAChF,wBAAgB,cAAc,CAAC,EAAE,EAAE,WAAW,GAAG,SAAS,EAAE,CAK3D;AAED,MAAM,WAAW,sBAAsB;IACrC;+CAC2C;IAC3C,KAAK,EAAE,SAAS,EAAE,CAAC;IACnB,mFAAmF;IACnF,GAAG,EAAE,OAAO,CAAC;IACb,4FAA4F;IAC5F,WAAW,EAAE,oBAAoB,GAAG,IAAI,CAAC;IACzC,wEAAwE;IACxE,SAAS,EAAE,MAAM,CAAC;CACnB;AAED;;;;;;;;;;;;;;;GAeG;AACH,wBAAsB,gBAAgB,CACpC,EAAE,EAAE,WAAW,EACf,QAAQ,EAAE,WAAW,EACrB,KAAK,EAAE,SAAS,EAAE,GACjB,OAAO,CAAC,sBAAsB,CAAC,CAYjC;AAYD,MAAM,WAAW,iBAAiB;IAChC;gFAC4E;IAC5E,UAAU,EAAE,kBAAkB,GAAG,IAAI,CAAC;IACtC,MAAM,CAAC,EAAE,mBAAmB,GAAG,eAAe,GAAG,OAAO,GAAG,qBAAqB,CAAC;IACjF,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,EAAE,MAAM,CAAC;IACf,UAAU,EAAE;QAAE,GAAG,EAAE,OAAO,CAAC;QAAC,QAAQ,EAAE,MAAM,CAAC;QAAC,SAAS,EAAE,MAAM,CAAA;KAAE,CAAC;IAClE,UAAU,EAAE,MAAM,CAAC;IACnB,QAAQ,CAAC,EAAE;QAAE,GAAG,EAAE,OAAO,CAAC;QAAC,OAAO,EAAE,MAAM,CAAC;QAAC,OAAO,EAAE,MAAM,CAAA;KAAE,CAAC;IAC9D,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,OAAO,CAAC,EAAE,aAAa,CAAC;CACzB;AAED;;;;;;;;;GASG;AACH,wBAAgB,0BAA0B,IAAI,OAAO,CAGpD;AAED;;;;;;uFAMuF;AACvF,wBAAgB,uBAAuB,IAAI,OAAO,CAGjD;AAED;;;;;4EAK4E;AAC5E,wBAAgB,gBAAgB,IAAI,MAAM,CAEzC;AAED;;oCAEoC;AACpC,wBAAgB,cAAc,CAAC,gBAAgB,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,OAAO,GAAG,OAAO,CAGlF;AAED;;;;;;;;;;;;;;;;;;;;;GAqBG;AACH,wBAAgB,mBAAmB,CAAC,KAAK,EAAE,SAAS,EAAE,GAAG;IAAE,KAAK,EAAE,SAAS,EAAE,CAAC;IAAC,MAAM,EAAE,MAAM,CAAA;CAAE,CA4C9F;AAED,wBAAsB,sBAAsB,CAC1C,EAAE,EAAE,WAAW,EACf,QAAQ,EAAE,WAAW,EACrB,UAAU,EAAE,MAAM,EAClB,IAAI,GAAE;IAAE,eAAe,CAAC,EAAE,MAAM,CAAC;IAAC,QAAQ,CAAC,EAAE,OAAO,CAAA;CAAO,GAC1D,OAAO,CAAC,iBAAiB,CAAC,CAmM5B"}
|