claude-flow-novice 2.3.4 → 2.3.6
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/src/booster/performance-benchmark.js +1 -1
- package/dist/src/booster/wasm-demo.js +1 -1
- package/dist/src/cli/command-registry.js +2 -2
- package/dist/src/cli/help-formatter.js +137 -109
- package/dist/src/cli/simple-cli.js +2528 -2121
- package/dist/src/cli/simple-commands/sparc/refinement.js +3 -3
- package/dist/src/cli/validation-helper.js +98 -49
- package/dist/src/commands/suggest-templates.js +4 -4
- package/dist/src/core/version.js +23 -15
- package/dist/src/memory/swarm-memory.js +603 -470
- package/dist/src/slash-commands/fullstack.js +2 -2
- package/dist/src/slash-commands/parse-epic.js +1 -1
- package/package.json +1 -1
- package/scripts/postinstall.js +41 -31
- package/dist/scripts/.claude-flow/metrics/agent-metrics.json +0 -1
- package/dist/scripts/.claude-flow/metrics/performance.json +0 -9
- package/dist/scripts/.claude-flow/metrics/task-metrics.json +0 -10
- package/dist/scripts/CLEANUP_OPTIMIZATION_REPORT.json +0 -312
- package/dist/scripts/CLEANUP_PERFORMANCE_OPTIMIZATION.md +0 -387
- package/dist/scripts/CLEANUP_QUICK_START.md +0 -268
- package/dist/scripts/CLEANUP_TEST_RESULTS.md +0 -205
- package/dist/scripts/README.md +0 -339
- package/dist/scripts/ace-query.sh +0 -384
- package/dist/scripts/agent-token-analysis.js +0 -430
- package/dist/scripts/auto-setup.js +0 -332
- package/dist/scripts/build/README.md +0 -167
- package/dist/scripts/build/build-config.js +0 -27
- package/dist/scripts/build/build-prompt-copier.sh +0 -30
- package/dist/scripts/build/performance-monitor.js +0 -869
- package/dist/scripts/build/prepare-publish.js +0 -150
- package/dist/scripts/build/typescript-fixer.js +0 -621
- package/dist/scripts/build/unified-builder.sh +0 -428
- package/dist/scripts/build/update-bin-version.js +0 -32
- package/dist/scripts/build/validate-agents.js +0 -238
- package/dist/scripts/build-index.js +0 -43
- package/dist/scripts/build-orchestrator.js +0 -320
- package/dist/scripts/check-routing-stats.cjs +0 -122
- package/dist/scripts/ci-validation.js +0 -375
- package/dist/scripts/cleanup-blocking-coordination.sh +0 -420
- package/dist/scripts/cleanup-idle-sessions.sh +0 -118
- package/dist/scripts/collect-build-metrics.js +0 -65
- package/dist/scripts/demo/README.md +0 -79
- package/dist/scripts/demo/autoscaling-demo-simplified.js +0 -963
- package/dist/scripts/demo/comprehensive-dashboard-test.js +0 -693
- package/dist/scripts/demo/confidence-log.js +0 -87
- package/dist/scripts/demo/confidence-report.js +0 -82
- package/dist/scripts/demo/demo-multi-swarm-coordination.js +0 -325
- package/dist/scripts/demo/demo-production-deployment.js +0 -399
- package/dist/scripts/demo/demo-visualization-system.js +0 -149
- package/dist/scripts/demo/performance-analysis.cjs +0 -71
- package/dist/scripts/demo/performance-analysis.js +0 -71
- package/dist/scripts/demo/test-autoscaling-demo.js +0 -314
- package/dist/scripts/dependency-optimizer.js +0 -349
- package/dist/scripts/dependency-security-assessment.js +0 -331
- package/dist/scripts/deploy-sdk.sh +0 -176
- package/dist/scripts/deployment-readiness-report.json +0 -179
- package/dist/scripts/dev/README.md +0 -264
- package/dist/scripts/dev/claude-flow-wrapper.sh +0 -35
- package/dist/scripts/dev/claude-monitor.py +0 -419
- package/dist/scripts/dev/claude-sparc.sh +0 -562
- package/dist/scripts/dev/claude-wrapper.sh +0 -17
- package/dist/scripts/dev/demo-phase3-compliance.js +0 -172
- package/dist/scripts/dev/demo-task-system.ts +0 -224
- package/dist/scripts/dev/deployment-validator.js +0 -315
- package/dist/scripts/dev/spawn-claude-terminal.sh +0 -32
- package/dist/scripts/dev/start-portal.sh +0 -506
- package/dist/scripts/dev/start-web-ui.js +0 -15
- package/dist/scripts/dev/stop-portal.sh +0 -311
- package/dist/scripts/dev/validate-examples.ts +0 -288
- package/dist/scripts/dev/validate-phase2.cjs +0 -451
- package/dist/scripts/dev/validate-phase2.js +0 -785
- package/dist/scripts/dev/validate-phase3.cjs +0 -208
- package/dist/scripts/dev/validate-security-remediation.js +0 -1
- package/dist/scripts/ecosystem.config.cjs +0 -90
- package/dist/scripts/enhanced-memory-spiral-killer.sh +0 -221
- package/dist/scripts/fix-js-extensions.js +0 -167
- package/dist/scripts/generate-basic-types.js +0 -73
- package/dist/scripts/generate-changelog.js +0 -318
- package/dist/scripts/git-hooks/pre-commit.sh +0 -143
- package/dist/scripts/health-checks.js +0 -634
- package/dist/scripts/hook-wrapper.sh +0 -54
- package/dist/scripts/install/README.md +0 -375
- package/dist/scripts/install/REDIS_SETUP_VALIDATION.json +0 -245
- package/dist/scripts/install/check-prerequisites.js +0 -303
- package/dist/scripts/install/config-wizard.js +0 -606
- package/dist/scripts/install/dependency-checker.js +0 -385
- package/dist/scripts/install/health-check.js +0 -765
- package/dist/scripts/install/install.js +0 -256
- package/dist/scripts/install/installation-benchmark.js +0 -461
- package/dist/scripts/install/quick-install.js +0 -720
- package/dist/scripts/install/quick-start-wizard.js +0 -295
- package/dist/scripts/install/redis-cli.js +0 -289
- package/dist/scripts/install/redis-install-guides.md +0 -407
- package/dist/scripts/install/redis-setup.js +0 -559
- package/dist/scripts/install/redis-test.js +0 -278
- package/dist/scripts/install/service-manager.js +0 -672
- package/dist/scripts/install/setup.js +0 -832
- package/dist/scripts/install/uninstall.js +0 -526
- package/dist/scripts/install/update.js +0 -461
- package/dist/scripts/install-pre-commit-hook.sh +0 -127
- package/dist/scripts/legacy/README.md +0 -272
- package/dist/scripts/legacy/batch-fix-ts.sh +0 -54
- package/dist/scripts/legacy/build-migration.sh +0 -105
- package/dist/scripts/legacy/build-monitor.js +0 -209
- package/dist/scripts/legacy/build-with-filter.sh +0 -84
- package/dist/scripts/legacy/build-workaround.sh +0 -71
- package/dist/scripts/legacy/fix-ts-advanced.js +0 -358
- package/dist/scripts/legacy/fix-ts-final.sh +0 -50
- package/dist/scripts/legacy/fix-ts-targeted.sh +0 -49
- package/dist/scripts/legacy/fix-typescript-errors.js +0 -305
- package/dist/scripts/legacy/force-build.sh +0 -63
- package/dist/scripts/legacy/optimize-performance.js +0 -400
- package/dist/scripts/legacy/performance-monitor.js +0 -263
- package/dist/scripts/legacy/performance-monitoring.js +0 -532
- package/dist/scripts/legacy/performance-test-runner.js +0 -645
- package/dist/scripts/legacy/quick-fix-ts.js +0 -281
- package/dist/scripts/legacy/safe-build.sh +0 -63
- package/dist/scripts/memory-monitor-coordinator.js +0 -451
- package/dist/scripts/migrate-to-sdk.sh +0 -520
- package/dist/scripts/migration/QUICK-START.md +0 -189
- package/dist/scripts/migration/QUICK-START.md.backup-1760135091363 +0 -189
- package/dist/scripts/migration/README.md +0 -464
- package/dist/scripts/migration/TASK-1.3.2-COMPLETION-REPORT.md +0 -500
- package/dist/scripts/migration/TASK-1.3.2-COMPLETION-REPORT.md.backup-1760135091348 +0 -500
- package/dist/scripts/migration/UPDATE-PATHS-README.md +0 -464
- package/dist/scripts/migration/UPDATE-PATHS-README.md.backup-1760135091337 +0 -464
- package/dist/scripts/migration/example-patterns.json +0 -19
- package/dist/scripts/migration/install-arm64.js +0 -78
- package/dist/scripts/migration/install.js +0 -83
- package/dist/scripts/migration/migrate-hooks.js +0 -173
- package/dist/scripts/migration/migration-examples.ts +0 -318
- package/dist/scripts/migration/reorganize-workspace.js +0 -504
- package/dist/scripts/migration/test-update-paths.js +0 -359
- package/dist/scripts/migration/update-paths.js +0 -664
- package/dist/scripts/migration/validate-migration.js +0 -647
- package/dist/scripts/monitor-loop.sh +0 -65
- package/dist/scripts/monitor-memory.sh +0 -47
- package/dist/scripts/monitor-migration.js +0 -339
- package/dist/scripts/monitor.py +0 -43
- package/dist/scripts/monitoring/README.md +0 -178
- package/dist/scripts/monitoring/alert-monitor.sh +0 -220
- package/dist/scripts/monitoring/analyze-resources.sh +0 -199
- package/dist/scripts/monitoring/dashboards/rate-limiting-dashboard.json +0 -211
- package/dist/scripts/monitoring/dynamic-monitor.sh +0 -85
- package/dist/scripts/monitoring/launch-stability-test.sh +0 -184
- package/dist/scripts/monitoring/monitor-test.sh +0 -93
- package/dist/scripts/monitoring/pre-test-validation.sh +0 -208
- package/dist/scripts/monitoring/quick-test-alerting.sh +0 -118
- package/dist/scripts/monitoring/quick-test-rate-limiting.sh +0 -206
- package/dist/scripts/monitoring/rate-limiting-monitor.sh +0 -380
- package/dist/scripts/monitoring/resource-monitor.sh +0 -126
- package/dist/scripts/monitoring/stability-monitor.js +0 -429
- package/dist/scripts/monitoring/test-monitor-quick.sh +0 -54
- package/dist/scripts/monitoring/view-alerts.sh +0 -307
- package/dist/scripts/npm-metrics-collector.js +0 -482
- package/dist/scripts/npm-package-validation.cjs +0 -299
- package/dist/scripts/optimization/build-optimizer.js +0 -438
- package/dist/scripts/optimization/config-validator.js +0 -761
- package/dist/scripts/optimization/test-optimization.js +0 -432
- package/dist/scripts/optimization/unified-activation.js +0 -839
- package/dist/scripts/optimize-package-swarm.js +0 -54
- package/dist/scripts/performance/ACTIVATION_COMMANDS.md +0 -292
- package/dist/scripts/performance/sqlite-enhanced-activation.sh +0 -583
- package/dist/scripts/performance/test-enhanced-backend.sh +0 -504
- package/dist/scripts/performance-monitor.js +0 -644
- package/dist/scripts/performance-test-runner.js +0 -698
- package/dist/scripts/post-deployment-monitoring.js +0 -350
- package/dist/scripts/post-edit-pipeline.js +0 -2091
- package/dist/scripts/post-install-claude-md.js +0 -78
- package/dist/scripts/postinstall.js +0 -84
- package/dist/scripts/pre-publish-validation.cjs +0 -212
- package/dist/scripts/pre-publish-validation.js +0 -429
- package/dist/scripts/redis-lua/cleanup-blocking-coordination.lua +0 -198
- package/dist/scripts/release-announcement.js +0 -425
- package/dist/scripts/release-notification.js +0 -248
- package/dist/scripts/release-rollback.js +0 -376
- package/dist/scripts/release-validation.js +0 -460
- package/dist/scripts/rollback-sdk.sh +0 -66
- package/dist/scripts/run-production-validation.ts +0 -590
- package/dist/scripts/run-stability-validation.sh +0 -687
- package/dist/scripts/security/README.md +0 -339
- package/dist/scripts/security/deployment-validation.cjs +0 -279
- package/dist/scripts/security/envelope-encryption-confidence-report.cjs +0 -422
- package/dist/scripts/security/install-git-hooks.sh +0 -132
- package/dist/scripts/security/install-git-secrets.sh +0 -295
- package/dist/scripts/security/rotate-api-keys.js +0 -469
- package/dist/scripts/security/ruv-swarm-safe.js +0 -74
- package/dist/scripts/security/security-audit.cjs +0 -538
- package/dist/scripts/security/setup-redis-auth.sh +0 -397
- package/dist/scripts/security/validate-envelope-encryption.cjs +0 -340
- package/dist/scripts/security-scan.js +0 -492
- package/dist/scripts/src/web/frontend/.claude-flow/metrics/agent-metrics.json +0 -1
- package/dist/scripts/src/web/frontend/.claude-flow/metrics/performance.json +0 -9
- package/dist/scripts/src/web/frontend/.claude-flow/metrics/task-metrics.json +0 -10
- package/dist/scripts/switch-api.sh +0 -159
- package/dist/scripts/sync-agents.js +0 -290
- package/dist/scripts/test/50-agent-test.js +0 -625
- package/dist/scripts/test/NEW_STABILITY_TEST_GUIDE.md +0 -407
- package/dist/scripts/test/README.md +0 -236
- package/dist/scripts/test/STABILITY_TEST_EXAMPLE.md +0 -347
- package/dist/scripts/test/STABILITY_TEST_README.md +0 -480
- package/dist/scripts/test/agent-worker.js +0 -309
- package/dist/scripts/test/ai-coordination-test.js +0 -650
- package/dist/scripts/test/ai-mesh-coordination-test.js +0 -416
- package/dist/scripts/test/check-links.ts +0 -274
- package/dist/scripts/test/check-performance-regression.ts +0 -168
- package/dist/scripts/test/cli-agent-coordination-test.js +0 -313
- package/dist/scripts/test/coordinator-multilingual-test.js +0 -396
- package/dist/scripts/test/coordinator-transparency-demo.js +0 -585
- package/dist/scripts/test/coverage-report.ts +0 -692
- package/dist/scripts/test/generate-swarm-tests.js +0 -633
- package/dist/scripts/test/integration-test-validation.cjs +0 -253
- package/dist/scripts/test/load-test-swarm.js +0 -576
- package/dist/scripts/test/mesh-coordination-zero-overlap-test.js +0 -740
- package/dist/scripts/test/multilingual-hello-world-test.js +0 -390
- package/dist/scripts/test/quick-multilingual-demo.js +0 -464
- package/dist/scripts/test/real-agent-test.js +0 -312
- package/dist/scripts/test/run-phase3-compliance-tests.js +0 -427
- package/dist/scripts/test/run-stability-test-examples.sh +0 -292
- package/dist/scripts/test/stability-results/stability-metrics.jsonl +0 -83
- package/dist/scripts/test/stability-results/stability-test-report.json +0 -128
- package/dist/scripts/test/stability-results/stability-test.log +0 -1827
- package/dist/scripts/test/stability-test-50-agents.js +0 -734
- package/dist/scripts/test/test-batch-tasks.ts +0 -29
- package/dist/scripts/test/test-byzantine-resolution.js +0 -246
- package/dist/scripts/test/test-claude-spawn-options.sh +0 -63
- package/dist/scripts/test/test-cli-wizard.js +0 -331
- package/dist/scripts/test/test-comprehensive.js +0 -401
- package/dist/scripts/test/test-coordination-features.ts +0 -238
- package/dist/scripts/test/test-fallback-systems.js +0 -276
- package/dist/scripts/test/test-init-command.ts +0 -302
- package/dist/scripts/test/test-mcp.ts +0 -251
- package/dist/scripts/test/test-runner.ts +0 -568
- package/dist/scripts/test/test-swarm-integration.sh +0 -92
- package/dist/scripts/test/test-swarm.ts +0 -142
- package/dist/scripts/test/validation-summary.ts +0 -408
- package/dist/scripts/test-cleanup-performance.sh +0 -416
- package/dist/scripts/test-dashboard-auth.cjs +0 -203
- package/dist/scripts/test-docker-deployment.sh +0 -207
- package/dist/scripts/test-npm-package.cjs +0 -167
- package/dist/scripts/test-provider-routing.cjs +0 -226
- package/dist/scripts/test-routing-telemetry.cjs +0 -147
- package/dist/scripts/test-runner.cjs +0 -154
- package/dist/scripts/test-zai-10k.cjs +0 -81
- package/dist/scripts/test-zai-api.cjs +0 -191
- package/dist/scripts/test-zai-diagnostic.cjs +0 -151
- package/dist/scripts/test-zai-final.cjs +0 -128
- package/dist/scripts/test-zai-with-env.cjs +0 -85
- package/dist/scripts/toggle-cost-savings.cjs +0 -302
- package/dist/scripts/unified-memory-monitor.js +0 -526
- package/dist/scripts/utils/README.md +0 -261
- package/dist/scripts/utils/clean-build-artifacts.sh +0 -94
- package/dist/scripts/utils/cleanup-root.sh +0 -69
- package/dist/scripts/utils/fix-cliffy-imports.js +0 -307
- package/dist/scripts/utils/fix-duplicate-imports.js +0 -114
- package/dist/scripts/utils/fix-error-handling.cjs +0 -70
- package/dist/scripts/utils/fix-import-paths.js +0 -104
- package/dist/scripts/utils/fix-imports.js +0 -116
- package/dist/scripts/utils/fix-shebang.js +0 -78
- package/dist/scripts/utils/fix-test-modules.js +0 -27
- package/dist/scripts/utils/fix-timezone-issue-246.js +0 -200
- package/dist/scripts/utils/fix-ts-comprehensive.py +0 -182
- package/dist/scripts/utils/fix-ts-targeted-batch.js +0 -250
- package/dist/scripts/utils/remove-benchmark-conflicts.sh +0 -140
- package/dist/scripts/utils/simple-test-fixer.js +0 -190
- package/dist/scripts/utils/validate-metrics-structure.cjs +0 -144
- package/dist/scripts/validate-agent-hooks.js +0 -506
- package/dist/scripts/validate-changelog.js +0 -241
- package/dist/scripts/validate-coordination-cli.js +0 -69
- package/dist/scripts/validate-coordination-toggle-integration.cjs +0 -501
- package/dist/scripts/validate-docker-infrastructure.sh +0 -502
- package/dist/scripts/validate-entry-points.js +0 -300
- package/dist/scripts/validate-memory-monitoring.sh +0 -225
- package/dist/scripts/validate-stage3-performance.ts +0 -377
- package/dist/scripts/validate-template-bundling.js +0 -180
- package/dist/scripts/validation/README.md +0 -33
- package/dist/scripts/validation/acl-security-validation.cjs +0 -214
- package/dist/scripts/validation/acl-security-validation.js +0 -402
- package/dist/scripts/validation/byzantine-verification.js +0 -407
- package/dist/scripts/validation/final-phase-2-consensus.cjs +0 -219
- package/dist/scripts/validation/final-security-validation.js +0 -791
- package/dist/scripts/validation/final-wasm-validation.cjs +0 -840
- package/dist/scripts/validation/integration-test-analysis.js +0 -105
- package/dist/scripts/validation/phase-0-comprehensive-validation.js +0 -474
- package/dist/scripts/validation/phase-0-consensus-report.js +0 -139
- package/dist/scripts/validation/phase-0-final-report.js +0 -112
- package/dist/scripts/validation/phase-0-redis-consensus-report.js +0 -129
- package/dist/scripts/validation/phase-0-validation-improved.js +0 -490
- package/dist/scripts/validation/phase-0-validation-test.js +0 -65
- package/dist/scripts/validation/phase-1-consensus-report.cjs +0 -342
- package/dist/scripts/validation/phase-1-consensus-validation.cjs +0 -551
- package/dist/scripts/validation/phase-1-consensus-validation.js +0 -551
- package/dist/scripts/validation/phase-2-consensus-report.cjs +0 -186
- package/dist/scripts/validation/phase-2-validation.cjs +0 -171
- package/dist/scripts/validation/phase-2-validation.js +0 -171
- package/dist/scripts/validation/phase-4-consensus-report.js +0 -181
- package/dist/scripts/validation/phase-4-final-validation.js +0 -351
- package/dist/scripts/validation/phase-5-consensus-report.cjs +0 -113
- package/dist/scripts/validation/phase-5-consensus-report.js +0 -113
- package/dist/scripts/validation/security-analysis.js +0 -49
- package/dist/scripts/validation/security-validation.js +0 -492
- package/dist/scripts/validation/simple-security-validation.js +0 -464
- package/dist/scripts/verify-installation.js +0 -112
- package/dist/scripts/verify-mcp-server.js +0 -86
- package/dist/scripts/verify-sdk-phase1.cjs +0 -293
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/accessibility/browser/accessibilityService.js +0 -88
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/accessibility/common/accessibility.js +0 -9
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/action/common/action.js +0 -7
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/action/common/actionCommonCategories.js +0 -13
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/actionWidget/browser/actionList.js +0 -276
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/actionWidget/browser/actionWidget.js +0 -248
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/actionWidget/common/actionWidget.js +0 -5
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/actions/common/actions.js +0 -409
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/audioCues/browser/audioCueService.js +0 -176
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/clipboard/browser/clipboardService.js +0 -141
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/clipboard/common/clipboardService.js +0 -6
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/commands/common/commands.js +0 -80
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/configuration/common/configuration.js +0 -86
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/configuration/common/configurationModels.js +0 -554
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/configuration/common/configurationRegistry.js +0 -317
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/configuration/common/configurations.js +0 -41
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/contextkey/browser/contextKeyService.js +0 -432
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/contextkey/common/contextkey.js +0 -1547
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/contextkey/common/contextkeys.js +0 -18
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/contextview/browser/contextMenuHandler.js +0 -124
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/contextview/browser/contextMenuService.js +0 -101
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/contextview/browser/contextView.js +0 -7
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/contextview/browser/contextViewService.js +0 -72
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/dialogs/common/dialogs.js +0 -2
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/dnd/browser/dnd.js +0 -36
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/editor/common/editor.js +0 -17
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/environment/common/environment.js +0 -2
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/extensions/common/extensions.js +0 -47
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/files/common/files.js +0 -9
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/history/browser/contextScopedHistoryWidget.js +0 -105
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/instantiation/common/descriptors.js +0 -11
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/instantiation/common/extensions.js +0 -15
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/keybinding/common/abstractKeybindingService.js +0 -277
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/keybinding/common/baseResolvedKeybinding.js +0 -53
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/quickinput/browser/commandsQuickAccess.js +0 -354
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/theme/browser/defaultStyles.js +0 -162
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/esm/vs/platform/theme/common/colorRegistry.js +0 -482
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/min/vs/basic-languages/abap/abap.js +0 -10
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/min/vs/basic-languages/apex/apex.js +0 -10
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/min/vs/basic-languages/azcli/azcli.js +0 -10
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/min/vs/basic-languages/bat/bat.js +0 -10
- package/dist/src/web/frontend/node_modules/.monaco-editor-MndU045b/min/vs/basic-languages/bicep/bicep.js +0 -11
|
@@ -1,471 +1,604 @@
|
|
|
1
|
-
function _define_property(obj, key, value) {
|
|
2
|
-
if (key in obj) {
|
|
3
|
-
Object.defineProperty(obj, key, {
|
|
4
|
-
value: value,
|
|
5
|
-
enumerable: true,
|
|
6
|
-
configurable: true,
|
|
7
|
-
writable: true
|
|
8
|
-
});
|
|
9
|
-
} else {
|
|
10
|
-
obj[key] = value;
|
|
11
|
-
}
|
|
12
|
-
return obj;
|
|
13
|
-
}
|
|
14
|
-
import { EventEmitter } from "node:events";
|
|
15
|
-
import { Logger } from "../core/logger.js";
|
|
16
|
-
import { MemoryManager } from "./manager.js";
|
|
17
|
-
import { EventBus } from "../core/event-bus.js";
|
|
18
|
-
import { generateId } from "../utils/helpers.js";
|
|
19
|
-
import * as fs from "node:fs/promises";
|
|
20
|
-
import * as path from "node:path";
|
|
21
|
-
export class SwarmMemoryManager extends EventEmitter {
|
|
22
|
-
async initialize() {
|
|
23
|
-
if (this.isInitialized) return;
|
|
24
|
-
this.logger.info('Initializing swarm memory manager...');
|
|
25
|
-
// Initialize base memory
|
|
26
|
-
await this.baseMemory.initialize();
|
|
27
|
-
// Create persistence directory
|
|
28
|
-
await fs.mkdir(this.config.persistencePath, {
|
|
29
|
-
recursive: true
|
|
30
|
-
});
|
|
31
|
-
// Load existing memory
|
|
32
|
-
await this.loadMemoryState();
|
|
33
|
-
// Start sync timer
|
|
34
|
-
if (this.config.syncInterval > 0) {
|
|
35
|
-
this.syncTimer = setInterval(()=>{
|
|
36
|
-
this.syncMemoryState();
|
|
37
|
-
}, this.config.syncInterval);
|
|
38
|
-
}
|
|
39
|
-
this.isInitialized = true;
|
|
40
|
-
this.emit('memory:initialized');
|
|
41
|
-
}
|
|
42
|
-
async shutdown() {
|
|
43
|
-
if (!this.isInitialized) return;
|
|
44
|
-
this.logger.info('Shutting down swarm memory manager...');
|
|
45
|
-
// Stop sync timer
|
|
46
|
-
if (this.syncTimer) {
|
|
47
|
-
clearInterval(this.syncTimer);
|
|
48
|
-
this.syncTimer = undefined;
|
|
49
|
-
}
|
|
50
|
-
// Save final state
|
|
51
|
-
await this.saveMemoryState();
|
|
52
|
-
this.isInitialized = false;
|
|
53
|
-
this.emit('memory:shutdown');
|
|
54
|
-
}
|
|
55
|
-
/**
|
|
56
|
-
* Close database connections and cleanup resources
|
|
57
|
-
* Alias for shutdown() to match test expectations
|
|
58
|
-
*/ async close() {
|
|
59
|
-
await this.shutdown();
|
|
60
|
-
}
|
|
61
|
-
async remember(agentId, type, content, metadata = {}) {
|
|
62
|
-
const entryId = generateId('mem');
|
|
63
|
-
const entry = {
|
|
64
|
-
id: entryId,
|
|
65
|
-
agentId,
|
|
66
|
-
type,
|
|
67
|
-
content,
|
|
68
|
-
timestamp: new Date(),
|
|
69
|
-
metadata: {
|
|
70
|
-
shareLevel: 'team',
|
|
71
|
-
priority: 1,
|
|
72
|
-
...metadata
|
|
73
|
-
}
|
|
74
|
-
};
|
|
75
|
-
this.entries.set(entryId, entry);
|
|
76
|
-
// Associate with agent
|
|
77
|
-
if (!this.agentMemories.has(agentId)) {
|
|
78
|
-
this.agentMemories.set(agentId, new Set());
|
|
79
|
-
}
|
|
80
|
-
this.agentMemories.get(agentId).add(entryId);
|
|
81
|
-
// Store in base memory for persistence
|
|
82
|
-
await this.baseMemory.store({
|
|
83
|
-
id: `entry:${entryId}`,
|
|
84
|
-
agentId,
|
|
85
|
-
sessionId: metadata.taskId || 'swarm-session',
|
|
86
|
-
type: 'artifact',
|
|
87
|
-
content: JSON.stringify(entry),
|
|
88
|
-
context: {
|
|
89
|
-
entryType: type,
|
|
90
|
-
shareLevel: entry.metadata.shareLevel
|
|
91
|
-
},
|
|
92
|
-
timestamp: entry.timestamp,
|
|
93
|
-
tags: metadata.tags || [],
|
|
94
|
-
version: 1
|
|
95
|
-
});
|
|
96
|
-
this.logger.debug(`Agent ${agentId} remembered: ${type} - ${entryId}`);
|
|
97
|
-
this.emit('memory:added', entry);
|
|
98
|
-
// Update knowledge base if applicable
|
|
99
|
-
if (type === 'knowledge' && this.config.enableKnowledgeBase) {
|
|
100
|
-
await this.updateKnowledgeBase(entry);
|
|
101
|
-
}
|
|
102
|
-
// Check for memory limits
|
|
103
|
-
await this.enforceMemoryLimits();
|
|
104
|
-
return entryId;
|
|
105
|
-
}
|
|
106
|
-
async recall(query) {
|
|
107
|
-
let results = Array.from(this.entries.values());
|
|
108
|
-
// Apply filters
|
|
109
|
-
if (query.agentId) {
|
|
110
|
-
results = results.filter((e)=>e.agentId === query.agentId);
|
|
111
|
-
}
|
|
112
|
-
if (query.type) {
|
|
113
|
-
results = results.filter((e)=>e.type === query.type);
|
|
114
|
-
}
|
|
115
|
-
if (query.taskId) {
|
|
116
|
-
results = results.filter((e)=>e.metadata.taskId === query.taskId);
|
|
117
|
-
}
|
|
118
|
-
if (query.objectiveId) {
|
|
119
|
-
results = results.filter((e)=>e.metadata.objectiveId === query.objectiveId);
|
|
120
|
-
}
|
|
121
|
-
if (query.tags && query.tags.length > 0) {
|
|
122
|
-
results = results.filter((e)=>e.metadata.tags && query.tags.some((tag)=>e.metadata.tags.includes(tag)));
|
|
123
|
-
}
|
|
124
|
-
if (query.since) {
|
|
125
|
-
results = results.filter((e)=>e.timestamp >= query.since);
|
|
126
|
-
}
|
|
127
|
-
if (query.before) {
|
|
128
|
-
results = results.filter((e)=>e.timestamp <= query.before);
|
|
129
|
-
}
|
|
130
|
-
if (query.shareLevel) {
|
|
131
|
-
results = results.filter((e)=>e.metadata.shareLevel === query.shareLevel);
|
|
132
|
-
}
|
|
133
|
-
// Sort by timestamp (newest first)
|
|
134
|
-
results.sort((a, b)=>b.timestamp.getTime() - a.timestamp.getTime());
|
|
135
|
-
// Apply limit
|
|
136
|
-
if (query.limit) {
|
|
137
|
-
results = results.slice(0, query.limit);
|
|
138
|
-
}
|
|
139
|
-
this.logger.debug(`Recalled ${results.length} memories for query`);
|
|
140
|
-
return results;
|
|
141
|
-
}
|
|
142
|
-
async shareMemory(entryId, targetAgentId) {
|
|
143
|
-
const entry = this.entries.get(entryId);
|
|
144
|
-
if (!entry) {
|
|
145
|
-
throw new Error('Memory entry not found');
|
|
146
|
-
}
|
|
147
|
-
if (!this.config.enableCrossAgentSharing) {
|
|
148
|
-
throw new Error('Cross-agent sharing is disabled');
|
|
149
|
-
}
|
|
150
|
-
// Check share level permissions
|
|
151
|
-
if (entry.metadata.shareLevel === 'private') {
|
|
152
|
-
throw new Error('Memory entry is private and cannot be shared');
|
|
153
|
-
}
|
|
154
|
-
// Create a shared copy for the target agent
|
|
155
|
-
const sharedEntry = {
|
|
156
|
-
...entry,
|
|
157
|
-
id: generateId('mem'),
|
|
158
|
-
metadata: {
|
|
159
|
-
...entry.metadata,
|
|
160
|
-
originalId: entryId,
|
|
161
|
-
sharedFrom: entry.agentId,
|
|
162
|
-
sharedTo: targetAgentId,
|
|
163
|
-
sharedAt: new Date()
|
|
164
|
-
}
|
|
165
|
-
};
|
|
166
|
-
this.entries.set(sharedEntry.id, sharedEntry);
|
|
167
|
-
// Associate with target agent
|
|
168
|
-
if (!this.agentMemories.has(targetAgentId)) {
|
|
169
|
-
this.agentMemories.set(targetAgentId, new Set());
|
|
170
|
-
}
|
|
171
|
-
this.agentMemories.get(targetAgentId).add(sharedEntry.id);
|
|
172
|
-
this.logger.info(`Shared memory ${entryId} from ${entry.agentId} to ${targetAgentId}`);
|
|
173
|
-
this.emit('memory:shared', {
|
|
174
|
-
original: entry,
|
|
175
|
-
shared: sharedEntry
|
|
176
|
-
});
|
|
177
|
-
}
|
|
178
|
-
async broadcastMemory(entryId, agentIds) {
|
|
179
|
-
const entry = this.entries.get(entryId);
|
|
180
|
-
if (!entry) {
|
|
181
|
-
throw new Error('Memory entry not found');
|
|
182
|
-
}
|
|
183
|
-
if (entry.metadata.shareLevel === 'private') {
|
|
184
|
-
throw new Error('Cannot broadcast private memory');
|
|
185
|
-
}
|
|
186
|
-
const targets = agentIds || Array.from(this.agentMemories.keys()).filter((id)=>id !== entry.agentId);
|
|
187
|
-
for (const targetId of targets){
|
|
188
|
-
try {
|
|
189
|
-
await this.shareMemory(entryId, targetId);
|
|
190
|
-
} catch (error) {
|
|
191
|
-
this.logger.warn(`Failed to share memory to ${targetId}:`, error);
|
|
192
|
-
}
|
|
193
|
-
}
|
|
194
|
-
this.logger.info(`Broadcasted memory ${entryId} to ${targets.length} agents`);
|
|
195
|
-
}
|
|
196
|
-
async createKnowledgeBase(name, description, domain, expertise) {
|
|
197
|
-
const kbId = generateId('kb');
|
|
198
|
-
const knowledgeBase = {
|
|
199
|
-
id: kbId,
|
|
200
|
-
name,
|
|
201
|
-
description,
|
|
202
|
-
entries: [],
|
|
203
|
-
metadata: {
|
|
204
|
-
domain,
|
|
205
|
-
expertise,
|
|
206
|
-
contributors: [],
|
|
207
|
-
lastUpdated: new Date()
|
|
208
|
-
}
|
|
209
|
-
};
|
|
210
|
-
this.knowledgeBases.set(kbId, knowledgeBase);
|
|
211
|
-
this.logger.info(`Created knowledge base: ${name} (${kbId})`);
|
|
212
|
-
this.emit('knowledgebase:created', knowledgeBase);
|
|
213
|
-
return kbId;
|
|
214
|
-
}
|
|
215
|
-
async updateKnowledgeBase(entry) {
|
|
216
|
-
if (!this.config.enableKnowledgeBase) return;
|
|
217
|
-
// Find relevant knowledge bases
|
|
218
|
-
const relevantKBs = Array.from(this.knowledgeBases.values()).filter((kb)=>{
|
|
219
|
-
// Simple matching based on tags and content
|
|
220
|
-
const tags = entry.metadata.tags || [];
|
|
221
|
-
return tags.some((tag)=>kb.metadata.expertise.some((exp)=>exp.toLowerCase().includes(tag.toLowerCase()) || tag.toLowerCase().includes(exp.toLowerCase())));
|
|
222
|
-
});
|
|
223
|
-
for (const kb of relevantKBs){
|
|
224
|
-
// Add entry to knowledge base
|
|
225
|
-
kb.entries.push(entry);
|
|
226
|
-
kb.metadata.lastUpdated = new Date();
|
|
227
|
-
// Add contributor
|
|
228
|
-
if (!kb.metadata.contributors.includes(entry.agentId)) {
|
|
229
|
-
kb.metadata.contributors.push(entry.agentId);
|
|
230
|
-
}
|
|
231
|
-
this.logger.debug(`Updated knowledge base ${kb.id} with entry ${entry.id}`);
|
|
232
|
-
}
|
|
233
|
-
}
|
|
234
|
-
async searchKnowledge(query, domain, expertise) {
|
|
235
|
-
const allEntries = [];
|
|
236
|
-
// Search in knowledge bases
|
|
237
|
-
for (const kb of this.knowledgeBases.values()){
|
|
238
|
-
if (domain && kb.metadata.domain !== domain) continue;
|
|
239
|
-
if (expertise && !expertise.some((exp)=>kb.metadata.expertise.includes(exp))) {
|
|
240
|
-
continue;
|
|
241
|
-
}
|
|
242
|
-
allEntries.push(...kb.entries);
|
|
243
|
-
}
|
|
244
|
-
// Simple text search (in real implementation, use better search)
|
|
245
|
-
const queryLower = query.toLowerCase();
|
|
246
|
-
const results = allEntries.filter((entry)=>{
|
|
247
|
-
const contentStr = JSON.stringify(entry.content).toLowerCase();
|
|
248
|
-
return contentStr.includes(queryLower);
|
|
249
|
-
});
|
|
250
|
-
return results.slice(0, 50); // Limit results
|
|
251
|
-
}
|
|
252
|
-
async getAgentMemorySnapshot(agentId) {
|
|
253
|
-
const agentEntryIds = this.agentMemories.get(agentId) || new Set();
|
|
254
|
-
const agentEntries = Array.from(agentEntryIds).map((id)=>this.entries.get(id)).filter(Boolean);
|
|
255
|
-
const recentEntries = agentEntries.sort((a, b)=>b.timestamp.getTime() - a.timestamp.getTime()).slice(0, 10);
|
|
256
|
-
const knowledgeContributions = agentEntries.filter((e)=>e.type === 'knowledge').length;
|
|
257
|
-
const sharedEntries = agentEntries.filter((e)=>e.metadata.shareLevel === 'public' || e.metadata.shareLevel === 'team').length;
|
|
258
|
-
return {
|
|
259
|
-
totalEntries: agentEntries.length,
|
|
260
|
-
recentEntries,
|
|
261
|
-
knowledgeContributions,
|
|
262
|
-
sharedEntries
|
|
263
|
-
};
|
|
264
|
-
}
|
|
265
|
-
async loadMemoryState() {
|
|
266
|
-
try {
|
|
267
|
-
// Load entries
|
|
268
|
-
const entriesFile = path.join(this.config.persistencePath, 'entries.json');
|
|
269
|
-
try {
|
|
270
|
-
const entriesData = await fs.readFile(entriesFile, 'utf-8');
|
|
271
|
-
const entriesArray = JSON.parse(entriesData);
|
|
272
|
-
for (const entry of entriesArray){
|
|
273
|
-
this.entries.set(entry.id, {
|
|
274
|
-
...entry,
|
|
275
|
-
timestamp: new Date(entry.timestamp)
|
|
276
|
-
});
|
|
277
|
-
// Rebuild agent memory associations
|
|
278
|
-
if (!this.agentMemories.has(entry.agentId)) {
|
|
279
|
-
this.agentMemories.set(entry.agentId, new Set());
|
|
280
|
-
}
|
|
281
|
-
this.agentMemories.get(entry.agentId).add(entry.id);
|
|
282
|
-
}
|
|
283
|
-
this.logger.info(`Loaded ${entriesArray.length} memory entries`);
|
|
284
|
-
} catch (error) {
|
|
285
|
-
this.logger.warn('No existing memory entries found');
|
|
286
|
-
}
|
|
287
|
-
// Load knowledge bases
|
|
288
|
-
const kbFile = path.join(this.config.persistencePath, 'knowledge-bases.json');
|
|
289
|
-
try {
|
|
290
|
-
const kbData = await fs.readFile(kbFile, 'utf-8');
|
|
291
|
-
const kbArray = JSON.parse(kbData);
|
|
292
|
-
for (const kb of kbArray){
|
|
293
|
-
this.knowledgeBases.set(kb.id, {
|
|
294
|
-
...kb,
|
|
295
|
-
metadata: {
|
|
296
|
-
...kb.metadata,
|
|
297
|
-
lastUpdated: new Date(kb.metadata.lastUpdated)
|
|
298
|
-
},
|
|
299
|
-
entries: kb.entries.map((e)=>({
|
|
300
|
-
...e,
|
|
301
|
-
timestamp: new Date(e.timestamp)
|
|
302
|
-
}))
|
|
303
|
-
});
|
|
304
|
-
}
|
|
305
|
-
this.logger.info(`Loaded ${kbArray.length} knowledge bases`);
|
|
306
|
-
} catch (error) {
|
|
307
|
-
this.logger.warn('No existing knowledge bases found');
|
|
308
|
-
}
|
|
309
|
-
} catch (error) {
|
|
310
|
-
this.logger.error('Error loading memory state:', error);
|
|
311
|
-
}
|
|
312
|
-
}
|
|
313
|
-
async saveMemoryState() {
|
|
314
|
-
try {
|
|
315
|
-
// Save entries
|
|
316
|
-
const entriesArray = Array.from(this.entries.values());
|
|
317
|
-
const entriesFile = path.join(this.config.persistencePath, 'entries.json');
|
|
318
|
-
await fs.writeFile(entriesFile, JSON.stringify(entriesArray, null, 2));
|
|
319
|
-
// Save knowledge bases
|
|
320
|
-
const kbArray = Array.from(this.knowledgeBases.values());
|
|
321
|
-
const kbFile = path.join(this.config.persistencePath, 'knowledge-bases.json');
|
|
322
|
-
await fs.writeFile(kbFile, JSON.stringify(kbArray, null, 2));
|
|
323
|
-
this.logger.debug('Saved memory state to disk');
|
|
324
|
-
} catch (error) {
|
|
325
|
-
this.logger.error('Error saving memory state:', error);
|
|
326
|
-
}
|
|
327
|
-
}
|
|
328
|
-
async syncMemoryState() {
|
|
329
|
-
try {
|
|
330
|
-
await this.saveMemoryState();
|
|
331
|
-
this.emit('memory:synced');
|
|
332
|
-
} catch (error) {
|
|
333
|
-
this.logger.error('Error syncing memory state:', error);
|
|
334
|
-
}
|
|
335
|
-
}
|
|
336
|
-
async enforceMemoryLimits() {
|
|
337
|
-
if (this.entries.size <= this.config.maxEntries) return;
|
|
338
|
-
this.logger.info('Enforcing memory limits...');
|
|
339
|
-
// Remove oldest entries that are not marked as important
|
|
340
|
-
const entries = Array.from(this.entries.values()).filter((e)=>(e.metadata.priority || 1) <= 1) // Only remove low priority
|
|
341
|
-
.sort((a, b)=>a.timestamp.getTime() - b.timestamp.getTime());
|
|
342
|
-
const toRemove = entries.slice(0, this.entries.size - this.config.maxEntries);
|
|
343
|
-
for (const entry of toRemove){
|
|
344
|
-
this.entries.delete(entry.id);
|
|
345
|
-
// Remove from agent memory
|
|
346
|
-
const agentEntries = this.agentMemories.get(entry.agentId);
|
|
347
|
-
if (agentEntries) {
|
|
348
|
-
agentEntries.delete(entry.id);
|
|
349
|
-
}
|
|
350
|
-
this.logger.debug(`Removed old memory entry: ${entry.id}`);
|
|
351
|
-
}
|
|
352
|
-
this.emit('memory:cleaned', toRemove.length);
|
|
353
|
-
}
|
|
354
|
-
// Public API methods
|
|
355
|
-
getMemoryStats() {
|
|
356
|
-
const entries = Array.from(this.entries.values());
|
|
357
|
-
const entriesByType = {};
|
|
358
|
-
const entriesByAgent = {};
|
|
359
|
-
for (const entry of entries){
|
|
360
|
-
entriesByType[entry.type] = (entriesByType[entry.type] || 0) + 1;
|
|
361
|
-
entriesByAgent[entry.agentId] = (entriesByAgent[entry.agentId] || 0) + 1;
|
|
362
|
-
}
|
|
363
|
-
// Rough memory usage calculation
|
|
364
|
-
const memoryUsage = JSON.stringify(entries).length;
|
|
365
|
-
return {
|
|
366
|
-
totalEntries: entries.length,
|
|
367
|
-
entriesByType,
|
|
368
|
-
entriesByAgent,
|
|
369
|
-
knowledgeBases: this.knowledgeBases.size,
|
|
370
|
-
memoryUsage
|
|
371
|
-
};
|
|
372
|
-
}
|
|
373
|
-
async exportMemory(agentId) {
|
|
374
|
-
const entries = agentId ? await this.recall({
|
|
375
|
-
agentId
|
|
376
|
-
}) : Array.from(this.entries.values());
|
|
377
|
-
return {
|
|
378
|
-
entries,
|
|
379
|
-
knowledgeBases: agentId ? Array.from(this.knowledgeBases.values()).filter((kb)=>kb.metadata.contributors.includes(agentId)) : Array.from(this.knowledgeBases.values()),
|
|
380
|
-
exportedAt: new Date(),
|
|
381
|
-
stats: this.getMemoryStats()
|
|
382
|
-
};
|
|
383
|
-
}
|
|
384
|
-
async clearMemory(agentId) {
|
|
385
|
-
if (agentId) {
|
|
386
|
-
// Clear specific agent's memory
|
|
387
|
-
const entryIds = this.agentMemories.get(agentId) || new Set();
|
|
388
|
-
for (const entryId of entryIds){
|
|
389
|
-
this.entries.delete(entryId);
|
|
390
|
-
}
|
|
391
|
-
this.agentMemories.delete(agentId);
|
|
392
|
-
this.logger.info(`Cleared memory for agent ${agentId}`);
|
|
393
|
-
} else {
|
|
394
|
-
// Clear all memory
|
|
395
|
-
this.entries.clear();
|
|
396
|
-
this.agentMemories.clear();
|
|
397
|
-
this.knowledgeBases.clear();
|
|
398
|
-
this.logger.info('Cleared all swarm memory');
|
|
399
|
-
}
|
|
400
|
-
this.emit('memory:cleared', {
|
|
401
|
-
agentId
|
|
402
|
-
});
|
|
403
|
-
}
|
|
404
|
-
// Compatibility methods for hive.ts
|
|
405
|
-
async store(key, value) {
|
|
406
|
-
// Extract namespace and actual key from the path
|
|
407
|
-
const parts = key.split('/');
|
|
408
|
-
const type = parts[0] || 'state';
|
|
409
|
-
const agentId = parts[1] || 'system';
|
|
410
|
-
await this.remember(agentId, type, value, {
|
|
411
|
-
tags: [
|
|
412
|
-
parts[0],
|
|
413
|
-
parts[1]
|
|
414
|
-
].filter(Boolean),
|
|
415
|
-
shareLevel: 'team'
|
|
416
|
-
});
|
|
417
|
-
}
|
|
418
|
-
async search(pattern, limit = 10) {
|
|
419
|
-
// Simple pattern matching on stored keys/content
|
|
420
|
-
const results = [];
|
|
421
|
-
for (const entry of this.entries.values()){
|
|
422
|
-
const entryString = JSON.stringify(entry);
|
|
423
|
-
if (entryString.includes(pattern.replace('*', ''))) {
|
|
424
|
-
results.push(entry.content);
|
|
425
|
-
if (results.length >= limit) break;
|
|
426
|
-
}
|
|
427
|
-
}
|
|
428
|
-
return results;
|
|
429
|
-
}
|
|
430
|
-
constructor(config = {}){
|
|
431
|
-
super(), _define_property(this, "logger", void 0), _define_property(this, "config", void 0), _define_property(this, "baseMemory", void 0), _define_property(this, "entries", void 0), _define_property(this, "knowledgeBases", void 0), _define_property(this, "agentMemories", void 0 // agentId -> set of entry IDs
|
|
432
|
-
), _define_property(this, "syncTimer", void 0), _define_property(this, "isInitialized", false);
|
|
433
|
-
this.logger = new Logger({
|
|
434
|
-
level: 'info',
|
|
435
|
-
format: 'json',
|
|
436
|
-
destination: 'console'
|
|
437
|
-
}, {
|
|
438
|
-
component: 'SwarmMemoryManager'
|
|
439
|
-
});
|
|
440
|
-
this.config = {
|
|
441
|
-
namespace: 'swarm',
|
|
442
|
-
enableDistribution: true,
|
|
443
|
-
enableReplication: true,
|
|
444
|
-
syncInterval: 10000,
|
|
445
|
-
maxEntries: 10000,
|
|
446
|
-
compressionThreshold: 1000,
|
|
447
|
-
enableKnowledgeBase: true,
|
|
448
|
-
enableCrossAgentSharing: true,
|
|
449
|
-
persistencePath: './swarm-memory',
|
|
450
|
-
...config
|
|
451
|
-
};
|
|
452
|
-
this.entries = new Map();
|
|
453
|
-
this.knowledgeBases = new Map();
|
|
454
|
-
this.agentMemories = new Map();
|
|
455
|
-
const eventBus = EventBus.getInstance();
|
|
456
|
-
this.baseMemory = new MemoryManager({
|
|
457
|
-
backend: 'sqlite',
|
|
458
|
-
cacheSizeMB: 50,
|
|
459
|
-
syncInterval: 5000,
|
|
460
|
-
conflictResolution: 'last-write',
|
|
461
|
-
retentionDays: 30,
|
|
462
|
-
sqlitePath: './swarm-memory.db'
|
|
463
|
-
}, eventBus, this.logger);
|
|
464
|
-
}
|
|
465
|
-
}
|
|
466
1
|
/**
|
|
467
|
-
*
|
|
468
|
-
* Provides
|
|
469
|
-
|
|
470
|
-
|
|
471
|
-
|
|
2
|
+
* SwarmMemory - MCP-specific memory persistence extending SharedMemory
|
|
3
|
+
* Provides swarm-specific features like agent coordination, task tracking, and neural patterns
|
|
4
|
+
*
|
|
5
|
+
* @module swarm-memory
|
|
6
|
+
*/
|
|
7
|
+
|
|
8
|
+
import { SharedMemory } from './shared-memory.js';
|
|
9
|
+
import path from 'path';
|
|
10
|
+
|
|
11
|
+
/**
|
|
12
|
+
* Swarm-specific namespaces
|
|
13
|
+
*/
|
|
14
|
+
const SWARM_NAMESPACES = {
|
|
15
|
+
AGENTS: 'swarm:agents',
|
|
16
|
+
TASKS: 'swarm:tasks',
|
|
17
|
+
COMMUNICATIONS: 'swarm:communications',
|
|
18
|
+
CONSENSUS: 'swarm:consensus',
|
|
19
|
+
PATTERNS: 'swarm:patterns',
|
|
20
|
+
METRICS: 'swarm:metrics',
|
|
21
|
+
COORDINATION: 'swarm:coordination',
|
|
22
|
+
};
|
|
23
|
+
|
|
24
|
+
/**
|
|
25
|
+
* SwarmMemory class - Extends SharedMemory with MCP features
|
|
26
|
+
*/
|
|
27
|
+
export class SwarmMemory extends SharedMemory {
|
|
28
|
+
constructor(options = {}) {
|
|
29
|
+
// Default to .swarm directory for MCP
|
|
30
|
+
super({
|
|
31
|
+
directory: options.directory || '.swarm',
|
|
32
|
+
filename: options.filename || 'swarm-memory.db',
|
|
33
|
+
...options,
|
|
34
|
+
});
|
|
35
|
+
|
|
36
|
+
this.swarmId = options.swarmId || 'default';
|
|
37
|
+
this.mcpMode = options.mcpMode !== false;
|
|
38
|
+
|
|
39
|
+
// Additional swarm-specific caches
|
|
40
|
+
this.agentCache = new Map();
|
|
41
|
+
this.taskCache = new Map();
|
|
42
|
+
this.patternCache = new Map();
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
/**
|
|
46
|
+
* Initialize with swarm-specific setup
|
|
47
|
+
*/
|
|
48
|
+
async initialize() {
|
|
49
|
+
await super.initialize();
|
|
50
|
+
|
|
51
|
+
// Initialize swarm-specific namespaces
|
|
52
|
+
await this._initializeSwarmNamespaces();
|
|
53
|
+
|
|
54
|
+
// Load active agents and tasks into cache
|
|
55
|
+
await this._loadSwarmState();
|
|
56
|
+
|
|
57
|
+
this.emit('swarm:initialized', { swarmId: this.swarmId });
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
/**
|
|
61
|
+
* Store agent information
|
|
62
|
+
*/
|
|
63
|
+
async storeAgent(agentId, agentData) {
|
|
64
|
+
const key = `agent:${agentId}`;
|
|
65
|
+
const enrichedData = {
|
|
66
|
+
...agentData,
|
|
67
|
+
swarmId: this.swarmId,
|
|
68
|
+
lastUpdated: new Date().toISOString(),
|
|
69
|
+
};
|
|
70
|
+
|
|
71
|
+
await this.store(key, enrichedData, {
|
|
72
|
+
namespace: SWARM_NAMESPACES.AGENTS,
|
|
73
|
+
tags: ['agent', agentData.type, agentData.status],
|
|
74
|
+
metadata: {
|
|
75
|
+
swarmId: this.swarmId,
|
|
76
|
+
agentType: agentData.type,
|
|
77
|
+
},
|
|
78
|
+
});
|
|
79
|
+
|
|
80
|
+
// Update agent cache
|
|
81
|
+
this.agentCache.set(agentId, enrichedData);
|
|
82
|
+
|
|
83
|
+
this.emit('swarm:agentStored', { agentId, type: agentData.type });
|
|
84
|
+
|
|
85
|
+
return { agentId, stored: true };
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
/**
|
|
89
|
+
* Retrieve agent information
|
|
90
|
+
*/
|
|
91
|
+
async getAgent(agentId) {
|
|
92
|
+
// Check cache first
|
|
93
|
+
if (this.agentCache.has(agentId)) {
|
|
94
|
+
return this.agentCache.get(agentId);
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
const key = `agent:${agentId}`;
|
|
98
|
+
const agent = await this.retrieve(key, SWARM_NAMESPACES.AGENTS);
|
|
99
|
+
|
|
100
|
+
if (agent) {
|
|
101
|
+
this.agentCache.set(agentId, agent);
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
return agent;
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
/**
|
|
108
|
+
* List all agents in swarm
|
|
109
|
+
*/
|
|
110
|
+
async listAgents(filter = {}) {
|
|
111
|
+
const agents = await this.list(SWARM_NAMESPACES.AGENTS, {
|
|
112
|
+
limit: filter.limit || 100,
|
|
113
|
+
});
|
|
114
|
+
|
|
115
|
+
return agents
|
|
116
|
+
.map((entry) => entry.value)
|
|
117
|
+
.filter((agent) => {
|
|
118
|
+
if (filter.type && agent.type !== filter.type) return false;
|
|
119
|
+
if (filter.status && agent.status !== filter.status) return false;
|
|
120
|
+
if (filter.swarmId && agent.swarmId !== filter.swarmId) return false;
|
|
121
|
+
return true;
|
|
122
|
+
});
|
|
123
|
+
}
|
|
124
|
+
|
|
125
|
+
/**
|
|
126
|
+
* Store task information
|
|
127
|
+
*/
|
|
128
|
+
async storeTask(taskId, taskData) {
|
|
129
|
+
const key = `task:${taskId}`;
|
|
130
|
+
const enrichedData = {
|
|
131
|
+
...taskData,
|
|
132
|
+
swarmId: this.swarmId,
|
|
133
|
+
createdAt: taskData.createdAt || new Date().toISOString(),
|
|
134
|
+
updatedAt: new Date().toISOString(),
|
|
135
|
+
};
|
|
136
|
+
|
|
137
|
+
await this.store(key, enrichedData, {
|
|
138
|
+
namespace: SWARM_NAMESPACES.TASKS,
|
|
139
|
+
tags: ['task', taskData.status, taskData.priority],
|
|
140
|
+
metadata: {
|
|
141
|
+
swarmId: this.swarmId,
|
|
142
|
+
assignedAgents: taskData.assignedAgents || [],
|
|
143
|
+
},
|
|
144
|
+
});
|
|
145
|
+
|
|
146
|
+
// Update task cache
|
|
147
|
+
this.taskCache.set(taskId, enrichedData);
|
|
148
|
+
|
|
149
|
+
this.emit('swarm:taskStored', { taskId, status: taskData.status });
|
|
150
|
+
|
|
151
|
+
return { taskId, stored: true };
|
|
152
|
+
}
|
|
153
|
+
|
|
154
|
+
/**
|
|
155
|
+
* Update task status
|
|
156
|
+
*/
|
|
157
|
+
async updateTaskStatus(taskId, status, result = null) {
|
|
158
|
+
const task = await this.getTask(taskId);
|
|
159
|
+
if (!task) {
|
|
160
|
+
throw new Error(`Task ${taskId} not found`);
|
|
161
|
+
}
|
|
162
|
+
|
|
163
|
+
task.status = status;
|
|
164
|
+
task.updatedAt = new Date().toISOString();
|
|
165
|
+
|
|
166
|
+
if (result) {
|
|
167
|
+
task.result = result;
|
|
168
|
+
}
|
|
169
|
+
|
|
170
|
+
if (status === 'completed') {
|
|
171
|
+
task.completedAt = new Date().toISOString();
|
|
172
|
+
}
|
|
173
|
+
|
|
174
|
+
await this.storeTask(taskId, task);
|
|
175
|
+
|
|
176
|
+
this.emit('swarm:taskStatusUpdated', { taskId, status });
|
|
177
|
+
|
|
178
|
+
return { taskId, status, updated: true };
|
|
179
|
+
}
|
|
180
|
+
|
|
181
|
+
/**
|
|
182
|
+
* Get task information
|
|
183
|
+
*/
|
|
184
|
+
async getTask(taskId) {
|
|
185
|
+
// Check cache first
|
|
186
|
+
if (this.taskCache.has(taskId)) {
|
|
187
|
+
return this.taskCache.get(taskId);
|
|
188
|
+
}
|
|
189
|
+
|
|
190
|
+
const key = `task:${taskId}`;
|
|
191
|
+
const task = await this.retrieve(key, SWARM_NAMESPACES.TASKS);
|
|
192
|
+
|
|
193
|
+
if (task) {
|
|
194
|
+
this.taskCache.set(taskId, task);
|
|
195
|
+
}
|
|
196
|
+
|
|
197
|
+
return task;
|
|
198
|
+
}
|
|
199
|
+
|
|
200
|
+
/**
|
|
201
|
+
* Store inter-agent communication
|
|
202
|
+
*/
|
|
203
|
+
async storeCommunication(fromAgent, toAgent, message) {
|
|
204
|
+
const commId = `comm:${Date.now()}-${Math.random().toString(36).substr(2, 9)}`;
|
|
205
|
+
const communication = {
|
|
206
|
+
id: commId,
|
|
207
|
+
fromAgent,
|
|
208
|
+
toAgent,
|
|
209
|
+
message,
|
|
210
|
+
swarmId: this.swarmId,
|
|
211
|
+
timestamp: new Date().toISOString(),
|
|
212
|
+
};
|
|
213
|
+
|
|
214
|
+
await this.store(commId, communication, {
|
|
215
|
+
namespace: SWARM_NAMESPACES.COMMUNICATIONS,
|
|
216
|
+
ttl: 86400, // 24 hours
|
|
217
|
+
tags: ['communication', message.type],
|
|
218
|
+
metadata: {
|
|
219
|
+
fromAgent,
|
|
220
|
+
toAgent,
|
|
221
|
+
messageType: message.type,
|
|
222
|
+
},
|
|
223
|
+
});
|
|
224
|
+
|
|
225
|
+
this.emit('swarm:communication', { fromAgent, toAgent, type: message.type });
|
|
226
|
+
|
|
227
|
+
return { id: commId, stored: true };
|
|
228
|
+
}
|
|
229
|
+
|
|
230
|
+
/**
|
|
231
|
+
* Store consensus decision
|
|
232
|
+
*/
|
|
233
|
+
async storeConsensus(consensusId, decision) {
|
|
234
|
+
const key = `consensus:${consensusId}`;
|
|
235
|
+
const consensusData = {
|
|
236
|
+
...decision,
|
|
237
|
+
swarmId: this.swarmId,
|
|
238
|
+
timestamp: new Date().toISOString(),
|
|
239
|
+
};
|
|
240
|
+
|
|
241
|
+
await this.store(key, consensusData, {
|
|
242
|
+
namespace: SWARM_NAMESPACES.CONSENSUS,
|
|
243
|
+
tags: ['consensus', decision.status],
|
|
244
|
+
metadata: {
|
|
245
|
+
swarmId: this.swarmId,
|
|
246
|
+
taskId: decision.taskId,
|
|
247
|
+
threshold: decision.threshold,
|
|
248
|
+
},
|
|
249
|
+
});
|
|
250
|
+
|
|
251
|
+
this.emit('swarm:consensus', { consensusId, status: decision.status });
|
|
252
|
+
|
|
253
|
+
return { consensusId, stored: true };
|
|
254
|
+
}
|
|
255
|
+
|
|
256
|
+
/**
|
|
257
|
+
* Store neural pattern
|
|
258
|
+
*/
|
|
259
|
+
async storePattern(patternId, pattern) {
|
|
260
|
+
const key = `pattern:${patternId}`;
|
|
261
|
+
const patternData = {
|
|
262
|
+
...pattern,
|
|
263
|
+
swarmId: this.swarmId,
|
|
264
|
+
createdAt: new Date().toISOString(),
|
|
265
|
+
usageCount: 0,
|
|
266
|
+
successRate: 0,
|
|
267
|
+
};
|
|
268
|
+
|
|
269
|
+
await this.store(key, patternData, {
|
|
270
|
+
namespace: SWARM_NAMESPACES.PATTERNS,
|
|
271
|
+
tags: ['pattern', pattern.type],
|
|
272
|
+
metadata: {
|
|
273
|
+
swarmId: this.swarmId,
|
|
274
|
+
patternType: pattern.type,
|
|
275
|
+
confidence: pattern.confidence || 0,
|
|
276
|
+
},
|
|
277
|
+
});
|
|
278
|
+
|
|
279
|
+
// Cache frequently used patterns
|
|
280
|
+
if (pattern.type === 'coordination' || pattern.type === 'optimization') {
|
|
281
|
+
this.patternCache.set(patternId, patternData);
|
|
282
|
+
}
|
|
283
|
+
|
|
284
|
+
this.emit('swarm:patternStored', { patternId, type: pattern.type });
|
|
285
|
+
|
|
286
|
+
return { patternId, stored: true };
|
|
287
|
+
}
|
|
288
|
+
|
|
289
|
+
/**
|
|
290
|
+
* Update pattern usage and success metrics
|
|
291
|
+
*/
|
|
292
|
+
async updatePatternMetrics(patternId, success = true) {
|
|
293
|
+
const pattern = await this.getPattern(patternId);
|
|
294
|
+
if (!pattern) {
|
|
295
|
+
throw new Error(`Pattern ${patternId} not found`);
|
|
296
|
+
}
|
|
297
|
+
|
|
298
|
+
pattern.usageCount++;
|
|
299
|
+
pattern.lastUsedAt = new Date().toISOString();
|
|
300
|
+
|
|
301
|
+
// Update success rate with exponential moving average
|
|
302
|
+
const alpha = 0.1; // Smoothing factor
|
|
303
|
+
const currentSuccess = success ? 1 : 0;
|
|
304
|
+
pattern.successRate = alpha * currentSuccess + (1 - alpha) * (pattern.successRate || 0);
|
|
305
|
+
|
|
306
|
+
await this.storePattern(patternId, pattern);
|
|
307
|
+
|
|
308
|
+
return { patternId, usageCount: pattern.usageCount, successRate: pattern.successRate };
|
|
309
|
+
}
|
|
310
|
+
|
|
311
|
+
/**
|
|
312
|
+
* Get pattern
|
|
313
|
+
*/
|
|
314
|
+
async getPattern(patternId) {
|
|
315
|
+
// Check cache first
|
|
316
|
+
if (this.patternCache.has(patternId)) {
|
|
317
|
+
return this.patternCache.get(patternId);
|
|
318
|
+
}
|
|
319
|
+
|
|
320
|
+
const key = `pattern:${patternId}`;
|
|
321
|
+
return await this.retrieve(key, SWARM_NAMESPACES.PATTERNS);
|
|
322
|
+
}
|
|
323
|
+
|
|
324
|
+
/**
|
|
325
|
+
* Find best patterns for a given context
|
|
326
|
+
*/
|
|
327
|
+
async findBestPatterns(context, limit = 5) {
|
|
328
|
+
const patterns = await this.search({
|
|
329
|
+
namespace: SWARM_NAMESPACES.PATTERNS,
|
|
330
|
+
tags: context.tags,
|
|
331
|
+
limit: 100,
|
|
332
|
+
});
|
|
333
|
+
|
|
334
|
+
// Score patterns based on success rate and relevance
|
|
335
|
+
const scored = patterns.map((entry) => {
|
|
336
|
+
const pattern = entry.value;
|
|
337
|
+
const score =
|
|
338
|
+
pattern.successRate * 0.7 +
|
|
339
|
+
(pattern.confidence || 0) * 0.2 +
|
|
340
|
+
(pattern.usageCount > 0 ? 0.1 : 0);
|
|
341
|
+
|
|
342
|
+
return { ...pattern, score };
|
|
343
|
+
});
|
|
344
|
+
|
|
345
|
+
// Sort by score and return top patterns
|
|
346
|
+
return scored.sort((a, b) => b.score - a.score).slice(0, limit);
|
|
347
|
+
}
|
|
348
|
+
|
|
349
|
+
/**
|
|
350
|
+
* Store coordination state
|
|
351
|
+
*/
|
|
352
|
+
async storeCoordination(key, state) {
|
|
353
|
+
await this.store(key, state, {
|
|
354
|
+
namespace: SWARM_NAMESPACES.COORDINATION,
|
|
355
|
+
ttl: 3600, // 1 hour
|
|
356
|
+
metadata: {
|
|
357
|
+
swarmId: this.swarmId,
|
|
358
|
+
timestamp: new Date().toISOString(),
|
|
359
|
+
},
|
|
360
|
+
});
|
|
361
|
+
|
|
362
|
+
return { key, stored: true };
|
|
363
|
+
}
|
|
364
|
+
|
|
365
|
+
/**
|
|
366
|
+
* Get coordination state
|
|
367
|
+
*/
|
|
368
|
+
async getCoordination(key) {
|
|
369
|
+
return await this.retrieve(key, SWARM_NAMESPACES.COORDINATION);
|
|
370
|
+
}
|
|
371
|
+
|
|
372
|
+
/**
|
|
373
|
+
* Store performance metrics
|
|
374
|
+
*/
|
|
375
|
+
async storeMetrics(metricsId, metrics) {
|
|
376
|
+
const key = `metrics:${metricsId}`;
|
|
377
|
+
await this.store(key, metrics, {
|
|
378
|
+
namespace: SWARM_NAMESPACES.METRICS,
|
|
379
|
+
ttl: 86400 * 7, // 7 days
|
|
380
|
+
tags: ['metrics', metrics.type],
|
|
381
|
+
metadata: {
|
|
382
|
+
swarmId: this.swarmId,
|
|
383
|
+
agentId: metrics.agentId,
|
|
384
|
+
timestamp: new Date().toISOString(),
|
|
385
|
+
},
|
|
386
|
+
});
|
|
387
|
+
|
|
388
|
+
this.emit('swarm:metricsStored', { metricsId, type: metrics.type });
|
|
389
|
+
|
|
390
|
+
return { metricsId, stored: true };
|
|
391
|
+
}
|
|
392
|
+
|
|
393
|
+
/**
|
|
394
|
+
* Get swarm statistics
|
|
395
|
+
*/
|
|
396
|
+
async getSwarmStats() {
|
|
397
|
+
const baseStats = await this.getStats();
|
|
398
|
+
|
|
399
|
+
// Add swarm-specific stats
|
|
400
|
+
const agentCount = await this._countNamespace(SWARM_NAMESPACES.AGENTS);
|
|
401
|
+
const taskCount = await this._countNamespace(SWARM_NAMESPACES.TASKS);
|
|
402
|
+
const patternCount = await this._countNamespace(SWARM_NAMESPACES.PATTERNS);
|
|
403
|
+
|
|
404
|
+
// Get active agents
|
|
405
|
+
const activeAgents = Array.from(this.agentCache.values()).filter(
|
|
406
|
+
(agent) => agent.status === 'active' || agent.status === 'busy',
|
|
407
|
+
).length;
|
|
408
|
+
|
|
409
|
+
// Get task statistics
|
|
410
|
+
const tasks = Array.from(this.taskCache.values());
|
|
411
|
+
const taskStats = {
|
|
412
|
+
total: tasks.length,
|
|
413
|
+
pending: tasks.filter((t) => t.status === 'pending').length,
|
|
414
|
+
inProgress: tasks.filter((t) => t.status === 'in_progress').length,
|
|
415
|
+
completed: tasks.filter((t) => t.status === 'completed').length,
|
|
416
|
+
failed: tasks.filter((t) => t.status === 'failed').length,
|
|
417
|
+
};
|
|
418
|
+
|
|
419
|
+
return {
|
|
420
|
+
...baseStats,
|
|
421
|
+
swarm: {
|
|
422
|
+
swarmId: this.swarmId,
|
|
423
|
+
agents: {
|
|
424
|
+
total: agentCount,
|
|
425
|
+
active: activeAgents,
|
|
426
|
+
cached: this.agentCache.size,
|
|
427
|
+
},
|
|
428
|
+
tasks: taskStats,
|
|
429
|
+
patterns: {
|
|
430
|
+
total: patternCount,
|
|
431
|
+
cached: this.patternCache.size,
|
|
432
|
+
},
|
|
433
|
+
namespaces: Object.values(SWARM_NAMESPACES),
|
|
434
|
+
},
|
|
435
|
+
};
|
|
436
|
+
}
|
|
437
|
+
|
|
438
|
+
/**
|
|
439
|
+
* Clean up old swarm data
|
|
440
|
+
*/
|
|
441
|
+
async cleanupSwarmData(options = {}) {
|
|
442
|
+
const {
|
|
443
|
+
maxAge = 86400 * 7, // 7 days
|
|
444
|
+
keepPatterns = true,
|
|
445
|
+
keepConsensus = true,
|
|
446
|
+
} = options;
|
|
447
|
+
|
|
448
|
+
const cutoffTime = Date.now() - maxAge * 1000;
|
|
449
|
+
let cleaned = 0;
|
|
450
|
+
|
|
451
|
+
// Clean old communications
|
|
452
|
+
const comms = await this.list(SWARM_NAMESPACES.COMMUNICATIONS);
|
|
453
|
+
for (const comm of comms) {
|
|
454
|
+
if (new Date(comm.value.timestamp).getTime() < cutoffTime) {
|
|
455
|
+
await this.delete(comm.key, SWARM_NAMESPACES.COMMUNICATIONS);
|
|
456
|
+
cleaned++;
|
|
457
|
+
}
|
|
458
|
+
}
|
|
459
|
+
|
|
460
|
+
// Clean completed tasks
|
|
461
|
+
const tasks = await this.list(SWARM_NAMESPACES.TASKS);
|
|
462
|
+
for (const task of tasks) {
|
|
463
|
+
if (
|
|
464
|
+
task.value.status === 'completed' &&
|
|
465
|
+
new Date(task.value.completedAt).getTime() < cutoffTime
|
|
466
|
+
) {
|
|
467
|
+
await this.delete(task.key, SWARM_NAMESPACES.TASKS);
|
|
468
|
+
this.taskCache.delete(task.value.id);
|
|
469
|
+
cleaned++;
|
|
470
|
+
}
|
|
471
|
+
}
|
|
472
|
+
|
|
473
|
+
// Clean old metrics
|
|
474
|
+
const metrics = await this.list(SWARM_NAMESPACES.METRICS);
|
|
475
|
+
for (const metric of metrics) {
|
|
476
|
+
if (new Date(metric.createdAt).getTime() < cutoffTime) {
|
|
477
|
+
await this.delete(metric.key, SWARM_NAMESPACES.METRICS);
|
|
478
|
+
cleaned++;
|
|
479
|
+
}
|
|
480
|
+
}
|
|
481
|
+
|
|
482
|
+
this.emit('swarm:cleanup', { cleaned, maxAge });
|
|
483
|
+
|
|
484
|
+
return { cleaned };
|
|
485
|
+
}
|
|
486
|
+
|
|
487
|
+
/**
|
|
488
|
+
* Export swarm state
|
|
489
|
+
*/
|
|
490
|
+
async exportSwarmState() {
|
|
491
|
+
const agents = await this.listAgents();
|
|
492
|
+
const tasks = Array.from(this.taskCache.values());
|
|
493
|
+
const patterns = await this.list(SWARM_NAMESPACES.PATTERNS);
|
|
494
|
+
|
|
495
|
+
return {
|
|
496
|
+
swarmId: this.swarmId,
|
|
497
|
+
exportedAt: new Date().toISOString(),
|
|
498
|
+
agents: agents,
|
|
499
|
+
tasks: tasks,
|
|
500
|
+
patterns: patterns.map((p) => p.value),
|
|
501
|
+
statistics: await this.getSwarmStats(),
|
|
502
|
+
};
|
|
503
|
+
}
|
|
504
|
+
|
|
505
|
+
/**
|
|
506
|
+
* Import swarm state
|
|
507
|
+
*/
|
|
508
|
+
async importSwarmState(state) {
|
|
509
|
+
let imported = {
|
|
510
|
+
agents: 0,
|
|
511
|
+
tasks: 0,
|
|
512
|
+
patterns: 0,
|
|
513
|
+
};
|
|
514
|
+
|
|
515
|
+
// Import agents
|
|
516
|
+
if (state.agents) {
|
|
517
|
+
for (const agent of state.agents) {
|
|
518
|
+
await this.storeAgent(agent.id, agent);
|
|
519
|
+
imported.agents++;
|
|
520
|
+
}
|
|
521
|
+
}
|
|
522
|
+
|
|
523
|
+
// Import tasks
|
|
524
|
+
if (state.tasks) {
|
|
525
|
+
for (const task of state.tasks) {
|
|
526
|
+
await this.storeTask(task.id, task);
|
|
527
|
+
imported.tasks++;
|
|
528
|
+
}
|
|
529
|
+
}
|
|
530
|
+
|
|
531
|
+
// Import patterns
|
|
532
|
+
if (state.patterns) {
|
|
533
|
+
for (const pattern of state.patterns) {
|
|
534
|
+
await this.storePattern(pattern.id, pattern);
|
|
535
|
+
imported.patterns++;
|
|
536
|
+
}
|
|
537
|
+
}
|
|
538
|
+
|
|
539
|
+
this.emit('swarm:imported', imported);
|
|
540
|
+
|
|
541
|
+
return imported;
|
|
542
|
+
}
|
|
543
|
+
|
|
544
|
+
/**
|
|
545
|
+
* Private helper methods
|
|
546
|
+
*/
|
|
547
|
+
|
|
548
|
+
async _initializeSwarmNamespaces() {
|
|
549
|
+
// Create swarm metadata
|
|
550
|
+
await this.store(
|
|
551
|
+
'swarm:metadata',
|
|
552
|
+
{
|
|
553
|
+
swarmId: this.swarmId,
|
|
554
|
+
createdAt: new Date().toISOString(),
|
|
555
|
+
version: '1.0.0',
|
|
556
|
+
namespaces: Object.values(SWARM_NAMESPACES),
|
|
557
|
+
},
|
|
558
|
+
{
|
|
559
|
+
namespace: 'swarm:system',
|
|
560
|
+
},
|
|
561
|
+
);
|
|
562
|
+
}
|
|
563
|
+
|
|
564
|
+
async _loadSwarmState() {
|
|
565
|
+
// Load active agents
|
|
566
|
+
const agents = await this.list(SWARM_NAMESPACES.AGENTS, { limit: 100 });
|
|
567
|
+
for (const entry of agents) {
|
|
568
|
+
if (entry.value.status === 'active' || entry.value.status === 'busy') {
|
|
569
|
+
this.agentCache.set(entry.value.id, entry.value);
|
|
570
|
+
}
|
|
571
|
+
}
|
|
572
|
+
|
|
573
|
+
// Load in-progress tasks
|
|
574
|
+
const tasks = await this.search({
|
|
575
|
+
namespace: SWARM_NAMESPACES.TASKS,
|
|
576
|
+
tags: ['in_progress'],
|
|
577
|
+
limit: 100,
|
|
578
|
+
});
|
|
579
|
+
for (const entry of tasks) {
|
|
580
|
+
this.taskCache.set(entry.value.id, entry.value);
|
|
581
|
+
}
|
|
582
|
+
|
|
583
|
+
// Load high-confidence patterns
|
|
584
|
+
const patterns = await this.list(SWARM_NAMESPACES.PATTERNS, { limit: 50 });
|
|
585
|
+
for (const entry of patterns) {
|
|
586
|
+
if (entry.value.confidence > 0.7 || entry.value.successRate > 0.8) {
|
|
587
|
+
this.patternCache.set(entry.value.id, entry.value);
|
|
588
|
+
}
|
|
589
|
+
}
|
|
590
|
+
}
|
|
591
|
+
|
|
592
|
+
async _countNamespace(namespace) {
|
|
593
|
+
const stats = await this.getStats();
|
|
594
|
+
return stats.namespaces[namespace]?.count || 0;
|
|
595
|
+
}
|
|
596
|
+
}
|
|
597
|
+
|
|
598
|
+
// Export factory function for easy creation
|
|
599
|
+
export function createSwarmMemory(options = {}) {
|
|
600
|
+
return new SwarmMemory(options);
|
|
601
|
+
}
|
|
602
|
+
|
|
603
|
+
// Export for backwards compatibility
|
|
604
|
+
export default SwarmMemory;
|