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,916 +0,0 @@
1
- # Node/TypeScript MCP Server Implementation Guide
2
-
3
- ## Overview
4
-
5
- This document provides Node/TypeScript-specific best practices and examples for implementing MCP servers using the MCP TypeScript SDK. It covers project structure, server setup, tool registration patterns, input validation with Zod, error handling, and complete working examples.
6
-
7
- ---
8
-
9
- ## Quick Reference
10
-
11
- ### Key Imports
12
- ```typescript
13
- import { McpServer } from "@modelcontextprotocol/sdk/server/mcp.js";
14
- import { StdioServerTransport } from "@modelcontextprotocol/sdk/server/stdio.js";
15
- import { z } from "zod";
16
- import axios, { AxiosError } from "axios";
17
- ```
18
-
19
- ### Server Initialization
20
- ```typescript
21
- const server = new McpServer({
22
- name: "service-mcp-server",
23
- version: "1.0.0"
24
- });
25
- ```
26
-
27
- ### Tool Registration Pattern
28
- ```typescript
29
- server.registerTool("tool_name", {...config}, async (params) => {
30
- // Implementation
31
- });
32
- ```
33
-
34
- ---
35
-
36
- ## MCP TypeScript SDK
37
-
38
- The official MCP TypeScript SDK provides:
39
- - `McpServer` class for server initialization
40
- - `registerTool` method for tool registration
41
- - Zod schema integration for runtime input validation
42
- - Type-safe tool handler implementations
43
-
44
- See the MCP SDK documentation in the references for complete details.
45
-
46
- ## Server Naming Convention
47
-
48
- Node/TypeScript MCP servers must follow this naming pattern:
49
- - **Format**: `{service}-mcp-server` (lowercase with hyphens)
50
- - **Examples**: `github-mcp-server`, `jira-mcp-server`, `stripe-mcp-server`
51
-
52
- The name should be:
53
- - General (not tied to specific features)
54
- - Descriptive of the service/API being integrated
55
- - Easy to infer from the task description
56
- - Without version numbers or dates
57
-
58
- ## Project Structure
59
-
60
- Create the following structure for Node/TypeScript MCP servers:
61
-
62
- ```
63
- {service}-mcp-server/
64
- ├── package.json
65
- ├── tsconfig.json
66
- ├── README.md
67
- ├── src/
68
- │ ├── index.ts # Main entry point with McpServer initialization
69
- │ ├── types.ts # TypeScript type definitions and interfaces
70
- │ ├── tools/ # Tool implementations (one file per domain)
71
- │ ├── services/ # API clients and shared utilities
72
- │ ├── schemas/ # Zod validation schemas
73
- │ └── constants.ts # Shared constants (API_URL, CHARACTER_LIMIT, etc.)
74
- └── dist/ # Built JavaScript files (entry point: dist/index.js)
75
- ```
76
-
77
- ## Tool Implementation
78
-
79
- ### Tool Naming
80
-
81
- Use snake_case for tool names (e.g., "search_users", "create_project", "get_channel_info") with clear, action-oriented names.
82
-
83
- **Avoid Naming Conflicts**: Include the service context to prevent overlaps:
84
- - Use "slack_send_message" instead of just "send_message"
85
- - Use "github_create_issue" instead of just "create_issue"
86
- - Use "asana_list_tasks" instead of just "list_tasks"
87
-
88
- ### Tool Structure
89
-
90
- Tools are registered using the `registerTool` method with the following requirements:
91
- - Use Zod schemas for runtime input validation and type safety
92
- - The `description` field must be explicitly provided - JSDoc comments are NOT automatically extracted
93
- - Explicitly provide `title`, `description`, `inputSchema`, and `annotations`
94
- - The `inputSchema` must be a Zod schema object (not a JSON schema)
95
- - Type all parameters and return values explicitly
96
-
97
- ```typescript
98
- import { McpServer } from "@modelcontextprotocol/sdk/server/mcp.js";
99
- import { z } from "zod";
100
-
101
- const server = new McpServer({
102
- name: "example-mcp",
103
- version: "1.0.0"
104
- });
105
-
106
- // Zod schema for input validation
107
- const UserSearchInputSchema = z.object({
108
- query: z.string()
109
- .min(2, "Query must be at least 2 characters")
110
- .max(200, "Query must not exceed 200 characters")
111
- .describe("Search string to match against names/emails"),
112
- limit: z.number()
113
- .int()
114
- .min(1)
115
- .max(100)
116
- .default(20)
117
- .describe("Maximum results to return"),
118
- offset: z.number()
119
- .int()
120
- .min(0)
121
- .default(0)
122
- .describe("Number of results to skip for pagination"),
123
- response_format: z.nativeEnum(ResponseFormat)
124
- .default(ResponseFormat.MARKDOWN)
125
- .describe("Output format: 'markdown' for human-readable or 'json' for machine-readable")
126
- }).strict();
127
-
128
- // Type definition from Zod schema
129
- type UserSearchInput = z.infer<typeof UserSearchInputSchema>;
130
-
131
- server.registerTool(
132
- "example_search_users",
133
- {
134
- title: "Search Example Users",
135
- description: `Search for users in the Example system by name, email, or team.
136
-
137
- This tool searches across all user profiles in the Example platform, supporting partial matches and various search filters. It does NOT create or modify users, only searches existing ones.
138
-
139
- Args:
140
- - query (string): Search string to match against names/emails
141
- - limit (number): Maximum results to return, between 1-100 (default: 20)
142
- - offset (number): Number of results to skip for pagination (default: 0)
143
- - response_format ('markdown' | 'json'): Output format (default: 'markdown')
144
-
145
- Returns:
146
- For JSON format: Structured data with schema:
147
- {
148
- "total": number, // Total number of matches found
149
- "count": number, // Number of results in this response
150
- "offset": number, // Current pagination offset
151
- "users": [
152
- {
153
- "id": string, // User ID (e.g., "U123456789")
154
- "name": string, // Full name (e.g., "John Doe")
155
- "email": string, // Email address
156
- "team": string, // Team name (optional)
157
- "active": boolean // Whether user is active
158
- }
159
- ],
160
- "has_more": boolean, // Whether more results are available
161
- "next_offset": number // Offset for next page (if has_more is true)
162
- }
163
-
164
- Examples:
165
- - Use when: "Find all marketing team members" -> params with query="team:marketing"
166
- - Use when: "Search for John's account" -> params with query="john"
167
- - Don't use when: You need to create a user (use example_create_user instead)
168
-
169
- Error Handling:
170
- - Returns "Error: Rate limit exceeded" if too many requests (429 status)
171
- - Returns "No users found matching '<query>'" if search returns empty`,
172
- inputSchema: UserSearchInputSchema,
173
- annotations: {
174
- readOnlyHint: true,
175
- destructiveHint: false,
176
- idempotentHint: true,
177
- openWorldHint: true
178
- }
179
- },
180
- async (params: UserSearchInput) => {
181
- try {
182
- // Input validation is handled by Zod schema
183
- // Make API request using validated parameters
184
- const data = await makeApiRequest<any>(
185
- "users/search",
186
- "GET",
187
- undefined,
188
- {
189
- q: params.query,
190
- limit: params.limit,
191
- offset: params.offset
192
- }
193
- );
194
-
195
- const users = data.users || [];
196
- const total = data.total || 0;
197
-
198
- if (!users.length) {
199
- return {
200
- content: [{
201
- type: "text",
202
- text: `No users found matching '${params.query}'`
203
- }]
204
- };
205
- }
206
-
207
- // Format response based on requested format
208
- let result: string;
209
-
210
- if (params.response_format === ResponseFormat.MARKDOWN) {
211
- // Human-readable markdown format
212
- const lines: string[] = [`# User Search Results: '${params.query}'`, ""];
213
- lines.push(`Found ${total} users (showing ${users.length})`);
214
- lines.push("");
215
-
216
- for (const user of users) {
217
- lines.push(`## ${user.name} (${user.id})`);
218
- lines.push(`- **Email**: ${user.email}`);
219
- if (user.team) {
220
- lines.push(`- **Team**: ${user.team}`);
221
- }
222
- lines.push("");
223
- }
224
-
225
- result = lines.join("\n");
226
-
227
- } else {
228
- // Machine-readable JSON format
229
- const response: any = {
230
- total,
231
- count: users.length,
232
- offset: params.offset,
233
- users: users.map((user: any) => ({
234
- id: user.id,
235
- name: user.name,
236
- email: user.email,
237
- ...(user.team ? { team: user.team } : {}),
238
- active: user.active ?? true
239
- }))
240
- };
241
-
242
- // Add pagination info if there are more results
243
- if (total > params.offset + users.length) {
244
- response.has_more = true;
245
- response.next_offset = params.offset + users.length;
246
- }
247
-
248
- result = JSON.stringify(response, null, 2);
249
- }
250
-
251
- return {
252
- content: [{
253
- type: "text",
254
- text: result
255
- }]
256
- };
257
- } catch (error) {
258
- return {
259
- content: [{
260
- type: "text",
261
- text: handleApiError(error)
262
- }]
263
- };
264
- }
265
- }
266
- );
267
- ```
268
-
269
- ## Zod Schemas for Input Validation
270
-
271
- Zod provides runtime type validation:
272
-
273
- ```typescript
274
- import { z } from "zod";
275
-
276
- // Basic schema with validation
277
- const CreateUserSchema = z.object({
278
- name: z.string()
279
- .min(1, "Name is required")
280
- .max(100, "Name must not exceed 100 characters"),
281
- email: z.string()
282
- .email("Invalid email format"),
283
- age: z.number()
284
- .int("Age must be a whole number")
285
- .min(0, "Age cannot be negative")
286
- .max(150, "Age cannot be greater than 150")
287
- }).strict(); // Use .strict() to forbid extra fields
288
-
289
- // Enums
290
- enum ResponseFormat {
291
- MARKDOWN = "markdown",
292
- JSON = "json"
293
- }
294
-
295
- const SearchSchema = z.object({
296
- response_format: z.nativeEnum(ResponseFormat)
297
- .default(ResponseFormat.MARKDOWN)
298
- .describe("Output format")
299
- });
300
-
301
- // Optional fields with defaults
302
- const PaginationSchema = z.object({
303
- limit: z.number()
304
- .int()
305
- .min(1)
306
- .max(100)
307
- .default(20)
308
- .describe("Maximum results to return"),
309
- offset: z.number()
310
- .int()
311
- .min(0)
312
- .default(0)
313
- .describe("Number of results to skip")
314
- });
315
- ```
316
-
317
- ## Response Format Options
318
-
319
- Support multiple output formats for flexibility:
320
-
321
- ```typescript
322
- enum ResponseFormat {
323
- MARKDOWN = "markdown",
324
- JSON = "json"
325
- }
326
-
327
- const inputSchema = z.object({
328
- query: z.string(),
329
- response_format: z.nativeEnum(ResponseFormat)
330
- .default(ResponseFormat.MARKDOWN)
331
- .describe("Output format: 'markdown' for human-readable or 'json' for machine-readable")
332
- });
333
- ```
334
-
335
- **Markdown format**:
336
- - Use headers, lists, and formatting for clarity
337
- - Convert timestamps to human-readable format
338
- - Show display names with IDs in parentheses
339
- - Omit verbose metadata
340
- - Group related information logically
341
-
342
- **JSON format**:
343
- - Return complete, structured data suitable for programmatic processing
344
- - Include all available fields and metadata
345
- - Use consistent field names and types
346
-
347
- ## Pagination Implementation
348
-
349
- For tools that list resources:
350
-
351
- ```typescript
352
- const ListSchema = z.object({
353
- limit: z.number().int().min(1).max(100).default(20),
354
- offset: z.number().int().min(0).default(0)
355
- });
356
-
357
- async function listItems(params: z.infer<typeof ListSchema>) {
358
- const data = await apiRequest(params.limit, params.offset);
359
-
360
- const response = {
361
- total: data.total,
362
- count: data.items.length,
363
- offset: params.offset,
364
- items: data.items,
365
- has_more: data.total > params.offset + data.items.length,
366
- next_offset: data.total > params.offset + data.items.length
367
- ? params.offset + data.items.length
368
- : undefined
369
- };
370
-
371
- return JSON.stringify(response, null, 2);
372
- }
373
- ```
374
-
375
- ## Character Limits and Truncation
376
-
377
- Add a CHARACTER_LIMIT constant to prevent overwhelming responses:
378
-
379
- ```typescript
380
- // At module level in constants.ts
381
- export const CHARACTER_LIMIT = 25000; // Maximum response size in characters
382
-
383
- async function searchTool(params: SearchInput) {
384
- let result = generateResponse(data);
385
-
386
- // Check character limit and truncate if needed
387
- if (result.length > CHARACTER_LIMIT) {
388
- const truncatedData = data.slice(0, Math.max(1, data.length / 2));
389
- response.data = truncatedData;
390
- response.truncated = true;
391
- response.truncation_message =
392
- `Response truncated from ${data.length} to ${truncatedData.length} items. ` +
393
- `Use 'offset' parameter or add filters to see more results.`;
394
- result = JSON.stringify(response, null, 2);
395
- }
396
-
397
- return result;
398
- }
399
- ```
400
-
401
- ## Error Handling
402
-
403
- Provide clear, actionable error messages:
404
-
405
- ```typescript
406
- import axios, { AxiosError } from "axios";
407
-
408
- function handleApiError(error: unknown): string {
409
- if (error instanceof AxiosError) {
410
- if (error.response) {
411
- switch (error.response.status) {
412
- case 404:
413
- return "Error: Resource not found. Please check the ID is correct.";
414
- case 403:
415
- return "Error: Permission denied. You don't have access to this resource.";
416
- case 429:
417
- return "Error: Rate limit exceeded. Please wait before making more requests.";
418
- default:
419
- return `Error: API request failed with status ${error.response.status}`;
420
- }
421
- } else if (error.code === "ECONNABORTED") {
422
- return "Error: Request timed out. Please try again.";
423
- }
424
- }
425
- return `Error: Unexpected error occurred: ${error instanceof Error ? error.message : String(error)}`;
426
- }
427
- ```
428
-
429
- ## Shared Utilities
430
-
431
- Extract common functionality into reusable functions:
432
-
433
- ```typescript
434
- // Shared API request function
435
- async function makeApiRequest<T>(
436
- endpoint: string,
437
- method: "GET" | "POST" | "PUT" | "DELETE" = "GET",
438
- data?: any,
439
- params?: any
440
- ): Promise<T> {
441
- try {
442
- const response = await axios({
443
- method,
444
- url: `${API_BASE_URL}/${endpoint}`,
445
- data,
446
- params,
447
- timeout: 30000,
448
- headers: {
449
- "Content-Type": "application/json",
450
- "Accept": "application/json"
451
- }
452
- });
453
- return response.data;
454
- } catch (error) {
455
- throw error;
456
- }
457
- }
458
- ```
459
-
460
- ## Async/Await Best Practices
461
-
462
- Always use async/await for network requests and I/O operations:
463
-
464
- ```typescript
465
- // Good: Async network request
466
- async function fetchData(resourceId: string): Promise<ResourceData> {
467
- const response = await axios.get(`${API_URL}/resource/${resourceId}`);
468
- return response.data;
469
- }
470
-
471
- // Bad: Promise chains
472
- function fetchData(resourceId: string): Promise<ResourceData> {
473
- return axios.get(`${API_URL}/resource/${resourceId}`)
474
- .then(response => response.data); // Harder to read and maintain
475
- }
476
- ```
477
-
478
- ## TypeScript Best Practices
479
-
480
- 1. **Use Strict TypeScript**: Enable strict mode in tsconfig.json
481
- 2. **Define Interfaces**: Create clear interface definitions for all data structures
482
- 3. **Avoid `any`**: Use proper types or `unknown` instead of `any`
483
- 4. **Zod for Runtime Validation**: Use Zod schemas to validate external data
484
- 5. **Type Guards**: Create type guard functions for complex type checking
485
- 6. **Error Handling**: Always use try-catch with proper error type checking
486
- 7. **Null Safety**: Use optional chaining (`?.`) and nullish coalescing (`??`)
487
-
488
- ```typescript
489
- // Good: Type-safe with Zod and interfaces
490
- interface UserResponse {
491
- id: string;
492
- name: string;
493
- email: string;
494
- team?: string;
495
- active: boolean;
496
- }
497
-
498
- const UserSchema = z.object({
499
- id: z.string(),
500
- name: z.string(),
501
- email: z.string().email(),
502
- team: z.string().optional(),
503
- active: z.boolean()
504
- });
505
-
506
- type User = z.infer<typeof UserSchema>;
507
-
508
- async function getUser(id: string): Promise<User> {
509
- const data = await apiCall(`/users/${id}`);
510
- return UserSchema.parse(data); // Runtime validation
511
- }
512
-
513
- // Bad: Using any
514
- async function getUser(id: string): Promise<any> {
515
- return await apiCall(`/users/${id}`); // No type safety
516
- }
517
- ```
518
-
519
- ## Package Configuration
520
-
521
- ### package.json
522
-
523
- ```json
524
- {
525
- "name": "{service}-mcp-server",
526
- "version": "1.0.0",
527
- "description": "MCP server for {Service} API integration",
528
- "type": "module",
529
- "main": "dist/index.js",
530
- "scripts": {
531
- "start": "node dist/index.js",
532
- "dev": "tsx watch src/index.ts",
533
- "build": "tsc",
534
- "clean": "rm -rf dist"
535
- },
536
- "engines": {
537
- "node": ">=18"
538
- },
539
- "dependencies": {
540
- "@modelcontextprotocol/sdk": "^1.6.1",
541
- "axios": "^1.7.9",
542
- "zod": "^3.23.8"
543
- },
544
- "devDependencies": {
545
- "@types/node": "^22.10.0",
546
- "tsx": "^4.19.2",
547
- "typescript": "^5.7.2"
548
- }
549
- }
550
- ```
551
-
552
- ### tsconfig.json
553
-
554
- ```json
555
- {
556
- "compilerOptions": {
557
- "target": "ES2022",
558
- "module": "Node16",
559
- "moduleResolution": "Node16",
560
- "lib": ["ES2022"],
561
- "outDir": "./dist",
562
- "rootDir": "./src",
563
- "strict": true,
564
- "esModuleInterop": true,
565
- "skipLibCheck": true,
566
- "forceConsistentCasingInFileNames": true,
567
- "declaration": true,
568
- "declarationMap": true,
569
- "sourceMap": true,
570
- "allowSyntheticDefaultImports": true
571
- },
572
- "include": ["src/**/*"],
573
- "exclude": ["node_modules", "dist"]
574
- }
575
- ```
576
-
577
- ## Complete Example
578
-
579
- ```typescript
580
- #!/usr/bin/env node
581
- /**
582
- * MCP Server for Example Service.
583
- *
584
- * This server provides tools to interact with Example API, including user search,
585
- * project management, and data export capabilities.
586
- */
587
-
588
- import { McpServer } from "@modelcontextprotocol/sdk/server/mcp.js";
589
- import { StdioServerTransport } from "@modelcontextprotocol/sdk/server/stdio.js";
590
- import { z } from "zod";
591
- import axios, { AxiosError } from "axios";
592
-
593
- // Constants
594
- const API_BASE_URL = "https://api.example.com/v1";
595
- const CHARACTER_LIMIT = 25000;
596
-
597
- // Enums
598
- enum ResponseFormat {
599
- MARKDOWN = "markdown",
600
- JSON = "json"
601
- }
602
-
603
- // Zod schemas
604
- const UserSearchInputSchema = z.object({
605
- query: z.string()
606
- .min(2, "Query must be at least 2 characters")
607
- .max(200, "Query must not exceed 200 characters")
608
- .describe("Search string to match against names/emails"),
609
- limit: z.number()
610
- .int()
611
- .min(1)
612
- .max(100)
613
- .default(20)
614
- .describe("Maximum results to return"),
615
- offset: z.number()
616
- .int()
617
- .min(0)
618
- .default(0)
619
- .describe("Number of results to skip for pagination"),
620
- response_format: z.nativeEnum(ResponseFormat)
621
- .default(ResponseFormat.MARKDOWN)
622
- .describe("Output format: 'markdown' for human-readable or 'json' for machine-readable")
623
- }).strict();
624
-
625
- type UserSearchInput = z.infer<typeof UserSearchInputSchema>;
626
-
627
- // Shared utility functions
628
- async function makeApiRequest<T>(
629
- endpoint: string,
630
- method: "GET" | "POST" | "PUT" | "DELETE" = "GET",
631
- data?: any,
632
- params?: any
633
- ): Promise<T> {
634
- try {
635
- const response = await axios({
636
- method,
637
- url: `${API_BASE_URL}/${endpoint}`,
638
- data,
639
- params,
640
- timeout: 30000,
641
- headers: {
642
- "Content-Type": "application/json",
643
- "Accept": "application/json"
644
- }
645
- });
646
- return response.data;
647
- } catch (error) {
648
- throw error;
649
- }
650
- }
651
-
652
- function handleApiError(error: unknown): string {
653
- if (error instanceof AxiosError) {
654
- if (error.response) {
655
- switch (error.response.status) {
656
- case 404:
657
- return "Error: Resource not found. Please check the ID is correct.";
658
- case 403:
659
- return "Error: Permission denied. You don't have access to this resource.";
660
- case 429:
661
- return "Error: Rate limit exceeded. Please wait before making more requests.";
662
- default:
663
- return `Error: API request failed with status ${error.response.status}`;
664
- }
665
- } else if (error.code === "ECONNABORTED") {
666
- return "Error: Request timed out. Please try again.";
667
- }
668
- }
669
- return `Error: Unexpected error occurred: ${error instanceof Error ? error.message : String(error)}`;
670
- }
671
-
672
- // Create MCP server instance
673
- const server = new McpServer({
674
- name: "example-mcp",
675
- version: "1.0.0"
676
- });
677
-
678
- // Register tools
679
- server.registerTool(
680
- "example_search_users",
681
- {
682
- title: "Search Example Users",
683
- description: `[Full description as shown above]`,
684
- inputSchema: UserSearchInputSchema,
685
- annotations: {
686
- readOnlyHint: true,
687
- destructiveHint: false,
688
- idempotentHint: true,
689
- openWorldHint: true
690
- }
691
- },
692
- async (params: UserSearchInput) => {
693
- // Implementation as shown above
694
- }
695
- );
696
-
697
- // Main function
698
- async function main() {
699
- // Verify environment variables if needed
700
- if (!process.env.EXAMPLE_API_KEY) {
701
- console.error("ERROR: EXAMPLE_API_KEY environment variable is required");
702
- process.exit(1);
703
- }
704
-
705
- // Create transport
706
- const transport = new StdioServerTransport();
707
-
708
- // Connect server to transport
709
- await server.connect(transport);
710
-
711
- console.error("Example MCP server running via stdio");
712
- }
713
-
714
- // Run the server
715
- main().catch((error) => {
716
- console.error("Server error:", error);
717
- process.exit(1);
718
- });
719
- ```
720
-
721
- ---
722
-
723
- ## Advanced MCP Features
724
-
725
- ### Resource Registration
726
-
727
- Expose data as resources for efficient, URI-based access:
728
-
729
- ```typescript
730
- import { ResourceTemplate } from "@modelcontextprotocol/sdk/types.js";
731
-
732
- // Register a resource with URI template
733
- server.registerResource(
734
- {
735
- uri: "file://documents/{name}",
736
- name: "Document Resource",
737
- description: "Access documents by name",
738
- mimeType: "text/plain"
739
- },
740
- async (uri: string) => {
741
- // Extract parameter from URI
742
- const match = uri.match(/^file:\/\/documents\/(.+)$/);
743
- if (!match) {
744
- throw new Error("Invalid URI format");
745
- }
746
-
747
- const documentName = match[1];
748
- const content = await loadDocument(documentName);
749
-
750
- return {
751
- contents: [{
752
- uri,
753
- mimeType: "text/plain",
754
- text: content
755
- }]
756
- };
757
- }
758
- );
759
-
760
- // List available resources dynamically
761
- server.registerResourceList(async () => {
762
- const documents = await getAvailableDocuments();
763
- return {
764
- resources: documents.map(doc => ({
765
- uri: `file://documents/${doc.name}`,
766
- name: doc.name,
767
- mimeType: "text/plain",
768
- description: doc.description
769
- }))
770
- };
771
- });
772
- ```
773
-
774
- **When to use Resources vs Tools:**
775
- - **Resources**: For data access with simple URI-based parameters
776
- - **Tools**: For complex operations requiring validation and business logic
777
- - **Resources**: When data is relatively static or template-based
778
- - **Tools**: When operations have side effects or complex workflows
779
-
780
- ### Multiple Transport Options
781
-
782
- The TypeScript SDK supports different transport mechanisms:
783
-
784
- ```typescript
785
- import { StdioServerTransport } from "@modelcontextprotocol/sdk/server/stdio.js";
786
- import { SSEServerTransport } from "@modelcontextprotocol/sdk/server/sse.js";
787
-
788
- // Stdio transport (default - for CLI tools)
789
- const stdioTransport = new StdioServerTransport();
790
- await server.connect(stdioTransport);
791
-
792
- // SSE transport (for real-time web updates)
793
- const sseTransport = new SSEServerTransport("/message", response);
794
- await server.connect(sseTransport);
795
-
796
- // HTTP transport (for web services)
797
- // Configure based on your HTTP framework integration
798
- ```
799
-
800
- **Transport selection guide:**
801
- - **Stdio**: Command-line tools, subprocess integration, local development
802
- - **HTTP**: Web services, remote access, multiple simultaneous clients
803
- - **SSE**: Real-time updates, server-push notifications, web dashboards
804
-
805
- ### Notification Support
806
-
807
- Notify clients when server state changes:
808
-
809
- ```typescript
810
- // Notify when tools list changes
811
- server.notification({
812
- method: "notifications/tools/list_changed"
813
- });
814
-
815
- // Notify when resources change
816
- server.notification({
817
- method: "notifications/resources/list_changed"
818
- });
819
- ```
820
-
821
- Use notifications sparingly - only when server capabilities genuinely change.
822
-
823
- ---
824
-
825
- ## Code Best Practices
826
-
827
- ### Code Composability and Reusability
828
-
829
- Your implementation MUST prioritize composability and code reuse:
830
-
831
- 1. **Extract Common Functionality**:
832
- - Create reusable helper functions for operations used across multiple tools
833
- - Build shared API clients for HTTP requests instead of duplicating code
834
- - Centralize error handling logic in utility functions
835
- - Extract business logic into dedicated functions that can be composed
836
- - Extract shared markdown or JSON field selection & formatting functionality
837
-
838
- 2. **Avoid Duplication**:
839
- - NEVER copy-paste similar code between tools
840
- - If you find yourself writing similar logic twice, extract it into a function
841
- - Common operations like pagination, filtering, field selection, and formatting should be shared
842
- - Authentication/authorization logic should be centralized
843
-
844
- ## Building and Running
845
-
846
- Always build your TypeScript code before running:
847
-
848
- ```bash
849
- # Build the project
850
- npm run build
851
-
852
- # Run the server
853
- npm start
854
-
855
- # Development with auto-reload
856
- npm run dev
857
- ```
858
-
859
- Always ensure `npm run build` completes successfully before considering the implementation complete.
860
-
861
- ## Quality Checklist
862
-
863
- Before finalizing your Node/TypeScript MCP server implementation, ensure:
864
-
865
- ### Strategic Design
866
- - [ ] Tools enable complete workflows, not just API endpoint wrappers
867
- - [ ] Tool names reflect natural task subdivisions
868
- - [ ] Response formats optimize for agent context efficiency
869
- - [ ] Human-readable identifiers used where appropriate
870
- - [ ] Error messages guide agents toward correct usage
871
-
872
- ### Implementation Quality
873
- - [ ] FOCUSED IMPLEMENTATION: Most important and valuable tools implemented
874
- - [ ] All tools registered using `registerTool` with complete configuration
875
- - [ ] All tools include `title`, `description`, `inputSchema`, and `annotations`
876
- - [ ] Annotations correctly set (readOnlyHint, destructiveHint, idempotentHint, openWorldHint)
877
- - [ ] All tools use Zod schemas for runtime input validation with `.strict()` enforcement
878
- - [ ] All Zod schemas have proper constraints and descriptive error messages
879
- - [ ] All tools have comprehensive descriptions with explicit input/output types
880
- - [ ] Descriptions include return value examples and complete schema documentation
881
- - [ ] Error messages are clear, actionable, and educational
882
-
883
- ### TypeScript Quality
884
- - [ ] TypeScript interfaces are defined for all data structures
885
- - [ ] Strict TypeScript is enabled in tsconfig.json
886
- - [ ] No use of `any` type - use `unknown` or proper types instead
887
- - [ ] All async functions have explicit Promise<T> return types
888
- - [ ] Error handling uses proper type guards (e.g., `axios.isAxiosError`, `z.ZodError`)
889
-
890
- ### Advanced Features (where applicable)
891
- - [ ] Resources registered for appropriate data endpoints
892
- - [ ] Appropriate transport configured (stdio, HTTP, SSE)
893
- - [ ] Notifications implemented for dynamic server capabilities
894
- - [ ] Type-safe with SDK interfaces
895
-
896
- ### Project Configuration
897
- - [ ] Package.json includes all necessary dependencies
898
- - [ ] Build script produces working JavaScript in dist/ directory
899
- - [ ] Main entry point is properly configured as dist/index.js
900
- - [ ] Server name follows format: `{service}-mcp-server`
901
- - [ ] tsconfig.json properly configured with strict mode
902
-
903
- ### Code Quality
904
- - [ ] Pagination is properly implemented where applicable
905
- - [ ] Large responses check CHARACTER_LIMIT constant and truncate with clear messages
906
- - [ ] Filtering options are provided for potentially large result sets
907
- - [ ] All network operations handle timeouts and connection errors gracefully
908
- - [ ] Common functionality is extracted into reusable functions
909
- - [ ] Return types are consistent across similar operations
910
-
911
- ### Testing and Build
912
- - [ ] `npm run build` completes successfully without errors
913
- - [ ] dist/index.js created and executable
914
- - [ ] Server runs: `node dist/index.js --help`
915
- - [ ] All imports resolve correctly
916
- - [ ] Sample tool calls work as expected