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.
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,260 +0,0 @@
1
- ---
2
- name: env-manager
3
- description: Environment variable validation, synchronization, and management across local development, CI/CD, and deployment platforms
4
- version: 1.0.0
5
- category: infrastructure
6
- progressive_disclosure:
7
- entry_point:
8
- summary: "Validate, synchronize, and secure environment variables across local dev, CI/CD, and deployment platforms with framework-specific support"
9
- when_to_use: "When managing .env files, deploying to Vercel/Railway/Heroku, syncing with secret managers, or troubleshooting env-related issues"
10
- quick_start: "1. Validate local .env 2. Check security 3. Sync to platform 4. Verify deployment 5. Generate documentation"
11
- references:
12
- - validation.md
13
- - security.md
14
- - synchronization.md
15
- - frameworks.md
16
- - troubleshooting.md
17
- author: Claude MPM Team
18
- license: MIT
19
- requires_tools:
20
- - bash
21
- - python
22
- tags:
23
- - environment-variables
24
- - deployment
25
- - security
26
- - devops
27
- - nextjs
28
- - vercel
29
- - railway
30
- context_limit: 800
31
- ---
32
-
33
- # Environment Variable Manager
34
-
35
- ## Overview
36
-
37
- Manage environment variables systematically across local development, CI/CD pipelines, and deployment platforms. Prevent common issues like missing variables, exposed secrets, platform misconfigurations, and framework-specific gotchas.
38
-
39
- **Core capabilities:**
40
- - **Validation**: Check structure, completeness, naming conventions
41
- - **Security**: Scan for exposed secrets, validate .gitignore coverage
42
- - **Synchronization**: Sync with deployment platforms and secret managers
43
- - **Framework Support**: Next.js, Express, Flask, Django patterns
44
- - **Documentation**: Auto-generate .env.example and setup guides
45
-
46
- ## When to Use This Skill
47
-
48
- Activate when:
49
- - Setting up new project environment configuration
50
- - Deploying to Vercel, Railway, Heroku, or other platforms
51
- - Troubleshooting "works locally but not in production"
52
- - Managing secrets across multiple environments
53
- - Syncing variables with 1Password, AWS Secrets Manager
54
- - Creating .env.example documentation
55
- - Onboarding new developers (environment setup)
56
- - Migrating between deployment platforms
57
- - Framework-specific env configuration (Next.js NEXT_PUBLIC_ prefix)
58
-
59
- ## Core Principles
60
-
61
- 1. **Never Log Secrets**: All operations must NEVER display actual secret values
62
- 2. **Validate Before Deploy**: Catch env issues locally, not in production
63
- 3. **Framework-Aware**: Respect framework conventions (Next.js, Express, Flask)
64
- 4. **Platform-Specific**: Generate correct configs for each deployment platform
65
- 5. **Security First**: Scan for exposed secrets, validate .gitignore
66
-
67
- ## Quick Start
68
-
69
- ### Validation Workflow
70
- ```bash
71
- # 1. Check local .env structure
72
- python scripts/validate_env.py .env
73
-
74
- # 2. Check for missing variables
75
- python scripts/validate_env.py .env --compare .env.example
76
-
77
- # 3. Validate naming conventions
78
- python scripts/validate_env.py .env --framework nextjs
79
-
80
- # 4. Check for duplicates
81
- python scripts/validate_env.py .env --check-duplicates
82
- ```
83
-
84
- ### Security Workflow
85
- ```bash
86
- # 1. Scan for exposed secrets in code
87
- python scripts/scan_exposed.py --scan-code
88
-
89
- # 2. Check .gitignore coverage
90
- python scripts/scan_exposed.py --check-gitignore
91
-
92
- # 3. Validate secret formats
93
- python scripts/scan_exposed.py --validate-formats .env
94
- ```
95
-
96
- ### Synchronization Workflow
97
- ```bash
98
- # 1. Compare local vs platform
99
- python scripts/sync_secrets.py --platform vercel --compare
100
-
101
- # 2. Generate platform config
102
- python scripts/sync_secrets.py --platform vercel --generate
103
-
104
- # 3. Sync to platform (dry-run first)
105
- python scripts/sync_secrets.py --platform vercel --sync --dry-run
106
-
107
- # 4. Actual sync
108
- python scripts/sync_secrets.py --platform vercel --sync
109
- ```
110
-
111
- ### Documentation Workflow
112
- ```bash
113
- # Generate .env.example from .env
114
- python scripts/validate_env.py .env --generate-example
115
-
116
- # Generate setup documentation
117
- python scripts/validate_env.py .env --generate-docs
118
- ```
119
-
120
- ## Navigation
121
-
122
- For detailed workflows and patterns:
123
- - **[Validation](references/validation.md)**: Complete validation workflows and checks
124
- - **[Security](references/security.md)**: Secret scanning and security patterns
125
- - **[Synchronization](references/synchronization.md)**: Platform sync and secret manager integration
126
- - **[Frameworks](references/frameworks.md)**: Framework-specific patterns (Next.js, Express, Flask)
127
- - **[Troubleshooting](references/troubleshooting.md)**: Common issues and solutions
128
-
129
- ## Framework-Specific Quick Reference
130
-
131
- ### Next.js
132
- ```bash
133
- # Validate Next.js env structure
134
- # - NEXT_PUBLIC_* for client-side vars
135
- # - Check .env.local, .env.production precedence
136
- python scripts/validate_env.py .env --framework nextjs
137
-
138
- # Files to manage:
139
- # - .env.local (local development, gitignored)
140
- # - .env.production (production, usually from platform)
141
- # - .env (shared defaults, committed)
142
- # - .env.example (documentation, committed)
143
- ```
144
-
145
- ### Express/Node.js
146
- ```bash
147
- # Validate Node.js env structure
148
- python scripts/validate_env.py .env --framework nodejs
149
-
150
- # Standard structure:
151
- # - process.env.NODE_ENV
152
- # - process.env.PORT
153
- # - process.env.DATABASE_URL
154
- ```
155
-
156
- ### Python/Flask
157
- ```bash
158
- # Validate Python env structure
159
- python scripts/validate_env.py .env --framework python
160
-
161
- # Standard structure:
162
- # - FLASK_APP
163
- # - FLASK_ENV
164
- # - DATABASE_URL (SQLAlchemy format)
165
- ```
166
-
167
- ## Platform-Specific Quick Reference
168
-
169
- ### Vercel
170
- ```bash
171
- # Generate vercel.json env config
172
- python scripts/sync_secrets.py --platform vercel --generate
173
-
174
- # Sync to Vercel project
175
- python scripts/sync_secrets.py --platform vercel --sync
176
-
177
- # Respects NEXT_PUBLIC_ prefix for client-side vars
178
- ```
179
-
180
- ### Railway
181
- ```bash
182
- # Generate Railway config
183
- python scripts/sync_secrets.py --platform railway --generate
184
-
185
- # Sync to Railway project
186
- python scripts/sync_secrets.py --platform railway --sync
187
- ```
188
-
189
- ### Heroku
190
- ```bash
191
- # Generate Heroku config
192
- python scripts/sync_secrets.py --platform heroku --generate
193
-
194
- # Sync via Heroku CLI
195
- python scripts/sync_secrets.py --platform heroku --sync
196
- ```
197
-
198
- ## Key Reminders
199
-
200
- - **NEVER log actual secret values** - Always mask/redact in output
201
- - **Validate before every deployment** - Catch issues locally
202
- - **Use .env.example for documentation** - Keep it updated
203
- - **Framework conventions matter** - Next.js NEXT_PUBLIC_, Django DJANGO_SETTINGS_MODULE
204
- - **Platform-specific quirks exist** - Vercel auto-exposes NEXT_PUBLIC_*, Railway uses exact syntax
205
- - **Secret managers are your friend** - 1Password, AWS Secrets Manager for team sync
206
- - **.gitignore is critical** - NEVER commit .env files with secrets
207
- - **Environment precedence can be tricky** - Know your framework's loading order
208
-
209
- ## Common Validation Checks
210
-
211
- ### Structure Validation
212
- - [ ] No empty values (except explicitly allowed)
213
- - [ ] No inline comments (some parsers don't support)
214
- - [ ] Proper quoting for values with spaces
215
- - [ ] No duplicate keys
216
- - [ ] Valid key naming (UPPERCASE_WITH_UNDERSCORES)
217
-
218
- ### Security Validation
219
- - [ ] No exposed secrets in code
220
- - [ ] .env files in .gitignore
221
- - [ ] No secrets in git history
222
- - [ ] API keys match expected format
223
- - [ ] No hardcoded URLs with credentials
224
-
225
- ### Framework Validation (Next.js)
226
- - [ ] NEXT_PUBLIC_* for client-side vars only
227
- - [ ] No secrets in NEXT_PUBLIC_* vars
228
- - [ ] .env.local exists for local secrets
229
- - [ ] .env.example documents all vars
230
-
231
- ### Platform Validation (Vercel)
232
- - [ ] All required vars defined
233
- - [ ] No conflicts between environments
234
- - [ ] Correct variable names (Vercel conventions)
235
- - [ ] Build-time vs runtime vars separated
236
-
237
- ## Integration with Other Skills
238
-
239
- ### Related Skills
240
- - **docker-containerization** - Environment variables in containers
241
- - **security-scanning** - Broader security checks including secrets
242
- - **nextjs-local-dev** - Next.js specific development patterns
243
- - **systematic-debugging** - Debug env-related issues
244
-
245
- ### Workflow Integration
246
- ```
247
- 1. Developer creates .env.local
248
- 2. env-manager validates structure
249
- 3. env-manager scans for security issues
250
- 4. Developer generates .env.example
251
- 5. Before deploy: env-manager compares local vs platform
252
- 6. env-manager generates platform config
253
- 7. Developer reviews and confirms sync
254
- 8. env-manager syncs to platform
255
- 9. Deployment proceeds with verified configuration
256
- ```
257
-
258
- ---
259
-
260
- **Lines**: 197 (including frontmatter) ✓ <200
@@ -1,315 +0,0 @@
1
- # Next.js Environment Variable Structure
2
-
3
- Complete guide to Next.js environment variable management.
4
-
5
- ## File Structure
6
-
7
- ```
8
- my-nextjs-app/
9
- ├── .env # Shared defaults (committed)
10
- ├── .env.local # Local secrets (gitignored)
11
- ├── .env.development # Development defaults (committed)
12
- ├── .env.development.local # Local dev overrides (gitignored)
13
- ├── .env.production # Production defaults (committed)
14
- ├── .env.production.local # Production secrets (gitignored)
15
- ├── .env.test # Test environment (committed)
16
- └── .env.example # Documentation (committed)
17
- ```
18
-
19
- ## File Precedence
20
-
21
- Next.js loads files in this order (higher = higher precedence):
22
-
23
- 1. `.env.$(NODE_ENV).local` (e.g., `.env.production.local`)
24
- 2. `.env.local` (not loaded in test environment)
25
- 3. `.env.$(NODE_ENV)` (e.g., `.env.production`)
26
- 4. `.env`
27
-
28
- **Example**: In production, if `DATABASE_URL` is defined in both `.env` and `.env.production.local`, the value from `.env.production.local` wins.
29
-
30
- ## Variable Types
31
-
32
- ### Client-Side Variables (NEXT_PUBLIC_*)
33
-
34
- Exposed to the browser. Must prefix with `NEXT_PUBLIC_`.
35
-
36
- ```bash
37
- # .env.local
38
- NEXT_PUBLIC_API_URL=https://api.example.com
39
- NEXT_PUBLIC_ANALYTICS_ID=UA-123456789
40
- NEXT_PUBLIC_SITE_NAME=My Awesome Site
41
- NEXT_PUBLIC_ENABLE_FEATURE_X=true
42
- ```
43
-
44
- **Access in code**:
45
- ```javascript
46
- // Works in both client and server
47
- const apiUrl = process.env.NEXT_PUBLIC_API_URL;
48
-
49
- // Usage in components
50
- export default function MyComponent() {
51
- return <div>API: {process.env.NEXT_PUBLIC_API_URL}</div>;
52
- }
53
- ```
54
-
55
- **⚠️ Security Warning**: NEVER put secrets in `NEXT_PUBLIC_*` variables!
56
-
57
- ```bash
58
- # ❌ WRONG - Secret exposed to browser
59
- NEXT_PUBLIC_API_SECRET=sk_live_abc123
60
-
61
- # ✅ CORRECT - Secret only on server
62
- API_SECRET=sk_live_abc123
63
- ```
64
-
65
- ### Server-Side Variables
66
-
67
- Only available in server-side code (API routes, getServerSideProps, etc.).
68
-
69
- ```bash
70
- # .env.local
71
- DATABASE_URL=postgres://localhost:5432/mydb
72
- JWT_SECRET=super-secret-jwt-key-do-not-expose
73
- STRIPE_SECRET_KEY=sk_live_abc123
74
- SMTP_PASSWORD=email-password-here
75
- ```
76
-
77
- **Access in code**:
78
- ```javascript
79
- // ✅ Works in API routes
80
- export default async function handler(req, res) {
81
- const dbUrl = process.env.DATABASE_URL;
82
- // Use dbUrl...
83
- }
84
-
85
- // ✅ Works in getServerSideProps
86
- export async function getServerSideProps() {
87
- const secret = process.env.JWT_SECRET;
88
- // Use secret...
89
- }
90
-
91
- // ❌ Does NOT work in components (browser)
92
- export default function MyComponent() {
93
- const dbUrl = process.env.DATABASE_URL; // undefined!
94
- }
95
- ```
96
-
97
- ## Example Files
98
-
99
- ### .env (Committed - Shared Defaults)
100
-
101
- ```bash
102
- # Shared defaults for all environments
103
- NEXT_PUBLIC_APP_NAME=My Next.js App
104
- NEXT_PUBLIC_DEFAULT_LOCALE=en
105
-
106
- # Database (overridden in .env.local)
107
- DATABASE_URL=postgres://localhost:5432/dev
108
-
109
- # External services (no secrets)
110
- NEXT_PUBLIC_STRIPE_PUBLISHABLE_KEY=pk_test_abc123
111
- ```
112
-
113
- ### .env.local (Gitignored - Local Secrets)
114
-
115
- ```bash
116
- # Local development secrets
117
- DATABASE_URL=postgres://localhost:5432/mylocal
118
- JWT_SECRET=dev-jwt-secret-change-in-production
119
- STRIPE_SECRET_KEY=sk_test_local_key
120
-
121
- # Local overrides
122
- NEXT_PUBLIC_API_URL=http://localhost:4000/api
123
- ```
124
-
125
- ### .env.production (Committed - Production Defaults)
126
-
127
- ```bash
128
- # Production environment defaults
129
- NEXT_PUBLIC_API_URL=https://api.production.com
130
- NEXT_PUBLIC_ANALYTICS_ID=UA-PROD-123456
131
-
132
- # These will be overridden by platform env vars
133
- DATABASE_URL=set-this-in-vercel
134
- JWT_SECRET=set-this-in-vercel
135
- ```
136
-
137
- ### .env.example (Committed - Documentation)
138
-
139
- ```bash
140
- # Copy this to .env.local and fill in actual values
141
-
142
- # Client-side (browser accessible)
143
- NEXT_PUBLIC_API_URL=https://api.example.com
144
- NEXT_PUBLIC_ANALYTICS_ID=your-analytics-id
145
- NEXT_PUBLIC_SITE_NAME=Your Site Name
146
-
147
- # Server-side (secrets)
148
- DATABASE_URL=postgres://user:password@host:5432/database # pragma: allowlist secret
149
- JWT_SECRET=your-jwt-secret-32-chars-minimum
150
- STRIPE_SECRET_KEY=sk_live_your_stripe_key
151
- SMTP_HOST=smtp.example.com
152
- SMTP_PORT=587
153
- SMTP_USER=your-email@example.com
154
- SMTP_PASSWORD=your-smtp-password
155
- ```
156
-
157
- ## Common Patterns
158
-
159
- ### Database Configuration
160
-
161
- ```bash
162
- # Development (.env.local)
163
- DATABASE_URL=postgres://localhost:5432/myapp_dev
164
-
165
- # Production (Vercel Environment Variables)
166
- DATABASE_URL=postgres://user:pass@prod-host:5432/myapp_prod # pragma: allowlist secret
167
- ```
168
-
169
- ### API Keys
170
-
171
- ```bash
172
- # Public keys (client-side)
173
- NEXT_PUBLIC_STRIPE_PUBLISHABLE_KEY=pk_live_abc123
174
-
175
- # Secret keys (server-side only)
176
- STRIPE_SECRET_KEY=sk_live_xyz789
177
- ```
178
-
179
- ### Feature Flags
180
-
181
- ```bash
182
- # Toggle features
183
- NEXT_PUBLIC_ENABLE_DARK_MODE=true
184
- NEXT_PUBLIC_ENABLE_BETA_FEATURES=false
185
- ```
186
-
187
- ## Deployment to Vercel
188
-
189
- ### Step 1: Add Environment Variables in Vercel
190
-
191
- 1. Go to Project Settings → Environment Variables
192
- 2. Add each variable:
193
- - **Key**: `DATABASE_URL`
194
- - **Value**: `postgres://...`
195
- - **Environments**: Production, Preview, Development
196
-
197
- ### Step 2: Separate Client vs Server Variables
198
-
199
- Vercel automatically exposes `NEXT_PUBLIC_*` variables at build time.
200
-
201
- ```bash
202
- # Vercel automatically handles:
203
- NEXT_PUBLIC_API_URL=https://api.example.com # ✅ Exposed to browser
204
-
205
- # Server-only:
206
- DATABASE_URL=postgres://... # ✅ Not exposed to browser
207
- ```
208
-
209
- ### Step 3: Rebuild After Changing NEXT_PUBLIC_ Variables
210
-
211
- ⚠️ Important: `NEXT_PUBLIC_*` variables are **baked into the build** at build time.
212
-
213
- If you change them in Vercel, you must **redeploy**:
214
-
215
- ```bash
216
- vercel --prod
217
- ```
218
-
219
- ## Validation Workflow
220
-
221
- ### 1. Validate Local Environment
222
-
223
- ```bash
224
- # Check structure
225
- python scripts/validate_env.py .env.local --framework nextjs
226
-
227
- # Compare with .env.example
228
- python scripts/validate_env.py .env.local --compare-with .env.example
229
-
230
- # Check for security issues
231
- python scripts/scan_exposed.py --check-gitignore
232
- ```
233
-
234
- ### 2. Check File Precedence
235
-
236
- ```bash
237
- # List all .env files
238
- ls -la .env*
239
-
240
- # Validate each
241
- for file in .env*; do
242
- echo "=== $file ==="
243
- python scripts/validate_env.py $file --framework nextjs
244
- done
245
- ```
246
-
247
- ### 3. Sync to Vercel
248
-
249
- ```bash
250
- # Compare local vs Vercel
251
- python scripts/sync_secrets.py --platform vercel --compare
252
-
253
- # Sync (dry-run first)
254
- python scripts/sync_secrets.py --platform vercel --sync --dry-run
255
-
256
- # Actually sync
257
- python scripts/sync_secrets.py --platform vercel --sync --confirm
258
- ```
259
-
260
- ## Common Issues
261
-
262
- ### Issue: Variable Undefined in Browser
263
-
264
- **Symptom**: `process.env.MY_VAR` is `undefined` in component.
265
-
266
- **Solution**: Add `NEXT_PUBLIC_` prefix:
267
-
268
- ```bash
269
- # ❌ Wrong
270
- API_URL=https://api.example.com
271
-
272
- # ✅ Correct
273
- NEXT_PUBLIC_API_URL=https://api.example.com
274
- ```
275
-
276
- ### Issue: Changed Variable Not Reflected
277
-
278
- **Symptom**: Changed `NEXT_PUBLIC_*` variable in Vercel, but app still uses old value.
279
-
280
- **Solution**: Redeploy (variables are baked into build):
281
-
282
- ```bash
283
- vercel --prod
284
- ```
285
-
286
- ### Issue: Works Locally, Not in Production
287
-
288
- **Symptom**: App works with `.env.local`, fails in production.
289
-
290
- **Solution**: Ensure all variables from `.env.local` are set in Vercel:
291
-
292
- ```bash
293
- # Compare
294
- python scripts/sync_secrets.py --platform vercel --compare
295
-
296
- # Find missing vars and add them in Vercel UI
297
- ```
298
-
299
- ## Security Checklist
300
-
301
- - [ ] `.env.local` in `.gitignore`
302
- - [ ] `.env.*.local` in `.gitignore`
303
- - [ ] No secrets in `NEXT_PUBLIC_*` variables
304
- - [ ] No `.env` files committed with real secrets
305
- - [ ] `.env.example` has structure, not actual values
306
- - [ ] Secrets set directly in Vercel (not in committed files)
307
-
308
- ## References
309
-
310
- - [Next.js Environment Variables Documentation](https://nextjs.org/docs/basic-features/environment-variables)
311
- - [Vercel Environment Variables](https://vercel.com/docs/environment-variables)
312
-
313
- ---
314
-
315
- **Related**: [validation.md](../references/validation.md) | [security.md](../references/security.md) | [frameworks.md](../references/frameworks.md)