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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (507) hide show
  1. claude_mpm/VERSION +1 -1
  2. claude_mpm/agents/BASE_PM.md +12 -0
  3. claude_mpm/agents/PM_INSTRUCTIONS.md +1055 -2230
  4. claude_mpm/agents/PM_INSTRUCTIONS_TEACH.md +1322 -0
  5. claude_mpm/agents/WORKFLOW.md +4 -4
  6. claude_mpm/agents/__init__.py +6 -0
  7. claude_mpm/agents/agent_loader.py +1 -4
  8. claude_mpm/agents/base_agent_loader.py +10 -35
  9. claude_mpm/agents/templates/{circuit_breakers.md → circuit-breakers.md} +576 -66
  10. claude_mpm/agents/templates/context-management-examples.md +544 -0
  11. claude_mpm/agents/templates/pr-workflow-examples.md +427 -0
  12. claude_mpm/agents/templates/research-gate-examples.md +669 -0
  13. claude_mpm/agents/templates/structured-questions-examples.md +615 -0
  14. claude_mpm/agents/templates/ticket-completeness-examples.md +139 -0
  15. claude_mpm/agents/templates/ticketing-examples.md +277 -0
  16. claude_mpm/cli/__init__.py +28 -3
  17. claude_mpm/cli/commands/__init__.py +2 -0
  18. claude_mpm/cli/commands/agent_source.py +774 -0
  19. claude_mpm/cli/commands/agent_state_manager.py +188 -30
  20. claude_mpm/cli/commands/agents.py +959 -36
  21. claude_mpm/cli/commands/agents_cleanup.py +210 -0
  22. claude_mpm/cli/commands/agents_discover.py +338 -0
  23. claude_mpm/cli/commands/auto_configure.py +537 -239
  24. claude_mpm/cli/commands/config.py +7 -4
  25. claude_mpm/cli/commands/configure.py +924 -45
  26. claude_mpm/cli/commands/configure_navigation.py +63 -46
  27. claude_mpm/cli/commands/doctor.py +10 -2
  28. claude_mpm/cli/commands/local_deploy.py +1 -4
  29. claude_mpm/cli/commands/postmortem.py +401 -0
  30. claude_mpm/cli/commands/run.py +1 -39
  31. claude_mpm/cli/commands/skill_source.py +694 -0
  32. claude_mpm/cli/commands/skills.py +322 -19
  33. claude_mpm/cli/executor.py +22 -3
  34. claude_mpm/cli/interactive/agent_wizard.py +1028 -43
  35. claude_mpm/cli/parsers/agent_source_parser.py +171 -0
  36. claude_mpm/cli/parsers/agents_parser.py +256 -4
  37. claude_mpm/cli/parsers/auto_configure_parser.py +13 -0
  38. claude_mpm/cli/parsers/base_parser.py +25 -0
  39. claude_mpm/cli/parsers/config_parser.py +96 -43
  40. claude_mpm/cli/parsers/skill_source_parser.py +169 -0
  41. claude_mpm/cli/parsers/skills_parser.py +7 -0
  42. claude_mpm/cli/parsers/source_parser.py +138 -0
  43. claude_mpm/cli/startup.py +456 -103
  44. claude_mpm/cli/startup_display.py +4 -4
  45. claude_mpm/commands/{mpm-auto-configure.md → mpm-agents-auto-configure.md} +9 -0
  46. claude_mpm/commands/mpm-agents-detect.md +9 -0
  47. claude_mpm/commands/{mpm-agents.md → mpm-agents-list.md} +9 -0
  48. claude_mpm/commands/mpm-agents-recommend.md +9 -0
  49. claude_mpm/commands/{mpm-config.md → mpm-config-view.md} +9 -0
  50. claude_mpm/commands/mpm-doctor.md +9 -0
  51. claude_mpm/commands/mpm-help.md +14 -2
  52. claude_mpm/commands/mpm-init.md +9 -0
  53. claude_mpm/commands/mpm-monitor.md +9 -0
  54. claude_mpm/commands/mpm-postmortem.md +123 -0
  55. claude_mpm/commands/{mpm-resume.md → mpm-session-resume.md} +9 -0
  56. claude_mpm/commands/mpm-status.md +9 -0
  57. claude_mpm/commands/{mpm-organize.md → mpm-ticket-organize.md} +9 -0
  58. claude_mpm/commands/mpm-ticket-view.md +552 -0
  59. claude_mpm/commands/mpm-version.md +9 -0
  60. claude_mpm/commands/mpm.md +10 -0
  61. claude_mpm/config/agent_presets.py +488 -0
  62. claude_mpm/config/agent_sources.py +325 -0
  63. claude_mpm/config/skill_presets.py +392 -0
  64. claude_mpm/config/skill_sources.py +590 -0
  65. claude_mpm/constants.py +1 -0
  66. claude_mpm/core/claude_runner.py +5 -34
  67. claude_mpm/core/config.py +16 -0
  68. claude_mpm/core/framework/__init__.py +3 -16
  69. claude_mpm/core/framework/loaders/file_loader.py +54 -101
  70. claude_mpm/core/framework/loaders/instruction_loader.py +25 -5
  71. claude_mpm/core/interactive_session.py +83 -7
  72. claude_mpm/core/oneshot_session.py +71 -8
  73. claude_mpm/core/protocols/__init__.py +23 -0
  74. claude_mpm/core/protocols/runner_protocol.py +103 -0
  75. claude_mpm/core/protocols/session_protocol.py +131 -0
  76. claude_mpm/core/shared/singleton_manager.py +11 -4
  77. claude_mpm/core/system_context.py +38 -0
  78. claude_mpm/core/unified_config.py +22 -0
  79. claude_mpm/experimental/cli_enhancements.py +1 -5
  80. claude_mpm/hooks/claude_hooks/__pycache__/__init__.cpython-313.pyc +0 -0
  81. claude_mpm/hooks/claude_hooks/__pycache__/event_handlers.cpython-313.pyc +0 -0
  82. claude_mpm/hooks/claude_hooks/__pycache__/hook_handler.cpython-313.pyc +0 -0
  83. claude_mpm/hooks/claude_hooks/__pycache__/memory_integration.cpython-313.pyc +0 -0
  84. claude_mpm/hooks/claude_hooks/__pycache__/response_tracking.cpython-313.pyc +0 -0
  85. claude_mpm/hooks/claude_hooks/__pycache__/tool_analysis.cpython-313.pyc +0 -0
  86. claude_mpm/hooks/claude_hooks/memory_integration.py +12 -1
  87. claude_mpm/hooks/claude_hooks/services/__pycache__/__init__.cpython-313.pyc +0 -0
  88. claude_mpm/hooks/claude_hooks/services/__pycache__/connection_manager_http.cpython-313.pyc +0 -0
  89. claude_mpm/hooks/claude_hooks/services/__pycache__/duplicate_detector.cpython-313.pyc +0 -0
  90. claude_mpm/hooks/claude_hooks/services/__pycache__/state_manager.cpython-313.pyc +0 -0
  91. claude_mpm/hooks/claude_hooks/services/__pycache__/subagent_processor.cpython-313.pyc +0 -0
  92. claude_mpm/hooks/failure_learning/__init__.py +2 -8
  93. claude_mpm/hooks/failure_learning/failure_detection_hook.py +1 -6
  94. claude_mpm/hooks/failure_learning/fix_detection_hook.py +1 -6
  95. claude_mpm/hooks/failure_learning/learning_extraction_hook.py +1 -6
  96. claude_mpm/hooks/kuzu_response_hook.py +1 -5
  97. claude_mpm/models/git_repository.py +198 -0
  98. claude_mpm/services/agents/agent_builder.py +45 -9
  99. claude_mpm/services/agents/agent_preset_service.py +238 -0
  100. claude_mpm/services/agents/agent_selection_service.py +484 -0
  101. claude_mpm/services/agents/auto_deploy_index_parser.py +569 -0
  102. claude_mpm/services/agents/cache_git_manager.py +621 -0
  103. claude_mpm/services/agents/deployment/agent_deployment.py +126 -2
  104. claude_mpm/services/agents/deployment/agent_discovery_service.py +105 -73
  105. claude_mpm/services/agents/deployment/agent_lifecycle_manager.py +1 -5
  106. claude_mpm/services/agents/deployment/agent_restore_handler.py +1 -4
  107. claude_mpm/services/agents/deployment/agent_template_builder.py +236 -15
  108. claude_mpm/services/agents/deployment/agents_directory_resolver.py +101 -15
  109. claude_mpm/services/agents/deployment/async_agent_deployment.py +2 -1
  110. claude_mpm/services/agents/deployment/multi_source_deployment_service.py +115 -15
  111. claude_mpm/services/agents/deployment/refactored_agent_deployment_service.py +1 -4
  112. claude_mpm/services/agents/deployment/remote_agent_discovery_service.py +363 -0
  113. claude_mpm/services/agents/deployment/single_agent_deployer.py +2 -2
  114. claude_mpm/services/agents/deployment/system_instructions_deployer.py +168 -46
  115. claude_mpm/services/agents/deployment/validation/deployment_validator.py +2 -2
  116. claude_mpm/services/agents/git_source_manager.py +629 -0
  117. claude_mpm/services/agents/loading/framework_agent_loader.py +1 -4
  118. claude_mpm/services/agents/local_template_manager.py +47 -9
  119. claude_mpm/services/agents/single_tier_deployment_service.py +696 -0
  120. claude_mpm/services/agents/sources/__init__.py +13 -0
  121. claude_mpm/services/agents/sources/agent_sync_state.py +516 -0
  122. claude_mpm/services/agents/sources/git_source_sync_service.py +1087 -0
  123. claude_mpm/services/agents/startup_sync.py +239 -0
  124. claude_mpm/services/agents/toolchain_detector.py +474 -0
  125. claude_mpm/services/analysis/__init__.py +25 -0
  126. claude_mpm/services/analysis/postmortem_reporter.py +474 -0
  127. claude_mpm/services/analysis/postmortem_service.py +765 -0
  128. claude_mpm/services/command_deployment_service.py +200 -6
  129. claude_mpm/services/core/base.py +7 -2
  130. claude_mpm/services/core/interfaces/__init__.py +1 -3
  131. claude_mpm/services/core/interfaces/health.py +1 -4
  132. claude_mpm/services/core/models/__init__.py +2 -11
  133. claude_mpm/services/diagnostics/checks/__init__.py +4 -0
  134. claude_mpm/services/diagnostics/checks/agent_sources_check.py +577 -0
  135. claude_mpm/services/diagnostics/checks/mcp_services_check.py +7 -15
  136. claude_mpm/services/diagnostics/checks/skill_sources_check.py +587 -0
  137. claude_mpm/services/diagnostics/diagnostic_runner.py +9 -0
  138. claude_mpm/services/diagnostics/doctor_reporter.py +34 -6
  139. claude_mpm/services/git/__init__.py +21 -0
  140. claude_mpm/services/git/git_operations_service.py +494 -0
  141. claude_mpm/services/github/__init__.py +21 -0
  142. claude_mpm/services/github/github_cli_service.py +397 -0
  143. claude_mpm/services/infrastructure/monitoring/__init__.py +1 -5
  144. claude_mpm/services/infrastructure/monitoring/aggregator.py +1 -6
  145. claude_mpm/services/instructions/__init__.py +9 -0
  146. claude_mpm/services/instructions/instruction_cache_service.py +374 -0
  147. claude_mpm/services/local_ops/__init__.py +3 -13
  148. claude_mpm/services/local_ops/health_checks/__init__.py +1 -3
  149. claude_mpm/services/local_ops/health_manager.py +1 -4
  150. claude_mpm/services/mcp_config_manager.py +75 -145
  151. claude_mpm/services/mcp_gateway/core/process_pool.py +22 -16
  152. claude_mpm/services/mcp_gateway/server/mcp_gateway.py +1 -6
  153. claude_mpm/services/mcp_service_verifier.py +6 -3
  154. claude_mpm/services/monitor/daemon.py +28 -8
  155. claude_mpm/services/monitor/daemon_manager.py +96 -19
  156. claude_mpm/services/pr/__init__.py +14 -0
  157. claude_mpm/services/pr/pr_template_service.py +329 -0
  158. claude_mpm/services/project/project_organizer.py +4 -0
  159. claude_mpm/services/runner_configuration_service.py +16 -3
  160. claude_mpm/services/session_management_service.py +16 -4
  161. claude_mpm/services/skills/__init__.py +18 -0
  162. claude_mpm/services/skills/git_skill_source_manager.py +1169 -0
  163. claude_mpm/services/skills/skill_discovery_service.py +568 -0
  164. claude_mpm/services/socketio/server/core.py +1 -4
  165. claude_mpm/services/socketio/server/main.py +1 -3
  166. claude_mpm/services/unified/deployment_strategies/vercel.py +1 -5
  167. claude_mpm/services/unified/unified_deployment.py +1 -5
  168. claude_mpm/services/visualization/__init__.py +1 -5
  169. claude_mpm/templates/questions/__init__.py +2 -7
  170. claude_mpm/templates/questions/pr_strategy.py +1 -4
  171. claude_mpm/templates/questions/project_init.py +1 -4
  172. claude_mpm/templates/questions/ticket_mgmt.py +1 -4
  173. claude_mpm/utils/agent_dependency_loader.py +77 -10
  174. claude_mpm/utils/agent_filters.py +288 -0
  175. claude_mpm/utils/gitignore.py +3 -0
  176. claude_mpm/utils/migration.py +372 -0
  177. claude_mpm/utils/progress.py +387 -0
  178. {claude_mpm-4.25.10.dist-info → claude_mpm-5.1.8.dist-info}/METADATA +356 -112
  179. {claude_mpm-4.25.10.dist-info → claude_mpm-5.1.8.dist-info}/RECORD +188 -439
  180. claude_mpm/agents/templates/agent-manager.json +0 -273
  181. claude_mpm/agents/templates/agentic-coder-optimizer.json +0 -248
  182. claude_mpm/agents/templates/api_qa.json +0 -183
  183. claude_mpm/agents/templates/clerk-ops.json +0 -235
  184. claude_mpm/agents/templates/code_analyzer.json +0 -101
  185. claude_mpm/agents/templates/content-agent.json +0 -358
  186. claude_mpm/agents/templates/dart_engineer.json +0 -307
  187. claude_mpm/agents/templates/data_engineer.json +0 -225
  188. claude_mpm/agents/templates/documentation.json +0 -238
  189. claude_mpm/agents/templates/engineer.json +0 -210
  190. claude_mpm/agents/templates/gcp_ops_agent.json +0 -253
  191. claude_mpm/agents/templates/golang_engineer.json +0 -270
  192. claude_mpm/agents/templates/imagemagick.json +0 -264
  193. claude_mpm/agents/templates/java_engineer.json +0 -346
  194. claude_mpm/agents/templates/javascript_engineer_agent.json +0 -380
  195. claude_mpm/agents/templates/local_ops_agent.json +0 -1840
  196. claude_mpm/agents/templates/memory_manager.json +0 -158
  197. claude_mpm/agents/templates/nextjs_engineer.json +0 -285
  198. claude_mpm/agents/templates/ops.json +0 -185
  199. claude_mpm/agents/templates/php-engineer.json +0 -287
  200. claude_mpm/agents/templates/product_owner.json +0 -338
  201. claude_mpm/agents/templates/project_organizer.json +0 -144
  202. claude_mpm/agents/templates/prompt-engineer.json +0 -737
  203. claude_mpm/agents/templates/python_engineer.json +0 -387
  204. claude_mpm/agents/templates/qa.json +0 -243
  205. claude_mpm/agents/templates/react_engineer.json +0 -239
  206. claude_mpm/agents/templates/refactoring_engineer.json +0 -276
  207. claude_mpm/agents/templates/research.json +0 -258
  208. claude_mpm/agents/templates/ruby-engineer.json +0 -280
  209. claude_mpm/agents/templates/rust_engineer.json +0 -275
  210. claude_mpm/agents/templates/security.json +0 -202
  211. claude_mpm/agents/templates/svelte-engineer.json +0 -225
  212. claude_mpm/agents/templates/tauri_engineer.json +0 -274
  213. claude_mpm/agents/templates/ticketing.json +0 -181
  214. claude_mpm/agents/templates/typescript_engineer.json +0 -285
  215. claude_mpm/agents/templates/vercel_ops_agent.json +0 -412
  216. claude_mpm/agents/templates/version_control.json +0 -159
  217. claude_mpm/agents/templates/web_qa.json +0 -400
  218. claude_mpm/agents/templates/web_ui.json +0 -189
  219. claude_mpm/cli/README.md +0 -253
  220. claude_mpm/cli/commands/mcp_install_commands.py.backup +0 -284
  221. claude_mpm/cli/commands/mpm_init/README.md +0 -365
  222. claude_mpm/cli_module/refactoring_guide.md +0 -253
  223. claude_mpm/commands/mpm-tickets.md +0 -151
  224. claude_mpm/config/agent_capabilities.yaml +0 -658
  225. claude_mpm/config/async_logging_config.yaml +0 -145
  226. claude_mpm/core/.claude-mpm/logs/hooks_20250730.log +0 -34
  227. claude_mpm/d2/.gitignore +0 -22
  228. claude_mpm/d2/ARCHITECTURE_COMPARISON.md +0 -273
  229. claude_mpm/d2/FLASK_INTEGRATION.md +0 -156
  230. claude_mpm/d2/IMPLEMENTATION_SUMMARY.md +0 -452
  231. claude_mpm/d2/QUICKSTART.md +0 -186
  232. claude_mpm/d2/README.md +0 -232
  233. claude_mpm/d2/STORE_FIX_SUMMARY.md +0 -167
  234. claude_mpm/d2/SVELTE5_STORES_GUIDE.md +0 -180
  235. claude_mpm/d2/TESTING.md +0 -288
  236. claude_mpm/d2/index.html +0 -118
  237. claude_mpm/d2/package.json +0 -19
  238. claude_mpm/d2/src/App.svelte +0 -110
  239. claude_mpm/d2/src/components/Header.svelte +0 -153
  240. claude_mpm/d2/src/components/MainContent.svelte +0 -74
  241. claude_mpm/d2/src/components/Sidebar.svelte +0 -85
  242. claude_mpm/d2/src/components/tabs/EventsTab.svelte +0 -326
  243. claude_mpm/d2/src/lib/socketio.js +0 -144
  244. claude_mpm/d2/src/main.js +0 -7
  245. claude_mpm/d2/src/stores/events.js +0 -114
  246. claude_mpm/d2/src/stores/socket.js +0 -108
  247. claude_mpm/d2/src/stores/theme.js +0 -65
  248. claude_mpm/d2/svelte.config.js +0 -12
  249. claude_mpm/d2/vite.config.js +0 -15
  250. claude_mpm/dashboard/.claude-mpm/memories/README.md +0 -36
  251. claude_mpm/dashboard/BUILD_NUMBER +0 -1
  252. claude_mpm/dashboard/README.md +0 -121
  253. claude_mpm/dashboard/VERSION +0 -1
  254. claude_mpm/dashboard/react/components/DataInspector/DataInspector.module.css +0 -188
  255. claude_mpm/dashboard/react/components/DataInspector/DataInspector.tsx +0 -273
  256. claude_mpm/dashboard/react/components/ErrorBoundary.tsx +0 -75
  257. claude_mpm/dashboard/react/components/EventViewer/EventViewer.module.css +0 -156
  258. claude_mpm/dashboard/react/components/EventViewer/EventViewer.tsx +0 -141
  259. claude_mpm/dashboard/react/components/shared/ConnectionStatus.module.css +0 -38
  260. claude_mpm/dashboard/react/components/shared/ConnectionStatus.tsx +0 -36
  261. claude_mpm/dashboard/react/components/shared/FilterBar.module.css +0 -92
  262. claude_mpm/dashboard/react/components/shared/FilterBar.tsx +0 -89
  263. claude_mpm/dashboard/react/contexts/DashboardContext.tsx +0 -215
  264. claude_mpm/dashboard/react/entries/events.tsx +0 -165
  265. claude_mpm/dashboard/react/hooks/useEvents.ts +0 -191
  266. claude_mpm/dashboard/react/hooks/useSocket.ts +0 -225
  267. claude_mpm/dashboard/static/archive/activity_dashboard_fixed.html +0 -248
  268. claude_mpm/dashboard/static/built/REFACTORING_SUMMARY.md +0 -170
  269. claude_mpm/dashboard/static/built/assets/events.DjpNxWNo.css +0 -1
  270. claude_mpm/dashboard/static/built/components/activity-tree.js +0 -2
  271. claude_mpm/dashboard/static/built/components/activity-tree.js.map +0 -1
  272. claude_mpm/dashboard/static/built/components/agent-hierarchy.js +0 -777
  273. claude_mpm/dashboard/static/built/components/agent-inference.js +0 -2
  274. claude_mpm/dashboard/static/built/components/agent-inference.js.map +0 -1
  275. claude_mpm/dashboard/static/built/components/build-tracker.js +0 -333
  276. claude_mpm/dashboard/static/built/components/code-simple.js +0 -857
  277. claude_mpm/dashboard/static/built/components/code-tree/tree-breadcrumb.js +0 -353
  278. claude_mpm/dashboard/static/built/components/code-tree/tree-constants.js +0 -235
  279. claude_mpm/dashboard/static/built/components/code-tree/tree-search.js +0 -409
  280. claude_mpm/dashboard/static/built/components/code-tree/tree-utils.js +0 -435
  281. claude_mpm/dashboard/static/built/components/code-tree.js +0 -2
  282. claude_mpm/dashboard/static/built/components/code-tree.js.map +0 -1
  283. claude_mpm/dashboard/static/built/components/code-viewer.js +0 -2
  284. claude_mpm/dashboard/static/built/components/code-viewer.js.map +0 -1
  285. claude_mpm/dashboard/static/built/components/connection-debug.js +0 -654
  286. claude_mpm/dashboard/static/built/components/diff-viewer.js +0 -891
  287. claude_mpm/dashboard/static/built/components/event-processor.js +0 -2
  288. claude_mpm/dashboard/static/built/components/event-processor.js.map +0 -1
  289. claude_mpm/dashboard/static/built/components/event-viewer.js +0 -2
  290. claude_mpm/dashboard/static/built/components/event-viewer.js.map +0 -1
  291. claude_mpm/dashboard/static/built/components/export-manager.js +0 -2
  292. claude_mpm/dashboard/static/built/components/export-manager.js.map +0 -1
  293. claude_mpm/dashboard/static/built/components/file-change-tracker.js +0 -443
  294. claude_mpm/dashboard/static/built/components/file-change-viewer.js +0 -690
  295. claude_mpm/dashboard/static/built/components/file-tool-tracker.js +0 -2
  296. claude_mpm/dashboard/static/built/components/file-tool-tracker.js.map +0 -1
  297. claude_mpm/dashboard/static/built/components/file-viewer.js +0 -2
  298. claude_mpm/dashboard/static/built/components/file-viewer.js.map +0 -1
  299. claude_mpm/dashboard/static/built/components/hud-library-loader.js +0 -2
  300. claude_mpm/dashboard/static/built/components/hud-library-loader.js.map +0 -1
  301. claude_mpm/dashboard/static/built/components/hud-manager.js +0 -2
  302. claude_mpm/dashboard/static/built/components/hud-manager.js.map +0 -1
  303. claude_mpm/dashboard/static/built/components/hud-visualizer.js +0 -2
  304. claude_mpm/dashboard/static/built/components/hud-visualizer.js.map +0 -1
  305. claude_mpm/dashboard/static/built/components/module-viewer.js +0 -2
  306. claude_mpm/dashboard/static/built/components/module-viewer.js.map +0 -1
  307. claude_mpm/dashboard/static/built/components/nav-bar.js +0 -145
  308. claude_mpm/dashboard/static/built/components/page-structure.js +0 -429
  309. claude_mpm/dashboard/static/built/components/session-manager.js +0 -2
  310. claude_mpm/dashboard/static/built/components/session-manager.js.map +0 -1
  311. claude_mpm/dashboard/static/built/components/socket-manager.js +0 -2
  312. claude_mpm/dashboard/static/built/components/socket-manager.js.map +0 -1
  313. claude_mpm/dashboard/static/built/components/ui-state-manager.js +0 -2
  314. claude_mpm/dashboard/static/built/components/ui-state-manager.js.map +0 -1
  315. claude_mpm/dashboard/static/built/components/unified-data-viewer.js +0 -2
  316. claude_mpm/dashboard/static/built/components/unified-data-viewer.js.map +0 -1
  317. claude_mpm/dashboard/static/built/components/working-directory.js +0 -2
  318. claude_mpm/dashboard/static/built/components/working-directory.js.map +0 -1
  319. claude_mpm/dashboard/static/built/connection-manager.js +0 -536
  320. claude_mpm/dashboard/static/built/dashboard.js +0 -2
  321. claude_mpm/dashboard/static/built/dashboard.js.map +0 -1
  322. claude_mpm/dashboard/static/built/extension-error-handler.js +0 -164
  323. claude_mpm/dashboard/static/built/react/events.js +0 -30
  324. claude_mpm/dashboard/static/built/react/events.js.map +0 -1
  325. claude_mpm/dashboard/static/built/shared/dom-helpers.js +0 -396
  326. claude_mpm/dashboard/static/built/shared/event-bus.js +0 -330
  327. claude_mpm/dashboard/static/built/shared/event-filter-service.js +0 -540
  328. claude_mpm/dashboard/static/built/shared/logger.js +0 -385
  329. claude_mpm/dashboard/static/built/shared/page-structure.js +0 -249
  330. claude_mpm/dashboard/static/built/shared/tooltip-service.js +0 -253
  331. claude_mpm/dashboard/static/built/socket-client.js +0 -2
  332. claude_mpm/dashboard/static/built/socket-client.js.map +0 -1
  333. claude_mpm/dashboard/static/built/tab-isolation-fix.js +0 -185
  334. claude_mpm/dashboard/static/events.html +0 -607
  335. claude_mpm/dashboard/static/index.html +0 -635
  336. claude_mpm/dashboard/static/js/REFACTORING_SUMMARY.md +0 -170
  337. claude_mpm/dashboard/static/js/shared/dom-helpers.js +0 -396
  338. claude_mpm/dashboard/static/js/shared/event-bus.js +0 -330
  339. claude_mpm/dashboard/static/js/shared/logger.js +0 -385
  340. claude_mpm/dashboard/static/js/shared/tooltip-service.js +0 -253
  341. claude_mpm/dashboard/static/js/stores/dashboard-store.js +0 -562
  342. claude_mpm/dashboard/static/legacy/activity.html +0 -736
  343. claude_mpm/dashboard/static/legacy/agents.html +0 -786
  344. claude_mpm/dashboard/static/legacy/files.html +0 -747
  345. claude_mpm/dashboard/static/legacy/tools.html +0 -831
  346. claude_mpm/dashboard/static/monitors.html +0 -431
  347. claude_mpm/dashboard/static/navigation-test-results.md +0 -118
  348. claude_mpm/dashboard/static/production/events.html +0 -659
  349. claude_mpm/dashboard/static/production/main.html +0 -698
  350. claude_mpm/dashboard/static/production/monitors.html +0 -483
  351. claude_mpm/dashboard/static/test-archive/dashboard.html +0 -635
  352. claude_mpm/dashboard/static/test-archive/debug-events.html +0 -147
  353. claude_mpm/dashboard/static/test-archive/test-navigation.html +0 -256
  354. claude_mpm/dashboard/static/test-archive/test-react-exports.html +0 -180
  355. claude_mpm/dashboard/templates/.claude-mpm/memories/README.md +0 -36
  356. claude_mpm/dashboard/templates/.claude-mpm/memories/engineer_agent.md +0 -39
  357. claude_mpm/dashboard/templates/.claude-mpm/memories/version_control_agent.md +0 -38
  358. claude_mpm/hooks/README.md +0 -143
  359. claude_mpm/hooks/templates/README.md +0 -180
  360. claude_mpm/hooks/templates/settings.json.example +0 -147
  361. claude_mpm/schemas/agent_schema.json +0 -596
  362. claude_mpm/schemas/frontmatter_schema.json +0 -165
  363. claude_mpm/services/event_bus/README.md +0 -244
  364. claude_mpm/services/events/README.md +0 -303
  365. claude_mpm/services/framework_claude_md_generator/README.md +0 -119
  366. claude_mpm/services/mcp_gateway/README.md +0 -185
  367. claude_mpm/services/socketio/handlers/connection.py.backup +0 -217
  368. claude_mpm/services/socketio/handlers/hook.py.backup +0 -154
  369. claude_mpm/services/static/.gitkeep +0 -2
  370. claude_mpm/services/version_control/VERSION +0 -1
  371. claude_mpm/skills/bundled/.gitkeep +0 -2
  372. claude_mpm/skills/bundled/collaboration/brainstorming/SKILL.md +0 -79
  373. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/SKILL.md +0 -178
  374. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/agent-prompts.md +0 -577
  375. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/coordination-patterns.md +0 -467
  376. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/examples.md +0 -537
  377. claude_mpm/skills/bundled/collaboration/dispatching-parallel-agents/references/troubleshooting.md +0 -730
  378. claude_mpm/skills/bundled/collaboration/git-worktrees.md +0 -317
  379. claude_mpm/skills/bundled/collaboration/requesting-code-review/SKILL.md +0 -112
  380. claude_mpm/skills/bundled/collaboration/requesting-code-review/references/code-reviewer-template.md +0 -146
  381. claude_mpm/skills/bundled/collaboration/requesting-code-review/references/review-examples.md +0 -412
  382. claude_mpm/skills/bundled/collaboration/stacked-prs.md +0 -251
  383. claude_mpm/skills/bundled/collaboration/writing-plans/SKILL.md +0 -81
  384. claude_mpm/skills/bundled/collaboration/writing-plans/references/best-practices.md +0 -362
  385. claude_mpm/skills/bundled/collaboration/writing-plans/references/plan-structure-templates.md +0 -312
  386. claude_mpm/skills/bundled/debugging/root-cause-tracing/SKILL.md +0 -152
  387. claude_mpm/skills/bundled/debugging/root-cause-tracing/find-polluter.sh +0 -63
  388. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/advanced-techniques.md +0 -668
  389. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/examples.md +0 -587
  390. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/integration.md +0 -438
  391. claude_mpm/skills/bundled/debugging/root-cause-tracing/references/tracing-techniques.md +0 -391
  392. claude_mpm/skills/bundled/debugging/systematic-debugging/CREATION-LOG.md +0 -119
  393. claude_mpm/skills/bundled/debugging/systematic-debugging/SKILL.md +0 -148
  394. claude_mpm/skills/bundled/debugging/systematic-debugging/references/anti-patterns.md +0 -483
  395. claude_mpm/skills/bundled/debugging/systematic-debugging/references/examples.md +0 -452
  396. claude_mpm/skills/bundled/debugging/systematic-debugging/references/troubleshooting.md +0 -449
  397. claude_mpm/skills/bundled/debugging/systematic-debugging/references/workflow.md +0 -411
  398. claude_mpm/skills/bundled/debugging/systematic-debugging/test-academic.md +0 -14
  399. claude_mpm/skills/bundled/debugging/systematic-debugging/test-pressure-1.md +0 -58
  400. claude_mpm/skills/bundled/debugging/systematic-debugging/test-pressure-2.md +0 -68
  401. claude_mpm/skills/bundled/debugging/systematic-debugging/test-pressure-3.md +0 -69
  402. claude_mpm/skills/bundled/debugging/verification-before-completion/SKILL.md +0 -131
  403. claude_mpm/skills/bundled/debugging/verification-before-completion/references/gate-function.md +0 -325
  404. claude_mpm/skills/bundled/debugging/verification-before-completion/references/integration-and-workflows.md +0 -490
  405. claude_mpm/skills/bundled/debugging/verification-before-completion/references/red-flags-and-failures.md +0 -425
  406. claude_mpm/skills/bundled/debugging/verification-before-completion/references/verification-patterns.md +0 -499
  407. claude_mpm/skills/bundled/infrastructure/env-manager/INTEGRATION.md +0 -611
  408. claude_mpm/skills/bundled/infrastructure/env-manager/README.md +0 -596
  409. claude_mpm/skills/bundled/infrastructure/env-manager/SKILL.md +0 -260
  410. claude_mpm/skills/bundled/infrastructure/env-manager/examples/nextjs-env-structure.md +0 -315
  411. claude_mpm/skills/bundled/infrastructure/env-manager/references/frameworks.md +0 -436
  412. claude_mpm/skills/bundled/infrastructure/env-manager/references/security.md +0 -433
  413. claude_mpm/skills/bundled/infrastructure/env-manager/references/synchronization.md +0 -452
  414. claude_mpm/skills/bundled/infrastructure/env-manager/references/troubleshooting.md +0 -404
  415. claude_mpm/skills/bundled/infrastructure/env-manager/references/validation.md +0 -420
  416. claude_mpm/skills/bundled/main/artifacts-builder/LICENSE.txt +0 -202
  417. claude_mpm/skills/bundled/main/artifacts-builder/SKILL.md +0 -86
  418. claude_mpm/skills/bundled/main/artifacts-builder/scripts/bundle-artifact.sh +0 -54
  419. claude_mpm/skills/bundled/main/artifacts-builder/scripts/init-artifact.sh +0 -322
  420. claude_mpm/skills/bundled/main/artifacts-builder/scripts/shadcn-components.tar.gz +0 -0
  421. claude_mpm/skills/bundled/main/internal-comms/LICENSE.txt +0 -202
  422. claude_mpm/skills/bundled/main/internal-comms/SKILL.md +0 -43
  423. claude_mpm/skills/bundled/main/internal-comms/examples/3p-updates.md +0 -47
  424. claude_mpm/skills/bundled/main/internal-comms/examples/company-newsletter.md +0 -65
  425. claude_mpm/skills/bundled/main/internal-comms/examples/faq-answers.md +0 -30
  426. claude_mpm/skills/bundled/main/internal-comms/examples/general-comms.md +0 -16
  427. claude_mpm/skills/bundled/main/mcp-builder/LICENSE.txt +0 -202
  428. claude_mpm/skills/bundled/main/mcp-builder/SKILL.md +0 -160
  429. claude_mpm/skills/bundled/main/mcp-builder/reference/design_principles.md +0 -412
  430. claude_mpm/skills/bundled/main/mcp-builder/reference/evaluation.md +0 -602
  431. claude_mpm/skills/bundled/main/mcp-builder/reference/mcp_best_practices.md +0 -915
  432. claude_mpm/skills/bundled/main/mcp-builder/reference/node_mcp_server.md +0 -916
  433. claude_mpm/skills/bundled/main/mcp-builder/reference/python_mcp_server.md +0 -752
  434. claude_mpm/skills/bundled/main/mcp-builder/reference/workflow.md +0 -1237
  435. claude_mpm/skills/bundled/main/mcp-builder/scripts/example_evaluation.xml +0 -22
  436. claude_mpm/skills/bundled/main/mcp-builder/scripts/requirements.txt +0 -2
  437. claude_mpm/skills/bundled/main/skill-creator/LICENSE.txt +0 -202
  438. claude_mpm/skills/bundled/main/skill-creator/SKILL.md +0 -189
  439. claude_mpm/skills/bundled/main/skill-creator/references/best-practices.md +0 -500
  440. claude_mpm/skills/bundled/main/skill-creator/references/creation-workflow.md +0 -464
  441. claude_mpm/skills/bundled/main/skill-creator/references/examples.md +0 -619
  442. claude_mpm/skills/bundled/main/skill-creator/references/progressive-disclosure.md +0 -437
  443. claude_mpm/skills/bundled/main/skill-creator/references/skill-structure.md +0 -231
  444. claude_mpm/skills/bundled/php/espocrm-development/SKILL.md +0 -170
  445. claude_mpm/skills/bundled/php/espocrm-development/references/architecture.md +0 -602
  446. claude_mpm/skills/bundled/php/espocrm-development/references/common-tasks.md +0 -821
  447. claude_mpm/skills/bundled/php/espocrm-development/references/development-workflow.md +0 -742
  448. claude_mpm/skills/bundled/php/espocrm-development/references/frontend-customization.md +0 -726
  449. claude_mpm/skills/bundled/php/espocrm-development/references/hooks-and-services.md +0 -764
  450. claude_mpm/skills/bundled/php/espocrm-development/references/testing-debugging.md +0 -831
  451. claude_mpm/skills/bundled/react/flexlayout-react.md +0 -742
  452. claude_mpm/skills/bundled/rust/desktop-applications/SKILL.md +0 -226
  453. claude_mpm/skills/bundled/rust/desktop-applications/references/architecture-patterns.md +0 -901
  454. claude_mpm/skills/bundled/rust/desktop-applications/references/native-gui-frameworks.md +0 -901
  455. claude_mpm/skills/bundled/rust/desktop-applications/references/platform-integration.md +0 -775
  456. claude_mpm/skills/bundled/rust/desktop-applications/references/state-management.md +0 -937
  457. claude_mpm/skills/bundled/rust/desktop-applications/references/tauri-framework.md +0 -770
  458. claude_mpm/skills/bundled/rust/desktop-applications/references/testing-deployment.md +0 -961
  459. claude_mpm/skills/bundled/tauri/tauri-async-patterns.md +0 -495
  460. claude_mpm/skills/bundled/tauri/tauri-build-deploy.md +0 -599
  461. claude_mpm/skills/bundled/tauri/tauri-command-patterns.md +0 -535
  462. claude_mpm/skills/bundled/tauri/tauri-error-handling.md +0 -613
  463. claude_mpm/skills/bundled/tauri/tauri-event-system.md +0 -648
  464. claude_mpm/skills/bundled/tauri/tauri-file-system.md +0 -673
  465. claude_mpm/skills/bundled/tauri/tauri-frontend-integration.md +0 -767
  466. claude_mpm/skills/bundled/tauri/tauri-performance.md +0 -669
  467. claude_mpm/skills/bundled/tauri/tauri-state-management.md +0 -573
  468. claude_mpm/skills/bundled/tauri/tauri-testing.md +0 -384
  469. claude_mpm/skills/bundled/tauri/tauri-window-management.md +0 -628
  470. claude_mpm/skills/bundled/testing/condition-based-waiting/SKILL.md +0 -119
  471. claude_mpm/skills/bundled/testing/condition-based-waiting/example.ts +0 -158
  472. claude_mpm/skills/bundled/testing/condition-based-waiting/references/patterns-and-implementation.md +0 -253
  473. claude_mpm/skills/bundled/testing/test-driven-development/SKILL.md +0 -145
  474. claude_mpm/skills/bundled/testing/test-driven-development/references/anti-patterns.md +0 -543
  475. claude_mpm/skills/bundled/testing/test-driven-development/references/examples.md +0 -741
  476. claude_mpm/skills/bundled/testing/test-driven-development/references/integration.md +0 -470
  477. claude_mpm/skills/bundled/testing/test-driven-development/references/philosophy.md +0 -458
  478. claude_mpm/skills/bundled/testing/test-driven-development/references/workflow.md +0 -639
  479. claude_mpm/skills/bundled/testing/test-quality-inspector/SKILL.md +0 -458
  480. claude_mpm/skills/bundled/testing/test-quality-inspector/examples/example-inspection-report.md +0 -411
  481. claude_mpm/skills/bundled/testing/test-quality-inspector/references/assertion-quality.md +0 -317
  482. claude_mpm/skills/bundled/testing/test-quality-inspector/references/inspection-checklist.md +0 -270
  483. claude_mpm/skills/bundled/testing/test-quality-inspector/references/red-flags.md +0 -436
  484. claude_mpm/skills/bundled/testing/testing-anti-patterns/SKILL.md +0 -140
  485. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/completeness-anti-patterns.md +0 -572
  486. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/core-anti-patterns.md +0 -411
  487. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/detection-guide.md +0 -569
  488. claude_mpm/skills/bundled/testing/testing-anti-patterns/references/tdd-connection.md +0 -695
  489. claude_mpm/skills/bundled/testing/webapp-testing/LICENSE.txt +0 -202
  490. claude_mpm/skills/bundled/testing/webapp-testing/SKILL.md +0 -184
  491. claude_mpm/skills/bundled/testing/webapp-testing/decision-tree.md +0 -459
  492. claude_mpm/skills/bundled/testing/webapp-testing/playwright-patterns.md +0 -479
  493. claude_mpm/skills/bundled/testing/webapp-testing/reconnaissance-pattern.md +0 -687
  494. claude_mpm/skills/bundled/testing/webapp-testing/server-management.md +0 -758
  495. claude_mpm/skills/bundled/testing/webapp-testing/troubleshooting.md +0 -868
  496. claude_mpm/templates/questions/EXAMPLES.md +0 -501
  497. claude_mpm/tools/README_SOCKETIO_DEBUG.md +0 -224
  498. claude_mpm/tools/code_tree_analyzer/README.md +0 -64
  499. /claude_mpm/agents/templates/{git_file_tracking.md → git-file-tracking.md} +0 -0
  500. /claude_mpm/agents/templates/{pm_examples.md → pm-examples.md} +0 -0
  501. /claude_mpm/agents/templates/{pm_red_flags.md → pm-red-flags.md} +0 -0
  502. /claude_mpm/agents/templates/{response_format.md → response-format.md} +0 -0
  503. /claude_mpm/agents/templates/{validation_templates.md → validation-templates.md} +0 -0
  504. {claude_mpm-4.25.10.dist-info → claude_mpm-5.1.8.dist-info}/WHEEL +0 -0
  505. {claude_mpm-4.25.10.dist-info → claude_mpm-5.1.8.dist-info}/entry_points.txt +0 -0
  506. {claude_mpm-4.25.10.dist-info → claude_mpm-5.1.8.dist-info}/licenses/LICENSE +0 -0
  507. {claude_mpm-4.25.10.dist-info → claude_mpm-5.1.8.dist-info}/top_level.txt +0 -0
