claude-mpm 4.21.3__py3-none-any.whl → 5.0.2__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 (484) hide show
  1. claude_mpm/VERSION +1 -1
  2. claude_mpm/agents/BASE_PM.md +12 -0
  3. claude_mpm/agents/OUTPUT_STYLE.md +3 -48
  4. claude_mpm/agents/PM_INSTRUCTIONS.md +632 -334
  5. claude_mpm/agents/WORKFLOW.md +75 -2
  6. claude_mpm/agents/__init__.py +6 -0
  7. claude_mpm/agents/agent_loader.py +1 -4
  8. claude_mpm/agents/base_agent.json +6 -3
  9. claude_mpm/agents/frontmatter_validator.py +1 -1
  10. claude_mpm/agents/templates/{circuit_breakers.md → circuit-breakers.md} +370 -3
  11. claude_mpm/agents/templates/context-management-examples.md +544 -0
  12. claude_mpm/agents/templates/{pm_red_flags.md → pm-red-flags.md} +89 -19
  13. claude_mpm/agents/templates/pr-workflow-examples.md +427 -0
  14. claude_mpm/agents/templates/research-gate-examples.md +669 -0
  15. claude_mpm/agents/templates/structured-questions-examples.md +615 -0
  16. claude_mpm/agents/templates/ticket-completeness-examples.md +139 -0
  17. claude_mpm/agents/templates/ticketing-examples.md +277 -0
  18. claude_mpm/cli/__init__.py +38 -2
  19. claude_mpm/cli/commands/agent_source.py +774 -0
  20. claude_mpm/cli/commands/agent_state_manager.py +125 -20
  21. claude_mpm/cli/commands/agents.py +684 -13
  22. claude_mpm/cli/commands/agents_cleanup.py +210 -0
  23. claude_mpm/cli/commands/agents_discover.py +338 -0
  24. claude_mpm/cli/commands/aggregate.py +1 -1
  25. claude_mpm/cli/commands/analyze.py +3 -3
  26. claude_mpm/cli/commands/auto_configure.py +2 -6
  27. claude_mpm/cli/commands/cleanup.py +1 -1
  28. claude_mpm/cli/commands/config.py +7 -4
  29. claude_mpm/cli/commands/configure.py +478 -44
  30. claude_mpm/cli/commands/configure_agent_display.py +4 -4
  31. claude_mpm/cli/commands/configure_navigation.py +63 -46
  32. claude_mpm/cli/commands/debug.py +12 -12
  33. claude_mpm/cli/commands/doctor.py +10 -2
  34. claude_mpm/cli/commands/hook_errors.py +277 -0
  35. claude_mpm/cli/commands/local_deploy.py +1 -4
  36. claude_mpm/cli/commands/mcp_install_commands.py +1 -1
  37. claude_mpm/cli/commands/mpm_init/core.py +50 -2
  38. claude_mpm/cli/commands/mpm_init/git_activity.py +10 -10
  39. claude_mpm/cli/commands/mpm_init/prompts.py +6 -6
  40. claude_mpm/cli/commands/run.py +124 -128
  41. claude_mpm/cli/commands/skill_source.py +694 -0
  42. claude_mpm/cli/commands/skills.py +435 -1
  43. claude_mpm/cli/executor.py +78 -3
  44. claude_mpm/cli/interactive/agent_wizard.py +919 -41
  45. claude_mpm/cli/parsers/agent_source_parser.py +171 -0
  46. claude_mpm/cli/parsers/agents_parser.py +173 -4
  47. claude_mpm/cli/parsers/base_parser.py +49 -0
  48. claude_mpm/cli/parsers/config_parser.py +96 -43
  49. claude_mpm/cli/parsers/skill_source_parser.py +169 -0
  50. claude_mpm/cli/parsers/skills_parser.py +138 -0
  51. claude_mpm/cli/parsers/source_parser.py +138 -0
  52. claude_mpm/cli/startup.py +499 -84
  53. claude_mpm/cli/startup_display.py +480 -0
  54. claude_mpm/cli/utils.py +1 -1
  55. claude_mpm/cli_module/commands.py +1 -1
  56. claude_mpm/commands/{mpm-auto-configure.md → mpm-agents-auto-configure.md} +9 -0
  57. claude_mpm/commands/mpm-agents-detect.md +9 -0
  58. claude_mpm/commands/{mpm-agents.md → mpm-agents-list.md} +9 -0
  59. claude_mpm/commands/mpm-agents-recommend.md +9 -0
  60. claude_mpm/commands/{mpm-config.md → mpm-config-view.md} +9 -0
  61. claude_mpm/commands/mpm-doctor.md +9 -0
  62. claude_mpm/commands/mpm-help.md +11 -2
  63. claude_mpm/commands/mpm-init.md +27 -2
  64. claude_mpm/commands/mpm-monitor.md +9 -0
  65. claude_mpm/commands/{mpm-resume.md → mpm-session-resume.md} +9 -0
  66. claude_mpm/commands/mpm-status.md +9 -0
  67. claude_mpm/commands/{mpm-organize.md → mpm-ticket-organize.md} +9 -0
  68. claude_mpm/commands/mpm-ticket-view.md +552 -0
  69. claude_mpm/commands/mpm-version.md +9 -0
  70. claude_mpm/commands/mpm.md +10 -0
  71. claude_mpm/config/agent_presets.py +258 -0
  72. claude_mpm/config/agent_sources.py +325 -0
  73. claude_mpm/config/skill_sources.py +590 -0
  74. claude_mpm/constants.py +12 -0
  75. claude_mpm/core/api_validator.py +1 -1
  76. claude_mpm/core/claude_runner.py +17 -10
  77. claude_mpm/core/config.py +24 -0
  78. claude_mpm/core/constants.py +1 -1
  79. claude_mpm/core/framework/__init__.py +3 -16
  80. claude_mpm/core/framework/loaders/instruction_loader.py +25 -5
  81. claude_mpm/core/framework/processors/metadata_processor.py +1 -1
  82. claude_mpm/core/hook_error_memory.py +381 -0
  83. claude_mpm/core/hook_manager.py +41 -2
  84. claude_mpm/core/interactive_session.py +112 -5
  85. claude_mpm/core/logger.py +3 -1
  86. claude_mpm/core/oneshot_session.py +94 -4
  87. claude_mpm/dashboard/static/css/activity.css +69 -69
  88. claude_mpm/dashboard/static/css/connection-status.css +10 -10
  89. claude_mpm/dashboard/static/css/dashboard.css +15 -15
  90. claude_mpm/dashboard/static/js/components/activity-tree.js +178 -178
  91. claude_mpm/dashboard/static/js/components/agent-hierarchy.js +101 -101
  92. claude_mpm/dashboard/static/js/components/agent-inference.js +31 -31
  93. claude_mpm/dashboard/static/js/components/build-tracker.js +59 -59
  94. claude_mpm/dashboard/static/js/components/code-simple.js +107 -107
  95. claude_mpm/dashboard/static/js/components/connection-debug.js +101 -101
  96. claude_mpm/dashboard/static/js/components/diff-viewer.js +113 -113
  97. claude_mpm/dashboard/static/js/components/event-viewer.js +12 -12
  98. claude_mpm/dashboard/static/js/components/file-change-tracker.js +57 -57
  99. claude_mpm/dashboard/static/js/components/file-change-viewer.js +74 -74
  100. claude_mpm/dashboard/static/js/components/file-tool-tracker.js +6 -6
  101. claude_mpm/dashboard/static/js/components/file-viewer.js +42 -42
  102. claude_mpm/dashboard/static/js/components/module-viewer.js +27 -27
  103. claude_mpm/dashboard/static/js/components/session-manager.js +14 -14
  104. claude_mpm/dashboard/static/js/components/socket-manager.js +1 -1
  105. claude_mpm/dashboard/static/js/components/ui-state-manager.js +14 -14
  106. claude_mpm/dashboard/static/js/components/unified-data-viewer.js +110 -110
  107. claude_mpm/dashboard/static/js/components/working-directory.js +8 -8
  108. claude_mpm/dashboard/static/js/connection-manager.js +76 -76
  109. claude_mpm/dashboard/static/js/dashboard.js +76 -58
  110. claude_mpm/dashboard/static/js/extension-error-handler.js +22 -22
  111. claude_mpm/dashboard/static/js/socket-client.js +138 -121
  112. claude_mpm/dashboard/templates/code_simple.html +23 -23
  113. claude_mpm/dashboard/templates/index.html +18 -18
  114. claude_mpm/experimental/cli_enhancements.py +1 -5
  115. claude_mpm/hooks/claude_hooks/event_handlers.py +3 -1
  116. claude_mpm/hooks/claude_hooks/hook_handler.py +24 -7
  117. claude_mpm/hooks/claude_hooks/installer.py +45 -0
  118. claude_mpm/hooks/failure_learning/__init__.py +2 -8
  119. claude_mpm/hooks/failure_learning/failure_detection_hook.py +1 -6
  120. claude_mpm/hooks/failure_learning/fix_detection_hook.py +1 -6
  121. claude_mpm/hooks/failure_learning/learning_extraction_hook.py +1 -6
  122. claude_mpm/hooks/kuzu_response_hook.py +1 -5
  123. claude_mpm/hooks/templates/pre_tool_use_simple.py +78 -0
  124. claude_mpm/hooks/templates/pre_tool_use_template.py +323 -0
  125. claude_mpm/models/git_repository.py +198 -0
  126. claude_mpm/scripts/claude-hook-handler.sh +3 -3
  127. claude_mpm/scripts/start_activity_logging.py +3 -1
  128. claude_mpm/services/agents/agent_builder.py +45 -9
  129. claude_mpm/services/agents/agent_preset_service.py +238 -0
  130. claude_mpm/services/agents/agent_selection_service.py +484 -0
  131. claude_mpm/services/agents/auto_deploy_index_parser.py +569 -0
  132. claude_mpm/services/agents/deployment/agent_deployment.py +126 -2
  133. claude_mpm/services/agents/deployment/agent_discovery_service.py +105 -73
  134. claude_mpm/services/agents/deployment/agent_format_converter.py +1 -1
  135. claude_mpm/services/agents/deployment/agent_lifecycle_manager.py +1 -5
  136. claude_mpm/services/agents/deployment/agent_metrics_collector.py +3 -3
  137. claude_mpm/services/agents/deployment/agent_restore_handler.py +1 -4
  138. claude_mpm/services/agents/deployment/agent_template_builder.py +236 -15
  139. claude_mpm/services/agents/deployment/agents_directory_resolver.py +101 -15
  140. claude_mpm/services/agents/deployment/async_agent_deployment.py +2 -1
  141. claude_mpm/services/agents/deployment/facade/deployment_facade.py +3 -3
  142. claude_mpm/services/agents/deployment/multi_source_deployment_service.py +115 -15
  143. claude_mpm/services/agents/deployment/pipeline/pipeline_executor.py +2 -2
  144. claude_mpm/services/agents/deployment/refactored_agent_deployment_service.py +1 -4
  145. claude_mpm/services/agents/deployment/remote_agent_discovery_service.py +363 -0
  146. claude_mpm/services/agents/deployment/single_agent_deployer.py +2 -2
  147. claude_mpm/services/agents/deployment/system_instructions_deployer.py +168 -46
  148. claude_mpm/services/agents/deployment/validation/deployment_validator.py +2 -2
  149. claude_mpm/services/agents/git_source_manager.py +629 -0
  150. claude_mpm/services/agents/loading/framework_agent_loader.py +9 -12
  151. claude_mpm/services/agents/local_template_manager.py +50 -10
  152. claude_mpm/services/agents/single_tier_deployment_service.py +696 -0
  153. claude_mpm/services/agents/sources/__init__.py +13 -0
  154. claude_mpm/services/agents/sources/agent_sync_state.py +516 -0
  155. claude_mpm/services/agents/sources/git_source_sync_service.py +1055 -0
  156. claude_mpm/services/agents/startup_sync.py +239 -0
  157. claude_mpm/services/agents/toolchain_detector.py +474 -0
  158. claude_mpm/services/cli/session_pause_manager.py +1 -1
  159. claude_mpm/services/cli/unified_dashboard_manager.py +1 -1
  160. claude_mpm/services/command_deployment_service.py +92 -1
  161. claude_mpm/services/core/interfaces/__init__.py +1 -3
  162. claude_mpm/services/core/interfaces/health.py +1 -4
  163. claude_mpm/services/core/models/__init__.py +2 -11
  164. claude_mpm/services/diagnostics/checks/__init__.py +4 -0
  165. claude_mpm/services/diagnostics/checks/agent_check.py +0 -2
  166. claude_mpm/services/diagnostics/checks/agent_sources_check.py +577 -0
  167. claude_mpm/services/diagnostics/checks/instructions_check.py +1 -2
  168. claude_mpm/services/diagnostics/checks/mcp_check.py +0 -1
  169. claude_mpm/services/diagnostics/checks/monitor_check.py +0 -1
  170. claude_mpm/services/diagnostics/checks/skill_sources_check.py +587 -0
  171. claude_mpm/services/diagnostics/diagnostic_runner.py +9 -0
  172. claude_mpm/services/diagnostics/doctor_reporter.py +40 -10
  173. claude_mpm/services/event_bus/direct_relay.py +3 -3
  174. claude_mpm/services/event_bus/event_bus.py +36 -3
  175. claude_mpm/services/events/consumers/logging.py +1 -2
  176. claude_mpm/services/git/__init__.py +21 -0
  177. claude_mpm/services/git/git_operations_service.py +494 -0
  178. claude_mpm/services/github/__init__.py +21 -0
  179. claude_mpm/services/github/github_cli_service.py +397 -0
  180. claude_mpm/services/infrastructure/monitoring/__init__.py +1 -5
  181. claude_mpm/services/infrastructure/monitoring/aggregator.py +1 -6
  182. claude_mpm/services/infrastructure/monitoring/resources.py +1 -1
  183. claude_mpm/services/instructions/__init__.py +9 -0
  184. claude_mpm/services/instructions/instruction_cache_service.py +374 -0
  185. claude_mpm/services/local_ops/__init__.py +3 -13
  186. claude_mpm/services/local_ops/health_checks/__init__.py +1 -3
  187. claude_mpm/services/local_ops/health_manager.py +1 -4
  188. claude_mpm/services/local_ops/process_manager.py +1 -1
  189. claude_mpm/services/local_ops/resource_monitor.py +2 -2
  190. claude_mpm/services/mcp_gateway/config/configuration.py +1 -1
  191. claude_mpm/services/mcp_gateway/server/mcp_gateway.py +1 -6
  192. claude_mpm/services/mcp_gateway/server/stdio_server.py +0 -2
  193. claude_mpm/services/mcp_gateway/tools/document_summarizer.py +1 -1
  194. claude_mpm/services/mcp_gateway/tools/kuzu_memory_service.py +6 -2
  195. claude_mpm/services/memory/optimizer.py +1 -1
  196. claude_mpm/services/model/model_router.py +8 -9
  197. claude_mpm/services/monitor/daemon.py +1 -1
  198. claude_mpm/services/monitor/server.py +2 -2
  199. claude_mpm/services/native_agent_converter.py +356 -0
  200. claude_mpm/services/port_manager.py +1 -1
  201. claude_mpm/services/pr/__init__.py +14 -0
  202. claude_mpm/services/pr/pr_template_service.py +329 -0
  203. claude_mpm/services/project/documentation_manager.py +2 -1
  204. claude_mpm/services/project/toolchain_analyzer.py +3 -1
  205. claude_mpm/services/runner_configuration_service.py +1 -0
  206. claude_mpm/services/self_upgrade_service.py +165 -7
  207. claude_mpm/services/skills/__init__.py +18 -0
  208. claude_mpm/services/skills/git_skill_source_manager.py +1169 -0
  209. claude_mpm/services/skills/skill_discovery_service.py +568 -0
  210. claude_mpm/services/skills_config.py +547 -0
  211. claude_mpm/services/skills_deployer.py +955 -0
  212. claude_mpm/services/socketio/handlers/connection.py +1 -1
  213. claude_mpm/services/socketio/handlers/git.py +2 -2
  214. claude_mpm/services/socketio/server/core.py +1 -4
  215. claude_mpm/services/socketio/server/main.py +1 -3
  216. claude_mpm/services/system_instructions_service.py +1 -3
  217. claude_mpm/services/unified/analyzer_strategies/performance_analyzer.py +0 -3
  218. claude_mpm/services/unified/analyzer_strategies/security_analyzer.py +0 -1
  219. claude_mpm/services/unified/deployment_strategies/cloud_strategies.py +1 -1
  220. claude_mpm/services/unified/deployment_strategies/vercel.py +1 -5
  221. claude_mpm/services/unified/unified_deployment.py +1 -5
  222. claude_mpm/services/version_control/conflict_resolution.py +6 -4
  223. claude_mpm/services/visualization/__init__.py +1 -5
  224. claude_mpm/services/visualization/mermaid_generator.py +2 -3
  225. claude_mpm/skills/bundled/infrastructure/env-manager/scripts/validate_env.py +576 -0
  226. claude_mpm/skills/bundled/performance-profiling.md +6 -0
  227. claude_mpm/skills/bundled/testing/webapp-testing/scripts/with_server.py +2 -2
  228. claude_mpm/skills/skills_registry.py +0 -1
  229. claude_mpm/templates/questions/__init__.py +38 -0
  230. claude_mpm/templates/questions/base.py +193 -0
  231. claude_mpm/templates/questions/pr_strategy.py +311 -0
  232. claude_mpm/templates/questions/project_init.py +385 -0
  233. claude_mpm/templates/questions/ticket_mgmt.py +394 -0
  234. claude_mpm/tools/__main__.py +8 -8
  235. claude_mpm/tools/code_tree_analyzer/analysis.py +1 -1
  236. claude_mpm/utils/agent_dependency_loader.py +80 -13
  237. claude_mpm/utils/dependency_cache.py +3 -1
  238. claude_mpm/utils/gitignore.py +241 -0
  239. claude_mpm/utils/log_cleanup.py +3 -3
  240. claude_mpm/utils/progress.py +383 -0
  241. claude_mpm/utils/robust_installer.py +3 -5
  242. claude_mpm/utils/structured_questions.py +619 -0
  243. {claude_mpm-4.21.3.dist-info → claude_mpm-5.0.2.dist-info}/METADATA +429 -59
  244. {claude_mpm-4.21.3.dist-info → claude_mpm-5.0.2.dist-info}/RECORD +252 -425
  245. claude_mpm/agents/templates/.claude-mpm/memories/README.md +0 -17
  246. claude_mpm/agents/templates/.claude-mpm/memories/engineer_memories.md +0 -3
  247. claude_mpm/agents/templates/agent-manager.json +0 -273
  248. claude_mpm/agents/templates/agentic-coder-optimizer.json +0 -248
  249. claude_mpm/agents/templates/api_qa.json +0 -180
  250. claude_mpm/agents/templates/clerk-ops.json +0 -235
  251. claude_mpm/agents/templates/code_analyzer.json +0 -101
  252. claude_mpm/agents/templates/content-agent.json +0 -358
  253. claude_mpm/agents/templates/dart_engineer.json +0 -307
  254. claude_mpm/agents/templates/data_engineer.json +0 -225
  255. claude_mpm/agents/templates/documentation.json +0 -211
  256. claude_mpm/agents/templates/engineer.json +0 -210
  257. claude_mpm/agents/templates/gcp_ops_agent.json +0 -253
  258. claude_mpm/agents/templates/golang_engineer.json +0 -270
  259. claude_mpm/agents/templates/imagemagick.json +0 -264
  260. claude_mpm/agents/templates/java_engineer.json +0 -346
  261. claude_mpm/agents/templates/local_ops_agent.json +0 -1840
  262. claude_mpm/agents/templates/logs/prompts/agent_engineer_20250826_014258_728.md +0 -39
  263. claude_mpm/agents/templates/logs/prompts/agent_engineer_20250901_010124_142.md +0 -400
  264. claude_mpm/agents/templates/memory_manager.json +0 -158
  265. claude_mpm/agents/templates/nextjs_engineer.json +0 -285
  266. claude_mpm/agents/templates/ops.json +0 -185
  267. claude_mpm/agents/templates/php-engineer.json +0 -287
  268. claude_mpm/agents/templates/product_owner.json +0 -338
  269. claude_mpm/agents/templates/project_organizer.json +0 -140
  270. claude_mpm/agents/templates/prompt-engineer.json +0 -737
  271. claude_mpm/agents/templates/python_engineer.json +0 -387
  272. claude_mpm/agents/templates/qa.json +0 -242
  273. claude_mpm/agents/templates/react_engineer.json +0 -238
  274. claude_mpm/agents/templates/refactoring_engineer.json +0 -276
  275. claude_mpm/agents/templates/research.json +0 -188
  276. claude_mpm/agents/templates/ruby-engineer.json +0 -280
  277. claude_mpm/agents/templates/rust_engineer.json +0 -275
  278. claude_mpm/agents/templates/security.json +0 -202
  279. claude_mpm/agents/templates/svelte-engineer.json +0 -225
  280. claude_mpm/agents/templates/ticketing.json +0 -177
  281. claude_mpm/agents/templates/typescript_engineer.json +0 -285
  282. claude_mpm/agents/templates/vercel_ops_agent.json +0 -412
  283. claude_mpm/agents/templates/version_control.json +0 -157
  284. claude_mpm/agents/templates/web_qa.json +0 -399
  285. claude_mpm/agents/templates/web_ui.json +0 -189
  286. claude_mpm/commands/mpm-tickets.md +0 -102
  287. claude_mpm/dashboard/.claude-mpm/socketio-instances.json +0 -1
  288. claude_mpm/dashboard/react/components/DataInspector/DataInspector.module.css +0 -188
  289. claude_mpm/dashboard/react/components/EventViewer/EventViewer.module.css +0 -156
  290. claude_mpm/dashboard/react/components/shared/ConnectionStatus.module.css +0 -38
  291. claude_mpm/dashboard/react/components/shared/FilterBar.module.css +0 -92
  292. claude_mpm/dashboard/static/archive/activity_dashboard_fixed.html +0 -248
  293. claude_mpm/dashboard/static/archive/activity_dashboard_test.html +0 -61
  294. claude_mpm/dashboard/static/archive/test_activity_connection.html +0 -179
  295. claude_mpm/dashboard/static/archive/test_claude_tree_tab.html +0 -68
  296. claude_mpm/dashboard/static/archive/test_dashboard.html +0 -409
  297. claude_mpm/dashboard/static/archive/test_dashboard_fixed.html +0 -519
  298. claude_mpm/dashboard/static/archive/test_dashboard_verification.html +0 -181
  299. claude_mpm/dashboard/static/archive/test_file_data.html +0 -315
  300. claude_mpm/dashboard/static/archive/test_file_tree_empty_state.html +0 -243
  301. claude_mpm/dashboard/static/archive/test_file_tree_fix.html +0 -234
  302. claude_mpm/dashboard/static/archive/test_file_tree_rename.html +0 -117
  303. claude_mpm/dashboard/static/archive/test_file_tree_tab.html +0 -115
  304. claude_mpm/dashboard/static/archive/test_file_viewer.html +0 -224
  305. claude_mpm/dashboard/static/archive/test_final_activity.html +0 -220
  306. claude_mpm/dashboard/static/archive/test_tab_fix.html +0 -139
  307. claude_mpm/dashboard/static/built/assets/events.DjpNxWNo.css +0 -1
  308. claude_mpm/dashboard/static/built/components/activity-tree.js +0 -2
  309. claude_mpm/dashboard/static/built/components/agent-hierarchy.js +0 -777
  310. claude_mpm/dashboard/static/built/components/agent-inference.js +0 -2
  311. claude_mpm/dashboard/static/built/components/build-tracker.js +0 -333
  312. claude_mpm/dashboard/static/built/components/code-simple.js +0 -857
  313. claude_mpm/dashboard/static/built/components/code-tree/tree-breadcrumb.js +0 -353
  314. claude_mpm/dashboard/static/built/components/code-tree/tree-constants.js +0 -235
  315. claude_mpm/dashboard/static/built/components/code-tree/tree-search.js +0 -409
  316. claude_mpm/dashboard/static/built/components/code-tree/tree-utils.js +0 -435
  317. claude_mpm/dashboard/static/built/components/code-tree.js +0 -2
  318. claude_mpm/dashboard/static/built/components/code-viewer.js +0 -2
  319. claude_mpm/dashboard/static/built/components/connection-debug.js +0 -654
  320. claude_mpm/dashboard/static/built/components/diff-viewer.js +0 -891
  321. claude_mpm/dashboard/static/built/components/event-processor.js +0 -2
  322. claude_mpm/dashboard/static/built/components/event-viewer.js +0 -2
  323. claude_mpm/dashboard/static/built/components/export-manager.js +0 -2
  324. claude_mpm/dashboard/static/built/components/file-change-tracker.js +0 -443
  325. claude_mpm/dashboard/static/built/components/file-change-viewer.js +0 -690
  326. claude_mpm/dashboard/static/built/components/file-tool-tracker.js +0 -2
  327. claude_mpm/dashboard/static/built/components/file-viewer.js +0 -2
  328. claude_mpm/dashboard/static/built/components/hud-library-loader.js +0 -2
  329. claude_mpm/dashboard/static/built/components/hud-manager.js +0 -2
  330. claude_mpm/dashboard/static/built/components/hud-visualizer.js +0 -2
  331. claude_mpm/dashboard/static/built/components/module-viewer.js +0 -2
  332. claude_mpm/dashboard/static/built/components/nav-bar.js +0 -145
  333. claude_mpm/dashboard/static/built/components/page-structure.js +0 -429
  334. claude_mpm/dashboard/static/built/components/session-manager.js +0 -2
  335. claude_mpm/dashboard/static/built/components/socket-manager.js +0 -2
  336. claude_mpm/dashboard/static/built/components/ui-state-manager.js +0 -2
  337. claude_mpm/dashboard/static/built/components/unified-data-viewer.js +0 -2
  338. claude_mpm/dashboard/static/built/components/working-directory.js +0 -2
  339. claude_mpm/dashboard/static/built/connection-manager.js +0 -536
  340. claude_mpm/dashboard/static/built/dashboard.js +0 -2
  341. claude_mpm/dashboard/static/built/extension-error-handler.js +0 -164
  342. claude_mpm/dashboard/static/built/react/events.js +0 -30
  343. claude_mpm/dashboard/static/built/shared/dom-helpers.js +0 -396
  344. claude_mpm/dashboard/static/built/shared/event-bus.js +0 -330
  345. claude_mpm/dashboard/static/built/shared/event-filter-service.js +0 -540
  346. claude_mpm/dashboard/static/built/shared/logger.js +0 -385
  347. claude_mpm/dashboard/static/built/shared/page-structure.js +0 -249
  348. claude_mpm/dashboard/static/built/shared/tooltip-service.js +0 -253
  349. claude_mpm/dashboard/static/built/socket-client.js +0 -2
  350. claude_mpm/dashboard/static/built/tab-isolation-fix.js +0 -185
  351. claude_mpm/dashboard/static/dist/assets/events.DjpNxWNo.css +0 -1
  352. claude_mpm/dashboard/static/dist/components/activity-tree.js +0 -2
  353. claude_mpm/dashboard/static/dist/components/agent-inference.js +0 -2
  354. claude_mpm/dashboard/static/dist/components/code-tree.js +0 -2
  355. claude_mpm/dashboard/static/dist/components/code-viewer.js +0 -2
  356. claude_mpm/dashboard/static/dist/components/event-processor.js +0 -2
  357. claude_mpm/dashboard/static/dist/components/event-viewer.js +0 -2
  358. claude_mpm/dashboard/static/dist/components/export-manager.js +0 -2
  359. claude_mpm/dashboard/static/dist/components/file-tool-tracker.js +0 -2
  360. claude_mpm/dashboard/static/dist/components/file-viewer.js +0 -2
  361. claude_mpm/dashboard/static/dist/components/hud-library-loader.js +0 -2
  362. claude_mpm/dashboard/static/dist/components/hud-manager.js +0 -2
  363. claude_mpm/dashboard/static/dist/components/hud-visualizer.js +0 -2
  364. claude_mpm/dashboard/static/dist/components/module-viewer.js +0 -2
  365. claude_mpm/dashboard/static/dist/components/session-manager.js +0 -2
  366. claude_mpm/dashboard/static/dist/components/socket-manager.js +0 -2
  367. claude_mpm/dashboard/static/dist/components/ui-state-manager.js +0 -2
  368. claude_mpm/dashboard/static/dist/components/unified-data-viewer.js +0 -2
  369. claude_mpm/dashboard/static/dist/components/working-directory.js +0 -2
  370. claude_mpm/dashboard/static/dist/dashboard.js +0 -2
  371. claude_mpm/dashboard/static/dist/react/events.js +0 -30
  372. claude_mpm/dashboard/static/dist/socket-client.js +0 -2
  373. claude_mpm/dashboard/static/events.html +0 -607
  374. claude_mpm/dashboard/static/index.html +0 -635
  375. claude_mpm/dashboard/static/js/shared/dom-helpers.js +0 -396
  376. claude_mpm/dashboard/static/js/shared/event-bus.js +0 -330
  377. claude_mpm/dashboard/static/js/shared/logger.js +0 -385
  378. claude_mpm/dashboard/static/js/shared/tooltip-service.js +0 -253
  379. claude_mpm/dashboard/static/js/stores/dashboard-store.js +0 -562
  380. claude_mpm/dashboard/static/legacy/activity.html +0 -736
  381. claude_mpm/dashboard/static/legacy/agents.html +0 -786
  382. claude_mpm/dashboard/static/legacy/files.html +0 -747
  383. claude_mpm/dashboard/static/legacy/tools.html +0 -831
  384. claude_mpm/dashboard/static/monitors.html +0 -431
  385. claude_mpm/dashboard/static/production/events.html +0 -659
  386. claude_mpm/dashboard/static/production/main.html +0 -698
  387. claude_mpm/dashboard/static/production/monitors.html +0 -483
  388. claude_mpm/dashboard/static/test-archive/dashboard.html +0 -635
  389. claude_mpm/dashboard/static/test-archive/debug-events.html +0 -147
  390. claude_mpm/dashboard/static/test-archive/test-navigation.html +0 -256
  391. claude_mpm/dashboard/static/test-archive/test-react-exports.html +0 -180
  392. claude_mpm/dashboard/static/test-archive/test_debug.html +0 -25
  393. claude_mpm/skills/bundled/collaboration/brainstorming/SKILL.md +0 -79
  394. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/SKILL.md +0 -178
  395. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/agent-prompts.md +0 -577
  396. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/coordination-patterns.md +0 -467
  397. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/examples.md +0 -537
  398. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/troubleshooting.md +0 -730
  399. claude_mpm/skills/bundled/collaboration/requesting-code-review/SKILL.md +0 -112
  400. claude_mpm/skills/bundled/collaboration/requesting-code-review/references/code-reviewer-template.md +0 -146
  401. claude_mpm/skills/bundled/collaboration/requesting-code-review/references/review-examples.md +0 -412
  402. claude_mpm/skills/bundled/collaboration/writing-plans/SKILL.md +0 -81
  403. claude_mpm/skills/bundled/collaboration/writing-plans/references/best-practices.md +0 -362
  404. claude_mpm/skills/bundled/collaboration/writing-plans/references/plan-structure-templates.md +0 -312
  405. claude_mpm/skills/bundled/debugging/root-cause-tracing/SKILL.md +0 -152
  406. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/advanced-techniques.md +0 -668
  407. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/examples.md +0 -587
  408. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/integration.md +0 -438
  409. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/tracing-techniques.md +0 -391
  410. claude_mpm/skills/bundled/debugging/systematic-debugging/CREATION-LOG.md +0 -119
  411. claude_mpm/skills/bundled/debugging/systematic-debugging/SKILL.md +0 -148
  412. claude_mpm/skills/bundled/debugging/systematic-debugging/references/anti-patterns.md +0 -483
  413. claude_mpm/skills/bundled/debugging/systematic-debugging/references/examples.md +0 -452
  414. claude_mpm/skills/bundled/debugging/systematic-debugging/references/troubleshooting.md +0 -449
  415. claude_mpm/skills/bundled/debugging/systematic-debugging/references/workflow.md +0 -411
  416. claude_mpm/skills/bundled/debugging/systematic-debugging/test-academic.md +0 -14
  417. claude_mpm/skills/bundled/debugging/systematic-debugging/test-pressure-1.md +0 -58
  418. claude_mpm/skills/bundled/debugging/systematic-debugging/test-pressure-2.md +0 -68
  419. claude_mpm/skills/bundled/debugging/systematic-debugging/test-pressure-3.md +0 -69
  420. claude_mpm/skills/bundled/debugging/verification-before-completion/SKILL.md +0 -131
  421. claude_mpm/skills/bundled/debugging/verification-before-completion/references/gate-function.md +0 -325
  422. claude_mpm/skills/bundled/debugging/verification-before-completion/references/integration-and-workflows.md +0 -490
  423. claude_mpm/skills/bundled/debugging/verification-before-completion/references/red-flags-and-failures.md +0 -425
  424. claude_mpm/skills/bundled/debugging/verification-before-completion/references/verification-patterns.md +0 -499
  425. claude_mpm/skills/bundled/main/artifacts-builder/SKILL.md +0 -86
  426. claude_mpm/skills/bundled/main/internal-comms/SKILL.md +0 -43
  427. claude_mpm/skills/bundled/main/internal-comms/examples/3p-updates.md +0 -47
  428. claude_mpm/skills/bundled/main/internal-comms/examples/company-newsletter.md +0 -65
  429. claude_mpm/skills/bundled/main/internal-comms/examples/faq-answers.md +0 -30
  430. claude_mpm/skills/bundled/main/internal-comms/examples/general-comms.md +0 -16
  431. claude_mpm/skills/bundled/main/mcp-builder/SKILL.md +0 -160
  432. claude_mpm/skills/bundled/main/mcp-builder/reference/design_principles.md +0 -412
  433. claude_mpm/skills/bundled/main/mcp-builder/reference/evaluation.md +0 -602
  434. claude_mpm/skills/bundled/main/mcp-builder/reference/mcp_best_practices.md +0 -915
  435. claude_mpm/skills/bundled/main/mcp-builder/reference/node_mcp_server.md +0 -916
  436. claude_mpm/skills/bundled/main/mcp-builder/reference/python_mcp_server.md +0 -752
  437. claude_mpm/skills/bundled/main/mcp-builder/reference/workflow.md +0 -1237
  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/rust/desktop-applications/SKILL.md +0 -226
  452. claude_mpm/skills/bundled/rust/desktop-applications/references/architecture-patterns.md +0 -901
  453. claude_mpm/skills/bundled/rust/desktop-applications/references/native-gui-frameworks.md +0 -901
  454. claude_mpm/skills/bundled/rust/desktop-applications/references/platform-integration.md +0 -775
  455. claude_mpm/skills/bundled/rust/desktop-applications/references/state-management.md +0 -937
  456. claude_mpm/skills/bundled/rust/desktop-applications/references/tauri-framework.md +0 -770
  457. claude_mpm/skills/bundled/rust/desktop-applications/references/testing-deployment.md +0 -961
  458. claude_mpm/skills/bundled/testing/condition-based-waiting/SKILL.md +0 -119
  459. claude_mpm/skills/bundled/testing/condition-based-waiting/references/patterns-and-implementation.md +0 -253
  460. claude_mpm/skills/bundled/testing/test-driven-development/SKILL.md +0 -145
  461. claude_mpm/skills/bundled/testing/test-driven-development/references/anti-patterns.md +0 -543
  462. claude_mpm/skills/bundled/testing/test-driven-development/references/examples.md +0 -741
  463. claude_mpm/skills/bundled/testing/test-driven-development/references/integration.md +0 -470
  464. claude_mpm/skills/bundled/testing/test-driven-development/references/philosophy.md +0 -458
  465. claude_mpm/skills/bundled/testing/test-driven-development/references/workflow.md +0 -639
  466. claude_mpm/skills/bundled/testing/testing-anti-patterns/SKILL.md +0 -140
  467. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/completeness-anti-patterns.md +0 -572
  468. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/core-anti-patterns.md +0 -411
  469. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/detection-guide.md +0 -569
  470. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/tdd-connection.md +0 -695
  471. claude_mpm/skills/bundled/testing/webapp-testing/SKILL.md +0 -184
  472. claude_mpm/skills/bundled/testing/webapp-testing/decision-tree.md +0 -459
  473. claude_mpm/skills/bundled/testing/webapp-testing/playwright-patterns.md +0 -479
  474. claude_mpm/skills/bundled/testing/webapp-testing/reconnaissance-pattern.md +0 -687
  475. claude_mpm/skills/bundled/testing/webapp-testing/server-management.md +0 -758
  476. claude_mpm/skills/bundled/testing/webapp-testing/troubleshooting.md +0 -868
  477. /claude_mpm/agents/templates/{git_file_tracking.md → git-file-tracking.md} +0 -0
  478. /claude_mpm/agents/templates/{pm_examples.md → pm-examples.md} +0 -0
  479. /claude_mpm/agents/templates/{response_format.md → response-format.md} +0 -0
  480. /claude_mpm/agents/templates/{validation_templates.md → validation-templates.md} +0 -0
  481. {claude_mpm-4.21.3.dist-info → claude_mpm-5.0.2.dist-info}/WHEEL +0 -0
  482. {claude_mpm-4.21.3.dist-info → claude_mpm-5.0.2.dist-info}/entry_points.txt +0 -0
  483. {claude_mpm-4.21.3.dist-info → claude_mpm-5.0.2.dist-info}/licenses/LICENSE +0 -0
  484. {claude_mpm-4.21.3.dist-info → claude_mpm-5.0.2.dist-info}/top_level.txt +0 -0
