claude-mpm 4.25.10__py3-none-any.whl → 5.1.8__py3-none-any.whl
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.
Potentially problematic release.
This version of claude-mpm might be problematic. Click here for more details.
- claude_mpm/VERSION +1 -1
- claude_mpm/agents/BASE_PM.md +12 -0
- claude_mpm/agents/PM_INSTRUCTIONS.md +1055 -2230
- claude_mpm/agents/PM_INSTRUCTIONS_TEACH.md +1322 -0
- claude_mpm/agents/WORKFLOW.md +4 -4
- claude_mpm/agents/__init__.py +6 -0
- claude_mpm/agents/agent_loader.py +1 -4
- claude_mpm/agents/base_agent_loader.py +10 -35
- claude_mpm/agents/templates/{circuit_breakers.md → circuit-breakers.md} +576 -66
- claude_mpm/agents/templates/context-management-examples.md +544 -0
- claude_mpm/agents/templates/pr-workflow-examples.md +427 -0
- claude_mpm/agents/templates/research-gate-examples.md +669 -0
- claude_mpm/agents/templates/structured-questions-examples.md +615 -0
- claude_mpm/agents/templates/ticket-completeness-examples.md +139 -0
- claude_mpm/agents/templates/ticketing-examples.md +277 -0
- claude_mpm/cli/__init__.py +28 -3
- claude_mpm/cli/commands/__init__.py +2 -0
- claude_mpm/cli/commands/agent_source.py +774 -0
- claude_mpm/cli/commands/agent_state_manager.py +188 -30
- claude_mpm/cli/commands/agents.py +959 -36
- claude_mpm/cli/commands/agents_cleanup.py +210 -0
- claude_mpm/cli/commands/agents_discover.py +338 -0
- claude_mpm/cli/commands/auto_configure.py +537 -239
- claude_mpm/cli/commands/config.py +7 -4
- claude_mpm/cli/commands/configure.py +924 -45
- claude_mpm/cli/commands/configure_navigation.py +63 -46
- claude_mpm/cli/commands/doctor.py +10 -2
- claude_mpm/cli/commands/local_deploy.py +1 -4
- claude_mpm/cli/commands/postmortem.py +401 -0
- claude_mpm/cli/commands/run.py +1 -39
- claude_mpm/cli/commands/skill_source.py +694 -0
- claude_mpm/cli/commands/skills.py +322 -19
- claude_mpm/cli/executor.py +22 -3
- claude_mpm/cli/interactive/agent_wizard.py +1028 -43
- claude_mpm/cli/parsers/agent_source_parser.py +171 -0
- claude_mpm/cli/parsers/agents_parser.py +256 -4
- claude_mpm/cli/parsers/auto_configure_parser.py +13 -0
- claude_mpm/cli/parsers/base_parser.py +25 -0
- claude_mpm/cli/parsers/config_parser.py +96 -43
- claude_mpm/cli/parsers/skill_source_parser.py +169 -0
- claude_mpm/cli/parsers/skills_parser.py +7 -0
- claude_mpm/cli/parsers/source_parser.py +138 -0
- claude_mpm/cli/startup.py +456 -103
- claude_mpm/cli/startup_display.py +4 -4
- claude_mpm/commands/{mpm-auto-configure.md → mpm-agents-auto-configure.md} +9 -0
- claude_mpm/commands/mpm-agents-detect.md +9 -0
- claude_mpm/commands/{mpm-agents.md → mpm-agents-list.md} +9 -0
- claude_mpm/commands/mpm-agents-recommend.md +9 -0
- claude_mpm/commands/{mpm-config.md → mpm-config-view.md} +9 -0
- claude_mpm/commands/mpm-doctor.md +9 -0
- claude_mpm/commands/mpm-help.md +14 -2
- claude_mpm/commands/mpm-init.md +9 -0
- claude_mpm/commands/mpm-monitor.md +9 -0
- claude_mpm/commands/mpm-postmortem.md +123 -0
- claude_mpm/commands/{mpm-resume.md → mpm-session-resume.md} +9 -0
- claude_mpm/commands/mpm-status.md +9 -0
- claude_mpm/commands/{mpm-organize.md → mpm-ticket-organize.md} +9 -0
- claude_mpm/commands/mpm-ticket-view.md +552 -0
- claude_mpm/commands/mpm-version.md +9 -0
- claude_mpm/commands/mpm.md +10 -0
- claude_mpm/config/agent_presets.py +488 -0
- claude_mpm/config/agent_sources.py +325 -0
- claude_mpm/config/skill_presets.py +392 -0
- claude_mpm/config/skill_sources.py +590 -0
- claude_mpm/constants.py +1 -0
- claude_mpm/core/claude_runner.py +5 -34
- claude_mpm/core/config.py +16 -0
- claude_mpm/core/framework/__init__.py +3 -16
- claude_mpm/core/framework/loaders/file_loader.py +54 -101
- claude_mpm/core/framework/loaders/instruction_loader.py +25 -5
- claude_mpm/core/interactive_session.py +83 -7
- claude_mpm/core/oneshot_session.py +71 -8
- claude_mpm/core/protocols/__init__.py +23 -0
- claude_mpm/core/protocols/runner_protocol.py +103 -0
- claude_mpm/core/protocols/session_protocol.py +131 -0
- claude_mpm/core/shared/singleton_manager.py +11 -4
- claude_mpm/core/system_context.py +38 -0
- claude_mpm/core/unified_config.py +22 -0
- claude_mpm/experimental/cli_enhancements.py +1 -5
- claude_mpm/hooks/claude_hooks/__pycache__/__init__.cpython-313.pyc +0 -0
- claude_mpm/hooks/claude_hooks/__pycache__/event_handlers.cpython-313.pyc +0 -0
- claude_mpm/hooks/claude_hooks/__pycache__/hook_handler.cpython-313.pyc +0 -0
- claude_mpm/hooks/claude_hooks/__pycache__/memory_integration.cpython-313.pyc +0 -0
- claude_mpm/hooks/claude_hooks/__pycache__/response_tracking.cpython-313.pyc +0 -0
- claude_mpm/hooks/claude_hooks/__pycache__/tool_analysis.cpython-313.pyc +0 -0
- claude_mpm/hooks/claude_hooks/memory_integration.py +12 -1
- claude_mpm/hooks/claude_hooks/services/__pycache__/__init__.cpython-313.pyc +0 -0
- claude_mpm/hooks/claude_hooks/services/__pycache__/connection_manager_http.cpython-313.pyc +0 -0
- claude_mpm/hooks/claude_hooks/services/__pycache__/duplicate_detector.cpython-313.pyc +0 -0
- claude_mpm/hooks/claude_hooks/services/__pycache__/state_manager.cpython-313.pyc +0 -0
- claude_mpm/hooks/claude_hooks/services/__pycache__/subagent_processor.cpython-313.pyc +0 -0
- claude_mpm/hooks/failure_learning/__init__.py +2 -8
- claude_mpm/hooks/failure_learning/failure_detection_hook.py +1 -6
- claude_mpm/hooks/failure_learning/fix_detection_hook.py +1 -6
- claude_mpm/hooks/failure_learning/learning_extraction_hook.py +1 -6
- claude_mpm/hooks/kuzu_response_hook.py +1 -5
- claude_mpm/models/git_repository.py +198 -0
- claude_mpm/services/agents/agent_builder.py +45 -9
- claude_mpm/services/agents/agent_preset_service.py +238 -0
- claude_mpm/services/agents/agent_selection_service.py +484 -0
- claude_mpm/services/agents/auto_deploy_index_parser.py +569 -0
- claude_mpm/services/agents/cache_git_manager.py +621 -0
- claude_mpm/services/agents/deployment/agent_deployment.py +126 -2
- claude_mpm/services/agents/deployment/agent_discovery_service.py +105 -73
- claude_mpm/services/agents/deployment/agent_lifecycle_manager.py +1 -5
- claude_mpm/services/agents/deployment/agent_restore_handler.py +1 -4
- claude_mpm/services/agents/deployment/agent_template_builder.py +236 -15
- claude_mpm/services/agents/deployment/agents_directory_resolver.py +101 -15
- claude_mpm/services/agents/deployment/async_agent_deployment.py +2 -1
- claude_mpm/services/agents/deployment/multi_source_deployment_service.py +115 -15
- claude_mpm/services/agents/deployment/refactored_agent_deployment_service.py +1 -4
- claude_mpm/services/agents/deployment/remote_agent_discovery_service.py +363 -0
- claude_mpm/services/agents/deployment/single_agent_deployer.py +2 -2
- claude_mpm/services/agents/deployment/system_instructions_deployer.py +168 -46
- claude_mpm/services/agents/deployment/validation/deployment_validator.py +2 -2
- claude_mpm/services/agents/git_source_manager.py +629 -0
- claude_mpm/services/agents/loading/framework_agent_loader.py +1 -4
- claude_mpm/services/agents/local_template_manager.py +47 -9
- claude_mpm/services/agents/single_tier_deployment_service.py +696 -0
- claude_mpm/services/agents/sources/__init__.py +13 -0
- claude_mpm/services/agents/sources/agent_sync_state.py +516 -0
- claude_mpm/services/agents/sources/git_source_sync_service.py +1087 -0
- claude_mpm/services/agents/startup_sync.py +239 -0
- claude_mpm/services/agents/toolchain_detector.py +474 -0
- claude_mpm/services/analysis/__init__.py +25 -0
- claude_mpm/services/analysis/postmortem_reporter.py +474 -0
- claude_mpm/services/analysis/postmortem_service.py +765 -0
- claude_mpm/services/command_deployment_service.py +200 -6
- claude_mpm/services/core/base.py +7 -2
- claude_mpm/services/core/interfaces/__init__.py +1 -3
- claude_mpm/services/core/interfaces/health.py +1 -4
- claude_mpm/services/core/models/__init__.py +2 -11
- claude_mpm/services/diagnostics/checks/__init__.py +4 -0
- claude_mpm/services/diagnostics/checks/agent_sources_check.py +577 -0
- claude_mpm/services/diagnostics/checks/mcp_services_check.py +7 -15
- claude_mpm/services/diagnostics/checks/skill_sources_check.py +587 -0
- claude_mpm/services/diagnostics/diagnostic_runner.py +9 -0
- claude_mpm/services/diagnostics/doctor_reporter.py +34 -6
- claude_mpm/services/git/__init__.py +21 -0
- claude_mpm/services/git/git_operations_service.py +494 -0
- claude_mpm/services/github/__init__.py +21 -0
- claude_mpm/services/github/github_cli_service.py +397 -0
- claude_mpm/services/infrastructure/monitoring/__init__.py +1 -5
- claude_mpm/services/infrastructure/monitoring/aggregator.py +1 -6
- claude_mpm/services/instructions/__init__.py +9 -0
- claude_mpm/services/instructions/instruction_cache_service.py +374 -0
- claude_mpm/services/local_ops/__init__.py +3 -13
- claude_mpm/services/local_ops/health_checks/__init__.py +1 -3
- claude_mpm/services/local_ops/health_manager.py +1 -4
- claude_mpm/services/mcp_config_manager.py +75 -145
- claude_mpm/services/mcp_gateway/core/process_pool.py +22 -16
- claude_mpm/services/mcp_gateway/server/mcp_gateway.py +1 -6
- claude_mpm/services/mcp_service_verifier.py +6 -3
- claude_mpm/services/monitor/daemon.py +28 -8
- claude_mpm/services/monitor/daemon_manager.py +96 -19
- claude_mpm/services/pr/__init__.py +14 -0
- claude_mpm/services/pr/pr_template_service.py +329 -0
- claude_mpm/services/project/project_organizer.py +4 -0
- claude_mpm/services/runner_configuration_service.py +16 -3
- claude_mpm/services/session_management_service.py +16 -4
- claude_mpm/services/skills/__init__.py +18 -0
- claude_mpm/services/skills/git_skill_source_manager.py +1169 -0
- claude_mpm/services/skills/skill_discovery_service.py +568 -0
- claude_mpm/services/socketio/server/core.py +1 -4
- claude_mpm/services/socketio/server/main.py +1 -3
- claude_mpm/services/unified/deployment_strategies/vercel.py +1 -5
- claude_mpm/services/unified/unified_deployment.py +1 -5
- claude_mpm/services/visualization/__init__.py +1 -5
- claude_mpm/templates/questions/__init__.py +2 -7
- claude_mpm/templates/questions/pr_strategy.py +1 -4
- claude_mpm/templates/questions/project_init.py +1 -4
- claude_mpm/templates/questions/ticket_mgmt.py +1 -4
- claude_mpm/utils/agent_dependency_loader.py +77 -10
- claude_mpm/utils/agent_filters.py +288 -0
- claude_mpm/utils/gitignore.py +3 -0
- claude_mpm/utils/migration.py +372 -0
- claude_mpm/utils/progress.py +387 -0
- {claude_mpm-4.25.10.dist-info → claude_mpm-5.1.8.dist-info}/METADATA +356 -112
- {claude_mpm-4.25.10.dist-info → claude_mpm-5.1.8.dist-info}/RECORD +188 -439
- claude_mpm/agents/templates/agent-manager.json +0 -273
- claude_mpm/agents/templates/agentic-coder-optimizer.json +0 -248
- claude_mpm/agents/templates/api_qa.json +0 -183
- claude_mpm/agents/templates/clerk-ops.json +0 -235
- claude_mpm/agents/templates/code_analyzer.json +0 -101
- claude_mpm/agents/templates/content-agent.json +0 -358
- claude_mpm/agents/templates/dart_engineer.json +0 -307
- claude_mpm/agents/templates/data_engineer.json +0 -225
- claude_mpm/agents/templates/documentation.json +0 -238
- claude_mpm/agents/templates/engineer.json +0 -210
- claude_mpm/agents/templates/gcp_ops_agent.json +0 -253
- claude_mpm/agents/templates/golang_engineer.json +0 -270
- claude_mpm/agents/templates/imagemagick.json +0 -264
- claude_mpm/agents/templates/java_engineer.json +0 -346
- claude_mpm/agents/templates/javascript_engineer_agent.json +0 -380
- claude_mpm/agents/templates/local_ops_agent.json +0 -1840
- claude_mpm/agents/templates/memory_manager.json +0 -158
- claude_mpm/agents/templates/nextjs_engineer.json +0 -285
- claude_mpm/agents/templates/ops.json +0 -185
- claude_mpm/agents/templates/php-engineer.json +0 -287
- claude_mpm/agents/templates/product_owner.json +0 -338
- claude_mpm/agents/templates/project_organizer.json +0 -144
- claude_mpm/agents/templates/prompt-engineer.json +0 -737
- claude_mpm/agents/templates/python_engineer.json +0 -387
- claude_mpm/agents/templates/qa.json +0 -243
- claude_mpm/agents/templates/react_engineer.json +0 -239
- claude_mpm/agents/templates/refactoring_engineer.json +0 -276
- claude_mpm/agents/templates/research.json +0 -258
- claude_mpm/agents/templates/ruby-engineer.json +0 -280
- claude_mpm/agents/templates/rust_engineer.json +0 -275
- claude_mpm/agents/templates/security.json +0 -202
- claude_mpm/agents/templates/svelte-engineer.json +0 -225
- claude_mpm/agents/templates/tauri_engineer.json +0 -274
- claude_mpm/agents/templates/ticketing.json +0 -181
- claude_mpm/agents/templates/typescript_engineer.json +0 -285
- claude_mpm/agents/templates/vercel_ops_agent.json +0 -412
- claude_mpm/agents/templates/version_control.json +0 -159
- claude_mpm/agents/templates/web_qa.json +0 -400
- claude_mpm/agents/templates/web_ui.json +0 -189
- claude_mpm/cli/README.md +0 -253
- claude_mpm/cli/commands/mcp_install_commands.py.backup +0 -284
- claude_mpm/cli/commands/mpm_init/README.md +0 -365
- claude_mpm/cli_module/refactoring_guide.md +0 -253
- claude_mpm/commands/mpm-tickets.md +0 -151
- claude_mpm/config/agent_capabilities.yaml +0 -658
- claude_mpm/config/async_logging_config.yaml +0 -145
- claude_mpm/core/.claude-mpm/logs/hooks_20250730.log +0 -34
- claude_mpm/d2/.gitignore +0 -22
- claude_mpm/d2/ARCHITECTURE_COMPARISON.md +0 -273
- claude_mpm/d2/FLASK_INTEGRATION.md +0 -156
- claude_mpm/d2/IMPLEMENTATION_SUMMARY.md +0 -452
- claude_mpm/d2/QUICKSTART.md +0 -186
- claude_mpm/d2/README.md +0 -232
- claude_mpm/d2/STORE_FIX_SUMMARY.md +0 -167
- claude_mpm/d2/SVELTE5_STORES_GUIDE.md +0 -180
- claude_mpm/d2/TESTING.md +0 -288
- claude_mpm/d2/index.html +0 -118
- claude_mpm/d2/package.json +0 -19
- claude_mpm/d2/src/App.svelte +0 -110
- claude_mpm/d2/src/components/Header.svelte +0 -153
- claude_mpm/d2/src/components/MainContent.svelte +0 -74
- claude_mpm/d2/src/components/Sidebar.svelte +0 -85
- claude_mpm/d2/src/components/tabs/EventsTab.svelte +0 -326
- claude_mpm/d2/src/lib/socketio.js +0 -144
- claude_mpm/d2/src/main.js +0 -7
- claude_mpm/d2/src/stores/events.js +0 -114
- claude_mpm/d2/src/stores/socket.js +0 -108
- claude_mpm/d2/src/stores/theme.js +0 -65
- claude_mpm/d2/svelte.config.js +0 -12
- claude_mpm/d2/vite.config.js +0 -15
- claude_mpm/dashboard/.claude-mpm/memories/README.md +0 -36
- claude_mpm/dashboard/BUILD_NUMBER +0 -1
- claude_mpm/dashboard/README.md +0 -121
- claude_mpm/dashboard/VERSION +0 -1
- claude_mpm/dashboard/react/components/DataInspector/DataInspector.module.css +0 -188
- claude_mpm/dashboard/react/components/DataInspector/DataInspector.tsx +0 -273
- claude_mpm/dashboard/react/components/ErrorBoundary.tsx +0 -75
- claude_mpm/dashboard/react/components/EventViewer/EventViewer.module.css +0 -156
- claude_mpm/dashboard/react/components/EventViewer/EventViewer.tsx +0 -141
- claude_mpm/dashboard/react/components/shared/ConnectionStatus.module.css +0 -38
- claude_mpm/dashboard/react/components/shared/ConnectionStatus.tsx +0 -36
- claude_mpm/dashboard/react/components/shared/FilterBar.module.css +0 -92
- claude_mpm/dashboard/react/components/shared/FilterBar.tsx +0 -89
- claude_mpm/dashboard/react/contexts/DashboardContext.tsx +0 -215
- claude_mpm/dashboard/react/entries/events.tsx +0 -165
- claude_mpm/dashboard/react/hooks/useEvents.ts +0 -191
- claude_mpm/dashboard/react/hooks/useSocket.ts +0 -225
- claude_mpm/dashboard/static/archive/activity_dashboard_fixed.html +0 -248
- claude_mpm/dashboard/static/built/REFACTORING_SUMMARY.md +0 -170
- claude_mpm/dashboard/static/built/assets/events.DjpNxWNo.css +0 -1
- claude_mpm/dashboard/static/built/components/activity-tree.js +0 -2
- claude_mpm/dashboard/static/built/components/activity-tree.js.map +0 -1
- claude_mpm/dashboard/static/built/components/agent-hierarchy.js +0 -777
- claude_mpm/dashboard/static/built/components/agent-inference.js +0 -2
- claude_mpm/dashboard/static/built/components/agent-inference.js.map +0 -1
- claude_mpm/dashboard/static/built/components/build-tracker.js +0 -333
- claude_mpm/dashboard/static/built/components/code-simple.js +0 -857
- claude_mpm/dashboard/static/built/components/code-tree/tree-breadcrumb.js +0 -353
- claude_mpm/dashboard/static/built/components/code-tree/tree-constants.js +0 -235
- claude_mpm/dashboard/static/built/components/code-tree/tree-search.js +0 -409
- claude_mpm/dashboard/static/built/components/code-tree/tree-utils.js +0 -435
- claude_mpm/dashboard/static/built/components/code-tree.js +0 -2
- claude_mpm/dashboard/static/built/components/code-tree.js.map +0 -1
- claude_mpm/dashboard/static/built/components/code-viewer.js +0 -2
- claude_mpm/dashboard/static/built/components/code-viewer.js.map +0 -1
- claude_mpm/dashboard/static/built/components/connection-debug.js +0 -654
- claude_mpm/dashboard/static/built/components/diff-viewer.js +0 -891
- claude_mpm/dashboard/static/built/components/event-processor.js +0 -2
- claude_mpm/dashboard/static/built/components/event-processor.js.map +0 -1
- claude_mpm/dashboard/static/built/components/event-viewer.js +0 -2
- claude_mpm/dashboard/static/built/components/event-viewer.js.map +0 -1
- claude_mpm/dashboard/static/built/components/export-manager.js +0 -2
- claude_mpm/dashboard/static/built/components/export-manager.js.map +0 -1
- claude_mpm/dashboard/static/built/components/file-change-tracker.js +0 -443
- claude_mpm/dashboard/static/built/components/file-change-viewer.js +0 -690
- claude_mpm/dashboard/static/built/components/file-tool-tracker.js +0 -2
- claude_mpm/dashboard/static/built/components/file-tool-tracker.js.map +0 -1
- claude_mpm/dashboard/static/built/components/file-viewer.js +0 -2
- claude_mpm/dashboard/static/built/components/file-viewer.js.map +0 -1
- claude_mpm/dashboard/static/built/components/hud-library-loader.js +0 -2
- claude_mpm/dashboard/static/built/components/hud-library-loader.js.map +0 -1
- claude_mpm/dashboard/static/built/components/hud-manager.js +0 -2
- claude_mpm/dashboard/static/built/components/hud-manager.js.map +0 -1
- claude_mpm/dashboard/static/built/components/hud-visualizer.js +0 -2
- claude_mpm/dashboard/static/built/components/hud-visualizer.js.map +0 -1
- claude_mpm/dashboard/static/built/components/module-viewer.js +0 -2
- claude_mpm/dashboard/static/built/components/module-viewer.js.map +0 -1
- claude_mpm/dashboard/static/built/components/nav-bar.js +0 -145
- claude_mpm/dashboard/static/built/components/page-structure.js +0 -429
- claude_mpm/dashboard/static/built/components/session-manager.js +0 -2
- claude_mpm/dashboard/static/built/components/session-manager.js.map +0 -1
- claude_mpm/dashboard/static/built/components/socket-manager.js +0 -2
- claude_mpm/dashboard/static/built/components/socket-manager.js.map +0 -1
- claude_mpm/dashboard/static/built/components/ui-state-manager.js +0 -2
- claude_mpm/dashboard/static/built/components/ui-state-manager.js.map +0 -1
- claude_mpm/dashboard/static/built/components/unified-data-viewer.js +0 -2
- claude_mpm/dashboard/static/built/components/unified-data-viewer.js.map +0 -1
- claude_mpm/dashboard/static/built/components/working-directory.js +0 -2
- claude_mpm/dashboard/static/built/components/working-directory.js.map +0 -1
- claude_mpm/dashboard/static/built/connection-manager.js +0 -536
- claude_mpm/dashboard/static/built/dashboard.js +0 -2
- claude_mpm/dashboard/static/built/dashboard.js.map +0 -1
- claude_mpm/dashboard/static/built/extension-error-handler.js +0 -164
- claude_mpm/dashboard/static/built/react/events.js +0 -30
- claude_mpm/dashboard/static/built/react/events.js.map +0 -1
- claude_mpm/dashboard/static/built/shared/dom-helpers.js +0 -396
- claude_mpm/dashboard/static/built/shared/event-bus.js +0 -330
- claude_mpm/dashboard/static/built/shared/event-filter-service.js +0 -540
- claude_mpm/dashboard/static/built/shared/logger.js +0 -385
- claude_mpm/dashboard/static/built/shared/page-structure.js +0 -249
- claude_mpm/dashboard/static/built/shared/tooltip-service.js +0 -253
- claude_mpm/dashboard/static/built/socket-client.js +0 -2
- claude_mpm/dashboard/static/built/socket-client.js.map +0 -1
- claude_mpm/dashboard/static/built/tab-isolation-fix.js +0 -185
- claude_mpm/dashboard/static/events.html +0 -607
- claude_mpm/dashboard/static/index.html +0 -635
- claude_mpm/dashboard/static/js/REFACTORING_SUMMARY.md +0 -170
- claude_mpm/dashboard/static/js/shared/dom-helpers.js +0 -396
- claude_mpm/dashboard/static/js/shared/event-bus.js +0 -330
- claude_mpm/dashboard/static/js/shared/logger.js +0 -385
- claude_mpm/dashboard/static/js/shared/tooltip-service.js +0 -253
- claude_mpm/dashboard/static/js/stores/dashboard-store.js +0 -562
- claude_mpm/dashboard/static/legacy/activity.html +0 -736
- claude_mpm/dashboard/static/legacy/agents.html +0 -786
- claude_mpm/dashboard/static/legacy/files.html +0 -747
- claude_mpm/dashboard/static/legacy/tools.html +0 -831
- claude_mpm/dashboard/static/monitors.html +0 -431
- claude_mpm/dashboard/static/navigation-test-results.md +0 -118
- claude_mpm/dashboard/static/production/events.html +0 -659
- claude_mpm/dashboard/static/production/main.html +0 -698
- claude_mpm/dashboard/static/production/monitors.html +0 -483
- claude_mpm/dashboard/static/test-archive/dashboard.html +0 -635
- claude_mpm/dashboard/static/test-archive/debug-events.html +0 -147
- claude_mpm/dashboard/static/test-archive/test-navigation.html +0 -256
- claude_mpm/dashboard/static/test-archive/test-react-exports.html +0 -180
- claude_mpm/dashboard/templates/.claude-mpm/memories/README.md +0 -36
- claude_mpm/dashboard/templates/.claude-mpm/memories/engineer_agent.md +0 -39
- claude_mpm/dashboard/templates/.claude-mpm/memories/version_control_agent.md +0 -38
- claude_mpm/hooks/README.md +0 -143
- claude_mpm/hooks/templates/README.md +0 -180
- claude_mpm/hooks/templates/settings.json.example +0 -147
- claude_mpm/schemas/agent_schema.json +0 -596
- claude_mpm/schemas/frontmatter_schema.json +0 -165
- claude_mpm/services/event_bus/README.md +0 -244
- claude_mpm/services/events/README.md +0 -303
- claude_mpm/services/framework_claude_md_generator/README.md +0 -119
- claude_mpm/services/mcp_gateway/README.md +0 -185
- claude_mpm/services/socketio/handlers/connection.py.backup +0 -217
- claude_mpm/services/socketio/handlers/hook.py.backup +0 -154
- claude_mpm/services/static/.gitkeep +0 -2
- claude_mpm/services/version_control/VERSION +0 -1
- claude_mpm/skills/bundled/.gitkeep +0 -2
- claude_mpm/skills/bundled/collaboration/brainstorming/SKILL.md +0 -79
- claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/SKILL.md +0 -178
- claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/agent-prompts.md +0 -577
- claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/coordination-patterns.md +0 -467
- claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/examples.md +0 -537
- claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/troubleshooting.md +0 -730
- claude_mpm/skills/bundled/collaboration/git-worktrees.md +0 -317
- claude_mpm/skills/bundled/collaboration/requesting-code-review/SKILL.md +0 -112
- claude_mpm/skills/bundled/collaboration/requesting-code-review/references/code-reviewer-template.md +0 -146
- claude_mpm/skills/bundled/collaboration/requesting-code-review/references/review-examples.md +0 -412
- claude_mpm/skills/bundled/collaboration/stacked-prs.md +0 -251
- claude_mpm/skills/bundled/collaboration/writing-plans/SKILL.md +0 -81
- claude_mpm/skills/bundled/collaboration/writing-plans/references/best-practices.md +0 -362
- claude_mpm/skills/bundled/collaboration/writing-plans/references/plan-structure-templates.md +0 -312
- claude_mpm/skills/bundled/debugging/root-cause-tracing/SKILL.md +0 -152
- claude_mpm/skills/bundled/debugging/root-cause-tracing/find-polluter.sh +0 -63
- claude_mpm/skills/bundled/debugging/root-cause-tracing/references/advanced-techniques.md +0 -668
- claude_mpm/skills/bundled/debugging/root-cause-tracing/references/examples.md +0 -587
- claude_mpm/skills/bundled/debugging/root-cause-tracing/references/integration.md +0 -438
- claude_mpm/skills/bundled/debugging/root-cause-tracing/references/tracing-techniques.md +0 -391
- claude_mpm/skills/bundled/debugging/systematic-debugging/CREATION-LOG.md +0 -119
- claude_mpm/skills/bundled/debugging/systematic-debugging/SKILL.md +0 -148
- claude_mpm/skills/bundled/debugging/systematic-debugging/references/anti-patterns.md +0 -483
- claude_mpm/skills/bundled/debugging/systematic-debugging/references/examples.md +0 -452
- claude_mpm/skills/bundled/debugging/systematic-debugging/references/troubleshooting.md +0 -449
- claude_mpm/skills/bundled/debugging/systematic-debugging/references/workflow.md +0 -411
- claude_mpm/skills/bundled/debugging/systematic-debugging/test-academic.md +0 -14
- claude_mpm/skills/bundled/debugging/systematic-debugging/test-pressure-1.md +0 -58
- claude_mpm/skills/bundled/debugging/systematic-debugging/test-pressure-2.md +0 -68
- claude_mpm/skills/bundled/debugging/systematic-debugging/test-pressure-3.md +0 -69
- claude_mpm/skills/bundled/debugging/verification-before-completion/SKILL.md +0 -131
- claude_mpm/skills/bundled/debugging/verification-before-completion/references/gate-function.md +0 -325
- claude_mpm/skills/bundled/debugging/verification-before-completion/references/integration-and-workflows.md +0 -490
- claude_mpm/skills/bundled/debugging/verification-before-completion/references/red-flags-and-failures.md +0 -425
- claude_mpm/skills/bundled/debugging/verification-before-completion/references/verification-patterns.md +0 -499
- claude_mpm/skills/bundled/infrastructure/env-manager/INTEGRATION.md +0 -611
- claude_mpm/skills/bundled/infrastructure/env-manager/README.md +0 -596
- claude_mpm/skills/bundled/infrastructure/env-manager/SKILL.md +0 -260
- claude_mpm/skills/bundled/infrastructure/env-manager/examples/nextjs-env-structure.md +0 -315
- claude_mpm/skills/bundled/infrastructure/env-manager/references/frameworks.md +0 -436
- claude_mpm/skills/bundled/infrastructure/env-manager/references/security.md +0 -433
- claude_mpm/skills/bundled/infrastructure/env-manager/references/synchronization.md +0 -452
- claude_mpm/skills/bundled/infrastructure/env-manager/references/troubleshooting.md +0 -404
- claude_mpm/skills/bundled/infrastructure/env-manager/references/validation.md +0 -420
- claude_mpm/skills/bundled/main/artifacts-builder/LICENSE.txt +0 -202
- claude_mpm/skills/bundled/main/artifacts-builder/SKILL.md +0 -86
- claude_mpm/skills/bundled/main/artifacts-builder/scripts/bundle-artifact.sh +0 -54
- claude_mpm/skills/bundled/main/artifacts-builder/scripts/init-artifact.sh +0 -322
- claude_mpm/skills/bundled/main/artifacts-builder/scripts/shadcn-components.tar.gz +0 -0
- claude_mpm/skills/bundled/main/internal-comms/LICENSE.txt +0 -202
- claude_mpm/skills/bundled/main/internal-comms/SKILL.md +0 -43
- claude_mpm/skills/bundled/main/internal-comms/examples/3p-updates.md +0 -47
- claude_mpm/skills/bundled/main/internal-comms/examples/company-newsletter.md +0 -65
- claude_mpm/skills/bundled/main/internal-comms/examples/faq-answers.md +0 -30
- claude_mpm/skills/bundled/main/internal-comms/examples/general-comms.md +0 -16
- claude_mpm/skills/bundled/main/mcp-builder/LICENSE.txt +0 -202
- claude_mpm/skills/bundled/main/mcp-builder/SKILL.md +0 -160
- claude_mpm/skills/bundled/main/mcp-builder/reference/design_principles.md +0 -412
- claude_mpm/skills/bundled/main/mcp-builder/reference/evaluation.md +0 -602
- claude_mpm/skills/bundled/main/mcp-builder/reference/mcp_best_practices.md +0 -915
- claude_mpm/skills/bundled/main/mcp-builder/reference/node_mcp_server.md +0 -916
- claude_mpm/skills/bundled/main/mcp-builder/reference/python_mcp_server.md +0 -752
- claude_mpm/skills/bundled/main/mcp-builder/reference/workflow.md +0 -1237
- claude_mpm/skills/bundled/main/mcp-builder/scripts/example_evaluation.xml +0 -22
- claude_mpm/skills/bundled/main/mcp-builder/scripts/requirements.txt +0 -2
- claude_mpm/skills/bundled/main/skill-creator/LICENSE.txt +0 -202
- claude_mpm/skills/bundled/main/skill-creator/SKILL.md +0 -189
- claude_mpm/skills/bundled/main/skill-creator/references/best-practices.md +0 -500
- claude_mpm/skills/bundled/main/skill-creator/references/creation-workflow.md +0 -464
- claude_mpm/skills/bundled/main/skill-creator/references/examples.md +0 -619
- claude_mpm/skills/bundled/main/skill-creator/references/progressive-disclosure.md +0 -437
- claude_mpm/skills/bundled/main/skill-creator/references/skill-structure.md +0 -231
- claude_mpm/skills/bundled/php/espocrm-development/SKILL.md +0 -170
- claude_mpm/skills/bundled/php/espocrm-development/references/architecture.md +0 -602
- claude_mpm/skills/bundled/php/espocrm-development/references/common-tasks.md +0 -821
- claude_mpm/skills/bundled/php/espocrm-development/references/development-workflow.md +0 -742
- claude_mpm/skills/bundled/php/espocrm-development/references/frontend-customization.md +0 -726
- claude_mpm/skills/bundled/php/espocrm-development/references/hooks-and-services.md +0 -764
- claude_mpm/skills/bundled/php/espocrm-development/references/testing-debugging.md +0 -831
- claude_mpm/skills/bundled/react/flexlayout-react.md +0 -742
- claude_mpm/skills/bundled/rust/desktop-applications/SKILL.md +0 -226
- claude_mpm/skills/bundled/rust/desktop-applications/references/architecture-patterns.md +0 -901
- claude_mpm/skills/bundled/rust/desktop-applications/references/native-gui-frameworks.md +0 -901
- claude_mpm/skills/bundled/rust/desktop-applications/references/platform-integration.md +0 -775
- claude_mpm/skills/bundled/rust/desktop-applications/references/state-management.md +0 -937
- claude_mpm/skills/bundled/rust/desktop-applications/references/tauri-framework.md +0 -770
- claude_mpm/skills/bundled/rust/desktop-applications/references/testing-deployment.md +0 -961
- claude_mpm/skills/bundled/tauri/tauri-async-patterns.md +0 -495
- claude_mpm/skills/bundled/tauri/tauri-build-deploy.md +0 -599
- claude_mpm/skills/bundled/tauri/tauri-command-patterns.md +0 -535
- claude_mpm/skills/bundled/tauri/tauri-error-handling.md +0 -613
- claude_mpm/skills/bundled/tauri/tauri-event-system.md +0 -648
- claude_mpm/skills/bundled/tauri/tauri-file-system.md +0 -673
- claude_mpm/skills/bundled/tauri/tauri-frontend-integration.md +0 -767
- claude_mpm/skills/bundled/tauri/tauri-performance.md +0 -669
- claude_mpm/skills/bundled/tauri/tauri-state-management.md +0 -573
- claude_mpm/skills/bundled/tauri/tauri-testing.md +0 -384
- claude_mpm/skills/bundled/tauri/tauri-window-management.md +0 -628
- claude_mpm/skills/bundled/testing/condition-based-waiting/SKILL.md +0 -119
- claude_mpm/skills/bundled/testing/condition-based-waiting/example.ts +0 -158
- claude_mpm/skills/bundled/testing/condition-based-waiting/references/patterns-and-implementation.md +0 -253
- claude_mpm/skills/bundled/testing/test-driven-development/SKILL.md +0 -145
- claude_mpm/skills/bundled/testing/test-driven-development/references/anti-patterns.md +0 -543
- claude_mpm/skills/bundled/testing/test-driven-development/references/examples.md +0 -741
- claude_mpm/skills/bundled/testing/test-driven-development/references/integration.md +0 -470
- claude_mpm/skills/bundled/testing/test-driven-development/references/philosophy.md +0 -458
- claude_mpm/skills/bundled/testing/test-driven-development/references/workflow.md +0 -639
- claude_mpm/skills/bundled/testing/test-quality-inspector/SKILL.md +0 -458
- claude_mpm/skills/bundled/testing/test-quality-inspector/examples/example-inspection-report.md +0 -411
- claude_mpm/skills/bundled/testing/test-quality-inspector/references/assertion-quality.md +0 -317
- claude_mpm/skills/bundled/testing/test-quality-inspector/references/inspection-checklist.md +0 -270
- claude_mpm/skills/bundled/testing/test-quality-inspector/references/red-flags.md +0 -436
- claude_mpm/skills/bundled/testing/testing-anti-patterns/SKILL.md +0 -140
- claude_mpm/skills/bundled/testing/testing-anti-patterns/references/completeness-anti-patterns.md +0 -572
- claude_mpm/skills/bundled/testing/testing-anti-patterns/references/core-anti-patterns.md +0 -411
- claude_mpm/skills/bundled/testing/testing-anti-patterns/references/detection-guide.md +0 -569
- claude_mpm/skills/bundled/testing/testing-anti-patterns/references/tdd-connection.md +0 -695
- claude_mpm/skills/bundled/testing/webapp-testing/LICENSE.txt +0 -202
- claude_mpm/skills/bundled/testing/webapp-testing/SKILL.md +0 -184
- claude_mpm/skills/bundled/testing/webapp-testing/decision-tree.md +0 -459
- claude_mpm/skills/bundled/testing/webapp-testing/playwright-patterns.md +0 -479
- claude_mpm/skills/bundled/testing/webapp-testing/reconnaissance-pattern.md +0 -687
- claude_mpm/skills/bundled/testing/webapp-testing/server-management.md +0 -758
- claude_mpm/skills/bundled/testing/webapp-testing/troubleshooting.md +0 -868
- claude_mpm/templates/questions/EXAMPLES.md +0 -501
- claude_mpm/tools/README_SOCKETIO_DEBUG.md +0 -224
- claude_mpm/tools/code_tree_analyzer/README.md +0 -64
- /claude_mpm/agents/templates/{git_file_tracking.md → git-file-tracking.md} +0 -0
- /claude_mpm/agents/templates/{pm_examples.md → pm-examples.md} +0 -0
- /claude_mpm/agents/templates/{pm_red_flags.md → pm-red-flags.md} +0 -0
- /claude_mpm/agents/templates/{response_format.md → response-format.md} +0 -0
- /claude_mpm/agents/templates/{validation_templates.md → validation-templates.md} +0 -0
- {claude_mpm-4.25.10.dist-info → claude_mpm-5.1.8.dist-info}/WHEEL +0 -0
- {claude_mpm-4.25.10.dist-info → claude_mpm-5.1.8.dist-info}/entry_points.txt +0 -0
- {claude_mpm-4.25.10.dist-info → claude_mpm-5.1.8.dist-info}/licenses/LICENSE +0 -0
- {claude_mpm-4.25.10.dist-info → claude_mpm-5.1.8.dist-info}/top_level.txt +0 -0
|
@@ -16,6 +16,7 @@ import sys
|
|
|
16
16
|
import time
|
|
17
17
|
from typing import Any, Dict, List, Optional, Set, Tuple
|
|
18
18
|
|
|
19
|
+
import yaml
|
|
19
20
|
from packaging.requirements import InvalidRequirement, Requirement
|
|
20
21
|
|
|
21
22
|
from ..core.logger import get_logger
|
|
@@ -89,10 +90,48 @@ class AgentDependencyLoader:
|
|
|
89
90
|
self.deployed_agents = deployed_agents
|
|
90
91
|
return deployed_agents
|
|
91
92
|
|
|
93
|
+
def _extract_yaml_frontmatter(self, content: str) -> Optional[Dict[str, Any]]:
|
|
94
|
+
"""
|
|
95
|
+
Extract and parse YAML frontmatter from markdown.
|
|
96
|
+
|
|
97
|
+
Frontmatter must be at the start of the file, delimited by '---'.
|
|
98
|
+
Example:
|
|
99
|
+
---
|
|
100
|
+
name: agent_name
|
|
101
|
+
dependencies:
|
|
102
|
+
python:
|
|
103
|
+
- package>=1.0.0
|
|
104
|
+
---
|
|
105
|
+
# Agent content...
|
|
106
|
+
|
|
107
|
+
Args:
|
|
108
|
+
content: File content to parse
|
|
109
|
+
|
|
110
|
+
Returns:
|
|
111
|
+
Parsed YAML frontmatter as dict, or None if not found/invalid
|
|
112
|
+
"""
|
|
113
|
+
if not content.strip().startswith("---"):
|
|
114
|
+
return None
|
|
115
|
+
|
|
116
|
+
# Split on --- delimiters
|
|
117
|
+
parts = content.split("---", 2)
|
|
118
|
+
if len(parts) < 3:
|
|
119
|
+
return None
|
|
120
|
+
|
|
121
|
+
try:
|
|
122
|
+
return yaml.safe_load(parts[1])
|
|
123
|
+
except yaml.YAMLError as e:
|
|
124
|
+
logger.warning(f"Failed to parse YAML frontmatter: {e}")
|
|
125
|
+
return None
|
|
126
|
+
|
|
92
127
|
def load_agent_dependencies(self) -> Dict[str, Dict]:
|
|
93
128
|
"""
|
|
94
129
|
Load dependency information for deployed agents from their source configs.
|
|
95
130
|
|
|
131
|
+
Searches for agent configuration in both markdown (.md) and JSON (.json) formats.
|
|
132
|
+
Markdown files with YAML frontmatter are searched first for better maintainability.
|
|
133
|
+
Falls back to JSON format for backward compatibility.
|
|
134
|
+
|
|
96
135
|
Returns:
|
|
97
136
|
Dictionary mapping agent IDs to their dependency requirements
|
|
98
137
|
"""
|
|
@@ -106,19 +145,47 @@ class AgentDependencyLoader:
|
|
|
106
145
|
]
|
|
107
146
|
|
|
108
147
|
for agent_id in self.deployed_agents:
|
|
109
|
-
|
|
148
|
+
found = False
|
|
149
|
+
|
|
150
|
+
# Try to find the agent's config (markdown first, then JSON)
|
|
110
151
|
for config_dir in config_paths:
|
|
111
|
-
|
|
112
|
-
|
|
152
|
+
if found:
|
|
153
|
+
break
|
|
154
|
+
|
|
155
|
+
# Try markdown first (current format with YAML frontmatter)
|
|
156
|
+
md_file = config_dir / f"{agent_id}.md"
|
|
157
|
+
if md_file.exists():
|
|
113
158
|
try:
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
159
|
+
content = md_file.read_text(encoding="utf-8")
|
|
160
|
+
frontmatter = self._extract_yaml_frontmatter(content)
|
|
161
|
+
if frontmatter and "dependencies" in frontmatter:
|
|
162
|
+
agent_dependencies[agent_id] = frontmatter["dependencies"]
|
|
163
|
+
logger.debug(
|
|
164
|
+
f"Loaded dependencies for {agent_id} from markdown"
|
|
165
|
+
)
|
|
166
|
+
found = True
|
|
167
|
+
break
|
|
120
168
|
except Exception as e:
|
|
121
|
-
logger.warning(f"Failed to load
|
|
169
|
+
logger.warning(f"Failed to load markdown for {agent_id}: {e}")
|
|
170
|
+
|
|
171
|
+
# Fall back to JSON for backward compatibility
|
|
172
|
+
if not found:
|
|
173
|
+
json_file = config_dir / f"{agent_id}.json"
|
|
174
|
+
if json_file.exists():
|
|
175
|
+
try:
|
|
176
|
+
with json_file.open() as f:
|
|
177
|
+
config = json.load(f)
|
|
178
|
+
if "dependencies" in config:
|
|
179
|
+
agent_dependencies[agent_id] = config[
|
|
180
|
+
"dependencies"
|
|
181
|
+
]
|
|
182
|
+
logger.debug(
|
|
183
|
+
f"Loaded dependencies for {agent_id} from JSON"
|
|
184
|
+
)
|
|
185
|
+
found = True
|
|
186
|
+
break
|
|
187
|
+
except Exception as e:
|
|
188
|
+
logger.warning(f"Failed to load JSON for {agent_id}: {e}")
|
|
122
189
|
|
|
123
190
|
self.agent_dependencies = agent_dependencies
|
|
124
191
|
logger.debug(f"Loaded dependencies for {len(agent_dependencies)} agents")
|
|
@@ -0,0 +1,288 @@
|
|
|
1
|
+
"""
|
|
2
|
+
Agent filtering utilities for claude-mpm.
|
|
3
|
+
|
|
4
|
+
WHY: This module provides centralized filtering logic to remove non-deployable
|
|
5
|
+
agents (BASE_AGENT) and already-deployed agents from user-facing displays.
|
|
6
|
+
|
|
7
|
+
DESIGN DECISIONS:
|
|
8
|
+
- BASE_AGENT is a build tool, not a deployable agent - filter everywhere
|
|
9
|
+
- Deployed agent detection supports both new (.claude-mpm/agents/) and
|
|
10
|
+
legacy (.claude/agents/)
|
|
11
|
+
- Case-insensitive BASE_AGENT detection for robustness
|
|
12
|
+
- Pure functions for easy testing and reuse
|
|
13
|
+
|
|
14
|
+
IMPLEMENTATION NOTES:
|
|
15
|
+
- Related to ticket 1M-502 Phase 1: UX improvements for agent filtering
|
|
16
|
+
- Addresses user confusion from seeing BASE_AGENT and deployed agents in lists
|
|
17
|
+
"""
|
|
18
|
+
|
|
19
|
+
from pathlib import Path
|
|
20
|
+
from typing import Dict, List, Optional, Set
|
|
21
|
+
|
|
22
|
+
|
|
23
|
+
def is_base_agent(agent_id: str) -> bool:
|
|
24
|
+
"""Check if agent is BASE_AGENT (build tool, not deployable).
|
|
25
|
+
|
|
26
|
+
BASE_AGENT is an internal build tool used to construct other agents.
|
|
27
|
+
It should never appear in user-facing agent lists or deployment menus.
|
|
28
|
+
|
|
29
|
+
Args:
|
|
30
|
+
agent_id: Agent identifier to check (may include path like "qa/BASE-AGENT")
|
|
31
|
+
|
|
32
|
+
Returns:
|
|
33
|
+
True if agent is BASE_AGENT (case-insensitive), False otherwise
|
|
34
|
+
|
|
35
|
+
Examples:
|
|
36
|
+
>>> is_base_agent("BASE_AGENT")
|
|
37
|
+
True
|
|
38
|
+
>>> is_base_agent("base-agent")
|
|
39
|
+
True
|
|
40
|
+
>>> is_base_agent("qa/BASE-AGENT")
|
|
41
|
+
True
|
|
42
|
+
>>> is_base_agent("ENGINEER")
|
|
43
|
+
False
|
|
44
|
+
"""
|
|
45
|
+
if not agent_id:
|
|
46
|
+
return False
|
|
47
|
+
|
|
48
|
+
# Extract filename from path (handle cases like "qa/BASE-AGENT")
|
|
49
|
+
# 1M-502: Remote agents may have path prefixes like "qa/", "pm/", etc.
|
|
50
|
+
agent_name = agent_id.split("/")[-1]
|
|
51
|
+
|
|
52
|
+
normalized_id = agent_name.lower().replace("-", "").replace("_", "")
|
|
53
|
+
return normalized_id == "baseagent"
|
|
54
|
+
|
|
55
|
+
|
|
56
|
+
def filter_base_agents(agents: List[Dict]) -> List[Dict]:
|
|
57
|
+
"""Remove BASE_AGENT from agent list.
|
|
58
|
+
|
|
59
|
+
Filters out any agent with agent_id matching BASE_AGENT (case-insensitive).
|
|
60
|
+
This prevents users from seeing or selecting the internal build tool.
|
|
61
|
+
|
|
62
|
+
Args:
|
|
63
|
+
agents: List of agent dictionaries, each containing at least 'agent_id' key
|
|
64
|
+
|
|
65
|
+
Returns:
|
|
66
|
+
Filtered list with BASE_AGENT removed
|
|
67
|
+
|
|
68
|
+
Examples:
|
|
69
|
+
>>> agents = [
|
|
70
|
+
... {"agent_id": "ENGINEER", "name": "Engineer"},
|
|
71
|
+
... {"agent_id": "BASE_AGENT", "name": "Base Agent"},
|
|
72
|
+
... {"agent_id": "PM", "name": "PM"}
|
|
73
|
+
... ]
|
|
74
|
+
>>> filtered = filter_base_agents(agents)
|
|
75
|
+
>>> len(filtered)
|
|
76
|
+
2
|
|
77
|
+
>>> "BASE_AGENT" in [a["agent_id"] for a in filtered]
|
|
78
|
+
False
|
|
79
|
+
"""
|
|
80
|
+
return [a for a in agents if not is_base_agent(a.get("agent_id", ""))]
|
|
81
|
+
|
|
82
|
+
|
|
83
|
+
def get_deployed_agent_ids(project_dir: Optional[Path] = None) -> Set[str]:
|
|
84
|
+
"""Get set of currently deployed agent IDs.
|
|
85
|
+
|
|
86
|
+
Checks virtual deployment state (.mpm_deployment_state) first, then falls back
|
|
87
|
+
to physical .md files for backward compatibility. This ensures agents are detected
|
|
88
|
+
whether deployed virtually or as physical files.
|
|
89
|
+
|
|
90
|
+
Args:
|
|
91
|
+
project_dir: Project directory to check, defaults to current working directory
|
|
92
|
+
|
|
93
|
+
Returns:
|
|
94
|
+
Set of deployed agent IDs (leaf names like "python-engineer", "qa")
|
|
95
|
+
|
|
96
|
+
Examples:
|
|
97
|
+
>>> deployed = get_deployed_agent_ids()
|
|
98
|
+
>>> "python-engineer" in deployed # If agent exists in deployment state
|
|
99
|
+
True
|
|
100
|
+
>>> "ENGINEER" in deployed # If ENGINEER.md exists
|
|
101
|
+
True
|
|
102
|
+
|
|
103
|
+
Design Rationale:
|
|
104
|
+
- Primary detection: Virtual deployment state (.mpm_deployment_state)
|
|
105
|
+
- Fallback detection: Physical .md files (.claude-mpm/agents/, .claude/agents/)
|
|
106
|
+
- Returns leaf names for consistent comparison with agent_id formats
|
|
107
|
+
- Combines both detection methods for complete coverage
|
|
108
|
+
- Graceful error handling for malformed or missing state files
|
|
109
|
+
|
|
110
|
+
Related:
|
|
111
|
+
- Fixes checkbox interface showing all agents as "○ [Available]" instead of "● [Installed]"
|
|
112
|
+
- Matches detection logic from _is_agent_deployed() in agent_state_manager.py
|
|
113
|
+
- Related to ticket 1M-502: Virtual deployment state detection
|
|
114
|
+
"""
|
|
115
|
+
deployed = set()
|
|
116
|
+
|
|
117
|
+
# Track if project_dir was explicitly provided
|
|
118
|
+
explicit_project_dir = project_dir is not None
|
|
119
|
+
|
|
120
|
+
if project_dir is None:
|
|
121
|
+
project_dir = Path.cwd()
|
|
122
|
+
|
|
123
|
+
# NEW: Check virtual deployment state (primary method)
|
|
124
|
+
# This is the current deployment model used by Claude Code
|
|
125
|
+
deployment_state_paths = [
|
|
126
|
+
project_dir / ".claude" / "agents" / ".mpm_deployment_state",
|
|
127
|
+
]
|
|
128
|
+
|
|
129
|
+
# Only check user-level state if using default project directory
|
|
130
|
+
# This prevents test isolation issues when explicit project_dir is provided
|
|
131
|
+
if not explicit_project_dir:
|
|
132
|
+
deployment_state_paths.append(
|
|
133
|
+
Path.home() / ".claude" / "agents" / ".mpm_deployment_state"
|
|
134
|
+
)
|
|
135
|
+
|
|
136
|
+
for state_path in deployment_state_paths:
|
|
137
|
+
if state_path.exists():
|
|
138
|
+
try:
|
|
139
|
+
import json
|
|
140
|
+
|
|
141
|
+
with state_path.open() as f:
|
|
142
|
+
state = json.load(f)
|
|
143
|
+
|
|
144
|
+
# Extract agent IDs from deployment state
|
|
145
|
+
# Agent IDs are leaf names (e.g., "python-engineer", "qa")
|
|
146
|
+
agents = state.get("last_check_results", {}).get("agents", {})
|
|
147
|
+
deployed.update(agents.keys())
|
|
148
|
+
|
|
149
|
+
except (json.JSONDecodeError, KeyError) as e:
|
|
150
|
+
# Log error but continue - don't break if state file is malformed
|
|
151
|
+
import logging
|
|
152
|
+
|
|
153
|
+
logger = logging.getLogger(__name__)
|
|
154
|
+
logger.debug(f"Failed to read deployment state from {state_path}: {e}")
|
|
155
|
+
continue
|
|
156
|
+
except Exception as e:
|
|
157
|
+
# Catch unexpected errors - fail gracefully
|
|
158
|
+
import logging
|
|
159
|
+
|
|
160
|
+
logger = logging.getLogger(__name__)
|
|
161
|
+
logger.debug(f"Unexpected error reading deployment state: {e}")
|
|
162
|
+
continue
|
|
163
|
+
|
|
164
|
+
# EXISTING: Check physical .md files (fallback for backward compatibility)
|
|
165
|
+
# Check new architecture
|
|
166
|
+
new_agents_dir = project_dir / ".claude-mpm" / "agents"
|
|
167
|
+
if new_agents_dir.exists():
|
|
168
|
+
for file in new_agents_dir.glob("*.md"):
|
|
169
|
+
if file.stem not in {"BASE-AGENT", ".DS_Store"}:
|
|
170
|
+
deployed.add(file.stem)
|
|
171
|
+
|
|
172
|
+
# Check legacy architecture
|
|
173
|
+
legacy_agents_dir = project_dir / ".claude" / "agents"
|
|
174
|
+
if legacy_agents_dir.exists():
|
|
175
|
+
for file in legacy_agents_dir.glob("*.md"):
|
|
176
|
+
if file.stem not in {"BASE-AGENT", ".DS_Store"}:
|
|
177
|
+
deployed.add(file.stem)
|
|
178
|
+
|
|
179
|
+
# Check .claude/templates/ directory (where agents are actually deployed)
|
|
180
|
+
templates_dir = project_dir / ".claude" / "templates"
|
|
181
|
+
if templates_dir.exists():
|
|
182
|
+
for file in templates_dir.glob("*.md"):
|
|
183
|
+
if file.stem not in {
|
|
184
|
+
"BASE-AGENT",
|
|
185
|
+
".DS_Store",
|
|
186
|
+
"README",
|
|
187
|
+
"circuit-breakers",
|
|
188
|
+
}:
|
|
189
|
+
# Skip template/example files
|
|
190
|
+
if not any(x in file.stem for x in ["example", "template", "pm-"]):
|
|
191
|
+
deployed.add(file.stem)
|
|
192
|
+
|
|
193
|
+
# Check user-level directory only if using default project directory
|
|
194
|
+
# This prevents test isolation issues when explicit project_dir is provided
|
|
195
|
+
if not explicit_project_dir:
|
|
196
|
+
user_agents_dir = Path.home() / ".claude" / "agents"
|
|
197
|
+
if user_agents_dir.exists():
|
|
198
|
+
for file in user_agents_dir.glob("*.md"):
|
|
199
|
+
if file.stem not in {"BASE-AGENT", ".DS_Store"}:
|
|
200
|
+
deployed.add(file.stem)
|
|
201
|
+
|
|
202
|
+
return deployed
|
|
203
|
+
|
|
204
|
+
|
|
205
|
+
def filter_deployed_agents(
|
|
206
|
+
agents: List[Dict], project_dir: Optional[Path] = None
|
|
207
|
+
) -> List[Dict]:
|
|
208
|
+
"""Remove already-deployed agents from list.
|
|
209
|
+
|
|
210
|
+
Filters agent list to show only agents that are not currently deployed.
|
|
211
|
+
This prevents users from attempting to re-deploy existing agents and
|
|
212
|
+
reduces confusion in deployment menus.
|
|
213
|
+
|
|
214
|
+
Args:
|
|
215
|
+
agents: List of agent dictionaries, each containing at least 'agent_id' key
|
|
216
|
+
project_dir: Project directory to check, defaults to current working directory
|
|
217
|
+
|
|
218
|
+
Returns:
|
|
219
|
+
Filtered list containing only non-deployed agents
|
|
220
|
+
|
|
221
|
+
Examples:
|
|
222
|
+
>>> agents = [
|
|
223
|
+
... {"agent_id": "ENGINEER", "name": "Engineer"},
|
|
224
|
+
... {"agent_id": "PM", "name": "PM"},
|
|
225
|
+
... {"agent_id": "QA", "name": "QA"}
|
|
226
|
+
... ]
|
|
227
|
+
>>> # Assuming ENGINEER is deployed
|
|
228
|
+
>>> filtered = filter_deployed_agents(agents)
|
|
229
|
+
>>> "ENGINEER" not in [a["agent_id"] for a in filtered]
|
|
230
|
+
True
|
|
231
|
+
|
|
232
|
+
Design Rationale:
|
|
233
|
+
- Checks filesystem for actual deployed files (source of truth)
|
|
234
|
+
- Supports both new and legacy agent directory structures
|
|
235
|
+
- Preserves agent order for consistent UX
|
|
236
|
+
"""
|
|
237
|
+
deployed_ids = get_deployed_agent_ids(project_dir)
|
|
238
|
+
return [a for a in agents if a.get("agent_id") not in deployed_ids]
|
|
239
|
+
|
|
240
|
+
|
|
241
|
+
def apply_all_filters(
|
|
242
|
+
agents: List[Dict],
|
|
243
|
+
project_dir: Optional[Path] = None,
|
|
244
|
+
filter_base: bool = True,
|
|
245
|
+
filter_deployed: bool = False,
|
|
246
|
+
) -> List[Dict]:
|
|
247
|
+
"""Apply multiple filters to agent list in correct order.
|
|
248
|
+
|
|
249
|
+
Convenience function to apply common filtering combinations. Filters are
|
|
250
|
+
applied in this order:
|
|
251
|
+
1. BASE_AGENT filtering (if enabled)
|
|
252
|
+
2. Deployed agent filtering (if enabled)
|
|
253
|
+
|
|
254
|
+
Args:
|
|
255
|
+
agents: List of agent dictionaries to filter
|
|
256
|
+
project_dir: Project directory for deployment checks
|
|
257
|
+
filter_base: Remove BASE_AGENT from list (default: True)
|
|
258
|
+
filter_deployed: Remove deployed agents from list (default: False)
|
|
259
|
+
|
|
260
|
+
Returns:
|
|
261
|
+
Filtered agent list
|
|
262
|
+
|
|
263
|
+
Examples:
|
|
264
|
+
>>> agents = get_all_agents()
|
|
265
|
+
>>> # For display/info purposes - remove only BASE_AGENT
|
|
266
|
+
>>> filtered = apply_all_filters(
|
|
267
|
+
... agents, filter_base=True, filter_deployed=False
|
|
268
|
+
... )
|
|
269
|
+
>>> # For deployment menus - remove BASE_AGENT and deployed agents
|
|
270
|
+
>>> deployable = apply_all_filters(
|
|
271
|
+
... agents, filter_base=True, filter_deployed=True
|
|
272
|
+
... )
|
|
273
|
+
|
|
274
|
+
Usage Guidelines:
|
|
275
|
+
- Use filter_base=True (default) for all user-facing displays
|
|
276
|
+
- Use filter_deployed=True when showing deployment options
|
|
277
|
+
- Use filter_deployed=False when showing all available agents
|
|
278
|
+
(info/list commands)
|
|
279
|
+
"""
|
|
280
|
+
result = agents
|
|
281
|
+
|
|
282
|
+
if filter_base:
|
|
283
|
+
result = filter_base_agents(result)
|
|
284
|
+
|
|
285
|
+
if filter_deployed:
|
|
286
|
+
result = filter_deployed_agents(result, project_dir)
|
|
287
|
+
|
|
288
|
+
return result
|
claude_mpm/utils/gitignore.py
CHANGED
|
@@ -212,6 +212,9 @@ def ensure_claude_mpm_gitignore(project_dir: str = ".") -> dict:
|
|
|
212
212
|
entries_to_add = [
|
|
213
213
|
".claude-mpm/",
|
|
214
214
|
".claude/agents/",
|
|
215
|
+
".mcp.json",
|
|
216
|
+
".claude.json",
|
|
217
|
+
".claude/",
|
|
215
218
|
]
|
|
216
219
|
|
|
217
220
|
added, existing = manager.ensure_entries(entries_to_add)
|