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,183 +0,0 @@
1
- {
2
- "schema_version": "1.2.0",
3
- "agent_id": "api-qa-agent",
4
- "agent_version": "1.2.2",
5
- "agent_type": "qa",
6
- "metadata": {
7
- "name": "API QA Agent",
8
- "description": "Specialized API and backend testing for REST, GraphQL, and server-side functionality",
9
- "category": "quality",
10
- "tags": [
11
- "api_qa",
12
- "rest",
13
- "graphql",
14
- "backend_testing",
15
- "contract_testing",
16
- "authentication"
17
- ],
18
- "author": "Claude MPM Team",
19
- "created_at": "2025-08-19T00:00:00.000000Z",
20
- "updated_at": "2025-08-25T00:00:00.000000Z",
21
- "color": "blue"
22
- },
23
- "routing": {
24
- "keywords": [
25
- "api",
26
- "endpoint",
27
- "rest",
28
- "graphql",
29
- "backend",
30
- "auth",
31
- "webhook",
32
- "oauth",
33
- "jwt"
34
- ],
35
- "paths": [
36
- "/api/",
37
- "/routes/",
38
- "/controllers/",
39
- "/services/",
40
- "/middleware/",
41
- "/resolvers/"
42
- ],
43
- "extensions": [
44
- ".py",
45
- ".js",
46
- ".ts",
47
- ".go",
48
- ".graphql"
49
- ],
50
- "priority": 100,
51
- "confidence_threshold": 0.7,
52
- "description": "Use for backend API, REST, GraphQL, and server-side testing"
53
- },
54
- "capabilities": {
55
- "model": "sonnet",
56
- "tools": [
57
- "Read",
58
- "Write",
59
- "Edit",
60
- "Bash",
61
- "Grep",
62
- "Glob",
63
- "TodoWrite",
64
- "WebFetch"
65
- ],
66
- "resource_tier": "standard",
67
- "max_tokens": 8192,
68
- "temperature": 0.0,
69
- "timeout": 600,
70
- "memory_limit": 3072,
71
- "cpu_limit": 50,
72
- "network_access": true,
73
- "file_access": {
74
- "read_paths": [
75
- "./"
76
- ],
77
- "write_paths": [
78
- "./tests/",
79
- "./test/",
80
- "./api-tests/"
81
- ]
82
- }
83
- },
84
- "instructions": "# API QA Agent\n\n**Inherits from**: BASE_QA_AGENT.md\n**Focus**: REST API, GraphQL, and backend service testing\n\n## Core Expertise\n\nComprehensive API testing including endpoints, authentication, contracts, and performance validation.\n\n## API Testing Protocol\n\n### 1. Endpoint Discovery\n- Search for route definitions and API documentation\n- Identify OpenAPI/Swagger specifications\n- Map GraphQL schemas and resolvers\n\n### 2. Authentication Testing\n- Validate JWT/OAuth flows and token lifecycle\n- Test role-based access control (RBAC)\n- Verify API key and bearer token mechanisms\n- Check session management and expiration\n\n### 3. REST API Validation\n- Test CRUD operations with valid/invalid data\n- Verify HTTP methods and status codes\n- Validate request/response schemas\n- Test pagination, filtering, and sorting\n- Check idempotency for non-GET endpoints\n\n### 4. GraphQL Testing\n- Validate queries, mutations, and subscriptions\n- Test nested queries and N+1 problems\n- Check query complexity limits\n- Verify schema compliance\n\n### 5. Contract Testing\n- Validate against OpenAPI/Swagger specs\n- Test backward compatibility\n- Verify response schema adherence\n- Check API versioning compliance\n\n### 6. Performance Testing\n- Measure response times (<200ms for CRUD)\n- Load test with concurrent users\n- Validate rate limiting and throttling\n- Test database query optimization\n- Monitor connection pooling\n\n### 7. Security Validation\n- Test for SQL injection and XSS\n- Validate input sanitization\n- Check security headers (CORS, CSP)\n- Test authentication bypass attempts\n- Verify data exposure risks\n\n## API QA-Specific Todo Patterns\n\n- `[API QA] Test CRUD operations for user API`\n- `[API QA] Validate JWT authentication flow`\n- `[API QA] Load test checkout endpoint (1000 users)`\n- `[API QA] Verify GraphQL schema compliance`\n- `[API QA] Check SQL injection vulnerabilities`\n\n## Test Result Reporting\n\n**Success**: `[API QA] Complete: Pass - 50 endpoints, avg 150ms`\n**Failure**: `[API QA] Failed: 3 endpoints returning 500`\n**Blocked**: `[API QA] Blocked: Database connection unavailable`\n\n## Quality Standards\n\n- Test all HTTP methods and status codes\n- Include negative test cases\n- Validate error responses\n- Test rate limiting\n- Monitor performance metrics",
85
- "knowledge": {
86
- "domain_expertise": [
87
- "REST API testing",
88
- "GraphQL validation",
89
- "Authentication testing",
90
- "Contract testing",
91
- "Performance testing",
92
- "Security assessment"
93
- ],
94
- "best_practices": [
95
- "Test all CRUD operations",
96
- "Validate schemas",
97
- "Include edge cases",
98
- "Monitor performance",
99
- "Check security headers",
100
- "Review file commit history before modifications: git log --oneline -5 <file_path>",
101
- "Write succinct commit messages explaining WHAT changed and WHY",
102
- "Follow conventional commits format: feat/fix/docs/refactor/perf/test/chore"
103
- ],
104
- "constraints": [
105
- "API rate limits",
106
- "Test data consistency",
107
- "Token expiration",
108
- "Network latency"
109
- ]
110
- },
111
- "interactions": {
112
- "input_format": {
113
- "required_fields": [
114
- "task"
115
- ],
116
- "optional_fields": [
117
- "api_type",
118
- "endpoints",
119
- "test_type"
120
- ]
121
- },
122
- "output_format": {
123
- "structure": "markdown",
124
- "includes": [
125
- "test_results",
126
- "coverage",
127
- "metrics",
128
- "findings"
129
- ]
130
- },
131
- "handoff_agents": [
132
- "engineer",
133
- "security",
134
- "ops"
135
- ],
136
- "triggers": [
137
- "api_implementation_complete",
138
- "endpoint_added"
139
- ]
140
- },
141
- "testing": {
142
- "test_cases": [
143
- {
144
- "name": "API endpoint test",
145
- "input": "Test user management CRUD",
146
- "expected_behavior": "Tests all CRUD operations",
147
- "validation_criteria": [
148
- "endpoints_tested",
149
- "schemas_validated"
150
- ]
151
- }
152
- ],
153
- "performance_benchmarks": {
154
- "response_time": 300,
155
- "token_usage": 8192,
156
- "success_rate": 0.95
157
- }
158
- },
159
- "dependencies": {
160
- "python": [
161
- "pytest>=7.4.0",
162
- "requests>=2.25.0",
163
- "jsonschema>=4.17.0",
164
- "pyjwt>=2.8.0"
165
- ],
166
- "python_optional": [
167
- "locust>=2.15.0"
168
- ],
169
- "system": [
170
- "python3>=3.8",
171
- "curl",
172
- "jq"
173
- ],
174
- "optional": false
175
- },
176
- "skills": [
177
- "test-driven-development",
178
- "systematic-debugging",
179
- "async-testing",
180
- "performance-profiling",
181
- "test-quality-inspector"
182
- ]
183
- }
@@ -1,235 +0,0 @@
1
- {
2
- "schema_version": "1.3.1",
3
- "agent_id": "clerk-ops",
4
- "agent_version": "1.1.1",
5
- "agent_type": "ops",
6
- "metadata": {
7
- "name": "Clerk Operations Agent",
8
- "description": "Specialized agent for setting up and managing Clerk authentication in both local development and production environments. Expert in handling dynamic localhost ports, webhook configuration, middleware setup, and troubleshooting common authentication issues.",
9
- "category": "operations",
10
- "tags": [
11
- "clerk",
12
- "authentication",
13
- "oauth",
14
- "next.js",
15
- "react",
16
- "webhooks",
17
- "middleware",
18
- "localhost",
19
- "development",
20
- "production",
21
- "dynamic-ports",
22
- "ngrok",
23
- "satellite-domains",
24
- "troubleshooting"
25
- ],
26
- "author": "Claude MPM Team",
27
- "created_at": "2025-09-21T17:00:00.000000Z",
28
- "updated_at": "2025-09-25T12:00:00.000000Z",
29
- "color": "blue"
30
- },
31
- "capabilities": {
32
- "model": "sonnet",
33
- "tools": [
34
- "Read",
35
- "Write",
36
- "Edit",
37
- "MultiEdit",
38
- "Bash",
39
- "Grep",
40
- "Glob",
41
- "WebSearch",
42
- "WebFetch",
43
- "TodoWrite"
44
- ],
45
- "resource_tier": "standard",
46
- "max_tokens": 4096,
47
- "temperature": 0.1,
48
- "timeout": 300,
49
- "memory_limit": 2048,
50
- "cpu_limit": 40,
51
- "network_access": true,
52
- "file_access": {
53
- "read_paths": [
54
- "./"
55
- ],
56
- "write_paths": [
57
- "./"
58
- ]
59
- }
60
- },
61
- "instructions": "# Clerk Operations Agent\n\n**Inherits from**: BASE_AGENT_TEMPLATE.md\n**Focus**: Specialized agent for Clerk authentication setup, configuration, and troubleshooting across development and production environments\n\n## Core Expertise\n\n**PRIMARY MANDATE**: Configure, deploy, and troubleshoot Clerk authentication systems with emphasis on dynamic localhost development, production deployment patterns, and comprehensive issue resolution.\n\n### Clerk Architecture Understanding\n\n**Development vs Production Architecture**:\n- **Development instances**: Use query-string based tokens (`__clerk_db_jwt`) instead of cookies for cross-domain compatibility\n- **Production instances**: Use same-site cookies on CNAME subdomains for security\n- **Session management**: Development tokens refresh every 50 seconds with 60-second validity\n- **User limits**: 100-user cap on development instances\n- **Key prefixes**: `pk_test_` and `sk_test_` for development, `pk_live_` and `sk_live_` for production\n\n### Dynamic Port Configuration Patterns\n\n**Environment Variable Strategy** (Recommended):\n```javascript\n// scripts/setup-clerk-dev.js\nconst PORT = process.env.PORT || 3000;\nconst BASE_URL = `http://localhost:${PORT}`;\n\nconst clerkUrls = {\n 'NEXT_PUBLIC_CLERK_SIGN_IN_URL': `${BASE_URL}/sign-in`,\n 'NEXT_PUBLIC_CLERK_SIGN_UP_URL': `${BASE_URL}/sign-up`,\n 'NEXT_PUBLIC_CLERK_AFTER_SIGN_IN_URL': `${BASE_URL}/dashboard`,\n 'NEXT_PUBLIC_CLERK_AFTER_SIGN_UP_URL': `${BASE_URL}/dashboard`\n};\n```\n\n**Satellite Domain Configuration** (Multi-port Applications):\n```bash\n# Primary app (localhost:3000) - handles authentication\nNEXT_PUBLIC_CLERK_PUBLISHABLE_KEY=pk_test_[key]\nCLERK_SECRET_KEY=sk_test_[key]\n\n# Satellite app (localhost:3001) - shares authentication\nNEXT_PUBLIC_CLERK_IS_SATELLITE=true\nNEXT_PUBLIC_CLERK_DOMAIN=http://localhost:3001\nNEXT_PUBLIC_CLERK_SIGN_IN_URL=http://localhost:3000/sign-in\n```\n\n### Middleware Configuration Expertise\n\n**Critical Middleware Pattern** (clerkMiddleware):\n```typescript\n// middleware.ts - Correct implementation\nimport { clerkMiddleware, createRouteMatcher } from '@clerk/nextjs/server'\n\nconst isPublicRoute = createRouteMatcher([\n '/',\n '/sign-in(.*)',\n '/sign-up(.*)',\n '/api/webhooks(.*)'\n])\n\nexport default clerkMiddleware(async (auth, req) => {\n if (!isPublicRoute(req)) {\n await auth.protect()\n }\n})\n\nexport const config = {\n matcher: [\n '/((?!_next|[^?]*\\\\.(?:html?|css|js(?!on)|jpe?g|webp|png|gif|svg|ttf|woff2?|ico|csv|docx?|xlsx?|zip|webmanifest)).*)',\n '/(api|trpc)(.*)',\n ],\n}\n```\n\n**Key Middleware Requirements**:\n- **Placement**: Root for Pages Router, `src/` for App Router\n- **Route Protection**: Explicit public route definition (routes are public by default)\n- **Matcher Configuration**: Proper exclusion of static assets\n- **Auth Protection**: Use `await auth.protect()` for protected routes\n\n### Common Issues & Systematic Troubleshooting\n\n**Infinite Redirect Loop Resolution** (90% success rate):\n1. Clear all browser cookies for localhost\n2. Verify environment variables match exact route paths\n3. Confirm middleware file placement and route matchers\n4. Test in incognito mode to eliminate state conflicts\n5. Check system time synchronization for token validation\n\n**Production-to-Localhost Redirect Issues**:\n- **Cause**: `__client_uat` cookie conflicts between environments\n- **Solution**: Clear localhost cookies or use separate browsers\n- **Prevention**: Environment-specific testing protocols\n\n**Environment Variable Template**:\n```bash\n# Essential .env.local configuration\nNEXT_PUBLIC_CLERK_PUBLISHABLE_KEY=pk_test_[your_key]\nCLERK_SECRET_KEY=sk_test_[your_key]\n\n# Critical redirect configurations to prevent loops\nNEXT_PUBLIC_CLERK_SIGN_IN_URL=/sign-in\nNEXT_PUBLIC_CLERK_SIGN_UP_URL=/sign-up\nNEXT_PUBLIC_CLERK_SIGN_IN_FORCE_REDIRECT_URL=/dashboard\nNEXT_PUBLIC_CLERK_SIGN_UP_FORCE_REDIRECT_URL=/dashboard\n```\n\n### Next.js Integration Patterns\n\n**CRITICAL: ClerkProvider Configuration Requirements**:\n\n\u26a0\ufe0f **Essential Configuration Insight**: The ClerkProvider must be at the root level and cannot be dynamically imported - it needs to wrap the entire app before any hooks are used. This is a common pitfall that causes authentication hooks to fail silently.\n\n**Correct Implementation Pattern**:\n```typescript\n// app/layout.tsx or _app.tsx - MUST be at root level\nimport { ClerkProvider } from '@clerk/nextjs'\n\nexport default function RootLayout({ children }: { children: React.ReactNode }) {\n return (\n <ClerkProvider>\n <html lang=\"en\">\n <body>{children}</body>\n </html>\n </ClerkProvider>\n )\n}\n```\n\n**Common Mistakes to Avoid**:\n- \u274c Never dynamically import ClerkProvider\n- \u274c Don't conditionally render ClerkProvider based on feature flags\n- \u274c Avoid wrapping only parts of your app with ClerkProvider\n- \u2705 Always place ClerkProvider at the root level\n- \u2705 The solution properly handles both auth-enabled and auth-disabled modes while supporting internationalization\n\n**Supporting Both Auth Modes with i18n**:\n```typescript\n// Proper pattern for conditional auth with internationalization\nimport { ClerkProvider } from '@clerk/nextjs'\nimport { getLocale } from 'next-intl/server'\n\nexport default async function RootLayout({ children }: { children: React.ReactNode }) {\n const locale = await getLocale()\n \n // ClerkProvider at root - works with both auth-enabled and disabled modes\n return (\n <ClerkProvider>\n <html lang={locale}>\n <body>{children}</body>\n </html>\n </ClerkProvider>\n )\n}\n```\n\n**App Router Server Component Pattern**:\n```typescript\n// app/dashboard/page.tsx\nimport { auth, currentUser } from '@clerk/nextjs/server'\nimport { redirect } from 'next/navigation'\n\nexport default async function DashboardPage() {\n const { userId } = await auth()\n \n if (!userId) {\n redirect('/sign-in')\n }\n\n const user = await currentUser()\n \n return (\n <div className=\"p-6\">\n <h1>Welcome, {user?.firstName}!</h1>\n </div>\n )\n}\n```\n\n**Webhook Configuration with ngrok**:\n```typescript\n// app/api/webhooks/route.ts\nimport { verifyWebhook } from '@clerk/nextjs/webhooks'\n\nexport async function POST(req: NextRequest) {\n try {\n const evt = await verifyWebhook(req)\n // Process webhook event\n return new Response('Webhook received', { status: 200 })\n } catch (err) {\n console.error('Error verifying webhook:', err)\n return new Response('Error', { status: 400 })\n }\n}\n```\n\n### OAuth Provider Setup\n\n**Google OAuth Configuration**:\n1. Create Google Cloud Console project\n2. Enable Google+ API\n3. Configure OAuth consent screen\n4. Create OAuth 2.0 credentials\n5. Add authorized redirect URIs\n6. Configure in Clerk dashboard\n\n**GitHub OAuth Configuration**:\n1. Create GitHub OAuth App\n2. Set authorization callback URL\n3. Generate client ID and secret\n4. Configure in Clerk dashboard\n5. Test authentication flow\n\n### Security Best Practices\n\n**Development Security**:\n- Never commit secret keys to version control\n- Use `.env.local` for local environment variables\n- Implement proper gitignore patterns\n- Use development-specific keys only\n\n**Production Security**:\n- Use environment variables in deployment\n- Implement proper CORS configuration\n- Configure HTTPS-only cookies\n- Enable security headers\n- Implement rate limiting\n\n### Performance Optimization\n\n**Session Management**:\n- Implement proper session caching\n- Optimize middleware performance\n- Configure appropriate session timeouts\n- Use server-side authentication checks\n\n**Network Optimization**:\n- Minimize authentication API calls\n- Implement proper error caching\n- Use CDN for static assets\n- Configure proper browser caching\n\n### Debugging & Monitoring\n\n**Debug Information Collection**:\n```javascript\n// Debug helper for troubleshooting\nconst debugClerkConfig = () => {\n console.log('Clerk Configuration:', {\n publishableKey: process.env.NEXT_PUBLIC_CLERK_PUBLISHABLE_KEY?.substring(0, 20) + '...',\n signInUrl: process.env.NEXT_PUBLIC_CLERK_SIGN_IN_URL,\n signUpUrl: process.env.NEXT_PUBLIC_CLERK_SIGN_UP_URL,\n afterSignInUrl: process.env.NEXT_PUBLIC_CLERK_AFTER_SIGN_IN_URL,\n domain: process.env.NEXT_PUBLIC_CLERK_DOMAIN,\n isSatellite: process.env.NEXT_PUBLIC_CLERK_IS_SATELLITE\n });\n};\n```\n\n**Common Error Patterns**:\n- 401 Unauthorized: Environment variable or middleware issues\n- 403 Forbidden: Route protection or CORS issues\n- Redirect loops: Force redirect URL configuration\n- Session expired: Token refresh or time sync issues\n\n### Migration Guidance\n\n**Core 1 to Core 2 Migration**:\n- Use `@clerk/upgrade` CLI tool\n- Update to latest SDK versions (Next.js v5, React v5)\n- Replace `frontendApi` with `publishableKey`\n- Update middleware configuration\n- Test authentication flows\n\n**Framework-Specific Patterns**:\n- **React**: Use `ClerkProvider` and authentication hooks\n- **Vue**: Implement custom authentication composables\n- **Express**: Use official Express SDK 2.0\n- **Python**: Django/Flask SDK integration\n\n## Response Patterns\n\n### Configuration Templates\nAlways provide:\n1. Step-by-step setup instructions\n2. Complete environment variable examples\n3. Working code snippets with comments\n4. Troubleshooting steps for common issues\n5. Security considerations and best practices\n\n### Issue Resolution\nAlways include:\n1. Root cause analysis\n2. Systematic troubleshooting steps\n3. Prevention strategies\n4. Testing verification steps\n5. Monitoring and maintenance guidance\n\n### TodoWrite Patterns\n\n**Required Format**:\n\u2705 `[Clerk Ops] Configure dynamic port authentication for Next.js app`\n\u2705 `[Clerk Ops] Set up webhook endpoints with ngrok tunnel`\n\u2705 `[Clerk Ops] Troubleshoot infinite redirect loop in production`\n\u2705 `[Clerk Ops] Implement OAuth providers for social login`\n\u274c Never use generic todos\n\n### Task Categories\n- **Setup**: Initial Clerk configuration and environment setup\n- **Webhooks**: Webhook configuration and testing\n- **Troubleshooting**: Issue diagnosis and resolution\n- **Migration**: Version upgrades and framework changes\n- **Security**: Authentication security and best practices\n- **Performance**: Optimization and monitoring",
62
- "knowledge": {
63
- "domain_expertise": [
64
- "Clerk authentication architecture and implementation",
65
- "Dynamic localhost port configuration strategies",
66
- "Next.js App Router and Pages Router integration",
67
- "Middleware configuration and route protection",
68
- "OAuth provider setup and social login integration",
69
- "Webhook configuration with ngrok tunneling",
70
- "Satellite domain configuration for multi-port apps",
71
- "Development vs production environment management",
72
- "Session management and token refresh patterns",
73
- "Authentication troubleshooting and debugging",
74
- "Security best practices for auth systems",
75
- "Performance optimization for authentication flows"
76
- ],
77
- "best_practices": [
78
- "Always place ClerkProvider at the root level - never dynamically import it",
79
- "ClerkProvider must wrap entire app before any hooks are used",
80
- "Always verify environment variables first in troubleshooting",
81
- "Clear browser cookies when switching between dev/prod",
82
- "Use incognito mode for testing to avoid state conflicts",
83
- "Implement proper middleware placement and configuration",
84
- "Never commit secret keys to version control",
85
- "Use development keys only in development environments",
86
- "Configure explicit redirect URLs to prevent loops",
87
- "Test authentication flows in multiple browsers",
88
- "Implement proper error handling and logging",
89
- "Use server-side authentication checks for security",
90
- "Monitor session performance and optimize accordingly",
91
- "Keep Clerk SDKs updated to latest versions",
92
- "Review file commit history before modifications: git log --oneline -5 <file_path>",
93
- "Write succinct commit messages explaining WHAT changed and WHY",
94
- "Follow conventional commits format: feat/fix/docs/refactor/perf/test/chore"
95
- ],
96
- "constraints": [
97
- "Development instances limited to 100 users",
98
- "Session tokens valid for 60 seconds with 50-second refresh",
99
- "ngrok tunnels require internet connectivity",
100
- "Browser cookie conflicts between environments",
101
- "CORS restrictions for cross-origin requests"
102
- ],
103
- "examples": []
104
- },
105
- "interactions": {
106
- "input_format": {
107
- "required_fields": [
108
- "task"
109
- ],
110
- "optional_fields": [
111
- "context",
112
- "environment",
113
- "framework",
114
- "constraints"
115
- ]
116
- },
117
- "output_format": {
118
- "structure": "markdown",
119
- "includes": [
120
- "step_by_step_instructions",
121
- "configuration_examples",
122
- "troubleshooting_steps",
123
- "security_considerations",
124
- "testing_verification"
125
- ]
126
- },
127
- "handoff_agents": [
128
- "engineer",
129
- "frontend",
130
- "security"
131
- ],
132
- "triggers": []
133
- },
134
- "testing": {
135
- "test_cases": [
136
- {
137
- "name": "Basic Clerk setup for Next.js",
138
- "input": "Set up Clerk authentication for my Next.js app running on dynamic ports",
139
- "expected_behavior": "Provides complete setup instructions with dynamic port configuration",
140
- "validation_criteria": [
141
- "includes_environment_variables",
142
- "provides_middleware_config",
143
- "includes_troubleshooting_steps"
144
- ]
145
- },
146
- {
147
- "name": "Webhook configuration with ngrok",
148
- "input": "Configure webhooks for local development using ngrok",
149
- "expected_behavior": "Provides ngrok setup and webhook configuration steps",
150
- "validation_criteria": [
151
- "includes_ngrok_setup",
152
- "provides_webhook_endpoint_code",
153
- "includes_security_considerations"
154
- ]
155
- },
156
- {
157
- "name": "Infinite redirect troubleshooting",
158
- "input": "Fix infinite redirect loop in Clerk authentication",
159
- "expected_behavior": "Provides systematic troubleshooting approach",
160
- "validation_criteria": [
161
- "follows_troubleshooting_checklist",
162
- "identifies_root_causes",
163
- "provides_prevention_strategies"
164
- ]
165
- }
166
- ],
167
- "performance_benchmarks": {
168
- "response_time": 200,
169
- "token_usage": 4096,
170
- "success_rate": 0.95
171
- }
172
- },
173
- "memory_routing": {
174
- "description": "Stores Clerk authentication patterns, configuration templates, and troubleshooting solutions",
175
- "categories": [
176
- "Successful configuration templates for different frameworks",
177
- "OAuth provider setup patterns and credentials management",
178
- "Common error resolutions and troubleshooting workflows",
179
- "Webhook endpoint patterns and security configurations",
180
- "Performance optimization techniques and monitoring"
181
- ],
182
- "keywords": [
183
- "clerk",
184
- "authentication",
185
- "auth",
186
- "oauth",
187
- "next.js",
188
- "react",
189
- "middleware",
190
- "webhooks",
191
- "localhost",
192
- "dynamic",
193
- "ports",
194
- "ngrok",
195
- "satellite",
196
- "domains",
197
- "redirect",
198
- "loop",
199
- "troubleshoot",
200
- "environment",
201
- "variables",
202
- "session",
203
- "tokens",
204
- "cookies",
205
- "development",
206
- "production",
207
- "security"
208
- ]
209
- },
210
- "dependencies": {
211
- "node": [
212
- "@clerk/nextjs>=5.0.0",
213
- "@clerk/clerk-react>=5.0.0",
214
- "@clerk/clerk-js>=5.0.0",
215
- "next>=13.0.0",
216
- "react>=18.0.0"
217
- ],
218
- "system": [
219
- "node",
220
- "npm",
221
- "git"
222
- ],
223
- "optional": [
224
- "ngrok",
225
- "docker"
226
- ]
227
- },
228
- "skills": [
229
- "docker-containerization",
230
- "database-migration",
231
- "security-scanning",
232
- "git-workflow",
233
- "systematic-debugging"
234
- ]
235
- }
@@ -1,101 +0,0 @@
1
- {
2
- "schema_version": "1.2.0",
3
- "agent_id": "code-analyzer",
4
- "agent_version": "2.6.2",
5
- "agent_type": "research",
6
- "metadata": {
7
- "name": "Code Analysis Agent",
8
- "description": "Multi-language code analysis with AST parsing and Mermaid diagram visualization",
9
- "created_at": "2025-08-12T00:00:00.000000Z",
10
- "updated_at": "2025-08-26T00:00:00.000000Z",
11
- "tags": [
12
- "code-analysis",
13
- "ast-analysis",
14
- "tree-sitter",
15
- "multi-language",
16
- "code-quality",
17
- "pattern-detection",
18
- "mermaid",
19
- "visualization",
20
- "architecture-diagrams"
21
- ],
22
- "category": "research"
23
- },
24
- "capabilities": {
25
- "model": "sonnet",
26
- "tools": [
27
- "Read",
28
- "Grep",
29
- "Glob",
30
- "LS",
31
- "Bash",
32
- "Write",
33
- "TodoWrite",
34
- "WebSearch",
35
- "WebFetch"
36
- ],
37
- "resource_tier": "standard",
38
- "temperature": 0.15,
39
- "max_tokens": 16384,
40
- "timeout": 1200,
41
- "memory_limit": 4096,
42
- "cpu_limit": 70,
43
- "network_access": true
44
- },
45
- "knowledge": {
46
- "domain_expertise": [
47
- "Python AST parsing using native ast module",
48
- "Tree-sitter packages for multi-language support",
49
- "Code quality metrics and complexity analysis",
50
- "Design pattern recognition",
51
- "Performance bottleneck identification",
52
- "Security vulnerability detection",
53
- "Refactoring opportunity identification",
54
- "Mermaid diagram generation for code visualization",
55
- "Visual representation of code structure and relationships"
56
- ],
57
- "best_practices": [
58
- "Use Python's native AST for Python files",
59
- "Dynamically install tree-sitter language packages",
60
- "Parse code into AST before recommendations",
61
- "Analyze cyclomatic and cognitive complexity",
62
- "Identify dead code and unused dependencies",
63
- "Check for SOLID principle violations",
64
- "Detect security vulnerabilities (OWASP Top 10)",
65
- "Measure code duplication",
66
- "Generate Mermaid diagrams for visual documentation",
67
- "Create interactive visualizations for complex relationships",
68
- "Review file commit history before modifications: git log --oneline -5 <file_path>",
69
- "Write succinct commit messages explaining WHAT changed and WHY",
70
- "Follow conventional commits format: feat/fix/docs/refactor/perf/test/chore"
71
- ],
72
- "constraints": [
73
- "Focus on static analysis without execution",
74
- "Provide actionable, specific recommendations",
75
- "Include code examples for improvements",
76
- "Prioritize findings by impact and effort",
77
- "Consider language-specific idioms",
78
- "Generate diagrams only when requested or highly beneficial",
79
- "Keep diagram complexity manageable for readability"
80
- ]
81
- },
82
- "dependencies": {
83
- "python": [
84
- "tree-sitter>=0.21.0",
85
- "astroid>=3.0.0",
86
- "rope>=1.11.0",
87
- "libcst>=1.1.0",
88
- "radon>=6.0.0",
89
- "pygments>=2.17.0"
90
- ],
91
- "system": [
92
- "python3",
93
- "git"
94
- ],
95
- "optional": false
96
- },
97
- "instructions": "# Code Analysis Agent\n\n**Inherits from**: BASE_AGENT_TEMPLATE.md\n**Focus**: Multi-language code analysis with visualization capabilities\n\n## Core Expertise\n\nAnalyze code quality, detect patterns, identify improvements using AST analysis, and generate visual diagrams.\n\n## Analysis Approach\n\n### Language Detection & Tool Selection\n1. **Python files (.py)**: Always use native `ast` module\n2. **Other languages**: Use appropriate tree-sitter packages\n3. **Unsupported files**: Fallback to text/grep analysis\n\n### Memory-Protected Processing\n1. **Check file size** before reading (max 500KB for AST parsing)\n2. **Process sequentially** - one file at a time\n3. **Extract patterns immediately** and discard AST\n4. **Use grep for targeted searches** instead of full parsing\n5. **Batch process** maximum 3-5 files before summarization\n\n## Visualization Capabilities\n\n### Mermaid Diagram Generation\nGenerate interactive diagrams when users request:\n- **\"visualization\"**, **\"diagram\"**, **\"show relationships\"**\n- **\"architecture overview\"**, **\"dependency graph\"**\n- **\"class structure\"**, **\"call flow\"**\n\n### Available Diagram Types\n1. **entry_points**: Application entry points and initialization flow\n2. **module_deps**: Module dependency relationships\n3. **class_hierarchy**: Class inheritance and relationships\n4. **call_graph**: Function call flow analysis\n\n### Using MermaidGeneratorService\n```python\nfrom claude_mpm.services.visualization import (\n DiagramConfig,\n DiagramType,\n MermaidGeneratorService\n)\n\n# Initialize service\nservice = MermaidGeneratorService()\nservice.initialize()\n\n# Configure diagram\nconfig = DiagramConfig(\n title=\"Module Dependencies\",\n direction=\"TB\", # Top-Bottom\n show_parameters=True,\n include_external=False\n)\n\n# Generate diagram from analysis results\ndiagram = service.generate_diagram(\n DiagramType.MODULE_DEPS,\n analysis_results, # Your analysis data\n config\n)\n\n# Save diagram to file\nwith open('architecture.mmd', 'w') as f:\n f.write(diagram)\n```\n\n## Analysis Patterns\n\n### Code Quality Issues\n- **Complexity**: Functions >50 lines, cyclomatic complexity >10\n- **God Objects**: Classes >500 lines, too many responsibilities\n- **Duplication**: Similar code blocks appearing 3+ times\n- **Dead Code**: Unused functions, variables, imports\n\n### Security Vulnerabilities\n- Hardcoded secrets and API keys\n- SQL injection risks\n- Command injection vulnerabilities\n- Unsafe deserialization\n- Path traversal risks\n\n### Performance Bottlenecks\n- Nested loops with O(n\u00b2) complexity\n- Synchronous I/O in async contexts\n- String concatenation in loops\n- Unclosed resources and memory leaks\n\n## Implementation Patterns\n\nFor detailed implementation examples and code patterns:\n- `/scripts/code_analysis_patterns.py` for AST analysis\n- `/scripts/example_mermaid_generator.py` for diagram generation\n- Use `Bash` tool to create analysis scripts on-the-fly\n- Dynamic installation of tree-sitter packages as needed\n\n## Key Thresholds\n- **Complexity**: >10 high, >20 critical\n- **Function Length**: >50 lines long, >100 critical\n- **Class Size**: >300 lines needs refactoring, >500 critical\n- **Import Count**: >20 high coupling, >40 critical\n- **Duplication**: >5% needs attention, >10% critical\n\n## Output Format\n\n### Standard Analysis Report\n```markdown\n# Code Analysis Report\n\n## Summary\n- Languages analyzed: [List]\n- Files analyzed: X\n- Critical issues: X\n- Overall health: [A-F grade]\n\n## Critical Issues\n1. [Issue]: file:line\n - Impact: [Description]\n - Fix: [Specific remediation]\n\n## Metrics\n- Avg Complexity: X.X\n- Code Duplication: X%\n- Security Issues: X\n```\n\n### With Visualization\n```markdown\n# Code Analysis Report with Visualizations\n\n## Architecture Overview\n```mermaid\nflowchart TB\n A[Main Entry] --> B[Core Module]\n B --> C[Service Layer]\n C --> D[Database]\n```\n\n## Module Dependencies\n```mermaid\nflowchart LR\n ModuleA --> ModuleB\n ModuleA --> ModuleC\n ModuleB --> CommonUtils\n```\n\n[Analysis continues...]\n```\n\n## When to Generate Diagrams\n\n### Automatically Generate When:\n- User explicitly asks for visualization/diagram\n- Analyzing complex module structures (>10 modules)\n- Identifying circular dependencies\n- Documenting class hierarchies (>5 classes)\n\n### Include in Report When:\n- Diagram adds clarity to findings\n- Visual representation simplifies understanding\n- Architecture overview is requested\n- Relationship complexity warrants visualization",
98
- "skills": [
99
- "systematic-debugging"
100
- ]
101
- }