@@ -1,775 +0,0 @@
1
- # Platform Integration
2
-
3
- Comprehensive guide to integrating with native platform features across Windows, macOS, and Linux in Rust desktop applications.
4
-
5
- ## File System Access
6
-
7
- ### File Dialogs
8
-
9
- ```rust
10
- use tauri::api::dialog::{FileDialogBuilder, MessageDialogBuilder, MessageDialogKind};
11
-
12
- #[tauri::command]
13
- async fn open_file_dialog() -> Result<Option<String>, String> {
14
- let path = FileDialogBuilder::new()
15
- .add_filter("Text Files", &["txt", "md"])
16
- .add_filter("All Files", &["*"])
17
- .set_title("Select a file")
18
- .pick_file();
19
-
20
- Ok(path.map(|p| p.to_string_lossy().to_string()))
21
- }
22
-
23
- #[tauri::command]
24
- async fn open_folder_dialog() -> Result<Option<String>, String> {
25
- let path = FileDialogBuilder::new()
26
- .set_title("Select a folder")
27
- .pick_folder();
28
-
29
- Ok(path.map(|p| p.to_string_lossy().to_string()))
30
- }
31
-
32
- #[tauri::command]
33
- async fn save_file_dialog() -> Result<Option<String>, String> {
34
- let path = FileDialogBuilder::new()
35
- .add_filter("JSON Files", &["json"])
36
- .set_file_name("untitled.json")
37
- .save_file();
38
-
39
- Ok(path.map(|p| p.to_string_lossy().to_string()))
40
- }
41
-
42
- #[tauri::command]
43
- async fn show_message(title: String, message: String) -> Result<(), String> {
44
- MessageDialogBuilder::new(title, message)
45
- .kind(MessageDialogKind::Info)
46
- .show();
47
-
48
- Ok(())
49
- }
50
-
51
- #[tauri::command]
52
- async fn confirm_dialog(title: String, message: String) -> Result<bool, String> {
53
- let confirmed = MessageDialogBuilder::new(title, message)
54
- .kind(MessageDialogKind::Warning)
55
- .buttons(tauri::api::dialog::MessageDialogButtons::OkCancel)
56
- .show();
57
-
58
- Ok(confirmed)
59
- }
60
- ```
61
-
62
- ### Safe File System Operations
63
-
64
- ```rust
65
- use std::path::{Path, PathBuf};
66
- use std::fs;
67
-
68
- // Validate file paths to prevent directory traversal
69
- fn validate_path(path: &str, base_dir: &Path) -> Result<PathBuf, String> {
70
- let path = Path::new(path);
71
-
72
- // Canonicalize to resolve .. and symlinks
73
- let canonical = path
74
- .canonicalize()
75
- .map_err(|_| "Invalid path".to_string())?;
76
-
77
- // Ensure path is within base directory
78
- if !canonical.starts_with(base_dir) {
79
- return Err("Path outside allowed directory".to_string());
80
- }
81
-
82
- Ok(canonical)
83
- }
84
-
85
- #[tauri::command]
86
- async fn read_file_safe(app: tauri::AppHandle, relative_path: String) -> Result<String, String> {
87
- let app_dir = app
88
- .path()
89
- .app_data_dir()
90
- .map_err(|e| e.to_string())?;
91
-
92
- let file_path = validate_path(&relative_path, &app_dir)?;
93
-
94
- fs::read_to_string(file_path).map_err(|e| e.to_string())
95
- }
96
-
97
- #[tauri::command]
98
- async fn write_file_safe(
99
- app: tauri::AppHandle,
100
- relative_path: String,
101
- content: String,
102
- ) -> Result<(), String> {
103
- let app_dir = app
104
- .path()
105
- .app_data_dir()
106
- .map_err(|e| e.to_string())?;
107
-
108
- // Ensure directory exists
109
- fs::create_dir_all(&app_dir).map_err(|e| e.to_string())?;
110
-
111
- let file_path = app_dir.join(&relative_path);
112
-
113
- // Security check
114
- let canonical = file_path
115
- .canonicalize()
116
- .or_else(|_| {
117
- // File doesn't exist yet, validate parent
118
- file_path
119
- .parent()
120
- .ok_or("Invalid path")?
121
- .canonicalize()
122
- .map(|p| p.join(file_path.file_name().unwrap()))
123
- })
124
- .map_err(|_| "Invalid path".to_string())?;
125
-
126
- if !canonical.starts_with(&app_dir) {
127
- return Err("Path outside allowed directory".to_string());
128
- }
129
-
130
- fs::write(canonical, content).map_err(|e| e.to_string())
131
- }
132
- ```
133
-
134
- ### File Watching
135
-
136
- ```rust
137
- use notify::{Watcher, RecursiveMode, Event};
138
- use std::sync::mpsc::channel;
139
- use std::time::Duration;
140
-
141
- struct FileWatcher {
142
- watcher: notify::RecommendedWatcher,
143
- }
144
-
145
- impl FileWatcher {
146
- fn new(app_handle: tauri::AppHandle) -> Result<Self, String> {
147
- let (tx, rx) = channel();
148
-
149
- let mut watcher = notify::recommended_watcher(tx)
150
- .map_err(|e| e.to_string())?;
151
-
152
- // Spawn task to handle events
153
- tokio::spawn(async move {
154
- while let Ok(event) = rx.recv() {
155
- if let Ok(Event { kind, paths, .. }) = event {
156
- let _ = app_handle.emit("file-changed", FileChangeEvent {
157
- kind: format!("{:?}", kind),
158
- paths: paths.iter().map(|p| p.to_string_lossy().to_string()).collect(),
159
- });
160
- }
161
- }
162
- });
163
-
164
- Ok(Self { watcher })
165
- }
166
-
167
- fn watch(&mut self, path: &str) -> Result<(), String> {
168
- self.watcher
169
- .watch(Path::new(path), RecursiveMode::Recursive)
170
- .map_err(|e| e.to_string())
171
- }
172
-
173
- fn unwatch(&mut self, path: &str) -> Result<(), String> {
174
- self.watcher
175
- .unwatch(Path::new(path))
176
- .map_err(|e| e.to_string())
177
- }
178
- }
179
-
180
- #[derive(Clone, serde::Serialize)]
181
- struct FileChangeEvent {
182
- kind: String,
183
- paths: Vec<String>,
184
- }
185
-
186
- #[tauri::command]
187
- fn watch_directory(
188
- watcher: tauri::State<FileWatcher>,
189
- path: String,
190
- ) -> Result<(), String> {
191
- watcher.inner().lock().unwrap().watch(&path)
192
- }
193
- ```
194
-
195
- ## System Tray Integration
196
-
197
- ### Cross-Platform System Tray
198
-
199
- ```rust
200
- use tauri::{
201
- menu::{Menu, MenuItem, Submenu},
202
- tray::{TrayIconBuilder, TrayIconEvent},
203
- Manager, Runtime,
204
- };
205
-
206
- fn create_tray<R: Runtime>(app: &tauri::AppHandle<R>) -> Result<(), Box<dyn std::error::Error>> {
207
- // Create menu items
208
- let show_item = MenuItem::with_id(app, "show", "Show Window", true, None::<&str>)?;
209
- let hide_item = MenuItem::with_id(app, "hide", "Hide Window", true, None::<&str>)?;
210
- let quit_item = MenuItem::with_id(app, "quit", "Quit", true, None::<&str>)?;
211
-
212
- // Create submenu
213
- let settings_menu = Submenu::with_items(
214
- app,
215
- "Settings",
216
- true,
217
- &[
218
- &MenuItem::with_id(app, "preferences", "Preferences", true, None::<&str>)?,
219
- &MenuItem::with_id(app, "about", "About", true, None::<&str>)?,
220
- ],
221
- )?;
222
-
223
- // Create menu
224
- let menu = Menu::with_items(app, &[&show_item, &hide_item, &settings_menu, &quit_item])?;
225
-
226
- // Build tray icon
227
- let _tray = TrayIconBuilder::new()
228
- .icon(app.default_window_icon().unwrap().clone())
229
- .menu(&menu)
230
- .tooltip("My Application")
231
- .on_menu_event(|app, event| match event.id.as_ref() {
232
- "show" => {
233
- if let Some(window) = app.get_webview_window("main") {
234
- let _ = window.show();
235
- let _ = window.set_focus();
236
- }
237
- }
238
- "hide" => {
239
- if let Some(window) = app.get_webview_window("main") {
240
- let _ = window.hide();
241
- }
242
- }
243
- "quit" => {
244
- app.exit(0);
245
- }
246
- "preferences" => {
247
- // Open preferences window
248
- println!("Open preferences");
249
- }
250
- "about" => {
251
- // Show about dialog
252
- println!("Show about dialog");
253
- }
254
- _ => {}
255
- })
256
- .on_tray_icon_event(|tray, event| {
257
- if let TrayIconEvent::Click { .. } = event {
258
- // Handle tray icon click
259
- let app = tray.app_handle();
260
- if let Some(window) = app.get_webview_window("main") {
261
- if window.is_visible().unwrap_or(false) {
262
- let _ = window.hide();
263
- } else {
264
- let _ = window.show();
265
- let _ = window.set_focus();
266
- }
267
- }
268
- }
269
- })
270
- .build(app)?;
271
-
272
- Ok(())
273
- }
274
-
275
- fn main() {
276
- tauri::Builder::default()
277
- .setup(|app| {
278
- create_tray(app.handle())?;
279
- Ok(())
280
- })
281
- .run(tauri::generate_context!())
282
- .expect("error while running tauri application");
283
- }
284
- ```
285
-
286
- ### Dynamic Tray Menu Updates
287
-
288
- ```rust
289
- use std::sync::Mutex;
290
-
291
- struct TrayState {
292
- is_recording: Mutex<bool>,
293
- }
294
-
295
- #[tauri::command]
296
- fn toggle_recording(
297
- app: tauri::AppHandle,
298
- state: tauri::State<TrayState>,
299
- ) -> Result<(), String> {
300
- let mut is_recording = state.is_recording.lock().unwrap();
301
- *is_recording = !*is_recording;
302
-
303
- // Update tray menu
304
- let tray = app.tray_by_id("main").ok_or("Tray not found")?;
305
-
306
- let menu_item = tray
307
- .get_item("toggle_recording")
308
- .ok_or("Menu item not found")?;
309
-
310
- menu_item
311
- .set_text(if *is_recording {
312
- "Stop Recording"
313
- } else {
314
- "Start Recording"
315
- })
316
- .map_err(|e| e.to_string())?;
317
-
318
- Ok(())
319
- }
320
- ```
321
-
322
- ## Native Notifications
323
-
324
- ### Cross-Platform Notifications
325
-
326
- ```rust
327
- use tauri::Notification;
328
-
329
- #[tauri::command]
330
- fn send_notification(
331
- app: tauri::AppHandle,
332
- title: String,
333
- body: String,
334
- ) -> Result<(), String> {
335
- Notification::new(&app.config().identifier)
336
- .title(title)
337
- .body(body)
338
- .icon("icon")
339
- .show()
340
- .map_err(|e| e.to_string())
341
- }
342
-
343
- #[tauri::command]
344
- fn send_notification_with_action(
345
- app: tauri::AppHandle,
346
- title: String,
347
- body: String,
348
- ) -> Result<(), String> {
349
- // Note: Actions are platform-dependent
350
- #[cfg(target_os = "macos")]
351
- {
352
- Notification::new(&app.config().identifier)
353
- .title(title)
354
- .body(body)
355
- .sound("default")
356
- .show()
357
- .map_err(|e| e.to_string())
358
- }
359
-
360
- #[cfg(not(target_os = "macos"))]
361
- {
362
- Notification::new(&app.config().identifier)
363
- .title(title)
364
- .body(body)
365
- .show()
366
- .map_err(|e| e.to_string())
367
- }
368
- }
369
- ```
370
-
371
- ### Notification with User Interaction
372
-
373
- ```rust
374
- use tauri::{Emitter, Manager};
375
-
376
- #[tauri::command]
377
- async fn send_interactive_notification(
378
- app: tauri::AppHandle,
379
- title: String,
380
- body: String,
381
- ) -> Result<(), String> {
382
- // Send notification
383
- Notification::new(&app.config().identifier)
384
- .title(&title)
385
- .body(&body)
386
- .show()
387
- .map_err(|e| e.to_string())?;
388
-
389
- // Listen for notification clicks (platform-dependent)
390
- // This is a simplified example; real implementation needs platform-specific code
391
-
392
- Ok(())
393
- }
394
- ```
395
-
396
- ## Auto-Updates
397
-
398
- ### Tauri Updater Integration
399
-
400
- ```rust
401
- use tauri_plugin_updater::UpdaterExt;
402
-
403
- #[tauri::command]
404
- async fn check_for_updates(app: tauri::AppHandle) -> Result<Option<String>, String> {
405
- let update = app
406
- .updater()
407
- .check()
408
- .await
409
- .map_err(|e| e.to_string())?;
410
-
411
- if let Some(update) = update {
412
- Ok(Some(format!(
413
- "Update available: {} (current: {})",
414
- update.version,
415
- update.current_version
416
- )))
417
- } else {
418
- Ok(None)
419
- }
420
- }
421
-
422
- #[tauri::command]
423
- async fn install_update(app: tauri::AppHandle) -> Result<(), String> {
424
- let update = app
425
- .updater()
426
- .check()
427
- .await
428
- .map_err(|e| e.to_string())?;
429
-
430
- if let Some(update) = update {
431
- // Download and install
432
- update
433
- .download_and_install(
434
- |chunk_length, content_length| {
435
- println!(
436
- "Downloaded {} of {:?}",
437
- chunk_length,
438
- content_length
439
- );
440
- },
441
- || {
442
- println!("Download finished");
443
- },
444
- )
445
- .await
446
- .map_err(|e| e.to_string())?;
447
-
448
- // Restart app
449
- app.restart();
450
- }
451
-
452
- Ok(())
453
- }
454
-
455
- // Setup auto-update check
456
- fn main() {
457
- tauri::Builder::default()
458
- .plugin(tauri_plugin_updater::Builder::new().build())
459
- .setup(|app| {
460
- let handle = app.handle().clone();
461
-
462
- // Check for updates on startup
463
- tauri::async_runtime::spawn(async move {
464
- tokio::time::sleep(tokio::time::Duration::from_secs(5)).await;
465
-
466
- if let Ok(Some(update)) = handle.updater().check().await {
467
- println!("Update available: {}", update.version);
468
-
469
- // Emit event to frontend
470
- let _ = handle.emit("update-available", &update.version);
471
- }
472
- });
473
-
474
- Ok(())
475
- })
476
- .run(tauri::generate_context!())
477
- .expect("error while running tauri application");
478
- }
479
- ```
480
-
481
- ## Deep Linking / Custom URL Schemes
482
-
483
- ### Register URL Scheme
484
-
485
- **tauri.conf.json:**
486
- ```json
487
- {
488
- "bundle": {
489
- "macOS": {
490
- "associatedDomains": ["myapp://"],
491
- "category": "public.app-category.developer-tools"
492
- },
493
- "windows": {
494
- "webviewInstallMode": {
495
- "type": "downloadBootstrapper"
496
- },
497
- "protocols": [
498
- {
499
- "name": "myapp",
500
- "schemes": ["myapp"]
501
- }
502
- ]
503
- }
504
- }
505
- }
506
- ```
507
-
508
- ### Handle Deep Links
509
-
510
- ```rust
511
- use tauri::{Emitter, Manager};
512
-
513
- fn main() {
514
- tauri::Builder::default()
515
- .setup(|app| {
516
- // Register URL handler
517
- app.listen_any("deep-link://", |event| {
518
- println!("Received deep link: {:?}", event.payload());
519
- });
520
-
521
- Ok(())
522
- })
523
- .plugin(tauri_plugin_deep_link::init())
524
- .run(tauri::generate_context!())
525
- .expect("error while running tauri application");
526
- }
527
-
528
- #[tauri::command]
529
- fn handle_url(app: tauri::AppHandle, url: String) -> Result<(), String> {
530
- println!("Handling URL: {}", url);
531
-
532
- // Parse URL and navigate
533
- if url.starts_with("myapp://open/") {
534
- let file = url.strip_prefix("myapp://open/").unwrap();
535
- app.emit("open-file", file).map_err(|e| e.to_string())?;
536
- }
537
-
538
- Ok(())
539
- }
540
- ```
541
-
542
- ## Platform-Specific Features
543
-
544
- ### Windows
545
-
546
- ```rust
547
- #[cfg(target_os = "windows")]
548
- mod windows {
549
- use winapi::um::winuser::{MessageBoxW, MB_OK};
550
- use std::ffi::OsStr;
551
- use std::os::windows::ffi::OsStrExt;
552
-
553
- pub fn show_native_message_box(title: &str, message: &str) {
554
- let title_wide: Vec<u16> = OsStr::new(title)
555
- .encode_wide()
556
- .chain(std::iter::once(0))
557
- .collect();
558
-
559
- let message_wide: Vec<u16> = OsStr::new(message)
560
- .encode_wide()
561
- .chain(std::iter::once(0))
562
- .collect();
563
-
564
- unsafe {
565
- MessageBoxW(
566
- std::ptr::null_mut(),
567
- message_wide.as_ptr(),
568
- title_wide.as_ptr(),
569
- MB_OK,
570
- );
571
- }
572
- }
573
-
574
- // Windows Registry access
575
- use winreg::enums::*;
576
- use winreg::RegKey;
577
-
578
- pub fn read_registry_value(key_path: &str, value_name: &str) -> Option<String> {
579
- let hklm = RegKey::predef(HKEY_CURRENT_USER);
580
- let key = hklm.open_subkey(key_path).ok()?;
581
- key.get_value(value_name).ok()
582
- }
583
-
584
- pub fn write_registry_value(
585
- key_path: &str,
586
- value_name: &str,
587
- value: &str,
588
- ) -> Result<(), std::io::Error> {
589
- let hklm = RegKey::predef(HKEY_CURRENT_USER);
590
- let (key, _) = hklm.create_subkey(key_path)?;
591
- key.set_value(value_name, &value)?;
592
- Ok(())
593
- }
594
- }
595
-
596
- #[tauri::command]
597
- #[cfg(target_os = "windows")]
598
- fn windows_specific_feature() -> Result<String, String> {
599
- windows::show_native_message_box("Title", "Message");
600
-
601
- let value = windows::read_registry_value(
602
- "Software\\MyApp",
603
- "Setting1",
604
- )
605
- .unwrap_or_default();
606
-
607
- Ok(value)
608
- }
609
- ```
610
-
611
- ### macOS
612
-
613
- ```rust
614
- #[cfg(target_os = "macos")]
615
- mod macos {
616
- use cocoa::base::nil;
617
- use cocoa::foundation::NSString;
618
- use objc::{class, msg_send, sel, sel_impl};
619
-
620
- pub fn set_dock_badge(label: &str) {
621
- unsafe {
622
- let app = cocoa::appkit::NSApp();
623
- let dock_tile: cocoa::base::id = msg_send![app, dockTile];
624
-
625
- let badge_label = NSString::alloc(nil).init_str(label);
626
- let _: () = msg_send![dock_tile, setBadgeLabel: badge_label];
627
- }
628
- }
629
-
630
- pub fn clear_dock_badge() {
631
- unsafe {
632
- let app = cocoa::appkit::NSApp();
633
- let dock_tile: cocoa::base::id = msg_send![app, dockTile];
634
- let _: () = msg_send![dock_tile, setBadgeLabel: nil];
635
- }
636
- }
637
-
638
- // Access macOS services
639
- use std::process::Command;
640
-
641
- pub fn trigger_notification_center(title: &str, message: &str) {
642
- let script = format!(
643
- r#"display notification "{}" with title "{}""#,
644
- message, title
645
- );
646
-
647
- Command::new("osascript")
648
- .arg("-e")
649
- .arg(script)
650
- .output()
651
- .ok();
652
- }
653
- }
654
-
655
- #[tauri::command]
656
- #[cfg(target_os = "macos")]
657
- fn macos_specific_feature(badge: String) -> Result<(), String> {
658
- macos::set_dock_badge(&badge);
659
- Ok(())
660
- }
661
-
662
- #[tauri::command]
663
- #[cfg(target_os = "macos")]
664
- fn clear_badge() -> Result<(), String> {
665
- macos::clear_dock_badge();
666
- Ok(())
667
- }
668
- ```
669
-
670
- ### Linux
671
-
672
- ```rust
673
- #[cfg(target_os = "linux")]
674
- mod linux {
675
- use std::process::Command;
676
-
677
- pub fn send_desktop_notification(title: &str, message: &str) -> Result<(), String> {
678
- Command::new("notify-send")
679
- .arg(title)
680
- .arg(message)
681
- .output()
682
- .map_err(|e| e.to_string())?;
683
-
684
- Ok(())
685
- }
686
-
687
- // D-Bus integration
688
- use dbus::blocking::Connection;
689
- use std::time::Duration;
690
-
691
- pub fn get_desktop_environment() -> Result<String, Box<dyn std::error::Error>> {
692
- let conn = Connection::new_session()?;
693
- let proxy = conn.with_proxy(
694
- "org.freedesktop.portal.Desktop",
695
- "/org/freedesktop/portal/desktop",
696
- Duration::from_millis(5000),
697
- );
698
-
699
- // Query desktop environment
700
- // This is a simplified example
701
- Ok("Unknown".to_string())
702
- }
703
- }
704
-
705
- #[tauri::command]
706
- #[cfg(target_os = "linux")]
707
- fn linux_specific_feature(title: String, message: String) -> Result<(), String> {
708
- linux::send_desktop_notification(&title, &message)
709
- }
710
- ```
711
-
712
- ## Permissions and Security
713
-
714
- ### Scope Configuration
715
-
716
- ```rust
717
- use tauri::Manager;
718
-
719
- fn main() {
720
- tauri::Builder::default()
721
- .setup(|app| {
722
- // Configure file system scope
723
- let scope = app.fs_scope();
724
-
725
- // Allow access to specific directories
726
- let app_data_dir = app.path().app_data_dir()?;
727
- scope.allow_directory(&app_data_dir, true)?;
728
-
729
- let documents_dir = app.path().document_dir()?;
730
- scope.allow_directory(&documents_dir, false)?;
731
-
732
- Ok(())
733
- })
734
- .run(tauri::generate_context!())
735
- .expect("error while running tauri application");
736
- }
737
- ```
738
-
739
- ### Runtime Permission Checks
740
-
741
- ```rust
742
- use tauri::Manager;
743
-
744
- #[tauri::command]
745
- fn read_file_with_permission(
746
- app: tauri::AppHandle,
747
- path: String,
748
- ) -> Result<String, String> {
749
- let scope = app.fs_scope();
750
-
751
- // Check if path is allowed
752
- if !scope.is_allowed(&path) {
753
- return Err("Access denied: path not in scope".to_string());
754
- }
755
-
756
- std::fs::read_to_string(&path).map_err(|e| e.to_string())
757
- }
758
-
759
- #[tauri::command]
760
- fn request_file_access(
761
- app: tauri::AppHandle,
762
- path: String,
763
- ) -> Result<(), String> {
764
- let scope = app.fs_scope();
765
-
766
- // Request access (user must approve via dialog)
767
- scope
768
- .allow_file(&path)
769
- .map_err(|e| e.to_string())?;
770
-
771
- Ok(())
772
- }
773
- ```
774
-
775
- These platform integration patterns enable full access to native OS features while maintaining cross-platform compatibility and security.