claude-mpm 4.21.3__py3-none-any.whl → 5.1.9__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/{OUTPUT_STYLE.md → CLAUDE_MPM_OUTPUT_STYLE.md} +3 -48
- claude_mpm/agents/CLAUDE_MPM_TEACHER_OUTPUT_STYLE.md +2002 -0
- claude_mpm/agents/PM_INSTRUCTIONS.md +1239 -674
- claude_mpm/agents/WORKFLOW.md +75 -2
- claude_mpm/agents/__init__.py +6 -0
- claude_mpm/agents/agent_loader.py +1 -4
- claude_mpm/agents/base_agent.json +6 -3
- claude_mpm/agents/base_agent_loader.py +10 -35
- claude_mpm/agents/frontmatter_validator.py +69 -1
- claude_mpm/agents/templates/circuit-breakers.md +1254 -0
- claude_mpm/agents/templates/context-management-examples.md +544 -0
- claude_mpm/agents/templates/{pm_red_flags.md → pm-red-flags.md} +89 -19
- 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 +37 -2
- 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 +1128 -36
- claude_mpm/cli/commands/agents_cleanup.py +210 -0
- claude_mpm/cli/commands/agents_discover.py +338 -0
- claude_mpm/cli/commands/aggregate.py +1 -1
- claude_mpm/cli/commands/analyze.py +3 -3
- claude_mpm/cli/commands/auto_configure.py +537 -239
- claude_mpm/cli/commands/cleanup.py +1 -1
- claude_mpm/cli/commands/config.py +7 -4
- claude_mpm/cli/commands/configure.py +935 -45
- claude_mpm/cli/commands/configure_agent_display.py +4 -4
- claude_mpm/cli/commands/configure_navigation.py +63 -46
- claude_mpm/cli/commands/debug.py +12 -12
- claude_mpm/cli/commands/doctor.py +10 -2
- claude_mpm/cli/commands/hook_errors.py +277 -0
- claude_mpm/cli/commands/local_deploy.py +1 -4
- claude_mpm/cli/commands/mcp_install_commands.py +1 -1
- claude_mpm/cli/commands/mpm_init/core.py +50 -2
- claude_mpm/cli/commands/mpm_init/git_activity.py +10 -10
- claude_mpm/cli/commands/mpm_init/prompts.py +6 -6
- claude_mpm/cli/commands/postmortem.py +401 -0
- claude_mpm/cli/commands/run.py +125 -167
- claude_mpm/cli/commands/skill_source.py +694 -0
- claude_mpm/cli/commands/skills.py +757 -20
- claude_mpm/cli/executor.py +78 -3
- claude_mpm/cli/interactive/agent_wizard.py +1032 -47
- claude_mpm/cli/parsers/agent_source_parser.py +171 -0
- claude_mpm/cli/parsers/agents_parser.py +310 -4
- claude_mpm/cli/parsers/auto_configure_parser.py +13 -0
- claude_mpm/cli/parsers/base_parser.py +53 -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 +145 -0
- claude_mpm/cli/parsers/source_parser.py +138 -0
- claude_mpm/cli/startup.py +564 -108
- claude_mpm/cli/startup_display.py +480 -0
- claude_mpm/cli/utils.py +1 -1
- claude_mpm/cli_module/commands.py +1 -1
- 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 +27 -2
- 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 +13 -0
- claude_mpm/core/api_validator.py +1 -1
- claude_mpm/core/claude_runner.py +19 -35
- claude_mpm/core/config.py +24 -0
- claude_mpm/core/constants.py +1 -1
- 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/framework/processors/metadata_processor.py +1 -1
- claude_mpm/core/hook_error_memory.py +381 -0
- claude_mpm/core/hook_manager.py +41 -2
- claude_mpm/core/interactive_session.py +131 -10
- claude_mpm/core/logger.py +3 -1
- claude_mpm/core/oneshot_session.py +110 -8
- claude_mpm/core/output_style_manager.py +173 -43
- 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_agent_registry.py +129 -1
- claude_mpm/core/unified_config.py +22 -0
- claude_mpm/dashboard/static/css/activity.css +69 -69
- claude_mpm/dashboard/static/css/connection-status.css +10 -10
- claude_mpm/dashboard/static/css/dashboard.css +15 -15
- claude_mpm/dashboard/static/js/components/activity-tree.js +178 -178
- claude_mpm/dashboard/static/js/components/agent-hierarchy.js +101 -101
- claude_mpm/dashboard/static/js/components/agent-inference.js +31 -31
- claude_mpm/dashboard/static/js/components/build-tracker.js +59 -59
- claude_mpm/dashboard/static/js/components/code-simple.js +107 -107
- claude_mpm/dashboard/static/js/components/connection-debug.js +101 -101
- claude_mpm/dashboard/static/js/components/diff-viewer.js +113 -113
- claude_mpm/dashboard/static/js/components/event-viewer.js +12 -12
- claude_mpm/dashboard/static/js/components/file-change-tracker.js +57 -57
- claude_mpm/dashboard/static/js/components/file-change-viewer.js +74 -74
- claude_mpm/dashboard/static/js/components/file-tool-tracker.js +6 -6
- claude_mpm/dashboard/static/js/components/file-viewer.js +42 -42
- claude_mpm/dashboard/static/js/components/module-viewer.js +27 -27
- claude_mpm/dashboard/static/js/components/session-manager.js +14 -14
- claude_mpm/dashboard/static/js/components/socket-manager.js +1 -1
- claude_mpm/dashboard/static/js/components/ui-state-manager.js +14 -14
- claude_mpm/dashboard/static/js/components/unified-data-viewer.js +110 -110
- claude_mpm/dashboard/static/js/components/working-directory.js +8 -8
- claude_mpm/dashboard/static/js/connection-manager.js +76 -76
- claude_mpm/dashboard/static/js/dashboard.js +76 -58
- claude_mpm/dashboard/static/js/extension-error-handler.js +22 -22
- claude_mpm/dashboard/static/js/socket-client.js +138 -121
- claude_mpm/dashboard/templates/code_simple.html +23 -23
- claude_mpm/dashboard/templates/index.html +18 -18
- claude_mpm/experimental/cli_enhancements.py +1 -5
- claude_mpm/hooks/claude_hooks/event_handlers.py +3 -1
- claude_mpm/hooks/claude_hooks/hook_handler.py +24 -7
- claude_mpm/hooks/claude_hooks/installer.py +45 -0
- claude_mpm/hooks/claude_hooks/memory_integration.py +12 -1
- 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/hooks/templates/pre_tool_use_simple.py +78 -0
- claude_mpm/hooks/templates/pre_tool_use_template.py +323 -0
- claude_mpm/models/agent_definition.py +7 -0
- claude_mpm/models/git_repository.py +198 -0
- claude_mpm/scripts/claude-hook-handler.sh +3 -3
- claude_mpm/scripts/start_activity_logging.py +3 -1
- 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_format_converter.py +1 -1
- claude_mpm/services/agents/deployment/agent_lifecycle_manager.py +1 -5
- claude_mpm/services/agents/deployment/agent_metrics_collector.py +3 -3
- 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/facade/deployment_facade.py +3 -3
- claude_mpm/services/agents/deployment/multi_source_deployment_service.py +225 -18
- claude_mpm/services/agents/deployment/pipeline/pipeline_executor.py +2 -2
- claude_mpm/services/agents/deployment/refactored_agent_deployment_service.py +1 -4
- claude_mpm/services/agents/deployment/remote_agent_discovery_service.py +557 -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 +9 -12
- claude_mpm/services/agents/local_template_manager.py +50 -10
- 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/cli/session_pause_manager.py +1 -1
- claude_mpm/services/cli/unified_dashboard_manager.py +1 -1
- 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_check.py +0 -2
- claude_mpm/services/diagnostics/checks/agent_sources_check.py +577 -0
- claude_mpm/services/diagnostics/checks/instructions_check.py +1 -2
- claude_mpm/services/diagnostics/checks/mcp_check.py +0 -1
- claude_mpm/services/diagnostics/checks/mcp_services_check.py +7 -15
- claude_mpm/services/diagnostics/checks/monitor_check.py +0 -1
- 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 +40 -10
- claude_mpm/services/event_bus/direct_relay.py +3 -3
- claude_mpm/services/event_bus/event_bus.py +36 -3
- claude_mpm/services/events/consumers/logging.py +1 -2
- 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/infrastructure/monitoring/resources.py +1 -1
- 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/local_ops/process_manager.py +1 -1
- claude_mpm/services/local_ops/resource_monitor.py +2 -2
- claude_mpm/services/mcp_config_manager.py +75 -145
- claude_mpm/services/mcp_gateway/config/configuration.py +1 -1
- 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_gateway/server/stdio_server.py +0 -2
- claude_mpm/services/mcp_gateway/tools/document_summarizer.py +1 -1
- claude_mpm/services/mcp_gateway/tools/kuzu_memory_service.py +6 -2
- claude_mpm/services/mcp_service_verifier.py +6 -3
- claude_mpm/services/memory/optimizer.py +1 -1
- claude_mpm/services/model/model_router.py +8 -9
- claude_mpm/services/monitor/daemon.py +29 -9
- claude_mpm/services/monitor/daemon_manager.py +96 -19
- claude_mpm/services/monitor/server.py +2 -2
- claude_mpm/services/native_agent_converter.py +356 -0
- claude_mpm/services/port_manager.py +1 -1
- claude_mpm/services/pr/__init__.py +14 -0
- claude_mpm/services/pr/pr_template_service.py +329 -0
- claude_mpm/services/project/documentation_manager.py +2 -1
- claude_mpm/services/project/project_organizer.py +4 -0
- claude_mpm/services/project/toolchain_analyzer.py +3 -1
- claude_mpm/services/runner_configuration_service.py +17 -3
- claude_mpm/services/self_upgrade_service.py +165 -7
- 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/skills_config.py +547 -0
- claude_mpm/services/skills_deployer.py +955 -0
- claude_mpm/services/socketio/handlers/connection.py +1 -1
- claude_mpm/services/socketio/handlers/git.py +2 -2
- claude_mpm/services/socketio/server/core.py +1 -4
- claude_mpm/services/socketio/server/main.py +1 -3
- claude_mpm/services/system_instructions_service.py +1 -3
- claude_mpm/services/unified/analyzer_strategies/performance_analyzer.py +0 -3
- claude_mpm/services/unified/analyzer_strategies/security_analyzer.py +0 -1
- claude_mpm/services/unified/deployment_strategies/cloud_strategies.py +1 -1
- claude_mpm/services/unified/deployment_strategies/vercel.py +1 -5
- claude_mpm/services/unified/unified_deployment.py +1 -5
- claude_mpm/services/version_control/conflict_resolution.py +6 -4
- claude_mpm/services/visualization/__init__.py +1 -5
- claude_mpm/services/visualization/mermaid_generator.py +2 -3
- claude_mpm/skills/bundled/infrastructure/env-manager/scripts/validate_env.py +576 -0
- claude_mpm/skills/bundled/performance-profiling.md +6 -0
- claude_mpm/skills/bundled/testing/webapp-testing/scripts/with_server.py +2 -2
- claude_mpm/skills/skills_registry.py +0 -1
- claude_mpm/templates/questions/__init__.py +38 -0
- claude_mpm/templates/questions/base.py +193 -0
- claude_mpm/templates/questions/pr_strategy.py +311 -0
- claude_mpm/templates/questions/project_init.py +385 -0
- claude_mpm/templates/questions/ticket_mgmt.py +394 -0
- claude_mpm/tools/__main__.py +8 -8
- claude_mpm/tools/code_tree_analyzer/analysis.py +1 -1
- claude_mpm/utils/agent_dependency_loader.py +80 -13
- claude_mpm/utils/agent_filters.py +288 -0
- claude_mpm/utils/dependency_cache.py +3 -1
- claude_mpm/utils/gitignore.py +244 -0
- claude_mpm/utils/log_cleanup.py +3 -3
- claude_mpm/utils/migration.py +372 -0
- claude_mpm/utils/progress.py +387 -0
- claude_mpm/utils/robust_installer.py +3 -5
- claude_mpm/utils/structured_questions.py +619 -0
- {claude_mpm-4.21.3.dist-info → claude_mpm-5.1.9.dist-info}/METADATA +496 -65
- {claude_mpm-4.21.3.dist-info → claude_mpm-5.1.9.dist-info}/RECORD +284 -443
- claude_mpm/agents/templates/.claude-mpm/memories/README.md +0 -17
- claude_mpm/agents/templates/.claude-mpm/memories/engineer_memories.md +0 -3
- 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 -180
- claude_mpm/agents/templates/circuit_breakers.md +0 -638
- 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 -211
- 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/local_ops_agent.json +0 -1840
- claude_mpm/agents/templates/logs/prompts/agent_engineer_20250826_014258_728.md +0 -39
- claude_mpm/agents/templates/logs/prompts/agent_engineer_20250901_010124_142.md +0 -400
- 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 -140
- 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 -242
- claude_mpm/agents/templates/react_engineer.json +0 -238
- claude_mpm/agents/templates/refactoring_engineer.json +0 -276
- claude_mpm/agents/templates/research.json +0 -188
- 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/ticketing.json +0 -177
- 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 -157
- claude_mpm/agents/templates/web_qa.json +0 -399
- claude_mpm/agents/templates/web_ui.json +0 -189
- claude_mpm/commands/mpm-tickets.md +0 -102
- claude_mpm/dashboard/.claude-mpm/socketio-instances.json +0 -1
- claude_mpm/dashboard/react/components/DataInspector/DataInspector.module.css +0 -188
- claude_mpm/dashboard/react/components/EventViewer/EventViewer.module.css +0 -156
- claude_mpm/dashboard/react/components/shared/ConnectionStatus.module.css +0 -38
- claude_mpm/dashboard/react/components/shared/FilterBar.module.css +0 -92
- claude_mpm/dashboard/static/archive/activity_dashboard_fixed.html +0 -248
- claude_mpm/dashboard/static/archive/activity_dashboard_test.html +0 -61
- claude_mpm/dashboard/static/archive/test_activity_connection.html +0 -179
- claude_mpm/dashboard/static/archive/test_claude_tree_tab.html +0 -68
- claude_mpm/dashboard/static/archive/test_dashboard.html +0 -409
- claude_mpm/dashboard/static/archive/test_dashboard_fixed.html +0 -519
- claude_mpm/dashboard/static/archive/test_dashboard_verification.html +0 -181
- claude_mpm/dashboard/static/archive/test_file_data.html +0 -315
- claude_mpm/dashboard/static/archive/test_file_tree_empty_state.html +0 -243
- claude_mpm/dashboard/static/archive/test_file_tree_fix.html +0 -234
- claude_mpm/dashboard/static/archive/test_file_tree_rename.html +0 -117
- claude_mpm/dashboard/static/archive/test_file_tree_tab.html +0 -115
- claude_mpm/dashboard/static/archive/test_file_viewer.html +0 -224
- claude_mpm/dashboard/static/archive/test_final_activity.html +0 -220
- claude_mpm/dashboard/static/archive/test_tab_fix.html +0 -139
- 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/agent-hierarchy.js +0 -777
- claude_mpm/dashboard/static/built/components/agent-inference.js +0 -2
- 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-viewer.js +0 -2
- 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-viewer.js +0 -2
- claude_mpm/dashboard/static/built/components/export-manager.js +0 -2
- 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-viewer.js +0 -2
- claude_mpm/dashboard/static/built/components/hud-library-loader.js +0 -2
- claude_mpm/dashboard/static/built/components/hud-manager.js +0 -2
- claude_mpm/dashboard/static/built/components/hud-visualizer.js +0 -2
- claude_mpm/dashboard/static/built/components/module-viewer.js +0 -2
- 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/socket-manager.js +0 -2
- claude_mpm/dashboard/static/built/components/ui-state-manager.js +0 -2
- claude_mpm/dashboard/static/built/components/unified-data-viewer.js +0 -2
- claude_mpm/dashboard/static/built/components/working-directory.js +0 -2
- claude_mpm/dashboard/static/built/connection-manager.js +0 -536
- claude_mpm/dashboard/static/built/dashboard.js +0 -2
- 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/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/tab-isolation-fix.js +0 -185
- claude_mpm/dashboard/static/dist/assets/events.DjpNxWNo.css +0 -1
- claude_mpm/dashboard/static/dist/components/activity-tree.js +0 -2
- claude_mpm/dashboard/static/dist/components/agent-inference.js +0 -2
- claude_mpm/dashboard/static/dist/components/code-tree.js +0 -2
- claude_mpm/dashboard/static/dist/components/code-viewer.js +0 -2
- claude_mpm/dashboard/static/dist/components/event-processor.js +0 -2
- claude_mpm/dashboard/static/dist/components/event-viewer.js +0 -2
- claude_mpm/dashboard/static/dist/components/export-manager.js +0 -2
- claude_mpm/dashboard/static/dist/components/file-tool-tracker.js +0 -2
- claude_mpm/dashboard/static/dist/components/file-viewer.js +0 -2
- claude_mpm/dashboard/static/dist/components/hud-library-loader.js +0 -2
- claude_mpm/dashboard/static/dist/components/hud-manager.js +0 -2
- claude_mpm/dashboard/static/dist/components/hud-visualizer.js +0 -2
- claude_mpm/dashboard/static/dist/components/module-viewer.js +0 -2
- claude_mpm/dashboard/static/dist/components/session-manager.js +0 -2
- claude_mpm/dashboard/static/dist/components/socket-manager.js +0 -2
- claude_mpm/dashboard/static/dist/components/ui-state-manager.js +0 -2
- claude_mpm/dashboard/static/dist/components/unified-data-viewer.js +0 -2
- claude_mpm/dashboard/static/dist/components/working-directory.js +0 -2
- claude_mpm/dashboard/static/dist/dashboard.js +0 -2
- claude_mpm/dashboard/static/dist/react/events.js +0 -30
- claude_mpm/dashboard/static/dist/socket-client.js +0 -2
- claude_mpm/dashboard/static/events.html +0 -607
- claude_mpm/dashboard/static/index.html +0 -635
- 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/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/static/test-archive/test_debug.html +0 -25
- 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/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/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/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/main/artifacts-builder/SKILL.md +0 -86
- 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/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/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/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/testing/condition-based-waiting/SKILL.md +0 -119
- 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/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/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/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/{response_format.md → response-format.md} +0 -0
- /claude_mpm/agents/templates/{validation_templates.md → validation-templates.md} +0 -0
- {claude_mpm-4.21.3.dist-info → claude_mpm-5.1.9.dist-info}/WHEEL +0 -0
- {claude_mpm-4.21.3.dist-info → claude_mpm-5.1.9.dist-info}/entry_points.txt +0 -0
- {claude_mpm-4.21.3.dist-info → claude_mpm-5.1.9.dist-info}/licenses/LICENSE +0 -0
- {claude_mpm-4.21.3.dist-info → claude_mpm-5.1.9.dist-info}/top_level.txt +0 -0
|
@@ -0,0 +1,587 @@
|
|
|
1
|
+
"""
|
|
2
|
+
Check skill sources configuration and health.
|
|
3
|
+
|
|
4
|
+
WHY: Verify that the single-tier Git-based skill system is properly configured,
|
|
5
|
+
sources are accessible, and skills are discoverable from configured repositories.
|
|
6
|
+
"""
|
|
7
|
+
|
|
8
|
+
import logging
|
|
9
|
+
from pathlib import Path
|
|
10
|
+
from typing import Dict, List, Optional
|
|
11
|
+
|
|
12
|
+
from ....core.enums import OperationResult, ValidationSeverity
|
|
13
|
+
from ..models import DiagnosticResult
|
|
14
|
+
from .base_check import BaseDiagnosticCheck
|
|
15
|
+
|
|
16
|
+
logger = logging.getLogger(__name__)
|
|
17
|
+
|
|
18
|
+
|
|
19
|
+
class SkillSourcesCheck(BaseDiagnosticCheck):
|
|
20
|
+
"""Check skill sources configuration and health.
|
|
21
|
+
|
|
22
|
+
Verifies:
|
|
23
|
+
- Configuration file exists and is valid YAML
|
|
24
|
+
- At least one source is configured
|
|
25
|
+
- Enabled sources are accessible (HTTP 200)
|
|
26
|
+
- Cache directory is healthy and writable
|
|
27
|
+
- Priority conflicts are identified
|
|
28
|
+
- Skills can be discovered from sources
|
|
29
|
+
|
|
30
|
+
WHY: The single-tier system relies on Git sources being properly configured
|
|
31
|
+
and accessible. This check ensures the skill deployment pipeline is healthy.
|
|
32
|
+
"""
|
|
33
|
+
|
|
34
|
+
@property
|
|
35
|
+
def name(self) -> str:
|
|
36
|
+
return "skill_sources_check"
|
|
37
|
+
|
|
38
|
+
@property
|
|
39
|
+
def category(self) -> str:
|
|
40
|
+
return "Skill Sources"
|
|
41
|
+
|
|
42
|
+
def should_run(self) -> bool:
|
|
43
|
+
"""Check should run if single-tier system is in use.
|
|
44
|
+
|
|
45
|
+
Returns:
|
|
46
|
+
True if skill sources configuration exists or could exist
|
|
47
|
+
"""
|
|
48
|
+
# Always run - we want to check if configuration should be created
|
|
49
|
+
return True
|
|
50
|
+
|
|
51
|
+
def run(self) -> DiagnosticResult:
|
|
52
|
+
"""Run skill sources diagnostics."""
|
|
53
|
+
try:
|
|
54
|
+
sub_results = []
|
|
55
|
+
details = {}
|
|
56
|
+
|
|
57
|
+
# Check 1: Configuration file exists
|
|
58
|
+
config_result = self._check_config_file()
|
|
59
|
+
sub_results.append(config_result)
|
|
60
|
+
details["config_exists"] = config_result.status == OperationResult.SUCCESS
|
|
61
|
+
|
|
62
|
+
# If no config file, return early with guidance
|
|
63
|
+
if config_result.status == ValidationSeverity.ERROR:
|
|
64
|
+
return DiagnosticResult(
|
|
65
|
+
category=self.category,
|
|
66
|
+
status=ValidationSeverity.ERROR,
|
|
67
|
+
message="Skill sources not configured",
|
|
68
|
+
details=details,
|
|
69
|
+
fix_command="claude-mpm skill-source add https://github.com/bobmatnyc/claude-mpm-skills",
|
|
70
|
+
fix_description="Add default system repository",
|
|
71
|
+
sub_results=sub_results if self.verbose else [],
|
|
72
|
+
)
|
|
73
|
+
|
|
74
|
+
# Check 2: Configuration is valid YAML
|
|
75
|
+
config_valid_result = self._check_config_valid()
|
|
76
|
+
sub_results.append(config_valid_result)
|
|
77
|
+
if config_valid_result.status == ValidationSeverity.ERROR:
|
|
78
|
+
return DiagnosticResult(
|
|
79
|
+
category=self.category,
|
|
80
|
+
status=ValidationSeverity.ERROR,
|
|
81
|
+
message="Invalid configuration file",
|
|
82
|
+
details=details,
|
|
83
|
+
fix_command="# Check YAML syntax and fix errors",
|
|
84
|
+
fix_description="Validate and fix configuration",
|
|
85
|
+
sub_results=sub_results if self.verbose else [],
|
|
86
|
+
)
|
|
87
|
+
|
|
88
|
+
# Load configuration for remaining checks
|
|
89
|
+
from ....config.skill_sources import SkillSourceConfiguration
|
|
90
|
+
|
|
91
|
+
config = SkillSourceConfiguration()
|
|
92
|
+
sources = config.load()
|
|
93
|
+
|
|
94
|
+
# Check 3: At least one source configured
|
|
95
|
+
sources_result = self._check_sources_configured(sources)
|
|
96
|
+
sub_results.append(sources_result)
|
|
97
|
+
details["total_sources"] = len(sources)
|
|
98
|
+
details["enabled_sources"] = len([s for s in sources if s.enabled])
|
|
99
|
+
|
|
100
|
+
# Check 4: System repository accessible (if enabled)
|
|
101
|
+
system_repo_result = self._check_system_repo_accessible(sources)
|
|
102
|
+
if system_repo_result:
|
|
103
|
+
sub_results.append(system_repo_result)
|
|
104
|
+
|
|
105
|
+
# Check 5: Enabled sources reachable
|
|
106
|
+
reachability_result = self._check_sources_reachable(sources)
|
|
107
|
+
sub_results.append(reachability_result)
|
|
108
|
+
details["reachable_sources"] = reachability_result.details.get(
|
|
109
|
+
"reachable_count", 0
|
|
110
|
+
)
|
|
111
|
+
details["unreachable_sources"] = reachability_result.details.get(
|
|
112
|
+
"unreachable_count", 0
|
|
113
|
+
)
|
|
114
|
+
|
|
115
|
+
# Check 6: Cache directory healthy
|
|
116
|
+
cache_result = self._check_cache_directory()
|
|
117
|
+
sub_results.append(cache_result)
|
|
118
|
+
details["cache_healthy"] = cache_result.status == OperationResult.SUCCESS
|
|
119
|
+
|
|
120
|
+
# Check 7: Priority conflicts
|
|
121
|
+
priority_result = self._check_priority_conflicts(sources)
|
|
122
|
+
if priority_result:
|
|
123
|
+
sub_results.append(priority_result)
|
|
124
|
+
details["priority_conflicts"] = priority_result.details.get(
|
|
125
|
+
"conflict_count", 0
|
|
126
|
+
)
|
|
127
|
+
|
|
128
|
+
# Check 8: Skills discovered
|
|
129
|
+
discovery_result = self._check_skills_discovered(config)
|
|
130
|
+
sub_results.append(discovery_result)
|
|
131
|
+
details["skills_discovered"] = discovery_result.details.get(
|
|
132
|
+
"total_skills", 0
|
|
133
|
+
)
|
|
134
|
+
|
|
135
|
+
# Determine overall status
|
|
136
|
+
error_results = [
|
|
137
|
+
r for r in sub_results if r.status == ValidationSeverity.ERROR
|
|
138
|
+
]
|
|
139
|
+
warning_results = [
|
|
140
|
+
r for r in sub_results if r.status == ValidationSeverity.WARNING
|
|
141
|
+
]
|
|
142
|
+
|
|
143
|
+
if error_results:
|
|
144
|
+
status = ValidationSeverity.ERROR
|
|
145
|
+
message = f"Skill sources have {len(error_results)} critical issue(s)"
|
|
146
|
+
fix_command = None
|
|
147
|
+
fix_description = None
|
|
148
|
+
elif warning_results:
|
|
149
|
+
status = ValidationSeverity.WARNING
|
|
150
|
+
message = f"Skill sources have {len(warning_results)} minor issue(s)"
|
|
151
|
+
fix_command = "claude-mpm skill-source update"
|
|
152
|
+
fix_description = "Update all sources to refresh cache"
|
|
153
|
+
else:
|
|
154
|
+
status = OperationResult.SUCCESS
|
|
155
|
+
enabled_count = details["enabled_sources"]
|
|
156
|
+
skills_count = details["skills_discovered"]
|
|
157
|
+
message = f"All checks passed ({enabled_count} source(s), {skills_count} skill(s))"
|
|
158
|
+
fix_command = None
|
|
159
|
+
fix_description = None
|
|
160
|
+
|
|
161
|
+
return DiagnosticResult(
|
|
162
|
+
category=self.category,
|
|
163
|
+
status=status,
|
|
164
|
+
message=message,
|
|
165
|
+
details=details,
|
|
166
|
+
fix_command=fix_command,
|
|
167
|
+
fix_description=fix_description,
|
|
168
|
+
sub_results=sub_results if self.verbose else [],
|
|
169
|
+
)
|
|
170
|
+
|
|
171
|
+
except Exception as e:
|
|
172
|
+
logger.exception("Skill sources check failed")
|
|
173
|
+
return DiagnosticResult(
|
|
174
|
+
category=self.category,
|
|
175
|
+
status=ValidationSeverity.ERROR,
|
|
176
|
+
message=f"Skill sources check failed: {e!s}",
|
|
177
|
+
details={"error": str(e)},
|
|
178
|
+
)
|
|
179
|
+
|
|
180
|
+
def _check_config_file(self) -> DiagnosticResult:
|
|
181
|
+
"""Check if configuration file exists."""
|
|
182
|
+
config_path = Path.home() / ".claude-mpm" / "config" / "skill_sources.yaml"
|
|
183
|
+
|
|
184
|
+
if not config_path.exists():
|
|
185
|
+
return DiagnosticResult(
|
|
186
|
+
category="Configuration File",
|
|
187
|
+
status=ValidationSeverity.ERROR,
|
|
188
|
+
message=f"Configuration file not found: {config_path}",
|
|
189
|
+
details={"path": str(config_path)},
|
|
190
|
+
fix_command="claude-mpm skill-source add https://github.com/bobmatnyc/claude-mpm-skills",
|
|
191
|
+
fix_description="Create configuration and add default repository",
|
|
192
|
+
)
|
|
193
|
+
|
|
194
|
+
return DiagnosticResult(
|
|
195
|
+
category="Configuration File",
|
|
196
|
+
status=OperationResult.SUCCESS,
|
|
197
|
+
message=f"Found at {config_path}",
|
|
198
|
+
details={"path": str(config_path)},
|
|
199
|
+
)
|
|
200
|
+
|
|
201
|
+
def _check_config_valid(self) -> DiagnosticResult:
|
|
202
|
+
"""Check if configuration is valid YAML."""
|
|
203
|
+
config_path = Path.home() / ".claude-mpm" / "config" / "skill_sources.yaml"
|
|
204
|
+
|
|
205
|
+
try:
|
|
206
|
+
import yaml
|
|
207
|
+
|
|
208
|
+
with open(config_path) as f:
|
|
209
|
+
data = yaml.safe_load(f)
|
|
210
|
+
|
|
211
|
+
if not data:
|
|
212
|
+
return DiagnosticResult(
|
|
213
|
+
category="Configuration Validity",
|
|
214
|
+
status=ValidationSeverity.WARNING,
|
|
215
|
+
message="Configuration file is empty",
|
|
216
|
+
details={"path": str(config_path)},
|
|
217
|
+
)
|
|
218
|
+
|
|
219
|
+
# Basic structure validation
|
|
220
|
+
if not isinstance(data, dict):
|
|
221
|
+
return DiagnosticResult(
|
|
222
|
+
category="Configuration Validity",
|
|
223
|
+
status=ValidationSeverity.ERROR,
|
|
224
|
+
message="Configuration must be YAML dictionary",
|
|
225
|
+
details={"path": str(config_path), "type": str(type(data))},
|
|
226
|
+
)
|
|
227
|
+
|
|
228
|
+
return DiagnosticResult(
|
|
229
|
+
category="Configuration Validity",
|
|
230
|
+
status=OperationResult.SUCCESS,
|
|
231
|
+
message="Configuration is valid YAML",
|
|
232
|
+
details={"path": str(config_path)},
|
|
233
|
+
)
|
|
234
|
+
|
|
235
|
+
except yaml.YAMLError as e:
|
|
236
|
+
return DiagnosticResult(
|
|
237
|
+
category="Configuration Validity",
|
|
238
|
+
status=ValidationSeverity.ERROR,
|
|
239
|
+
message=f"Invalid YAML: {e!s}",
|
|
240
|
+
details={"path": str(config_path), "error": str(e)},
|
|
241
|
+
fix_command=f"cat {config_path}",
|
|
242
|
+
fix_description="Check YAML syntax errors",
|
|
243
|
+
)
|
|
244
|
+
except Exception as e:
|
|
245
|
+
return DiagnosticResult(
|
|
246
|
+
category="Configuration Validity",
|
|
247
|
+
status=ValidationSeverity.ERROR,
|
|
248
|
+
message=f"Failed to read configuration: {e!s}",
|
|
249
|
+
details={"path": str(config_path), "error": str(e)},
|
|
250
|
+
)
|
|
251
|
+
|
|
252
|
+
def _check_sources_configured(self, sources: List) -> DiagnosticResult:
|
|
253
|
+
"""Check if at least one source is configured.
|
|
254
|
+
|
|
255
|
+
Args:
|
|
256
|
+
sources: List of SkillSource instances
|
|
257
|
+
"""
|
|
258
|
+
total_sources = len(sources)
|
|
259
|
+
|
|
260
|
+
if total_sources == 0:
|
|
261
|
+
return DiagnosticResult(
|
|
262
|
+
category="Sources Configured",
|
|
263
|
+
status=ValidationSeverity.WARNING,
|
|
264
|
+
message="No skill sources configured",
|
|
265
|
+
details={"total": 0, "enabled": 0},
|
|
266
|
+
fix_command="claude-mpm skill-source add https://github.com/bobmatnyc/claude-mpm-skills",
|
|
267
|
+
fix_description="Add default skill repository",
|
|
268
|
+
)
|
|
269
|
+
|
|
270
|
+
enabled_sources = len([s for s in sources if s.enabled])
|
|
271
|
+
|
|
272
|
+
if enabled_sources == 0:
|
|
273
|
+
return DiagnosticResult(
|
|
274
|
+
category="Sources Configured",
|
|
275
|
+
status=ValidationSeverity.WARNING,
|
|
276
|
+
message=f"{total_sources} source(s) configured but all disabled",
|
|
277
|
+
details={"total": total_sources, "enabled": 0},
|
|
278
|
+
fix_command="claude-mpm skill-source enable <source-id>",
|
|
279
|
+
fix_description="Enable at least one source",
|
|
280
|
+
)
|
|
281
|
+
|
|
282
|
+
return DiagnosticResult(
|
|
283
|
+
category="Sources Configured",
|
|
284
|
+
status=OperationResult.SUCCESS,
|
|
285
|
+
message=f"{enabled_sources} enabled source(s) ({total_sources} total)",
|
|
286
|
+
details={"total": total_sources, "enabled": enabled_sources},
|
|
287
|
+
)
|
|
288
|
+
|
|
289
|
+
def _check_system_repo_accessible(
|
|
290
|
+
self, sources: List
|
|
291
|
+
) -> Optional[DiagnosticResult]:
|
|
292
|
+
"""Check if system repository is accessible.
|
|
293
|
+
|
|
294
|
+
Args:
|
|
295
|
+
sources: List of SkillSource instances
|
|
296
|
+
"""
|
|
297
|
+
# Find system repository (priority 0)
|
|
298
|
+
system_sources = [s for s in sources if s.priority == 0 and s.enabled]
|
|
299
|
+
|
|
300
|
+
if not system_sources:
|
|
301
|
+
# No system repo or disabled, skip check
|
|
302
|
+
return None
|
|
303
|
+
|
|
304
|
+
system_repo = system_sources[0]
|
|
305
|
+
return self._check_repo_accessible(
|
|
306
|
+
system_repo.url, "System Repository", is_system=True
|
|
307
|
+
)
|
|
308
|
+
|
|
309
|
+
def _check_sources_reachable(self, sources: List) -> DiagnosticResult:
|
|
310
|
+
"""Check if enabled sources are reachable.
|
|
311
|
+
|
|
312
|
+
Args:
|
|
313
|
+
sources: List of SkillSource instances
|
|
314
|
+
"""
|
|
315
|
+
enabled_sources = [s for s in sources if s.enabled]
|
|
316
|
+
|
|
317
|
+
if not enabled_sources:
|
|
318
|
+
return DiagnosticResult(
|
|
319
|
+
category="Source Reachability",
|
|
320
|
+
status=OperationResult.SKIPPED,
|
|
321
|
+
message="No enabled sources to check",
|
|
322
|
+
details={"reachable_count": 0, "unreachable_count": 0},
|
|
323
|
+
)
|
|
324
|
+
|
|
325
|
+
reachable = []
|
|
326
|
+
unreachable = []
|
|
327
|
+
details: Dict[str, str] = {}
|
|
328
|
+
|
|
329
|
+
for source in enabled_sources:
|
|
330
|
+
result = self._check_repo_accessible(source.url, source.id)
|
|
331
|
+
if result.status == OperationResult.SUCCESS:
|
|
332
|
+
reachable.append(source.id)
|
|
333
|
+
details[source.id] = "reachable"
|
|
334
|
+
else:
|
|
335
|
+
unreachable.append(source.id)
|
|
336
|
+
details[source.id] = result.message
|
|
337
|
+
|
|
338
|
+
if len(unreachable) == len(enabled_sources):
|
|
339
|
+
# All sources unreachable
|
|
340
|
+
return DiagnosticResult(
|
|
341
|
+
category="Source Reachability",
|
|
342
|
+
status=ValidationSeverity.ERROR,
|
|
343
|
+
message=f"All {len(enabled_sources)} source(s) unreachable",
|
|
344
|
+
details={
|
|
345
|
+
"reachable_count": 0,
|
|
346
|
+
"unreachable_count": len(unreachable),
|
|
347
|
+
"sources": details,
|
|
348
|
+
},
|
|
349
|
+
fix_command="claude-mpm skill-source list",
|
|
350
|
+
fix_description="Check source URLs and network connectivity",
|
|
351
|
+
)
|
|
352
|
+
if unreachable:
|
|
353
|
+
# Some sources unreachable
|
|
354
|
+
return DiagnosticResult(
|
|
355
|
+
category="Source Reachability",
|
|
356
|
+
status=ValidationSeverity.WARNING,
|
|
357
|
+
message=f"{len(unreachable)}/{len(enabled_sources)} source(s) unreachable",
|
|
358
|
+
details={
|
|
359
|
+
"reachable_count": len(reachable),
|
|
360
|
+
"unreachable_count": len(unreachable),
|
|
361
|
+
"sources": details,
|
|
362
|
+
"unreachable_sources": unreachable,
|
|
363
|
+
},
|
|
364
|
+
)
|
|
365
|
+
# All sources reachable
|
|
366
|
+
return DiagnosticResult(
|
|
367
|
+
category="Source Reachability",
|
|
368
|
+
status=OperationResult.SUCCESS,
|
|
369
|
+
message=f"All {len(enabled_sources)} source(s) reachable",
|
|
370
|
+
details={
|
|
371
|
+
"reachable_count": len(reachable),
|
|
372
|
+
"unreachable_count": 0,
|
|
373
|
+
"sources": details,
|
|
374
|
+
},
|
|
375
|
+
)
|
|
376
|
+
|
|
377
|
+
def _check_repo_accessible(
|
|
378
|
+
self, url: str, identifier: str, is_system: bool = False
|
|
379
|
+
) -> DiagnosticResult:
|
|
380
|
+
"""Check if a repository is accessible via HTTP."""
|
|
381
|
+
try:
|
|
382
|
+
import urllib.request
|
|
383
|
+
from urllib.error import HTTPError, URLError
|
|
384
|
+
|
|
385
|
+
# Convert git URL to HTTPS if needed
|
|
386
|
+
if url.startswith("git@github.com:"):
|
|
387
|
+
url = url.replace("git@github.com:", "https://github.com/")
|
|
388
|
+
if url.endswith(".git"):
|
|
389
|
+
url = url[:-4]
|
|
390
|
+
|
|
391
|
+
# Try to fetch repository (use HEAD request to be lightweight)
|
|
392
|
+
req = urllib.request.Request(url, method="HEAD")
|
|
393
|
+
req.add_header("User-Agent", "claude-mpm-doctor/1.0")
|
|
394
|
+
|
|
395
|
+
with urllib.request.urlopen(req, timeout=5) as response:
|
|
396
|
+
status = response.status
|
|
397
|
+
|
|
398
|
+
if status == 200:
|
|
399
|
+
return DiagnosticResult(
|
|
400
|
+
category=identifier,
|
|
401
|
+
status=OperationResult.SUCCESS,
|
|
402
|
+
message="Accessible",
|
|
403
|
+
details={"url": url, "status": status},
|
|
404
|
+
)
|
|
405
|
+
return DiagnosticResult(
|
|
406
|
+
category=identifier,
|
|
407
|
+
status=ValidationSeverity.WARNING,
|
|
408
|
+
message=f"HTTP {status}",
|
|
409
|
+
details={"url": url, "status": status},
|
|
410
|
+
)
|
|
411
|
+
|
|
412
|
+
except HTTPError as e:
|
|
413
|
+
return DiagnosticResult(
|
|
414
|
+
category=identifier,
|
|
415
|
+
status=ValidationSeverity.WARNING,
|
|
416
|
+
message=f"HTTP {e.code}",
|
|
417
|
+
details={"url": url, "status": e.code, "error": str(e)},
|
|
418
|
+
)
|
|
419
|
+
except URLError as e:
|
|
420
|
+
return DiagnosticResult(
|
|
421
|
+
category=identifier,
|
|
422
|
+
status=ValidationSeverity.WARNING,
|
|
423
|
+
message=f"Network error: {e.reason}",
|
|
424
|
+
details={"url": url, "error": str(e.reason)},
|
|
425
|
+
)
|
|
426
|
+
except Exception as e:
|
|
427
|
+
return DiagnosticResult(
|
|
428
|
+
category=identifier,
|
|
429
|
+
status=ValidationSeverity.WARNING,
|
|
430
|
+
message=f"Check failed: {e!s}",
|
|
431
|
+
details={"url": url, "error": str(e)},
|
|
432
|
+
)
|
|
433
|
+
|
|
434
|
+
def _check_cache_directory(self) -> DiagnosticResult:
|
|
435
|
+
"""Check cache directory health."""
|
|
436
|
+
cache_dir = Path.home() / ".claude-mpm" / "cache" / "skills"
|
|
437
|
+
|
|
438
|
+
if not cache_dir.exists():
|
|
439
|
+
return DiagnosticResult(
|
|
440
|
+
category="Cache Directory",
|
|
441
|
+
status=ValidationSeverity.WARNING,
|
|
442
|
+
message=f"Cache directory does not exist: {cache_dir}",
|
|
443
|
+
details={"path": str(cache_dir), "exists": False},
|
|
444
|
+
fix_command="claude-mpm skill-source update",
|
|
445
|
+
fix_description="Create cache directory and sync sources",
|
|
446
|
+
)
|
|
447
|
+
|
|
448
|
+
# Check if writable
|
|
449
|
+
if not cache_dir.is_dir():
|
|
450
|
+
return DiagnosticResult(
|
|
451
|
+
category="Cache Directory",
|
|
452
|
+
status=ValidationSeverity.ERROR,
|
|
453
|
+
message=f"Cache path exists but is not a directory: {cache_dir}",
|
|
454
|
+
details={"path": str(cache_dir), "is_dir": False},
|
|
455
|
+
)
|
|
456
|
+
|
|
457
|
+
# Test write access
|
|
458
|
+
try:
|
|
459
|
+
test_file = cache_dir / ".write_test"
|
|
460
|
+
test_file.touch()
|
|
461
|
+
test_file.unlink()
|
|
462
|
+
|
|
463
|
+
return DiagnosticResult(
|
|
464
|
+
category="Cache Directory",
|
|
465
|
+
status=OperationResult.SUCCESS,
|
|
466
|
+
message=f"Cache directory healthy: {cache_dir}",
|
|
467
|
+
details={"path": str(cache_dir), "writable": True},
|
|
468
|
+
)
|
|
469
|
+
|
|
470
|
+
except Exception as e:
|
|
471
|
+
return DiagnosticResult(
|
|
472
|
+
category="Cache Directory",
|
|
473
|
+
status=ValidationSeverity.ERROR,
|
|
474
|
+
message=f"Cache directory not writable: {e!s}",
|
|
475
|
+
details={"path": str(cache_dir), "writable": False, "error": str(e)},
|
|
476
|
+
fix_command=f"chmod -R u+w {cache_dir}",
|
|
477
|
+
fix_description="Fix cache directory permissions",
|
|
478
|
+
)
|
|
479
|
+
|
|
480
|
+
def _check_priority_conflicts(self, sources: List) -> Optional[DiagnosticResult]:
|
|
481
|
+
"""Check for priority conflicts.
|
|
482
|
+
|
|
483
|
+
Args:
|
|
484
|
+
sources: List of SkillSource instances
|
|
485
|
+
"""
|
|
486
|
+
enabled_sources = [s for s in sources if s.enabled]
|
|
487
|
+
|
|
488
|
+
if len(enabled_sources) < 2:
|
|
489
|
+
# No conflicts possible with 0-1 sources
|
|
490
|
+
return None
|
|
491
|
+
|
|
492
|
+
# Group sources by priority
|
|
493
|
+
priority_groups: Dict[int, List[str]] = {}
|
|
494
|
+
for source in enabled_sources:
|
|
495
|
+
priority = source.priority
|
|
496
|
+
if priority not in priority_groups:
|
|
497
|
+
priority_groups[priority] = []
|
|
498
|
+
priority_groups[priority].append(source.id)
|
|
499
|
+
|
|
500
|
+
# Find conflicts (multiple sources with same priority)
|
|
501
|
+
conflicts = {p: ids for p, ids in priority_groups.items() if len(ids) > 1}
|
|
502
|
+
|
|
503
|
+
if not conflicts:
|
|
504
|
+
return DiagnosticResult(
|
|
505
|
+
category="Priority Conflicts",
|
|
506
|
+
status=OperationResult.SUCCESS,
|
|
507
|
+
message="No priority conflicts detected",
|
|
508
|
+
details={"conflict_count": 0},
|
|
509
|
+
)
|
|
510
|
+
|
|
511
|
+
conflict_details = []
|
|
512
|
+
for priority, identifiers in conflicts.items():
|
|
513
|
+
conflict_details.append(f"Priority {priority}: {', '.join(identifiers)}")
|
|
514
|
+
|
|
515
|
+
return DiagnosticResult(
|
|
516
|
+
category="Priority Conflicts",
|
|
517
|
+
status=ValidationSeverity.INFO,
|
|
518
|
+
message=f"{len(conflicts)} priority conflict(s) detected",
|
|
519
|
+
details={
|
|
520
|
+
"conflict_count": len(conflicts),
|
|
521
|
+
"conflicts": conflict_details,
|
|
522
|
+
},
|
|
523
|
+
fix_description="Consider assigning unique priorities to avoid ambiguous resolution",
|
|
524
|
+
)
|
|
525
|
+
|
|
526
|
+
def _check_skills_discovered(self, config) -> DiagnosticResult:
|
|
527
|
+
"""Check if skills can be discovered from sources.
|
|
528
|
+
|
|
529
|
+
Args:
|
|
530
|
+
config: SkillSourceConfiguration instance
|
|
531
|
+
"""
|
|
532
|
+
try:
|
|
533
|
+
from ....services.skills.git_skill_source_manager import (
|
|
534
|
+
GitSkillSourceManager,
|
|
535
|
+
)
|
|
536
|
+
|
|
537
|
+
cache_dir = Path.home() / ".claude-mpm" / "cache" / "skills"
|
|
538
|
+
manager = GitSkillSourceManager(config, cache_dir)
|
|
539
|
+
|
|
540
|
+
# Check if cache has any content
|
|
541
|
+
if not cache_dir.exists() or not list(cache_dir.glob("*")):
|
|
542
|
+
return DiagnosticResult(
|
|
543
|
+
category="Skill Discovery",
|
|
544
|
+
status=ValidationSeverity.INFO,
|
|
545
|
+
message="No cached skills (run: claude-mpm skill-source update)",
|
|
546
|
+
details={"total_skills": 0, "skills_by_source": {}},
|
|
547
|
+
fix_command="claude-mpm skill-source update",
|
|
548
|
+
fix_description="Sync sources to discover skills",
|
|
549
|
+
)
|
|
550
|
+
|
|
551
|
+
available_skills = manager.get_all_skills()
|
|
552
|
+
|
|
553
|
+
if not available_skills:
|
|
554
|
+
return DiagnosticResult(
|
|
555
|
+
category="Skill Discovery",
|
|
556
|
+
status=ValidationSeverity.WARNING,
|
|
557
|
+
message="No skills discovered from configured sources",
|
|
558
|
+
details={"total_skills": 0, "skills_by_source": {}},
|
|
559
|
+
fix_command="claude-mpm skill-source update",
|
|
560
|
+
fix_description="Sync sources to discover skills",
|
|
561
|
+
)
|
|
562
|
+
|
|
563
|
+
# Group skills by source
|
|
564
|
+
skills_by_source: Dict[str, int] = {}
|
|
565
|
+
for skill in available_skills:
|
|
566
|
+
source = skill.get("source_id", "unknown")
|
|
567
|
+
skills_by_source[source] = skills_by_source.get(source, 0) + 1
|
|
568
|
+
|
|
569
|
+
return DiagnosticResult(
|
|
570
|
+
category="Skill Discovery",
|
|
571
|
+
status=OperationResult.SUCCESS,
|
|
572
|
+
message=f"Discovered {len(available_skills)} skill(s)",
|
|
573
|
+
details={
|
|
574
|
+
"total_skills": len(available_skills),
|
|
575
|
+
"skills_by_source": skills_by_source,
|
|
576
|
+
"skill_names": [s.get("name", "unknown") for s in available_skills],
|
|
577
|
+
},
|
|
578
|
+
)
|
|
579
|
+
|
|
580
|
+
except Exception as e:
|
|
581
|
+
logger.exception("Failed to discover skills")
|
|
582
|
+
return DiagnosticResult(
|
|
583
|
+
category="Skill Discovery",
|
|
584
|
+
status=ValidationSeverity.WARNING,
|
|
585
|
+
message=f"Skill discovery failed: {e!s}",
|
|
586
|
+
details={"error": str(e)},
|
|
587
|
+
)
|
|
@@ -14,6 +14,7 @@ from claude_mpm.core.logging_utils import get_logger
|
|
|
14
14
|
|
|
15
15
|
from .checks import (
|
|
16
16
|
AgentCheck,
|
|
17
|
+
AgentSourcesCheck,
|
|
17
18
|
BaseDiagnosticCheck,
|
|
18
19
|
ClaudeCodeCheck,
|
|
19
20
|
CommonIssuesCheck,
|
|
@@ -24,6 +25,7 @@ from .checks import (
|
|
|
24
25
|
MCPCheck,
|
|
25
26
|
MCPServicesCheck,
|
|
26
27
|
MonitorCheck,
|
|
28
|
+
SkillSourcesCheck,
|
|
27
29
|
StartupLogCheck,
|
|
28
30
|
)
|
|
29
31
|
from .models import DiagnosticResult, DiagnosticSummary
|
|
@@ -56,6 +58,8 @@ class DiagnosticRunner:
|
|
|
56
58
|
InstructionsCheck, # Check instruction files early
|
|
57
59
|
ClaudeCodeCheck,
|
|
58
60
|
AgentCheck,
|
|
61
|
+
AgentSourcesCheck, # Check agent sources configuration
|
|
62
|
+
SkillSourcesCheck, # Check skill sources configuration
|
|
59
63
|
MCPCheck,
|
|
60
64
|
MCPServicesCheck, # Check external MCP services
|
|
61
65
|
MonitorCheck,
|
|
@@ -124,6 +128,8 @@ class DiagnosticRunner:
|
|
|
124
128
|
level2 = [
|
|
125
129
|
ClaudeCodeCheck,
|
|
126
130
|
AgentCheck,
|
|
131
|
+
AgentSourcesCheck,
|
|
132
|
+
SkillSourcesCheck,
|
|
127
133
|
MCPCheck,
|
|
128
134
|
MCPServicesCheck,
|
|
129
135
|
MonitorCheck,
|
|
@@ -214,6 +220,9 @@ class DiagnosticRunner:
|
|
|
214
220
|
"claude_code": ClaudeCodeCheck,
|
|
215
221
|
"agents": AgentCheck,
|
|
216
222
|
"agent": AgentCheck,
|
|
223
|
+
"agent-sources": AgentSourcesCheck,
|
|
224
|
+
"agent_sources": AgentSourcesCheck,
|
|
225
|
+
"sources": AgentSourcesCheck,
|
|
217
226
|
"mcp": MCPCheck,
|
|
218
227
|
"mcp_services": MCPServicesCheck,
|
|
219
228
|
"mcp-services": MCPServicesCheck,
|