monomind 1.11.13 → 1.12.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/.claude/agents/generated/channel-intelligence-director.md +87 -0
- package/.claude/agents/generated/chief-growth-officer.md +88 -0
- package/.claude/agents/generated/content-seo-strategist.md +90 -0
- package/.claude/agents/generated/developer-community-strategist.md +91 -0
- package/.claude/agents/generated/outreach-partnership-strategist.md +90 -0
- package/.claude/agents/generated/social-media-strategist.md +91 -0
- package/.claude/agents/generated/video-visual-strategist.md +90 -0
- package/.claude/commands/mastermind/idea.md +1 -1
- package/.claude/helpers/auto-memory-hook.mjs +13 -4
- package/.claude/helpers/control-start.cjs +5 -0
- package/.claude/helpers/event-logger.cjs +114 -0
- package/.claude/helpers/handlers/adr-draft-handler.cjs +19 -5
- package/.claude/helpers/handlers/agent-start-handler.cjs +13 -4
- package/.claude/helpers/handlers/compact-handler.cjs +2 -0
- package/.claude/helpers/handlers/edit-handler.cjs +1 -1
- package/.claude/helpers/handlers/gates-handler.cjs +3 -0
- package/.claude/helpers/handlers/graph-status-handler.cjs +14 -8
- package/.claude/helpers/handlers/loops-status-handler.cjs +5 -2
- package/.claude/helpers/handlers/route-handler.cjs +13 -6
- package/.claude/helpers/handlers/session-handler.cjs +11 -4
- package/.claude/helpers/handlers/session-restore-handler.cjs +21 -11
- package/.claude/helpers/handlers/task-handler.cjs +13 -5
- package/.claude/helpers/intelligence.cjs +7 -2
- package/.claude/helpers/loop-tracker.cjs +15 -3
- package/.claude/helpers/memory.cjs +6 -1
- package/.claude/helpers/router.cjs +5 -2
- package/.claude/helpers/session.cjs +2 -0
- package/.claude/helpers/statusline.cjs +10 -2
- package/.claude/helpers/utils/micro-agents.cjs +20 -4
- package/.claude/scheduled_tasks.lock +1 -1
- package/.claude/settings.json +92 -1
- package/.claude/skills/mastermind/_protocol.md +23 -13
- package/.claude/skills/mastermind/architect.md +6 -9
- package/.claude/skills/mastermind/build.md +3 -3
- package/.claude/skills/mastermind/content.md +3 -3
- package/.claude/skills/mastermind/createorg.md +2 -2
- package/.claude/skills/mastermind/finance.md +3 -3
- package/.claude/skills/mastermind/idea.md +5 -3
- package/.claude/skills/mastermind/marketing.md +3 -3
- package/.claude/skills/mastermind/monitor.md +2 -2
- package/.claude/skills/mastermind/release.md +3 -3
- package/.claude/skills/mastermind/research.md +3 -3
- package/.claude/skills/mastermind/review.md +3 -3
- package/.claude/skills/mastermind/runorg.md +153 -86
- package/.claude/skills/mastermind/sales.md +3 -3
- package/README.md +286 -129
- package/package.json +19 -2
- package/packages/@monomind/cli/README.md +286 -129
- package/packages/@monomind/cli/bundled-graph/dist/src/build.js +73 -0
- package/packages/@monomind/cli/bundled-graph/dist/src/cluster.js +120 -0
- package/packages/@monomind/cli/bundled-graph/package.json +57 -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.js +2 -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.js +10 -5
- package/packages/@monomind/cli/dist/src/benchmarks/benchmark-runner.js +13 -0
- package/packages/@monomind/cli/dist/src/benchmarks/metric-evaluators.js +20 -9
- package/packages/@monomind/cli/dist/src/benchmarks/pretrain/index.d.ts +45 -0
- package/packages/@monomind/cli/dist/src/benchmarks/pretrain/index.js +404 -0
- package/packages/@monomind/cli/dist/src/browser/actions.js +10 -3
- package/packages/@monomind/cli/dist/src/browser/browser.js +12 -2
- package/packages/@monomind/cli/dist/src/browser/cdp.js +21 -3
- package/packages/@monomind/cli/dist/src/browser/har.js +27 -5
- 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.js +11 -8
- package/packages/@monomind/cli/dist/src/commands/analyze.js +36 -21
- package/packages/@monomind/cli/dist/src/commands/autopilot.js +12 -4
- package/packages/@monomind/cli/dist/src/commands/benchmark.js +51 -8
- package/packages/@monomind/cli/dist/src/commands/browse.js +5 -2
- package/packages/@monomind/cli/dist/src/commands/claims.js +29 -11
- package/packages/@monomind/cli/dist/src/commands/cleanup.js +25 -5
- package/packages/@monomind/cli/dist/src/commands/config.js +15 -7
- package/packages/@monomind/cli/dist/src/commands/daemon.js +6 -0
- package/packages/@monomind/cli/dist/src/commands/deployment.js +34 -19
- package/packages/@monomind/cli/dist/src/commands/doctor.js +151 -20
- package/packages/@monomind/cli/dist/src/commands/guidance.js +15 -2
- package/packages/@monomind/cli/dist/src/commands/hive-mind.js +37 -14
- package/packages/@monomind/cli/dist/src/commands/hooks.js +42 -25
- package/packages/@monomind/cli/dist/src/commands/init.js +9 -4
- package/packages/@monomind/cli/dist/src/commands/issues.js +29 -26
- package/packages/@monomind/cli/dist/src/commands/mcp.js +11 -5
- package/packages/@monomind/cli/dist/src/commands/memory.js +10 -0
- package/packages/@monomind/cli/dist/src/commands/migrate.js +5 -5
- package/packages/@monomind/cli/dist/src/commands/monograph.js +18 -5
- package/packages/@monomind/cli/dist/src/commands/monovector/backup.js +8 -2
- package/packages/@monomind/cli/dist/src/commands/monovector/benchmark.js +20 -7
- package/packages/@monomind/cli/dist/src/commands/monovector/import.js +15 -0
- package/packages/@monomind/cli/dist/src/commands/monovector/migrate.js +4 -1
- package/packages/@monomind/cli/dist/src/commands/monovector/optimize.js +11 -0
- package/packages/@monomind/cli/dist/src/commands/monovector/setup.js +11 -1
- package/packages/@monomind/cli/dist/src/commands/neural.js +1 -1
- package/packages/@monomind/cli/dist/src/commands/performance.js +20 -7
- package/packages/@monomind/cli/dist/src/commands/platforms.js +90 -8
- package/packages/@monomind/cli/dist/src/commands/plugins.js +12 -5
- package/packages/@monomind/cli/dist/src/commands/process.js +33 -10
- package/packages/@monomind/cli/dist/src/commands/progress.js +5 -3
- package/packages/@monomind/cli/dist/src/commands/providers.js +5 -5
- package/packages/@monomind/cli/dist/src/commands/replay.js +8 -2
- package/packages/@monomind/cli/dist/src/commands/route.js +27 -7
- package/packages/@monomind/cli/dist/src/commands/security.js +4 -0
- package/packages/@monomind/cli/dist/src/commands/session.js +12 -1
- package/packages/@monomind/cli/dist/src/commands/start.js +11 -4
- package/packages/@monomind/cli/dist/src/commands/status.js +7 -4
- package/packages/@monomind/cli/dist/src/commands/swarm.js +27 -13
- package/packages/@monomind/cli/dist/src/commands/task.js +26 -11
- package/packages/@monomind/cli/dist/src/commands/tokens.js +7 -2
- package/packages/@monomind/cli/dist/src/commands/transfer-store.js +36 -22
- package/packages/@monomind/cli/dist/src/commands/ui.js +68 -0
- package/packages/@monomind/cli/dist/src/commands/update.js +15 -3
- package/packages/@monomind/cli/dist/src/commands/workflow.js +39 -6
- package/packages/@monomind/cli/dist/src/consensus/audit-writer.js +18 -7
- 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.js +25 -8
- 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-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.js +7 -3
- 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/executor.js +14 -11
- package/packages/@monomind/cli/dist/src/init/shared-instructions-generator.js +20 -4
- package/packages/@monomind/cli/dist/src/init/statusline-generator.js +33 -12
- 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-tools/a2a-tools.js +98 -13
- package/packages/@monomind/cli/dist/src/mcp-tools/agent-tools.js +16 -3
- package/packages/@monomind/cli/dist/src/mcp-tools/analyze-tools.js +80 -17
- package/packages/@monomind/cli/dist/src/mcp-tools/browser-tools.js +84 -22
- package/packages/@monomind/cli/dist/src/mcp-tools/claims-tools.js +35 -7
- package/packages/@monomind/cli/dist/src/mcp-tools/config-tools.js +82 -17
- package/packages/@monomind/cli/dist/src/mcp-tools/coordination-tools.js +37 -4
- package/packages/@monomind/cli/dist/src/mcp-tools/daa-tools.js +49 -7
- package/packages/@monomind/cli/dist/src/mcp-tools/embeddings-tools.js +45 -18
- package/packages/@monomind/cli/dist/src/mcp-tools/github-tools.js +75 -25
- package/packages/@monomind/cli/dist/src/mcp-tools/guidance-tools.js +32 -10
- package/packages/@monomind/cli/dist/src/mcp-tools/hive-mind-tools.js +91 -20
- package/packages/@monomind/cli/dist/src/mcp-tools/hooks-tools.js +188 -29
- package/packages/@monomind/cli/dist/src/mcp-tools/memory-tools.js +25 -7
- package/packages/@monomind/cli/dist/src/mcp-tools/monograph-compat.js +11 -2
- package/packages/@monomind/cli/dist/src/mcp-tools/monograph-tools.js +148 -26
- package/packages/@monomind/cli/dist/src/mcp-tools/neural-tools.js +44 -9
- package/packages/@monomind/cli/dist/src/mcp-tools/performance-tools.js +45 -10
- package/packages/@monomind/cli/dist/src/mcp-tools/progress-tools.js +7 -4
- package/packages/@monomind/cli/dist/src/mcp-tools/request-tracker.js +15 -1
- package/packages/@monomind/cli/dist/src/mcp-tools/security-tools.js +61 -9
- package/packages/@monomind/cli/dist/src/mcp-tools/session-tools.js +45 -14
- package/packages/@monomind/cli/dist/src/mcp-tools/swarm-tools.js +15 -3
- package/packages/@monomind/cli/dist/src/mcp-tools/system-tools.js +14 -7
- package/packages/@monomind/cli/dist/src/mcp-tools/task-tools.js +52 -10
- package/packages/@monomind/cli/dist/src/mcp-tools/terminal-tools.js +40 -6
- package/packages/@monomind/cli/dist/src/mcp-tools/transfer-tools.js +37 -4
- 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.js +29 -6
- package/packages/@monomind/cli/dist/src/memory/ewc-consolidation.js +26 -10
- package/packages/@monomind/cli/dist/src/memory/intelligence.js +80 -19
- package/packages/@monomind/cli/dist/src/memory/memory-bridge.js +21 -2
- package/packages/@monomind/cli/dist/src/memory/memory-initializer.js +67 -3
- package/packages/@monomind/cli/dist/src/memory/sona-optimizer.js +14 -4
- 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/monovector/capabilities.d.ts +34 -0
- package/packages/@monomind/cli/dist/src/monovector/capabilities.js +37 -0
- package/packages/@monomind/cli/dist/src/monovector/command-outcomes.js +43 -7
- package/packages/@monomind/cli/dist/src/monovector/coverage-router.js +8 -4
- package/packages/@monomind/cli/dist/src/monovector/coverage-tools.js +6 -3
- package/packages/@monomind/cli/dist/src/monovector/diff-classifier.js +13 -0
- package/packages/@monomind/cli/dist/src/monovector/route-outcomes.d.ts +2 -1
- package/packages/@monomind/cli/dist/src/monovector/route-outcomes.js +46 -4
- package/packages/@monomind/cli/dist/src/observability/replay-reader.d.ts +1 -1
- 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/plugins/manager.js +8 -3
- package/packages/@monomind/cli/dist/src/plugins/store/discovery.js +46 -2
- package/packages/@monomind/cli/dist/src/plugins/store/search.js +5 -4
- 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.js +17 -3
- package/packages/@monomind/cli/dist/src/production/error-handler.js +3 -0
- package/packages/@monomind/cli/dist/src/production/monitoring.js +20 -3
- package/packages/@monomind/cli/dist/src/production/rate-limiter.js +13 -4
- package/packages/@monomind/cli/dist/src/production/retry.js +17 -9
- package/packages/@monomind/cli/dist/src/routing/embed-worker.js +6 -2
- package/packages/@monomind/cli/dist/src/routing/embedder.js +0 -0
- package/packages/@monomind/cli/dist/src/routing/llm-caller.js +13 -2
- package/packages/@monomind/cli/dist/src/routing/route-layer-factory.js +18 -3
- 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/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 +1 -0
- package/packages/@monomind/cli/dist/src/services/claim-service.js +8 -0
- package/packages/@monomind/cli/dist/src/services/config-file-manager.js +14 -2
- 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.js +18 -2
- 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/worker-daemon.js +53 -12
- 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/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 +0 -3
- package/packages/@monomind/cli/dist/src/transfer/anonymization/index.js +16 -1
- 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.js +8 -0
- package/packages/@monomind/cli/dist/src/transfer/ipfs/upload.js +33 -3
- package/packages/@monomind/cli/dist/src/transfer/serialization/cfp.js +9 -3
- package/packages/@monomind/cli/dist/src/transfer/storage/gcs.js +37 -3
- package/packages/@monomind/cli/dist/src/transfer/store/discovery.js +45 -3
- package/packages/@monomind/cli/dist/src/transfer/store/download.js +5 -0
- package/packages/@monomind/cli/dist/src/transfer/store/publish.js +13 -1
- package/packages/@monomind/cli/dist/src/transfer/store/registry.d.ts +8 -0
- package/packages/@monomind/cli/dist/src/transfer/store/registry.js +30 -5
- package/packages/@monomind/cli/dist/src/transfer/store/search.js +20 -5
- 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/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/update/checker.js +59 -7
- package/packages/@monomind/cli/dist/src/update/executor.js +50 -3
- package/packages/@monomind/cli/dist/src/update/index.js +18 -1
- package/packages/@monomind/cli/dist/src/update/rate-limiter.d.ts +6 -0
- package/packages/@monomind/cli/dist/src/update/rate-limiter.js +79 -7
- package/packages/@monomind/cli/dist/src/update/validator.js +52 -1
- 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 +9 -10
- package/packages/@monomind/guidance/dist/adversarial.d.ts +284 -0
- package/packages/@monomind/guidance/dist/adversarial.js +572 -0
- package/packages/@monomind/guidance/dist/analyzer.d.ts +530 -0
- package/packages/@monomind/guidance/dist/analyzer.js +2518 -0
- package/packages/@monomind/guidance/dist/artifacts.d.ts +283 -0
- package/packages/@monomind/guidance/dist/artifacts.js +356 -0
- package/packages/@monomind/guidance/dist/authority.d.ts +290 -0
- package/packages/@monomind/guidance/dist/authority.js +558 -0
- package/packages/@monomind/guidance/dist/capabilities.d.ts +209 -0
- package/packages/@monomind/guidance/dist/capabilities.js +485 -0
- package/packages/@monomind/guidance/dist/coherence.d.ts +233 -0
- package/packages/@monomind/guidance/dist/coherence.js +372 -0
- package/packages/@monomind/guidance/dist/compiler.d.ts +87 -0
- package/packages/@monomind/guidance/dist/compiler.js +419 -0
- package/packages/@monomind/guidance/dist/conformance-kit.d.ts +225 -0
- package/packages/@monomind/guidance/dist/conformance-kit.js +629 -0
- package/packages/@monomind/guidance/dist/continue-gate.d.ts +214 -0
- package/packages/@monomind/guidance/dist/continue-gate.js +353 -0
- package/packages/@monomind/guidance/dist/crypto-utils.d.ts +17 -0
- package/packages/@monomind/guidance/dist/crypto-utils.js +24 -0
- package/packages/@monomind/guidance/dist/evolution.d.ts +282 -0
- package/packages/@monomind/guidance/dist/evolution.js +500 -0
- package/packages/@monomind/guidance/dist/gates.d.ts +79 -0
- package/packages/@monomind/guidance/dist/gates.js +302 -0
- package/packages/@monomind/guidance/dist/gateway.d.ts +206 -0
- package/packages/@monomind/guidance/dist/gateway.js +452 -0
- package/packages/@monomind/guidance/dist/generators.d.ts +153 -0
- package/packages/@monomind/guidance/dist/generators.js +682 -0
- package/packages/@monomind/guidance/dist/headless.d.ts +177 -0
- package/packages/@monomind/guidance/dist/headless.js +342 -0
- package/packages/@monomind/guidance/dist/hooks.d.ts +109 -0
- package/packages/@monomind/guidance/dist/hooks.js +347 -0
- package/packages/@monomind/guidance/dist/index.d.ts +205 -0
- package/packages/@monomind/guidance/dist/index.js +321 -0
- package/packages/@monomind/guidance/dist/ledger.d.ts +162 -0
- package/packages/@monomind/guidance/dist/ledger.js +375 -0
- package/packages/@monomind/guidance/dist/manifest-validator.d.ts +289 -0
- package/packages/@monomind/guidance/dist/manifest-validator.js +838 -0
- package/packages/@monomind/guidance/dist/memory-gate.d.ts +222 -0
- package/packages/@monomind/guidance/dist/memory-gate.js +382 -0
- package/packages/@monomind/guidance/dist/meta-governance.d.ts +265 -0
- package/packages/@monomind/guidance/dist/meta-governance.js +348 -0
- package/packages/@monomind/guidance/dist/optimizer.d.ts +104 -0
- package/packages/@monomind/guidance/dist/optimizer.js +329 -0
- package/packages/@monomind/guidance/dist/persistence.d.ts +189 -0
- package/packages/@monomind/guidance/dist/persistence.js +464 -0
- package/packages/@monomind/guidance/dist/proof.d.ts +185 -0
- package/packages/@monomind/guidance/dist/proof.js +238 -0
- package/packages/@monomind/guidance/dist/retriever.d.ts +116 -0
- package/packages/@monomind/guidance/dist/retriever.js +394 -0
- package/packages/@monomind/guidance/dist/ruvbot-integration.d.ts +370 -0
- package/packages/@monomind/guidance/dist/ruvbot-integration.js +738 -0
- package/packages/@monomind/guidance/dist/temporal.d.ts +426 -0
- package/packages/@monomind/guidance/dist/temporal.js +658 -0
- package/packages/@monomind/guidance/dist/trust.d.ts +283 -0
- package/packages/@monomind/guidance/dist/trust.js +473 -0
- package/packages/@monomind/guidance/dist/truth-anchors.d.ts +276 -0
- package/packages/@monomind/guidance/dist/truth-anchors.js +488 -0
- package/packages/@monomind/guidance/dist/types.d.ts +378 -0
- package/packages/@monomind/guidance/dist/types.js +10 -0
- package/packages/@monomind/guidance/dist/uncertainty.d.ts +372 -0
- package/packages/@monomind/guidance/dist/uncertainty.js +619 -0
- package/packages/@monomind/guidance/dist/wasm-kernel.d.ts +48 -0
- package/packages/@monomind/guidance/dist/wasm-kernel.js +158 -0
|
@@ -0,0 +1,107 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* DatasetManager - JSONL-based eval dataset management (Task 33)
|
|
3
|
+
*/
|
|
4
|
+
import { randomUUID } from 'crypto';
|
|
5
|
+
import { appendFileSync, readFileSync, writeFileSync, renameSync, existsSync, statSync } from 'fs';
|
|
6
|
+
import { resolve, sep } from 'path';
|
|
7
|
+
import { parseJsonl } from '../utils/parse-jsonl.js';
|
|
8
|
+
export class DatasetManager {
|
|
9
|
+
datasetsPath;
|
|
10
|
+
entriesPath;
|
|
11
|
+
constructor(datasetsPath, entriesPath) {
|
|
12
|
+
this.datasetsPath = datasetsPath;
|
|
13
|
+
this.entriesPath = entriesPath;
|
|
14
|
+
}
|
|
15
|
+
/**
|
|
16
|
+
* Create a dataset from a set of filtered traces.
|
|
17
|
+
*/
|
|
18
|
+
createFromTraces(opts) {
|
|
19
|
+
const now = new Date().toISOString();
|
|
20
|
+
const agentSlugs = opts.agentSlugs ?? [...new Set(opts.traces.map((t) => t.agentSlug))];
|
|
21
|
+
const dataset = {
|
|
22
|
+
datasetId: randomUUID(),
|
|
23
|
+
name: opts.name,
|
|
24
|
+
description: opts.description,
|
|
25
|
+
agentSlugs,
|
|
26
|
+
createdAt: now,
|
|
27
|
+
updatedAt: now,
|
|
28
|
+
entryCount: opts.traces.length,
|
|
29
|
+
};
|
|
30
|
+
appendFileSync(this.datasetsPath, JSON.stringify(dataset) + '\n', 'utf-8');
|
|
31
|
+
for (const trace of opts.traces) {
|
|
32
|
+
const entry = {
|
|
33
|
+
entryId: randomUUID(),
|
|
34
|
+
datasetId: dataset.datasetId,
|
|
35
|
+
traceId: trace.traceId,
|
|
36
|
+
addedAt: now,
|
|
37
|
+
};
|
|
38
|
+
appendFileSync(this.entriesPath, JSON.stringify(entry) + '\n', 'utf-8');
|
|
39
|
+
}
|
|
40
|
+
return dataset;
|
|
41
|
+
}
|
|
42
|
+
/**
|
|
43
|
+
* List all datasets.
|
|
44
|
+
*/
|
|
45
|
+
listDatasets() {
|
|
46
|
+
if (!existsSync(this.datasetsPath))
|
|
47
|
+
return [];
|
|
48
|
+
if (statSync(this.datasetsPath).size > 50 * 1024 * 1024) {
|
|
49
|
+
throw new Error('Dataset file exceeds 50MB — run cleanup');
|
|
50
|
+
}
|
|
51
|
+
const content = readFileSync(this.datasetsPath, 'utf-8');
|
|
52
|
+
return parseJsonl(content);
|
|
53
|
+
}
|
|
54
|
+
/**
|
|
55
|
+
* Get entries for a specific dataset.
|
|
56
|
+
*/
|
|
57
|
+
getEntries(datasetId) {
|
|
58
|
+
if (!existsSync(this.entriesPath))
|
|
59
|
+
return [];
|
|
60
|
+
if (statSync(this.entriesPath).size > 50 * 1024 * 1024) {
|
|
61
|
+
throw new Error('Entries file exceeds 50MB — run cleanup');
|
|
62
|
+
}
|
|
63
|
+
const content = readFileSync(this.entriesPath, 'utf-8');
|
|
64
|
+
return parseJsonl(content).filter((e) => e.datasetId === datasetId);
|
|
65
|
+
}
|
|
66
|
+
/**
|
|
67
|
+
* Add a single trace to an existing dataset.
|
|
68
|
+
*/
|
|
69
|
+
addTraceToDataset(datasetId, traceId) {
|
|
70
|
+
const entry = {
|
|
71
|
+
entryId: randomUUID(),
|
|
72
|
+
datasetId,
|
|
73
|
+
traceId,
|
|
74
|
+
addedAt: new Date().toISOString(),
|
|
75
|
+
};
|
|
76
|
+
appendFileSync(this.entriesPath, JSON.stringify(entry) + '\n', 'utf-8');
|
|
77
|
+
// Update dataset entryCount via atomic write
|
|
78
|
+
const datasets = this.listDatasets();
|
|
79
|
+
const updated = datasets.map((d) => {
|
|
80
|
+
if (d.datasetId === datasetId) {
|
|
81
|
+
return { ...d, entryCount: d.entryCount + 1, updatedAt: new Date().toISOString() };
|
|
82
|
+
}
|
|
83
|
+
return d;
|
|
84
|
+
});
|
|
85
|
+
const tmp = `${this.datasetsPath}.${randomUUID()}.tmp`;
|
|
86
|
+
writeFileSync(tmp, updated.map((d) => JSON.stringify(d)).join('\n') + '\n', 'utf-8');
|
|
87
|
+
renameSync(tmp, this.datasetsPath);
|
|
88
|
+
return entry;
|
|
89
|
+
}
|
|
90
|
+
/**
|
|
91
|
+
* Export a dataset to a JSON file. Output path must be within `allowedRoot`.
|
|
92
|
+
*/
|
|
93
|
+
exportToFile(datasetId, outputPath, allowedRoot) {
|
|
94
|
+
if (allowedRoot) {
|
|
95
|
+
const resolvedOut = resolve(outputPath);
|
|
96
|
+
const resolvedRoot = resolve(allowedRoot);
|
|
97
|
+
if (!resolvedOut.startsWith(resolvedRoot + sep) && resolvedOut !== resolvedRoot) {
|
|
98
|
+
throw new Error(`Export path escapes allowed root: ${resolvedOut}`);
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
const datasets = this.listDatasets();
|
|
102
|
+
const dataset = datasets.find((d) => d.datasetId === datasetId);
|
|
103
|
+
const entries = this.getEntries(datasetId);
|
|
104
|
+
writeFileSync(outputPath, JSON.stringify({ dataset, entries }, null, 2), 'utf-8');
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
//# sourceMappingURL=dataset-manager.js.map
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import type { EvalRunResult, EvalTrace } from '../../../shared/src/types/eval.js';
|
|
2
|
+
export interface AgentRunnerResult {
|
|
3
|
+
agentOutput: string;
|
|
4
|
+
outcome: 'success' | 'failure' | 'timeout';
|
|
5
|
+
qualityScore: number;
|
|
6
|
+
latencyMs: number;
|
|
7
|
+
}
|
|
8
|
+
export interface DatasetRunOpts {
|
|
9
|
+
datasetId: string;
|
|
10
|
+
agentVersion: string;
|
|
11
|
+
traces: EvalTrace[];
|
|
12
|
+
agentRunner: (trace: EvalTrace) => Promise<AgentRunnerResult>;
|
|
13
|
+
baselineResult?: EvalRunResult;
|
|
14
|
+
regressionThreshold?: number;
|
|
15
|
+
}
|
|
16
|
+
export declare class DatasetRunner {
|
|
17
|
+
/**
|
|
18
|
+
* Run all traces through the agent runner and compute stats.
|
|
19
|
+
* Optionally compare against a baseline to detect regressions.
|
|
20
|
+
*/
|
|
21
|
+
run(opts: DatasetRunOpts): Promise<EvalRunResult>;
|
|
22
|
+
}
|
|
23
|
+
//# sourceMappingURL=dataset-runner.d.ts.map
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* DatasetRunner - Run eval datasets against agents and detect regressions (Task 33)
|
|
3
|
+
*/
|
|
4
|
+
import { randomUUID } from 'crypto';
|
|
5
|
+
export class DatasetRunner {
|
|
6
|
+
/**
|
|
7
|
+
* Run all traces through the agent runner and compute stats.
|
|
8
|
+
* Optionally compare against a baseline to detect regressions.
|
|
9
|
+
*/
|
|
10
|
+
async run(opts) {
|
|
11
|
+
const { datasetId, agentVersion, traces, agentRunner, baselineResult, regressionThreshold = 0.1, } = opts;
|
|
12
|
+
const results = [];
|
|
13
|
+
for (const trace of traces) {
|
|
14
|
+
const result = await agentRunner(trace);
|
|
15
|
+
results.push({ trace, result });
|
|
16
|
+
}
|
|
17
|
+
const passCount = results.filter((r) => r.result.outcome === 'success').length;
|
|
18
|
+
const failCount = results.length - passCount;
|
|
19
|
+
const totalQuality = results.reduce((sum, r) => sum + r.result.qualityScore, 0);
|
|
20
|
+
const totalLatency = results.reduce((sum, r) => sum + r.result.latencyMs, 0);
|
|
21
|
+
const avgQualityScore = results.length > 0 ? totalQuality / results.length : 0;
|
|
22
|
+
const avgLatencyMs = results.length > 0 ? totalLatency / results.length : 0;
|
|
23
|
+
// Regression detection
|
|
24
|
+
const regressionDetails = [];
|
|
25
|
+
let regressionDetected = false;
|
|
26
|
+
if (baselineResult) {
|
|
27
|
+
const delta = baselineResult.avgQualityScore - avgQualityScore;
|
|
28
|
+
if (delta > regressionThreshold) {
|
|
29
|
+
regressionDetected = true;
|
|
30
|
+
// Report per-trace regressions for traces with quality below baseline average
|
|
31
|
+
for (const { trace, result } of results) {
|
|
32
|
+
if (result.qualityScore < baselineResult.avgQualityScore) {
|
|
33
|
+
regressionDetails.push({
|
|
34
|
+
traceId: trace.traceId,
|
|
35
|
+
agentSlug: trace.agentSlug,
|
|
36
|
+
baselineScore: baselineResult.avgQualityScore,
|
|
37
|
+
currentScore: result.qualityScore,
|
|
38
|
+
delta: baselineResult.avgQualityScore - result.qualityScore,
|
|
39
|
+
});
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
return {
|
|
45
|
+
runId: randomUUID(),
|
|
46
|
+
datasetId,
|
|
47
|
+
runAt: new Date().toISOString(),
|
|
48
|
+
agentVersion,
|
|
49
|
+
entriesTested: results.length,
|
|
50
|
+
passCount,
|
|
51
|
+
failCount,
|
|
52
|
+
avgQualityScore,
|
|
53
|
+
avgLatencyMs,
|
|
54
|
+
regressionDetected,
|
|
55
|
+
regressionDetails,
|
|
56
|
+
};
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
//# sourceMappingURL=dataset-runner.js.map
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Eval Module - Automated eval dataset from production traces (Task 33)
|
|
3
|
+
*/
|
|
4
|
+
export { TraceCollector } from './trace-collector.js';
|
|
5
|
+
export type { RecordTraceInput } from './trace-collector.js';
|
|
6
|
+
export { DatasetManager } from './dataset-manager.js';
|
|
7
|
+
export type { CreateFromTracesOpts } from './dataset-manager.js';
|
|
8
|
+
export { DatasetRunner } from './dataset-runner.js';
|
|
9
|
+
export type { AgentRunnerResult, DatasetRunOpts } from './dataset-runner.js';
|
|
10
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Eval Module - Automated eval dataset from production traces (Task 33)
|
|
3
|
+
*/
|
|
4
|
+
export { TraceCollector } from './trace-collector.js';
|
|
5
|
+
export { DatasetManager } from './dataset-manager.js';
|
|
6
|
+
export { DatasetRunner } from './dataset-runner.js';
|
|
7
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import type { EvalTrace } from '../../../shared/src/types/eval.js';
|
|
2
|
+
export interface RecordTraceInput {
|
|
3
|
+
agentSlug: string;
|
|
4
|
+
agentVersion: string;
|
|
5
|
+
taskDescription: string;
|
|
6
|
+
taskInput: string;
|
|
7
|
+
agentOutput: string;
|
|
8
|
+
retryCount: number;
|
|
9
|
+
qualityScore?: number;
|
|
10
|
+
outcome: 'success' | 'failure' | 'timeout';
|
|
11
|
+
latencyMs: number;
|
|
12
|
+
tokenCount?: number;
|
|
13
|
+
costUsd?: number;
|
|
14
|
+
correctedOutput?: string;
|
|
15
|
+
}
|
|
16
|
+
export declare class TraceCollector {
|
|
17
|
+
private filePath;
|
|
18
|
+
constructor(filePath: string);
|
|
19
|
+
/**
|
|
20
|
+
* Determine auto review status based on trace quality signals.
|
|
21
|
+
*/
|
|
22
|
+
autoReviewStatus(input: RecordTraceInput): 'pending' | 'approved';
|
|
23
|
+
/**
|
|
24
|
+
* Auto-generate tags based on trace characteristics.
|
|
25
|
+
*/
|
|
26
|
+
autoTag(input: RecordTraceInput): string[];
|
|
27
|
+
/**
|
|
28
|
+
* Record a trace, auto-generating traceId, capturedAt, reviewStatus, and tags.
|
|
29
|
+
*/
|
|
30
|
+
record(input: RecordTraceInput): EvalTrace;
|
|
31
|
+
/**
|
|
32
|
+
* Read all traces from the JSONL file.
|
|
33
|
+
*/
|
|
34
|
+
readAll(): EvalTrace[];
|
|
35
|
+
/**
|
|
36
|
+
* Get traces pending review, with optional limit.
|
|
37
|
+
*/
|
|
38
|
+
getTracesPendingReview(limit?: number): EvalTrace[];
|
|
39
|
+
}
|
|
40
|
+
//# sourceMappingURL=trace-collector.d.ts.map
|
|
@@ -0,0 +1,102 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* TraceCollector - JSONL-based production trace collection (Task 33)
|
|
3
|
+
*/
|
|
4
|
+
import { randomUUID } from 'crypto';
|
|
5
|
+
import { appendFileSync, readFileSync, existsSync, statSync } from 'fs';
|
|
6
|
+
import { parseJsonl } from '../utils/parse-jsonl.js';
|
|
7
|
+
export class TraceCollector {
|
|
8
|
+
filePath;
|
|
9
|
+
constructor(filePath) {
|
|
10
|
+
this.filePath = filePath;
|
|
11
|
+
}
|
|
12
|
+
/**
|
|
13
|
+
* Determine auto review status based on trace quality signals.
|
|
14
|
+
*/
|
|
15
|
+
autoReviewStatus(input) {
|
|
16
|
+
if (input.retryCount > 1)
|
|
17
|
+
return 'pending';
|
|
18
|
+
if (input.qualityScore !== undefined && input.qualityScore < 0.6)
|
|
19
|
+
return 'pending';
|
|
20
|
+
if (input.outcome === 'failure')
|
|
21
|
+
return 'pending';
|
|
22
|
+
return 'approved';
|
|
23
|
+
}
|
|
24
|
+
/**
|
|
25
|
+
* Auto-generate tags based on trace characteristics.
|
|
26
|
+
*/
|
|
27
|
+
autoTag(input) {
|
|
28
|
+
const tags = [];
|
|
29
|
+
if (input.retryCount > 1)
|
|
30
|
+
tags.push('high-retry');
|
|
31
|
+
if (input.outcome === 'failure')
|
|
32
|
+
tags.push('failure');
|
|
33
|
+
if (input.outcome === 'timeout')
|
|
34
|
+
tags.push('timeout');
|
|
35
|
+
return tags;
|
|
36
|
+
}
|
|
37
|
+
/**
|
|
38
|
+
* Record a trace, auto-generating traceId, capturedAt, reviewStatus, and tags.
|
|
39
|
+
*/
|
|
40
|
+
record(input) {
|
|
41
|
+
const trace = {
|
|
42
|
+
traceId: randomUUID(),
|
|
43
|
+
agentSlug: input.agentSlug,
|
|
44
|
+
agentVersion: input.agentVersion,
|
|
45
|
+
taskDescription: input.taskDescription,
|
|
46
|
+
taskInput: input.taskInput,
|
|
47
|
+
agentOutput: input.agentOutput,
|
|
48
|
+
retryCount: input.retryCount,
|
|
49
|
+
qualityScore: input.qualityScore,
|
|
50
|
+
outcome: input.outcome,
|
|
51
|
+
latencyMs: input.latencyMs,
|
|
52
|
+
tokenCount: input.tokenCount,
|
|
53
|
+
costUsd: input.costUsd,
|
|
54
|
+
capturedAt: new Date().toISOString(),
|
|
55
|
+
reviewStatus: this.autoReviewStatus(input),
|
|
56
|
+
correctedOutput: input.correctedOutput,
|
|
57
|
+
tags: this.autoTag(input),
|
|
58
|
+
};
|
|
59
|
+
// Defensive serialization — agent outputs may contain circular references
|
|
60
|
+
// or BigInt; without this guard the writer crashes mid-trace.
|
|
61
|
+
let serialized;
|
|
62
|
+
try {
|
|
63
|
+
serialized = JSON.stringify(trace);
|
|
64
|
+
}
|
|
65
|
+
catch {
|
|
66
|
+
serialized = JSON.stringify({
|
|
67
|
+
traceId: trace.traceId,
|
|
68
|
+
agentSlug: trace.agentSlug,
|
|
69
|
+
capturedAt: trace.capturedAt,
|
|
70
|
+
reviewStatus: trace.reviewStatus,
|
|
71
|
+
outcome: 'serialize_failed',
|
|
72
|
+
});
|
|
73
|
+
}
|
|
74
|
+
appendFileSync(this.filePath, serialized + '\n', 'utf-8');
|
|
75
|
+
return trace;
|
|
76
|
+
}
|
|
77
|
+
/**
|
|
78
|
+
* Read all traces from the JSONL file.
|
|
79
|
+
*/
|
|
80
|
+
readAll() {
|
|
81
|
+
if (!existsSync(this.filePath))
|
|
82
|
+
return [];
|
|
83
|
+
const stat = statSync(this.filePath);
|
|
84
|
+
if (stat.size > 256 * 1024 * 1024) {
|
|
85
|
+
throw new Error(`Trace file exceeds 256MB (${stat.size} bytes). Run rotation/cleanup.`);
|
|
86
|
+
}
|
|
87
|
+
const content = readFileSync(this.filePath, 'utf-8').trim();
|
|
88
|
+
if (!content)
|
|
89
|
+
return [];
|
|
90
|
+
return parseJsonl(content);
|
|
91
|
+
}
|
|
92
|
+
/**
|
|
93
|
+
* Get traces pending review, with optional limit.
|
|
94
|
+
*/
|
|
95
|
+
getTracesPendingReview(limit) {
|
|
96
|
+
const all = this.readAll().filter((t) => t.reviewStatus === 'pending');
|
|
97
|
+
if (limit !== undefined)
|
|
98
|
+
return all.slice(0, limit);
|
|
99
|
+
return all;
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
//# sourceMappingURL=trace-collector.js.map
|
|
@@ -4,7 +4,7 @@
|
|
|
4
4
|
*
|
|
5
5
|
* github.com/monoes/monomind
|
|
6
6
|
*/
|
|
7
|
-
import { readFileSync } from 'fs';
|
|
7
|
+
import { readFileSync, statSync } from 'fs';
|
|
8
8
|
import { fileURLToPath } from 'url';
|
|
9
9
|
import { dirname, join } from 'path';
|
|
10
10
|
import { commandParser } from './parser.js';
|
|
@@ -19,6 +19,9 @@ function getPackageVersion() {
|
|
|
19
19
|
const __dirname = dirname(__filename);
|
|
20
20
|
// Navigate from dist/src to package root
|
|
21
21
|
const pkgPath = join(__dirname, '..', '..', 'package.json');
|
|
22
|
+
// Guard: skip if package.json is unexpectedly large (> 1 MB)
|
|
23
|
+
if (statSync(pkgPath).size > 1024 * 1024)
|
|
24
|
+
return '3.0.0';
|
|
22
25
|
const pkg = JSON.parse(readFileSync(pkgPath, 'utf-8'));
|
|
23
26
|
return pkg.version || '3.0.0';
|
|
24
27
|
}
|
|
@@ -458,10 +461,11 @@ export class CLI {
|
|
|
458
461
|
catch { /* optional — registry build failures must never block startup */ }
|
|
459
462
|
// Task 04: CapabilityMetadata — validate agent registry at startup
|
|
460
463
|
try {
|
|
461
|
-
const { readFileSync, existsSync } = await import('fs');
|
|
464
|
+
const { readFileSync, existsSync, statSync: statSyncReg } = await import('fs');
|
|
462
465
|
const { join: pathJoin } = await import('path');
|
|
463
466
|
const registryPath = pathJoin(process.cwd(), '.monomind', 'registry.json');
|
|
464
|
-
|
|
467
|
+
const MAX_REGISTRY_BYTES = 10 * 1024 * 1024; // 10 MB
|
|
468
|
+
if (existsSync(registryPath) && statSyncReg(registryPath).size <= MAX_REGISTRY_BYTES) {
|
|
465
469
|
const registry = JSON.parse(readFileSync(registryPath, 'utf-8'));
|
|
466
470
|
const entries = registry.agents ?? [];
|
|
467
471
|
const issues = [];
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* In-Memory Repositories - CLI Infrastructure
|
|
3
|
+
*
|
|
4
|
+
* Lightweight in-memory implementations for CLI use.
|
|
5
|
+
*
|
|
6
|
+
* @module v1/cli/infrastructure
|
|
7
|
+
*/
|
|
8
|
+
import { Agent, AgentStatus, AgentRole } from '../../../swarm/src/domain/entities/agent.js';
|
|
9
|
+
import { Task, TaskStatus, TaskPriority } from '../../../swarm/src/domain/entities/task.js';
|
|
10
|
+
import { IAgentRepository, AgentQueryOptions, AgentStatistics } from '../../../swarm/src/domain/repositories/agent-repository.interface.js';
|
|
11
|
+
import { ITaskRepository, TaskQueryOptions, TaskStatistics } from '../../../swarm/src/domain/repositories/task-repository.interface.js';
|
|
12
|
+
/**
|
|
13
|
+
* In-Memory Agent Repository
|
|
14
|
+
*/
|
|
15
|
+
export declare class InMemoryAgentRepository implements IAgentRepository {
|
|
16
|
+
private agents;
|
|
17
|
+
private initialized;
|
|
18
|
+
initialize(): Promise<void>;
|
|
19
|
+
shutdown(): Promise<void>;
|
|
20
|
+
clear(): Promise<void>;
|
|
21
|
+
save(agent: Agent): Promise<void>;
|
|
22
|
+
findById(id: string): Promise<Agent | null>;
|
|
23
|
+
findByName(name: string): Promise<Agent | null>;
|
|
24
|
+
delete(id: string): Promise<boolean>;
|
|
25
|
+
exists(id: string): Promise<boolean>;
|
|
26
|
+
saveMany(agents: Agent[]): Promise<void>;
|
|
27
|
+
findByIds(ids: string[]): Promise<Agent[]>;
|
|
28
|
+
deleteMany(ids: string[]): Promise<number>;
|
|
29
|
+
findAll(options?: AgentQueryOptions): Promise<Agent[]>;
|
|
30
|
+
findByStatus(status: AgentStatus): Promise<Agent[]>;
|
|
31
|
+
findByRole(role: AgentRole): Promise<Agent[]>;
|
|
32
|
+
findByDomain(domain: string): Promise<Agent[]>;
|
|
33
|
+
findByParent(parentId: string): Promise<Agent[]>;
|
|
34
|
+
findByCapability(capability: string): Promise<Agent[]>;
|
|
35
|
+
findAvailable(): Promise<Agent[]>;
|
|
36
|
+
getStatistics(): Promise<AgentStatistics>;
|
|
37
|
+
count(options?: AgentQueryOptions): Promise<number>;
|
|
38
|
+
}
|
|
39
|
+
/**
|
|
40
|
+
* In-Memory Task Repository
|
|
41
|
+
*/
|
|
42
|
+
export declare class InMemoryTaskRepository implements ITaskRepository {
|
|
43
|
+
private tasks;
|
|
44
|
+
private initialized;
|
|
45
|
+
initialize(): Promise<void>;
|
|
46
|
+
shutdown(): Promise<void>;
|
|
47
|
+
clear(): Promise<void>;
|
|
48
|
+
save(task: Task): Promise<void>;
|
|
49
|
+
findById(id: string): Promise<Task | null>;
|
|
50
|
+
delete(id: string): Promise<boolean>;
|
|
51
|
+
exists(id: string): Promise<boolean>;
|
|
52
|
+
saveMany(tasks: Task[]): Promise<void>;
|
|
53
|
+
findByIds(ids: string[]): Promise<Task[]>;
|
|
54
|
+
deleteMany(ids: string[]): Promise<number>;
|
|
55
|
+
findAll(options?: TaskQueryOptions): Promise<Task[]>;
|
|
56
|
+
findByStatus(status: TaskStatus): Promise<Task[]>;
|
|
57
|
+
findByPriority(priority: TaskPriority): Promise<Task[]>;
|
|
58
|
+
findByAgent(agentId: string): Promise<Task[]>;
|
|
59
|
+
findPending(): Promise<Task[]>;
|
|
60
|
+
findQueued(): Promise<Task[]>;
|
|
61
|
+
findRunning(): Promise<Task[]>;
|
|
62
|
+
findTimedOut(): Promise<Task[]>;
|
|
63
|
+
getNextTask(agentCapabilities?: string[]): Promise<Task | null>;
|
|
64
|
+
getTaskQueue(limit?: number): Promise<Task[]>;
|
|
65
|
+
getStatistics(): Promise<TaskStatistics>;
|
|
66
|
+
count(options?: TaskQueryOptions): Promise<number>;
|
|
67
|
+
}
|
|
68
|
+
//# sourceMappingURL=in-memory-repositories.d.ts.map
|