monomind 1.10.0 → 1.10.2
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/.claude/commands/monomind/understand.md +111 -70
- package/.claude/settings.local.json +1 -2
- package/package.json +1 -1
- package/packages/@monomind/cli/bundled-graph/dist/src/analyze.d.ts +32 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/analyze.d.ts.map +1 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/analyze.js +297 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/analyze.js.map +1 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/build.d.ts +8 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/build.d.ts.map +1 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/build.js +73 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/build.js.map +1 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/cache.d.ts +12 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/cache.d.ts.map +1 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/cache.js +43 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/cache.js.map +1 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/cluster.d.ts +5 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/cluster.d.ts.map +1 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/cluster.js +120 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/cluster.js.map +1 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/detect.d.ts +21 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/detect.d.ts.map +1 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/detect.js +195 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/detect.js.map +1 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/export.d.ts +21 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/export.d.ts.map +1 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/export.js +68 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/export.js.map +1 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/index.d.ts +20 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/index.d.ts.map +1 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/index.js +158 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/index.js.map +1 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/c.d.ts +3 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/c.d.ts.map +1 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/c.js +88 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/c.js.map +1 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/cpp.d.ts +3 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/cpp.d.ts.map +1 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/cpp.js +121 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/cpp.js.map +1 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/csharp.d.ts +3 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/csharp.d.ts.map +1 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/csharp.js +121 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/csharp.js.map +1 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/go.d.ts +3 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/go.d.ts.map +1 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/go.js +181 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/go.js.map +1 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/java.d.ts +3 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/java.d.ts.map +1 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/java.js +117 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/java.js.map +1 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/kotlin.d.ts +3 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/kotlin.d.ts.map +1 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/kotlin.js +112 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/kotlin.js.map +1 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/php.d.ts +3 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/php.d.ts.map +1 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/php.js +130 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/php.js.map +1 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/python.d.ts +3 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/python.d.ts.map +1 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/python.js +230 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/python.js.map +1 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/ruby.d.ts +3 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/ruby.d.ts.map +1 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/ruby.js +120 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/ruby.js.map +1 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/rust.d.ts +3 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/rust.d.ts.map +1 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/rust.js +195 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/rust.js.map +1 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/scala.d.ts +3 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/scala.d.ts.map +1 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/scala.js +110 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/scala.js.map +1 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/swift.d.ts +3 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/swift.d.ts.map +1 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/swift.js +122 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/swift.js.map +1 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/typescript.d.ts +3 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/typescript.d.ts.map +1 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/typescript.js +295 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/languages/typescript.js.map +1 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/semantic.d.ts +38 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/semantic.d.ts.map +1 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/semantic.js +242 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/semantic.js.map +1 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/tree-sitter-runner.d.ts +48 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/tree-sitter-runner.d.ts.map +1 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/tree-sitter-runner.js +137 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/tree-sitter-runner.js.map +1 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/types.d.ts +7 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/types.d.ts.map +1 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/types.js +2 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/extract/types.js.map +1 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/index.d.ts +28 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/index.d.ts.map +1 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/index.js +26 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/index.js.map +1 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/pipeline.d.ts +27 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/pipeline.d.ts.map +1 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/pipeline.js +269 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/pipeline.js.map +1 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/report.d.ts +26 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/report.d.ts.map +1 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/report.js +214 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/report.js.map +1 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/types.d.ts +124 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/types.d.ts.map +1 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/types.js +2 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/types.js.map +1 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/visualize.d.ts +4 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/visualize.d.ts.map +1 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/visualize.js +574 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/visualize.js.map +1 -0
- package/packages/@monomind/cli/dist/src/agents/halt-signal.d.ts +25 -0
- package/packages/@monomind/cli/dist/src/agents/halt-signal.js +76 -0
- package/packages/@monomind/cli/dist/src/agents/index.d.ts +18 -0
- package/packages/@monomind/cli/dist/src/agents/index.js +13 -0
- package/packages/@monomind/cli/dist/src/agents/managed-agent.d.ts +41 -0
- package/packages/@monomind/cli/dist/src/agents/managed-agent.js +69 -0
- package/packages/@monomind/cli/dist/src/agents/prompt-experiment.d.ts +23 -0
- package/packages/@monomind/cli/dist/src/agents/prompt-experiment.js +49 -0
- package/packages/@monomind/cli/dist/src/agents/prompt-version-manager.d.ts +22 -0
- package/packages/@monomind/cli/dist/src/agents/prompt-version-manager.js +80 -0
- package/packages/@monomind/cli/dist/src/agents/registry-builder.d.ts +36 -0
- package/packages/@monomind/cli/dist/src/agents/registry-builder.js +200 -0
- package/packages/@monomind/cli/dist/src/agents/registry-query.d.ts +71 -0
- package/packages/@monomind/cli/dist/src/agents/registry-query.js +125 -0
- package/packages/@monomind/cli/dist/src/agents/score-decay.d.ts +19 -0
- package/packages/@monomind/cli/dist/src/agents/score-decay.js +22 -0
- package/packages/@monomind/cli/dist/src/agents/shared-instructions-loader.d.ts +13 -0
- package/packages/@monomind/cli/dist/src/agents/shared-instructions-loader.js +40 -0
- package/packages/@monomind/cli/dist/src/agents/specialization-scorer.d.ts +54 -0
- package/packages/@monomind/cli/dist/src/agents/specialization-scorer.js +212 -0
- package/packages/@monomind/cli/dist/src/agents/termination-watcher.d.ts +30 -0
- package/packages/@monomind/cli/dist/src/agents/termination-watcher.js +84 -0
- package/packages/@monomind/cli/dist/src/agents/trigger-index.d.ts +20 -0
- package/packages/@monomind/cli/dist/src/agents/trigger-index.js +38 -0
- package/packages/@monomind/cli/dist/src/agents/trigger-scanner.d.ts +64 -0
- package/packages/@monomind/cli/dist/src/agents/trigger-scanner.js +308 -0
- package/packages/@monomind/cli/dist/src/agents/version-diff.d.ts +18 -0
- package/packages/@monomind/cli/dist/src/agents/version-diff.js +64 -0
- package/packages/@monomind/cli/dist/src/agents/version-store.d.ts +60 -0
- package/packages/@monomind/cli/dist/src/agents/version-store.js +235 -0
- package/packages/@monomind/cli/dist/src/autopilot-state.d.ts +77 -0
- package/packages/@monomind/cli/dist/src/autopilot-state.js +330 -0
- package/packages/@monomind/cli/dist/src/benchmarks/benchmark-runner.d.ts +87 -0
- package/packages/@monomind/cli/dist/src/benchmarks/benchmark-runner.js +273 -0
- package/packages/@monomind/cli/dist/src/benchmarks/metric-evaluators.d.ts +36 -0
- package/packages/@monomind/cli/dist/src/benchmarks/metric-evaluators.js +114 -0
- package/packages/@monomind/cli/dist/src/benchmarks/pretrain/index.d.ts +58 -0
- package/packages/@monomind/cli/dist/src/benchmarks/pretrain/index.js +404 -0
- package/packages/@monomind/cli/dist/src/commands/agent-wasm.d.ts +14 -0
- package/packages/@monomind/cli/dist/src/commands/agent-wasm.js +333 -0
- package/packages/@monomind/cli/dist/src/commands/agent.d.ts +8 -0
- package/packages/@monomind/cli/dist/src/commands/agent.js +943 -0
- package/packages/@monomind/cli/dist/src/commands/analyze.d.ts +19 -0
- package/packages/@monomind/cli/dist/src/commands/analyze.js +2048 -0
- package/packages/@monomind/cli/dist/src/commands/appliance-advanced.d.ts +9 -0
- package/packages/@monomind/cli/dist/src/commands/appliance-advanced.js +238 -0
- package/packages/@monomind/cli/dist/src/commands/appliance.d.ts +8 -0
- package/packages/@monomind/cli/dist/src/commands/appliance.js +406 -0
- package/packages/@monomind/cli/dist/src/commands/autopilot.d.ts +15 -0
- package/packages/@monomind/cli/dist/src/commands/autopilot.js +362 -0
- package/packages/@monomind/cli/dist/src/commands/benchmark.d.ts +10 -0
- package/packages/@monomind/cli/dist/src/commands/benchmark.js +571 -0
- package/packages/@monomind/cli/dist/src/commands/claims.d.ts +10 -0
- package/packages/@monomind/cli/dist/src/commands/claims.js +632 -0
- package/packages/@monomind/cli/dist/src/commands/cleanup.d.ts +13 -0
- package/packages/@monomind/cli/dist/src/commands/cleanup.js +218 -0
- package/packages/@monomind/cli/dist/src/commands/completions.d.ts +10 -0
- package/packages/@monomind/cli/dist/src/commands/completions.js +539 -0
- package/packages/@monomind/cli/dist/src/commands/config.d.ts +8 -0
- package/packages/@monomind/cli/dist/src/commands/config.js +460 -0
- package/packages/@monomind/cli/dist/src/commands/daemon.d.ts +8 -0
- package/packages/@monomind/cli/dist/src/commands/daemon.js +671 -0
- package/packages/@monomind/cli/dist/src/commands/deployment.d.ts +10 -0
- package/packages/@monomind/cli/dist/src/commands/deployment.js +691 -0
- package/packages/@monomind/cli/dist/src/commands/doctor.d.ts +10 -0
- package/packages/@monomind/cli/dist/src/commands/doctor.js +647 -0
- package/packages/@monomind/cli/dist/src/commands/embeddings.d.ts +18 -0
- package/packages/@monomind/cli/dist/src/commands/embeddings.js +1652 -0
- package/packages/@monomind/cli/dist/src/commands/guidance.d.ts +8 -0
- package/packages/@monomind/cli/dist/src/commands/guidance.js +560 -0
- package/packages/@monomind/cli/dist/src/commands/hive-mind.d.ts +11 -0
- package/packages/@monomind/cli/dist/src/commands/hive-mind.js +1238 -0
- package/packages/@monomind/cli/dist/src/commands/hooks.d.ts +8 -0
- package/packages/@monomind/cli/dist/src/commands/hooks.js +4446 -0
- package/packages/@monomind/cli/dist/src/commands/index.d.ts +119 -0
- package/packages/@monomind/cli/dist/src/commands/index.js +404 -0
- package/packages/@monomind/cli/dist/src/commands/init.d.ts +8 -0
- package/packages/@monomind/cli/dist/src/commands/init.js +853 -0
- package/packages/@monomind/cli/dist/src/commands/issues.d.ts +21 -0
- package/packages/@monomind/cli/dist/src/commands/issues.js +567 -0
- package/packages/@monomind/cli/dist/src/commands/mcp.d.ts +11 -0
- package/packages/@monomind/cli/dist/src/commands/mcp.js +705 -0
- package/packages/@monomind/cli/dist/src/commands/memory.d.ts +8 -0
- package/packages/@monomind/cli/dist/src/commands/memory.js +1596 -0
- package/packages/@monomind/cli/dist/src/commands/migrate.d.ts +8 -0
- package/packages/@monomind/cli/dist/src/commands/migrate.js +790 -0
- package/packages/@monomind/cli/dist/src/commands/monograph.d.ts +8 -0
- package/packages/@monomind/cli/dist/src/commands/monograph.js +526 -0
- package/packages/@monomind/cli/dist/src/commands/neural.d.ts +10 -0
- package/packages/@monomind/cli/dist/src/commands/neural.js +1494 -0
- package/packages/@monomind/cli/dist/src/commands/performance.d.ts +10 -0
- package/packages/@monomind/cli/dist/src/commands/performance.js +601 -0
- package/packages/@monomind/cli/dist/src/commands/plugins.d.ts +11 -0
- package/packages/@monomind/cli/dist/src/commands/plugins.js +796 -0
- package/packages/@monomind/cli/dist/src/commands/process.d.ts +10 -0
- package/packages/@monomind/cli/dist/src/commands/process.js +718 -0
- package/packages/@monomind/cli/dist/src/commands/progress.d.ts +11 -0
- package/packages/@monomind/cli/dist/src/commands/progress.js +259 -0
- package/packages/@monomind/cli/dist/src/commands/providers.d.ts +10 -0
- package/packages/@monomind/cli/dist/src/commands/providers.js +391 -0
- package/packages/@monomind/cli/dist/src/commands/replay.d.ts +8 -0
- package/packages/@monomind/cli/dist/src/commands/replay.js +60 -0
- package/packages/@monomind/cli/dist/src/commands/route.d.ts +16 -0
- package/packages/@monomind/cli/dist/src/commands/route.js +939 -0
- package/packages/@monomind/cli/dist/src/commands/ruvector/backup.d.ts +11 -0
- package/packages/@monomind/cli/dist/src/commands/ruvector/backup.js +746 -0
- package/packages/@monomind/cli/dist/src/commands/ruvector/benchmark.d.ts +11 -0
- package/packages/@monomind/cli/dist/src/commands/ruvector/benchmark.js +489 -0
- package/packages/@monomind/cli/dist/src/commands/ruvector/import.d.ts +18 -0
- package/packages/@monomind/cli/dist/src/commands/ruvector/import.js +359 -0
- package/packages/@monomind/cli/dist/src/commands/ruvector/index.d.ts +29 -0
- package/packages/@monomind/cli/dist/src/commands/ruvector/index.js +129 -0
- package/packages/@monomind/cli/dist/src/commands/ruvector/init.d.ts +11 -0
- package/packages/@monomind/cli/dist/src/commands/ruvector/init.js +481 -0
- package/packages/@monomind/cli/dist/src/commands/ruvector/migrate.d.ts +11 -0
- package/packages/@monomind/cli/dist/src/commands/ruvector/migrate.js +497 -0
- package/packages/@monomind/cli/dist/src/commands/ruvector/optimize.d.ts +11 -0
- package/packages/@monomind/cli/dist/src/commands/ruvector/optimize.js +504 -0
- package/packages/@monomind/cli/dist/src/commands/ruvector/setup.d.ts +18 -0
- package/packages/@monomind/cli/dist/src/commands/ruvector/setup.js +765 -0
- package/packages/@monomind/cli/dist/src/commands/ruvector/status.d.ts +11 -0
- package/packages/@monomind/cli/dist/src/commands/ruvector/status.js +491 -0
- package/packages/@monomind/cli/dist/src/commands/security.d.ts +10 -0
- package/packages/@monomind/cli/dist/src/commands/security.js +943 -0
- package/packages/@monomind/cli/dist/src/commands/session.d.ts +8 -0
- package/packages/@monomind/cli/dist/src/commands/session.js +793 -0
- package/packages/@monomind/cli/dist/src/commands/start.d.ts +8 -0
- package/packages/@monomind/cli/dist/src/commands/start.js +432 -0
- package/packages/@monomind/cli/dist/src/commands/status.d.ts +8 -0
- package/packages/@monomind/cli/dist/src/commands/status.js +591 -0
- package/packages/@monomind/cli/dist/src/commands/swarm.d.ts +8 -0
- package/packages/@monomind/cli/dist/src/commands/swarm.js +812 -0
- package/packages/@monomind/cli/dist/src/commands/task.d.ts +8 -0
- package/packages/@monomind/cli/dist/src/commands/task.js +671 -0
- package/packages/@monomind/cli/dist/src/commands/tokens.d.ts +8 -0
- package/packages/@monomind/cli/dist/src/commands/tokens.js +107 -0
- package/packages/@monomind/cli/dist/src/commands/transfer-store.d.ts +13 -0
- package/packages/@monomind/cli/dist/src/commands/transfer-store.js +428 -0
- package/packages/@monomind/cli/dist/src/commands/ui.js +68 -0
- package/packages/@monomind/cli/dist/src/commands/update.d.ts +8 -0
- package/packages/@monomind/cli/dist/src/commands/update.js +276 -0
- package/packages/@monomind/cli/dist/src/commands/workflow.d.ts +8 -0
- package/packages/@monomind/cli/dist/src/commands/workflow.js +644 -0
- package/packages/@monomind/cli/dist/src/config-adapter.d.ts +16 -0
- package/packages/@monomind/cli/dist/src/config-adapter.js +186 -0
- package/packages/@monomind/cli/dist/src/consensus/audit-writer.d.ts +50 -0
- package/packages/@monomind/cli/dist/src/consensus/audit-writer.js +142 -0
- package/packages/@monomind/cli/dist/src/consensus/index.d.ts +7 -0
- package/packages/@monomind/cli/dist/src/consensus/index.js +6 -0
- package/packages/@monomind/cli/dist/src/consensus/vote-signer.d.ts +36 -0
- package/packages/@monomind/cli/dist/src/consensus/vote-signer.js +71 -0
- package/packages/@monomind/cli/dist/src/context/context-provider.d.ts +44 -0
- package/packages/@monomind/cli/dist/src/context/context-provider.js +25 -0
- package/packages/@monomind/cli/dist/src/context/git-state-provider.d.ts +12 -0
- package/packages/@monomind/cli/dist/src/context/git-state-provider.js +34 -0
- package/packages/@monomind/cli/dist/src/context/index.d.ts +12 -0
- package/packages/@monomind/cli/dist/src/context/index.js +12 -0
- package/packages/@monomind/cli/dist/src/context/project-conventions-provider.d.ts +15 -0
- package/packages/@monomind/cli/dist/src/context/project-conventions-provider.js +19 -0
- package/packages/@monomind/cli/dist/src/context/prompt-assembler.d.ts +26 -0
- package/packages/@monomind/cli/dist/src/context/prompt-assembler.js +93 -0
- package/packages/@monomind/cli/dist/src/context/task-history-provider.d.ts +24 -0
- package/packages/@monomind/cli/dist/src/context/task-history-provider.js +32 -0
- package/packages/@monomind/cli/dist/src/context/user-preferences-provider.d.ts +14 -0
- package/packages/@monomind/cli/dist/src/context/user-preferences-provider.js +27 -0
- package/packages/@monomind/cli/dist/src/dlq/dlq-reader.d.ts +31 -0
- package/packages/@monomind/cli/dist/src/dlq/dlq-reader.js +81 -0
- package/packages/@monomind/cli/dist/src/dlq/dlq-replayer.d.ts +27 -0
- package/packages/@monomind/cli/dist/src/dlq/dlq-replayer.js +90 -0
- package/packages/@monomind/cli/dist/src/dlq/dlq-writer.d.ts +24 -0
- package/packages/@monomind/cli/dist/src/dlq/dlq-writer.js +65 -0
- package/packages/@monomind/cli/dist/src/dlq/index.d.ts +10 -0
- package/packages/@monomind/cli/dist/src/dlq/index.js +7 -0
- package/packages/@monomind/cli/dist/src/eval/dataset-manager.d.ts +33 -0
- package/packages/@monomind/cli/dist/src/eval/dataset-manager.js +107 -0
- package/packages/@monomind/cli/dist/src/eval/dataset-runner.d.ts +23 -0
- package/packages/@monomind/cli/dist/src/eval/dataset-runner.js +59 -0
- package/packages/@monomind/cli/dist/src/eval/index.d.ts +10 -0
- package/packages/@monomind/cli/dist/src/eval/index.js +7 -0
- package/packages/@monomind/cli/dist/src/eval/trace-collector.d.ts +40 -0
- package/packages/@monomind/cli/dist/src/eval/trace-collector.js +102 -0
- package/packages/@monomind/cli/dist/src/index.d.ts +82 -0
- package/packages/@monomind/cli/dist/src/index.js +580 -0
- package/packages/@monomind/cli/dist/src/infrastructure/in-memory-repositories.d.ts +68 -0
- package/packages/@monomind/cli/dist/src/infrastructure/in-memory-repositories.js +264 -0
- package/packages/@monomind/cli/dist/src/init/claudemd-generator.d.ts +25 -0
- package/packages/@monomind/cli/dist/src/init/claudemd-generator.js +558 -0
- package/packages/@monomind/cli/dist/src/init/executor.d.ts +38 -0
- package/packages/@monomind/cli/dist/src/init/executor.js +2172 -0
- package/packages/@monomind/cli/dist/src/init/helpers-generator.d.ts +60 -0
- package/packages/@monomind/cli/dist/src/init/helpers-generator.js +1235 -0
- package/packages/@monomind/cli/dist/src/init/index.d.ts +13 -0
- package/packages/@monomind/cli/dist/src/init/index.js +15 -0
- package/packages/@monomind/cli/dist/src/init/mcp-generator.d.ts +26 -0
- package/packages/@monomind/cli/dist/src/init/mcp-generator.js +99 -0
- package/packages/@monomind/cli/dist/src/init/settings-generator.d.ts +14 -0
- package/packages/@monomind/cli/dist/src/init/settings-generator.js +417 -0
- package/packages/@monomind/cli/dist/src/init/shared-instructions-generator.d.ts +38 -0
- package/packages/@monomind/cli/dist/src/init/shared-instructions-generator.js +586 -0
- package/packages/@monomind/cli/dist/src/init/statusline-generator.d.ts +25 -0
- package/packages/@monomind/cli/dist/src/init/statusline-generator.js +1171 -0
- package/packages/@monomind/cli/dist/src/init/types.d.ts +315 -0
- package/packages/@monomind/cli/dist/src/init/types.js +254 -0
- package/packages/@monomind/cli/dist/src/interactive/interrupt.d.ts +22 -0
- package/packages/@monomind/cli/dist/src/interactive/interrupt.js +71 -0
- package/packages/@monomind/cli/dist/src/mcp/deprecation-injector.d.ts +25 -0
- package/packages/@monomind/cli/dist/src/mcp/deprecation-injector.js +48 -0
- package/packages/@monomind/cli/dist/src/mcp/tool-registry.d.ts +61 -0
- package/packages/@monomind/cli/dist/src/mcp/tool-registry.js +246 -0
- package/packages/@monomind/cli/dist/src/mcp-client.d.ts +92 -0
- package/packages/@monomind/cli/dist/src/mcp-client.js +270 -0
- package/packages/@monomind/cli/dist/src/mcp-server.d.ts +170 -0
- package/packages/@monomind/cli/dist/src/mcp-server.js +829 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/a2a-tools.d.ts +14 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/a2a-tools.js +244 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/agent-tools.d.ts +9 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/agent-tools.js +607 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/agentdb-tools.d.ts +30 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/agentdb-tools.js +596 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/analyze-tools.d.ts +38 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/analyze-tools.js +326 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/auto-install.d.ts +83 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/auto-install.js +129 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/autopilot-tools.d.ts +12 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/autopilot-tools.js +237 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/browser-tools.d.ts +13 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/browser-tools.js +729 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/claims-tools.d.ts +12 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/claims-tools.js +797 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/config-tools.d.ts +8 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/config-tools.js +381 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/coordination-tools.d.ts +13 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/coordination-tools.js +728 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/daa-tools.d.ts +13 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/daa-tools.js +509 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/embeddings-tools.d.ts +9 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/embeddings-tools.js +823 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/github-tools.d.ts +9 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/github-tools.js +485 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/graphify-tools.d.ts +10 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/graphify-tools.js +49 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/guidance-tools.d.ts +15 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/guidance-tools.js +646 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/hive-mind-tools.d.ts +8 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/hive-mind-tools.js +957 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/hooks-tools.d.ts +44 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/hooks-tools.js +3440 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/index.d.ts +39 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/index.js +41 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/memory-tools.d.ts +14 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/memory-tools.js +530 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/monograph-tools.d.ts +9 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/monograph-tools.js +6306 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/neural-tools.d.ts +16 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/neural-tools.js +718 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/performance-tools.d.ts +16 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/performance-tools.js +656 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/progress-tools.d.ts +14 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/progress-tools.js +350 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/request-tracker.d.ts +17 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/request-tracker.js +30 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/ruvllm-tools.d.ts +9 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/ruvllm-tools.js +295 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/security-tools.d.ts +18 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/security-tools.js +434 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/session-tools.d.ts +8 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/session-tools.js +378 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/swarm-tools.d.ts +9 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/swarm-tools.js +317 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/system-tools.d.ts +13 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/system-tools.js +552 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/task-tools.d.ts +8 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/task-tools.js +446 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/terminal-tools.d.ts +8 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/terminal-tools.js +309 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/transfer-tools.d.ts +14 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/transfer-tools.js +401 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/types.d.ts +37 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/types.js +14 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/wasm-agent-tools.d.ts +9 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/wasm-agent-tools.js +230 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/workflow-tools.d.ts +8 -0
- package/packages/@monomind/cli/dist/src/mcp-tools/workflow-tools.js +631 -0
- package/packages/@monomind/cli/dist/src/memory/ewc-consolidation.d.ts +295 -0
- package/packages/@monomind/cli/dist/src/memory/ewc-consolidation.js +632 -0
- package/packages/@monomind/cli/dist/src/memory/intelligence.d.ts +338 -0
- package/packages/@monomind/cli/dist/src/memory/intelligence.js +1049 -0
- package/packages/@monomind/cli/dist/src/memory/memory-bridge.d.ts +410 -0
- package/packages/@monomind/cli/dist/src/memory/memory-bridge.js +1654 -0
- package/packages/@monomind/cli/dist/src/memory/memory-initializer.d.ts +414 -0
- package/packages/@monomind/cli/dist/src/memory/memory-initializer.js +2284 -0
- package/packages/@monomind/cli/dist/src/memory/sona-optimizer.d.ts +234 -0
- package/packages/@monomind/cli/dist/src/memory/sona-optimizer.js +650 -0
- package/packages/@monomind/cli/dist/src/model/complexity-scorer.d.ts +21 -0
- package/packages/@monomind/cli/dist/src/model/complexity-scorer.js +106 -0
- package/packages/@monomind/cli/dist/src/model/index.d.ts +4 -0
- package/packages/@monomind/cli/dist/src/model/index.js +4 -0
- package/packages/@monomind/cli/dist/src/model/model-settings.d.ts +22 -0
- package/packages/@monomind/cli/dist/src/model/model-settings.js +33 -0
- package/packages/@monomind/cli/dist/src/model/model-tier-resolver.d.ts +24 -0
- package/packages/@monomind/cli/dist/src/model/model-tier-resolver.js +65 -0
- package/packages/@monomind/cli/dist/src/observability/replay-reader.d.ts +40 -0
- package/packages/@monomind/cli/dist/src/observability/replay-reader.js +138 -0
- package/packages/@monomind/cli/dist/src/orchestration/index.d.ts +7 -0
- package/packages/@monomind/cli/dist/src/orchestration/index.js +6 -0
- package/packages/@monomind/cli/dist/src/orchestration/mode-dispatcher.d.ts +11 -0
- package/packages/@monomind/cli/dist/src/orchestration/mode-dispatcher.js +31 -0
- package/packages/@monomind/cli/dist/src/orchestration/routing-modes.d.ts +68 -0
- package/packages/@monomind/cli/dist/src/orchestration/routing-modes.js +180 -0
- package/packages/@monomind/cli/dist/src/output.d.ts +133 -0
- package/packages/@monomind/cli/dist/src/output.js +514 -0
- package/packages/@monomind/cli/dist/src/parser.d.ts +59 -0
- package/packages/@monomind/cli/dist/src/parser.js +459 -0
- package/packages/@monomind/cli/dist/src/plugins/manager.d.ts +133 -0
- package/packages/@monomind/cli/dist/src/plugins/manager.js +493 -0
- package/packages/@monomind/cli/dist/src/plugins/store/discovery.d.ts +88 -0
- package/packages/@monomind/cli/dist/src/plugins/store/discovery.js +859 -0
- package/packages/@monomind/cli/dist/src/plugins/store/index.d.ts +76 -0
- package/packages/@monomind/cli/dist/src/plugins/store/index.js +141 -0
- package/packages/@monomind/cli/dist/src/plugins/store/search.d.ts +46 -0
- package/packages/@monomind/cli/dist/src/plugins/store/search.js +230 -0
- package/packages/@monomind/cli/dist/src/plugins/store/types.d.ts +274 -0
- package/packages/@monomind/cli/dist/src/plugins/store/types.js +7 -0
- package/packages/@monomind/cli/dist/src/plugins/tests/demo-plugin-store.d.ts +7 -0
- package/packages/@monomind/cli/dist/src/plugins/tests/demo-plugin-store.js +126 -0
- package/packages/@monomind/cli/dist/src/plugins/tests/standalone-test.d.ts +12 -0
- package/packages/@monomind/cli/dist/src/plugins/tests/standalone-test.js +188 -0
- package/packages/@monomind/cli/dist/src/plugins/tests/test-plugin-store.d.ts +7 -0
- package/packages/@monomind/cli/dist/src/plugins/tests/test-plugin-store.js +206 -0
- package/packages/@monomind/cli/dist/src/production/circuit-breaker.d.ts +101 -0
- package/packages/@monomind/cli/dist/src/production/circuit-breaker.js +248 -0
- package/packages/@monomind/cli/dist/src/production/error-handler.d.ts +94 -0
- package/packages/@monomind/cli/dist/src/production/error-handler.js +321 -0
- package/packages/@monomind/cli/dist/src/production/index.d.ts +23 -0
- package/packages/@monomind/cli/dist/src/production/index.js +18 -0
- package/packages/@monomind/cli/dist/src/production/monitoring.d.ts +161 -0
- package/packages/@monomind/cli/dist/src/production/monitoring.js +360 -0
- package/packages/@monomind/cli/dist/src/production/rate-limiter.d.ts +80 -0
- package/packages/@monomind/cli/dist/src/production/rate-limiter.js +209 -0
- package/packages/@monomind/cli/dist/src/production/retry.d.ts +48 -0
- package/packages/@monomind/cli/dist/src/production/retry.js +179 -0
- package/packages/@monomind/cli/dist/src/prompt.d.ts +44 -0
- package/packages/@monomind/cli/dist/src/prompt.js +501 -0
- package/packages/@monomind/cli/dist/src/runtime/headless.d.ts +60 -0
- package/packages/@monomind/cli/dist/src/runtime/headless.js +284 -0
- package/packages/@monomind/cli/dist/src/ruvector/agent-wasm.d.ts +182 -0
- package/packages/@monomind/cli/dist/src/ruvector/agent-wasm.js +316 -0
- package/packages/@monomind/cli/dist/src/ruvector/ast-analyzer.d.ts +67 -0
- package/packages/@monomind/cli/dist/src/ruvector/ast-analyzer.js +277 -0
- package/packages/@monomind/cli/dist/src/ruvector/coverage-router.d.ts +160 -0
- package/packages/@monomind/cli/dist/src/ruvector/coverage-router.js +539 -0
- package/packages/@monomind/cli/dist/src/ruvector/coverage-tools.d.ts +33 -0
- package/packages/@monomind/cli/dist/src/ruvector/coverage-tools.js +157 -0
- package/packages/@monomind/cli/dist/src/ruvector/diff-classifier.d.ts +176 -0
- package/packages/@monomind/cli/dist/src/ruvector/diff-classifier.js +718 -0
- package/packages/@monomind/cli/dist/src/ruvector/enhanced-model-router.d.ts +146 -0
- package/packages/@monomind/cli/dist/src/ruvector/enhanced-model-router.js +551 -0
- package/packages/@monomind/cli/dist/src/ruvector/flash-attention.d.ts +195 -0
- package/packages/@monomind/cli/dist/src/ruvector/flash-attention.js +643 -0
- package/packages/@monomind/cli/dist/src/ruvector/graph-analyzer.d.ts +187 -0
- package/packages/@monomind/cli/dist/src/ruvector/graph-analyzer.js +929 -0
- package/packages/@monomind/cli/dist/src/ruvector/index.d.ts +39 -0
- package/packages/@monomind/cli/dist/src/ruvector/index.js +76 -0
- package/packages/@monomind/cli/dist/src/ruvector/lora-adapter.d.ts +218 -0
- package/packages/@monomind/cli/dist/src/ruvector/lora-adapter.js +455 -0
- package/packages/@monomind/cli/dist/src/ruvector/model-router.d.ts +222 -0
- package/packages/@monomind/cli/dist/src/ruvector/model-router.js +512 -0
- package/packages/@monomind/cli/dist/src/ruvector/moe-router.d.ts +213 -0
- package/packages/@monomind/cli/dist/src/ruvector/moe-router.js +649 -0
- package/packages/@monomind/cli/dist/src/ruvector/q-learning-router.d.ts +217 -0
- package/packages/@monomind/cli/dist/src/ruvector/q-learning-router.js +712 -0
- package/packages/@monomind/cli/dist/src/ruvector/ruvllm-wasm.d.ts +179 -0
- package/packages/@monomind/cli/dist/src/ruvector/ruvllm-wasm.js +363 -0
- package/packages/@monomind/cli/dist/src/ruvector/semantic-router.d.ts +77 -0
- package/packages/@monomind/cli/dist/src/ruvector/semantic-router.js +178 -0
- package/packages/@monomind/cli/dist/src/ruvector/vector-db.d.ts +69 -0
- package/packages/@monomind/cli/dist/src/ruvector/vector-db.js +243 -0
- package/packages/@monomind/cli/dist/src/services/agentic-flow-bridge.d.ts +50 -0
- package/packages/@monomind/cli/dist/src/services/agentic-flow-bridge.js +95 -0
- package/packages/@monomind/cli/dist/src/services/claim-service.d.ts +206 -0
- package/packages/@monomind/cli/dist/src/services/claim-service.js +849 -0
- package/packages/@monomind/cli/dist/src/services/config-file-manager.d.ts +51 -0
- package/packages/@monomind/cli/dist/src/services/config-file-manager.js +312 -0
- package/packages/@monomind/cli/dist/src/services/container-worker-pool.d.ts +197 -0
- package/packages/@monomind/cli/dist/src/services/container-worker-pool.js +623 -0
- package/packages/@monomind/cli/dist/src/services/headless-worker-executor.d.ts +311 -0
- package/packages/@monomind/cli/dist/src/services/headless-worker-executor.js +1167 -0
- package/packages/@monomind/cli/dist/src/services/index.d.ts +13 -0
- package/packages/@monomind/cli/dist/src/services/index.js +11 -0
- package/packages/@monomind/cli/dist/src/services/registry-api.d.ts +58 -0
- package/packages/@monomind/cli/dist/src/services/registry-api.js +199 -0
- package/packages/@monomind/cli/dist/src/services/ruvector-training.d.ts +222 -0
- package/packages/@monomind/cli/dist/src/services/ruvector-training.js +696 -0
- package/packages/@monomind/cli/dist/src/services/worker-daemon.d.ts +248 -0
- package/packages/@monomind/cli/dist/src/services/worker-daemon.js +1083 -0
- package/packages/@monomind/cli/dist/src/services/worker-queue.d.ts +201 -0
- package/packages/@monomind/cli/dist/src/services/worker-queue.js +594 -0
- package/packages/@monomind/cli/dist/src/suggest.d.ts +53 -0
- package/packages/@monomind/cli/dist/src/suggest.js +209 -0
- package/packages/@monomind/cli/dist/src/swarm/communication-graph.d.ts +25 -0
- package/packages/@monomind/cli/dist/src/swarm/communication-graph.js +77 -0
- package/packages/@monomind/cli/dist/src/swarm/flow-enforcer.d.ts +31 -0
- package/packages/@monomind/cli/dist/src/swarm/flow-enforcer.js +61 -0
- package/packages/@monomind/cli/dist/src/swarm/flow-visualizer.d.ts +19 -0
- package/packages/@monomind/cli/dist/src/swarm/flow-visualizer.js +68 -0
- package/packages/@monomind/cli/dist/src/transfer/anonymization/index.d.ts +25 -0
- package/packages/@monomind/cli/dist/src/transfer/anonymization/index.js +177 -0
- package/packages/@monomind/cli/dist/src/transfer/deploy-seraphine.d.ts +13 -0
- package/packages/@monomind/cli/dist/src/transfer/deploy-seraphine.js +205 -0
- package/packages/@monomind/cli/dist/src/transfer/export.d.ts +25 -0
- package/packages/@monomind/cli/dist/src/transfer/export.js +115 -0
- package/packages/@monomind/cli/dist/src/transfer/index.d.ts +12 -0
- package/packages/@monomind/cli/dist/src/transfer/index.js +31 -0
- package/packages/@monomind/cli/dist/src/transfer/ipfs/client.d.ts +109 -0
- package/packages/@monomind/cli/dist/src/transfer/ipfs/client.js +384 -0
- package/packages/@monomind/cli/dist/src/transfer/ipfs/upload.d.ts +95 -0
- package/packages/@monomind/cli/dist/src/transfer/ipfs/upload.js +420 -0
- package/packages/@monomind/cli/dist/src/transfer/models/seraphine.d.ts +72 -0
- package/packages/@monomind/cli/dist/src/transfer/models/seraphine.js +373 -0
- package/packages/@monomind/cli/dist/src/transfer/serialization/cfp.d.ts +49 -0
- package/packages/@monomind/cli/dist/src/transfer/serialization/cfp.js +183 -0
- package/packages/@monomind/cli/dist/src/transfer/storage/gcs.d.ts +82 -0
- package/packages/@monomind/cli/dist/src/transfer/storage/gcs.js +281 -0
- package/packages/@monomind/cli/dist/src/transfer/storage/index.d.ts +6 -0
- package/packages/@monomind/cli/dist/src/transfer/storage/index.js +6 -0
- package/packages/@monomind/cli/dist/src/transfer/store/discovery.d.ts +91 -0
- package/packages/@monomind/cli/dist/src/transfer/store/discovery.js +437 -0
- package/packages/@monomind/cli/dist/src/transfer/store/download.d.ts +79 -0
- package/packages/@monomind/cli/dist/src/transfer/store/download.js +423 -0
- package/packages/@monomind/cli/dist/src/transfer/store/index.d.ts +84 -0
- package/packages/@monomind/cli/dist/src/transfer/store/index.js +153 -0
- package/packages/@monomind/cli/dist/src/transfer/store/publish.d.ts +76 -0
- package/packages/@monomind/cli/dist/src/transfer/store/publish.js +293 -0
- package/packages/@monomind/cli/dist/src/transfer/store/registry.d.ts +58 -0
- package/packages/@monomind/cli/dist/src/transfer/store/registry.js +301 -0
- package/packages/@monomind/cli/dist/src/transfer/store/search.d.ts +54 -0
- package/packages/@monomind/cli/dist/src/transfer/store/search.js +232 -0
- package/packages/@monomind/cli/dist/src/transfer/store/tests/standalone-test.d.ts +12 -0
- package/packages/@monomind/cli/dist/src/transfer/store/tests/standalone-test.js +190 -0
- package/packages/@monomind/cli/dist/src/transfer/store/types.d.ts +193 -0
- package/packages/@monomind/cli/dist/src/transfer/store/types.js +6 -0
- package/packages/@monomind/cli/dist/src/transfer/test-seraphine.d.ts +6 -0
- package/packages/@monomind/cli/dist/src/transfer/test-seraphine.js +105 -0
- package/packages/@monomind/cli/dist/src/transfer/tests/test-store.d.ts +7 -0
- package/packages/@monomind/cli/dist/src/transfer/tests/test-store.js +214 -0
- package/packages/@monomind/cli/dist/src/transfer/types.d.ts +245 -0
- package/packages/@monomind/cli/dist/src/transfer/types.js +6 -0
- package/packages/@monomind/cli/dist/src/types.d.ts +198 -0
- package/packages/@monomind/cli/dist/src/types.js +38 -0
- package/packages/@monomind/cli/dist/src/update/checker.d.ts +34 -0
- package/packages/@monomind/cli/dist/src/update/checker.js +198 -0
- package/packages/@monomind/cli/dist/src/update/executor.d.ts +32 -0
- package/packages/@monomind/cli/dist/src/update/executor.js +186 -0
- package/packages/@monomind/cli/dist/src/update/index.d.ts +33 -0
- package/packages/@monomind/cli/dist/src/update/index.js +64 -0
- package/packages/@monomind/cli/dist/src/update/rate-limiter.d.ts +31 -0
- package/packages/@monomind/cli/dist/src/update/rate-limiter.js +116 -0
- package/packages/@monomind/cli/dist/src/update/validator.d.ts +17 -0
- package/packages/@monomind/cli/dist/src/update/validator.js +118 -0
- package/packages/@monomind/cli/dist/src/utils/parse-jsonl.d.ts +6 -0
- package/packages/@monomind/cli/dist/src/utils/parse-jsonl.js +22 -0
- package/packages/@monomind/cli/dist/src/workflow/condition-evaluator.d.ts +10 -0
- package/packages/@monomind/cli/dist/src/workflow/condition-evaluator.js +82 -0
- package/packages/@monomind/cli/dist/src/workflow/context-resolver.d.ts +12 -0
- package/packages/@monomind/cli/dist/src/workflow/context-resolver.js +23 -0
- package/packages/@monomind/cli/dist/src/workflow/dag-builder.d.ts +17 -0
- package/packages/@monomind/cli/dist/src/workflow/dag-builder.js +129 -0
- package/packages/@monomind/cli/dist/src/workflow/dag-executor.d.ts +9 -0
- package/packages/@monomind/cli/dist/src/workflow/dag-executor.js +116 -0
- package/packages/@monomind/cli/dist/src/workflow/dag-types.d.ts +41 -0
- package/packages/@monomind/cli/dist/src/workflow/dag-types.js +8 -0
- package/packages/@monomind/cli/dist/src/workflow/dsl-parser.d.ts +12 -0
- package/packages/@monomind/cli/dist/src/workflow/dsl-parser.js +20 -0
- package/packages/@monomind/cli/dist/src/workflow/dsl-schema.d.ts +165 -0
- package/packages/@monomind/cli/dist/src/workflow/dsl-schema.js +82 -0
- package/packages/@monomind/cli/dist/src/workflow/index.d.ts +13 -0
- package/packages/@monomind/cli/dist/src/workflow/index.js +11 -0
- package/packages/@monomind/cli/dist/src/workflow/template-engine.d.ts +11 -0
- package/packages/@monomind/cli/dist/src/workflow/template-engine.js +40 -0
- package/packages/@monomind/cli/dist/src/workflow/workflow-executor.d.ts +29 -0
- package/packages/@monomind/cli/dist/src/workflow/workflow-executor.js +227 -0
- package/packages/@monomind/cli/package.json +2 -1
|
@@ -0,0 +1,206 @@
|
|
|
1
|
+
#!/usr/bin/env npx tsx
|
|
2
|
+
/**
|
|
3
|
+
* Plugin Store Test Suite
|
|
4
|
+
* Tests IPFS-based plugin registry discovery, search, and operations
|
|
5
|
+
*/
|
|
6
|
+
import { createPluginDiscoveryService, searchPlugins, getPluginSearchSuggestions, getPluginTagCloud, getFeaturedPlugins, getTrendingPlugins, getOfficialPlugins, findSimilarPlugins, } from '../store/index.js';
|
|
7
|
+
// Test results tracking
|
|
8
|
+
const results = [];
|
|
9
|
+
function logTest(name, passed, details) {
|
|
10
|
+
results.push({ test: name, passed, details });
|
|
11
|
+
const icon = passed ? '✅' : '❌';
|
|
12
|
+
console.log(`${icon} ${name}${details ? `: ${details}` : ''}`);
|
|
13
|
+
}
|
|
14
|
+
async function runTests() {
|
|
15
|
+
console.log('');
|
|
16
|
+
console.log('╔══════════════════════════════════════════════════════════╗');
|
|
17
|
+
console.log('║ PLUGIN STORE TEST SUITE ║');
|
|
18
|
+
console.log('║ Testing IPFS-Based Registry Discovery ║');
|
|
19
|
+
console.log('╚══════════════════════════════════════════════════════════╝');
|
|
20
|
+
console.log('');
|
|
21
|
+
// ==========================================================================
|
|
22
|
+
// 1. DISCOVERY TESTS
|
|
23
|
+
// ==========================================================================
|
|
24
|
+
console.log('─── Discovery Tests ───────────────────────────────────────');
|
|
25
|
+
try {
|
|
26
|
+
const discovery = createPluginDiscoveryService();
|
|
27
|
+
logTest('Discovery service created', true);
|
|
28
|
+
// List registries
|
|
29
|
+
const registries = discovery.listRegistries();
|
|
30
|
+
logTest('List registries', registries.length > 0, `Found ${registries.length} registries`);
|
|
31
|
+
// Discover registry
|
|
32
|
+
const result = await discovery.discoverRegistry();
|
|
33
|
+
logTest('Discover registry via IPNS', result.success, result.success
|
|
34
|
+
? `Loaded ${result.registry?.plugins.length || 0} plugins`
|
|
35
|
+
: result.error);
|
|
36
|
+
// Cache test
|
|
37
|
+
if (result.success) {
|
|
38
|
+
const cachedResult = await discovery.discoverRegistry();
|
|
39
|
+
logTest('Cache hit', cachedResult.fromCache === true, 'Second request from cache');
|
|
40
|
+
}
|
|
41
|
+
console.log('');
|
|
42
|
+
// ==========================================================================
|
|
43
|
+
// 2. SEARCH TESTS
|
|
44
|
+
// ==========================================================================
|
|
45
|
+
console.log('─── Search Tests ──────────────────────────────────────────');
|
|
46
|
+
if (result.success && result.registry) {
|
|
47
|
+
const registry = result.registry;
|
|
48
|
+
// Basic search
|
|
49
|
+
const basicSearch = searchPlugins(registry);
|
|
50
|
+
logTest('Basic search', basicSearch.plugins.length > 0, `Found ${basicSearch.total} plugins`);
|
|
51
|
+
// Query search for plugin-creator
|
|
52
|
+
const creatorSearch = searchPlugins(registry, { query: 'creator' });
|
|
53
|
+
logTest('Query search: "creator"', creatorSearch.plugins.length > 0, `Found ${creatorSearch.plugins.length} plugins matching "creator"`);
|
|
54
|
+
// Verify plugin-creator exists
|
|
55
|
+
const pluginCreator = creatorSearch.plugins.find(p => p.id === 'plugin-creator');
|
|
56
|
+
logTest('Plugin Creator found', pluginCreator !== undefined, pluginCreator ? `v${pluginCreator.version} - ${pluginCreator.displayName}` : 'Not found');
|
|
57
|
+
// Category filter
|
|
58
|
+
const securitySearch = searchPlugins(registry, { category: 'security' });
|
|
59
|
+
logTest('Category filter: security', true, `Found ${securitySearch.plugins.length} security plugins`);
|
|
60
|
+
// Type filter
|
|
61
|
+
const commandSearch = searchPlugins(registry, { type: 'command' });
|
|
62
|
+
logTest('Type filter: command', commandSearch.plugins.length > 0, `Found ${commandSearch.plugins.length} command plugins`);
|
|
63
|
+
// Verified filter
|
|
64
|
+
const verifiedSearch = searchPlugins(registry, { verified: true });
|
|
65
|
+
logTest('Verified filter', verifiedSearch.plugins.length > 0, `Verified plugins: ${verifiedSearch.plugins.length}`);
|
|
66
|
+
// Sort by downloads
|
|
67
|
+
const sortedSearch = searchPlugins(registry, {
|
|
68
|
+
sortBy: 'downloads',
|
|
69
|
+
sortOrder: 'desc',
|
|
70
|
+
});
|
|
71
|
+
logTest('Sort by downloads', true, `Top plugin: ${sortedSearch.plugins[0]?.displayName || 'none'} (${sortedSearch.plugins[0]?.downloads || 0} downloads)`);
|
|
72
|
+
// Pagination
|
|
73
|
+
const page1 = searchPlugins(registry, { limit: 3, offset: 0 });
|
|
74
|
+
logTest('Pagination', page1.pageSize === 3, `Page 1 with ${page1.plugins.length} plugins, hasMore: ${page1.hasMore}`);
|
|
75
|
+
// Search suggestions
|
|
76
|
+
const suggestions = getPluginSearchSuggestions(registry, 'neu');
|
|
77
|
+
logTest('Search suggestions', suggestions.length >= 0, `Suggestions for "neu": ${suggestions.slice(0, 3).join(', ') || 'none'}`);
|
|
78
|
+
// Tag cloud
|
|
79
|
+
const tagCloud = getPluginTagCloud(registry);
|
|
80
|
+
logTest('Tag cloud', tagCloud.size > 0, `${tagCloud.size} unique tags`);
|
|
81
|
+
}
|
|
82
|
+
console.log('');
|
|
83
|
+
// ==========================================================================
|
|
84
|
+
// 3. FEATURED/TRENDING/OFFICIAL TESTS
|
|
85
|
+
// ==========================================================================
|
|
86
|
+
console.log('─── Featured/Trending/Official Tests ─────────────────────');
|
|
87
|
+
if (result.success && result.registry) {
|
|
88
|
+
const registry = result.registry;
|
|
89
|
+
// Featured plugins
|
|
90
|
+
const featured = getFeaturedPlugins(registry);
|
|
91
|
+
logTest('Featured plugins', featured.length > 0, `${featured.length} featured: ${featured.map(p => p.name).join(', ')}`);
|
|
92
|
+
// Check plugin-creator is featured
|
|
93
|
+
const creatorFeatured = featured.some(p => p.id === 'plugin-creator');
|
|
94
|
+
logTest('Plugin Creator is featured', creatorFeatured, creatorFeatured ? 'Yes' : 'No');
|
|
95
|
+
// Trending plugins
|
|
96
|
+
const trending = getTrendingPlugins(registry);
|
|
97
|
+
logTest('Trending plugins', trending.length > 0, `${trending.length} trending: ${trending.map(p => p.name).join(', ')}`);
|
|
98
|
+
// Official plugins
|
|
99
|
+
const official = getOfficialPlugins(registry);
|
|
100
|
+
logTest('Official plugins', official.length > 0, `${official.length} official plugins`);
|
|
101
|
+
// Similar plugins
|
|
102
|
+
const similar = findSimilarPlugins(registry, '@monoes/neural', 3);
|
|
103
|
+
logTest('Similar plugins', similar.length >= 0, `Similar to @monoes/neural: ${similar.map(p => p.name).join(', ') || 'none'}`);
|
|
104
|
+
}
|
|
105
|
+
console.log('');
|
|
106
|
+
// ==========================================================================
|
|
107
|
+
// 4. PLUGIN DETAILS TEST
|
|
108
|
+
// ==========================================================================
|
|
109
|
+
console.log('─── Plugin Details Test ───────────────────────────────────');
|
|
110
|
+
if (result.success && result.registry) {
|
|
111
|
+
const pluginCreator = result.registry.plugins.find(p => p.id === 'plugin-creator');
|
|
112
|
+
if (pluginCreator) {
|
|
113
|
+
logTest('Plugin Creator details', true);
|
|
114
|
+
console.log('');
|
|
115
|
+
console.log(' Plugin Creator Pro Details:');
|
|
116
|
+
console.log(` ├─ ID: ${pluginCreator.id}`);
|
|
117
|
+
console.log(` ├─ Version: ${pluginCreator.version}`);
|
|
118
|
+
console.log(` ├─ CID: ${pluginCreator.cid}`);
|
|
119
|
+
console.log(` ├─ Size: ${(pluginCreator.size / 1024).toFixed(1)} KB`);
|
|
120
|
+
console.log(` ├─ Downloads: ${pluginCreator.downloads.toLocaleString()}`);
|
|
121
|
+
console.log(` ├─ Rating: ${pluginCreator.rating}★ (${pluginCreator.ratingCount} ratings)`);
|
|
122
|
+
console.log(` ├─ Trust: ${pluginCreator.trustLevel}`);
|
|
123
|
+
console.log(` ├─ Verified: ${pluginCreator.verified ? '✓' : '✗'}`);
|
|
124
|
+
console.log(` ├─ Commands: ${pluginCreator.commands.length}`);
|
|
125
|
+
pluginCreator.commands.forEach(cmd => {
|
|
126
|
+
console.log(` │ └─ ${cmd}`);
|
|
127
|
+
});
|
|
128
|
+
console.log(` ├─ Hooks: ${pluginCreator.hooks.length}`);
|
|
129
|
+
pluginCreator.hooks.forEach(hook => {
|
|
130
|
+
console.log(` │ └─ ${hook}`);
|
|
131
|
+
});
|
|
132
|
+
console.log(` ├─ Permissions: ${pluginCreator.permissions.join(', ')}`);
|
|
133
|
+
console.log(` ├─ Security Audit: ${pluginCreator.securityAudit ? '✓ Passed' : 'None'}`);
|
|
134
|
+
console.log(` └─ License: ${pluginCreator.license}`);
|
|
135
|
+
console.log('');
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
// ==========================================================================
|
|
139
|
+
// 5. INTEGRATION TEST
|
|
140
|
+
// ==========================================================================
|
|
141
|
+
console.log('─── Integration Test ──────────────────────────────────────');
|
|
142
|
+
// Full workflow: discover -> search -> get details
|
|
143
|
+
const store = createPluginDiscoveryService();
|
|
144
|
+
const discoverResult = await store.discoverRegistry();
|
|
145
|
+
if (discoverResult.success && discoverResult.registry) {
|
|
146
|
+
const searchResult = searchPlugins(discoverResult.registry, {
|
|
147
|
+
query: 'plugin creator',
|
|
148
|
+
});
|
|
149
|
+
if (searchResult.plugins.length > 0) {
|
|
150
|
+
const plugin = searchResult.plugins[0];
|
|
151
|
+
logTest('Full workflow', true, `Discover → Search → Found "${plugin.displayName}" ready to download`);
|
|
152
|
+
}
|
|
153
|
+
else {
|
|
154
|
+
logTest('Full workflow', true, 'Discover → Search completed');
|
|
155
|
+
}
|
|
156
|
+
}
|
|
157
|
+
}
|
|
158
|
+
catch (error) {
|
|
159
|
+
console.error('Test error:', error);
|
|
160
|
+
logTest('Test suite', false, `Error: ${error}`);
|
|
161
|
+
}
|
|
162
|
+
// ==========================================================================
|
|
163
|
+
// SUMMARY
|
|
164
|
+
// ==========================================================================
|
|
165
|
+
console.log('');
|
|
166
|
+
console.log('═══════════════════════════════════════════════════════════');
|
|
167
|
+
console.log(' TEST SUMMARY ');
|
|
168
|
+
console.log('═══════════════════════════════════════════════════════════');
|
|
169
|
+
console.log('');
|
|
170
|
+
const passed = results.filter(r => r.passed).length;
|
|
171
|
+
const failed = results.filter(r => !r.passed).length;
|
|
172
|
+
const total = results.length;
|
|
173
|
+
console.log(` Total Tests: ${total}`);
|
|
174
|
+
console.log(` ✅ Passed: ${passed}`);
|
|
175
|
+
console.log(` ❌ Failed: ${failed}`);
|
|
176
|
+
console.log('');
|
|
177
|
+
if (failed === 0) {
|
|
178
|
+
console.log(' 🎉 All tests passed!');
|
|
179
|
+
console.log('');
|
|
180
|
+
console.log(' 📦 Plugin Store Features Verified:');
|
|
181
|
+
console.log(' - Registry discovery via IPNS');
|
|
182
|
+
console.log(' - Plugin search with filters');
|
|
183
|
+
console.log(' - Featured/Trending/Official listings');
|
|
184
|
+
console.log(' - Plugin Creator Pro available for download');
|
|
185
|
+
console.log('');
|
|
186
|
+
console.log(' 🔧 Plugin Creator Pro Commands:');
|
|
187
|
+
console.log(' - plugin-creator new Create new plugin');
|
|
188
|
+
console.log(' - plugin-creator template Use template');
|
|
189
|
+
console.log(' - plugin-creator validate Validate plugin');
|
|
190
|
+
console.log(' - plugin-creator test Run tests');
|
|
191
|
+
console.log(' - plugin-creator build Build plugin');
|
|
192
|
+
console.log(' - plugin-creator publish Publish to IPFS');
|
|
193
|
+
console.log(' - plugin-creator watch Hot-reload dev mode');
|
|
194
|
+
console.log('');
|
|
195
|
+
}
|
|
196
|
+
else {
|
|
197
|
+
console.log(' ⚠️ Some tests failed. Please review the output above.');
|
|
198
|
+
}
|
|
199
|
+
process.exit(failed > 0 ? 1 : 0);
|
|
200
|
+
}
|
|
201
|
+
// Run tests
|
|
202
|
+
runTests().catch(error => {
|
|
203
|
+
console.error('Fatal error:', error);
|
|
204
|
+
process.exit(1);
|
|
205
|
+
});
|
|
206
|
+
//# sourceMappingURL=test-plugin-store.js.map
|
|
@@ -0,0 +1,101 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Production Circuit Breaker
|
|
3
|
+
*
|
|
4
|
+
* Implements the circuit breaker pattern to prevent cascading failures:
|
|
5
|
+
* - Closed: Normal operation
|
|
6
|
+
* - Open: Failing fast, not calling service
|
|
7
|
+
* - Half-Open: Testing if service recovered
|
|
8
|
+
*
|
|
9
|
+
* @module @monoes/cli/production/circuit-breaker
|
|
10
|
+
*/
|
|
11
|
+
export type CircuitState = 'closed' | 'open' | 'half-open';
|
|
12
|
+
export interface CircuitBreakerConfig {
|
|
13
|
+
failureThreshold: number;
|
|
14
|
+
resetTimeoutMs: number;
|
|
15
|
+
successThreshold: number;
|
|
16
|
+
failureWindowMs: number;
|
|
17
|
+
halfOpenRequestPercentage: number;
|
|
18
|
+
onStateChange?: (from: CircuitState, to: CircuitState) => void;
|
|
19
|
+
onOpen?: (failures: number) => void;
|
|
20
|
+
onClose?: () => void;
|
|
21
|
+
}
|
|
22
|
+
export interface CircuitStats {
|
|
23
|
+
state: CircuitState;
|
|
24
|
+
failures: number;
|
|
25
|
+
successes: number;
|
|
26
|
+
lastFailure: Date | null;
|
|
27
|
+
lastSuccess: Date | null;
|
|
28
|
+
stateChangedAt: Date;
|
|
29
|
+
totalRequests: number;
|
|
30
|
+
totalFailures: number;
|
|
31
|
+
totalSuccesses: number;
|
|
32
|
+
}
|
|
33
|
+
export declare class CircuitBreaker {
|
|
34
|
+
private config;
|
|
35
|
+
private state;
|
|
36
|
+
private failures;
|
|
37
|
+
private successCount;
|
|
38
|
+
private stateChangedAt;
|
|
39
|
+
private totalRequests;
|
|
40
|
+
private totalFailures;
|
|
41
|
+
private totalSuccesses;
|
|
42
|
+
private lastFailure;
|
|
43
|
+
private lastSuccess;
|
|
44
|
+
constructor(config?: Partial<CircuitBreakerConfig>);
|
|
45
|
+
/**
|
|
46
|
+
* Get current circuit state
|
|
47
|
+
*/
|
|
48
|
+
getState(): CircuitState;
|
|
49
|
+
/**
|
|
50
|
+
* Check if request is allowed
|
|
51
|
+
*/
|
|
52
|
+
isAllowed(): boolean;
|
|
53
|
+
/**
|
|
54
|
+
* Execute a function through the circuit breaker
|
|
55
|
+
*/
|
|
56
|
+
execute<T>(fn: () => Promise<T>): Promise<T>;
|
|
57
|
+
/**
|
|
58
|
+
* Record a successful operation
|
|
59
|
+
*/
|
|
60
|
+
recordSuccess(): void;
|
|
61
|
+
/**
|
|
62
|
+
* Record a failed operation
|
|
63
|
+
*/
|
|
64
|
+
recordFailure(): void;
|
|
65
|
+
/**
|
|
66
|
+
* Manually open the circuit
|
|
67
|
+
*/
|
|
68
|
+
open(): void;
|
|
69
|
+
/**
|
|
70
|
+
* Manually close the circuit
|
|
71
|
+
*/
|
|
72
|
+
close(): void;
|
|
73
|
+
/**
|
|
74
|
+
* Reset the circuit breaker
|
|
75
|
+
*/
|
|
76
|
+
reset(): void;
|
|
77
|
+
/**
|
|
78
|
+
* Get circuit statistics
|
|
79
|
+
*/
|
|
80
|
+
getStats(): CircuitStats;
|
|
81
|
+
/**
|
|
82
|
+
* Get failure rate
|
|
83
|
+
*/
|
|
84
|
+
getFailureRate(): number;
|
|
85
|
+
private checkStateTransition;
|
|
86
|
+
private transitionTo;
|
|
87
|
+
}
|
|
88
|
+
/**
|
|
89
|
+
* Get or create a circuit breaker by name
|
|
90
|
+
*/
|
|
91
|
+
export declare function getCircuitBreaker(name: string, config?: Partial<CircuitBreakerConfig>): CircuitBreaker;
|
|
92
|
+
/**
|
|
93
|
+
* Get all circuit breaker stats
|
|
94
|
+
*/
|
|
95
|
+
export declare function getAllCircuitStats(): Record<string, CircuitStats>;
|
|
96
|
+
/**
|
|
97
|
+
* Reset all circuit breakers
|
|
98
|
+
*/
|
|
99
|
+
export declare function resetAllCircuits(): void;
|
|
100
|
+
export default CircuitBreaker;
|
|
101
|
+
//# sourceMappingURL=circuit-breaker.d.ts.map
|
|
@@ -0,0 +1,248 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Production Circuit Breaker
|
|
3
|
+
*
|
|
4
|
+
* Implements the circuit breaker pattern to prevent cascading failures:
|
|
5
|
+
* - Closed: Normal operation
|
|
6
|
+
* - Open: Failing fast, not calling service
|
|
7
|
+
* - Half-Open: Testing if service recovered
|
|
8
|
+
*
|
|
9
|
+
* @module @monomind/cli/production/circuit-breaker
|
|
10
|
+
*/
|
|
11
|
+
// ============================================================================
|
|
12
|
+
// Default Configuration
|
|
13
|
+
// ============================================================================
|
|
14
|
+
const DEFAULT_CONFIG = {
|
|
15
|
+
failureThreshold: 5,
|
|
16
|
+
resetTimeoutMs: 30000,
|
|
17
|
+
successThreshold: 3,
|
|
18
|
+
failureWindowMs: 60000,
|
|
19
|
+
halfOpenRequestPercentage: 0.1,
|
|
20
|
+
};
|
|
21
|
+
// ============================================================================
|
|
22
|
+
// Circuit Breaker Implementation
|
|
23
|
+
// ============================================================================
|
|
24
|
+
export class CircuitBreaker {
|
|
25
|
+
config;
|
|
26
|
+
state = 'closed';
|
|
27
|
+
failures = [];
|
|
28
|
+
successCount = 0;
|
|
29
|
+
stateChangedAt = Date.now();
|
|
30
|
+
totalRequests = 0;
|
|
31
|
+
totalFailures = 0;
|
|
32
|
+
totalSuccesses = 0;
|
|
33
|
+
lastFailure = null;
|
|
34
|
+
lastSuccess = null;
|
|
35
|
+
constructor(config = {}) {
|
|
36
|
+
this.config = { ...DEFAULT_CONFIG, ...config };
|
|
37
|
+
}
|
|
38
|
+
/**
|
|
39
|
+
* Get current circuit state
|
|
40
|
+
*/
|
|
41
|
+
getState() {
|
|
42
|
+
this.checkStateTransition();
|
|
43
|
+
return this.state;
|
|
44
|
+
}
|
|
45
|
+
/**
|
|
46
|
+
* Check if request is allowed
|
|
47
|
+
*/
|
|
48
|
+
isAllowed() {
|
|
49
|
+
this.checkStateTransition();
|
|
50
|
+
switch (this.state) {
|
|
51
|
+
case 'closed':
|
|
52
|
+
return true;
|
|
53
|
+
case 'open':
|
|
54
|
+
return false;
|
|
55
|
+
case 'half-open':
|
|
56
|
+
// Allow a percentage of requests through
|
|
57
|
+
return Math.random() < this.config.halfOpenRequestPercentage;
|
|
58
|
+
default:
|
|
59
|
+
return true;
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
/**
|
|
63
|
+
* Execute a function through the circuit breaker
|
|
64
|
+
*/
|
|
65
|
+
async execute(fn) {
|
|
66
|
+
if (!this.isAllowed()) {
|
|
67
|
+
throw new Error('Circuit breaker is open. Service temporarily unavailable.');
|
|
68
|
+
}
|
|
69
|
+
this.totalRequests++;
|
|
70
|
+
try {
|
|
71
|
+
const result = await fn();
|
|
72
|
+
this.recordSuccess();
|
|
73
|
+
return result;
|
|
74
|
+
}
|
|
75
|
+
catch (error) {
|
|
76
|
+
this.recordFailure();
|
|
77
|
+
throw error;
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
/**
|
|
81
|
+
* Record a successful operation
|
|
82
|
+
*/
|
|
83
|
+
recordSuccess() {
|
|
84
|
+
this.totalSuccesses++;
|
|
85
|
+
this.lastSuccess = new Date();
|
|
86
|
+
if (this.state === 'half-open') {
|
|
87
|
+
this.successCount++;
|
|
88
|
+
if (this.successCount >= this.config.successThreshold) {
|
|
89
|
+
this.transitionTo('closed');
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
// Reset failure count on success in closed state
|
|
93
|
+
if (this.state === 'closed') {
|
|
94
|
+
this.failures = [];
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
/**
|
|
98
|
+
* Record a failed operation
|
|
99
|
+
*/
|
|
100
|
+
recordFailure() {
|
|
101
|
+
const now = Date.now();
|
|
102
|
+
this.totalFailures++;
|
|
103
|
+
this.lastFailure = new Date();
|
|
104
|
+
// Add failure timestamp
|
|
105
|
+
this.failures.push(now);
|
|
106
|
+
// Clean old failures outside window
|
|
107
|
+
this.failures = this.failures.filter(t => t > now - this.config.failureWindowMs);
|
|
108
|
+
// Check if we should open the circuit
|
|
109
|
+
if (this.state === 'closed' && this.failures.length >= this.config.failureThreshold) {
|
|
110
|
+
this.transitionTo('open');
|
|
111
|
+
if (this.config.onOpen) {
|
|
112
|
+
this.config.onOpen(this.failures.length);
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
// If half-open and we fail, go back to open
|
|
116
|
+
if (this.state === 'half-open') {
|
|
117
|
+
this.transitionTo('open');
|
|
118
|
+
if (this.config.onOpen) {
|
|
119
|
+
this.config.onOpen(this.failures.length);
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
/**
|
|
124
|
+
* Manually open the circuit
|
|
125
|
+
*/
|
|
126
|
+
open() {
|
|
127
|
+
if (this.state !== 'open') {
|
|
128
|
+
this.transitionTo('open');
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
/**
|
|
132
|
+
* Manually close the circuit
|
|
133
|
+
*/
|
|
134
|
+
close() {
|
|
135
|
+
if (this.state !== 'closed') {
|
|
136
|
+
this.transitionTo('closed');
|
|
137
|
+
}
|
|
138
|
+
}
|
|
139
|
+
/**
|
|
140
|
+
* Reset the circuit breaker
|
|
141
|
+
*/
|
|
142
|
+
reset() {
|
|
143
|
+
this.state = 'closed';
|
|
144
|
+
this.failures = [];
|
|
145
|
+
this.successCount = 0;
|
|
146
|
+
this.stateChangedAt = Date.now();
|
|
147
|
+
this.totalRequests = 0;
|
|
148
|
+
this.totalFailures = 0;
|
|
149
|
+
this.totalSuccesses = 0;
|
|
150
|
+
this.lastFailure = null;
|
|
151
|
+
this.lastSuccess = null;
|
|
152
|
+
}
|
|
153
|
+
/**
|
|
154
|
+
* Get circuit statistics
|
|
155
|
+
*/
|
|
156
|
+
getStats() {
|
|
157
|
+
return {
|
|
158
|
+
state: this.state,
|
|
159
|
+
failures: this.failures.length,
|
|
160
|
+
successes: this.successCount,
|
|
161
|
+
lastFailure: this.lastFailure,
|
|
162
|
+
lastSuccess: this.lastSuccess,
|
|
163
|
+
stateChangedAt: new Date(this.stateChangedAt),
|
|
164
|
+
totalRequests: this.totalRequests,
|
|
165
|
+
totalFailures: this.totalFailures,
|
|
166
|
+
totalSuccesses: this.totalSuccesses,
|
|
167
|
+
};
|
|
168
|
+
}
|
|
169
|
+
/**
|
|
170
|
+
* Get failure rate
|
|
171
|
+
*/
|
|
172
|
+
getFailureRate() {
|
|
173
|
+
if (this.totalRequests === 0)
|
|
174
|
+
return 0;
|
|
175
|
+
return this.totalFailures / this.totalRequests;
|
|
176
|
+
}
|
|
177
|
+
// ============================================================================
|
|
178
|
+
// Private Methods
|
|
179
|
+
// ============================================================================
|
|
180
|
+
checkStateTransition() {
|
|
181
|
+
const now = Date.now();
|
|
182
|
+
if (this.state === 'open') {
|
|
183
|
+
// Check if we should transition to half-open
|
|
184
|
+
if (now - this.stateChangedAt >= this.config.resetTimeoutMs) {
|
|
185
|
+
this.transitionTo('half-open');
|
|
186
|
+
}
|
|
187
|
+
}
|
|
188
|
+
}
|
|
189
|
+
transitionTo(newState) {
|
|
190
|
+
const oldState = this.state;
|
|
191
|
+
if (oldState === newState)
|
|
192
|
+
return;
|
|
193
|
+
this.state = newState;
|
|
194
|
+
this.stateChangedAt = Date.now();
|
|
195
|
+
// Reset counters on state change
|
|
196
|
+
if (newState === 'half-open') {
|
|
197
|
+
this.successCount = 0;
|
|
198
|
+
}
|
|
199
|
+
if (newState === 'closed') {
|
|
200
|
+
this.failures = [];
|
|
201
|
+
this.successCount = 0;
|
|
202
|
+
if (this.config.onClose) {
|
|
203
|
+
this.config.onClose();
|
|
204
|
+
}
|
|
205
|
+
}
|
|
206
|
+
// Notify state change
|
|
207
|
+
if (this.config.onStateChange) {
|
|
208
|
+
this.config.onStateChange(oldState, newState);
|
|
209
|
+
}
|
|
210
|
+
}
|
|
211
|
+
}
|
|
212
|
+
// ============================================================================
|
|
213
|
+
// Circuit Breaker Registry
|
|
214
|
+
// ============================================================================
|
|
215
|
+
const circuitBreakers = new Map();
|
|
216
|
+
const MAX_CIRCUIT_BREAKERS = 1000;
|
|
217
|
+
/**
|
|
218
|
+
* Get or create a circuit breaker by name
|
|
219
|
+
*/
|
|
220
|
+
export function getCircuitBreaker(name, config) {
|
|
221
|
+
if (!circuitBreakers.has(name)) {
|
|
222
|
+
if (circuitBreakers.size >= MAX_CIRCUIT_BREAKERS) {
|
|
223
|
+
throw new Error(`Circuit breaker registry full (max ${MAX_CIRCUIT_BREAKERS})`);
|
|
224
|
+
}
|
|
225
|
+
circuitBreakers.set(name, new CircuitBreaker(config));
|
|
226
|
+
}
|
|
227
|
+
return circuitBreakers.get(name);
|
|
228
|
+
}
|
|
229
|
+
/**
|
|
230
|
+
* Get all circuit breaker stats
|
|
231
|
+
*/
|
|
232
|
+
export function getAllCircuitStats() {
|
|
233
|
+
const stats = {};
|
|
234
|
+
for (const [name, breaker] of circuitBreakers) {
|
|
235
|
+
stats[name] = breaker.getStats();
|
|
236
|
+
}
|
|
237
|
+
return stats;
|
|
238
|
+
}
|
|
239
|
+
/**
|
|
240
|
+
* Reset all circuit breakers
|
|
241
|
+
*/
|
|
242
|
+
export function resetAllCircuits() {
|
|
243
|
+
for (const breaker of circuitBreakers.values()) {
|
|
244
|
+
breaker.reset();
|
|
245
|
+
}
|
|
246
|
+
}
|
|
247
|
+
export default CircuitBreaker;
|
|
248
|
+
//# sourceMappingURL=circuit-breaker.js.map
|
|
@@ -0,0 +1,94 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Production Error Handling
|
|
3
|
+
*
|
|
4
|
+
* Provides standardized error handling with:
|
|
5
|
+
* - Error classification
|
|
6
|
+
* - Sanitization (no sensitive data leak)
|
|
7
|
+
* - Structured error responses
|
|
8
|
+
* - Error aggregation and reporting
|
|
9
|
+
*
|
|
10
|
+
* @module @monomind/cli/production/error-handler
|
|
11
|
+
*/
|
|
12
|
+
export interface ErrorContext {
|
|
13
|
+
operation: string;
|
|
14
|
+
tool?: string;
|
|
15
|
+
input?: Record<string, unknown>;
|
|
16
|
+
userId?: string;
|
|
17
|
+
agentId?: string;
|
|
18
|
+
requestId?: string;
|
|
19
|
+
timestamp: string;
|
|
20
|
+
}
|
|
21
|
+
export interface ErrorHandlerConfig {
|
|
22
|
+
includeStack: boolean;
|
|
23
|
+
sanitize: boolean;
|
|
24
|
+
reportToMonitoring: boolean;
|
|
25
|
+
maxErrorsPerMinute: number;
|
|
26
|
+
errorCategories: Record<string, string[]>;
|
|
27
|
+
}
|
|
28
|
+
export type ErrorCategory = 'validation' | 'authentication' | 'authorization' | 'not_found' | 'rate_limit' | 'timeout' | 'circuit_open' | 'external_service' | 'internal' | 'unknown';
|
|
29
|
+
export interface StructuredError {
|
|
30
|
+
success: false;
|
|
31
|
+
error: {
|
|
32
|
+
code: string;
|
|
33
|
+
message: string;
|
|
34
|
+
category: ErrorCategory;
|
|
35
|
+
retryable: boolean;
|
|
36
|
+
retryAfterMs?: number;
|
|
37
|
+
details?: Record<string, unknown>;
|
|
38
|
+
};
|
|
39
|
+
context?: Partial<ErrorContext>;
|
|
40
|
+
timestamp: string;
|
|
41
|
+
}
|
|
42
|
+
export declare class ErrorHandler {
|
|
43
|
+
private config;
|
|
44
|
+
private errorCounts;
|
|
45
|
+
private errorLog;
|
|
46
|
+
private maxLogSize;
|
|
47
|
+
constructor(config?: Partial<ErrorHandlerConfig>);
|
|
48
|
+
/**
|
|
49
|
+
* Classify an error into a category
|
|
50
|
+
*/
|
|
51
|
+
classifyError(error: Error | string): ErrorCategory;
|
|
52
|
+
/**
|
|
53
|
+
* Check if an error category is retryable
|
|
54
|
+
*/
|
|
55
|
+
isRetryable(category: ErrorCategory): boolean;
|
|
56
|
+
/**
|
|
57
|
+
* Sanitize input to remove sensitive data
|
|
58
|
+
* Cycle-safe and depth-bounded — circular references and deeply nested objects
|
|
59
|
+
* will not cause stack overflow.
|
|
60
|
+
*/
|
|
61
|
+
sanitize(input: Record<string, unknown>, _seen?: WeakSet<object>, _depth?: number): Record<string, unknown>;
|
|
62
|
+
/**
|
|
63
|
+
* Handle an error and return a structured response
|
|
64
|
+
*/
|
|
65
|
+
handle(error: Error | string, context?: Partial<ErrorContext>): StructuredError;
|
|
66
|
+
/**
|
|
67
|
+
* Wrap a handler with error handling
|
|
68
|
+
*/
|
|
69
|
+
wrap<T extends (...args: unknown[]) => Promise<unknown>>(handler: T, context: Partial<ErrorContext>): T;
|
|
70
|
+
/**
|
|
71
|
+
* Get error statistics
|
|
72
|
+
*/
|
|
73
|
+
getStats(): {
|
|
74
|
+
totalErrors: number;
|
|
75
|
+
byCategory: Record<string, number>;
|
|
76
|
+
recentErrors: StructuredError[];
|
|
77
|
+
errorRate: number;
|
|
78
|
+
};
|
|
79
|
+
/**
|
|
80
|
+
* Clear error log
|
|
81
|
+
*/
|
|
82
|
+
clearLog(): void;
|
|
83
|
+
private getErrorCode;
|
|
84
|
+
private getRetryDelay;
|
|
85
|
+
private sanitizeMessage;
|
|
86
|
+
private trackError;
|
|
87
|
+
private logError;
|
|
88
|
+
}
|
|
89
|
+
/**
|
|
90
|
+
* Wrap a handler with error handling (convenience function)
|
|
91
|
+
*/
|
|
92
|
+
export declare function withErrorHandling<T extends (...args: unknown[]) => Promise<unknown>>(handler: T, context?: Partial<ErrorContext>): T;
|
|
93
|
+
export default ErrorHandler;
|
|
94
|
+
//# sourceMappingURL=error-handler.d.ts.map
|