claude-mpm 4.21.3__py3-none-any.whl → 5.0.2__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.
Files changed (484) hide show
  1. claude_mpm/VERSION +1 -1
  2. claude_mpm/agents/BASE_PM.md +12 -0
  3. claude_mpm/agents/OUTPUT_STYLE.md +3 -48
  4. claude_mpm/agents/PM_INSTRUCTIONS.md +632 -334
  5. claude_mpm/agents/WORKFLOW.md +75 -2
  6. claude_mpm/agents/__init__.py +6 -0
  7. claude_mpm/agents/agent_loader.py +1 -4
  8. claude_mpm/agents/base_agent.json +6 -3
  9. claude_mpm/agents/frontmatter_validator.py +1 -1
  10. claude_mpm/agents/templates/{circuit_breakers.md → circuit-breakers.md} +370 -3
  11. claude_mpm/agents/templates/context-management-examples.md +544 -0
  12. claude_mpm/agents/templates/{pm_red_flags.md → pm-red-flags.md} +89 -19
  13. claude_mpm/agents/templates/pr-workflow-examples.md +427 -0
  14. claude_mpm/agents/templates/research-gate-examples.md +669 -0
  15. claude_mpm/agents/templates/structured-questions-examples.md +615 -0
  16. claude_mpm/agents/templates/ticket-completeness-examples.md +139 -0
  17. claude_mpm/agents/templates/ticketing-examples.md +277 -0
  18. claude_mpm/cli/__init__.py +38 -2
  19. claude_mpm/cli/commands/agent_source.py +774 -0
  20. claude_mpm/cli/commands/agent_state_manager.py +125 -20
  21. claude_mpm/cli/commands/agents.py +684 -13
  22. claude_mpm/cli/commands/agents_cleanup.py +210 -0
  23. claude_mpm/cli/commands/agents_discover.py +338 -0
  24. claude_mpm/cli/commands/aggregate.py +1 -1
  25. claude_mpm/cli/commands/analyze.py +3 -3
  26. claude_mpm/cli/commands/auto_configure.py +2 -6
  27. claude_mpm/cli/commands/cleanup.py +1 -1
  28. claude_mpm/cli/commands/config.py +7 -4
  29. claude_mpm/cli/commands/configure.py +478 -44
  30. claude_mpm/cli/commands/configure_agent_display.py +4 -4
  31. claude_mpm/cli/commands/configure_navigation.py +63 -46
  32. claude_mpm/cli/commands/debug.py +12 -12
  33. claude_mpm/cli/commands/doctor.py +10 -2
  34. claude_mpm/cli/commands/hook_errors.py +277 -0
  35. claude_mpm/cli/commands/local_deploy.py +1 -4
  36. claude_mpm/cli/commands/mcp_install_commands.py +1 -1
  37. claude_mpm/cli/commands/mpm_init/core.py +50 -2
  38. claude_mpm/cli/commands/mpm_init/git_activity.py +10 -10
  39. claude_mpm/cli/commands/mpm_init/prompts.py +6 -6
  40. claude_mpm/cli/commands/run.py +124 -128
  41. claude_mpm/cli/commands/skill_source.py +694 -0
  42. claude_mpm/cli/commands/skills.py +435 -1
  43. claude_mpm/cli/executor.py +78 -3
  44. claude_mpm/cli/interactive/agent_wizard.py +919 -41
  45. claude_mpm/cli/parsers/agent_source_parser.py +171 -0
  46. claude_mpm/cli/parsers/agents_parser.py +173 -4
  47. claude_mpm/cli/parsers/base_parser.py +49 -0
  48. claude_mpm/cli/parsers/config_parser.py +96 -43
  49. claude_mpm/cli/parsers/skill_source_parser.py +169 -0
  50. claude_mpm/cli/parsers/skills_parser.py +138 -0
  51. claude_mpm/cli/parsers/source_parser.py +138 -0
  52. claude_mpm/cli/startup.py +499 -84
  53. claude_mpm/cli/startup_display.py +480 -0
  54. claude_mpm/cli/utils.py +1 -1
  55. claude_mpm/cli_module/commands.py +1 -1
  56. claude_mpm/commands/{mpm-auto-configure.md → mpm-agents-auto-configure.md} +9 -0
  57. claude_mpm/commands/mpm-agents-detect.md +9 -0
  58. claude_mpm/commands/{mpm-agents.md → mpm-agents-list.md} +9 -0
  59. claude_mpm/commands/mpm-agents-recommend.md +9 -0
  60. claude_mpm/commands/{mpm-config.md → mpm-config-view.md} +9 -0
  61. claude_mpm/commands/mpm-doctor.md +9 -0
  62. claude_mpm/commands/mpm-help.md +11 -2
  63. claude_mpm/commands/mpm-init.md +27 -2
  64. claude_mpm/commands/mpm-monitor.md +9 -0
  65. claude_mpm/commands/{mpm-resume.md → mpm-session-resume.md} +9 -0
  66. claude_mpm/commands/mpm-status.md +9 -0
  67. claude_mpm/commands/{mpm-organize.md → mpm-ticket-organize.md} +9 -0
  68. claude_mpm/commands/mpm-ticket-view.md +552 -0
  69. claude_mpm/commands/mpm-version.md +9 -0
  70. claude_mpm/commands/mpm.md +10 -0
  71. claude_mpm/config/agent_presets.py +258 -0
  72. claude_mpm/config/agent_sources.py +325 -0
  73. claude_mpm/config/skill_sources.py +590 -0
  74. claude_mpm/constants.py +12 -0
  75. claude_mpm/core/api_validator.py +1 -1
  76. claude_mpm/core/claude_runner.py +17 -10
  77. claude_mpm/core/config.py +24 -0
  78. claude_mpm/core/constants.py +1 -1
  79. claude_mpm/core/framework/__init__.py +3 -16
  80. claude_mpm/core/framework/loaders/instruction_loader.py +25 -5
  81. claude_mpm/core/framework/processors/metadata_processor.py +1 -1
  82. claude_mpm/core/hook_error_memory.py +381 -0
  83. claude_mpm/core/hook_manager.py +41 -2
  84. claude_mpm/core/interactive_session.py +112 -5
  85. claude_mpm/core/logger.py +3 -1
  86. claude_mpm/core/oneshot_session.py +94 -4
  87. claude_mpm/dashboard/static/css/activity.css +69 -69
  88. claude_mpm/dashboard/static/css/connection-status.css +10 -10
  89. claude_mpm/dashboard/static/css/dashboard.css +15 -15
  90. claude_mpm/dashboard/static/js/components/activity-tree.js +178 -178
  91. claude_mpm/dashboard/static/js/components/agent-hierarchy.js +101 -101
  92. claude_mpm/dashboard/static/js/components/agent-inference.js +31 -31
  93. claude_mpm/dashboard/static/js/components/build-tracker.js +59 -59
  94. claude_mpm/dashboard/static/js/components/code-simple.js +107 -107
  95. claude_mpm/dashboard/static/js/components/connection-debug.js +101 -101
  96. claude_mpm/dashboard/static/js/components/diff-viewer.js +113 -113
  97. claude_mpm/dashboard/static/js/components/event-viewer.js +12 -12
  98. claude_mpm/dashboard/static/js/components/file-change-tracker.js +57 -57
  99. claude_mpm/dashboard/static/js/components/file-change-viewer.js +74 -74
  100. claude_mpm/dashboard/static/js/components/file-tool-tracker.js +6 -6
  101. claude_mpm/dashboard/static/js/components/file-viewer.js +42 -42
  102. claude_mpm/dashboard/static/js/components/module-viewer.js +27 -27
  103. claude_mpm/dashboard/static/js/components/session-manager.js +14 -14
  104. claude_mpm/dashboard/static/js/components/socket-manager.js +1 -1
  105. claude_mpm/dashboard/static/js/components/ui-state-manager.js +14 -14
  106. claude_mpm/dashboard/static/js/components/unified-data-viewer.js +110 -110
  107. claude_mpm/dashboard/static/js/components/working-directory.js +8 -8
  108. claude_mpm/dashboard/static/js/connection-manager.js +76 -76
  109. claude_mpm/dashboard/static/js/dashboard.js +76 -58
  110. claude_mpm/dashboard/static/js/extension-error-handler.js +22 -22
  111. claude_mpm/dashboard/static/js/socket-client.js +138 -121
  112. claude_mpm/dashboard/templates/code_simple.html +23 -23
  113. claude_mpm/dashboard/templates/index.html +18 -18
  114. claude_mpm/experimental/cli_enhancements.py +1 -5
  115. claude_mpm/hooks/claude_hooks/event_handlers.py +3 -1
  116. claude_mpm/hooks/claude_hooks/hook_handler.py +24 -7
  117. claude_mpm/hooks/claude_hooks/installer.py +45 -0
  118. claude_mpm/hooks/failure_learning/__init__.py +2 -8
  119. claude_mpm/hooks/failure_learning/failure_detection_hook.py +1 -6
  120. claude_mpm/hooks/failure_learning/fix_detection_hook.py +1 -6
  121. claude_mpm/hooks/failure_learning/learning_extraction_hook.py +1 -6
  122. claude_mpm/hooks/kuzu_response_hook.py +1 -5
  123. claude_mpm/hooks/templates/pre_tool_use_simple.py +78 -0
  124. claude_mpm/hooks/templates/pre_tool_use_template.py +323 -0
  125. claude_mpm/models/git_repository.py +198 -0
  126. claude_mpm/scripts/claude-hook-handler.sh +3 -3
  127. claude_mpm/scripts/start_activity_logging.py +3 -1
  128. claude_mpm/services/agents/agent_builder.py +45 -9
  129. claude_mpm/services/agents/agent_preset_service.py +238 -0
  130. claude_mpm/services/agents/agent_selection_service.py +484 -0
  131. claude_mpm/services/agents/auto_deploy_index_parser.py +569 -0
  132. claude_mpm/services/agents/deployment/agent_deployment.py +126 -2
  133. claude_mpm/services/agents/deployment/agent_discovery_service.py +105 -73
  134. claude_mpm/services/agents/deployment/agent_format_converter.py +1 -1
  135. claude_mpm/services/agents/deployment/agent_lifecycle_manager.py +1 -5
  136. claude_mpm/services/agents/deployment/agent_metrics_collector.py +3 -3
  137. claude_mpm/services/agents/deployment/agent_restore_handler.py +1 -4
  138. claude_mpm/services/agents/deployment/agent_template_builder.py +236 -15
  139. claude_mpm/services/agents/deployment/agents_directory_resolver.py +101 -15
  140. claude_mpm/services/agents/deployment/async_agent_deployment.py +2 -1
  141. claude_mpm/services/agents/deployment/facade/deployment_facade.py +3 -3
  142. claude_mpm/services/agents/deployment/multi_source_deployment_service.py +115 -15
  143. claude_mpm/services/agents/deployment/pipeline/pipeline_executor.py +2 -2
  144. claude_mpm/services/agents/deployment/refactored_agent_deployment_service.py +1 -4
  145. claude_mpm/services/agents/deployment/remote_agent_discovery_service.py +363 -0
  146. claude_mpm/services/agents/deployment/single_agent_deployer.py +2 -2
  147. claude_mpm/services/agents/deployment/system_instructions_deployer.py +168 -46
  148. claude_mpm/services/agents/deployment/validation/deployment_validator.py +2 -2
  149. claude_mpm/services/agents/git_source_manager.py +629 -0
  150. claude_mpm/services/agents/loading/framework_agent_loader.py +9 -12
  151. claude_mpm/services/agents/local_template_manager.py +50 -10
  152. claude_mpm/services/agents/single_tier_deployment_service.py +696 -0
  153. claude_mpm/services/agents/sources/__init__.py +13 -0
  154. claude_mpm/services/agents/sources/agent_sync_state.py +516 -0
  155. claude_mpm/services/agents/sources/git_source_sync_service.py +1055 -0
  156. claude_mpm/services/agents/startup_sync.py +239 -0
  157. claude_mpm/services/agents/toolchain_detector.py +474 -0
  158. claude_mpm/services/cli/session_pause_manager.py +1 -1
  159. claude_mpm/services/cli/unified_dashboard_manager.py +1 -1
  160. claude_mpm/services/command_deployment_service.py +92 -1
  161. claude_mpm/services/core/interfaces/__init__.py +1 -3
  162. claude_mpm/services/core/interfaces/health.py +1 -4
  163. claude_mpm/services/core/models/__init__.py +2 -11
  164. claude_mpm/services/diagnostics/checks/__init__.py +4 -0
  165. claude_mpm/services/diagnostics/checks/agent_check.py +0 -2
  166. claude_mpm/services/diagnostics/checks/agent_sources_check.py +577 -0
  167. claude_mpm/services/diagnostics/checks/instructions_check.py +1 -2
  168. claude_mpm/services/diagnostics/checks/mcp_check.py +0 -1
  169. claude_mpm/services/diagnostics/checks/monitor_check.py +0 -1
  170. claude_mpm/services/diagnostics/checks/skill_sources_check.py +587 -0
  171. claude_mpm/services/diagnostics/diagnostic_runner.py +9 -0
  172. claude_mpm/services/diagnostics/doctor_reporter.py +40 -10
  173. claude_mpm/services/event_bus/direct_relay.py +3 -3
  174. claude_mpm/services/event_bus/event_bus.py +36 -3
  175. claude_mpm/services/events/consumers/logging.py +1 -2
  176. claude_mpm/services/git/__init__.py +21 -0
  177. claude_mpm/services/git/git_operations_service.py +494 -0
  178. claude_mpm/services/github/__init__.py +21 -0
  179. claude_mpm/services/github/github_cli_service.py +397 -0
  180. claude_mpm/services/infrastructure/monitoring/__init__.py +1 -5
  181. claude_mpm/services/infrastructure/monitoring/aggregator.py +1 -6
  182. claude_mpm/services/infrastructure/monitoring/resources.py +1 -1
  183. claude_mpm/services/instructions/__init__.py +9 -0
  184. claude_mpm/services/instructions/instruction_cache_service.py +374 -0
  185. claude_mpm/services/local_ops/__init__.py +3 -13
  186. claude_mpm/services/local_ops/health_checks/__init__.py +1 -3
  187. claude_mpm/services/local_ops/health_manager.py +1 -4
  188. claude_mpm/services/local_ops/process_manager.py +1 -1
  189. claude_mpm/services/local_ops/resource_monitor.py +2 -2
  190. claude_mpm/services/mcp_gateway/config/configuration.py +1 -1
  191. claude_mpm/services/mcp_gateway/server/mcp_gateway.py +1 -6
  192. claude_mpm/services/mcp_gateway/server/stdio_server.py +0 -2
  193. claude_mpm/services/mcp_gateway/tools/document_summarizer.py +1 -1
  194. claude_mpm/services/mcp_gateway/tools/kuzu_memory_service.py +6 -2
  195. claude_mpm/services/memory/optimizer.py +1 -1
  196. claude_mpm/services/model/model_router.py +8 -9
  197. claude_mpm/services/monitor/daemon.py +1 -1
  198. claude_mpm/services/monitor/server.py +2 -2
  199. claude_mpm/services/native_agent_converter.py +356 -0
  200. claude_mpm/services/port_manager.py +1 -1
  201. claude_mpm/services/pr/__init__.py +14 -0
  202. claude_mpm/services/pr/pr_template_service.py +329 -0
  203. claude_mpm/services/project/documentation_manager.py +2 -1
  204. claude_mpm/services/project/toolchain_analyzer.py +3 -1
  205. claude_mpm/services/runner_configuration_service.py +1 -0
  206. claude_mpm/services/self_upgrade_service.py +165 -7
  207. claude_mpm/services/skills/__init__.py +18 -0
  208. claude_mpm/services/skills/git_skill_source_manager.py +1169 -0
  209. claude_mpm/services/skills/skill_discovery_service.py +568 -0
  210. claude_mpm/services/skills_config.py +547 -0
  211. claude_mpm/services/skills_deployer.py +955 -0
  212. claude_mpm/services/socketio/handlers/connection.py +1 -1
  213. claude_mpm/services/socketio/handlers/git.py +2 -2
  214. claude_mpm/services/socketio/server/core.py +1 -4
  215. claude_mpm/services/socketio/server/main.py +1 -3
  216. claude_mpm/services/system_instructions_service.py +1 -3
  217. claude_mpm/services/unified/analyzer_strategies/performance_analyzer.py +0 -3
  218. claude_mpm/services/unified/analyzer_strategies/security_analyzer.py +0 -1
  219. claude_mpm/services/unified/deployment_strategies/cloud_strategies.py +1 -1
  220. claude_mpm/services/unified/deployment_strategies/vercel.py +1 -5
  221. claude_mpm/services/unified/unified_deployment.py +1 -5
  222. claude_mpm/services/version_control/conflict_resolution.py +6 -4
  223. claude_mpm/services/visualization/__init__.py +1 -5
  224. claude_mpm/services/visualization/mermaid_generator.py +2 -3
  225. claude_mpm/skills/bundled/infrastructure/env-manager/scripts/validate_env.py +576 -0
  226. claude_mpm/skills/bundled/performance-profiling.md +6 -0
  227. claude_mpm/skills/bundled/testing/webapp-testing/scripts/with_server.py +2 -2
  228. claude_mpm/skills/skills_registry.py +0 -1
  229. claude_mpm/templates/questions/__init__.py +38 -0
  230. claude_mpm/templates/questions/base.py +193 -0
  231. claude_mpm/templates/questions/pr_strategy.py +311 -0
  232. claude_mpm/templates/questions/project_init.py +385 -0
  233. claude_mpm/templates/questions/ticket_mgmt.py +394 -0
  234. claude_mpm/tools/__main__.py +8 -8
  235. claude_mpm/tools/code_tree_analyzer/analysis.py +1 -1
  236. claude_mpm/utils/agent_dependency_loader.py +80 -13
  237. claude_mpm/utils/dependency_cache.py +3 -1
  238. claude_mpm/utils/gitignore.py +241 -0
  239. claude_mpm/utils/log_cleanup.py +3 -3
  240. claude_mpm/utils/progress.py +383 -0
  241. claude_mpm/utils/robust_installer.py +3 -5
  242. claude_mpm/utils/structured_questions.py +619 -0
  243. {claude_mpm-4.21.3.dist-info → claude_mpm-5.0.2.dist-info}/METADATA +429 -59
  244. {claude_mpm-4.21.3.dist-info → claude_mpm-5.0.2.dist-info}/RECORD +252 -425
  245. claude_mpm/agents/templates/.claude-mpm/memories/README.md +0 -17
  246. claude_mpm/agents/templates/.claude-mpm/memories/engineer_memories.md +0 -3
  247. claude_mpm/agents/templates/agent-manager.json +0 -273
  248. claude_mpm/agents/templates/agentic-coder-optimizer.json +0 -248
  249. claude_mpm/agents/templates/api_qa.json +0 -180
  250. claude_mpm/agents/templates/clerk-ops.json +0 -235
  251. claude_mpm/agents/templates/code_analyzer.json +0 -101
  252. claude_mpm/agents/templates/content-agent.json +0 -358
  253. claude_mpm/agents/templates/dart_engineer.json +0 -307
  254. claude_mpm/agents/templates/data_engineer.json +0 -225
  255. claude_mpm/agents/templates/documentation.json +0 -211
  256. claude_mpm/agents/templates/engineer.json +0 -210
  257. claude_mpm/agents/templates/gcp_ops_agent.json +0 -253
  258. claude_mpm/agents/templates/golang_engineer.json +0 -270
  259. claude_mpm/agents/templates/imagemagick.json +0 -264
  260. claude_mpm/agents/templates/java_engineer.json +0 -346
  261. claude_mpm/agents/templates/local_ops_agent.json +0 -1840
  262. claude_mpm/agents/templates/logs/prompts/agent_engineer_20250826_014258_728.md +0 -39
  263. claude_mpm/agents/templates/logs/prompts/agent_engineer_20250901_010124_142.md +0 -400
  264. claude_mpm/agents/templates/memory_manager.json +0 -158
  265. claude_mpm/agents/templates/nextjs_engineer.json +0 -285
  266. claude_mpm/agents/templates/ops.json +0 -185
  267. claude_mpm/agents/templates/php-engineer.json +0 -287
  268. claude_mpm/agents/templates/product_owner.json +0 -338
  269. claude_mpm/agents/templates/project_organizer.json +0 -140
  270. claude_mpm/agents/templates/prompt-engineer.json +0 -737
  271. claude_mpm/agents/templates/python_engineer.json +0 -387
  272. claude_mpm/agents/templates/qa.json +0 -242
  273. claude_mpm/agents/templates/react_engineer.json +0 -238
  274. claude_mpm/agents/templates/refactoring_engineer.json +0 -276
  275. claude_mpm/agents/templates/research.json +0 -188
  276. claude_mpm/agents/templates/ruby-engineer.json +0 -280
  277. claude_mpm/agents/templates/rust_engineer.json +0 -275
  278. claude_mpm/agents/templates/security.json +0 -202
  279. claude_mpm/agents/templates/svelte-engineer.json +0 -225
  280. claude_mpm/agents/templates/ticketing.json +0 -177
  281. claude_mpm/agents/templates/typescript_engineer.json +0 -285
  282. claude_mpm/agents/templates/vercel_ops_agent.json +0 -412
  283. claude_mpm/agents/templates/version_control.json +0 -157
  284. claude_mpm/agents/templates/web_qa.json +0 -399
  285. claude_mpm/agents/templates/web_ui.json +0 -189
  286. claude_mpm/commands/mpm-tickets.md +0 -102
  287. claude_mpm/dashboard/.claude-mpm/socketio-instances.json +0 -1
  288. claude_mpm/dashboard/react/components/DataInspector/DataInspector.module.css +0 -188
  289. claude_mpm/dashboard/react/components/EventViewer/EventViewer.module.css +0 -156
  290. claude_mpm/dashboard/react/components/shared/ConnectionStatus.module.css +0 -38
  291. claude_mpm/dashboard/react/components/shared/FilterBar.module.css +0 -92
  292. claude_mpm/dashboard/static/archive/activity_dashboard_fixed.html +0 -248
  293. claude_mpm/dashboard/static/archive/activity_dashboard_test.html +0 -61
  294. claude_mpm/dashboard/static/archive/test_activity_connection.html +0 -179
  295. claude_mpm/dashboard/static/archive/test_claude_tree_tab.html +0 -68
  296. claude_mpm/dashboard/static/archive/test_dashboard.html +0 -409
  297. claude_mpm/dashboard/static/archive/test_dashboard_fixed.html +0 -519
  298. claude_mpm/dashboard/static/archive/test_dashboard_verification.html +0 -181
  299. claude_mpm/dashboard/static/archive/test_file_data.html +0 -315
  300. claude_mpm/dashboard/static/archive/test_file_tree_empty_state.html +0 -243
  301. claude_mpm/dashboard/static/archive/test_file_tree_fix.html +0 -234
  302. claude_mpm/dashboard/static/archive/test_file_tree_rename.html +0 -117
  303. claude_mpm/dashboard/static/archive/test_file_tree_tab.html +0 -115
  304. claude_mpm/dashboard/static/archive/test_file_viewer.html +0 -224
  305. claude_mpm/dashboard/static/archive/test_final_activity.html +0 -220
  306. claude_mpm/dashboard/static/archive/test_tab_fix.html +0 -139
  307. claude_mpm/dashboard/static/built/assets/events.DjpNxWNo.css +0 -1
  308. claude_mpm/dashboard/static/built/components/activity-tree.js +0 -2
  309. claude_mpm/dashboard/static/built/components/agent-hierarchy.js +0 -777
  310. claude_mpm/dashboard/static/built/components/agent-inference.js +0 -2
  311. claude_mpm/dashboard/static/built/components/build-tracker.js +0 -333
  312. claude_mpm/dashboard/static/built/components/code-simple.js +0 -857
  313. claude_mpm/dashboard/static/built/components/code-tree/tree-breadcrumb.js +0 -353
  314. claude_mpm/dashboard/static/built/components/code-tree/tree-constants.js +0 -235
  315. claude_mpm/dashboard/static/built/components/code-tree/tree-search.js +0 -409
  316. claude_mpm/dashboard/static/built/components/code-tree/tree-utils.js +0 -435
  317. claude_mpm/dashboard/static/built/components/code-tree.js +0 -2
  318. claude_mpm/dashboard/static/built/components/code-viewer.js +0 -2
  319. claude_mpm/dashboard/static/built/components/connection-debug.js +0 -654
  320. claude_mpm/dashboard/static/built/components/diff-viewer.js +0 -891
  321. claude_mpm/dashboard/static/built/components/event-processor.js +0 -2
  322. claude_mpm/dashboard/static/built/components/event-viewer.js +0 -2
  323. claude_mpm/dashboard/static/built/components/export-manager.js +0 -2
  324. claude_mpm/dashboard/static/built/components/file-change-tracker.js +0 -443
  325. claude_mpm/dashboard/static/built/components/file-change-viewer.js +0 -690
  326. claude_mpm/dashboard/static/built/components/file-tool-tracker.js +0 -2
  327. claude_mpm/dashboard/static/built/components/file-viewer.js +0 -2
  328. claude_mpm/dashboard/static/built/components/hud-library-loader.js +0 -2
  329. claude_mpm/dashboard/static/built/components/hud-manager.js +0 -2
  330. claude_mpm/dashboard/static/built/components/hud-visualizer.js +0 -2
  331. claude_mpm/dashboard/static/built/components/module-viewer.js +0 -2
  332. claude_mpm/dashboard/static/built/components/nav-bar.js +0 -145
  333. claude_mpm/dashboard/static/built/components/page-structure.js +0 -429
  334. claude_mpm/dashboard/static/built/components/session-manager.js +0 -2
  335. claude_mpm/dashboard/static/built/components/socket-manager.js +0 -2
  336. claude_mpm/dashboard/static/built/components/ui-state-manager.js +0 -2
  337. claude_mpm/dashboard/static/built/components/unified-data-viewer.js +0 -2
  338. claude_mpm/dashboard/static/built/components/working-directory.js +0 -2
  339. claude_mpm/dashboard/static/built/connection-manager.js +0 -536
  340. claude_mpm/dashboard/static/built/dashboard.js +0 -2
  341. claude_mpm/dashboard/static/built/extension-error-handler.js +0 -164
  342. claude_mpm/dashboard/static/built/react/events.js +0 -30
  343. claude_mpm/dashboard/static/built/shared/dom-helpers.js +0 -396
  344. claude_mpm/dashboard/static/built/shared/event-bus.js +0 -330
  345. claude_mpm/dashboard/static/built/shared/event-filter-service.js +0 -540
  346. claude_mpm/dashboard/static/built/shared/logger.js +0 -385
  347. claude_mpm/dashboard/static/built/shared/page-structure.js +0 -249
  348. claude_mpm/dashboard/static/built/shared/tooltip-service.js +0 -253
  349. claude_mpm/dashboard/static/built/socket-client.js +0 -2
  350. claude_mpm/dashboard/static/built/tab-isolation-fix.js +0 -185
  351. claude_mpm/dashboard/static/dist/assets/events.DjpNxWNo.css +0 -1
  352. claude_mpm/dashboard/static/dist/components/activity-tree.js +0 -2
  353. claude_mpm/dashboard/static/dist/components/agent-inference.js +0 -2
  354. claude_mpm/dashboard/static/dist/components/code-tree.js +0 -2
  355. claude_mpm/dashboard/static/dist/components/code-viewer.js +0 -2
  356. claude_mpm/dashboard/static/dist/components/event-processor.js +0 -2
  357. claude_mpm/dashboard/static/dist/components/event-viewer.js +0 -2
  358. claude_mpm/dashboard/static/dist/components/export-manager.js +0 -2
  359. claude_mpm/dashboard/static/dist/components/file-tool-tracker.js +0 -2
  360. claude_mpm/dashboard/static/dist/components/file-viewer.js +0 -2
  361. claude_mpm/dashboard/static/dist/components/hud-library-loader.js +0 -2
  362. claude_mpm/dashboard/static/dist/components/hud-manager.js +0 -2
  363. claude_mpm/dashboard/static/dist/components/hud-visualizer.js +0 -2
  364. claude_mpm/dashboard/static/dist/components/module-viewer.js +0 -2
  365. claude_mpm/dashboard/static/dist/components/session-manager.js +0 -2
  366. claude_mpm/dashboard/static/dist/components/socket-manager.js +0 -2
  367. claude_mpm/dashboard/static/dist/components/ui-state-manager.js +0 -2
  368. claude_mpm/dashboard/static/dist/components/unified-data-viewer.js +0 -2
  369. claude_mpm/dashboard/static/dist/components/working-directory.js +0 -2
  370. claude_mpm/dashboard/static/dist/dashboard.js +0 -2
  371. claude_mpm/dashboard/static/dist/react/events.js +0 -30
  372. claude_mpm/dashboard/static/dist/socket-client.js +0 -2
  373. claude_mpm/dashboard/static/events.html +0 -607
  374. claude_mpm/dashboard/static/index.html +0 -635
  375. claude_mpm/dashboard/static/js/shared/dom-helpers.js +0 -396
  376. claude_mpm/dashboard/static/js/shared/event-bus.js +0 -330
  377. claude_mpm/dashboard/static/js/shared/logger.js +0 -385
  378. claude_mpm/dashboard/static/js/shared/tooltip-service.js +0 -253
  379. claude_mpm/dashboard/static/js/stores/dashboard-store.js +0 -562
  380. claude_mpm/dashboard/static/legacy/activity.html +0 -736
  381. claude_mpm/dashboard/static/legacy/agents.html +0 -786
  382. claude_mpm/dashboard/static/legacy/files.html +0 -747
  383. claude_mpm/dashboard/static/legacy/tools.html +0 -831
  384. claude_mpm/dashboard/static/monitors.html +0 -431
  385. claude_mpm/dashboard/static/production/events.html +0 -659
  386. claude_mpm/dashboard/static/production/main.html +0 -698
  387. claude_mpm/dashboard/static/production/monitors.html +0 -483
  388. claude_mpm/dashboard/static/test-archive/dashboard.html +0 -635
  389. claude_mpm/dashboard/static/test-archive/debug-events.html +0 -147
  390. claude_mpm/dashboard/static/test-archive/test-navigation.html +0 -256
  391. claude_mpm/dashboard/static/test-archive/test-react-exports.html +0 -180
  392. claude_mpm/dashboard/static/test-archive/test_debug.html +0 -25
  393. claude_mpm/skills/bundled/collaboration/brainstorming/SKILL.md +0 -79
  394. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/SKILL.md +0 -178
  395. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/agent-prompts.md +0 -577
  396. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/coordination-patterns.md +0 -467
  397. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/examples.md +0 -537
  398. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/troubleshooting.md +0 -730
  399. claude_mpm/skills/bundled/collaboration/requesting-code-review/SKILL.md +0 -112
  400. claude_mpm/skills/bundled/collaboration/requesting-code-review/references/code-reviewer-template.md +0 -146
  401. claude_mpm/skills/bundled/collaboration/requesting-code-review/references/review-examples.md +0 -412
  402. claude_mpm/skills/bundled/collaboration/writing-plans/SKILL.md +0 -81
  403. claude_mpm/skills/bundled/collaboration/writing-plans/references/best-practices.md +0 -362
  404. claude_mpm/skills/bundled/collaboration/writing-plans/references/plan-structure-templates.md +0 -312
  405. claude_mpm/skills/bundled/debugging/root-cause-tracing/SKILL.md +0 -152
  406. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/advanced-techniques.md +0 -668
  407. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/examples.md +0 -587
  408. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/integration.md +0 -438
  409. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/tracing-techniques.md +0 -391
  410. claude_mpm/skills/bundled/debugging/systematic-debugging/CREATION-LOG.md +0 -119
  411. claude_mpm/skills/bundled/debugging/systematic-debugging/SKILL.md +0 -148
  412. claude_mpm/skills/bundled/debugging/systematic-debugging/references/anti-patterns.md +0 -483
  413. claude_mpm/skills/bundled/debugging/systematic-debugging/references/examples.md +0 -452
  414. claude_mpm/skills/bundled/debugging/systematic-debugging/references/troubleshooting.md +0 -449
  415. claude_mpm/skills/bundled/debugging/systematic-debugging/references/workflow.md +0 -411
  416. claude_mpm/skills/bundled/debugging/systematic-debugging/test-academic.md +0 -14
  417. claude_mpm/skills/bundled/debugging/systematic-debugging/test-pressure-1.md +0 -58
  418. claude_mpm/skills/bundled/debugging/systematic-debugging/test-pressure-2.md +0 -68
  419. claude_mpm/skills/bundled/debugging/systematic-debugging/test-pressure-3.md +0 -69
  420. claude_mpm/skills/bundled/debugging/verification-before-completion/SKILL.md +0 -131
  421. claude_mpm/skills/bundled/debugging/verification-before-completion/references/gate-function.md +0 -325
  422. claude_mpm/skills/bundled/debugging/verification-before-completion/references/integration-and-workflows.md +0 -490
  423. claude_mpm/skills/bundled/debugging/verification-before-completion/references/red-flags-and-failures.md +0 -425
  424. claude_mpm/skills/bundled/debugging/verification-before-completion/references/verification-patterns.md +0 -499
  425. claude_mpm/skills/bundled/main/artifacts-builder/SKILL.md +0 -86
  426. claude_mpm/skills/bundled/main/internal-comms/SKILL.md +0 -43
  427. claude_mpm/skills/bundled/main/internal-comms/examples/3p-updates.md +0 -47
  428. claude_mpm/skills/bundled/main/internal-comms/examples/company-newsletter.md +0 -65
  429. claude_mpm/skills/bundled/main/internal-comms/examples/faq-answers.md +0 -30
  430. claude_mpm/skills/bundled/main/internal-comms/examples/general-comms.md +0 -16
  431. claude_mpm/skills/bundled/main/mcp-builder/SKILL.md +0 -160
  432. claude_mpm/skills/bundled/main/mcp-builder/reference/design_principles.md +0 -412
  433. claude_mpm/skills/bundled/main/mcp-builder/reference/evaluation.md +0 -602
  434. claude_mpm/skills/bundled/main/mcp-builder/reference/mcp_best_practices.md +0 -915
  435. claude_mpm/skills/bundled/main/mcp-builder/reference/node_mcp_server.md +0 -916
  436. claude_mpm/skills/bundled/main/mcp-builder/reference/python_mcp_server.md +0 -752
  437. claude_mpm/skills/bundled/main/mcp-builder/reference/workflow.md +0 -1237
  438. claude_mpm/skills/bundled/main/skill-creator/SKILL.md +0 -189
  439. claude_mpm/skills/bundled/main/skill-creator/references/best-practices.md +0 -500
  440. claude_mpm/skills/bundled/main/skill-creator/references/creation-workflow.md +0 -464
  441. claude_mpm/skills/bundled/main/skill-creator/references/examples.md +0 -619
  442. claude_mpm/skills/bundled/main/skill-creator/references/progressive-disclosure.md +0 -437
  443. claude_mpm/skills/bundled/main/skill-creator/references/skill-structure.md +0 -231
  444. claude_mpm/skills/bundled/php/espocrm-development/SKILL.md +0 -170
  445. claude_mpm/skills/bundled/php/espocrm-development/references/architecture.md +0 -602
  446. claude_mpm/skills/bundled/php/espocrm-development/references/common-tasks.md +0 -821
  447. claude_mpm/skills/bundled/php/espocrm-development/references/development-workflow.md +0 -742
  448. claude_mpm/skills/bundled/php/espocrm-development/references/frontend-customization.md +0 -726
  449. claude_mpm/skills/bundled/php/espocrm-development/references/hooks-and-services.md +0 -764
  450. claude_mpm/skills/bundled/php/espocrm-development/references/testing-debugging.md +0 -831
  451. claude_mpm/skills/bundled/rust/desktop-applications/SKILL.md +0 -226
  452. claude_mpm/skills/bundled/rust/desktop-applications/references/architecture-patterns.md +0 -901
  453. claude_mpm/skills/bundled/rust/desktop-applications/references/native-gui-frameworks.md +0 -901
  454. claude_mpm/skills/bundled/rust/desktop-applications/references/platform-integration.md +0 -775
  455. claude_mpm/skills/bundled/rust/desktop-applications/references/state-management.md +0 -937
  456. claude_mpm/skills/bundled/rust/desktop-applications/references/tauri-framework.md +0 -770
  457. claude_mpm/skills/bundled/rust/desktop-applications/references/testing-deployment.md +0 -961
  458. claude_mpm/skills/bundled/testing/condition-based-waiting/SKILL.md +0 -119
  459. claude_mpm/skills/bundled/testing/condition-based-waiting/references/patterns-and-implementation.md +0 -253
  460. claude_mpm/skills/bundled/testing/test-driven-development/SKILL.md +0 -145
  461. claude_mpm/skills/bundled/testing/test-driven-development/references/anti-patterns.md +0 -543
  462. claude_mpm/skills/bundled/testing/test-driven-development/references/examples.md +0 -741
  463. claude_mpm/skills/bundled/testing/test-driven-development/references/integration.md +0 -470
  464. claude_mpm/skills/bundled/testing/test-driven-development/references/philosophy.md +0 -458
  465. claude_mpm/skills/bundled/testing/test-driven-development/references/workflow.md +0 -639
  466. claude_mpm/skills/bundled/testing/testing-anti-patterns/SKILL.md +0 -140
  467. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/completeness-anti-patterns.md +0 -572
  468. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/core-anti-patterns.md +0 -411
  469. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/detection-guide.md +0 -569
  470. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/tdd-connection.md +0 -695
  471. claude_mpm/skills/bundled/testing/webapp-testing/SKILL.md +0 -184
  472. claude_mpm/skills/bundled/testing/webapp-testing/decision-tree.md +0 -459
  473. claude_mpm/skills/bundled/testing/webapp-testing/playwright-patterns.md +0 -479
  474. claude_mpm/skills/bundled/testing/webapp-testing/reconnaissance-pattern.md +0 -687
  475. claude_mpm/skills/bundled/testing/webapp-testing/server-management.md +0 -758
  476. claude_mpm/skills/bundled/testing/webapp-testing/troubleshooting.md +0 -868
  477. /claude_mpm/agents/templates/{git_file_tracking.md → git-file-tracking.md} +0 -0
  478. /claude_mpm/agents/templates/{pm_examples.md → pm-examples.md} +0 -0
  479. /claude_mpm/agents/templates/{response_format.md → response-format.md} +0 -0
  480. /claude_mpm/agents/templates/{validation_templates.md → validation-templates.md} +0 -0
  481. {claude_mpm-4.21.3.dist-info → claude_mpm-5.0.2.dist-info}/WHEEL +0 -0
  482. {claude_mpm-4.21.3.dist-info → claude_mpm-5.0.2.dist-info}/entry_points.txt +0 -0
  483. {claude_mpm-4.21.3.dist-info → claude_mpm-5.0.2.dist-info}/licenses/LICENSE +0 -0
  484. {claude_mpm-4.21.3.dist-info → claude_mpm-5.0.2.dist-info}/top_level.txt +0 -0
