claude-mpm 4.25.10__py3-none-any.whl → 5.1.8__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.

Potentially problematic release.


This version of claude-mpm might be problematic. Click here for more details.

Files changed (507) hide show
  1. claude_mpm/VERSION +1 -1
  2. claude_mpm/agents/BASE_PM.md +12 -0
  3. claude_mpm/agents/PM_INSTRUCTIONS.md +1055 -2230
  4. claude_mpm/agents/PM_INSTRUCTIONS_TEACH.md +1322 -0
  5. claude_mpm/agents/WORKFLOW.md +4 -4
  6. claude_mpm/agents/__init__.py +6 -0
  7. claude_mpm/agents/agent_loader.py +1 -4
  8. claude_mpm/agents/base_agent_loader.py +10 -35
  9. claude_mpm/agents/templates/{circuit_breakers.md → circuit-breakers.md} +576 -66
  10. claude_mpm/agents/templates/context-management-examples.md +544 -0
  11. claude_mpm/agents/templates/pr-workflow-examples.md +427 -0
  12. claude_mpm/agents/templates/research-gate-examples.md +669 -0
  13. claude_mpm/agents/templates/structured-questions-examples.md +615 -0
  14. claude_mpm/agents/templates/ticket-completeness-examples.md +139 -0
  15. claude_mpm/agents/templates/ticketing-examples.md +277 -0
  16. claude_mpm/cli/__init__.py +28 -3
  17. claude_mpm/cli/commands/__init__.py +2 -0
  18. claude_mpm/cli/commands/agent_source.py +774 -0
  19. claude_mpm/cli/commands/agent_state_manager.py +188 -30
  20. claude_mpm/cli/commands/agents.py +959 -36
  21. claude_mpm/cli/commands/agents_cleanup.py +210 -0
  22. claude_mpm/cli/commands/agents_discover.py +338 -0
  23. claude_mpm/cli/commands/auto_configure.py +537 -239
  24. claude_mpm/cli/commands/config.py +7 -4
  25. claude_mpm/cli/commands/configure.py +924 -45
  26. claude_mpm/cli/commands/configure_navigation.py +63 -46
  27. claude_mpm/cli/commands/doctor.py +10 -2
  28. claude_mpm/cli/commands/local_deploy.py +1 -4
  29. claude_mpm/cli/commands/postmortem.py +401 -0
  30. claude_mpm/cli/commands/run.py +1 -39
  31. claude_mpm/cli/commands/skill_source.py +694 -0
  32. claude_mpm/cli/commands/skills.py +322 -19
  33. claude_mpm/cli/executor.py +22 -3
  34. claude_mpm/cli/interactive/agent_wizard.py +1028 -43
  35. claude_mpm/cli/parsers/agent_source_parser.py +171 -0
  36. claude_mpm/cli/parsers/agents_parser.py +256 -4
  37. claude_mpm/cli/parsers/auto_configure_parser.py +13 -0
  38. claude_mpm/cli/parsers/base_parser.py +25 -0
  39. claude_mpm/cli/parsers/config_parser.py +96 -43
  40. claude_mpm/cli/parsers/skill_source_parser.py +169 -0
  41. claude_mpm/cli/parsers/skills_parser.py +7 -0
  42. claude_mpm/cli/parsers/source_parser.py +138 -0
  43. claude_mpm/cli/startup.py +456 -103
  44. claude_mpm/cli/startup_display.py +4 -4
  45. claude_mpm/commands/{mpm-auto-configure.md → mpm-agents-auto-configure.md} +9 -0
  46. claude_mpm/commands/mpm-agents-detect.md +9 -0
  47. claude_mpm/commands/{mpm-agents.md → mpm-agents-list.md} +9 -0
  48. claude_mpm/commands/mpm-agents-recommend.md +9 -0
  49. claude_mpm/commands/{mpm-config.md → mpm-config-view.md} +9 -0
  50. claude_mpm/commands/mpm-doctor.md +9 -0
  51. claude_mpm/commands/mpm-help.md +14 -2
  52. claude_mpm/commands/mpm-init.md +9 -0
  53. claude_mpm/commands/mpm-monitor.md +9 -0
  54. claude_mpm/commands/mpm-postmortem.md +123 -0
  55. claude_mpm/commands/{mpm-resume.md → mpm-session-resume.md} +9 -0
  56. claude_mpm/commands/mpm-status.md +9 -0
  57. claude_mpm/commands/{mpm-organize.md → mpm-ticket-organize.md} +9 -0
  58. claude_mpm/commands/mpm-ticket-view.md +552 -0
  59. claude_mpm/commands/mpm-version.md +9 -0
  60. claude_mpm/commands/mpm.md +10 -0
  61. claude_mpm/config/agent_presets.py +488 -0
  62. claude_mpm/config/agent_sources.py +325 -0
  63. claude_mpm/config/skill_presets.py +392 -0
  64. claude_mpm/config/skill_sources.py +590 -0
  65. claude_mpm/constants.py +1 -0
  66. claude_mpm/core/claude_runner.py +5 -34
  67. claude_mpm/core/config.py +16 -0
  68. claude_mpm/core/framework/__init__.py +3 -16
  69. claude_mpm/core/framework/loaders/file_loader.py +54 -101
  70. claude_mpm/core/framework/loaders/instruction_loader.py +25 -5
  71. claude_mpm/core/interactive_session.py +83 -7
  72. claude_mpm/core/oneshot_session.py +71 -8
  73. claude_mpm/core/protocols/__init__.py +23 -0
  74. claude_mpm/core/protocols/runner_protocol.py +103 -0
  75. claude_mpm/core/protocols/session_protocol.py +131 -0
  76. claude_mpm/core/shared/singleton_manager.py +11 -4
  77. claude_mpm/core/system_context.py +38 -0
  78. claude_mpm/core/unified_config.py +22 -0
  79. claude_mpm/experimental/cli_enhancements.py +1 -5
  80. claude_mpm/hooks/claude_hooks/__pycache__/__init__.cpython-313.pyc +0 -0
  81. claude_mpm/hooks/claude_hooks/__pycache__/event_handlers.cpython-313.pyc +0 -0
  82. claude_mpm/hooks/claude_hooks/__pycache__/hook_handler.cpython-313.pyc +0 -0
  83. claude_mpm/hooks/claude_hooks/__pycache__/memory_integration.cpython-313.pyc +0 -0
  84. claude_mpm/hooks/claude_hooks/__pycache__/response_tracking.cpython-313.pyc +0 -0
  85. claude_mpm/hooks/claude_hooks/__pycache__/tool_analysis.cpython-313.pyc +0 -0
  86. claude_mpm/hooks/claude_hooks/memory_integration.py +12 -1
  87. claude_mpm/hooks/claude_hooks/services/__pycache__/__init__.cpython-313.pyc +0 -0
  88. claude_mpm/hooks/claude_hooks/services/__pycache__/connection_manager_http.cpython-313.pyc +0 -0
  89. claude_mpm/hooks/claude_hooks/services/__pycache__/duplicate_detector.cpython-313.pyc +0 -0
  90. claude_mpm/hooks/claude_hooks/services/__pycache__/state_manager.cpython-313.pyc +0 -0
  91. claude_mpm/hooks/claude_hooks/services/__pycache__/subagent_processor.cpython-313.pyc +0 -0
  92. claude_mpm/hooks/failure_learning/__init__.py +2 -8
  93. claude_mpm/hooks/failure_learning/failure_detection_hook.py +1 -6
  94. claude_mpm/hooks/failure_learning/fix_detection_hook.py +1 -6
  95. claude_mpm/hooks/failure_learning/learning_extraction_hook.py +1 -6
  96. claude_mpm/hooks/kuzu_response_hook.py +1 -5
  97. claude_mpm/models/git_repository.py +198 -0
  98. claude_mpm/services/agents/agent_builder.py +45 -9
  99. claude_mpm/services/agents/agent_preset_service.py +238 -0
  100. claude_mpm/services/agents/agent_selection_service.py +484 -0
  101. claude_mpm/services/agents/auto_deploy_index_parser.py +569 -0
  102. claude_mpm/services/agents/cache_git_manager.py +621 -0
  103. claude_mpm/services/agents/deployment/agent_deployment.py +126 -2
  104. claude_mpm/services/agents/deployment/agent_discovery_service.py +105 -73
  105. claude_mpm/services/agents/deployment/agent_lifecycle_manager.py +1 -5
  106. claude_mpm/services/agents/deployment/agent_restore_handler.py +1 -4
  107. claude_mpm/services/agents/deployment/agent_template_builder.py +236 -15
  108. claude_mpm/services/agents/deployment/agents_directory_resolver.py +101 -15
  109. claude_mpm/services/agents/deployment/async_agent_deployment.py +2 -1
  110. claude_mpm/services/agents/deployment/multi_source_deployment_service.py +115 -15
  111. claude_mpm/services/agents/deployment/refactored_agent_deployment_service.py +1 -4
  112. claude_mpm/services/agents/deployment/remote_agent_discovery_service.py +363 -0
  113. claude_mpm/services/agents/deployment/single_agent_deployer.py +2 -2
  114. claude_mpm/services/agents/deployment/system_instructions_deployer.py +168 -46
  115. claude_mpm/services/agents/deployment/validation/deployment_validator.py +2 -2
  116. claude_mpm/services/agents/git_source_manager.py +629 -0
  117. claude_mpm/services/agents/loading/framework_agent_loader.py +1 -4
  118. claude_mpm/services/agents/local_template_manager.py +47 -9
  119. claude_mpm/services/agents/single_tier_deployment_service.py +696 -0
  120. claude_mpm/services/agents/sources/__init__.py +13 -0
  121. claude_mpm/services/agents/sources/agent_sync_state.py +516 -0
  122. claude_mpm/services/agents/sources/git_source_sync_service.py +1087 -0
  123. claude_mpm/services/agents/startup_sync.py +239 -0
  124. claude_mpm/services/agents/toolchain_detector.py +474 -0
  125. claude_mpm/services/analysis/__init__.py +25 -0
  126. claude_mpm/services/analysis/postmortem_reporter.py +474 -0
  127. claude_mpm/services/analysis/postmortem_service.py +765 -0
  128. claude_mpm/services/command_deployment_service.py +200 -6
  129. claude_mpm/services/core/base.py +7 -2
  130. claude_mpm/services/core/interfaces/__init__.py +1 -3
  131. claude_mpm/services/core/interfaces/health.py +1 -4
  132. claude_mpm/services/core/models/__init__.py +2 -11
  133. claude_mpm/services/diagnostics/checks/__init__.py +4 -0
  134. claude_mpm/services/diagnostics/checks/agent_sources_check.py +577 -0
  135. claude_mpm/services/diagnostics/checks/mcp_services_check.py +7 -15
  136. claude_mpm/services/diagnostics/checks/skill_sources_check.py +587 -0
  137. claude_mpm/services/diagnostics/diagnostic_runner.py +9 -0
  138. claude_mpm/services/diagnostics/doctor_reporter.py +34 -6
  139. claude_mpm/services/git/__init__.py +21 -0
  140. claude_mpm/services/git/git_operations_service.py +494 -0
  141. claude_mpm/services/github/__init__.py +21 -0
  142. claude_mpm/services/github/github_cli_service.py +397 -0
  143. claude_mpm/services/infrastructure/monitoring/__init__.py +1 -5
  144. claude_mpm/services/infrastructure/monitoring/aggregator.py +1 -6
  145. claude_mpm/services/instructions/__init__.py +9 -0
  146. claude_mpm/services/instructions/instruction_cache_service.py +374 -0
  147. claude_mpm/services/local_ops/__init__.py +3 -13
  148. claude_mpm/services/local_ops/health_checks/__init__.py +1 -3
  149. claude_mpm/services/local_ops/health_manager.py +1 -4
  150. claude_mpm/services/mcp_config_manager.py +75 -145
  151. claude_mpm/services/mcp_gateway/core/process_pool.py +22 -16
  152. claude_mpm/services/mcp_gateway/server/mcp_gateway.py +1 -6
  153. claude_mpm/services/mcp_service_verifier.py +6 -3
  154. claude_mpm/services/monitor/daemon.py +28 -8
  155. claude_mpm/services/monitor/daemon_manager.py +96 -19
  156. claude_mpm/services/pr/__init__.py +14 -0
  157. claude_mpm/services/pr/pr_template_service.py +329 -0
  158. claude_mpm/services/project/project_organizer.py +4 -0
  159. claude_mpm/services/runner_configuration_service.py +16 -3
  160. claude_mpm/services/session_management_service.py +16 -4
  161. claude_mpm/services/skills/__init__.py +18 -0
  162. claude_mpm/services/skills/git_skill_source_manager.py +1169 -0
  163. claude_mpm/services/skills/skill_discovery_service.py +568 -0
  164. claude_mpm/services/socketio/server/core.py +1 -4
  165. claude_mpm/services/socketio/server/main.py +1 -3
  166. claude_mpm/services/unified/deployment_strategies/vercel.py +1 -5
  167. claude_mpm/services/unified/unified_deployment.py +1 -5
  168. claude_mpm/services/visualization/__init__.py +1 -5
  169. claude_mpm/templates/questions/__init__.py +2 -7
  170. claude_mpm/templates/questions/pr_strategy.py +1 -4
  171. claude_mpm/templates/questions/project_init.py +1 -4
  172. claude_mpm/templates/questions/ticket_mgmt.py +1 -4
  173. claude_mpm/utils/agent_dependency_loader.py +77 -10
  174. claude_mpm/utils/agent_filters.py +288 -0
  175. claude_mpm/utils/gitignore.py +3 -0
  176. claude_mpm/utils/migration.py +372 -0
  177. claude_mpm/utils/progress.py +387 -0
  178. {claude_mpm-4.25.10.dist-info → claude_mpm-5.1.8.dist-info}/METADATA +356 -112
  179. {claude_mpm-4.25.10.dist-info → claude_mpm-5.1.8.dist-info}/RECORD +188 -439
  180. claude_mpm/agents/templates/agent-manager.json +0 -273
  181. claude_mpm/agents/templates/agentic-coder-optimizer.json +0 -248
  182. claude_mpm/agents/templates/api_qa.json +0 -183
  183. claude_mpm/agents/templates/clerk-ops.json +0 -235
  184. claude_mpm/agents/templates/code_analyzer.json +0 -101
  185. claude_mpm/agents/templates/content-agent.json +0 -358
  186. claude_mpm/agents/templates/dart_engineer.json +0 -307
  187. claude_mpm/agents/templates/data_engineer.json +0 -225
  188. claude_mpm/agents/templates/documentation.json +0 -238
  189. claude_mpm/agents/templates/engineer.json +0 -210
  190. claude_mpm/agents/templates/gcp_ops_agent.json +0 -253
  191. claude_mpm/agents/templates/golang_engineer.json +0 -270
  192. claude_mpm/agents/templates/imagemagick.json +0 -264
  193. claude_mpm/agents/templates/java_engineer.json +0 -346
  194. claude_mpm/agents/templates/javascript_engineer_agent.json +0 -380
  195. claude_mpm/agents/templates/local_ops_agent.json +0 -1840
  196. claude_mpm/agents/templates/memory_manager.json +0 -158
  197. claude_mpm/agents/templates/nextjs_engineer.json +0 -285
  198. claude_mpm/agents/templates/ops.json +0 -185
  199. claude_mpm/agents/templates/php-engineer.json +0 -287
  200. claude_mpm/agents/templates/product_owner.json +0 -338
  201. claude_mpm/agents/templates/project_organizer.json +0 -144
  202. claude_mpm/agents/templates/prompt-engineer.json +0 -737
  203. claude_mpm/agents/templates/python_engineer.json +0 -387
  204. claude_mpm/agents/templates/qa.json +0 -243
  205. claude_mpm/agents/templates/react_engineer.json +0 -239
  206. claude_mpm/agents/templates/refactoring_engineer.json +0 -276
  207. claude_mpm/agents/templates/research.json +0 -258
  208. claude_mpm/agents/templates/ruby-engineer.json +0 -280
  209. claude_mpm/agents/templates/rust_engineer.json +0 -275
  210. claude_mpm/agents/templates/security.json +0 -202
  211. claude_mpm/agents/templates/svelte-engineer.json +0 -225
  212. claude_mpm/agents/templates/tauri_engineer.json +0 -274
  213. claude_mpm/agents/templates/ticketing.json +0 -181
  214. claude_mpm/agents/templates/typescript_engineer.json +0 -285
  215. claude_mpm/agents/templates/vercel_ops_agent.json +0 -412
  216. claude_mpm/agents/templates/version_control.json +0 -159
  217. claude_mpm/agents/templates/web_qa.json +0 -400
  218. claude_mpm/agents/templates/web_ui.json +0 -189
  219. claude_mpm/cli/README.md +0 -253
  220. claude_mpm/cli/commands/mcp_install_commands.py.backup +0 -284
  221. claude_mpm/cli/commands/mpm_init/README.md +0 -365
  222. claude_mpm/cli_module/refactoring_guide.md +0 -253
  223. claude_mpm/commands/mpm-tickets.md +0 -151
  224. claude_mpm/config/agent_capabilities.yaml +0 -658
  225. claude_mpm/config/async_logging_config.yaml +0 -145
  226. claude_mpm/core/.claude-mpm/logs/hooks_20250730.log +0 -34
  227. claude_mpm/d2/.gitignore +0 -22
  228. claude_mpm/d2/ARCHITECTURE_COMPARISON.md +0 -273
  229. claude_mpm/d2/FLASK_INTEGRATION.md +0 -156
  230. claude_mpm/d2/IMPLEMENTATION_SUMMARY.md +0 -452
  231. claude_mpm/d2/QUICKSTART.md +0 -186
  232. claude_mpm/d2/README.md +0 -232
  233. claude_mpm/d2/STORE_FIX_SUMMARY.md +0 -167
  234. claude_mpm/d2/SVELTE5_STORES_GUIDE.md +0 -180
  235. claude_mpm/d2/TESTING.md +0 -288
  236. claude_mpm/d2/index.html +0 -118
  237. claude_mpm/d2/package.json +0 -19
  238. claude_mpm/d2/src/App.svelte +0 -110
  239. claude_mpm/d2/src/components/Header.svelte +0 -153
  240. claude_mpm/d2/src/components/MainContent.svelte +0 -74
  241. claude_mpm/d2/src/components/Sidebar.svelte +0 -85
  242. claude_mpm/d2/src/components/tabs/EventsTab.svelte +0 -326
  243. claude_mpm/d2/src/lib/socketio.js +0 -144
  244. claude_mpm/d2/src/main.js +0 -7
  245. claude_mpm/d2/src/stores/events.js +0 -114
  246. claude_mpm/d2/src/stores/socket.js +0 -108
  247. claude_mpm/d2/src/stores/theme.js +0 -65
  248. claude_mpm/d2/svelte.config.js +0 -12
  249. claude_mpm/d2/vite.config.js +0 -15
  250. claude_mpm/dashboard/.claude-mpm/memories/README.md +0 -36
  251. claude_mpm/dashboard/BUILD_NUMBER +0 -1
  252. claude_mpm/dashboard/README.md +0 -121
  253. claude_mpm/dashboard/VERSION +0 -1
  254. claude_mpm/dashboard/react/components/DataInspector/DataInspector.module.css +0 -188
  255. claude_mpm/dashboard/react/components/DataInspector/DataInspector.tsx +0 -273
  256. claude_mpm/dashboard/react/components/ErrorBoundary.tsx +0 -75
  257. claude_mpm/dashboard/react/components/EventViewer/EventViewer.module.css +0 -156
  258. claude_mpm/dashboard/react/components/EventViewer/EventViewer.tsx +0 -141
  259. claude_mpm/dashboard/react/components/shared/ConnectionStatus.module.css +0 -38
  260. claude_mpm/dashboard/react/components/shared/ConnectionStatus.tsx +0 -36
  261. claude_mpm/dashboard/react/components/shared/FilterBar.module.css +0 -92
  262. claude_mpm/dashboard/react/components/shared/FilterBar.tsx +0 -89
  263. claude_mpm/dashboard/react/contexts/DashboardContext.tsx +0 -215
  264. claude_mpm/dashboard/react/entries/events.tsx +0 -165
  265. claude_mpm/dashboard/react/hooks/useEvents.ts +0 -191
  266. claude_mpm/dashboard/react/hooks/useSocket.ts +0 -225
  267. claude_mpm/dashboard/static/archive/activity_dashboard_fixed.html +0 -248
  268. claude_mpm/dashboard/static/built/REFACTORING_SUMMARY.md +0 -170
  269. claude_mpm/dashboard/static/built/assets/events.DjpNxWNo.css +0 -1
  270. claude_mpm/dashboard/static/built/components/activity-tree.js +0 -2
  271. claude_mpm/dashboard/static/built/components/activity-tree.js.map +0 -1
  272. claude_mpm/dashboard/static/built/components/agent-hierarchy.js +0 -777
  273. claude_mpm/dashboard/static/built/components/agent-inference.js +0 -2
  274. claude_mpm/dashboard/static/built/components/agent-inference.js.map +0 -1
  275. claude_mpm/dashboard/static/built/components/build-tracker.js +0 -333
  276. claude_mpm/dashboard/static/built/components/code-simple.js +0 -857
  277. claude_mpm/dashboard/static/built/components/code-tree/tree-breadcrumb.js +0 -353
  278. claude_mpm/dashboard/static/built/components/code-tree/tree-constants.js +0 -235
  279. claude_mpm/dashboard/static/built/components/code-tree/tree-search.js +0 -409
  280. claude_mpm/dashboard/static/built/components/code-tree/tree-utils.js +0 -435
  281. claude_mpm/dashboard/static/built/components/code-tree.js +0 -2
  282. claude_mpm/dashboard/static/built/components/code-tree.js.map +0 -1
  283. claude_mpm/dashboard/static/built/components/code-viewer.js +0 -2
  284. claude_mpm/dashboard/static/built/components/code-viewer.js.map +0 -1
  285. claude_mpm/dashboard/static/built/components/connection-debug.js +0 -654
  286. claude_mpm/dashboard/static/built/components/diff-viewer.js +0 -891
  287. claude_mpm/dashboard/static/built/components/event-processor.js +0 -2
  288. claude_mpm/dashboard/static/built/components/event-processor.js.map +0 -1
  289. claude_mpm/dashboard/static/built/components/event-viewer.js +0 -2
  290. claude_mpm/dashboard/static/built/components/event-viewer.js.map +0 -1
  291. claude_mpm/dashboard/static/built/components/export-manager.js +0 -2
  292. claude_mpm/dashboard/static/built/components/export-manager.js.map +0 -1
  293. claude_mpm/dashboard/static/built/components/file-change-tracker.js +0 -443
  294. claude_mpm/dashboard/static/built/components/file-change-viewer.js +0 -690
  295. claude_mpm/dashboard/static/built/components/file-tool-tracker.js +0 -2
  296. claude_mpm/dashboard/static/built/components/file-tool-tracker.js.map +0 -1
  297. claude_mpm/dashboard/static/built/components/file-viewer.js +0 -2
  298. claude_mpm/dashboard/static/built/components/file-viewer.js.map +0 -1
  299. claude_mpm/dashboard/static/built/components/hud-library-loader.js +0 -2
  300. claude_mpm/dashboard/static/built/components/hud-library-loader.js.map +0 -1
  301. claude_mpm/dashboard/static/built/components/hud-manager.js +0 -2
  302. claude_mpm/dashboard/static/built/components/hud-manager.js.map +0 -1
  303. claude_mpm/dashboard/static/built/components/hud-visualizer.js +0 -2
  304. claude_mpm/dashboard/static/built/components/hud-visualizer.js.map +0 -1
  305. claude_mpm/dashboard/static/built/components/module-viewer.js +0 -2
  306. claude_mpm/dashboard/static/built/components/module-viewer.js.map +0 -1
  307. claude_mpm/dashboard/static/built/components/nav-bar.js +0 -145
  308. claude_mpm/dashboard/static/built/components/page-structure.js +0 -429
  309. claude_mpm/dashboard/static/built/components/session-manager.js +0 -2
  310. claude_mpm/dashboard/static/built/components/session-manager.js.map +0 -1
  311. claude_mpm/dashboard/static/built/components/socket-manager.js +0 -2
  312. claude_mpm/dashboard/static/built/components/socket-manager.js.map +0 -1
  313. claude_mpm/dashboard/static/built/components/ui-state-manager.js +0 -2
  314. claude_mpm/dashboard/static/built/components/ui-state-manager.js.map +0 -1
  315. claude_mpm/dashboard/static/built/components/unified-data-viewer.js +0 -2
  316. claude_mpm/dashboard/static/built/components/unified-data-viewer.js.map +0 -1
  317. claude_mpm/dashboard/static/built/components/working-directory.js +0 -2
  318. claude_mpm/dashboard/static/built/components/working-directory.js.map +0 -1
  319. claude_mpm/dashboard/static/built/connection-manager.js +0 -536
  320. claude_mpm/dashboard/static/built/dashboard.js +0 -2
  321. claude_mpm/dashboard/static/built/dashboard.js.map +0 -1
  322. claude_mpm/dashboard/static/built/extension-error-handler.js +0 -164
  323. claude_mpm/dashboard/static/built/react/events.js +0 -30
  324. claude_mpm/dashboard/static/built/react/events.js.map +0 -1
  325. claude_mpm/dashboard/static/built/shared/dom-helpers.js +0 -396
  326. claude_mpm/dashboard/static/built/shared/event-bus.js +0 -330
  327. claude_mpm/dashboard/static/built/shared/event-filter-service.js +0 -540
  328. claude_mpm/dashboard/static/built/shared/logger.js +0 -385
  329. claude_mpm/dashboard/static/built/shared/page-structure.js +0 -249
  330. claude_mpm/dashboard/static/built/shared/tooltip-service.js +0 -253
  331. claude_mpm/dashboard/static/built/socket-client.js +0 -2
  332. claude_mpm/dashboard/static/built/socket-client.js.map +0 -1
  333. claude_mpm/dashboard/static/built/tab-isolation-fix.js +0 -185
  334. claude_mpm/dashboard/static/events.html +0 -607
  335. claude_mpm/dashboard/static/index.html +0 -635
  336. claude_mpm/dashboard/static/js/REFACTORING_SUMMARY.md +0 -170
  337. claude_mpm/dashboard/static/js/shared/dom-helpers.js +0 -396
  338. claude_mpm/dashboard/static/js/shared/event-bus.js +0 -330
  339. claude_mpm/dashboard/static/js/shared/logger.js +0 -385
  340. claude_mpm/dashboard/static/js/shared/tooltip-service.js +0 -253
  341. claude_mpm/dashboard/static/js/stores/dashboard-store.js +0 -562
  342. claude_mpm/dashboard/static/legacy/activity.html +0 -736
  343. claude_mpm/dashboard/static/legacy/agents.html +0 -786
  344. claude_mpm/dashboard/static/legacy/files.html +0 -747
  345. claude_mpm/dashboard/static/legacy/tools.html +0 -831
  346. claude_mpm/dashboard/static/monitors.html +0 -431
  347. claude_mpm/dashboard/static/navigation-test-results.md +0 -118
  348. claude_mpm/dashboard/static/production/events.html +0 -659
  349. claude_mpm/dashboard/static/production/main.html +0 -698
  350. claude_mpm/dashboard/static/production/monitors.html +0 -483
  351. claude_mpm/dashboard/static/test-archive/dashboard.html +0 -635
  352. claude_mpm/dashboard/static/test-archive/debug-events.html +0 -147
  353. claude_mpm/dashboard/static/test-archive/test-navigation.html +0 -256
  354. claude_mpm/dashboard/static/test-archive/test-react-exports.html +0 -180
  355. claude_mpm/dashboard/templates/.claude-mpm/memories/README.md +0 -36
  356. claude_mpm/dashboard/templates/.claude-mpm/memories/engineer_agent.md +0 -39
  357. claude_mpm/dashboard/templates/.claude-mpm/memories/version_control_agent.md +0 -38
  358. claude_mpm/hooks/README.md +0 -143
  359. claude_mpm/hooks/templates/README.md +0 -180
  360. claude_mpm/hooks/templates/settings.json.example +0 -147
  361. claude_mpm/schemas/agent_schema.json +0 -596
  362. claude_mpm/schemas/frontmatter_schema.json +0 -165
  363. claude_mpm/services/event_bus/README.md +0 -244
  364. claude_mpm/services/events/README.md +0 -303
  365. claude_mpm/services/framework_claude_md_generator/README.md +0 -119
  366. claude_mpm/services/mcp_gateway/README.md +0 -185
  367. claude_mpm/services/socketio/handlers/connection.py.backup +0 -217
  368. claude_mpm/services/socketio/handlers/hook.py.backup +0 -154
  369. claude_mpm/services/static/.gitkeep +0 -2
  370. claude_mpm/services/version_control/VERSION +0 -1
  371. claude_mpm/skills/bundled/.gitkeep +0 -2
  372. claude_mpm/skills/bundled/collaboration/brainstorming/SKILL.md +0 -79
  373. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/SKILL.md +0 -178
  374. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/agent-prompts.md +0 -577
  375. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/coordination-patterns.md +0 -467
  376. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/examples.md +0 -537
  377. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/troubleshooting.md +0 -730
  378. claude_mpm/skills/bundled/collaboration/git-worktrees.md +0 -317
  379. claude_mpm/skills/bundled/collaboration/requesting-code-review/SKILL.md +0 -112
  380. claude_mpm/skills/bundled/collaboration/requesting-code-review/references/code-reviewer-template.md +0 -146
  381. claude_mpm/skills/bundled/collaboration/requesting-code-review/references/review-examples.md +0 -412
  382. claude_mpm/skills/bundled/collaboration/stacked-prs.md +0 -251
  383. claude_mpm/skills/bundled/collaboration/writing-plans/SKILL.md +0 -81
  384. claude_mpm/skills/bundled/collaboration/writing-plans/references/best-practices.md +0 -362
  385. claude_mpm/skills/bundled/collaboration/writing-plans/references/plan-structure-templates.md +0 -312
  386. claude_mpm/skills/bundled/debugging/root-cause-tracing/SKILL.md +0 -152
  387. claude_mpm/skills/bundled/debugging/root-cause-tracing/find-polluter.sh +0 -63
  388. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/advanced-techniques.md +0 -668
  389. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/examples.md +0 -587
  390. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/integration.md +0 -438
  391. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/tracing-techniques.md +0 -391
  392. claude_mpm/skills/bundled/debugging/systematic-debugging/CREATION-LOG.md +0 -119
  393. claude_mpm/skills/bundled/debugging/systematic-debugging/SKILL.md +0 -148
  394. claude_mpm/skills/bundled/debugging/systematic-debugging/references/anti-patterns.md +0 -483
  395. claude_mpm/skills/bundled/debugging/systematic-debugging/references/examples.md +0 -452
  396. claude_mpm/skills/bundled/debugging/systematic-debugging/references/troubleshooting.md +0 -449
  397. claude_mpm/skills/bundled/debugging/systematic-debugging/references/workflow.md +0 -411
  398. claude_mpm/skills/bundled/debugging/systematic-debugging/test-academic.md +0 -14
  399. claude_mpm/skills/bundled/debugging/systematic-debugging/test-pressure-1.md +0 -58
  400. claude_mpm/skills/bundled/debugging/systematic-debugging/test-pressure-2.md +0 -68
  401. claude_mpm/skills/bundled/debugging/systematic-debugging/test-pressure-3.md +0 -69
  402. claude_mpm/skills/bundled/debugging/verification-before-completion/SKILL.md +0 -131
  403. claude_mpm/skills/bundled/debugging/verification-before-completion/references/gate-function.md +0 -325
  404. claude_mpm/skills/bundled/debugging/verification-before-completion/references/integration-and-workflows.md +0 -490
  405. claude_mpm/skills/bundled/debugging/verification-before-completion/references/red-flags-and-failures.md +0 -425
  406. claude_mpm/skills/bundled/debugging/verification-before-completion/references/verification-patterns.md +0 -499
  407. claude_mpm/skills/bundled/infrastructure/env-manager/INTEGRATION.md +0 -611
  408. claude_mpm/skills/bundled/infrastructure/env-manager/README.md +0 -596
  409. claude_mpm/skills/bundled/infrastructure/env-manager/SKILL.md +0 -260
  410. claude_mpm/skills/bundled/infrastructure/env-manager/examples/nextjs-env-structure.md +0 -315
  411. claude_mpm/skills/bundled/infrastructure/env-manager/references/frameworks.md +0 -436
  412. claude_mpm/skills/bundled/infrastructure/env-manager/references/security.md +0 -433
  413. claude_mpm/skills/bundled/infrastructure/env-manager/references/synchronization.md +0 -452
  414. claude_mpm/skills/bundled/infrastructure/env-manager/references/troubleshooting.md +0 -404
  415. claude_mpm/skills/bundled/infrastructure/env-manager/references/validation.md +0 -420
  416. claude_mpm/skills/bundled/main/artifacts-builder/LICENSE.txt +0 -202
  417. claude_mpm/skills/bundled/main/artifacts-builder/SKILL.md +0 -86
  418. claude_mpm/skills/bundled/main/artifacts-builder/scripts/bundle-artifact.sh +0 -54
  419. claude_mpm/skills/bundled/main/artifacts-builder/scripts/init-artifact.sh +0 -322
  420. claude_mpm/skills/bundled/main/artifacts-builder/scripts/shadcn-components.tar.gz +0 -0
  421. claude_mpm/skills/bundled/main/internal-comms/LICENSE.txt +0 -202
  422. claude_mpm/skills/bundled/main/internal-comms/SKILL.md +0 -43
  423. claude_mpm/skills/bundled/main/internal-comms/examples/3p-updates.md +0 -47
  424. claude_mpm/skills/bundled/main/internal-comms/examples/company-newsletter.md +0 -65
  425. claude_mpm/skills/bundled/main/internal-comms/examples/faq-answers.md +0 -30
  426. claude_mpm/skills/bundled/main/internal-comms/examples/general-comms.md +0 -16
  427. claude_mpm/skills/bundled/main/mcp-builder/LICENSE.txt +0 -202
  428. claude_mpm/skills/bundled/main/mcp-builder/SKILL.md +0 -160
  429. claude_mpm/skills/bundled/main/mcp-builder/reference/design_principles.md +0 -412
  430. claude_mpm/skills/bundled/main/mcp-builder/reference/evaluation.md +0 -602
  431. claude_mpm/skills/bundled/main/mcp-builder/reference/mcp_best_practices.md +0 -915
  432. claude_mpm/skills/bundled/main/mcp-builder/reference/node_mcp_server.md +0 -916
  433. claude_mpm/skills/bundled/main/mcp-builder/reference/python_mcp_server.md +0 -752
  434. claude_mpm/skills/bundled/main/mcp-builder/reference/workflow.md +0 -1237
  435. claude_mpm/skills/bundled/main/mcp-builder/scripts/example_evaluation.xml +0 -22
  436. claude_mpm/skills/bundled/main/mcp-builder/scripts/requirements.txt +0 -2
  437. claude_mpm/skills/bundled/main/skill-creator/LICENSE.txt +0 -202
  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/react/flexlayout-react.md +0 -742
  452. claude_mpm/skills/bundled/rust/desktop-applications/SKILL.md +0 -226
  453. claude_mpm/skills/bundled/rust/desktop-applications/references/architecture-patterns.md +0 -901
  454. claude_mpm/skills/bundled/rust/desktop-applications/references/native-gui-frameworks.md +0 -901
  455. claude_mpm/skills/bundled/rust/desktop-applications/references/platform-integration.md +0 -775
  456. claude_mpm/skills/bundled/rust/desktop-applications/references/state-management.md +0 -937
  457. claude_mpm/skills/bundled/rust/desktop-applications/references/tauri-framework.md +0 -770
  458. claude_mpm/skills/bundled/rust/desktop-applications/references/testing-deployment.md +0 -961
  459. claude_mpm/skills/bundled/tauri/tauri-async-patterns.md +0 -495
  460. claude_mpm/skills/bundled/tauri/tauri-build-deploy.md +0 -599
  461. claude_mpm/skills/bundled/tauri/tauri-command-patterns.md +0 -535
  462. claude_mpm/skills/bundled/tauri/tauri-error-handling.md +0 -613
  463. claude_mpm/skills/bundled/tauri/tauri-event-system.md +0 -648
  464. claude_mpm/skills/bundled/tauri/tauri-file-system.md +0 -673
  465. claude_mpm/skills/bundled/tauri/tauri-frontend-integration.md +0 -767
  466. claude_mpm/skills/bundled/tauri/tauri-performance.md +0 -669
  467. claude_mpm/skills/bundled/tauri/tauri-state-management.md +0 -573
  468. claude_mpm/skills/bundled/tauri/tauri-testing.md +0 -384
  469. claude_mpm/skills/bundled/tauri/tauri-window-management.md +0 -628
  470. claude_mpm/skills/bundled/testing/condition-based-waiting/SKILL.md +0 -119
  471. claude_mpm/skills/bundled/testing/condition-based-waiting/example.ts +0 -158
  472. claude_mpm/skills/bundled/testing/condition-based-waiting/references/patterns-and-implementation.md +0 -253
  473. claude_mpm/skills/bundled/testing/test-driven-development/SKILL.md +0 -145
  474. claude_mpm/skills/bundled/testing/test-driven-development/references/anti-patterns.md +0 -543
  475. claude_mpm/skills/bundled/testing/test-driven-development/references/examples.md +0 -741
  476. claude_mpm/skills/bundled/testing/test-driven-development/references/integration.md +0 -470
  477. claude_mpm/skills/bundled/testing/test-driven-development/references/philosophy.md +0 -458
  478. claude_mpm/skills/bundled/testing/test-driven-development/references/workflow.md +0 -639
  479. claude_mpm/skills/bundled/testing/test-quality-inspector/SKILL.md +0 -458
  480. claude_mpm/skills/bundled/testing/test-quality-inspector/examples/example-inspection-report.md +0 -411
  481. claude_mpm/skills/bundled/testing/test-quality-inspector/references/assertion-quality.md +0 -317
  482. claude_mpm/skills/bundled/testing/test-quality-inspector/references/inspection-checklist.md +0 -270
  483. claude_mpm/skills/bundled/testing/test-quality-inspector/references/red-flags.md +0 -436
  484. claude_mpm/skills/bundled/testing/testing-anti-patterns/SKILL.md +0 -140
  485. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/completeness-anti-patterns.md +0 -572
  486. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/core-anti-patterns.md +0 -411
  487. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/detection-guide.md +0 -569
  488. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/tdd-connection.md +0 -695
  489. claude_mpm/skills/bundled/testing/webapp-testing/LICENSE.txt +0 -202
  490. claude_mpm/skills/bundled/testing/webapp-testing/SKILL.md +0 -184
  491. claude_mpm/skills/bundled/testing/webapp-testing/decision-tree.md +0 -459
  492. claude_mpm/skills/bundled/testing/webapp-testing/playwright-patterns.md +0 -479
  493. claude_mpm/skills/bundled/testing/webapp-testing/reconnaissance-pattern.md +0 -687
  494. claude_mpm/skills/bundled/testing/webapp-testing/server-management.md +0 -758
  495. claude_mpm/skills/bundled/testing/webapp-testing/troubleshooting.md +0 -868
  496. claude_mpm/templates/questions/EXAMPLES.md +0 -501
  497. claude_mpm/tools/README_SOCKETIO_DEBUG.md +0 -224
  498. claude_mpm/tools/code_tree_analyzer/README.md +0 -64
  499. /claude_mpm/agents/templates/{git_file_tracking.md → git-file-tracking.md} +0 -0
  500. /claude_mpm/agents/templates/{pm_examples.md → pm-examples.md} +0 -0
  501. /claude_mpm/agents/templates/{pm_red_flags.md → pm-red-flags.md} +0 -0
  502. /claude_mpm/agents/templates/{response_format.md → response-format.md} +0 -0
  503. /claude_mpm/agents/templates/{validation_templates.md → validation-templates.md} +0 -0
  504. {claude_mpm-4.25.10.dist-info → claude_mpm-5.1.8.dist-info}/WHEEL +0 -0
  505. {claude_mpm-4.25.10.dist-info → claude_mpm-5.1.8.dist-info}/entry_points.txt +0 -0
  506. {claude_mpm-4.25.10.dist-info → claude_mpm-5.1.8.dist-info}/licenses/LICENSE +0 -0
  507. {claude_mpm-4.25.10.dist-info → claude_mpm-5.1.8.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