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

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

Potentially problematic release.


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

Files changed (454) hide show
  1. claude_mpm/VERSION +1 -1
  2. claude_mpm/agents/BASE_PM.md +23 -6
  3. claude_mpm/agents/OUTPUT_STYLE.md +3 -48
  4. claude_mpm/agents/PM_INSTRUCTIONS.md +1783 -34
  5. claude_mpm/agents/WORKFLOW.md +75 -2
  6. claude_mpm/agents/base_agent.json +6 -3
  7. claude_mpm/agents/frontmatter_validator.py +1 -1
  8. claude_mpm/agents/templates/api_qa.json +5 -2
  9. claude_mpm/agents/templates/circuit_breakers.md +108 -2
  10. claude_mpm/agents/templates/documentation.json +33 -6
  11. claude_mpm/agents/templates/javascript_engineer_agent.json +380 -0
  12. claude_mpm/agents/templates/php-engineer.json +10 -4
  13. claude_mpm/agents/templates/pm_red_flags.md +89 -19
  14. claude_mpm/agents/templates/project_organizer.json +7 -3
  15. claude_mpm/agents/templates/qa.json +2 -1
  16. claude_mpm/agents/templates/react_engineer.json +1 -0
  17. claude_mpm/agents/templates/research.json +82 -12
  18. claude_mpm/agents/templates/security.json +4 -4
  19. claude_mpm/agents/templates/tauri_engineer.json +274 -0
  20. claude_mpm/agents/templates/ticketing.json +10 -6
  21. claude_mpm/agents/templates/version_control.json +4 -2
  22. claude_mpm/agents/templates/web_qa.json +2 -1
  23. claude_mpm/cli/README.md +253 -0
  24. claude_mpm/cli/__init__.py +11 -1
  25. claude_mpm/cli/commands/aggregate.py +1 -1
  26. claude_mpm/cli/commands/analyze.py +3 -3
  27. claude_mpm/cli/commands/cleanup.py +1 -1
  28. claude_mpm/cli/commands/configure_agent_display.py +4 -4
  29. claude_mpm/cli/commands/debug.py +12 -12
  30. claude_mpm/cli/commands/hook_errors.py +277 -0
  31. claude_mpm/cli/commands/mcp_install_commands.py +1 -1
  32. claude_mpm/cli/commands/mcp_install_commands.py.backup +284 -0
  33. claude_mpm/cli/commands/mpm_init/README.md +365 -0
  34. claude_mpm/cli/commands/mpm_init/__init__.py +73 -0
  35. claude_mpm/cli/commands/mpm_init/core.py +573 -0
  36. claude_mpm/cli/commands/mpm_init/display.py +341 -0
  37. claude_mpm/cli/commands/mpm_init/git_activity.py +427 -0
  38. claude_mpm/cli/commands/mpm_init/modes.py +397 -0
  39. claude_mpm/cli/commands/mpm_init/prompts.py +442 -0
  40. claude_mpm/cli/commands/mpm_init_cli.py +396 -0
  41. claude_mpm/cli/commands/mpm_init_handler.py +67 -1
  42. claude_mpm/cli/commands/run.py +124 -128
  43. claude_mpm/cli/commands/skills.py +522 -34
  44. claude_mpm/cli/executor.py +56 -0
  45. claude_mpm/cli/interactive/agent_wizard.py +5 -5
  46. claude_mpm/cli/parsers/base_parser.py +28 -0
  47. claude_mpm/cli/parsers/mpm_init_parser.py +42 -0
  48. claude_mpm/cli/parsers/skills_parser.py +138 -0
  49. claude_mpm/cli/startup.py +111 -8
  50. claude_mpm/cli/startup_display.py +480 -0
  51. claude_mpm/cli/utils.py +1 -1
  52. claude_mpm/cli_module/commands.py +1 -1
  53. claude_mpm/cli_module/refactoring_guide.md +253 -0
  54. claude_mpm/commands/mpm-help.md +3 -0
  55. claude_mpm/commands/mpm-init.md +19 -3
  56. claude_mpm/commands/mpm-resume.md +372 -0
  57. claude_mpm/commands/mpm-tickets.md +56 -7
  58. claude_mpm/commands/mpm.md +1 -0
  59. claude_mpm/config/agent_capabilities.yaml +658 -0
  60. claude_mpm/config/async_logging_config.yaml +145 -0
  61. claude_mpm/constants.py +12 -0
  62. claude_mpm/core/.claude-mpm/logs/hooks_20250730.log +34 -0
  63. claude_mpm/core/api_validator.py +1 -1
  64. claude_mpm/core/claude_runner.py +14 -1
  65. claude_mpm/core/config.py +8 -0
  66. claude_mpm/core/constants.py +1 -1
  67. claude_mpm/core/framework/processors/metadata_processor.py +1 -1
  68. claude_mpm/core/hook_error_memory.py +381 -0
  69. claude_mpm/core/hook_manager.py +41 -2
  70. claude_mpm/core/interactive_session.py +48 -3
  71. claude_mpm/core/interfaces.py +56 -1
  72. claude_mpm/core/logger.py +3 -1
  73. claude_mpm/core/oneshot_session.py +39 -0
  74. claude_mpm/d2/.gitignore +22 -0
  75. claude_mpm/d2/ARCHITECTURE_COMPARISON.md +273 -0
  76. claude_mpm/d2/FLASK_INTEGRATION.md +156 -0
  77. claude_mpm/d2/IMPLEMENTATION_SUMMARY.md +452 -0
  78. claude_mpm/d2/QUICKSTART.md +186 -0
  79. claude_mpm/d2/README.md +232 -0
  80. claude_mpm/d2/STORE_FIX_SUMMARY.md +167 -0
  81. claude_mpm/d2/SVELTE5_STORES_GUIDE.md +180 -0
  82. claude_mpm/d2/TESTING.md +288 -0
  83. claude_mpm/d2/index.html +118 -0
  84. claude_mpm/d2/package.json +19 -0
  85. claude_mpm/d2/src/App.svelte +110 -0
  86. claude_mpm/d2/src/components/Header.svelte +153 -0
  87. claude_mpm/d2/src/components/MainContent.svelte +74 -0
  88. claude_mpm/d2/src/components/Sidebar.svelte +85 -0
  89. claude_mpm/d2/src/components/tabs/EventsTab.svelte +326 -0
  90. claude_mpm/d2/src/lib/socketio.js +144 -0
  91. claude_mpm/d2/src/main.js +7 -0
  92. claude_mpm/d2/src/stores/events.js +114 -0
  93. claude_mpm/d2/src/stores/socket.js +108 -0
  94. claude_mpm/d2/src/stores/theme.js +65 -0
  95. claude_mpm/d2/svelte.config.js +12 -0
  96. claude_mpm/d2/vite.config.js +15 -0
  97. claude_mpm/dashboard/.claude-mpm/memories/README.md +36 -0
  98. claude_mpm/dashboard/BUILD_NUMBER +1 -0
  99. claude_mpm/dashboard/README.md +121 -0
  100. claude_mpm/dashboard/VERSION +1 -0
  101. claude_mpm/dashboard/react/components/DataInspector/DataInspector.tsx +273 -0
  102. claude_mpm/dashboard/react/components/ErrorBoundary.tsx +75 -0
  103. claude_mpm/dashboard/react/components/EventViewer/EventViewer.tsx +141 -0
  104. claude_mpm/dashboard/react/components/shared/ConnectionStatus.tsx +36 -0
  105. claude_mpm/dashboard/react/components/shared/FilterBar.tsx +89 -0
  106. claude_mpm/dashboard/react/contexts/DashboardContext.tsx +215 -0
  107. claude_mpm/dashboard/react/entries/events.tsx +165 -0
  108. claude_mpm/dashboard/react/hooks/useEvents.ts +191 -0
  109. claude_mpm/dashboard/react/hooks/useSocket.ts +225 -0
  110. claude_mpm/dashboard/static/built/REFACTORING_SUMMARY.md +170 -0
  111. claude_mpm/dashboard/static/built/components/activity-tree.js.map +1 -0
  112. claude_mpm/dashboard/static/built/components/agent-hierarchy.js +101 -101
  113. claude_mpm/dashboard/static/built/components/agent-inference.js.map +1 -0
  114. claude_mpm/dashboard/static/built/components/build-tracker.js +59 -59
  115. claude_mpm/dashboard/static/built/components/code-simple.js +107 -107
  116. claude_mpm/dashboard/static/built/components/code-tree/tree-breadcrumb.js +29 -29
  117. claude_mpm/dashboard/static/built/components/code-tree/tree-constants.js +24 -24
  118. claude_mpm/dashboard/static/built/components/code-tree/tree-search.js +27 -27
  119. claude_mpm/dashboard/static/built/components/code-tree/tree-utils.js +25 -25
  120. claude_mpm/dashboard/static/built/components/code-tree.js.map +1 -0
  121. claude_mpm/dashboard/static/built/components/code-viewer.js.map +1 -0
  122. claude_mpm/dashboard/static/built/components/connection-debug.js +101 -101
  123. claude_mpm/dashboard/static/built/components/diff-viewer.js +113 -113
  124. claude_mpm/dashboard/static/built/components/event-processor.js.map +1 -0
  125. claude_mpm/dashboard/static/built/components/event-viewer.js.map +1 -0
  126. claude_mpm/dashboard/static/built/components/export-manager.js.map +1 -0
  127. claude_mpm/dashboard/static/built/components/file-change-tracker.js +57 -57
  128. claude_mpm/dashboard/static/built/components/file-change-viewer.js +74 -74
  129. claude_mpm/dashboard/static/built/components/file-tool-tracker.js.map +1 -0
  130. claude_mpm/dashboard/static/built/components/file-viewer.js.map +1 -0
  131. claude_mpm/dashboard/static/built/components/hud-library-loader.js.map +1 -0
  132. claude_mpm/dashboard/static/built/components/hud-manager.js.map +1 -0
  133. claude_mpm/dashboard/static/built/components/hud-visualizer.js.map +1 -0
  134. claude_mpm/dashboard/static/built/components/module-viewer.js.map +1 -0
  135. claude_mpm/dashboard/static/built/components/session-manager.js.map +1 -0
  136. claude_mpm/dashboard/static/built/components/socket-manager.js.map +1 -0
  137. claude_mpm/dashboard/static/built/components/ui-state-manager.js.map +1 -0
  138. claude_mpm/dashboard/static/built/components/unified-data-viewer.js.map +1 -0
  139. claude_mpm/dashboard/static/built/components/working-directory.js.map +1 -0
  140. claude_mpm/dashboard/static/built/connection-manager.js +76 -76
  141. claude_mpm/dashboard/static/built/dashboard.js.map +1 -0
  142. claude_mpm/dashboard/static/built/extension-error-handler.js +22 -22
  143. claude_mpm/dashboard/static/built/react/events.js.map +1 -0
  144. claude_mpm/dashboard/static/built/shared/dom-helpers.js +9 -9
  145. claude_mpm/dashboard/static/built/shared/event-bus.js +5 -5
  146. claude_mpm/dashboard/static/built/shared/logger.js +16 -16
  147. claude_mpm/dashboard/static/built/shared/tooltip-service.js +6 -6
  148. claude_mpm/dashboard/static/built/socket-client.js.map +1 -0
  149. claude_mpm/dashboard/static/css/activity.css +69 -69
  150. claude_mpm/dashboard/static/css/connection-status.css +10 -10
  151. claude_mpm/dashboard/static/css/dashboard.css +15 -15
  152. claude_mpm/dashboard/static/index.html +22 -22
  153. claude_mpm/dashboard/static/js/REFACTORING_SUMMARY.md +170 -0
  154. claude_mpm/dashboard/static/js/components/activity-tree.js +178 -178
  155. claude_mpm/dashboard/static/js/components/agent-hierarchy.js +101 -101
  156. claude_mpm/dashboard/static/js/components/agent-inference.js +31 -31
  157. claude_mpm/dashboard/static/js/components/build-tracker.js +59 -59
  158. claude_mpm/dashboard/static/js/components/code-simple.js +107 -107
  159. claude_mpm/dashboard/static/js/components/connection-debug.js +101 -101
  160. claude_mpm/dashboard/static/js/components/diff-viewer.js +113 -113
  161. claude_mpm/dashboard/static/js/components/event-viewer.js +12 -12
  162. claude_mpm/dashboard/static/js/components/file-change-tracker.js +57 -57
  163. claude_mpm/dashboard/static/js/components/file-change-viewer.js +74 -74
  164. claude_mpm/dashboard/static/js/components/file-tool-tracker.js +6 -6
  165. claude_mpm/dashboard/static/js/components/file-viewer.js +42 -42
  166. claude_mpm/dashboard/static/js/components/module-viewer.js +27 -27
  167. claude_mpm/dashboard/static/js/components/session-manager.js +14 -14
  168. claude_mpm/dashboard/static/js/components/socket-manager.js +1 -1
  169. claude_mpm/dashboard/static/js/components/ui-state-manager.js +14 -14
  170. claude_mpm/dashboard/static/js/components/unified-data-viewer.js +110 -110
  171. claude_mpm/dashboard/static/js/components/working-directory.js +8 -8
  172. claude_mpm/dashboard/static/js/connection-manager.js +76 -76
  173. claude_mpm/dashboard/static/js/dashboard.js +76 -58
  174. claude_mpm/dashboard/static/js/extension-error-handler.js +22 -22
  175. claude_mpm/dashboard/static/js/shared/dom-helpers.js +9 -9
  176. claude_mpm/dashboard/static/js/shared/event-bus.js +5 -5
  177. claude_mpm/dashboard/static/js/shared/logger.js +16 -16
  178. claude_mpm/dashboard/static/js/shared/tooltip-service.js +6 -6
  179. claude_mpm/dashboard/static/js/socket-client.js +138 -121
  180. claude_mpm/dashboard/static/navigation-test-results.md +118 -0
  181. claude_mpm/dashboard/static/production/main.html +21 -21
  182. claude_mpm/dashboard/static/test-archive/dashboard.html +22 -22
  183. claude_mpm/dashboard/templates/.claude-mpm/memories/README.md +36 -0
  184. claude_mpm/dashboard/templates/.claude-mpm/memories/engineer_agent.md +39 -0
  185. claude_mpm/dashboard/templates/.claude-mpm/memories/version_control_agent.md +38 -0
  186. claude_mpm/dashboard/templates/code_simple.html +23 -23
  187. claude_mpm/dashboard/templates/index.html +18 -18
  188. claude_mpm/hooks/README.md +143 -0
  189. claude_mpm/hooks/claude_hooks/event_handlers.py +3 -1
  190. claude_mpm/hooks/claude_hooks/hook_handler.py +24 -7
  191. claude_mpm/hooks/claude_hooks/installer.py +45 -0
  192. claude_mpm/hooks/templates/README.md +180 -0
  193. claude_mpm/hooks/templates/pre_tool_use_simple.py +78 -0
  194. claude_mpm/hooks/templates/pre_tool_use_template.py +323 -0
  195. claude_mpm/hooks/templates/settings.json.example +147 -0
  196. claude_mpm/schemas/agent_schema.json +596 -0
  197. claude_mpm/schemas/frontmatter_schema.json +165 -0
  198. claude_mpm/scripts/claude-hook-handler.sh +3 -3
  199. claude_mpm/scripts/start_activity_logging.py +3 -1
  200. claude_mpm/services/agents/deployment/agent_format_converter.py +1 -1
  201. claude_mpm/services/agents/deployment/agent_metrics_collector.py +3 -3
  202. claude_mpm/services/agents/deployment/facade/deployment_facade.py +3 -3
  203. claude_mpm/services/agents/deployment/pipeline/pipeline_executor.py +2 -2
  204. claude_mpm/services/agents/loading/framework_agent_loader.py +8 -8
  205. claude_mpm/services/agents/local_template_manager.py +3 -1
  206. claude_mpm/services/cli/session_pause_manager.py +504 -0
  207. claude_mpm/services/cli/session_resume_helper.py +36 -16
  208. claude_mpm/services/cli/unified_dashboard_manager.py +1 -1
  209. claude_mpm/services/core/base.py +26 -11
  210. claude_mpm/services/core/interfaces.py +56 -1
  211. claude_mpm/services/core/models/agent_config.py +3 -0
  212. claude_mpm/services/core/models/process.py +4 -0
  213. claude_mpm/services/diagnostics/checks/agent_check.py +0 -2
  214. claude_mpm/services/diagnostics/checks/instructions_check.py +1 -2
  215. claude_mpm/services/diagnostics/checks/mcp_check.py +0 -1
  216. claude_mpm/services/diagnostics/checks/monitor_check.py +0 -1
  217. claude_mpm/services/diagnostics/doctor_reporter.py +6 -4
  218. claude_mpm/services/diagnostics/models.py +21 -0
  219. claude_mpm/services/event_bus/README.md +244 -0
  220. claude_mpm/services/event_bus/direct_relay.py +3 -3
  221. claude_mpm/services/event_bus/event_bus.py +36 -3
  222. claude_mpm/services/event_bus/relay.py +23 -7
  223. claude_mpm/services/events/README.md +303 -0
  224. claude_mpm/services/events/consumers/logging.py +1 -2
  225. claude_mpm/services/framework_claude_md_generator/README.md +119 -0
  226. claude_mpm/services/infrastructure/monitoring/resources.py +1 -1
  227. claude_mpm/services/local_ops/__init__.py +2 -0
  228. claude_mpm/services/local_ops/process_manager.py +1 -1
  229. claude_mpm/services/local_ops/resource_monitor.py +2 -2
  230. claude_mpm/services/mcp_gateway/README.md +185 -0
  231. claude_mpm/services/mcp_gateway/auto_configure.py +31 -25
  232. claude_mpm/services/mcp_gateway/config/configuration.py +1 -1
  233. claude_mpm/services/mcp_gateway/core/process_pool.py +19 -10
  234. claude_mpm/services/mcp_gateway/server/stdio_server.py +0 -2
  235. claude_mpm/services/mcp_gateway/tools/document_summarizer.py +1 -1
  236. claude_mpm/services/mcp_gateway/tools/external_mcp_services.py +26 -21
  237. claude_mpm/services/mcp_gateway/tools/kuzu_memory_service.py +6 -2
  238. claude_mpm/services/memory/failure_tracker.py +19 -4
  239. claude_mpm/services/memory/optimizer.py +1 -1
  240. claude_mpm/services/model/model_router.py +8 -9
  241. claude_mpm/services/monitor/daemon.py +1 -1
  242. claude_mpm/services/monitor/server.py +2 -2
  243. claude_mpm/services/native_agent_converter.py +356 -0
  244. claude_mpm/services/port_manager.py +1 -1
  245. claude_mpm/services/project/documentation_manager.py +2 -1
  246. claude_mpm/services/project/toolchain_analyzer.py +3 -1
  247. claude_mpm/services/runner_configuration_service.py +1 -0
  248. claude_mpm/services/self_upgrade_service.py +165 -7
  249. claude_mpm/services/skills_config.py +547 -0
  250. claude_mpm/services/skills_deployer.py +955 -0
  251. claude_mpm/services/socketio/handlers/connection.py +1 -1
  252. claude_mpm/services/socketio/handlers/connection.py.backup +217 -0
  253. claude_mpm/services/socketio/handlers/git.py +2 -2
  254. claude_mpm/services/socketio/handlers/hook.py.backup +154 -0
  255. claude_mpm/services/static/.gitkeep +2 -0
  256. claude_mpm/services/system_instructions_service.py +1 -3
  257. claude_mpm/services/unified/analyzer_strategies/performance_analyzer.py +0 -3
  258. claude_mpm/services/unified/analyzer_strategies/security_analyzer.py +0 -1
  259. claude_mpm/services/unified/deployment_strategies/cloud_strategies.py +1 -1
  260. claude_mpm/services/version_control/VERSION +1 -0
  261. claude_mpm/services/version_control/conflict_resolution.py +6 -4
  262. claude_mpm/services/visualization/mermaid_generator.py +2 -3
  263. claude_mpm/skills/__init__.py +3 -3
  264. claude_mpm/skills/agent_skills_injector.py +42 -49
  265. claude_mpm/skills/bundled/.gitkeep +2 -0
  266. claude_mpm/skills/bundled/collaboration/brainstorming/SKILL.md +4 -0
  267. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/SKILL.md +108 -114
  268. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/agent-prompts.md +577 -0
  269. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/coordination-patterns.md +467 -0
  270. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/examples.md +537 -0
  271. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/troubleshooting.md +730 -0
  272. claude_mpm/skills/bundled/collaboration/git-worktrees.md +317 -0
  273. claude_mpm/skills/bundled/collaboration/requesting-code-review/SKILL.md +46 -41
  274. claude_mpm/skills/bundled/collaboration/requesting-code-review/references/review-examples.md +412 -0
  275. claude_mpm/skills/bundled/collaboration/stacked-prs.md +251 -0
  276. claude_mpm/skills/bundled/collaboration/writing-plans/SKILL.md +36 -73
  277. claude_mpm/skills/bundled/collaboration/writing-plans/references/best-practices.md +362 -0
  278. claude_mpm/skills/bundled/collaboration/writing-plans/references/plan-structure-templates.md +312 -0
  279. claude_mpm/skills/bundled/debugging/root-cause-tracing/SKILL.md +100 -125
  280. claude_mpm/skills/bundled/debugging/root-cause-tracing/find-polluter.sh +63 -0
  281. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/advanced-techniques.md +668 -0
  282. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/examples.md +587 -0
  283. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/integration.md +438 -0
  284. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/tracing-techniques.md +391 -0
  285. claude_mpm/skills/bundled/debugging/verification-before-completion/SKILL.md +28 -72
  286. claude_mpm/skills/bundled/debugging/verification-before-completion/references/gate-function.md +11 -0
  287. claude_mpm/skills/bundled/debugging/verification-before-completion/references/integration-and-workflows.md +490 -0
  288. claude_mpm/skills/bundled/debugging/verification-before-completion/references/red-flags-and-failures.md +425 -0
  289. claude_mpm/skills/bundled/debugging/verification-before-completion/references/verification-patterns.md +272 -0
  290. claude_mpm/skills/bundled/infrastructure/env-manager/INTEGRATION.md +611 -0
  291. claude_mpm/skills/bundled/infrastructure/env-manager/README.md +596 -0
  292. claude_mpm/skills/bundled/infrastructure/env-manager/SKILL.md +260 -0
  293. claude_mpm/skills/bundled/infrastructure/env-manager/examples/nextjs-env-structure.md +315 -0
  294. claude_mpm/skills/bundled/infrastructure/env-manager/references/frameworks.md +436 -0
  295. claude_mpm/skills/bundled/infrastructure/env-manager/references/security.md +433 -0
  296. claude_mpm/skills/bundled/infrastructure/env-manager/references/synchronization.md +452 -0
  297. claude_mpm/skills/bundled/infrastructure/env-manager/references/troubleshooting.md +404 -0
  298. claude_mpm/skills/bundled/infrastructure/env-manager/references/validation.md +420 -0
  299. claude_mpm/skills/bundled/infrastructure/env-manager/scripts/validate_env.py +576 -0
  300. claude_mpm/skills/bundled/main/artifacts-builder/LICENSE.txt +202 -0
  301. claude_mpm/skills/bundled/main/artifacts-builder/SKILL.md +13 -1
  302. claude_mpm/skills/bundled/main/artifacts-builder/scripts/bundle-artifact.sh +54 -0
  303. claude_mpm/skills/bundled/main/artifacts-builder/scripts/init-artifact.sh +322 -0
  304. claude_mpm/skills/bundled/main/artifacts-builder/scripts/shadcn-components.tar.gz +0 -0
  305. claude_mpm/skills/bundled/main/internal-comms/LICENSE.txt +202 -0
  306. claude_mpm/skills/bundled/main/internal-comms/SKILL.md +11 -0
  307. claude_mpm/skills/bundled/main/mcp-builder/LICENSE.txt +202 -0
  308. claude_mpm/skills/bundled/main/mcp-builder/SKILL.md +109 -277
  309. claude_mpm/skills/bundled/main/mcp-builder/reference/design_principles.md +412 -0
  310. claude_mpm/skills/bundled/main/mcp-builder/reference/workflow.md +1237 -0
  311. claude_mpm/skills/bundled/main/mcp-builder/scripts/connections.py +17 -10
  312. claude_mpm/skills/bundled/main/mcp-builder/scripts/evaluation.py +92 -39
  313. claude_mpm/skills/bundled/main/mcp-builder/scripts/example_evaluation.xml +22 -0
  314. claude_mpm/skills/bundled/main/mcp-builder/scripts/requirements.txt +2 -0
  315. claude_mpm/skills/bundled/main/skill-creator/LICENSE.txt +202 -0
  316. claude_mpm/skills/bundled/main/skill-creator/SKILL.md +135 -155
  317. claude_mpm/skills/bundled/main/skill-creator/references/best-practices.md +500 -0
  318. claude_mpm/skills/bundled/main/skill-creator/references/creation-workflow.md +464 -0
  319. claude_mpm/skills/bundled/main/skill-creator/references/examples.md +619 -0
  320. claude_mpm/skills/bundled/main/skill-creator/references/progressive-disclosure.md +437 -0
  321. claude_mpm/skills/bundled/main/skill-creator/references/skill-structure.md +231 -0
  322. claude_mpm/skills/bundled/main/skill-creator/scripts/init_skill.py +13 -12
  323. claude_mpm/skills/bundled/main/skill-creator/scripts/package_skill.py +5 -3
  324. claude_mpm/skills/bundled/main/skill-creator/scripts/quick_validate.py +19 -12
  325. claude_mpm/skills/bundled/performance-profiling.md +6 -0
  326. claude_mpm/skills/bundled/php/espocrm-development/SKILL.md +170 -0
  327. claude_mpm/skills/bundled/php/espocrm-development/references/architecture.md +602 -0
  328. claude_mpm/skills/bundled/php/espocrm-development/references/common-tasks.md +821 -0
  329. claude_mpm/skills/bundled/php/espocrm-development/references/development-workflow.md +742 -0
  330. claude_mpm/skills/bundled/php/espocrm-development/references/frontend-customization.md +726 -0
  331. claude_mpm/skills/bundled/php/espocrm-development/references/hooks-and-services.md +764 -0
  332. claude_mpm/skills/bundled/php/espocrm-development/references/testing-debugging.md +831 -0
  333. claude_mpm/skills/bundled/react/flexlayout-react.md +742 -0
  334. claude_mpm/skills/bundled/rust/desktop-applications/SKILL.md +226 -0
  335. claude_mpm/skills/bundled/rust/desktop-applications/references/architecture-patterns.md +901 -0
  336. claude_mpm/skills/bundled/rust/desktop-applications/references/native-gui-frameworks.md +901 -0
  337. claude_mpm/skills/bundled/rust/desktop-applications/references/platform-integration.md +775 -0
  338. claude_mpm/skills/bundled/rust/desktop-applications/references/state-management.md +937 -0
  339. claude_mpm/skills/bundled/rust/desktop-applications/references/tauri-framework.md +770 -0
  340. claude_mpm/skills/bundled/rust/desktop-applications/references/testing-deployment.md +961 -0
  341. claude_mpm/skills/bundled/tauri/tauri-async-patterns.md +495 -0
  342. claude_mpm/skills/bundled/tauri/tauri-build-deploy.md +599 -0
  343. claude_mpm/skills/bundled/tauri/tauri-command-patterns.md +535 -0
  344. claude_mpm/skills/bundled/tauri/tauri-error-handling.md +613 -0
  345. claude_mpm/skills/bundled/tauri/tauri-event-system.md +648 -0
  346. claude_mpm/skills/bundled/tauri/tauri-file-system.md +673 -0
  347. claude_mpm/skills/bundled/tauri/tauri-frontend-integration.md +767 -0
  348. claude_mpm/skills/bundled/tauri/tauri-performance.md +669 -0
  349. claude_mpm/skills/bundled/tauri/tauri-state-management.md +573 -0
  350. claude_mpm/skills/bundled/tauri/tauri-testing.md +384 -0
  351. claude_mpm/skills/bundled/tauri/tauri-window-management.md +628 -0
  352. claude_mpm/skills/bundled/testing/condition-based-waiting/SKILL.md +21 -25
  353. claude_mpm/skills/bundled/testing/condition-based-waiting/example.ts +158 -0
  354. claude_mpm/skills/bundled/testing/condition-based-waiting/references/patterns-and-implementation.md +253 -0
  355. claude_mpm/skills/bundled/testing/test-quality-inspector/SKILL.md +458 -0
  356. claude_mpm/skills/bundled/testing/test-quality-inspector/examples/example-inspection-report.md +411 -0
  357. claude_mpm/skills/bundled/testing/test-quality-inspector/references/assertion-quality.md +317 -0
  358. claude_mpm/skills/bundled/testing/test-quality-inspector/references/inspection-checklist.md +270 -0
  359. claude_mpm/skills/bundled/testing/test-quality-inspector/references/red-flags.md +436 -0
  360. claude_mpm/skills/bundled/testing/testing-anti-patterns/SKILL.md +86 -250
  361. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/completeness-anti-patterns.md +572 -0
  362. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/core-anti-patterns.md +411 -0
  363. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/detection-guide.md +569 -0
  364. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/tdd-connection.md +695 -0
  365. claude_mpm/skills/bundled/testing/webapp-testing/LICENSE.txt +202 -0
  366. claude_mpm/skills/bundled/testing/webapp-testing/SKILL.md +145 -57
  367. claude_mpm/skills/bundled/testing/webapp-testing/decision-tree.md +459 -0
  368. claude_mpm/skills/bundled/testing/webapp-testing/examples/console_logging.py +6 -6
  369. claude_mpm/skills/bundled/testing/webapp-testing/examples/element_discovery.py +13 -9
  370. claude_mpm/skills/bundled/testing/webapp-testing/examples/static_html_automation.py +8 -8
  371. claude_mpm/skills/bundled/testing/webapp-testing/playwright-patterns.md +479 -0
  372. claude_mpm/skills/bundled/testing/webapp-testing/reconnaissance-pattern.md +687 -0
  373. claude_mpm/skills/bundled/testing/webapp-testing/scripts/with_server.py +37 -15
  374. claude_mpm/skills/bundled/testing/webapp-testing/server-management.md +758 -0
  375. claude_mpm/skills/bundled/testing/webapp-testing/troubleshooting.md +868 -0
  376. claude_mpm/skills/skills_registry.py +44 -48
  377. claude_mpm/skills/skills_service.py +117 -108
  378. claude_mpm/templates/questions/EXAMPLES.md +501 -0
  379. claude_mpm/templates/questions/__init__.py +43 -0
  380. claude_mpm/templates/questions/base.py +193 -0
  381. claude_mpm/templates/questions/pr_strategy.py +314 -0
  382. claude_mpm/templates/questions/project_init.py +388 -0
  383. claude_mpm/templates/questions/ticket_mgmt.py +397 -0
  384. claude_mpm/tools/README_SOCKETIO_DEBUG.md +224 -0
  385. claude_mpm/tools/__main__.py +8 -8
  386. claude_mpm/tools/code_tree_analyzer/README.md +64 -0
  387. claude_mpm/tools/code_tree_analyzer/__init__.py +45 -0
  388. claude_mpm/tools/code_tree_analyzer/analysis.py +299 -0
  389. claude_mpm/tools/code_tree_analyzer/cache.py +131 -0
  390. claude_mpm/tools/code_tree_analyzer/core.py +380 -0
  391. claude_mpm/tools/code_tree_analyzer/discovery.py +403 -0
  392. claude_mpm/tools/code_tree_analyzer/events.py +168 -0
  393. claude_mpm/tools/code_tree_analyzer/gitignore.py +308 -0
  394. claude_mpm/tools/code_tree_analyzer/models.py +39 -0
  395. claude_mpm/tools/code_tree_analyzer/multilang_analyzer.py +224 -0
  396. claude_mpm/tools/code_tree_analyzer/python_analyzer.py +284 -0
  397. claude_mpm/utils/agent_dependency_loader.py +3 -3
  398. claude_mpm/utils/dependency_cache.py +3 -1
  399. claude_mpm/utils/gitignore.py +241 -0
  400. claude_mpm/utils/log_cleanup.py +3 -3
  401. claude_mpm/utils/robust_installer.py +3 -5
  402. claude_mpm/utils/structured_questions.py +619 -0
  403. {claude_mpm-4.20.3.dist-info → claude_mpm-4.25.10.dist-info}/METADATA +218 -31
  404. {claude_mpm-4.20.3.dist-info → claude_mpm-4.25.10.dist-info}/RECORD +409 -246
  405. claude_mpm/agents/templates/.claude-mpm/memories/README.md +0 -17
  406. claude_mpm/agents/templates/.claude-mpm/memories/engineer_memories.md +0 -3
  407. claude_mpm/agents/templates/logs/prompts/agent_engineer_20250826_014258_728.md +0 -39
  408. claude_mpm/agents/templates/logs/prompts/agent_engineer_20250901_010124_142.md +0 -400
  409. claude_mpm/cli/commands/mpm_init.py +0 -2093
  410. claude_mpm/dashboard/.claude-mpm/socketio-instances.json +0 -1
  411. claude_mpm/dashboard/static/archive/activity_dashboard_test.html +0 -61
  412. claude_mpm/dashboard/static/archive/test_activity_connection.html +0 -179
  413. claude_mpm/dashboard/static/archive/test_claude_tree_tab.html +0 -68
  414. claude_mpm/dashboard/static/archive/test_dashboard.html +0 -409
  415. claude_mpm/dashboard/static/archive/test_dashboard_fixed.html +0 -519
  416. claude_mpm/dashboard/static/archive/test_dashboard_verification.html +0 -181
  417. claude_mpm/dashboard/static/archive/test_file_data.html +0 -315
  418. claude_mpm/dashboard/static/archive/test_file_tree_empty_state.html +0 -243
  419. claude_mpm/dashboard/static/archive/test_file_tree_fix.html +0 -234
  420. claude_mpm/dashboard/static/archive/test_file_tree_rename.html +0 -117
  421. claude_mpm/dashboard/static/archive/test_file_tree_tab.html +0 -115
  422. claude_mpm/dashboard/static/archive/test_file_viewer.html +0 -224
  423. claude_mpm/dashboard/static/archive/test_final_activity.html +0 -220
  424. claude_mpm/dashboard/static/archive/test_tab_fix.html +0 -139
  425. claude_mpm/dashboard/static/dist/assets/events.DjpNxWNo.css +0 -1
  426. claude_mpm/dashboard/static/dist/components/activity-tree.js +0 -2
  427. claude_mpm/dashboard/static/dist/components/agent-inference.js +0 -2
  428. claude_mpm/dashboard/static/dist/components/code-tree.js +0 -2
  429. claude_mpm/dashboard/static/dist/components/code-viewer.js +0 -2
  430. claude_mpm/dashboard/static/dist/components/event-processor.js +0 -2
  431. claude_mpm/dashboard/static/dist/components/event-viewer.js +0 -2
  432. claude_mpm/dashboard/static/dist/components/export-manager.js +0 -2
  433. claude_mpm/dashboard/static/dist/components/file-tool-tracker.js +0 -2
  434. claude_mpm/dashboard/static/dist/components/file-viewer.js +0 -2
  435. claude_mpm/dashboard/static/dist/components/hud-library-loader.js +0 -2
  436. claude_mpm/dashboard/static/dist/components/hud-manager.js +0 -2
  437. claude_mpm/dashboard/static/dist/components/hud-visualizer.js +0 -2
  438. claude_mpm/dashboard/static/dist/components/module-viewer.js +0 -2
  439. claude_mpm/dashboard/static/dist/components/session-manager.js +0 -2
  440. claude_mpm/dashboard/static/dist/components/socket-manager.js +0 -2
  441. claude_mpm/dashboard/static/dist/components/ui-state-manager.js +0 -2
  442. claude_mpm/dashboard/static/dist/components/unified-data-viewer.js +0 -2
  443. claude_mpm/dashboard/static/dist/components/working-directory.js +0 -2
  444. claude_mpm/dashboard/static/dist/dashboard.js +0 -2
  445. claude_mpm/dashboard/static/dist/react/events.js +0 -30
  446. claude_mpm/dashboard/static/dist/socket-client.js +0 -2
  447. claude_mpm/dashboard/static/test-archive/test_debug.html +0 -25
  448. claude_mpm/skills/bundled/debugging/verification-before-completion/references/common-failures.md +0 -213
  449. claude_mpm/tools/code_tree_analyzer.py +0 -1825
  450. /claude_mpm/skills/bundled/collaboration/requesting-code-review/{code-reviewer.md → references/code-reviewer-template.md} +0 -0
  451. {claude_mpm-4.20.3.dist-info → claude_mpm-4.25.10.dist-info}/WHEEL +0 -0
  452. {claude_mpm-4.20.3.dist-info → claude_mpm-4.25.10.dist-info}/entry_points.txt +0 -0
  453. {claude_mpm-4.20.3.dist-info → claude_mpm-4.25.10.dist-info}/licenses/LICENSE +0 -0
  454. {claude_mpm-4.20.3.dist-info → claude_mpm-4.25.10.dist-info}/top_level.txt +0 -0
@@ -0,0 +1,775 @@
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.