claude-mpm 4.24.0__py3-none-any.whl → 5.4.41__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.

Files changed (623) hide show
  1. claude_mpm/VERSION +1 -1
  2. claude_mpm/__init__.py +4 -0
  3. claude_mpm/agents/BASE_AGENT.md +164 -0
  4. claude_mpm/agents/{OUTPUT_STYLE.md → CLAUDE_MPM_OUTPUT_STYLE.md} +3 -48
  5. claude_mpm/agents/CLAUDE_MPM_TEACHER_OUTPUT_STYLE.md +2002 -0
  6. claude_mpm/agents/MEMORY.md +1 -1
  7. claude_mpm/agents/PM_INSTRUCTIONS.md +735 -925
  8. claude_mpm/agents/WORKFLOW.md +5 -254
  9. claude_mpm/agents/__init__.py +6 -0
  10. claude_mpm/agents/agent_loader.py +14 -48
  11. claude_mpm/agents/base_agent.json +7 -4
  12. claude_mpm/agents/frontmatter_validator.py +71 -3
  13. claude_mpm/agents/templates/circuit-breakers.md +1391 -0
  14. claude_mpm/agents/templates/context-management-examples.md +544 -0
  15. claude_mpm/agents/templates/{pm_red_flags.md → pm-red-flags.md} +48 -0
  16. claude_mpm/agents/templates/pr-workflow-examples.md +427 -0
  17. claude_mpm/agents/templates/research-gate-examples.md +669 -0
  18. claude_mpm/agents/templates/structured-questions-examples.md +615 -0
  19. claude_mpm/agents/templates/ticket-completeness-examples.md +139 -0
  20. claude_mpm/agents/templates/ticketing-examples.md +277 -0
  21. claude_mpm/cli/__init__.py +37 -2
  22. claude_mpm/cli/__main__.py +4 -0
  23. claude_mpm/cli/chrome_devtools_installer.py +175 -0
  24. claude_mpm/cli/commands/__init__.py +2 -0
  25. claude_mpm/cli/commands/agent_source.py +774 -0
  26. claude_mpm/cli/commands/agent_state_manager.py +180 -31
  27. claude_mpm/cli/commands/agents.py +1116 -55
  28. claude_mpm/cli/commands/agents_cleanup.py +210 -0
  29. claude_mpm/cli/commands/agents_discover.py +338 -0
  30. claude_mpm/cli/commands/aggregate.py +1 -1
  31. claude_mpm/cli/commands/analyze.py +3 -3
  32. claude_mpm/cli/commands/auto_configure.py +725 -242
  33. claude_mpm/cli/commands/config.py +95 -6
  34. claude_mpm/cli/commands/configure.py +1875 -46
  35. claude_mpm/cli/commands/configure_agent_display.py +29 -10
  36. claude_mpm/cli/commands/configure_navigation.py +63 -46
  37. claude_mpm/cli/commands/debug.py +12 -12
  38. claude_mpm/cli/commands/doctor.py +10 -2
  39. claude_mpm/cli/commands/hook_errors.py +277 -0
  40. claude_mpm/cli/commands/local_deploy.py +1 -4
  41. claude_mpm/cli/commands/mcp_install_commands.py +1 -1
  42. claude_mpm/cli/commands/mpm_init/core.py +229 -2
  43. claude_mpm/cli/commands/mpm_init/git_activity.py +10 -10
  44. claude_mpm/cli/commands/mpm_init/knowledge_extractor.py +481 -0
  45. claude_mpm/cli/commands/mpm_init/prompts.py +286 -6
  46. claude_mpm/cli/commands/postmortem.py +401 -0
  47. claude_mpm/cli/commands/profile.py +277 -0
  48. claude_mpm/cli/commands/run.py +123 -165
  49. claude_mpm/cli/commands/skill_source.py +694 -0
  50. claude_mpm/cli/commands/skills.py +782 -20
  51. claude_mpm/cli/commands/summarize.py +413 -0
  52. claude_mpm/cli/executor.py +96 -3
  53. claude_mpm/cli/interactive/agent_wizard.py +1030 -45
  54. claude_mpm/cli/parsers/agent_source_parser.py +171 -0
  55. claude_mpm/cli/parsers/agents_parser.py +307 -10
  56. claude_mpm/cli/parsers/auto_configure_parser.py +13 -138
  57. claude_mpm/cli/parsers/base_parser.py +65 -0
  58. claude_mpm/cli/parsers/config_parser.py +162 -39
  59. claude_mpm/cli/parsers/profile_parser.py +148 -0
  60. claude_mpm/cli/parsers/skill_source_parser.py +169 -0
  61. claude_mpm/cli/parsers/skills_parser.py +146 -0
  62. claude_mpm/cli/parsers/source_parser.py +138 -0
  63. claude_mpm/cli/startup.py +1280 -118
  64. claude_mpm/cli/startup_display.py +480 -0
  65. claude_mpm/cli/utils.py +1 -1
  66. claude_mpm/cli_module/commands.py +1 -1
  67. claude_mpm/commands/mpm-config.md +21 -134
  68. claude_mpm/commands/mpm-doctor.md +16 -20
  69. claude_mpm/commands/mpm-help.md +13 -283
  70. claude_mpm/commands/mpm-init.md +88 -489
  71. claude_mpm/commands/mpm-monitor.md +23 -401
  72. claude_mpm/commands/mpm-organize.md +72 -247
  73. claude_mpm/commands/mpm-postmortem.md +21 -0
  74. claude_mpm/commands/mpm-session-resume.md +30 -0
  75. claude_mpm/commands/mpm-status.md +13 -68
  76. claude_mpm/commands/mpm-ticket-view.md +109 -0
  77. claude_mpm/commands/mpm-version.md +13 -106
  78. claude_mpm/commands/mpm.md +10 -0
  79. claude_mpm/config/agent_presets.py +488 -0
  80. claude_mpm/config/agent_sources.py +352 -0
  81. claude_mpm/config/skill_presets.py +392 -0
  82. claude_mpm/config/skill_sources.py +590 -0
  83. claude_mpm/constants.py +13 -0
  84. claude_mpm/core/claude_runner.py +5 -34
  85. claude_mpm/core/config.py +15 -1
  86. claude_mpm/core/constants.py +1 -1
  87. claude_mpm/core/framework/__init__.py +3 -16
  88. claude_mpm/core/framework/formatters/content_formatter.py +3 -13
  89. claude_mpm/core/framework/loaders/agent_loader.py +8 -5
  90. claude_mpm/core/framework/loaders/file_loader.py +54 -101
  91. claude_mpm/core/framework/loaders/instruction_loader.py +66 -5
  92. claude_mpm/core/framework_loader.py +4 -2
  93. claude_mpm/core/hook_error_memory.py +381 -0
  94. claude_mpm/core/hook_manager.py +41 -2
  95. claude_mpm/core/interactive_session.py +91 -10
  96. claude_mpm/core/logger.py +16 -1
  97. claude_mpm/core/oneshot_session.py +71 -8
  98. claude_mpm/core/optimized_startup.py +59 -0
  99. claude_mpm/core/output_style_manager.py +173 -43
  100. claude_mpm/core/protocols/__init__.py +23 -0
  101. claude_mpm/core/protocols/runner_protocol.py +103 -0
  102. claude_mpm/core/protocols/session_protocol.py +131 -0
  103. claude_mpm/core/shared/config_loader.py +1 -1
  104. claude_mpm/core/shared/singleton_manager.py +11 -4
  105. claude_mpm/core/socketio_pool.py +3 -3
  106. claude_mpm/core/system_context.py +38 -0
  107. claude_mpm/core/unified_agent_registry.py +134 -16
  108. claude_mpm/core/unified_config.py +22 -0
  109. claude_mpm/dashboard/static/svelte-build/_app/env.js +1 -0
  110. claude_mpm/dashboard/static/svelte-build/_app/immutable/assets/0.B_FtCwCQ.css +1 -0
  111. claude_mpm/dashboard/static/svelte-build/_app/immutable/assets/2.Cl_eSA4x.css +1 -0
  112. claude_mpm/dashboard/static/svelte-build/_app/immutable/chunks/BgChzWQ1.js +1 -0
  113. claude_mpm/dashboard/static/svelte-build/_app/immutable/chunks/CIXEwuWe.js +1 -0
  114. claude_mpm/dashboard/static/svelte-build/_app/immutable/chunks/CWc5urbQ.js +1 -0
  115. claude_mpm/dashboard/static/svelte-build/_app/immutable/chunks/DMkZpdF2.js +2 -0
  116. claude_mpm/dashboard/static/svelte-build/_app/immutable/chunks/DjhvlsAc.js +1 -0
  117. claude_mpm/dashboard/static/svelte-build/_app/immutable/chunks/N4qtv3Hx.js +2 -0
  118. claude_mpm/dashboard/static/svelte-build/_app/immutable/chunks/uj46x2Wr.js +1 -0
  119. claude_mpm/dashboard/static/svelte-build/_app/immutable/entry/app.DTL5mJO-.js +2 -0
  120. claude_mpm/dashboard/static/svelte-build/_app/immutable/entry/start.DzuEhzqh.js +1 -0
  121. claude_mpm/dashboard/static/svelte-build/_app/immutable/nodes/0.CAGBuiOw.js +1 -0
  122. claude_mpm/dashboard/static/svelte-build/_app/immutable/nodes/1.DFLC8jdE.js +1 -0
  123. claude_mpm/dashboard/static/svelte-build/_app/immutable/nodes/2.DPvEihJJ.js +10 -0
  124. claude_mpm/dashboard/static/svelte-build/_app/version.json +1 -0
  125. claude_mpm/dashboard/static/svelte-build/favicon.svg +7 -0
  126. claude_mpm/dashboard/static/svelte-build/index.html +36 -0
  127. claude_mpm/experimental/cli_enhancements.py +1 -5
  128. claude_mpm/hooks/claude_hooks/__pycache__/__init__.cpython-311.pyc +0 -0
  129. claude_mpm/hooks/claude_hooks/__pycache__/correlation_manager.cpython-311.pyc +0 -0
  130. claude_mpm/hooks/claude_hooks/__pycache__/event_handlers.cpython-311.pyc +0 -0
  131. claude_mpm/hooks/claude_hooks/__pycache__/hook_handler.cpython-311.pyc +0 -0
  132. claude_mpm/hooks/claude_hooks/__pycache__/installer.cpython-311.pyc +0 -0
  133. claude_mpm/hooks/claude_hooks/__pycache__/memory_integration.cpython-311.pyc +0 -0
  134. claude_mpm/hooks/claude_hooks/__pycache__/response_tracking.cpython-311.pyc +0 -0
  135. claude_mpm/hooks/claude_hooks/__pycache__/tool_analysis.cpython-311.pyc +0 -0
  136. claude_mpm/hooks/claude_hooks/correlation_manager.py +60 -0
  137. claude_mpm/hooks/claude_hooks/event_handlers.py +214 -79
  138. claude_mpm/hooks/claude_hooks/hook_handler.py +155 -1
  139. claude_mpm/hooks/claude_hooks/installer.py +33 -10
  140. claude_mpm/hooks/claude_hooks/memory_integration.py +28 -0
  141. claude_mpm/hooks/claude_hooks/response_tracking.py +2 -3
  142. claude_mpm/hooks/claude_hooks/services/__pycache__/__init__.cpython-311.pyc +0 -0
  143. claude_mpm/hooks/claude_hooks/services/__pycache__/connection_manager.cpython-311.pyc +0 -0
  144. claude_mpm/hooks/claude_hooks/services/__pycache__/connection_manager_http.cpython-311.pyc +0 -0
  145. claude_mpm/hooks/claude_hooks/services/__pycache__/duplicate_detector.cpython-311.pyc +0 -0
  146. claude_mpm/hooks/claude_hooks/services/__pycache__/state_manager.cpython-311.pyc +0 -0
  147. claude_mpm/hooks/claude_hooks/services/__pycache__/subagent_processor.cpython-311.pyc +0 -0
  148. claude_mpm/hooks/claude_hooks/services/connection_manager.py +30 -6
  149. claude_mpm/hooks/failure_learning/__init__.py +2 -8
  150. claude_mpm/hooks/failure_learning/failure_detection_hook.py +1 -6
  151. claude_mpm/hooks/failure_learning/fix_detection_hook.py +1 -6
  152. claude_mpm/hooks/failure_learning/learning_extraction_hook.py +1 -6
  153. claude_mpm/hooks/kuzu_response_hook.py +1 -5
  154. claude_mpm/hooks/memory_integration_hook.py +46 -1
  155. claude_mpm/init.py +63 -19
  156. claude_mpm/models/agent_definition.py +7 -0
  157. claude_mpm/models/git_repository.py +198 -0
  158. claude_mpm/scripts/claude-hook-handler.sh +60 -20
  159. claude_mpm/scripts/launch_monitor.py +93 -13
  160. claude_mpm/scripts/start_activity_logging.py +3 -1
  161. claude_mpm/services/agents/agent_builder.py +48 -12
  162. claude_mpm/services/agents/agent_preset_service.py +238 -0
  163. claude_mpm/services/agents/agent_recommendation_service.py +278 -0
  164. claude_mpm/services/agents/agent_review_service.py +280 -0
  165. claude_mpm/services/agents/agent_selection_service.py +484 -0
  166. claude_mpm/services/agents/auto_deploy_index_parser.py +569 -0
  167. claude_mpm/services/agents/cache_git_manager.py +621 -0
  168. claude_mpm/services/agents/deployment/agent_deployment.py +148 -2
  169. claude_mpm/services/agents/deployment/agent_discovery_service.py +104 -73
  170. claude_mpm/services/agents/deployment/agent_format_converter.py +1 -1
  171. claude_mpm/services/agents/deployment/agent_lifecycle_manager.py +1 -5
  172. claude_mpm/services/agents/deployment/agent_metrics_collector.py +3 -3
  173. claude_mpm/services/agents/deployment/agent_restore_handler.py +1 -4
  174. claude_mpm/services/agents/deployment/agent_template_builder.py +238 -15
  175. claude_mpm/services/agents/deployment/agents_directory_resolver.py +101 -15
  176. claude_mpm/services/agents/deployment/async_agent_deployment.py +2 -1
  177. claude_mpm/services/agents/deployment/facade/deployment_facade.py +3 -3
  178. claude_mpm/services/agents/deployment/multi_source_deployment_service.py +422 -31
  179. claude_mpm/services/agents/deployment/pipeline/pipeline_executor.py +2 -2
  180. claude_mpm/services/agents/deployment/refactored_agent_deployment_service.py +1 -4
  181. claude_mpm/services/agents/deployment/remote_agent_discovery_service.py +841 -0
  182. claude_mpm/services/agents/deployment/single_agent_deployer.py +2 -2
  183. claude_mpm/services/agents/deployment/system_instructions_deployer.py +168 -46
  184. claude_mpm/services/agents/deployment/validation/deployment_validator.py +2 -2
  185. claude_mpm/services/agents/git_source_manager.py +663 -0
  186. claude_mpm/services/agents/loading/base_agent_manager.py +1 -13
  187. claude_mpm/services/agents/loading/framework_agent_loader.py +9 -12
  188. claude_mpm/services/agents/local_template_manager.py +50 -10
  189. claude_mpm/services/agents/recommender.py +5 -3
  190. claude_mpm/services/agents/single_tier_deployment_service.py +696 -0
  191. claude_mpm/services/agents/sources/__init__.py +13 -0
  192. claude_mpm/services/agents/sources/agent_sync_state.py +516 -0
  193. claude_mpm/services/agents/sources/git_source_sync_service.py +1094 -0
  194. claude_mpm/services/agents/startup_sync.py +259 -0
  195. claude_mpm/services/agents/toolchain_detector.py +478 -0
  196. claude_mpm/services/analysis/__init__.py +35 -0
  197. claude_mpm/services/analysis/clone_detector.py +1030 -0
  198. claude_mpm/services/analysis/postmortem_reporter.py +474 -0
  199. claude_mpm/services/analysis/postmortem_service.py +765 -0
  200. claude_mpm/services/cli/session_pause_manager.py +1 -1
  201. claude_mpm/services/command_deployment_service.py +271 -6
  202. claude_mpm/services/core/base.py +7 -2
  203. claude_mpm/services/core/interfaces/__init__.py +1 -3
  204. claude_mpm/services/core/interfaces/health.py +1 -4
  205. claude_mpm/services/core/models/__init__.py +2 -11
  206. claude_mpm/services/diagnostics/checks/__init__.py +4 -0
  207. claude_mpm/services/diagnostics/checks/agent_check.py +2 -4
  208. claude_mpm/services/diagnostics/checks/agent_sources_check.py +577 -0
  209. claude_mpm/services/diagnostics/checks/instructions_check.py +1 -2
  210. claude_mpm/services/diagnostics/checks/mcp_check.py +0 -1
  211. claude_mpm/services/diagnostics/checks/mcp_services_check.py +7 -15
  212. claude_mpm/services/diagnostics/checks/monitor_check.py +0 -1
  213. claude_mpm/services/diagnostics/checks/skill_sources_check.py +587 -0
  214. claude_mpm/services/diagnostics/diagnostic_runner.py +9 -0
  215. claude_mpm/services/diagnostics/doctor_reporter.py +40 -10
  216. claude_mpm/services/event_bus/config.py +3 -1
  217. claude_mpm/services/event_bus/direct_relay.py +3 -3
  218. claude_mpm/services/events/consumers/logging.py +1 -2
  219. claude_mpm/services/git/__init__.py +21 -0
  220. claude_mpm/services/git/git_operations_service.py +579 -0
  221. claude_mpm/services/github/__init__.py +21 -0
  222. claude_mpm/services/github/github_cli_service.py +397 -0
  223. claude_mpm/services/infrastructure/monitoring/__init__.py +1 -5
  224. claude_mpm/services/infrastructure/monitoring/aggregator.py +1 -6
  225. claude_mpm/services/instructions/__init__.py +9 -0
  226. claude_mpm/services/instructions/instruction_cache_service.py +374 -0
  227. claude_mpm/services/local_ops/__init__.py +3 -13
  228. claude_mpm/services/local_ops/health_checks/__init__.py +1 -3
  229. claude_mpm/services/local_ops/health_manager.py +1 -4
  230. claude_mpm/services/local_ops/resource_monitor.py +1 -1
  231. claude_mpm/services/mcp_config_manager.py +75 -145
  232. claude_mpm/services/mcp_service_verifier.py +6 -3
  233. claude_mpm/services/model/model_router.py +1 -2
  234. claude_mpm/services/monitor/daemon.py +38 -11
  235. claude_mpm/services/monitor/daemon_manager.py +134 -21
  236. claude_mpm/services/monitor/management/lifecycle.py +8 -1
  237. claude_mpm/services/monitor/server.py +700 -24
  238. claude_mpm/services/pm_skills_deployer.py +676 -0
  239. claude_mpm/services/port_manager.py +1 -1
  240. claude_mpm/services/pr/__init__.py +14 -0
  241. claude_mpm/services/pr/pr_template_service.py +329 -0
  242. claude_mpm/services/profile_manager.py +331 -0
  243. claude_mpm/services/project/documentation_manager.py +2 -1
  244. claude_mpm/services/project/project_organizer.py +4 -0
  245. claude_mpm/services/project/toolchain_analyzer.py +3 -1
  246. claude_mpm/services/runner_configuration_service.py +16 -3
  247. claude_mpm/services/self_upgrade_service.py +120 -12
  248. claude_mpm/services/session_management_service.py +16 -4
  249. claude_mpm/services/skills/__init__.py +21 -0
  250. claude_mpm/services/skills/git_skill_source_manager.py +1297 -0
  251. claude_mpm/services/skills/selective_skill_deployer.py +704 -0
  252. claude_mpm/services/skills/skill_discovery_service.py +568 -0
  253. claude_mpm/services/skills/skill_to_agent_mapper.py +406 -0
  254. claude_mpm/services/skills_config.py +547 -0
  255. claude_mpm/services/skills_deployer.py +1072 -0
  256. claude_mpm/services/socketio/dashboard_server.py +1 -0
  257. claude_mpm/services/socketio/event_normalizer.py +51 -6
  258. claude_mpm/services/socketio/handlers/connection.py +1 -1
  259. claude_mpm/services/socketio/handlers/git.py +1 -1
  260. claude_mpm/services/socketio/server/core.py +387 -112
  261. claude_mpm/services/socketio/server/main.py +1 -3
  262. claude_mpm/services/system_instructions_service.py +1 -3
  263. claude_mpm/services/unified/analyzer_strategies/performance_analyzer.py +0 -3
  264. claude_mpm/services/unified/analyzer_strategies/security_analyzer.py +0 -1
  265. claude_mpm/services/unified/deployment_strategies/vercel.py +1 -5
  266. claude_mpm/services/unified/unified_deployment.py +1 -5
  267. claude_mpm/services/version_control/conflict_resolution.py +6 -4
  268. claude_mpm/services/version_control/git_operations.py +103 -0
  269. claude_mpm/services/visualization/__init__.py +1 -5
  270. claude_mpm/services/visualization/mermaid_generator.py +2 -3
  271. claude_mpm/skills/bundled/testing/webapp-testing/scripts/with_server.py +2 -2
  272. claude_mpm/skills/skill_manager.py +92 -3
  273. claude_mpm/skills/skills_registry.py +0 -1
  274. claude_mpm/templates/questions/__init__.py +38 -0
  275. claude_mpm/templates/questions/base.py +193 -0
  276. claude_mpm/templates/questions/pr_strategy.py +311 -0
  277. claude_mpm/templates/questions/project_init.py +385 -0
  278. claude_mpm/templates/questions/ticket_mgmt.py +394 -0
  279. claude_mpm/tools/__main__.py +8 -8
  280. claude_mpm/utils/agent_dependency_loader.py +91 -12
  281. claude_mpm/utils/agent_filters.py +261 -0
  282. claude_mpm/utils/dependency_cache.py +3 -1
  283. claude_mpm/utils/gitignore.py +244 -0
  284. claude_mpm/utils/migration.py +372 -0
  285. claude_mpm/utils/progress.py +387 -0
  286. claude_mpm/utils/robust_installer.py +49 -7
  287. claude_mpm/utils/structured_questions.py +619 -0
  288. {claude_mpm-4.24.0.dist-info → claude_mpm-5.4.41.dist-info}/METADATA +445 -122
  289. {claude_mpm-4.24.0.dist-info → claude_mpm-5.4.41.dist-info}/RECORD +298 -503
  290. claude_mpm-5.4.41.dist-info/entry_points.txt +5 -0
  291. claude_mpm-5.4.41.dist-info/licenses/LICENSE +94 -0
  292. claude_mpm-5.4.41.dist-info/licenses/LICENSE-FAQ.md +153 -0
  293. claude_mpm/agents/BASE_AGENT_TEMPLATE.md +0 -292
  294. claude_mpm/agents/BASE_DOCUMENTATION.md +0 -53
  295. claude_mpm/agents/BASE_OPS.md +0 -219
  296. claude_mpm/agents/BASE_PM.md +0 -468
  297. claude_mpm/agents/BASE_PROMPT_ENGINEER.md +0 -787
  298. claude_mpm/agents/BASE_QA.md +0 -167
  299. claude_mpm/agents/BASE_RESEARCH.md +0 -53
  300. claude_mpm/agents/base_agent_loader.py +0 -626
  301. claude_mpm/agents/templates/.claude-mpm/memories/README.md +0 -17
  302. claude_mpm/agents/templates/.claude-mpm/memories/engineer_memories.md +0 -3
  303. claude_mpm/agents/templates/agent-manager.json +0 -273
  304. claude_mpm/agents/templates/agentic-coder-optimizer.json +0 -248
  305. claude_mpm/agents/templates/api_qa.json +0 -183
  306. claude_mpm/agents/templates/circuit_breakers.md +0 -638
  307. claude_mpm/agents/templates/clerk-ops.json +0 -235
  308. claude_mpm/agents/templates/code_analyzer.json +0 -101
  309. claude_mpm/agents/templates/content-agent.json +0 -358
  310. claude_mpm/agents/templates/dart_engineer.json +0 -307
  311. claude_mpm/agents/templates/data_engineer.json +0 -225
  312. claude_mpm/agents/templates/documentation.json +0 -238
  313. claude_mpm/agents/templates/engineer.json +0 -210
  314. claude_mpm/agents/templates/gcp_ops_agent.json +0 -253
  315. claude_mpm/agents/templates/golang_engineer.json +0 -270
  316. claude_mpm/agents/templates/imagemagick.json +0 -264
  317. claude_mpm/agents/templates/java_engineer.json +0 -346
  318. claude_mpm/agents/templates/javascript_engineer_agent.json +0 -380
  319. claude_mpm/agents/templates/local_ops_agent.json +0 -1840
  320. claude_mpm/agents/templates/logs/prompts/agent_engineer_20250826_014258_728.md +0 -39
  321. claude_mpm/agents/templates/logs/prompts/agent_engineer_20250901_010124_142.md +0 -400
  322. claude_mpm/agents/templates/memory_manager.json +0 -158
  323. claude_mpm/agents/templates/nextjs_engineer.json +0 -285
  324. claude_mpm/agents/templates/ops.json +0 -185
  325. claude_mpm/agents/templates/php-engineer.json +0 -287
  326. claude_mpm/agents/templates/product_owner.json +0 -338
  327. claude_mpm/agents/templates/project_organizer.json +0 -144
  328. claude_mpm/agents/templates/prompt-engineer.json +0 -737
  329. claude_mpm/agents/templates/python_engineer.json +0 -387
  330. claude_mpm/agents/templates/qa.json +0 -243
  331. claude_mpm/agents/templates/react_engineer.json +0 -239
  332. claude_mpm/agents/templates/refactoring_engineer.json +0 -276
  333. claude_mpm/agents/templates/research.json +0 -188
  334. claude_mpm/agents/templates/ruby-engineer.json +0 -280
  335. claude_mpm/agents/templates/rust_engineer.json +0 -275
  336. claude_mpm/agents/templates/security.json +0 -202
  337. claude_mpm/agents/templates/svelte-engineer.json +0 -225
  338. claude_mpm/agents/templates/tauri_engineer.json +0 -274
  339. claude_mpm/agents/templates/ticketing.json +0 -178
  340. claude_mpm/agents/templates/typescript_engineer.json +0 -285
  341. claude_mpm/agents/templates/vercel_ops_agent.json +0 -412
  342. claude_mpm/agents/templates/version_control.json +0 -159
  343. claude_mpm/agents/templates/web_qa.json +0 -400
  344. claude_mpm/agents/templates/web_ui.json +0 -189
  345. claude_mpm/cli/commands/agents_detect.py +0 -380
  346. claude_mpm/cli/commands/agents_recommend.py +0 -309
  347. claude_mpm/cli/ticket_cli.py +0 -35
  348. claude_mpm/commands/mpm-agents-detect.md +0 -168
  349. claude_mpm/commands/mpm-agents-recommend.md +0 -214
  350. claude_mpm/commands/mpm-agents.md +0 -122
  351. claude_mpm/commands/mpm-auto-configure.md +0 -269
  352. claude_mpm/commands/mpm-resume.md +0 -372
  353. claude_mpm/commands/mpm-tickets.md +0 -151
  354. claude_mpm/dashboard/.claude-mpm/socketio-instances.json +0 -1
  355. claude_mpm/dashboard/analysis_runner.py +0 -455
  356. claude_mpm/dashboard/index.html +0 -13
  357. claude_mpm/dashboard/open_dashboard.py +0 -66
  358. claude_mpm/dashboard/react/components/DataInspector/DataInspector.module.css +0 -188
  359. claude_mpm/dashboard/react/components/EventViewer/EventViewer.module.css +0 -156
  360. claude_mpm/dashboard/react/components/shared/ConnectionStatus.module.css +0 -38
  361. claude_mpm/dashboard/react/components/shared/FilterBar.module.css +0 -92
  362. claude_mpm/dashboard/static/archive/activity_dashboard_fixed.html +0 -248
  363. claude_mpm/dashboard/static/archive/activity_dashboard_test.html +0 -61
  364. claude_mpm/dashboard/static/archive/test_activity_connection.html +0 -179
  365. claude_mpm/dashboard/static/archive/test_claude_tree_tab.html +0 -68
  366. claude_mpm/dashboard/static/archive/test_dashboard.html +0 -409
  367. claude_mpm/dashboard/static/archive/test_dashboard_fixed.html +0 -519
  368. claude_mpm/dashboard/static/archive/test_dashboard_verification.html +0 -181
  369. claude_mpm/dashboard/static/archive/test_file_data.html +0 -315
  370. claude_mpm/dashboard/static/archive/test_file_tree_empty_state.html +0 -243
  371. claude_mpm/dashboard/static/archive/test_file_tree_fix.html +0 -234
  372. claude_mpm/dashboard/static/archive/test_file_tree_rename.html +0 -117
  373. claude_mpm/dashboard/static/archive/test_file_tree_tab.html +0 -115
  374. claude_mpm/dashboard/static/archive/test_file_viewer.html +0 -224
  375. claude_mpm/dashboard/static/archive/test_final_activity.html +0 -220
  376. claude_mpm/dashboard/static/archive/test_tab_fix.html +0 -139
  377. claude_mpm/dashboard/static/built/assets/events.DjpNxWNo.css +0 -1
  378. claude_mpm/dashboard/static/built/components/activity-tree.js +0 -2
  379. claude_mpm/dashboard/static/built/components/agent-hierarchy.js +0 -777
  380. claude_mpm/dashboard/static/built/components/agent-inference.js +0 -2
  381. claude_mpm/dashboard/static/built/components/build-tracker.js +0 -333
  382. claude_mpm/dashboard/static/built/components/code-simple.js +0 -857
  383. claude_mpm/dashboard/static/built/components/code-tree/tree-breadcrumb.js +0 -353
  384. claude_mpm/dashboard/static/built/components/code-tree/tree-constants.js +0 -235
  385. claude_mpm/dashboard/static/built/components/code-tree/tree-search.js +0 -409
  386. claude_mpm/dashboard/static/built/components/code-tree/tree-utils.js +0 -435
  387. claude_mpm/dashboard/static/built/components/code-tree.js +0 -2
  388. claude_mpm/dashboard/static/built/components/code-viewer.js +0 -2
  389. claude_mpm/dashboard/static/built/components/connection-debug.js +0 -654
  390. claude_mpm/dashboard/static/built/components/diff-viewer.js +0 -891
  391. claude_mpm/dashboard/static/built/components/event-processor.js +0 -2
  392. claude_mpm/dashboard/static/built/components/event-viewer.js +0 -2
  393. claude_mpm/dashboard/static/built/components/export-manager.js +0 -2
  394. claude_mpm/dashboard/static/built/components/file-change-tracker.js +0 -443
  395. claude_mpm/dashboard/static/built/components/file-change-viewer.js +0 -690
  396. claude_mpm/dashboard/static/built/components/file-tool-tracker.js +0 -2
  397. claude_mpm/dashboard/static/built/components/file-viewer.js +0 -2
  398. claude_mpm/dashboard/static/built/components/hud-library-loader.js +0 -2
  399. claude_mpm/dashboard/static/built/components/hud-manager.js +0 -2
  400. claude_mpm/dashboard/static/built/components/hud-visualizer.js +0 -2
  401. claude_mpm/dashboard/static/built/components/module-viewer.js +0 -2
  402. claude_mpm/dashboard/static/built/components/nav-bar.js +0 -145
  403. claude_mpm/dashboard/static/built/components/page-structure.js +0 -429
  404. claude_mpm/dashboard/static/built/components/session-manager.js +0 -2
  405. claude_mpm/dashboard/static/built/components/socket-manager.js +0 -2
  406. claude_mpm/dashboard/static/built/components/ui-state-manager.js +0 -2
  407. claude_mpm/dashboard/static/built/components/unified-data-viewer.js +0 -2
  408. claude_mpm/dashboard/static/built/components/working-directory.js +0 -2
  409. claude_mpm/dashboard/static/built/connection-manager.js +0 -536
  410. claude_mpm/dashboard/static/built/dashboard.js +0 -2
  411. claude_mpm/dashboard/static/built/extension-error-handler.js +0 -164
  412. claude_mpm/dashboard/static/built/react/events.js +0 -30
  413. claude_mpm/dashboard/static/built/shared/dom-helpers.js +0 -396
  414. claude_mpm/dashboard/static/built/shared/event-bus.js +0 -330
  415. claude_mpm/dashboard/static/built/shared/event-filter-service.js +0 -540
  416. claude_mpm/dashboard/static/built/shared/logger.js +0 -385
  417. claude_mpm/dashboard/static/built/shared/page-structure.js +0 -249
  418. claude_mpm/dashboard/static/built/shared/tooltip-service.js +0 -253
  419. claude_mpm/dashboard/static/built/socket-client.js +0 -2
  420. claude_mpm/dashboard/static/built/tab-isolation-fix.js +0 -185
  421. claude_mpm/dashboard/static/css/activity.css +0 -1958
  422. claude_mpm/dashboard/static/css/connection-status.css +0 -370
  423. claude_mpm/dashboard/static/css/dashboard.css +0 -4701
  424. claude_mpm/dashboard/static/dist/assets/events.DjpNxWNo.css +0 -1
  425. claude_mpm/dashboard/static/dist/components/activity-tree.js +0 -2
  426. claude_mpm/dashboard/static/dist/components/agent-inference.js +0 -2
  427. claude_mpm/dashboard/static/dist/components/code-tree.js +0 -2
  428. claude_mpm/dashboard/static/dist/components/code-viewer.js +0 -2
  429. claude_mpm/dashboard/static/dist/components/event-processor.js +0 -2
  430. claude_mpm/dashboard/static/dist/components/event-viewer.js +0 -2
  431. claude_mpm/dashboard/static/dist/components/export-manager.js +0 -2
  432. claude_mpm/dashboard/static/dist/components/file-tool-tracker.js +0 -2
  433. claude_mpm/dashboard/static/dist/components/file-viewer.js +0 -2
  434. claude_mpm/dashboard/static/dist/components/hud-library-loader.js +0 -2
  435. claude_mpm/dashboard/static/dist/components/hud-manager.js +0 -2
  436. claude_mpm/dashboard/static/dist/components/hud-visualizer.js +0 -2
  437. claude_mpm/dashboard/static/dist/components/module-viewer.js +0 -2
  438. claude_mpm/dashboard/static/dist/components/session-manager.js +0 -2
  439. claude_mpm/dashboard/static/dist/components/socket-manager.js +0 -2
  440. claude_mpm/dashboard/static/dist/components/ui-state-manager.js +0 -2
  441. claude_mpm/dashboard/static/dist/components/unified-data-viewer.js +0 -2
  442. claude_mpm/dashboard/static/dist/components/working-directory.js +0 -2
  443. claude_mpm/dashboard/static/dist/dashboard.js +0 -2
  444. claude_mpm/dashboard/static/dist/react/events.js +0 -30
  445. claude_mpm/dashboard/static/dist/socket-client.js +0 -2
  446. claude_mpm/dashboard/static/events.html +0 -607
  447. claude_mpm/dashboard/static/index.html +0 -635
  448. claude_mpm/dashboard/static/js/components/activity-tree.js +0 -1871
  449. claude_mpm/dashboard/static/js/components/agent-hierarchy.js +0 -777
  450. claude_mpm/dashboard/static/js/components/agent-inference.js +0 -956
  451. claude_mpm/dashboard/static/js/components/build-tracker.js +0 -333
  452. claude_mpm/dashboard/static/js/components/code-simple.js +0 -857
  453. claude_mpm/dashboard/static/js/components/connection-debug.js +0 -654
  454. claude_mpm/dashboard/static/js/components/diff-viewer.js +0 -891
  455. claude_mpm/dashboard/static/js/components/event-processor.js +0 -542
  456. claude_mpm/dashboard/static/js/components/event-viewer.js +0 -1155
  457. claude_mpm/dashboard/static/js/components/export-manager.js +0 -368
  458. claude_mpm/dashboard/static/js/components/file-change-tracker.js +0 -443
  459. claude_mpm/dashboard/static/js/components/file-change-viewer.js +0 -690
  460. claude_mpm/dashboard/static/js/components/file-tool-tracker.js +0 -724
  461. claude_mpm/dashboard/static/js/components/file-viewer.js +0 -580
  462. claude_mpm/dashboard/static/js/components/hud-library-loader.js +0 -211
  463. claude_mpm/dashboard/static/js/components/hud-manager.js +0 -671
  464. claude_mpm/dashboard/static/js/components/hud-visualizer.js +0 -1718
  465. claude_mpm/dashboard/static/js/components/module-viewer.js +0 -2764
  466. claude_mpm/dashboard/static/js/components/session-manager.js +0 -579
  467. claude_mpm/dashboard/static/js/components/socket-manager.js +0 -368
  468. claude_mpm/dashboard/static/js/components/ui-state-manager.js +0 -749
  469. claude_mpm/dashboard/static/js/components/unified-data-viewer.js +0 -1824
  470. claude_mpm/dashboard/static/js/components/working-directory.js +0 -920
  471. claude_mpm/dashboard/static/js/connection-manager.js +0 -536
  472. claude_mpm/dashboard/static/js/dashboard.js +0 -1896
  473. claude_mpm/dashboard/static/js/extension-error-handler.js +0 -164
  474. claude_mpm/dashboard/static/js/shared/dom-helpers.js +0 -396
  475. claude_mpm/dashboard/static/js/shared/event-bus.js +0 -330
  476. claude_mpm/dashboard/static/js/shared/logger.js +0 -385
  477. claude_mpm/dashboard/static/js/shared/tooltip-service.js +0 -253
  478. claude_mpm/dashboard/static/js/socket-client.js +0 -1457
  479. claude_mpm/dashboard/static/js/stores/dashboard-store.js +0 -562
  480. claude_mpm/dashboard/static/js/tab-isolation-fix.js +0 -185
  481. claude_mpm/dashboard/static/legacy/activity.html +0 -736
  482. claude_mpm/dashboard/static/legacy/agents.html +0 -786
  483. claude_mpm/dashboard/static/legacy/files.html +0 -747
  484. claude_mpm/dashboard/static/legacy/tools.html +0 -831
  485. claude_mpm/dashboard/static/monitors.html +0 -431
  486. claude_mpm/dashboard/static/production/events.html +0 -659
  487. claude_mpm/dashboard/static/production/main.html +0 -698
  488. claude_mpm/dashboard/static/production/monitors.html +0 -483
  489. claude_mpm/dashboard/static/socket.io.min.js +0 -7
  490. claude_mpm/dashboard/static/socket.io.v4.8.1.backup.js +0 -7
  491. claude_mpm/dashboard/static/test-archive/dashboard.html +0 -635
  492. claude_mpm/dashboard/static/test-archive/debug-events.html +0 -147
  493. claude_mpm/dashboard/static/test-archive/test-navigation.html +0 -256
  494. claude_mpm/dashboard/static/test-archive/test-react-exports.html +0 -180
  495. claude_mpm/dashboard/static/test-archive/test_debug.html +0 -25
  496. claude_mpm/dashboard/templates/code_simple.html +0 -153
  497. claude_mpm/dashboard/templates/index.html +0 -606
  498. claude_mpm/dashboard/test_dashboard.html +0 -372
  499. claude_mpm/scripts/mcp_server.py +0 -75
  500. claude_mpm/scripts/mcp_wrapper.py +0 -39
  501. claude_mpm/services/mcp_gateway/__init__.py +0 -159
  502. claude_mpm/services/mcp_gateway/auto_configure.py +0 -369
  503. claude_mpm/services/mcp_gateway/config/__init__.py +0 -17
  504. claude_mpm/services/mcp_gateway/config/config_loader.py +0 -296
  505. claude_mpm/services/mcp_gateway/config/config_schema.py +0 -243
  506. claude_mpm/services/mcp_gateway/config/configuration.py +0 -429
  507. claude_mpm/services/mcp_gateway/core/__init__.py +0 -43
  508. claude_mpm/services/mcp_gateway/core/base.py +0 -312
  509. claude_mpm/services/mcp_gateway/core/exceptions.py +0 -253
  510. claude_mpm/services/mcp_gateway/core/interfaces.py +0 -443
  511. claude_mpm/services/mcp_gateway/core/process_pool.py +0 -971
  512. claude_mpm/services/mcp_gateway/core/singleton_manager.py +0 -315
  513. claude_mpm/services/mcp_gateway/core/startup_verification.py +0 -316
  514. claude_mpm/services/mcp_gateway/main.py +0 -589
  515. claude_mpm/services/mcp_gateway/registry/__init__.py +0 -12
  516. claude_mpm/services/mcp_gateway/registry/service_registry.py +0 -412
  517. claude_mpm/services/mcp_gateway/registry/tool_registry.py +0 -489
  518. claude_mpm/services/mcp_gateway/server/__init__.py +0 -15
  519. claude_mpm/services/mcp_gateway/server/mcp_gateway.py +0 -419
  520. claude_mpm/services/mcp_gateway/server/stdio_handler.py +0 -372
  521. claude_mpm/services/mcp_gateway/server/stdio_server.py +0 -714
  522. claude_mpm/services/mcp_gateway/tools/__init__.py +0 -36
  523. claude_mpm/services/mcp_gateway/tools/base_adapter.py +0 -485
  524. claude_mpm/services/mcp_gateway/tools/document_summarizer.py +0 -789
  525. claude_mpm/services/mcp_gateway/tools/external_mcp_services.py +0 -654
  526. claude_mpm/services/mcp_gateway/tools/health_check_tool.py +0 -456
  527. claude_mpm/services/mcp_gateway/tools/hello_world.py +0 -551
  528. claude_mpm/services/mcp_gateway/tools/kuzu_memory_service.py +0 -551
  529. claude_mpm/services/mcp_gateway/utils/__init__.py +0 -14
  530. claude_mpm/services/mcp_gateway/utils/package_version_checker.py +0 -160
  531. claude_mpm/services/mcp_gateway/utils/update_preferences.py +0 -170
  532. claude_mpm/skills/bundled/collaboration/brainstorming/SKILL.md +0 -79
  533. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/SKILL.md +0 -178
  534. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/agent-prompts.md +0 -577
  535. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/coordination-patterns.md +0 -467
  536. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/examples.md +0 -537
  537. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/troubleshooting.md +0 -730
  538. claude_mpm/skills/bundled/collaboration/requesting-code-review/SKILL.md +0 -112
  539. claude_mpm/skills/bundled/collaboration/requesting-code-review/references/code-reviewer-template.md +0 -146
  540. claude_mpm/skills/bundled/collaboration/requesting-code-review/references/review-examples.md +0 -412
  541. claude_mpm/skills/bundled/collaboration/writing-plans/SKILL.md +0 -81
  542. claude_mpm/skills/bundled/collaboration/writing-plans/references/best-practices.md +0 -362
  543. claude_mpm/skills/bundled/collaboration/writing-plans/references/plan-structure-templates.md +0 -312
  544. claude_mpm/skills/bundled/debugging/root-cause-tracing/SKILL.md +0 -152
  545. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/advanced-techniques.md +0 -668
  546. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/examples.md +0 -587
  547. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/integration.md +0 -438
  548. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/tracing-techniques.md +0 -391
  549. claude_mpm/skills/bundled/debugging/systematic-debugging/CREATION-LOG.md +0 -119
  550. claude_mpm/skills/bundled/debugging/systematic-debugging/SKILL.md +0 -148
  551. claude_mpm/skills/bundled/debugging/systematic-debugging/references/anti-patterns.md +0 -483
  552. claude_mpm/skills/bundled/debugging/systematic-debugging/references/examples.md +0 -452
  553. claude_mpm/skills/bundled/debugging/systematic-debugging/references/troubleshooting.md +0 -449
  554. claude_mpm/skills/bundled/debugging/systematic-debugging/references/workflow.md +0 -411
  555. claude_mpm/skills/bundled/debugging/systematic-debugging/test-academic.md +0 -14
  556. claude_mpm/skills/bundled/debugging/systematic-debugging/test-pressure-1.md +0 -58
  557. claude_mpm/skills/bundled/debugging/systematic-debugging/test-pressure-2.md +0 -68
  558. claude_mpm/skills/bundled/debugging/systematic-debugging/test-pressure-3.md +0 -69
  559. claude_mpm/skills/bundled/debugging/verification-before-completion/SKILL.md +0 -131
  560. claude_mpm/skills/bundled/debugging/verification-before-completion/references/gate-function.md +0 -325
  561. claude_mpm/skills/bundled/debugging/verification-before-completion/references/integration-and-workflows.md +0 -490
  562. claude_mpm/skills/bundled/debugging/verification-before-completion/references/red-flags-and-failures.md +0 -425
  563. claude_mpm/skills/bundled/debugging/verification-before-completion/references/verification-patterns.md +0 -499
  564. claude_mpm/skills/bundled/main/artifacts-builder/SKILL.md +0 -86
  565. claude_mpm/skills/bundled/main/internal-comms/SKILL.md +0 -43
  566. claude_mpm/skills/bundled/main/internal-comms/examples/3p-updates.md +0 -47
  567. claude_mpm/skills/bundled/main/internal-comms/examples/company-newsletter.md +0 -65
  568. claude_mpm/skills/bundled/main/internal-comms/examples/faq-answers.md +0 -30
  569. claude_mpm/skills/bundled/main/internal-comms/examples/general-comms.md +0 -16
  570. claude_mpm/skills/bundled/main/mcp-builder/SKILL.md +0 -160
  571. claude_mpm/skills/bundled/main/mcp-builder/reference/design_principles.md +0 -412
  572. claude_mpm/skills/bundled/main/mcp-builder/reference/evaluation.md +0 -602
  573. claude_mpm/skills/bundled/main/mcp-builder/reference/mcp_best_practices.md +0 -915
  574. claude_mpm/skills/bundled/main/mcp-builder/reference/node_mcp_server.md +0 -916
  575. claude_mpm/skills/bundled/main/mcp-builder/reference/python_mcp_server.md +0 -752
  576. claude_mpm/skills/bundled/main/mcp-builder/reference/workflow.md +0 -1237
  577. claude_mpm/skills/bundled/main/skill-creator/SKILL.md +0 -189
  578. claude_mpm/skills/bundled/main/skill-creator/references/best-practices.md +0 -500
  579. claude_mpm/skills/bundled/main/skill-creator/references/creation-workflow.md +0 -464
  580. claude_mpm/skills/bundled/main/skill-creator/references/examples.md +0 -619
  581. claude_mpm/skills/bundled/main/skill-creator/references/progressive-disclosure.md +0 -437
  582. claude_mpm/skills/bundled/main/skill-creator/references/skill-structure.md +0 -231
  583. claude_mpm/skills/bundled/php/espocrm-development/SKILL.md +0 -170
  584. claude_mpm/skills/bundled/php/espocrm-development/references/architecture.md +0 -602
  585. claude_mpm/skills/bundled/php/espocrm-development/references/common-tasks.md +0 -821
  586. claude_mpm/skills/bundled/php/espocrm-development/references/development-workflow.md +0 -742
  587. claude_mpm/skills/bundled/php/espocrm-development/references/frontend-customization.md +0 -726
  588. claude_mpm/skills/bundled/php/espocrm-development/references/hooks-and-services.md +0 -764
  589. claude_mpm/skills/bundled/php/espocrm-development/references/testing-debugging.md +0 -831
  590. claude_mpm/skills/bundled/rust/desktop-applications/SKILL.md +0 -226
  591. claude_mpm/skills/bundled/rust/desktop-applications/references/architecture-patterns.md +0 -901
  592. claude_mpm/skills/bundled/rust/desktop-applications/references/native-gui-frameworks.md +0 -901
  593. claude_mpm/skills/bundled/rust/desktop-applications/references/platform-integration.md +0 -775
  594. claude_mpm/skills/bundled/rust/desktop-applications/references/state-management.md +0 -937
  595. claude_mpm/skills/bundled/rust/desktop-applications/references/tauri-framework.md +0 -770
  596. claude_mpm/skills/bundled/rust/desktop-applications/references/testing-deployment.md +0 -961
  597. claude_mpm/skills/bundled/testing/condition-based-waiting/SKILL.md +0 -119
  598. claude_mpm/skills/bundled/testing/condition-based-waiting/references/patterns-and-implementation.md +0 -253
  599. claude_mpm/skills/bundled/testing/test-driven-development/SKILL.md +0 -145
  600. claude_mpm/skills/bundled/testing/test-driven-development/references/anti-patterns.md +0 -543
  601. claude_mpm/skills/bundled/testing/test-driven-development/references/examples.md +0 -741
  602. claude_mpm/skills/bundled/testing/test-driven-development/references/integration.md +0 -470
  603. claude_mpm/skills/bundled/testing/test-driven-development/references/philosophy.md +0 -458
  604. claude_mpm/skills/bundled/testing/test-driven-development/references/workflow.md +0 -639
  605. claude_mpm/skills/bundled/testing/testing-anti-patterns/SKILL.md +0 -140
  606. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/completeness-anti-patterns.md +0 -572
  607. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/core-anti-patterns.md +0 -411
  608. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/detection-guide.md +0 -569
  609. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/tdd-connection.md +0 -695
  610. claude_mpm/skills/bundled/testing/webapp-testing/SKILL.md +0 -184
  611. claude_mpm/skills/bundled/testing/webapp-testing/decision-tree.md +0 -459
  612. claude_mpm/skills/bundled/testing/webapp-testing/playwright-patterns.md +0 -479
  613. claude_mpm/skills/bundled/testing/webapp-testing/reconnaissance-pattern.md +0 -687
  614. claude_mpm/skills/bundled/testing/webapp-testing/server-management.md +0 -758
  615. claude_mpm/skills/bundled/testing/webapp-testing/troubleshooting.md +0 -868
  616. claude_mpm-4.24.0.dist-info/entry_points.txt +0 -10
  617. claude_mpm-4.24.0.dist-info/licenses/LICENSE +0 -21
  618. /claude_mpm/agents/templates/{git_file_tracking.md → git-file-tracking.md} +0 -0
  619. /claude_mpm/agents/templates/{pm_examples.md → pm-examples.md} +0 -0
  620. /claude_mpm/agents/templates/{response_format.md → response-format.md} +0 -0
  621. /claude_mpm/agents/templates/{validation_templates.md → validation-templates.md} +0 -0
  622. {claude_mpm-4.24.0.dist-info → claude_mpm-5.4.41.dist-info}/WHEEL +0 -0
  623. {claude_mpm-4.24.0.dist-info → claude_mpm-5.4.41.dist-info}/top_level.txt +0 -0