@@ -1,673 +0,0 @@
1
- ---
2
- name: tauri-file-system
3
- description: Safe file system operations in Tauri including path validation, file dialogs, directory operations, and secure file access patterns
4
- version: 1.0.0
5
- category: development
6
- author: Claude MPM Team
7
- license: MIT
8
- progressive_disclosure:
9
- entry_point:
10
- summary: "Secure file operations: path validation, scoped access, file dialogs, directory management, safe read/write patterns"
11
- when_to_use: "When implementing file operations, document management, or any file system access in Tauri apps"
12
- quick_start: "1. Configure fs allowlist 2. Validate paths 3. Use app directories 4. Implement dialogs 5. Handle errors"
13
- context_limit: 600
14
- tags:
15
- - tauri
16
- - filesystem
17
- - security
18
- - file-operations
19
- - path-validation
20
- requires_tools: []
21
- ---
22
-
23
- # Tauri File System Operations
24
-
25
- ## Security Configuration
26
-
27
- ### Allowlist Setup
28
-
29
- ```json
30
- // src-tauri/tauri.conf.json
31
- {
32
- "tauri": {
33
- "allowlist": {
34
- "fs": {
35
- "all": false,
36
- "readFile": true,
37
- "writeFile": true,
38
- "readDir": true,
39
- "createDir": true,
40
- "removeFile": true,
41
- "removeDir": true,
42
- "renameFile": true,
43
- "exists": true,
44
- "scope": [
45
- "$APPDATA/**",
46
- "$DOCUMENT/**",
47
- "$DOWNLOAD/**",
48
- "$HOME/Documents/**"
49
- ]
50
- }
51
- }
52
- }
53
- }
54
- ```
55
-
56
- **Path Variables**:
57
- - `$APPDATA` - Application data directory
58
- - `$DOCUMENT` - User documents directory
59
- - `$DOWNLOAD` - User downloads directory
60
- - `$HOME` - User home directory
61
- - `$TEMP` - Temporary directory
62
-
63
- ## Safe Path Handling
64
-
65
- ### Path Validation Pattern
66
-
67
- ```rust
68
- use std::path::{Path, PathBuf};
69
-
70
- fn validate_path(base_dir: &Path, user_path: &str) -> Result<PathBuf, String> {
71
- // Resolve the path
72
- let full_path = base_dir.join(user_path);
73
-
74
- // Canonicalize to resolve .. and symlinks
75
- let canonical = full_path.canonicalize()
76
- .map_err(|e| format!("Invalid path: {}", e))?;
77
-
78
- // CRITICAL: Ensure path is within base directory
79
- if !canonical.starts_with(base_dir) {
80
- return Err("Path traversal attempt detected".to_string());
81
- }
82
-
83
- Ok(canonical)
84
- }
85
-
86
- #[tauri::command]
87
- async fn read_app_file(
88
- filename: String,
89
- app: tauri::AppHandle,
90
- ) -> Result<String, String> {
91
- let app_dir = app.path_resolver()
92
- .app_data_dir()
93
- .ok_or("Failed to get app data dir")?;
94
-
95
- let safe_path = validate_path(&app_dir, &filename)?;
96
-
97
- tokio::fs::read_to_string(safe_path)
98
- .await
99
- .map_err(|e| e.to_string())
100
- }
101
- ```
102
-
103
- ### App Directory Helpers
104
-
105
- ```rust
106
- use tauri::Manager;
107
-
108
- #[tauri::command]
109
- async fn get_app_paths(app: tauri::AppHandle) -> Result<AppPaths, String> {
110
- let resolver = app.path_resolver();
111
-
112
- Ok(AppPaths {
113
- app_data: resolver.app_data_dir()
114
- .map(|p| p.to_string_lossy().to_string()),
115
- app_config: resolver.app_config_dir()
116
- .map(|p| p.to_string_lossy().to_string()),
117
- app_cache: resolver.app_cache_dir()
118
- .map(|p| p.to_string_lossy().to_string()),
119
- app_log: resolver.app_log_dir()
120
- .map(|p| p.to_string_lossy().to_string()),
121
- })
122
- }
123
-
124
- #[derive(serde::Serialize)]
125
- struct AppPaths {
126
- app_data: Option<String>,
127
- app_config: Option<String>,
128
- app_cache: Option<String>,
129
- app_log: Option<String>,
130
- }
131
- ```
132
-
133
- ## File Operations
134
-
135
- ### Reading Files
136
-
137
- ```rust
138
- use tokio::fs;
139
-
140
- #[tauri::command]
141
- async fn read_document(
142
- filename: String,
143
- app: tauri::AppHandle,
144
- ) -> Result<String, String> {
145
- let app_data = app.path_resolver()
146
- .app_data_dir()
147
- .ok_or("Failed to get app data dir")?;
148
-
149
- let file_path = validate_path(&app_data, &filename)?;
150
-
151
- // Check if file exists
152
- if !file_path.exists() {
153
- return Err(format!("File not found: {}", filename));
154
- }
155
-
156
- // Read file
157
- fs::read_to_string(file_path)
158
- .await
159
- .map_err(|e| format!("Failed to read file: {}", e))
160
- }
161
-
162
- #[tauri::command]
163
- async fn read_binary_file(
164
- filename: String,
165
- app: tauri::AppHandle,
166
- ) -> Result<Vec<u8>, String> {
167
- let app_data = app.path_resolver()
168
- .app_data_dir()
169
- .ok_or("Failed to get app data dir")?;
170
-
171
- let file_path = validate_path(&app_data, &filename)?;
172
-
173
- fs::read(file_path)
174
- .await
175
- .map_err(|e| e.to_string())
176
- }
177
- ```
178
-
179
- ### Writing Files
180
-
181
- ```rust
182
- #[tauri::command]
183
- async fn save_document(
184
- filename: String,
185
- content: String,
186
- app: tauri::AppHandle,
187
- ) -> Result<(), String> {
188
- let app_data = app.path_resolver()
189
- .app_data_dir()
190
- .ok_or("Failed to get app data dir")?;
191
-
192
- // Ensure directory exists
193
- fs::create_dir_all(&app_data)
194
- .await
195
- .map_err(|e| format!("Failed to create directory: {}", e))?;
196
-
197
- let file_path = validate_path(&app_data, &filename)?;
198
-
199
- // Write file
200
- fs::write(file_path, content)
201
- .await
202
- .map_err(|e| format!("Failed to write file: {}", e))
203
- }
204
-
205
- #[tauri::command]
206
- async fn append_to_file(
207
- filename: String,
208
- content: String,
209
- app: tauri::AppHandle,
210
- ) -> Result<(), String> {
211
- use tokio::io::AsyncWriteExt;
212
-
213
- let app_data = app.path_resolver()
214
- .app_data_dir()
215
- .ok_or("Failed to get app data dir")?;
216
-
217
- let file_path = validate_path(&app_data, &filename)?;
218
-
219
- let mut file = fs::OpenOptions::new()
220
- .append(true)
221
- .create(true)
222
- .open(file_path)
223
- .await
224
- .map_err(|e| e.to_string())?;
225
-
226
- file.write_all(content.as_bytes())
227
- .await
228
- .map_err(|e| e.to_string())?;
229
-
230
- Ok(())
231
- }
232
- ```
233
-
234
- ## Directory Operations
235
-
236
- ### Listing Directories
237
-
238
- ```rust
239
- #[derive(serde::Serialize)]
240
- struct FileEntry {
241
- name: String,
242
- path: String,
243
- is_dir: bool,
244
- size: u64,
245
- modified: Option<u64>,
246
- }
247
-
248
- #[tauri::command]
249
- async fn list_directory(
250
- directory: String,
251
- app: tauri::AppHandle,
252
- ) -> Result<Vec<FileEntry>, String> {
253
- let app_data = app.path_resolver()
254
- .app_data_dir()
255
- .ok_or("Failed to get app data dir")?;
256
-
257
- let dir_path = validate_path(&app_data, &directory)?;
258
-
259
- let mut entries = Vec::new();
260
- let mut read_dir = fs::read_dir(dir_path)
261
- .await
262
- .map_err(|e| e.to_string())?;
263
-
264
- while let Some(entry) = read_dir.next_entry()
265
- .await
266
- .map_err(|e| e.to_string())? {
267
-
268
- let metadata = entry.metadata()
269
- .await
270
- .map_err(|e| e.to_string())?;
271
-
272
- let modified = metadata.modified()
273
- .ok()
274
- .and_then(|t| t.duration_since(std::time::UNIX_EPOCH).ok())
275
- .map(|d| d.as_secs());
276
-
277
- entries.push(FileEntry {
278
- name: entry.file_name().to_string_lossy().to_string(),
279
- path: entry.path().to_string_lossy().to_string(),
280
- is_dir: metadata.is_dir(),
281
- size: metadata.len(),
282
- modified,
283
- });
284
- }
285
-
286
- Ok(entries)
287
- }
288
- ```
289
-
290
- ### Creating Directories
291
-
292
- ```rust
293
- #[tauri::command]
294
- async fn create_directory(
295
- directory: String,
296
- app: tauri::AppHandle,
297
- ) -> Result<(), String> {
298
- let app_data = app.path_resolver()
299
- .app_data_dir()
300
- .ok_or("Failed to get app data dir")?;
301
-
302
- let dir_path = validate_path(&app_data, &directory)?;
303
-
304
- fs::create_dir_all(dir_path)
305
- .await
306
- .map_err(|e| format!("Failed to create directory: {}", e))
307
- }
308
-
309
- #[tauri::command]
310
- async fn remove_directory(
311
- directory: String,
312
- recursive: bool,
313
- app: tauri::AppHandle,
314
- ) -> Result<(), String> {
315
- let app_data = app.path_resolver()
316
- .app_data_dir()
317
- .ok_or("Failed to get app data dir")?;
318
-
319
- let dir_path = validate_path(&app_data, &directory)?;
320
-
321
- if recursive {
322
- fs::remove_dir_all(dir_path)
323
- .await
324
- .map_err(|e| e.to_string())
325
- } else {
326
- fs::remove_dir(dir_path)
327
- .await
328
- .map_err(|e| e.to_string())
329
- }
330
- }
331
- ```
332
-
333
- ## File Dialogs
334
-
335
- ### Open File Dialog
336
-
337
- ```rust
338
- use tauri::api::dialog::FileDialogBuilder;
339
-
340
- #[tauri::command]
341
- async fn select_file() -> Result<Option<String>, String> {
342
- let result = tokio::task::spawn_blocking(|| {
343
- FileDialogBuilder::new()
344
- .add_filter("Text Files", &["txt", "md", "json"])
345
- .add_filter("All Files", &["*"])
346
- .set_title("Select a file")
347
- .pick_file()
348
- })
349
- .await
350
- .map_err(|e| e.to_string())?;
351
-
352
- Ok(result.map(|p| p.to_string_lossy().to_string()))
353
- }
354
-
355
- #[tauri::command]
356
- async fn select_multiple_files() -> Result<Vec<String>, String> {
357
- let result = tokio::task::spawn_blocking(|| {
358
- FileDialogBuilder::new()
359
- .add_filter("Documents", &["txt", "pdf", "doc", "docx"])
360
- .pick_files()
361
- })
362
- .await
363
- .map_err(|e| e.to_string())?;
364
-
365
- Ok(result.map(|files| {
366
- files.iter()
367
- .map(|p| p.to_string_lossy().to_string())
368
- .collect()
369
- }).unwrap_or_default())
370
- }
371
- ```
372
-
373
- ### Save File Dialog
374
-
375
- ```rust
376
- #[tauri::command]
377
- async fn save_file_dialog(
378
- default_name: String,
379
- content: String,
380
- ) -> Result<Option<String>, String> {
381
- let path = tokio::task::spawn_blocking(move || {
382
- FileDialogBuilder::new()
383
- .set_file_name(&default_name)
384
- .add_filter("Text Files", &["txt"])
385
- .save_file()
386
- })
387
- .await
388
- .map_err(|e| e.to_string())?;
389
-
390
- if let Some(file_path) = path {
391
- tokio::fs::write(&file_path, content)
392
- .await
393
- .map_err(|e| e.to_string())?;
394
-
395
- Ok(Some(file_path.to_string_lossy().to_string()))
396
- } else {
397
- Ok(None)
398
- }
399
- }
400
- ```
401
-
402
- ### Folder Selection Dialog
403
-
404
- ```rust
405
- #[tauri::command]
406
- async fn select_folder() -> Result<Option<String>, String> {
407
- let result = tokio::task::spawn_blocking(|| {
408
- FileDialogBuilder::new()
409
- .set_title("Select a folder")
410
- .pick_folder()
411
- })
412
- .await
413
- .map_err(|e| e.to_string())?;
414
-
415
- Ok(result.map(|p| p.to_string_lossy().to_string()))
416
- }
417
- ```
418
-
419
- ## Advanced File Operations
420
-
421
- ### File Watching
422
-
423
- ```rust
424
- use notify::{Watcher, RecursiveMode, Event};
425
-
426
- #[tauri::command]
427
- async fn watch_file(
428
- filepath: String,
429
- window: tauri::Window,
430
- app: tauri::AppHandle,
431
- ) -> Result<(), String> {
432
- let app_data = app.path_resolver()
433
- .app_data_dir()
434
- .ok_or("Failed to get app data dir")?;
435
-
436
- let safe_path = validate_path(&app_data, &filepath)?;
437
-
438
- let (tx, mut rx) = tokio::sync::mpsc::channel(100);
439
-
440
- // Create watcher
441
- let mut watcher = notify::recommended_watcher(move |res: Result<Event, _>| {
442
- if let Ok(event) = res {
443
- let _ = tx.blocking_send(event);
444
- }
445
- }).map_err(|e| e.to_string())?;
446
-
447
- watcher.watch(&safe_path, RecursiveMode::NonRecursive)
448
- .map_err(|e| e.to_string())?;
449
-
450
- // Spawn task to handle events
451
- tokio::spawn(async move {
452
- while let Some(event) = rx.recv().await {
453
- let _ = window.emit("file-changed", event);
454
- }
455
- });
456
-
457
- Ok(())
458
- }
459
- ```
460
-
461
- ### Atomic File Operations
462
-
463
- ```rust
464
- use tokio::fs;
465
- use uuid::Uuid;
466
-
467
- #[tauri::command]
468
- async fn atomic_write(
469
- filename: String,
470
- content: String,
471
- app: tauri::AppHandle,
472
- ) -> Result<(), String> {
473
- let app_data = app.path_resolver()
474
- .app_data_dir()
475
- .ok_or("Failed to get app data dir")?;
476
-
477
- let target_path = validate_path(&app_data, &filename)?;
478
-
479
- // Write to temporary file
480
- let temp_filename = format!("{}.tmp.{}", filename, Uuid::new_v4());
481
- let temp_path = validate_path(&app_data, &temp_filename)?;
482
-
483
- fs::write(&temp_path, content)
484
- .await
485
- .map_err(|e| format!("Failed to write temp file: {}", e))?;
486
-
487
- // Atomic rename
488
- fs::rename(temp_path, target_path)
489
- .await
490
- .map_err(|e| format!("Failed to rename file: {}", e))?;
491
-
492
- Ok(())
493
- }
494
- ```
495
-
496
- ### Batch File Operations
497
-
498
- ```rust
499
- #[derive(serde::Deserialize)]
500
- struct BatchOperation {
501
- operation: String, // "copy", "move", "delete"
502
- source: String,
503
- destination: Option<String>,
504
- }
505
-
506
- #[tauri::command]
507
- async fn batch_file_operations(
508
- operations: Vec<BatchOperation>,
509
- app: tauri::AppHandle,
510
- ) -> Result<Vec<String>, String> {
511
- let app_data = app.path_resolver()
512
- .app_data_dir()
513
- .ok_or("Failed to get app data dir")?;
514
-
515
- let mut results = Vec::new();
516
-
517
- for op in operations {
518
- let source_path = validate_path(&app_data, &op.source)?;
519
-
520
- let result = match op.operation.as_str() {
521
- "copy" => {
522
- if let Some(dest) = op.destination {
523
- let dest_path = validate_path(&app_data, &dest)?;
524
- fs::copy(source_path, dest_path)
525
- .await
526
- .map(|_| "Success".to_string())
527
- .map_err(|e| e.to_string())
528
- } else {
529
- Err("Missing destination".to_string())
530
- }
531
- }
532
- "move" => {
533
- if let Some(dest) = op.destination {
534
- let dest_path = validate_path(&app_data, &dest)?;
535
- fs::rename(source_path, dest_path)
536
- .await
537
- .map(|_| "Success".to_string())
538
- .map_err(|e| e.to_string())
539
- } else {
540
- Err("Missing destination".to_string())
541
- }
542
- }
543
- "delete" => {
544
- fs::remove_file(source_path)
545
- .await
546
- .map(|_| "Success".to_string())
547
- .map_err(|e| e.to_string())
548
- }
549
- _ => Err(format!("Unknown operation: {}", op.operation))
550
- };
551
-
552
- results.push(result.unwrap_or_else(|e| format!("Error: {}", e)));
553
- }
554
-
555
- Ok(results)
556
- }
557
- ```
558
-
559
- ## Frontend Integration
560
-
561
- ### File Service Pattern
562
-
563
- ```typescript
564
- import { invoke } from '@tauri-apps/api/core';
565
-
566
- export class FileService {
567
- async readFile(filename: string): Promise<string> {
568
- return await invoke<string>('read_document', { filename });
569
- }
570
-
571
- async saveFile(filename: string, content: string): Promise<void> {
572
- await invoke('save_document', { filename, content });
573
- }
574
-
575
- async listFiles(directory: string): Promise<FileEntry[]> {
576
- return await invoke<FileEntry[]>('list_directory', { directory });
577
- }
578
-
579
- async selectFile(): Promise<string | null> {
580
- return await invoke<string | null>('select_file');
581
- }
582
-
583
- async saveFileDialog(
584
- defaultName: string,
585
- content: string
586
- ): Promise<string | null> {
587
- return await invoke<string | null>('save_file_dialog', {
588
- defaultName,
589
- content
590
- });
591
- }
592
- }
593
-
594
- export const fileService = new FileService();
595
- ```
596
-
597
- ## Best Practices
598
-
599
- 1. **Always validate paths** - Use `validate_path()` for all user inputs
600
- 2. **Use app directories** - Never hardcode paths, use path resolver
601
- 3. **Configure scopes strictly** - Only allow necessary directories
602
- 4. **Handle errors gracefully** - Provide meaningful error messages
603
- 5. **Use atomic writes** - For critical data, write to temp then rename
604
- 6. **Spawn blocking for dialogs** - File dialogs block thread
605
- 7. **Check file existence** - Before read/write operations
606
- 8. **Use relative paths** - Store relative to app directories
607
- 9. **Implement proper cleanup** - Remove temp files
608
- 10. **Test path traversal** - Ensure security with `../` attacks
609
-
610
- ## Security Checklist
611
-
612
- - [ ] Allowlist configured with minimal permissions
613
- - [ ] All paths validated with `starts_with()` check
614
- - [ ] No hardcoded absolute paths
615
- - [ ] User input paths go through `validate_path()`
616
- - [ ] Scopes defined in tauri.conf.json
617
- - [ ] File operations use tokio::fs (async)
618
- - [ ] Error messages don't leak path information
619
- - [ ] Temporary files cleaned up
620
- - [ ] Symlink attacks prevented with canonicalize()
621
-
622
- ## Common Pitfalls
623
-
624
- ❌ **Not validating paths**:
625
- ```rust
626
- // WRONG - path traversal vulnerability
627
- #[tauri::command]
628
- async fn read_file_unsafe(path: String) -> Result<String, String> {
629
- tokio::fs::read_to_string(path).await.map_err(|e| e.to_string())
630
- }
631
-
632
- // CORRECT - validate first
633
- #[tauri::command]
634
- async fn read_file_safe(
635
- filename: String,
636
- app: tauri::AppHandle,
637
- ) -> Result<String, String> {
638
- let app_dir = app.path_resolver().app_data_dir().unwrap();
639
- let safe_path = validate_path(&app_dir, &filename)?;
640
- tokio::fs::read_to_string(safe_path).await.map_err(|e| e.to_string())
641
- }
642
- ```
643
-
644
- ❌ **Using blocking fs in async**:
645
- ```rust
646
- // WRONG - blocks async runtime
647
- std::fs::read_to_string(path)?;
648
-
649
- // CORRECT - use tokio::fs
650
- tokio::fs::read_to_string(path).await?;
651
- ```
652
-
653
- ❌ **Not using spawn_blocking for dialogs**:
654
- ```rust
655
- // WRONG - blocks async runtime
656
- FileDialogBuilder::new().pick_file();
657
-
658
- // CORRECT - spawn blocking
659
- tokio::task::spawn_blocking(|| {
660
- FileDialogBuilder::new().pick_file()
661
- }).await?
662
- ```
663
-
664
- ## Summary
665
-
666
- - **Always validate paths** - Prevent path traversal attacks
667
- - **Use app directories** - Via path resolver, not hardcoded
668
- - **Configure allowlist** - Minimum necessary permissions
669
- - **Async file operations** - Use tokio::fs, not std::fs
670
- - **File dialogs** - Spawn in blocking context
671
- - **Error handling** - Provide user-friendly messages
672
- - **Atomic operations** - Write to temp, then rename
673
- - **Security first** - Validate, scope, sanitize all inputs