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,130 @@
|
|
|
1
|
+
// GET /api/models — the slimming mapper for the web-UI model picker.
|
|
2
|
+
// Fixtures are the REAL OpenRouter /api/v1/models shape (verified live 2026-06-16).
|
|
3
|
+
// Run: node --import=tsx/esm --test src/routes/__tests__/models-catalog.test.ts
|
|
4
|
+
import { test, describe, beforeEach, afterEach } from "node:test";
|
|
5
|
+
import assert from "node:assert/strict";
|
|
6
|
+
import { slimOpenRouterModel, buildPassRouting, safeParseModelCaps } from "../admin.js";
|
|
7
|
+
describe("slimOpenRouterModel", () => {
|
|
8
|
+
test("output ceiling comes from top_provider.max_completion_tokens, NOT context_length", () => {
|
|
9
|
+
// Real gpt-4o entry shape.
|
|
10
|
+
const m = slimOpenRouterModel({
|
|
11
|
+
id: "openai/gpt-4o",
|
|
12
|
+
name: "OpenAI: GPT-4o",
|
|
13
|
+
context_length: 128000,
|
|
14
|
+
top_provider: { context_length: 128000, max_completion_tokens: 16384, is_moderated: false },
|
|
15
|
+
pricing: { prompt: "0.0000025", completion: "0.00001" },
|
|
16
|
+
supported_parameters: ["tools", "response_format", "structured_outputs"],
|
|
17
|
+
architecture: { modality: "text+image+file->text" },
|
|
18
|
+
});
|
|
19
|
+
assert.equal(m.max_completion_tokens, 16384, "output cap = top_provider.max_completion_tokens");
|
|
20
|
+
assert.equal(m.context_length, 128000, "context window kept as its own (larger) number");
|
|
21
|
+
assert.notEqual(m.max_completion_tokens, m.context_length, "cap must NOT be the context window");
|
|
22
|
+
assert.equal(m.supports_structured, true);
|
|
23
|
+
assert.equal(m.supports_tools, true);
|
|
24
|
+
assert.deepEqual(m.pricing, { prompt: "0.0000025", completion: "0.00001" });
|
|
25
|
+
assert.equal(m.modality, "text+image+file->text");
|
|
26
|
+
});
|
|
27
|
+
test("big-cap model (gemini-2.5-flash 65535) maps through", () => {
|
|
28
|
+
const m = slimOpenRouterModel({
|
|
29
|
+
id: "google/gemini-2.5-flash", name: "Google: Gemini 2.5 Flash",
|
|
30
|
+
context_length: 1048576,
|
|
31
|
+
top_provider: { context_length: 1048576, max_completion_tokens: 65535 },
|
|
32
|
+
pricing: { prompt: "0.0000003", completion: "0.0000025" },
|
|
33
|
+
supported_parameters: ["structured_outputs", "tools"],
|
|
34
|
+
});
|
|
35
|
+
assert.equal(m.max_completion_tokens, 65535);
|
|
36
|
+
assert.equal(m.context_length, 1048576);
|
|
37
|
+
});
|
|
38
|
+
test("null max_completion_tokens when top_provider omits it (caller falls back to default cap)", () => {
|
|
39
|
+
const m = slimOpenRouterModel({ id: "x/y", name: "Y", context_length: 8000, top_provider: {} });
|
|
40
|
+
assert.equal(m.max_completion_tokens, null, "null → modelOutputCeiling() default applies downstream");
|
|
41
|
+
assert.equal(m.context_length, 8000);
|
|
42
|
+
});
|
|
43
|
+
test("supports_structured is false when supported_parameters lacks the keys", () => {
|
|
44
|
+
const m = slimOpenRouterModel({ id: "a/b", supported_parameters: ["temperature", "top_p"] });
|
|
45
|
+
assert.equal(m.supports_structured, false);
|
|
46
|
+
assert.equal(m.supports_tools, false);
|
|
47
|
+
});
|
|
48
|
+
test("missing/garbage fields degrade to safe defaults (no throw)", () => {
|
|
49
|
+
const m = slimOpenRouterModel({});
|
|
50
|
+
assert.equal(m.id, "");
|
|
51
|
+
assert.equal(m.max_completion_tokens, null);
|
|
52
|
+
assert.equal(m.context_length, null);
|
|
53
|
+
assert.equal(m.pricing, null);
|
|
54
|
+
assert.equal(m.supports_structured, false);
|
|
55
|
+
assert.equal(m.modality, null);
|
|
56
|
+
});
|
|
57
|
+
});
|
|
58
|
+
describe("safeParseModelCaps", () => {
|
|
59
|
+
test("valid JSON object → parsed", () => {
|
|
60
|
+
assert.deepEqual(safeParseModelCaps('{"openai/gpt-4o":16384}'), { "openai/gpt-4o": 16384 });
|
|
61
|
+
});
|
|
62
|
+
test("undefined / malformed / array → {}", () => {
|
|
63
|
+
assert.deepEqual(safeParseModelCaps(undefined), {});
|
|
64
|
+
assert.deepEqual(safeParseModelCaps("not json"), {});
|
|
65
|
+
assert.deepEqual(safeParseModelCaps("[1,2,3]"), {}, "an array is not a model→cap map");
|
|
66
|
+
});
|
|
67
|
+
});
|
|
68
|
+
describe("buildPassRouting — per-pass model routing + smartness hint", () => {
|
|
69
|
+
const KEYS = [
|
|
70
|
+
"AI_MODEL", "NODEDEX_PRIMARY_MODEL", "NODEDEX_REASONING_MODEL", "NODEDEX_STRUCTURAL_MODEL",
|
|
71
|
+
"NODEDEX_COMPREHEND_MODEL", "NODEDEX_JUDGE_MODEL", "NODEDEX_PASS2B_MODEL",
|
|
72
|
+
"NODEDEX_PASS3_MODEL", "NODEDEX_PASS4_MODEL", "NODEDEX_PASS5_MODEL",
|
|
73
|
+
];
|
|
74
|
+
let saved;
|
|
75
|
+
beforeEach(() => { saved = {}; for (const k of KEYS) {
|
|
76
|
+
saved[k] = process.env[k];
|
|
77
|
+
delete process.env[k];
|
|
78
|
+
} });
|
|
79
|
+
afterEach(() => { for (const k of KEYS) {
|
|
80
|
+
if (saved[k] === undefined)
|
|
81
|
+
delete process.env[k];
|
|
82
|
+
else
|
|
83
|
+
process.env[k] = saved[k];
|
|
84
|
+
} });
|
|
85
|
+
const stage = (r, name) => r.stages.find((s) => s.stage === name);
|
|
86
|
+
test("no overrides → every stage resolves to the default model", () => {
|
|
87
|
+
process.env.AI_MODEL = "google/gemini-2.5-flash";
|
|
88
|
+
const r = buildPassRouting();
|
|
89
|
+
assert.equal(r.default_model, "google/gemini-2.5-flash");
|
|
90
|
+
for (const s of r.stages)
|
|
91
|
+
assert.equal(s.effective, "google/gemini-2.5-flash", `${s.stage} → default`);
|
|
92
|
+
});
|
|
93
|
+
test("per-stage override wins over tier and default", () => {
|
|
94
|
+
process.env.AI_MODEL = "default-model";
|
|
95
|
+
process.env.NODEDEX_REASONING_MODEL = "smart-model";
|
|
96
|
+
process.env.NODEDEX_PASS3_MODEL = "build-special";
|
|
97
|
+
const r = buildPassRouting();
|
|
98
|
+
assert.equal(stage(r, "build").effective, "build-special", "override wins");
|
|
99
|
+
assert.equal(stage(r, "build").override, "build-special");
|
|
100
|
+
});
|
|
101
|
+
test("REASONING tier applies to smart stages (selector/build/connect), not to comprehend", () => {
|
|
102
|
+
process.env.AI_MODEL = "default-model";
|
|
103
|
+
process.env.NODEDEX_REASONING_MODEL = "smart-model";
|
|
104
|
+
const r = buildPassRouting();
|
|
105
|
+
assert.equal(stage(r, "selector").effective, "smart-model", "judge → reasoning tier");
|
|
106
|
+
assert.equal(stage(r, "build").effective, "smart-model", "pass3 → reasoning tier");
|
|
107
|
+
assert.equal(stage(r, "connect").effective, "smart-model", "pass4 → reasoning tier");
|
|
108
|
+
assert.equal(stage(r, "comprehend").effective, "default-model", "comprehend has no tier — falls to default");
|
|
109
|
+
});
|
|
110
|
+
test("STRUCTURAL tier applies to the mechanical fill stage", () => {
|
|
111
|
+
process.env.AI_MODEL = "default-model";
|
|
112
|
+
process.env.NODEDEX_STRUCTURAL_MODEL = "cheap-model";
|
|
113
|
+
assert.equal(stage(buildPassRouting(), "fill").effective, "cheap-model");
|
|
114
|
+
});
|
|
115
|
+
test("comprehend reads its OWN env knob (the workhorse)", () => {
|
|
116
|
+
process.env.AI_MODEL = "default-model";
|
|
117
|
+
process.env.NODEDEX_COMPREHEND_MODEL = "comprehend-special";
|
|
118
|
+
const s = stage(buildPassRouting(), "comprehend");
|
|
119
|
+
assert.equal(s.effective, "comprehend-special");
|
|
120
|
+
assert.equal(s.tier, "smart");
|
|
121
|
+
});
|
|
122
|
+
test("tier hint matches the stage tier", () => {
|
|
123
|
+
process.env.AI_MODEL = "m";
|
|
124
|
+
const r = buildPassRouting();
|
|
125
|
+
assert.equal(stage(r, "comprehend").hint, "wants a strong model");
|
|
126
|
+
assert.equal(stage(r, "fill").hint, "a cheap model is fine");
|
|
127
|
+
assert.equal(stage(r, "chain").hint, "moderate");
|
|
128
|
+
});
|
|
129
|
+
});
|
|
130
|
+
//# sourceMappingURL=models-catalog.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"models-catalog.test.js","sourceRoot":"","sources":["../../../src/routes/__tests__/models-catalog.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"reflect-pause-drain.test.d.ts","sourceRoot":"","sources":["../../../src/routes/__tests__/reflect-pause-drain.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { describe, it, beforeEach, afterEach } from "node:test";
|
|
2
|
+
import assert from "node:assert/strict";
|
|
3
|
+
import { reflectQueue, processReflectQueue, setReflectPaused } from "../state.js";
|
|
4
|
+
// Regression lock for the 2026-06-01 surprise-spend bug: pause must HALT the
|
|
5
|
+
// drain, not just gate new enqueues. Before the fix, processReflectQueue kept
|
|
6
|
+
// draining a recovered queue while paused → credit burned on restart.
|
|
7
|
+
describe("reflect drain respects pause", () => {
|
|
8
|
+
beforeEach(() => { reflectQueue.length = 0; setReflectPaused(false); });
|
|
9
|
+
afterEach(() => { reflectQueue.length = 0; setReflectPaused(false); });
|
|
10
|
+
it("does not touch the DB (does not drain) while paused, and leaves jobs queued", async () => {
|
|
11
|
+
// A db that throws on ANY access — proves the drain loop returns before
|
|
12
|
+
// reaching any job processing while paused.
|
|
13
|
+
const throwingDb = new Proxy({}, {
|
|
14
|
+
get() { throw new Error("db must not be touched while reflect is paused"); },
|
|
15
|
+
});
|
|
16
|
+
reflectQueue.push({
|
|
17
|
+
agentResponse: "x".repeat(60),
|
|
18
|
+
agentThinking: "",
|
|
19
|
+
userMessage: "",
|
|
20
|
+
loadedBlockIds: [],
|
|
21
|
+
agentId: "test-agent",
|
|
22
|
+
dbId: "job-1",
|
|
23
|
+
});
|
|
24
|
+
setReflectPaused(true);
|
|
25
|
+
await processReflectQueue(throwingDb, undefined); // must not throw
|
|
26
|
+
assert.equal(reflectQueue.length, 1, "job remains queued while paused (not shifted/processed)");
|
|
27
|
+
});
|
|
28
|
+
it("processes the queue when NOT paused (guard doesn't block normal drain)", async () => {
|
|
29
|
+
// Empty queue + not paused → loop runs and exits cleanly without touching db.
|
|
30
|
+
let dbTouched = false;
|
|
31
|
+
const watchDb = new Proxy({}, { get() { dbTouched = true; return () => undefined; } });
|
|
32
|
+
setReflectPaused(false);
|
|
33
|
+
await processReflectQueue(watchDb, undefined); // empty queue → no work, no db access
|
|
34
|
+
assert.equal(reflectQueue.length, 0);
|
|
35
|
+
assert.equal(dbTouched, false, "empty queue means no db access regardless");
|
|
36
|
+
});
|
|
37
|
+
});
|
|
38
|
+
//# sourceMappingURL=reflect-pause-drain.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"reflect-pause-drain.test.js","sourceRoot":"","sources":["../../../src/routes/__tests__/reflect-pause-drain.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,WAAW,CAAC;AAChE,OAAO,MAAM,MAAM,oBAAoB,CAAC;AACxC,OAAO,EAAE,YAAY,EAAE,mBAAmB,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAC;AAElF,6EAA6E;AAC7E,8EAA8E;AAC9E,sEAAsE;AACtE,QAAQ,CAAC,8BAA8B,EAAE,GAAG,EAAE;IAC5C,UAAU,CAAC,GAAG,EAAE,GAAG,YAAY,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IACxE,SAAS,CAAC,GAAG,EAAE,GAAG,YAAY,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAEvE,EAAE,CAAC,6EAA6E,EAAE,KAAK,IAAI,EAAE;QAC3F,wEAAwE;QACxE,4CAA4C;QAC5C,MAAM,UAAU,GAAQ,IAAI,KAAK,CAAC,EAAE,EAAE;YACpC,GAAG,KAAK,MAAM,IAAI,KAAK,CAAC,gDAAgD,CAAC,CAAC,CAAC,CAAC;SAC7E,CAAC,CAAC;QACH,YAAY,CAAC,IAAI,CAAC;YAChB,aAAa,EAAE,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC;YAC7B,aAAa,EAAE,EAAE;YACjB,WAAW,EAAE,EAAE;YACf,cAAc,EAAE,EAAE;YAClB,OAAO,EAAE,YAAY;YACrB,IAAI,EAAE,OAAO;SACP,CAAC,CAAC;QAEV,gBAAgB,CAAC,IAAI,CAAC,CAAC;QACvB,MAAM,mBAAmB,CAAC,UAAU,EAAE,SAAS,CAAC,CAAC,CAAC,iBAAiB;QAEnE,MAAM,CAAC,KAAK,CAAC,YAAY,CAAC,MAAM,EAAE,CAAC,EAAE,yDAAyD,CAAC,CAAC;IAClG,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,wEAAwE,EAAE,KAAK,IAAI,EAAE;QACtF,8EAA8E;QAC9E,IAAI,SAAS,GAAG,KAAK,CAAC;QACtB,MAAM,OAAO,GAAQ,IAAI,KAAK,CAAC,EAAE,EAAE,EAAE,GAAG,KAAK,SAAS,GAAG,IAAI,CAAC,CAAC,OAAO,GAAG,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;QAC5F,gBAAgB,CAAC,KAAK,CAAC,CAAC;QACxB,MAAM,mBAAmB,CAAC,OAAO,EAAE,SAAS,CAAC,CAAC,CAAC,sCAAsC;QACrF,MAAM,CAAC,KAAK,CAAC,YAAY,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;QACrC,MAAM,CAAC,KAAK,CAAC,SAAS,EAAE,KAAK,EAAE,2CAA2C,CAAC,CAAC;IAC9E,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"spend-pause-drain.test.d.ts","sourceRoot":"","sources":["../../../src/routes/__tests__/spend-pause-drain.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { describe, it, beforeEach, afterEach } from "node:test";
|
|
2
|
+
import assert from "node:assert/strict";
|
|
3
|
+
import { reflectQueue, processReflectQueue, setReflectPaused, setSpendPaused } from "../state.js";
|
|
4
|
+
// Credit-exhaustion handling (2026-06-21): a SPEND pause halts the drain (stop spending)
|
|
5
|
+
// while CAPTURE keeps queuing — distinct from reflectPaused (which stops capture too). This
|
|
6
|
+
// locks the drain-halt half: processReflectQueue must return WITHOUT touching the DB while
|
|
7
|
+
// spendPaused, leaving every job queued for a top-up. (The capture-keeps-queuing half lives
|
|
8
|
+
// in the /trigger handler, which is gated on reflectPaused ONLY — not spendPaused.)
|
|
9
|
+
describe("reflect drain respects the SPEND pause (credit-out)", () => {
|
|
10
|
+
beforeEach(() => { reflectQueue.length = 0; setReflectPaused(false); setSpendPaused(false); });
|
|
11
|
+
afterEach(() => { reflectQueue.length = 0; setReflectPaused(false); setSpendPaused(false); });
|
|
12
|
+
it("does not drain (no DB access) while spend-paused, and leaves jobs queued for top-up", async () => {
|
|
13
|
+
const throwingDb = new Proxy({}, {
|
|
14
|
+
get() { throw new Error("db must not be touched while spending is paused"); },
|
|
15
|
+
});
|
|
16
|
+
reflectQueue.push({
|
|
17
|
+
agentResponse: "x".repeat(60),
|
|
18
|
+
agentThinking: "",
|
|
19
|
+
userMessage: "",
|
|
20
|
+
loadedBlockIds: [],
|
|
21
|
+
agentId: "test-agent",
|
|
22
|
+
dbId: "job-1",
|
|
23
|
+
});
|
|
24
|
+
setSpendPaused(true);
|
|
25
|
+
await processReflectQueue(throwingDb, undefined); // must not throw, must not drain
|
|
26
|
+
assert.equal(reflectQueue.length, 1, "job remains queued while spend-paused (preserved for top-up)");
|
|
27
|
+
});
|
|
28
|
+
it("drains normally once the spend pause clears (auto-resume path)", async () => {
|
|
29
|
+
// Empty queue + both pauses off → loop runs and exits cleanly without touching db.
|
|
30
|
+
let dbTouched = false;
|
|
31
|
+
const watchDb = new Proxy({}, { get() { dbTouched = true; return () => undefined; } });
|
|
32
|
+
setSpendPaused(false);
|
|
33
|
+
await processReflectQueue(watchDb, undefined);
|
|
34
|
+
assert.equal(reflectQueue.length, 0);
|
|
35
|
+
assert.equal(dbTouched, false, "empty queue means no db access regardless");
|
|
36
|
+
});
|
|
37
|
+
});
|
|
38
|
+
//# sourceMappingURL=spend-pause-drain.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"spend-pause-drain.test.js","sourceRoot":"","sources":["../../../src/routes/__tests__/spend-pause-drain.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,WAAW,CAAC;AAChE,OAAO,MAAM,MAAM,oBAAoB,CAAC;AACxC,OAAO,EAAE,YAAY,EAAE,mBAAmB,EAAE,gBAAgB,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAElG,yFAAyF;AACzF,4FAA4F;AAC5F,2FAA2F;AAC3F,4FAA4F;AAC5F,oFAAoF;AACpF,QAAQ,CAAC,qDAAqD,EAAE,GAAG,EAAE;IACnE,UAAU,CAAC,GAAG,EAAE,GAAG,YAAY,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAC/F,SAAS,CAAC,GAAG,EAAE,GAAG,YAAY,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAE9F,EAAE,CAAC,qFAAqF,EAAE,KAAK,IAAI,EAAE;QACnG,MAAM,UAAU,GAAQ,IAAI,KAAK,CAAC,EAAE,EAAE;YACpC,GAAG,KAAK,MAAM,IAAI,KAAK,CAAC,iDAAiD,CAAC,CAAC,CAAC,CAAC;SAC9E,CAAC,CAAC;QACH,YAAY,CAAC,IAAI,CAAC;YAChB,aAAa,EAAE,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC;YAC7B,aAAa,EAAE,EAAE;YACjB,WAAW,EAAE,EAAE;YACf,cAAc,EAAE,EAAE;YAClB,OAAO,EAAE,YAAY;YACrB,IAAI,EAAE,OAAO;SACP,CAAC,CAAC;QAEV,cAAc,CAAC,IAAI,CAAC,CAAC;QACrB,MAAM,mBAAmB,CAAC,UAAU,EAAE,SAAS,CAAC,CAAC,CAAC,iCAAiC;QAEnF,MAAM,CAAC,KAAK,CAAC,YAAY,CAAC,MAAM,EAAE,CAAC,EAAE,8DAA8D,CAAC,CAAC;IACvG,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,gEAAgE,EAAE,KAAK,IAAI,EAAE;QAC9E,mFAAmF;QACnF,IAAI,SAAS,GAAG,KAAK,CAAC;QACtB,MAAM,OAAO,GAAQ,IAAI,KAAK,CAAC,EAAE,EAAE,EAAE,GAAG,KAAK,SAAS,GAAG,IAAI,CAAC,CAAC,OAAO,GAAG,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;QAC5F,cAAc,CAAC,KAAK,CAAC,CAAC;QACtB,MAAM,mBAAmB,CAAC,OAAO,EAAE,SAAS,CAAC,CAAC;QAC9C,MAAM,CAAC,KAAK,CAAC,YAAY,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;QACrC,MAAM,CAAC,KAAK,CAAC,SAAS,EAAE,KAAK,EAAE,2CAA2C,CAAC,CAAC;IAC9E,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
import { Router } from "express";
|
|
2
|
+
import { WorkspaceDB } from "../store/database.js";
|
|
3
|
+
import { EmbeddingEngine } from "../engine/embeddings.js";
|
|
4
|
+
import type { SchedulerJobStatus } from "../server.js";
|
|
5
|
+
/** Slim an OpenRouter `/api/v1/models` entry to what the web-UI picker needs. Pure /
|
|
6
|
+
* testable. `max_completion_tokens` (under `top_provider`) is the OUTPUT ceiling that
|
|
7
|
+
* feeds NODEDEX_MODEL_CAPS; `context_length` is the whole input+output window (NOT the
|
|
8
|
+
* output cap — do not use it for caps). `supported_parameters` tells whether the model
|
|
9
|
+
* can do structured output, so the UI can warn/filter rather than discover it at the
|
|
10
|
+
* first pass failure. Shape verified live 2026-06-16 against the real endpoint. */
|
|
11
|
+
/** Parse NODEDEX_MODEL_CAPS (a JSON `{model: maxOutputTokens}` string) defensively. */
|
|
12
|
+
export declare function safeParseModelCaps(raw?: string): Record<string, number>;
|
|
13
|
+
type StageTier = "smart" | "mechanical" | "light";
|
|
14
|
+
export interface PassRoutingStage {
|
|
15
|
+
stage: string;
|
|
16
|
+
env: string;
|
|
17
|
+
tier: StageTier;
|
|
18
|
+
role: string;
|
|
19
|
+
override: string;
|
|
20
|
+
effective: string;
|
|
21
|
+
hint: string;
|
|
22
|
+
}
|
|
23
|
+
/** The v2 engine stages, each with its model-override env knob, TIER (the "needs a
|
|
24
|
+
* smarter model" hint the web UI shows), role, and resolved model. Resolution mirrors
|
|
25
|
+
* the real call sites: comprehend → NODEDEX_COMPREHEND_MODEL (no tier); selector/build/
|
|
26
|
+
* connect → REASONING tier; fill → STRUCTURAL tier; chain → default. effective =
|
|
27
|
+
* override || tier model || default model. Pure / testable (reads env only). */
|
|
28
|
+
export declare function buildPassRouting(): {
|
|
29
|
+
default_model: string;
|
|
30
|
+
reasoning_tier: string;
|
|
31
|
+
structural_tier: string;
|
|
32
|
+
stages: PassRoutingStage[];
|
|
33
|
+
};
|
|
34
|
+
export declare function slimOpenRouterModel(m: any): {
|
|
35
|
+
id: string;
|
|
36
|
+
name: string;
|
|
37
|
+
context_length: number | null;
|
|
38
|
+
max_completion_tokens: number | null;
|
|
39
|
+
pricing: {
|
|
40
|
+
prompt: string;
|
|
41
|
+
completion: string;
|
|
42
|
+
} | null;
|
|
43
|
+
supports_structured: boolean;
|
|
44
|
+
supports_tools: boolean;
|
|
45
|
+
modality: string | null;
|
|
46
|
+
};
|
|
47
|
+
export declare function createAdminRouter(db: WorkspaceDB, schedulerHealth?: Record<string, SchedulerJobStatus>, embeddings?: EmbeddingEngine): Router;
|
|
48
|
+
export {};
|
|
49
|
+
//# sourceMappingURL=admin.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"admin.d.ts","sourceRoot":"","sources":["../../src/routes/admin.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AACjC,OAAO,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AACnD,OAAO,EAAE,eAAe,EAAsB,MAAM,yBAAyB,CAAC;AAE9E,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,cAAc,CAAC;AAiDvD;;;;;oFAKoF;AACpF,uFAAuF;AACvF,wBAAgB,kBAAkB,CAAC,GAAG,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAGvE;AAED,KAAK,SAAS,GAAG,OAAO,GAAG,YAAY,GAAG,OAAO,CAAC;AAClD,MAAM,WAAW,gBAAgB;IAC/B,KAAK,EAAE,MAAM,CAAC;IAAC,GAAG,EAAE,MAAM,CAAC;IAAC,IAAI,EAAE,SAAS,CAAC;IAAC,IAAI,EAAE,MAAM,CAAC;IAC1D,QAAQ,EAAE,MAAM,CAAC;IAAC,SAAS,EAAE,MAAM,CAAC;IAAC,IAAI,EAAE,MAAM,CAAC;CACnD;AAED;;;;iFAIiF;AACjF,wBAAgB,gBAAgB,IAAI;IAClC,aAAa,EAAE,MAAM,CAAC;IAAC,cAAc,EAAE,MAAM,CAAC;IAAC,eAAe,EAAE,MAAM,CAAC;IAAC,MAAM,EAAE,gBAAgB,EAAE,CAAC;CACpG,CAqBA;AAED,wBAAgB,mBAAmB,CAAC,CAAC,EAAE,GAAG,GAAG;IAC3C,EAAE,EAAE,MAAM,CAAC;IAAC,IAAI,EAAE,MAAM,CAAC;IAAC,cAAc,EAAE,MAAM,GAAG,IAAI,CAAC;IACxD,qBAAqB,EAAE,MAAM,GAAG,IAAI,CAAC;IACrC,OAAO,EAAE;QAAE,MAAM,EAAE,MAAM,CAAC;QAAC,UAAU,EAAE,MAAM,CAAA;KAAE,GAAG,IAAI,CAAC;IACvD,mBAAmB,EAAE,OAAO,CAAC;IAAC,cAAc,EAAE,OAAO,CAAC;IAAC,QAAQ,EAAE,MAAM,GAAG,IAAI,CAAC;CAChF,CAeA;AAED,wBAAgB,iBAAiB,CAC/B,EAAE,EAAE,WAAW,EACf,eAAe,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,kBAAkB,CAAC,EACpD,UAAU,CAAC,EAAE,eAAe,GAC3B,MAAM,CAyUR"}
|