@@ -1,1840 +0,0 @@
1
- {
2
- "name": "local-ops",
3
- "display_name": "Local Operations Agent",
4
- "description": "Specialized agent for managing local development deployments with focus on maintaining single stable instances, protecting existing services, and never interfering with other projects or Claude Code services",
5
- "author": "Claude MPM",
6
- "authority": {
7
- "level": "deployment_manager",
8
- "domains": [
9
- "local_deployments",
10
- "process_management",
11
- "port_allocation",
12
- "resource_monitoring",
13
- "log_management"
14
- ]
15
- },
16
- "capabilities": {
17
- "local_deploy_cli": {
18
- "description": "Use claude-mpm local-deploy CLI for advanced process management",
19
- "commands": {
20
- "start": {
21
- "syntax": "claude-mpm local-deploy start --command <cmd> [--port <port>] [--auto-restart] [--health-check <url>]",
22
- "description": "Start a deployment with background process spawning, health monitoring, and auto-restart",
23
- "example": "claude-mpm local-deploy start --command 'uvicorn main:app --reload' --port 8000 --auto-restart --health-check http://localhost:8000/health"
24
- },
25
- "status": {
26
- "syntax": "claude-mpm local-deploy status <deployment-id>",
27
- "description": "Get detailed deployment status including process info, health, and resource usage",
28
- "provides": [
29
- "process_info",
30
- "health_status",
31
- "resource_usage",
32
- "uptime",
33
- "restart_count"
34
- ]
35
- },
36
- "monitor": {
37
- "syntax": "claude-mpm local-deploy monitor <deployment-id> [--refresh 2]",
38
- "description": "Live dashboard with real-time updates of deployment metrics"
39
- },
40
- "health": {
41
- "syntax": "claude-mpm local-deploy health <deployment-id>",
42
- "description": "Run comprehensive health checks (HTTP endpoint, process responsive, resource limits)",
43
- "checks": [
44
- "http_endpoint",
45
- "process_responsive",
46
- "resource_limits"
47
- ]
48
- },
49
- "stop": {
50
- "syntax": "claude-mpm local-deploy stop <deployment-id>",
51
- "description": "Gracefully stop a deployment"
52
- },
53
- "restart": {
54
- "syntax": "claude-mpm local-deploy restart <deployment-id>",
55
- "description": "Restart a deployment with graceful shutdown"
56
- },
57
- "list": {
58
- "syntax": "claude-mpm local-deploy list [--status running|stopped|crashed]",
59
- "description": "List all deployments with optional status filtering"
60
- },
61
- "history": {
62
- "syntax": "claude-mpm local-deploy history <deployment-id>",
63
- "description": "View deployment restart history and crash logs"
64
- },
65
- "enable-auto-restart": {
66
- "syntax": "claude-mpm local-deploy enable-auto-restart <deployment-id>",
67
- "description": "Enable automatic restart on crashes with exponential backoff"
68
- },
69
- "disable-auto-restart": {
70
- "syntax": "claude-mpm local-deploy disable-auto-restart <deployment-id>",
71
- "description": "Disable automatic restart for a deployment"
72
- }
73
- },
74
- "features": [
75
- "background_process_spawning",
76
- "automatic_health_monitoring",
77
- "auto_restart_with_exponential_backoff",
78
- "memory_leak_detection",
79
- "log_pattern_monitoring",
80
- "resource_usage_tracking",
81
- "graceful_shutdown_handling"
82
- ],
83
- "integration_workflow": [
84
- "detect_framework",
85
- "build_start_command",
86
- "execute_local_deploy_start",
87
- "configure_health_endpoint",
88
- "enable_auto_restart",
89
- "verify_health_endpoint",
90
- "monitor_initial_stability",
91
- "report_deployment_url_and_status"
92
- ]
93
- },
94
- "port_allocation": {
95
- "description": "Deterministic hash-based port allocation for consistent project ports",
96
- "features": [
97
- "single_port_per_project",
98
- "hash_based_allocation",
99
- "automatic_conflict_resolution",
100
- "persistent_state_tracking",
101
- "environment_variable_override"
102
- ],
103
- "port_range": [
104
- 3000,
105
- 3999
106
- ],
107
- "environment_override": "PROJECT_PORT"
108
- },
109
- "orphan_detection": {
110
- "description": "Detect and cleanup orphaned deployment processes",
111
- "capabilities": [
112
- "dead_pid_detection",
113
- "deleted_project_cleanup",
114
- "untracked_process_scanning",
115
- "pm2_orphan_detection",
116
- "docker_orphan_detection"
117
- ],
118
- "safety_features": [
119
- "process_age_verification",
120
- "protected_service_preservation",
121
- "severity_based_confirmation",
122
- "multi_level_safety_checks"
123
- ]
124
- },
125
- "frameworks": {
126
- "javascript": [
127
- "next.js",
128
- "react",
129
- "vue",
130
- "angular",
131
- "svelte",
132
- "nuxt",
133
- "gatsby",
134
- "vite",
135
- "express",
136
- "nestjs",
137
- "remix",
138
- "sveltekit",
139
- "astro"
140
- ],
141
- "python": [
142
- "django",
143
- "flask",
144
- "fastapi",
145
- "streamlit",
146
- "gradio"
147
- ],
148
- "rust": [
149
- "actix-web",
150
- "rocket",
151
- "axum",
152
- "warp"
153
- ],
154
- "go": [
155
- "gin",
156
- "echo",
157
- "fiber",
158
- "net/http"
159
- ],
160
- "java": [
161
- "spring-boot",
162
- "tomcat",
163
- "jetty"
164
- ],
165
- "ruby": [
166
- "rails",
167
- "sinatra"
168
- ],
169
- "php": [
170
- "laravel",
171
- "symfony"
172
- ],
173
- "dart": [
174
- "flutter-web",
175
- "shelf"
176
- ],
177
- "static": [
178
- "hugo",
179
- "jekyll",
180
- "eleventy"
181
- ]
182
- },
183
- "deployment_methods": {
184
- "pm2": {
185
- "description": "Node.js process manager for production deployments",
186
- "commands": [
187
- "start",
188
- "stop",
189
- "restart",
190
- "status",
191
- "logs",
192
- "monit"
193
- ],
194
- "features": [
195
- "auto-restart",
196
- "clustering",
197
- "log-rotation",
198
- "monitoring"
199
- ]
200
- },
201
- "docker": {
202
- "description": "Container-based deployment for isolation",
203
- "commands": [
204
- "build",
205
- "run",
206
- "stop",
207
- "logs",
208
- "exec"
209
- ],
210
- "features": [
211
- "isolation",
212
- "reproducibility",
213
- "multi-service"
214
- ]
215
- },
216
- "native": {
217
- "description": "Direct process management for simple cases",
218
- "commands": [
219
- "start",
220
- "stop",
221
- "status"
222
- ],
223
- "features": [
224
- "lightweight",
225
- "direct-control"
226
- ]
227
- },
228
- "systemd": {
229
- "description": "Linux system service management",
230
- "commands": [
231
- "start",
232
- "stop",
233
- "enable",
234
- "status"
235
- ],
236
- "features": [
237
- "boot-persistence",
238
- "system-integration"
239
- ]
240
- }
241
- },
242
- "monitoring": {
243
- "health_checks": [
244
- "http",
245
- "tcp",
246
- "process"
247
- ],
248
- "metrics": [
249
- "cpu",
250
- "memory",
251
- "response_time",
252
- "error_rate"
253
- ],
254
- "alerts": [
255
- "crash",
256
- "high_memory",
257
- "port_conflict",
258
- "unhealthy"
259
- ]
260
- },
261
- "model": "sonnet"
262
- },
263
- "metadata": {
264
- "category": "operations",
265
- "tags": [
266
- "deployment",
267
- "devops",
268
- "local",
269
- "process-management",
270
- "monitoring"
271
- ],
272
- "requirements": {
273
- "optional": [
274
- "pm2",
275
- "docker",
276
- "nginx"
277
- ],
278
- "auto_install": [
279
- "pm2"
280
- ]
281
- }
282
- },
283
- "configuration": {
284
- "default_port_range": [
285
- 3000,
286
- 9999
287
- ],
288
- "deployment_directory": ".claude-mpm/deployments",
289
- "log_directory": ".claude-mpm/logs",
290
- "state_file": ".claude-mpm/deployment-state.json",
291
- "health_check_interval": 30,
292
- "auto_restart_attempts": 3,
293
- "cleanup_on_exit": false,
294
- "stability_policy": {
295
- "single_instance_enforcement": true,
296
- "reuse_existing_processes": true,
297
- "protect_external_services": true,
298
- "avoid_port_conflicts": true,
299
- "graceful_shutdown_timeout": 10000,
300
- "check_process_ownership": true,
301
- "preserve_claude_mpm_services": true
302
- },
303
- "auto_updating_policy": {
304
- "enable_by_default": true,
305
- "watch_mode_for_dev": true,
306
- "hot_reload_preferred": true,
307
- "pm2_watch_mode": true,
308
- "description": "Always deploy in auto-updating mode (watch/hot-reload) for development"
309
- },
310
- "verification_policy": {
311
- "mandatory_endpoint_check": true,
312
- "fetch_timeout_ms": 5000,
313
- "retry_attempts": 3,
314
- "report_only_after_verification": true,
315
- "description": "MUST verify deployment responds before claiming success"
316
- }
317
- },
318
- "commands": {
319
- "deploy": {
320
- "description": "Deploy application with optimal method",
321
- "examples": [
322
- "Deploy this Next.js app in production mode",
323
- "Start the development server with hot reload",
324
- "Deploy with PM2 for stability"
325
- ],
326
- "workflow": [
327
- "detect_framework",
328
- "check_existing_deployments",
329
- "allocate_project_port",
330
- "verify_no_conflicts",
331
- "check_process_ownership",
332
- "register_port_allocation",
333
- "build_if_needed",
334
- "start_or_attach_to_process",
335
- "verify_port_responds",
336
- "confirm_auto_updating_mode",
337
- "report_verified_url_with_evidence",
338
- "monitor_health",
339
- "report_status"
340
- ]
341
- },
342
- "detect_orphans": {
343
- "description": "Scan for orphaned deployment processes",
344
- "examples": [
345
- "Check for orphaned processes",
346
- "Scan for dead deployments",
347
- "Find processes without state tracking"
348
- ],
349
- "workflow": [
350
- "scan_dead_pids",
351
- "scan_deleted_projects",
352
- "scan_untracked_processes",
353
- "scan_pm2_orphans",
354
- "scan_docker_orphans",
355
- "classify_by_severity",
356
- "report_findings"
357
- ]
358
- },
359
- "cleanup_orphans": {
360
- "description": "Clean up orphaned processes safely",
361
- "examples": [
362
- "Clean up dead process entries",
363
- "Remove orphaned PM2 processes",
364
- "Stop untracked Docker containers"
365
- ],
366
- "safety_rules": [
367
- "verify_process_age",
368
- "check_protected_services",
369
- "require_confirmation_for_high_severity",
370
- "never_kill_claude_mpm_services",
371
- "graceful_shutdown_first"
372
- ],
373
- "workflow": [
374
- "verify_orphan_validity",
375
- "check_safety_rules",
376
- "request_confirmation_if_needed",
377
- "execute_cleanup_action",
378
- "update_state_files",
379
- "report_results"
380
- ]
381
- },
382
- "status": {
383
- "description": "Check deployment status",
384
- "provides": [
385
- "process_info",
386
- "port_mapping",
387
- "health_status",
388
- "resource_usage"
389
- ]
390
- },
391
- "logs": {
392
- "description": "Stream or fetch deployment logs",
393
- "options": [
394
- "tail",
395
- "follow",
396
- "filter",
397
- "since"
398
- ]
399
- },
400
- "stop": {
401
- "description": "Gracefully stop deployments",
402
- "options": [
403
- "force",
404
- "timeout",
405
- "cleanup"
406
- ]
407
- },
408
- "scale": {
409
- "description": "Scale deployments (PM2 cluster mode)",
410
- "options": [
411
- "instances",
412
- "auto"
413
- ]
414
- }
415
- },
416
- "detection_patterns": {
417
- "nextjs": {
418
- "files": [
419
- "next.config.js",
420
- "next.config.mjs",
421
- "next.config.ts"
422
- ],
423
- "package_json": [
424
- "next"
425
- ],
426
- "commands": {
427
- "dev": "next dev",
428
- "build": "next build",
429
- "start": "next start",
430
- "export": "next export"
431
- }
432
- },
433
- "react": {
434
- "files": [
435
- "react-scripts",
436
- "vite.config.js",
437
- "webpack.config.js"
438
- ],
439
- "package_json": [
440
- "react",
441
- "react-dom"
442
- ],
443
- "commands": {
444
- "dev": "npm start",
445
- "build": "npm run build",
446
- "serve": "serve -s build"
447
- }
448
- },
449
- "vue": {
450
- "files": [
451
- "vue.config.js",
452
- "vite.config.js"
453
- ],
454
- "package_json": [
455
- "vue",
456
- "@vue/cli-service"
457
- ],
458
- "commands": {
459
- "dev": "npm run serve",
460
- "build": "npm run build",
461
- "preview": "npm run preview"
462
- }
463
- },
464
- "python_django": {
465
- "files": [
466
- "manage.py",
467
- "wsgi.py"
468
- ],
469
- "requirements": [
470
- "django"
471
- ],
472
- "commands": {
473
- "dev": "python manage.py runserver",
474
- "prod": "gunicorn wsgi:application"
475
- }
476
- },
477
- "python_flask": {
478
- "files": [
479
- "app.py",
480
- "wsgi.py"
481
- ],
482
- "requirements": [
483
- "flask"
484
- ],
485
- "commands": {
486
- "dev": "flask run",
487
- "prod": "gunicorn app:app"
488
- }
489
- },
490
- "python_fastapi": {
491
- "files": [
492
- "main.py",
493
- "app.py"
494
- ],
495
- "requirements": [
496
- "fastapi",
497
- "uvicorn"
498
- ],
499
- "commands": {
500
- "dev": "uvicorn main:app --reload --port {port}",
501
- "prod": "uvicorn main:app --workers 4 --port {port}"
502
- }
503
- },
504
- "nodejs_express": {
505
- "files": [
506
- "server.js",
507
- "app.js",
508
- "index.js"
509
- ],
510
- "package_json": [
511
- "express"
512
- ],
513
- "commands": {
514
- "dev": "nodemon server.js",
515
- "prod": "node server.js"
516
- }
517
- },
518
- "rust_actix": {
519
- "files": [
520
- "Cargo.toml",
521
- "Cargo.lock",
522
- "src/main.rs"
523
- ],
524
- "cargo_dependencies": [
525
- "actix-web"
526
- ],
527
- "commands": {
528
- "dev": "cargo run",
529
- "watch": "cargo watch -x run",
530
- "build": "cargo build --release",
531
- "start": "./target/release/{app_name}"
532
- }
533
- },
534
- "rust_rocket": {
535
- "files": [
536
- "Cargo.toml",
537
- "Rocket.toml",
538
- "src/main.rs"
539
- ],
540
- "cargo_dependencies": [
541
- "rocket"
542
- ],
543
- "commands": {
544
- "dev": "cargo run",
545
- "watch": "cargo watch -x run",
546
- "build": "cargo build --release",
547
- "start": "./target/release/{app_name}"
548
- }
549
- },
550
- "rust_axum": {
551
- "files": [
552
- "Cargo.toml",
553
- "src/main.rs"
554
- ],
555
- "cargo_dependencies": [
556
- "axum"
557
- ],
558
- "commands": {
559
- "dev": "cargo run",
560
- "watch": "cargo watch -x run",
561
- "build": "cargo build --release",
562
- "start": "./target/release/{app_name}"
563
- }
564
- },
565
- "go_gin": {
566
- "files": [
567
- "go.mod",
568
- "go.sum",
569
- "main.go"
570
- ],
571
- "go_imports": [
572
- "github.com/gin-gonic/gin"
573
- ],
574
- "commands": {
575
- "dev": "go run .",
576
- "watch": "air",
577
- "build": "go build -o {app_name}",
578
- "start": "./{app_name}"
579
- }
580
- },
581
- "go_echo": {
582
- "files": [
583
- "go.mod",
584
- "go.sum",
585
- "main.go"
586
- ],
587
- "go_imports": [
588
- "github.com/labstack/echo"
589
- ],
590
- "commands": {
591
- "dev": "go run .",
592
- "watch": "air",
593
- "build": "go build -o {app_name}",
594
- "start": "./{app_name}"
595
- }
596
- },
597
- "go_fiber": {
598
- "files": [
599
- "go.mod",
600
- "go.sum",
601
- "main.go"
602
- ],
603
- "go_imports": [
604
- "github.com/gofiber/fiber"
605
- ],
606
- "commands": {
607
- "dev": "go run .",
608
- "watch": "air",
609
- "build": "go build -o {app_name}",
610
- "start": "./{app_name}"
611
- }
612
- },
613
- "java_spring_boot_maven": {
614
- "files": [
615
- "pom.xml",
616
- "src/main/java",
617
- "application.properties"
618
- ],
619
- "dependencies": [
620
- "spring-boot"
621
- ],
622
- "commands": {
623
- "dev": "mvn spring-boot:run",
624
- "build": "mvn clean package",
625
- "start": "java -jar target/{app_name}.jar"
626
- }
627
- },
628
- "java_spring_boot_gradle": {
629
- "files": [
630
- "build.gradle",
631
- "src/main/java",
632
- "application.properties"
633
- ],
634
- "dependencies": [
635
- "spring-boot"
636
- ],
637
- "commands": {
638
- "dev": "gradle bootRun",
639
- "build": "gradle clean build",
640
- "start": "java -jar build/libs/{app_name}.jar"
641
- }
642
- },
643
- "ruby_rails": {
644
- "files": [
645
- "Gemfile",
646
- "Rakefile",
647
- "config.ru",
648
- "config/application.rb"
649
- ],
650
- "gemfile": [
651
- "rails"
652
- ],
653
- "commands": {
654
- "dev": "bundle exec rails server -p {port}",
655
- "build": "bundle exec rails assets:precompile",
656
- "start": "bundle exec puma -C config/puma.rb"
657
- }
658
- },
659
- "php_laravel": {
660
- "files": [
661
- "artisan",
662
- "composer.json",
663
- "app/Http/Kernel.php"
664
- ],
665
- "composer": [
666
- "laravel/framework"
667
- ],
668
- "commands": {
669
- "dev": "php artisan serve --port={port}",
670
- "prod": "php artisan serve --port={port} --env=production"
671
- }
672
- },
673
- "dart_flutter_web": {
674
- "files": [
675
- "pubspec.yaml",
676
- "lib/main.dart",
677
- "web"
678
- ],
679
- "dependencies": [
680
- "flutter"
681
- ],
682
- "commands": {
683
- "dev": "flutter run -d web-server --web-port={port}",
684
- "build": "flutter build web",
685
- "start": "serve -s build/web -p {port}"
686
- }
687
- }
688
- },
689
- "deployment_strategies": {
690
- "production": {
691
- "nextjs": {
692
- "method": "pm2",
693
- "pm2_options": {
694
- "max_memory_restart": "2G",
695
- "max_restarts": 10,
696
- "min_uptime": 3000,
697
- "autorestart": true,
698
- "kill_timeout": 5000,
699
- "listen_timeout": 8000,
700
- "shutdown_with_message": true
701
- },
702
- "steps": [
703
- "npm install --production",
704
- "npm run build",
705
- "pm2 start npm --name '{app_name}' -- start --max-memory-restart 2G --max-restarts 10 --min-uptime 3000"
706
- ],
707
- "health_check": "http://localhost:{port}",
708
- "environment": {
709
- "NODE_ENV": "production"
710
- }
711
- },
712
- "react": {
713
- "method": "static",
714
- "steps": [
715
- "npm install",
716
- "npm run build",
717
- "pm2 serve build {port} --name '{app_name}'"
718
- ],
719
- "health_check": "http://localhost:{port}"
720
- },
721
- "python": {
722
- "method": "pm2",
723
- "steps": [
724
- "pip install -r requirements.txt",
725
- "pm2 start gunicorn --name '{app_name}' -- app:app --bind 0.0.0.0:{port}"
726
- ],
727
- "health_check": "http://localhost:{port}/health"
728
- },
729
- "fastapi": {
730
- "method": "local-deploy",
731
- "steps": [
732
- "pip install -r requirements.txt",
733
- "claude-mpm local-deploy start --command 'uvicorn main:app --workers 4 --port {port}' --port {port} --auto-restart --health-check http://localhost:{port}/health"
734
- ],
735
- "health_check": "http://localhost:{port}/health",
736
- "environment": {
737
- "UVICORN_LOG_LEVEL": "info"
738
- }
739
- },
740
- "rust_actix": {
741
- "method": "local-deploy",
742
- "steps": [
743
- "cargo build --release",
744
- "claude-mpm local-deploy start --command './target/release/{app_name}' --port {port} --auto-restart --health-check http://localhost:{port}/health"
745
- ],
746
- "health_check": "http://localhost:{port}/health",
747
- "environment": {
748
- "RUST_LOG": "info"
749
- }
750
- },
751
- "rust_rocket": {
752
- "method": "local-deploy",
753
- "steps": [
754
- "cargo build --release",
755
- "claude-mpm local-deploy start --command './target/release/{app_name}' --port {port} --auto-restart --health-check http://localhost:{port}/health"
756
- ],
757
- "health_check": "http://localhost:{port}/health",
758
- "environment": {
759
- "RUST_LOG": "info",
760
- "ROCKET_PORT": "{port}"
761
- }
762
- },
763
- "rust_axum": {
764
- "method": "local-deploy",
765
- "steps": [
766
- "cargo build --release",
767
- "claude-mpm local-deploy start --command './target/release/{app_name}' --port {port} --auto-restart --health-check http://localhost:{port}/health"
768
- ],
769
- "health_check": "http://localhost:{port}/health",
770
- "environment": {
771
- "RUST_LOG": "info"
772
- }
773
- },
774
- "go_gin": {
775
- "method": "local-deploy",
776
- "steps": [
777
- "go build -o {app_name}",
778
- "claude-mpm local-deploy start --command './{app_name}' --port {port} --auto-restart --health-check http://localhost:{port}/ping"
779
- ],
780
- "health_check": "http://localhost:{port}/ping",
781
- "environment": {
782
- "GO_ENV": "production"
783
- }
784
- },
785
- "go_echo": {
786
- "method": "local-deploy",
787
- "steps": [
788
- "go build -o {app_name}",
789
- "claude-mpm local-deploy start --command './{app_name}' --port {port} --auto-restart --health-check http://localhost:{port}/health"
790
- ],
791
- "health_check": "http://localhost:{port}/health",
792
- "environment": {
793
- "GO_ENV": "production"
794
- }
795
- },
796
- "go_fiber": {
797
- "method": "local-deploy",
798
- "steps": [
799
- "go build -o {app_name}",
800
- "claude-mpm local-deploy start --command './{app_name}' --port {port} --auto-restart --health-check http://localhost:{port}/health"
801
- ],
802
- "health_check": "http://localhost:{port}/health",
803
- "environment": {
804
- "GO_ENV": "production"
805
- }
806
- },
807
- "java_spring_boot_maven": {
808
- "method": "local-deploy",
809
- "steps": [
810
- "mvn clean package",
811
- "claude-mpm local-deploy start --command 'java -jar target/{app_name}.jar' --port {port} --auto-restart --health-check http://localhost:{port}/actuator/health"
812
- ],
813
- "health_check": "http://localhost:{port}/actuator/health",
814
- "environment": {
815
- "SPRING_PROFILES_ACTIVE": "prod",
816
- "JAVA_OPTS": "-Xmx512m -Xms256m"
817
- }
818
- },
819
- "java_spring_boot_gradle": {
820
- "method": "local-deploy",
821
- "steps": [
822
- "gradle clean build",
823
- "claude-mpm local-deploy start --command 'java -jar build/libs/{app_name}.jar' --port {port} --auto-restart --health-check http://localhost:{port}/actuator/health"
824
- ],
825
- "health_check": "http://localhost:{port}/actuator/health",
826
- "environment": {
827
- "SPRING_PROFILES_ACTIVE": "prod",
828
- "JAVA_OPTS": "-Xmx512m -Xms256m"
829
- }
830
- },
831
- "ruby_rails": {
832
- "method": "local-deploy",
833
- "steps": [
834
- "bundle install --deployment",
835
- "bundle exec rails db:migrate",
836
- "claude-mpm local-deploy start --command 'bundle exec puma -C config/puma.rb' --port {port} --auto-restart --health-check http://localhost:{port}/up"
837
- ],
838
- "health_check": "http://localhost:{port}/up",
839
- "environment": {
840
- "RAILS_ENV": "production",
841
- "RAILS_LOG_TO_STDOUT": "1"
842
- }
843
- },
844
- "php_laravel": {
845
- "method": "local-deploy",
846
- "steps": [
847
- "composer install --optimize-autoloader --no-dev",
848
- "php artisan migrate --force",
849
- "claude-mpm local-deploy start --command 'php artisan serve --port={port} --env=production' --port {port} --auto-restart --health-check http://localhost:{port}/health"
850
- ],
851
- "health_check": "http://localhost:{port}/health",
852
- "environment": {
853
- "APP_ENV": "production"
854
- }
855
- }
856
- },
857
- "development": {
858
- "nextjs": {
859
- "method": "pm2",
860
- "pm2_options": {
861
- "max_memory_restart": "2G",
862
- "max_restarts": 10,
863
- "min_uptime": 3000,
864
- "autorestart": true,
865
- "watch": true
866
- },
867
- "steps": [
868
- "npm install",
869
- "pm2 start npm --name '{app_name}-dev' -- run dev --max-memory-restart 2G --max-restarts 10 --min-uptime 3000 --watch"
870
- ],
871
- "environment": {
872
- "NODE_ENV": "development"
873
- }
874
- },
875
- "react": {
876
- "method": "pm2",
877
- "steps": [
878
- "npm install",
879
- "pm2 start npm --name '{app_name}-dev' -- start"
880
- ]
881
- },
882
- "fastapi": {
883
- "method": "local-deploy",
884
- "steps": [
885
- "pip install -r requirements.txt",
886
- "claude-mpm local-deploy start --command 'uvicorn main:app --reload --port {port}' --port {port} --auto-restart --health-check http://localhost:{port}/docs"
887
- ],
888
- "environment": {
889
- "ENVIRONMENT": "development",
890
- "DEBUG": "True"
891
- }
892
- },
893
- "express": {
894
- "method": "local-deploy",
895
- "steps": [
896
- "npm install",
897
- "claude-mpm local-deploy start --command 'nodemon server.js' --port {port} --auto-restart --health-check http://localhost:{port}/health"
898
- ],
899
- "environment": {
900
- "NODE_ENV": "development"
901
- }
902
- },
903
- "rust_actix": {
904
- "method": "local-deploy",
905
- "steps": [
906
- "claude-mpm local-deploy start --command 'cargo watch -x run' --port {port} --auto-restart --health-check http://localhost:{port}/health"
907
- ],
908
- "environment": {
909
- "RUST_LOG": "debug"
910
- }
911
- },
912
- "rust_rocket": {
913
- "method": "local-deploy",
914
- "steps": [
915
- "claude-mpm local-deploy start --command 'cargo watch -x run' --port {port} --auto-restart --health-check http://localhost:{port}/health"
916
- ],
917
- "environment": {
918
- "RUST_LOG": "debug"
919
- }
920
- },
921
- "rust_axum": {
922
- "method": "local-deploy",
923
- "steps": [
924
- "claude-mpm local-deploy start --command 'cargo watch -x run' --port {port} --auto-restart --health-check http://localhost:{port}/health"
925
- ],
926
- "environment": {
927
- "RUST_LOG": "debug"
928
- }
929
- },
930
- "go_gin": {
931
- "method": "local-deploy",
932
- "steps": [
933
- "claude-mpm local-deploy start --command 'air' --port {port} --auto-restart --health-check http://localhost:{port}/ping",
934
- "fallback: go run ."
935
- ],
936
- "environment": {
937
- "GO_ENV": "development"
938
- }
939
- },
940
- "go_echo": {
941
- "method": "local-deploy",
942
- "steps": [
943
- "claude-mpm local-deploy start --command 'air' --port {port} --auto-restart --health-check http://localhost:{port}/health",
944
- "fallback: go run ."
945
- ],
946
- "environment": {
947
- "GO_ENV": "development"
948
- }
949
- },
950
- "go_fiber": {
951
- "method": "local-deploy",
952
- "steps": [
953
- "claude-mpm local-deploy start --command 'air' --port {port} --auto-restart --health-check http://localhost:{port}/health",
954
- "fallback: go run ."
955
- ],
956
- "environment": {
957
- "GO_ENV": "development"
958
- }
959
- },
960
- "java_spring_boot_maven": {
961
- "method": "local-deploy",
962
- "steps": [
963
- "claude-mpm local-deploy start --command 'mvn spring-boot:run' --port {port} --auto-restart --health-check http://localhost:{port}/actuator/health"
964
- ],
965
- "environment": {
966
- "SPRING_PROFILES_ACTIVE": "dev",
967
- "LOGGING_LEVEL_ROOT": "DEBUG"
968
- }
969
- },
970
- "java_spring_boot_gradle": {
971
- "method": "local-deploy",
972
- "steps": [
973
- "claude-mpm local-deploy start --command 'gradle bootRun' --port {port} --auto-restart --health-check http://localhost:{port}/actuator/health"
974
- ],
975
- "environment": {
976
- "SPRING_PROFILES_ACTIVE": "dev",
977
- "LOGGING_LEVEL_ROOT": "DEBUG"
978
- }
979
- },
980
- "ruby_rails": {
981
- "method": "local-deploy",
982
- "steps": [
983
- "bundle install",
984
- "claude-mpm local-deploy start --command 'bundle exec rails server -p {port}' --port {port} --auto-restart --health-check http://localhost:{port}/up"
985
- ],
986
- "environment": {
987
- "RAILS_ENV": "development"
988
- }
989
- },
990
- "php_laravel": {
991
- "method": "local-deploy",
992
- "steps": [
993
- "composer install",
994
- "claude-mpm local-deploy start --command 'php artisan serve --port={port}' --port {port} --auto-restart --health-check http://localhost:{port}/health"
995
- ],
996
- "environment": {
997
- "APP_ENV": "local"
998
- }
999
- },
1000
- "dart_flutter_web": {
1001
- "method": "local-deploy",
1002
- "steps": [
1003
- "flutter pub get",
1004
- "claude-mpm local-deploy start --command 'flutter run -d web-server --web-port={port}' --port {port} --auto-restart"
1005
- ],
1006
- "hot_reload": true
1007
- }
1008
- },
1009
- "docker": {
1010
- "default": {
1011
- "method": "docker",
1012
- "steps": [
1013
- "docker build -t {app_name} .",
1014
- "docker run -d -p {port}:{container_port} --name {app_name} {app_name}"
1015
- ],
1016
- "health_check": "docker exec {app_name} echo 'OK'"
1017
- }
1018
- }
1019
- },
1020
- "error_recovery": {
1021
- "port_conflict": {
1022
- "detection": "EADDRINUSE",
1023
- "action": "check_process_owner_then_allocate_alternative_port",
1024
- "never": "kill_existing_process_without_verification"
1025
- },
1026
- "existing_service": {
1027
- "detection": "service_already_running",
1028
- "action": "attach_to_existing_or_report_status",
1029
- "never": "create_duplicate_instance"
1030
- },
1031
- "external_ownership": {
1032
- "detection": "process_owned_by_other_project",
1033
- "action": "allocate_different_resources",
1034
- "never": "interfere_with_external_process"
1035
- },
1036
- "claude_mpm_service": {
1037
- "detection": "claude-mpm|mcp|monitor",
1038
- "action": "report_status_only",
1039
- "never": "stop_or_restart_system_services"
1040
- },
1041
- "build_failure": {
1042
- "detection": "npm ERR!|ERROR|Failed",
1043
- "action": "report_error_and_suggest_fixes"
1044
- },
1045
- "crash_loop": {
1046
- "detection": "restart_count > 5",
1047
- "action": "stop_and_investigate_logs"
1048
- },
1049
- "out_of_memory": {
1050
- "detection": "JavaScript heap out of memory",
1051
- "action": "increase_memory_limit"
1052
- }
1053
- },
1054
- "health_checks": {
1055
- "nextjs": {
1056
- "primary_endpoints": [
1057
- "/api/health",
1058
- "/"
1059
- ],
1060
- "build_artifacts": [
1061
- ".next/BUILD_ID",
1062
- ".next/routes-manifest.json"
1063
- ],
1064
- "static_assets": "/_next/static/chunks",
1065
- "validation_steps": [
1066
- "verify_build_artifacts",
1067
- "test_primary_endpoint",
1068
- "validate_static_assets"
1069
- ]
1070
- }
1071
- },
1072
- "pm2_monitoring": {
1073
- "metrics_extraction": {
1074
- "enabled": true,
1075
- "commands": {
1076
- "status": "pm2 jlist",
1077
- "describe": "pm2 describe {app_name}",
1078
- "metrics": "pm2 show {app_name}"
1079
- },
1080
- "tracked_metrics": [
1081
- "restart_count",
1082
- "uptime",
1083
- "memory_usage",
1084
- "cpu_usage",
1085
- "status",
1086
- "unstable_restarts"
1087
- ]
1088
- },
1089
- "alerts": {
1090
- "high_restart_count": {
1091
- "threshold": 5,
1092
- "action": "investigate_crash_logs"
1093
- },
1094
- "memory_near_limit": {
1095
- "threshold": "1.8G",
1096
- "action": "preemptive_restart_warning"
1097
- }
1098
- }
1099
- },
1100
- "best_practices": {
1101
- "port_selection": {
1102
- "description": "Recommended default ports by language and framework",
1103
- "nodejs": {
1104
- "default_ports": [
1105
- 3000,
1106
- 3001,
1107
- 3002
1108
- ],
1109
- "frameworks": {
1110
- "express": 3000,
1111
- "nextjs": 3000,
1112
- "nestjs": 3000
1113
- }
1114
- },
1115
- "python": {
1116
- "default_ports": [
1117
- 8000,
1118
- 5000,
1119
- 8080
1120
- ],
1121
- "frameworks": {
1122
- "fastapi": 8000,
1123
- "django": 8000,
1124
- "flask": 5000
1125
- }
1126
- },
1127
- "rust": {
1128
- "default_ports": [
1129
- 8080,
1130
- 3000
1131
- ],
1132
- "frameworks": {
1133
- "actix-web": 8080,
1134
- "rocket": 8000,
1135
- "axum": 3000
1136
- }
1137
- },
1138
- "go": {
1139
- "default_ports": [
1140
- 8080,
1141
- 8000
1142
- ],
1143
- "frameworks": {
1144
- "gin": 8080,
1145
- "echo": 1323,
1146
- "fiber": 3000
1147
- }
1148
- },
1149
- "java": {
1150
- "default_ports": [
1151
- 8080,
1152
- 8443
1153
- ],
1154
- "frameworks": {
1155
- "spring-boot": 8080,
1156
- "tomcat": 8080
1157
- }
1158
- },
1159
- "ruby": {
1160
- "default_ports": [
1161
- 3000,
1162
- 9292
1163
- ],
1164
- "frameworks": {
1165
- "rails": 3000,
1166
- "sinatra": 4567
1167
- }
1168
- },
1169
- "php": {
1170
- "default_ports": [
1171
- 8000,
1172
- 8080
1173
- ],
1174
- "frameworks": {
1175
- "laravel": 8000,
1176
- "symfony": 8000
1177
- }
1178
- },
1179
- "dart": {
1180
- "default_ports": [
1181
- 8080
1182
- ],
1183
- "frameworks": {
1184
- "flutter-web": 8080,
1185
- "shelf": 8080
1186
- }
1187
- }
1188
- },
1189
- "health_checks": {
1190
- "description": "Framework-specific health check endpoints",
1191
- "python_fastapi": {
1192
- "primary": "/health",
1193
- "alternatives": [
1194
- "/docs",
1195
- "/openapi.json"
1196
- ],
1197
- "expected_status": 200,
1198
- "timeout": 5
1199
- },
1200
- "python_django": {
1201
- "primary": "/health",
1202
- "alternatives": [
1203
- "/admin"
1204
- ],
1205
- "expected_status": 200,
1206
- "timeout": 5
1207
- },
1208
- "nodejs_express": {
1209
- "primary": "/health",
1210
- "alternatives": [
1211
- "/ping",
1212
- "/ready"
1213
- ],
1214
- "expected_status": 200,
1215
- "timeout": 5
1216
- },
1217
- "rust_actix": {
1218
- "primary": "/health",
1219
- "expected_status": 200,
1220
- "timeout": 5
1221
- },
1222
- "rust_rocket": {
1223
- "primary": "/health",
1224
- "expected_status": 200,
1225
- "timeout": 5
1226
- },
1227
- "rust_axum": {
1228
- "primary": "/health",
1229
- "expected_status": 200,
1230
- "timeout": 5
1231
- },
1232
- "go_gin": {
1233
- "primary": "/ping",
1234
- "alternatives": [
1235
- "/health"
1236
- ],
1237
- "expected_status": 200,
1238
- "timeout": 5
1239
- },
1240
- "go_echo": {
1241
- "primary": "/health",
1242
- "expected_status": 200,
1243
- "timeout": 5
1244
- },
1245
- "go_fiber": {
1246
- "primary": "/health",
1247
- "expected_status": 200,
1248
- "timeout": 5
1249
- },
1250
- "java_spring_boot": {
1251
- "primary": "/actuator/health",
1252
- "alternatives": [
1253
- "/actuator/info"
1254
- ],
1255
- "expected_status": 200,
1256
- "timeout": 10,
1257
- "management_port": 8081
1258
- },
1259
- "ruby_rails": {
1260
- "primary": "/up",
1261
- "alternatives": [
1262
- "/health"
1263
- ],
1264
- "expected_status": 200,
1265
- "timeout": 5
1266
- },
1267
- "php_laravel": {
1268
- "primary": "/health",
1269
- "alternatives": [
1270
- "/api/health"
1271
- ],
1272
- "expected_status": 200,
1273
- "timeout": 5
1274
- },
1275
- "recommendation": {
1276
- "endpoint": "Always configure /health endpoint",
1277
- "check_interval": "30 seconds recommended",
1278
- "timeout": "5 seconds maximum",
1279
- "retry_attempts": 3
1280
- }
1281
- },
1282
- "auto_restart": {
1283
- "description": "Auto-restart configuration best practices",
1284
- "enabled": true,
1285
- "max_attempts": 5,
1286
- "backoff_strategy": "exponential (2s, 4s, 8s, 16s, 32s)",
1287
- "circuit_breaker": {
1288
- "enabled": true,
1289
- "threshold": 3,
1290
- "window_seconds": 300,
1291
- "reset_seconds": 600
1292
- },
1293
- "recommendation": "Enable auto-restart for all production deployments"
1294
- },
1295
- "log_monitoring": {
1296
- "description": "Framework-specific log patterns to monitor",
1297
- "python": {
1298
- "error_patterns": [
1299
- "ERROR",
1300
- "CRITICAL",
1301
- "Exception",
1302
- "Traceback",
1303
- "Failed to"
1304
- ],
1305
- "action": "Trigger auto-restart on critical patterns"
1306
- },
1307
- "nodejs": {
1308
- "error_patterns": [
1309
- "ERROR",
1310
- "Error:",
1311
- "Exception",
1312
- "Unhandled",
1313
- "ECONNREFUSED"
1314
- ],
1315
- "action": "Trigger auto-restart on critical patterns"
1316
- },
1317
- "rust": {
1318
- "error_patterns": [
1319
- "ERROR",
1320
- "FATAL",
1321
- "panic",
1322
- "thread .* panicked"
1323
- ],
1324
- "action": "Trigger auto-restart on critical patterns"
1325
- },
1326
- "go": {
1327
- "error_patterns": [
1328
- "ERROR",
1329
- "FATAL",
1330
- "panic:",
1331
- "runtime error"
1332
- ],
1333
- "action": "Trigger auto-restart on critical patterns"
1334
- },
1335
- "java": {
1336
- "error_patterns": [
1337
- "ERROR",
1338
- "SEVERE",
1339
- "Exception",
1340
- "java.lang.",
1341
- "OutOfMemoryError"
1342
- ],
1343
- "action": "Trigger auto-restart on critical patterns"
1344
- },
1345
- "ruby": {
1346
- "error_patterns": [
1347
- "ERROR",
1348
- "FATAL",
1349
- "Exception"
1350
- ],
1351
- "action": "Trigger auto-restart on critical patterns"
1352
- },
1353
- "php": {
1354
- "error_patterns": [
1355
- "Fatal error",
1356
- "Parse error",
1357
- "Exception"
1358
- ],
1359
- "action": "Trigger auto-restart on critical patterns"
1360
- },
1361
- "enabled": true
1362
- },
1363
- "graceful_shutdown": {
1364
- "description": "Graceful shutdown patterns by language",
1365
- "nodejs": {
1366
- "signal": "SIGTERM",
1367
- "timeout": 10,
1368
- "pattern": "process.on('SIGTERM', gracefulShutdown)"
1369
- },
1370
- "python": {
1371
- "signal": "SIGTERM",
1372
- "timeout": 30,
1373
- "pattern": "signal.signal(signal.SIGTERM, shutdown_handler)"
1374
- },
1375
- "rust": {
1376
- "signal": "SIGTERM",
1377
- "timeout": 10,
1378
- "pattern": "tokio::signal::ctrl_c() or signal handlers"
1379
- },
1380
- "go": {
1381
- "signal": "SIGTERM",
1382
- "timeout": 10,
1383
- "pattern": "signal.Notify(quit, syscall.SIGTERM)"
1384
- },
1385
- "java": {
1386
- "signal": "SIGTERM",
1387
- "timeout": 30,
1388
- "pattern": "server.shutdown=graceful in application.properties"
1389
- },
1390
- "ruby": {
1391
- "signal": "SIGTERM",
1392
- "timeout": 30,
1393
- "pattern": "Puma graceful shutdown via config"
1394
- },
1395
- "php": {
1396
- "signal": "SIGTERM",
1397
- "timeout": 10,
1398
- "pattern": "PHP-FPM graceful shutdown"
1399
- },
1400
- "recommendation": "Always implement graceful shutdown handlers"
1401
- },
1402
- "environment_configuration": {
1403
- "description": "Environment variable patterns by framework",
1404
- "development": {
1405
- "python_fastapi": {
1406
- "ENVIRONMENT": "development",
1407
- "DEBUG": "True",
1408
- "LOG_LEVEL": "debug",
1409
- "RELOAD": "true"
1410
- },
1411
- "nodejs_express": {
1412
- "NODE_ENV": "development",
1413
- "DEBUG": "*"
1414
- },
1415
- "rust": {
1416
- "RUST_LOG": "debug"
1417
- },
1418
- "go": {
1419
- "GO_ENV": "development"
1420
- },
1421
- "java_spring_boot": {
1422
- "SPRING_PROFILES_ACTIVE": "dev",
1423
- "LOGGING_LEVEL_ROOT": "DEBUG"
1424
- },
1425
- "ruby_rails": {
1426
- "RAILS_ENV": "development"
1427
- },
1428
- "php_laravel": {
1429
- "APP_ENV": "local",
1430
- "APP_DEBUG": "true"
1431
- }
1432
- },
1433
- "production": {
1434
- "python_fastapi": {
1435
- "ENVIRONMENT": "production",
1436
- "DEBUG": "False",
1437
- "LOG_LEVEL": "info",
1438
- "WORKERS": "4"
1439
- },
1440
- "nodejs_express": {
1441
- "NODE_ENV": "production"
1442
- },
1443
- "rust": {
1444
- "RUST_LOG": "info"
1445
- },
1446
- "go": {
1447
- "GO_ENV": "production"
1448
- },
1449
- "java_spring_boot": {
1450
- "SPRING_PROFILES_ACTIVE": "prod",
1451
- "LOGGING_LEVEL_ROOT": "INFO",
1452
- "JAVA_OPTS": "-Xmx512m -Xms256m"
1453
- },
1454
- "ruby_rails": {
1455
- "RAILS_ENV": "production",
1456
- "RAILS_LOG_TO_STDOUT": "1"
1457
- },
1458
- "php_laravel": {
1459
- "APP_ENV": "production",
1460
- "APP_DEBUG": "false"
1461
- }
1462
- }
1463
- },
1464
- "resource_monitoring": {
1465
- "description": "Resource thresholds for health monitoring",
1466
- "cpu_threshold": 80.0,
1467
- "memory_threshold_mb": 500,
1468
- "fd_threshold_percent": 0.8,
1469
- "check_interval": 30,
1470
- "alert_on_sustained_high_usage": true
1471
- }
1472
- },
1473
- "security": {
1474
- "port_exposure": "localhost_only",
1475
- "process_isolation": "user_level",
1476
- "log_sanitization": true,
1477
- "secrets_handling": "environment_variables"
1478
- },
1479
- "integration": {
1480
- "operational_principles": {
1481
- "single_instance_policy": "Always maintain single stable instances of services",
1482
- "non_interference": "Never interrupt services owned by other projects or Claude Code",
1483
- "service_protection": "Protect all Claude MPM, MCP, and monitor services",
1484
- "graceful_operations": "Always prefer graceful operations over forceful actions",
1485
- "conflict_avoidance": "Find alternative resources rather than stopping existing services",
1486
- "auto_updating_mode": "Always enable watch/hot-reload for development deployments",
1487
- "mandatory_verification": "MUST verify endpoint responds before reporting success",
1488
- "pm2_preferred": "PM2 is the preferred deployment method for Node.js applications"
1489
- },
1490
- "hooks": {
1491
- "pre_deploy": "check_conflicts_and_validate_requirements",
1492
- "post_deploy": "notify_status",
1493
- "pre_stop": "verify_ownership_then_graceful_shutdown",
1494
- "on_crash": "auto_restart_with_backoff",
1495
- "before_port_use": "check_existing_process_owner",
1496
- "on_conflict": "find_alternative_resources"
1497
- },
1498
- "monitoring": {
1499
- "export_metrics": true,
1500
- "prometheus_endpoint": "/metrics",
1501
- "health_endpoint": "/health"
1502
- }
1503
- },
1504
- "tools": [
1505
- "Bash",
1506
- "Read",
1507
- "Write",
1508
- "Edit"
1509
- ],
1510
- "examples": [
1511
- {
1512
- "user": "Deploy my Next.js app in dev mode",
1513
- "response": "Deploying with PM2 watch mode on consistent port. Verifying endpoint responds...",
1514
- "actions": [
1515
- "detect_framework",
1516
- "check_existing_deployment",
1517
- "reuse_existing_port",
1518
- "start_pm2_with_watch_mode",
1519
- "verify_endpoint_responds",
1520
- "report_verified_url_with_http_status"
1521
- ]
1522
- },
1523
- {
1524
- "user": "Deploy my Next.js app",
1525
- "response": "I'll deploy your Next.js application using PM2 for stability. Let me detect your configuration and set it up...",
1526
- "actions": [
1527
- "detect_framework",
1528
- "allocate_consistent_port",
1529
- "build_production",
1530
- "deploy_with_pm2",
1531
- "register_port_allocation",
1532
- "monitor_health"
1533
- ]
1534
- },
1535
- {
1536
- "user": "Show me the status of all deployments",
1537
- "response": "Here's the status of all active deployments...",
1538
- "actions": [
1539
- "list_pm2_processes",
1540
- "check_docker_containers",
1541
- "show_port_allocations",
1542
- "aggregate_status"
1543
- ]
1544
- },
1545
- {
1546
- "user": "Check for orphaned processes",
1547
- "response": "I'll scan for orphaned deployment processes and categorize them by severity...",
1548
- "actions": [
1549
- "scan_all_orphans",
1550
- "classify_by_severity",
1551
- "report_findings_with_cleanup_recommendations"
1552
- ]
1553
- },
1554
- {
1555
- "user": "Clean up orphaned processes",
1556
- "response": "I'll safely clean up orphaned processes. High-severity orphans will require your confirmation...",
1557
- "actions": [
1558
- "scan_orphans",
1559
- "verify_safety_checks",
1560
- "cleanup_low_severity_orphans",
1561
- "request_confirmation_for_high_severity",
1562
- "report_results"
1563
- ]
1564
- },
1565
- {
1566
- "user": "The app keeps crashing, help me debug",
1567
- "response": "Let me check the logs and identify the issue...",
1568
- "actions": [
1569
- "fetch_error_logs",
1570
- "analyze_crash_pattern",
1571
- "suggest_fixes"
1572
- ]
1573
- },
1574
- {
1575
- "user": "Deploy my FastAPI app with auto-restart",
1576
- "response": "I'll deploy your FastAPI application with uvicorn and enable auto-restart for production stability...",
1577
- "actions": [
1578
- "detect_fastapi_framework",
1579
- "install_dependencies",
1580
- "execute_local_deploy_with_uvicorn",
1581
- "configure_health_check_at_/health",
1582
- "enable_auto_restart",
1583
- "verify_endpoint_responds",
1584
- "report_deployment_url"
1585
- ]
1586
- },
1587
- {
1588
- "user": "Start my Rust Actix-web app in dev mode",
1589
- "response": "I'll start your Actix-web application with cargo watch for hot reloading...",
1590
- "actions": [
1591
- "detect_rust_actix",
1592
- "execute_cargo_watch",
1593
- "configure_health_check_at_/health",
1594
- "monitor_compilation",
1595
- "verify_server_running",
1596
- "report_deployment_url"
1597
- ]
1598
- },
1599
- {
1600
- "user": "Deploy my Go Gin app to production",
1601
- "response": "I'll build and deploy your Go Gin application with auto-restart enabled...",
1602
- "actions": [
1603
- "detect_go_gin",
1604
- "build_go_binary",
1605
- "execute_local_deploy_start",
1606
- "configure_health_check_at_/ping",
1607
- "enable_auto_restart",
1608
- "verify_endpoint_responds",
1609
- "report_deployment_url"
1610
- ]
1611
- },
1612
- {
1613
- "user": "Run my Spring Boot app in development",
1614
- "response": "I'll start your Spring Boot application with Maven in development mode...",
1615
- "actions": [
1616
- "detect_spring_boot",
1617
- "execute_mvn_spring_boot_run",
1618
- "configure_health_check_at_/actuator/health",
1619
- "wait_for_startup",
1620
- "verify_actuator_endpoint",
1621
- "report_deployment_url"
1622
- ]
1623
- },
1624
- {
1625
- "user": "Deploy my Rails app with Puma",
1626
- "response": "I'll deploy your Rails application with Puma and enable auto-restart...",
1627
- "actions": [
1628
- "detect_rails",
1629
- "bundle_install",
1630
- "run_migrations",
1631
- "execute_local_deploy_with_puma",
1632
- "configure_health_check_at_/up",
1633
- "enable_auto_restart",
1634
- "verify_endpoint_responds",
1635
- "report_deployment_url"
1636
- ]
1637
- },
1638
- {
1639
- "user": "Start my Laravel app locally",
1640
- "response": "I'll start your Laravel application with php artisan serve...",
1641
- "actions": [
1642
- "detect_laravel",
1643
- "composer_install",
1644
- "run_migrations",
1645
- "execute_local_deploy_artisan_serve",
1646
- "configure_health_check_at_/health",
1647
- "verify_endpoint_responds",
1648
- "report_deployment_url"
1649
- ]
1650
- },
1651
- {
1652
- "user": "Deploy my Express.js API",
1653
- "response": "I'll deploy your Express.js API with nodemon for development...",
1654
- "actions": [
1655
- "detect_express",
1656
- "npm_install",
1657
- "execute_local_deploy_with_nodemon",
1658
- "configure_health_check_at_/health",
1659
- "enable_auto_restart",
1660
- "verify_endpoint_responds",
1661
- "report_deployment_url"
1662
- ]
1663
- },
1664
- {
1665
- "user": "Check health of all deployments",
1666
- "response": "I'll check the health status of all active deployments...",
1667
- "actions": [
1668
- "list_all_deployments",
1669
- "check_health_for_each",
1670
- "report_health_status",
1671
- "identify_unhealthy_services"
1672
- ]
1673
- }
1674
- ],
1675
- "usage_guide": {
1676
- "port_allocation": {
1677
- "description": "Projects automatically get consistent ports based on their path hash",
1678
- "override": "Set PROJECT_PORT environment variable to override automatic allocation",
1679
- "example": "PROJECT_PORT=3500 npm run dev",
1680
- "benefits": [
1681
- "Same port across sessions",
1682
- "No manual port management",
1683
- "Automatic conflict resolution",
1684
- "Global registry prevents cross-project conflicts"
1685
- ]
1686
- },
1687
- "orphan_detection": {
1688
- "description": "Detect and cleanup orphaned processes from failed or abandoned deployments",
1689
- "severity_levels": {
1690
- "low": "Safe to auto-cleanup (e.g., dead PIDs in state files)",
1691
- "medium": "Needs awareness (e.g., untracked processes)",
1692
- "high": "Requires confirmation (e.g., running PM2/Docker services)"
1693
- },
1694
- "safety_guarantees": [
1695
- "Never touches processes < 1 minute old",
1696
- "Never kills Claude MPM/MCP services (ports 8765-8785)",
1697
- "Never interferes with other projects",
1698
- "Graceful shutdown before force kill",
1699
- "Multiple verification layers"
1700
- ]
1701
- },
1702
- "troubleshooting": {
1703
- "port_conflicts": "If port is in use, allocator will use linear probing to find next available port",
1704
- "environment_override": "Use PROJECT_PORT=XXXX to force specific port (bypasses hash allocation)",
1705
- "orphan_cleanup_failed": "High-severity orphans require explicit confirmation for safety",
1706
- "state_file_corruption": "Delete .claude-mpm/deployment-state.json to reset (will lose tracking)"
1707
- }
1708
- },
1709
- "agent_version": "2.0.1",
1710
- "knowledge": {
1711
- "best_practices": [
1712
- "Review file commit history before modifications: git log --oneline -5 <file_path>",
1713
- "Write succinct commit messages explaining WHAT changed and WHY",
1714
- "Follow conventional commits format: feat/fix/docs/refactor/perf/test/chore"
1715
- ]
1716
- },
1717
- "tool_use_patterns": {
1718
- "framework_detection": {
1719
- "description": "Detect the framework before deployment",
1720
- "workflow": [
1721
- "Check for framework-specific files (Cargo.toml, go.mod, pom.xml, package.json, etc.)",
1722
- "Read configuration files to identify dependencies",
1723
- "Match against detection_patterns to determine framework",
1724
- "Select appropriate deployment strategy based on framework"
1725
- ]
1726
- },
1727
- "deployment_workflow": {
1728
- "description": "Standard deployment workflow for all frameworks",
1729
- "steps": [
1730
- "1. Detect framework using detection_patterns",
1731
- "2. Choose deployment mode (development or production)",
1732
- "3. Install dependencies if needed",
1733
- "4. Build application if production mode",
1734
- "5. Execute local-deploy start command with appropriate flags",
1735
- "6. Configure health check endpoint based on framework",
1736
- "7. Enable auto-restart for production deployments",
1737
- "8. Verify endpoint responds before reporting success",
1738
- "9. Report deployment URL with health status"
1739
- ]
1740
- },
1741
- "health_check_configuration": {
1742
- "description": "Configure health checks based on framework",
1743
- "examples": {
1744
- "fastapi": "claude-mpm local-deploy start --command 'uvicorn main:app --reload' --port 8000 --auto-restart --health-check http://localhost:8000/health",
1745
- "spring_boot": "claude-mpm local-deploy start --command 'mvn spring-boot:run' --port 8080 --auto-restart --health-check http://localhost:8080/actuator/health",
1746
- "gin": "claude-mpm local-deploy start --command './app' --port 8080 --auto-restart --health-check http://localhost:8080/ping",
1747
- "actix": "claude-mpm local-deploy start --command 'cargo run' --port 8080 --auto-restart --health-check http://localhost:8080/health"
1748
- }
1749
- },
1750
- "auto_restart_patterns": {
1751
- "description": "Enable auto-restart for production stability",
1752
- "when_to_use": [
1753
- "Production deployments",
1754
- "Long-running services",
1755
- "APIs with high availability requirements",
1756
- "Services that may encounter transient failures"
1757
- ],
1758
- "configuration": {
1759
- "max_attempts": 5,
1760
- "backoff_strategy": "exponential",
1761
- "circuit_breaker_enabled": true
1762
- }
1763
- },
1764
- "log_monitoring_setup": {
1765
- "description": "Configure log monitoring for automatic issue detection",
1766
- "python_example": "Monitor for: ERROR, CRITICAL, Exception, Traceback",
1767
- "rust_example": "Monitor for: ERROR, FATAL, panic, thread .* panicked",
1768
- "go_example": "Monitor for: ERROR, FATAL, panic:, runtime error",
1769
- "java_example": "Monitor for: ERROR, SEVERE, Exception, OutOfMemoryError"
1770
- },
1771
- "multi_language_support": {
1772
- "description": "Support for multiple programming languages and frameworks",
1773
- "languages": {
1774
- "python": [
1775
- "FastAPI",
1776
- "Django",
1777
- "Flask"
1778
- ],
1779
- "nodejs": [
1780
- "Express",
1781
- "Next.js",
1782
- "NestJS"
1783
- ],
1784
- "rust": [
1785
- "Actix-web",
1786
- "Rocket",
1787
- "Axum"
1788
- ],
1789
- "go": [
1790
- "Gin",
1791
- "Echo",
1792
- "Fiber"
1793
- ],
1794
- "java": [
1795
- "Spring Boot"
1796
- ],
1797
- "ruby": [
1798
- "Rails"
1799
- ],
1800
- "php": [
1801
- "Laravel"
1802
- ],
1803
- "dart": [
1804
- "Flutter Web"
1805
- ]
1806
- },
1807
- "detection_priority": [
1808
- "1. Check for language-specific lock files (Cargo.lock, go.sum, pom.xml)",
1809
- "2. Check for framework-specific config files",
1810
- "3. Check for main entry points (main.rs, main.go, server.js)",
1811
- "4. Read dependencies to identify framework"
1812
- ]
1813
- },
1814
- "troubleshooting_patterns": {
1815
- "port_conflicts": {
1816
- "detection": "EADDRINUSE or 'port already in use'",
1817
- "action": "Use hash-based port allocation with linear probing to find available port",
1818
- "never": "Kill existing process without verification"
1819
- },
1820
- "build_failures": {
1821
- "rust": "Check Cargo.toml dependencies and run 'cargo check'",
1822
- "go": "Check go.mod and run 'go mod tidy'",
1823
- "java": "Check pom.xml or build.gradle and run dependency resolution",
1824
- "nodejs": "Check package.json and run 'npm install'"
1825
- },
1826
- "health_check_failures": {
1827
- "action": "Wait for application startup (up to 30 seconds for Java, 10 seconds for others)",
1828
- "retry": "Retry health check 3 times with backoff",
1829
- "report": "Show startup logs if health check fails"
1830
- }
1831
- }
1832
- },
1833
- "skills": [
1834
- "docker-containerization",
1835
- "database-migration",
1836
- "security-scanning",
1837
- "git-workflow",
1838
- "systematic-debugging"
1839
- ]
1840
- }