@@ -1,915 +0,0 @@
1
- # MCP Server Development Best Practices and Guidelines
2
-
3
- ## Overview
4
-
5
- This document compiles essential best practices and guidelines for building Model Context Protocol (MCP) servers. It covers naming conventions, tool design, response formats, pagination, error handling, security, and compliance requirements.
6
-
7
- ---
8
-
9
- ## Quick Reference
10
-
11
- ### Server Naming
12
- - **Python**: `{service}_mcp` (e.g., `slack_mcp`)
13
- - **Node/TypeScript**: `{service}-mcp-server` (e.g., `slack-mcp-server`)
14
-
15
- ### Tool Naming
16
- - Use snake_case with service prefix
17
- - Format: `{service}_{action}_{resource}`
18
- - Example: `slack_send_message`, `github_create_issue`
19
-
20
- ### Response Formats
21
- - Support both JSON and Markdown formats
22
- - JSON for programmatic processing
23
- - Markdown for human readability
24
-
25
- ### Pagination
26
- - Always respect `limit` parameter
27
- - Return `has_more`, `next_offset`, `total_count`
28
- - Default to 20-50 items
29
-
30
- ### Character Limits
31
- - Set CHARACTER_LIMIT constant (typically 25,000)
32
- - Truncate gracefully with clear messages
33
- - Provide guidance on filtering
34
-
35
- ---
36
-
37
- ## Table of Contents
38
- 1. Server Naming Conventions
39
- 2. Tool Naming and Design
40
- 3. Response Format Guidelines
41
- 4. Pagination Best Practices
42
- 5. Character Limits and Truncation
43
- 6. Tool Development Best Practices
44
- 7. Transport Best Practices
45
- 8. Testing Requirements
46
- 9. OAuth and Security Best Practices
47
- 10. Resource Management Best Practices
48
- 11. Prompt Management Best Practices
49
- 12. Error Handling Standards
50
- 13. Documentation Requirements
51
- 14. Compliance and Monitoring
52
-
53
- ---
54
-
55
- ## 1. Server Naming Conventions
56
-
57
- Follow these standardized naming patterns for MCP servers:
58
-
59
- **Python**: Use format `{service}_mcp` (lowercase with underscores)
60
- - Examples: `slack_mcp`, `github_mcp`, `jira_mcp`, `stripe_mcp`
61
-
62
- **Node/TypeScript**: Use format `{service}-mcp-server` (lowercase with hyphens)
63
- - Examples: `slack-mcp-server`, `github-mcp-server`, `jira-mcp-server`
64
-
65
- The name should be:
66
- - General (not tied to specific features)
67
- - Descriptive of the service/API being integrated
68
- - Easy to infer from the task description
69
- - Without version numbers or dates
70
-
71
- ---
72
-
73
- ## 2. Tool Naming and Design
74
-
75
- ### Tool Naming Best Practices
76
-
77
- 1. **Use snake_case**: `search_users`, `create_project`, `get_channel_info`
78
- 2. **Include service prefix**: Anticipate that your MCP server may be used alongside other MCP servers
79
- - Use `slack_send_message` instead of just `send_message`
80
- - Use `github_create_issue` instead of just `create_issue`
81
- - Use `asana_list_tasks` instead of just `list_tasks`
82
- 3. **Be action-oriented**: Start with verbs (get, list, search, create, etc.)
83
- 4. **Be specific**: Avoid generic names that could conflict with other servers
84
- 5. **Maintain consistency**: Use consistent naming patterns within your server
85
-
86
- ### Tool Design Guidelines
87
-
88
- - Tool descriptions must narrowly and unambiguously describe functionality
89
- - Descriptions must precisely match actual functionality
90
- - Should not create confusion with other MCP servers
91
- - Should provide tool annotations (readOnlyHint, destructiveHint, idempotentHint, openWorldHint)
92
- - Keep tool operations focused and atomic
93
-
94
- ---
95
-
96
- ## 3. Response Format Guidelines
97
-
98
- All tools that return data should support multiple formats for flexibility:
99
-
100
- ### JSON Format (`response_format="json"`)
101
- - Machine-readable structured data
102
- - Include all available fields and metadata
103
- - Consistent field names and types
104
- - Suitable for programmatic processing
105
- - Use for when LLMs need to process data further
106
-
107
- ### Markdown Format (`response_format="markdown"`, typically default)
108
- - Human-readable formatted text
109
- - Use headers, lists, and formatting for clarity
110
- - Convert timestamps to human-readable format (e.g., "2024-01-15 10:30:00 UTC" instead of epoch)
111
- - Show display names with IDs in parentheses (e.g., "@john.doe (U123456)")
112
- - Omit verbose metadata (e.g., show only one profile image URL, not all sizes)
113
- - Group related information logically
114
- - Use for when presenting information to users
115
-
116
- ---
117
-
118
- ## 4. Pagination Best Practices
119
-
120
- For tools that list resources:
121
-
122
- - **Always respect the `limit` parameter**: Never load all results when a limit is specified
123
- - **Implement pagination**: Use `offset` or cursor-based pagination
124
- - **Return pagination metadata**: Include `has_more`, `next_offset`/`next_cursor`, `total_count`
125
- - **Never load all results into memory**: Especially important for large datasets
126
- - **Default to reasonable limits**: 20-50 items is typical
127
- - **Include clear pagination info in responses**: Make it easy for LLMs to request more data
128
-
129
- Example pagination response structure:
130
- ```json
131
- {
132
- "total": 150,
133
- "count": 20,
134
- "offset": 0,
135
- "items": [...],
136
- "has_more": true,
137
- "next_offset": 20
138
- }
139
- ```
140
-
141
- ---
142
-
143
- ## 5. Character Limits and Truncation
144
-
145
- To prevent overwhelming responses with too much data:
146
-
147
- - **Define CHARACTER_LIMIT constant**: Typically 25,000 characters at module level
148
- - **Check response size before returning**: Measure the final response length
149
- - **Truncate gracefully with clear indicators**: Let the LLM know data was truncated
150
- - **Provide guidance on filtering**: Suggest how to use parameters to reduce results
151
- - **Include truncation metadata**: Show what was truncated and how to get more
152
-
153
- Example truncation handling:
154
- ```python
155
- CHARACTER_LIMIT = 25000
156
-
157
- if len(result) > CHARACTER_LIMIT:
158
- truncated_data = data[:max(1, len(data) // 2)]
159
- response["truncated"] = True
160
- response["truncation_message"] = (
161
- f"Response truncated from {len(data)} to {len(truncated_data)} items. "
162
- f"Use 'offset' parameter or add filters to see more results."
163
- )
164
- ```
165
-
166
- ---
167
-
168
- ## 6. Transport Options
169
-
170
- MCP servers support multiple transport mechanisms for different deployment scenarios:
171
-
172
- ### Stdio Transport
173
-
174
- **Best for**: Command-line tools, local integrations, subprocess execution
175
-
176
- **Characteristics**:
177
- - Standard input/output stream communication
178
- - Simple setup, no network configuration needed
179
- - Runs as a subprocess of the client
180
- - Ideal for desktop applications and CLI tools
181
-
182
- **Use when**:
183
- - Building tools for local development environments
184
- - Integrating with desktop applications (e.g., Claude Desktop)
185
- - Creating command-line utilities
186
- - Single-user, single-session scenarios
187
-
188
- ### HTTP Transport
189
-
190
- **Best for**: Web services, remote access, multi-client scenarios
191
-
192
- **Characteristics**:
193
- - Request-response pattern over HTTP
194
- - Supports multiple simultaneous clients
195
- - Can be deployed as a web service
196
- - Requires network configuration and security considerations
197
-
198
- **Use when**:
199
- - Serving multiple clients simultaneously
200
- - Deploying as a cloud service
201
- - Integration with web applications
202
- - Need for load balancing or scaling
203
-
204
- ### Server-Sent Events (SSE) Transport
205
-
206
- **Best for**: Real-time updates, push notifications, streaming data
207
-
208
- **Characteristics**:
209
- - One-way server-to-client streaming over HTTP
210
- - Enables real-time updates without polling
211
- - Long-lived connections for continuous data flow
212
- - Built on standard HTTP infrastructure
213
-
214
- **Use when**:
215
- - Clients need real-time data updates
216
- - Implementing push notifications
217
- - Streaming logs or monitoring data
218
- - Progressive result delivery for long operations
219
-
220
- ### Transport Selection Criteria
221
-
222
- | Criterion | Stdio | HTTP | SSE |
223
- |-----------|-------|------|-----|
224
- | **Deployment** | Local | Remote | Remote |
225
- | **Clients** | Single | Multiple | Multiple |
226
- | **Communication** | Bidirectional | Request-Response | Server-Push |
227
- | **Complexity** | Low | Medium | Medium-High |
228
- | **Real-time** | No | No | Yes |
229
-
230
- ---
231
-
232
- ## 7. Tool Development Best Practices
233
-
234
- ### General Guidelines
235
- 1. Tool names should be descriptive and action-oriented
236
- 2. Use parameter validation with detailed JSON schemas
237
- 3. Include examples in tool descriptions
238
- 4. Implement proper error handling and validation
239
- 5. Use progress reporting for long operations
240
- 6. Keep tool operations focused and atomic
241
- 7. Document expected return value structures
242
- 8. Implement proper timeouts
243
- 9. Consider rate limiting for resource-intensive operations
244
- 10. Log tool usage for debugging and monitoring
245
-
246
- ### Security Considerations for Tools
247
-
248
- #### Input Validation
249
- - Validate all parameters against schema
250
- - Sanitize file paths and system commands
251
- - Validate URLs and external identifiers
252
- - Check parameter sizes and ranges
253
- - Prevent command injection
254
-
255
- #### Access Control
256
- - Implement authentication where needed
257
- - Use appropriate authorization checks
258
- - Audit tool usage
259
- - Rate limit requests
260
- - Monitor for abuse
261
-
262
- #### Error Handling
263
- - Don't expose internal errors to clients
264
- - Log security-relevant errors
265
- - Handle timeouts appropriately
266
- - Clean up resources after errors
267
- - Validate return values
268
-
269
- ### Tool Annotations
270
- - Provide readOnlyHint and destructiveHint annotations
271
- - Remember annotations are hints, not security guarantees
272
- - Clients should not make security-critical decisions based solely on annotations
273
-
274
- ---
275
-
276
- ## 8. Transport Best Practices
277
-
278
- ### General Transport Guidelines
279
- 1. Handle connection lifecycle properly
280
- 2. Implement proper error handling
281
- 3. Use appropriate timeout values
282
- 4. Implement connection state management
283
- 5. Clean up resources on disconnection
284
-
285
- ### Security Best Practices for Transport
286
- - Follow security considerations for DNS rebinding attacks
287
- - Implement proper authentication mechanisms
288
- - Validate message formats
289
- - Handle malformed messages gracefully
290
-
291
- ### Stdio Transport Specific
292
- - Local MCP servers should NOT log to stdout (interferes with protocol)
293
- - Use stderr for logging messages
294
- - Handle standard I/O streams properly
295
-
296
- ---
297
-
298
- ## 9. Testing Requirements
299
-
300
- A comprehensive testing strategy should cover:
301
-
302
- ### Functional Testing
303
- - Verify correct execution with valid/invalid inputs
304
-
305
- ### Integration Testing
306
- - Test interaction with external systems
307
-
308
- ### Security Testing
309
- - Validate auth, input sanitization, rate limiting
310
-
311
- ### Performance Testing
312
- - Check behavior under load, timeouts
313
-
314
- ### Error Handling
315
- - Ensure proper error reporting and cleanup
316
-
317
- ---
318
-
319
- ## 10. OAuth and Security Best Practices
320
-
321
- ### Authentication and Authorization
322
-
323
- MCP servers that connect to external services should implement proper authentication:
324
-
325
- **OAuth 2.1 Implementation:**
326
- - Use secure OAuth 2.1 with certificates from recognized authorities
327
- - Validate access tokens before processing requests
328
- - Only accept tokens specifically intended for your server
329
- - Reject tokens without proper audience claims
330
- - Never pass through tokens received from MCP clients
331
-
332
- **API Key Management:**
333
- - Store API keys in environment variables, never in code
334
- - Validate keys on server startup
335
- - Provide clear error messages when authentication fails
336
- - Use secure transmission for sensitive credentials
337
-
338
- ### Input Validation and Security
339
-
340
- **Always validate inputs:**
341
- - Sanitize file paths to prevent directory traversal
342
- - Validate URLs and external identifiers
343
- - Check parameter sizes and ranges
344
- - Prevent command injection in system calls
345
- - Use schema validation (Pydantic/Zod) for all inputs
346
-
347
- **Error handling security:**
348
- - Don't expose internal errors to clients
349
- - Log security-relevant errors server-side
350
- - Provide helpful but not revealing error messages
351
- - Clean up resources after errors
352
-
353
- ### Privacy and Data Protection
354
-
355
- **Data collection principles:**
356
- - Only collect data strictly necessary for functionality
357
- - Don't collect extraneous conversation data
358
- - Don't collect PII unless explicitly required for the tool's purpose
359
- - Provide clear information about what data is accessed
360
-
361
- **Data transmission:**
362
- - Don't send data to servers outside your organization without disclosure
363
- - Use secure transmission (HTTPS) for all network communication
364
- - Validate certificates for external services
365
-
366
- ---
367
-
368
- ## 11. Resource Management Best Practices
369
-
370
- 1. Only suggest necessary resources
371
- 2. Use clear, descriptive names for roots
372
- 3. Handle resource boundaries properly
373
- 4. Respect client control over resources
374
- 5. Use model-controlled primitives (tools) for automatic data exposure
375
-
376
- ---
377
-
378
- ## 12. Prompt Management Best Practices
379
-
380
- - Clients should show users proposed prompts
381
- - Users should be able to modify or reject prompts
382
- - Clients should show users completions
383
- - Users should be able to modify or reject completions
384
- - Consider costs when using sampling
385
-
386
- ---
387
-
388
- ## 13. Error Handling Standards
389
-
390
- - Use standard JSON-RPC error codes
391
- - Report tool errors within result objects (not protocol-level)
392
- - Provide helpful, specific error messages
393
- - Don't expose internal implementation details
394
- - Clean up resources properly on errors
395
-
396
- ---
397
-
398
- ## 14. Documentation Requirements
399
-
400
- - Provide clear documentation of all tools and capabilities
401
- - Include working examples (at least 3 per major feature)
402
- - Document security considerations
403
- - Specify required permissions and access levels
404
- - Document rate limits and performance characteristics
405
-
406
- ---
407
-
408
- ## 15. Compliance and Monitoring
409
-
410
- - Implement logging for debugging and monitoring
411
- - Track tool usage patterns
412
- - Monitor for potential abuse
413
- - Maintain audit trails for security-relevant operations
414
- - Be prepared for ongoing compliance reviews
415
-
416
- ---
417
-
418
- ## Summary
419
-
420
- These best practices represent the comprehensive guidelines for building secure, efficient, and compliant MCP servers that work well within the ecosystem. Developers should follow these guidelines to ensure their MCP servers meet the standards for inclusion in the MCP directory and provide a safe, reliable experience for users.
421
-
422
-
423
- ----------
424
-
425
-
426
- # Tools
427
-
428
- > Enable LLMs to perform actions through your server
429
-
430
- Tools are a powerful primitive in the Model Context Protocol (MCP) that enable servers to expose executable functionality to clients. Through tools, LLMs can interact with external systems, perform computations, and take actions in the real world.
431
-
432
- <Note>
433
- Tools are designed to be **model-controlled**, meaning that tools are exposed from servers to clients with the intention of the AI model being able to automatically invoke them (with a human in the loop to grant approval).
434
- </Note>
435
-
436
- ## Overview
437
-
438
- Tools in MCP allow servers to expose executable functions that can be invoked by clients and used by LLMs to perform actions. Key aspects of tools include:
439
-
440
- * **Discovery**: Clients can obtain a list of available tools by sending a `tools/list` request
441
- * **Invocation**: Tools are called using the `tools/call` request, where servers perform the requested operation and return results
442
- * **Flexibility**: Tools can range from simple calculations to complex API interactions
443
-
444
- Like [resources](/docs/concepts/resources), tools are identified by unique names and can include descriptions to guide their usage. However, unlike resources, tools represent dynamic operations that can modify state or interact with external systems.
445
-
446
- ## Tool definition structure
447
-
448
- Each tool is defined with the following structure:
449
-
450
- ```typescript
451
- {
452
- name: string; // Unique identifier for the tool
453
- description?: string; // Human-readable description
454
- inputSchema: { // JSON Schema for the tool's parameters
455
- type: "object",
456
- properties: { ... } // Tool-specific parameters
457
- },
458
- annotations?: { // Optional hints about tool behavior
459
- title?: string; // Human-readable title for the tool
460
- readOnlyHint?: boolean; // If true, the tool does not modify its environment
461
- destructiveHint?: boolean; // If true, the tool may perform destructive updates
462
- idempotentHint?: boolean; // If true, repeated calls with same args have no additional effect
463
- openWorldHint?: boolean; // If true, tool interacts with external entities
464
- }
465
- }
466
- ```
467
-
468
- ## Implementing tools
469
-
470
- Here's an example of implementing a basic tool in an MCP server:
471
-
472
- <Tabs>
473
- <Tab title="TypeScript">
474
- ```typescript
475
- const server = new Server({
476
- name: "example-server",
477
- version: "1.0.0"
478
- }, {
479
- capabilities: {
480
- tools: {}
481
- }
482
- });
483
-
484
- // Define available tools
485
- server.setRequestHandler(ListToolsRequestSchema, async () => {
486
- return {
487
- tools: [{
488
- name: "calculate_sum",
489
- description: "Add two numbers together",
490
- inputSchema: {
491
- type: "object",
492
- properties: {
493
- a: { type: "number" },
494
- b: { type: "number" }
495
- },
496
- required: ["a", "b"]
497
- }
498
- }]
499
- };
500
- });
501
-
502
- // Handle tool execution
503
- server.setRequestHandler(CallToolRequestSchema, async (request) => {
504
- if (request.params.name === "calculate_sum") {
505
- const { a, b } = request.params.arguments;
506
- return {
507
- content: [
508
- {
509
- type: "text",
510
- text: String(a + b)
511
- }
512
- ]
513
- };
514
- }
515
- throw new Error("Tool not found");
516
- });
517
- ```
518
- </Tab>
519
-
520
- <Tab title="Python">
521
- ```python
522
- app = Server("example-server")
523
-
524
- @app.list_tools()
525
- async def list_tools() -> list[types.Tool]:
526
- return [
527
- types.Tool(
528
- name="calculate_sum",
529
- description="Add two numbers together",
530
- inputSchema={
531
- "type": "object",
532
- "properties": {
533
- "a": {"type": "number"},
534
- "b": {"type": "number"}
535
- },
536
- "required": ["a", "b"]
537
- }
538
- )
539
- ]
540
-
541
- @app.call_tool()
542
- async def call_tool(
543
- name: str,
544
- arguments: dict
545
- ) -> list[types.TextContent | types.ImageContent | types.EmbeddedResource]:
546
- if name == "calculate_sum":
547
- a = arguments["a"]
548
- b = arguments["b"]
549
- result = a + b
550
- return [types.TextContent(type="text", text=str(result))]
551
- raise ValueError(f"Tool not found: {name}")
552
- ```
553
- </Tab>
554
- </Tabs>
555
-
556
- ## Example tool patterns
557
-
558
- Here are some examples of types of tools that a server could provide:
559
-
560
- ### System operations
561
-
562
- Tools that interact with the local system:
563
-
564
- ```typescript
565
- {
566
- name: "execute_command",
567
- description: "Run a shell command",
568
- inputSchema: {
569
- type: "object",
570
- properties: {
571
- command: { type: "string" },
572
- args: { type: "array", items: { type: "string" } }
573
- }
574
- }
575
- }
576
- ```
577
-
578
- ### API integrations
579
-
580
- Tools that wrap external APIs:
581
-
582
- ```typescript
583
- {
584
- name: "github_create_issue",
585
- description: "Create a GitHub issue",
586
- inputSchema: {
587
- type: "object",
588
- properties: {
589
- title: { type: "string" },
590
- body: { type: "string" },
591
- labels: { type: "array", items: { type: "string" } }
592
- }
593
- }
594
- }
595
- ```
596
-
597
- ### Data processing
598
-
599
- Tools that transform or analyze data:
600
-
601
- ```typescript
602
- {
603
- name: "analyze_csv",
604
- description: "Analyze a CSV file",
605
- inputSchema: {
606
- type: "object",
607
- properties: {
608
- filepath: { type: "string" },
609
- operations: {
610
- type: "array",
611
- items: {
612
- enum: ["sum", "average", "count"]
613
- }
614
- }
615
- }
616
- }
617
- }
618
- ```
619
-
620
- ## Best practices
621
-
622
- When implementing tools:
623
-
624
- 1. Provide clear, descriptive names and descriptions
625
- 2. Use detailed JSON Schema definitions for parameters
626
- 3. Include examples in tool descriptions to demonstrate how the model should use them
627
- 4. Implement proper error handling and validation
628
- 5. Use progress reporting for long operations
629
- 6. Keep tool operations focused and atomic
630
- 7. Document expected return value structures
631
- 8. Implement proper timeouts
632
- 9. Consider rate limiting for resource-intensive operations
633
- 10. Log tool usage for debugging and monitoring
634
-
635
- ### Tool name conflicts
636
-
637
- MCP client applications and MCP server proxies may encounter tool name conflicts when building their own tool lists. For example, two connected MCP servers `web1` and `web2` may both expose a tool named `search_web`.
638
-
639
- Applications may disambiguiate tools with one of the following strategies (among others; not an exhaustive list):
640
-
641
- * Concatenating a unique, user-defined server name with the tool name, e.g. `web1___search_web` and `web2___search_web`. This strategy may be preferable when unique server names are already provided by the user in a configuration file.
642
- * Generating a random prefix for the tool name, e.g. `jrwxs___search_web` and `6cq52___search_web`. This strategy may be preferable in server proxies where user-defined unique names are not available.
643
- * Using the server URI as a prefix for the tool name, e.g. `web1.example.com:search_web` and `web2.example.com:search_web`. This strategy may be suitable when working with remote MCP servers.
644
-
645
- Note that the server-provided name from the initialization flow is not guaranteed to be unique and is not generally suitable for disambiguation purposes.
646
-
647
- ## Security considerations
648
-
649
- When exposing tools:
650
-
651
- ### Input validation
652
-
653
- * Validate all parameters against the schema
654
- * Sanitize file paths and system commands
655
- * Validate URLs and external identifiers
656
- * Check parameter sizes and ranges
657
- * Prevent command injection
658
-
659
- ### Access control
660
-
661
- * Implement authentication where needed
662
- * Use appropriate authorization checks
663
- * Audit tool usage
664
- * Rate limit requests
665
- * Monitor for abuse
666
-
667
- ### Error handling
668
-
669
- * Don't expose internal errors to clients
670
- * Log security-relevant errors
671
- * Handle timeouts appropriately
672
- * Clean up resources after errors
673
- * Validate return values
674
-
675
- ## Tool discovery and updates
676
-
677
- MCP supports dynamic tool discovery:
678
-
679
- 1. Clients can list available tools at any time
680
- 2. Servers can notify clients when tools change using `notifications/tools/list_changed`
681
- 3. Tools can be added or removed during runtime
682
- 4. Tool definitions can be updated (though this should be done carefully)
683
-
684
- ## Error handling
685
-
686
- Tool errors should be reported within the result object, not as MCP protocol-level errors. This allows the LLM to see and potentially handle the error. When a tool encounters an error:
687
-
688
- 1. Set `isError` to `true` in the result
689
- 2. Include error details in the `content` array
690
-
691
- Here's an example of proper error handling for tools:
692
-
693
- <Tabs>
694
- <Tab title="TypeScript">
695
- ```typescript
696
- try {
697
- // Tool operation
698
- const result = performOperation();
699
- return {
700
- content: [
701
- {
702
- type: "text",
703
- text: `Operation successful: ${result}`
704
- }
705
- ]
706
- };
707
- } catch (error) {
708
- return {
709
- isError: true,
710
- content: [
711
- {
712
- type: "text",
713
- text: `Error: ${error.message}`
714
- }
715
- ]
716
- };
717
- }
718
- ```
719
- </Tab>
720
-
721
- <Tab title="Python">
722
- ```python
723
- try:
724
- # Tool operation
725
- result = perform_operation()
726
- return types.CallToolResult(
727
- content=[
728
- types.TextContent(
729
- type="text",
730
- text=f"Operation successful: {result}"
731
- )
732
- ]
733
- )
734
- except Exception as error:
735
- return types.CallToolResult(
736
- isError=True,
737
- content=[
738
- types.TextContent(
739
- type="text",
740
- text=f"Error: {str(error)}"
741
- )
742
- ]
743
- )
744
- ```
745
- </Tab>
746
- </Tabs>
747
-
748
- This approach allows the LLM to see that an error occurred and potentially take corrective action or request human intervention.
749
-
750
- ## Tool annotations
751
-
752
- Tool annotations provide additional metadata about a tool's behavior, helping clients understand how to present and manage tools. These annotations are hints that describe the nature and impact of a tool, but should not be relied upon for security decisions.
753
-
754
- ### Purpose of tool annotations
755
-
756
- Tool annotations serve several key purposes:
757
-
758
- 1. Provide UX-specific information without affecting model context
759
- 2. Help clients categorize and present tools appropriately
760
- 3. Convey information about a tool's potential side effects
761
- 4. Assist in developing intuitive interfaces for tool approval
762
-
763
- ### Available tool annotations
764
-
765
- The MCP specification defines the following annotations for tools:
766
-
767
- | Annotation | Type | Default | Description |
768
- | ----------------- | ------- | ------- | ------------------------------------------------------------------------------------------------------------------------------------ |
769
- | `title` | string | - | A human-readable title for the tool, useful for UI display |
770
- | `readOnlyHint` | boolean | false | If true, indicates the tool does not modify its environment |
771
- | `destructiveHint` | boolean | true | If true, the tool may perform destructive updates (only meaningful when `readOnlyHint` is false) |
772
- | `idempotentHint` | boolean | false | If true, calling the tool repeatedly with the same arguments has no additional effect (only meaningful when `readOnlyHint` is false) |
773
- | `openWorldHint` | boolean | true | If true, the tool may interact with an "open world" of external entities |
774
-
775
- ### Example usage
776
-
777
- Here's how to define tools with annotations for different scenarios:
778
-
779
- ```typescript
780
- // A read-only search tool
781
- {
782
- name: "web_search",
783
- description: "Search the web for information",
784
- inputSchema: {
785
- type: "object",
786
- properties: {
787
- query: { type: "string" }
788
- },
789
- required: ["query"]
790
- },
791
- annotations: {
792
- title: "Web Search",
793
- readOnlyHint: true,
794
- openWorldHint: true
795
- }
796
- }
797
-
798
- // A destructive file deletion tool
799
- {
800
- name: "delete_file",
801
- description: "Delete a file from the filesystem",
802
- inputSchema: {
803
- type: "object",
804
- properties: {
805
- path: { type: "string" }
806
- },
807
- required: ["path"]
808
- },
809
- annotations: {
810
- title: "Delete File",
811
- readOnlyHint: false,
812
- destructiveHint: true,
813
- idempotentHint: true,
814
- openWorldHint: false
815
- }
816
- }
817
-
818
- // A non-destructive database record creation tool
819
- {
820
- name: "create_record",
821
- description: "Create a new record in the database",
822
- inputSchema: {
823
- type: "object",
824
- properties: {
825
- table: { type: "string" },
826
- data: { type: "object" }
827
- },
828
- required: ["table", "data"]
829
- },
830
- annotations: {
831
- title: "Create Database Record",
832
- readOnlyHint: false,
833
- destructiveHint: false,
834
- idempotentHint: false,
835
- openWorldHint: false
836
- }
837
- }
838
- ```
839
-
840
- ### Integrating annotations in server implementation
841
-
842
- <Tabs>
843
- <Tab title="TypeScript">
844
- ```typescript
845
- server.setRequestHandler(ListToolsRequestSchema, async () => {
846
- return {
847
- tools: [{
848
- name: "calculate_sum",
849
- description: "Add two numbers together",
850
- inputSchema: {
851
- type: "object",
852
- properties: {
853
- a: { type: "number" },
854
- b: { type: "number" }
855
- },
856
- required: ["a", "b"]
857
- },
858
- annotations: {
859
- title: "Calculate Sum",
860
- readOnlyHint: true,
861
- openWorldHint: false
862
- }
863
- }]
864
- };
865
- });
866
- ```
867
- </Tab>
868
-
869
- <Tab title="Python">
870
- ```python
871
- from mcp.server.fastmcp import FastMCP
872
-
873
- mcp = FastMCP("example-server")
874
-
875
- @mcp.tool(
876
- annotations={
877
- "title": "Calculate Sum",
878
- "readOnlyHint": True,
879
- "openWorldHint": False
880
- }
881
- )
882
- async def calculate_sum(a: float, b: float) -> str:
883
- """Add two numbers together.
884
-
885
- Args:
886
- a: First number to add
887
- b: Second number to add
888
- """
889
- result = a + b
890
- return str(result)
891
- ```
892
- </Tab>
893
- </Tabs>
894
-
895
- ### Best practices for tool annotations
896
-
897
- 1. **Be accurate about side effects**: Clearly indicate whether a tool modifies its environment and whether those modifications are destructive.
898
-
899
- 2. **Use descriptive titles**: Provide human-friendly titles that clearly describe the tool's purpose.
900
-
901
- 3. **Indicate idempotency properly**: Mark tools as idempotent only if repeated calls with the same arguments truly have no additional effect.
902
-
903
- 4. **Set appropriate open/closed world hints**: Indicate whether a tool interacts with a closed system (like a database) or an open system (like the web).
904
-
905
- 5. **Remember annotations are hints**: All properties in ToolAnnotations are hints and not guaranteed to provide a faithful description of tool behavior. Clients should never make security-critical decisions based solely on annotations.
906
-
907
- ## Testing tools
908
-
909
- A comprehensive testing strategy for MCP tools should cover:
910
-
911
- * **Functional testing**: Verify tools execute correctly with valid inputs and handle invalid inputs appropriately
912
- * **Integration testing**: Test tool interaction with external systems using both real and mocked dependencies
913
- * **Security testing**: Validate authentication, authorization, input sanitization, and rate limiting
914
- * **Performance testing**: Check behavior under load, timeout handling, and resource cleanup
915
- * **Error handling**: Ensure tools properly report errors through the MCP protocol and clean up resources