codex-linux 1.0.0

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 (367) hide show
  1. package/.claude/settings.local.json +10 -0
  2. package/.eslintrc.json +27 -0
  3. package/.github/workflows/ci.yml +156 -0
  4. package/.huskyrc +7 -0
  5. package/.lintstagedrc +13 -0
  6. package/.prettierrc +12 -0
  7. package/CLAUDE.md +163 -0
  8. package/DESIGN_SUPERIOR.md +73 -0
  9. package/Dockerfile +64 -0
  10. package/INSTALLATION.md +152 -0
  11. package/LICENSE +21 -0
  12. package/README.md +245 -0
  13. package/assets/skills/code-review/instructions.md +102 -0
  14. package/assets/skills/code-review/skill.yaml +15 -0
  15. package/assets/skills/refactoring/instructions.md +149 -0
  16. package/assets/skills/refactoring/skill.yaml +15 -0
  17. package/assets/skills/testing/skill.yaml +15 -0
  18. package/commitlint.config.js +23 -0
  19. package/dist/main/DatabaseManager.js +763 -0
  20. package/dist/main/DatabaseManager.js.map +1 -0
  21. package/dist/main/SettingsManager.js +61 -0
  22. package/dist/main/SettingsManager.js.map +1 -0
  23. package/dist/main/agents/AgentOrchestrator.js +787 -0
  24. package/dist/main/agents/AgentOrchestrator.js.map +1 -0
  25. package/dist/main/agents/AgentSDK.js +219 -0
  26. package/dist/main/agents/AgentSDK.js.map +1 -0
  27. package/dist/main/agents/AgentTools.js +348 -0
  28. package/dist/main/agents/AgentTools.js.map +1 -0
  29. package/dist/main/agents/CodeIndex.js +233 -0
  30. package/dist/main/agents/CodeIndex.js.map +1 -0
  31. package/dist/main/agents/EmbeddingService.js +80 -0
  32. package/dist/main/agents/EmbeddingService.js.map +1 -0
  33. package/dist/main/agents/NativeToolCalling.js +206 -0
  34. package/dist/main/agents/NativeToolCalling.js.map +1 -0
  35. package/dist/main/api/APIServer.js +278 -0
  36. package/dist/main/api/APIServer.js.map +1 -0
  37. package/dist/main/api/RateLimiter.js +138 -0
  38. package/dist/main/api/RateLimiter.js.map +1 -0
  39. package/dist/main/api/WebSocketManager.js +300 -0
  40. package/dist/main/api/WebSocketManager.js.map +1 -0
  41. package/dist/main/assistant/ContextOptimizer.js +192 -0
  42. package/dist/main/assistant/ContextOptimizer.js.map +1 -0
  43. package/dist/main/assistant/PredictedOutputManager.js +172 -0
  44. package/dist/main/assistant/PredictedOutputManager.js.map +1 -0
  45. package/dist/main/assistant/PromptCacheManager.js +193 -0
  46. package/dist/main/assistant/PromptCacheManager.js.map +1 -0
  47. package/dist/main/assistant/PromptOptimizer.js +626 -0
  48. package/dist/main/assistant/PromptOptimizer.js.map +1 -0
  49. package/dist/main/assistant/SmartCodeAssistant.js +224 -0
  50. package/dist/main/assistant/SmartCodeAssistant.js.map +1 -0
  51. package/dist/main/auth/SessionManager.js +300 -0
  52. package/dist/main/auth/SessionManager.js.map +1 -0
  53. package/dist/main/automations/AdvancedWebhookSystem.js +212 -0
  54. package/dist/main/automations/AdvancedWebhookSystem.js.map +1 -0
  55. package/dist/main/automations/AutomationScheduler.js +269 -0
  56. package/dist/main/automations/AutomationScheduler.js.map +1 -0
  57. package/dist/main/automations/BatchProcessingSystem.js +159 -0
  58. package/dist/main/automations/BatchProcessingSystem.js.map +1 -0
  59. package/dist/main/automations/BrowserAutomationManager.js +195 -0
  60. package/dist/main/automations/BrowserAutomationManager.js.map +1 -0
  61. package/dist/main/automations/GitHubActionsManager.js +129 -0
  62. package/dist/main/automations/GitHubActionsManager.js.map +1 -0
  63. package/dist/main/automations/GitLabCIManager.js +122 -0
  64. package/dist/main/automations/GitLabCIManager.js.map +1 -0
  65. package/dist/main/automations/PriorityQueueManager.js +240 -0
  66. package/dist/main/automations/PriorityQueueManager.js.map +1 -0
  67. package/dist/main/background/BackgroundModeManager.js +117 -0
  68. package/dist/main/background/BackgroundModeManager.js.map +1 -0
  69. package/dist/main/backup/BackupManager.js +254 -0
  70. package/dist/main/backup/BackupManager.js.map +1 -0
  71. package/dist/main/backup/MigrationManager.js +114 -0
  72. package/dist/main/backup/MigrationManager.js.map +1 -0
  73. package/dist/main/commands/SlashCommandManager.js +399 -0
  74. package/dist/main/commands/SlashCommandManager.js.map +1 -0
  75. package/dist/main/config/ClaudeMdParser.js +519 -0
  76. package/dist/main/config/ClaudeMdParser.js.map +1 -0
  77. package/dist/main/config/CustomizationManager.js +381 -0
  78. package/dist/main/config/CustomizationManager.js.map +1 -0
  79. package/dist/main/config/LaunchConfigManager.js +211 -0
  80. package/dist/main/config/LaunchConfigManager.js.map +1 -0
  81. package/dist/main/config/SettingsManager.js +166 -0
  82. package/dist/main/config/SettingsManager.js.map +1 -0
  83. package/dist/main/connectors/ConnectorManager.js +151 -0
  84. package/dist/main/connectors/ConnectorManager.js.map +1 -0
  85. package/dist/main/connectors/DatabaseConnector.js +222 -0
  86. package/dist/main/connectors/DatabaseConnector.js.map +1 -0
  87. package/dist/main/cowork/CoworkManager.js +324 -0
  88. package/dist/main/cowork/CoworkManager.js.map +1 -0
  89. package/dist/main/evals/AgentEvalFramework.js +538 -0
  90. package/dist/main/evals/AgentEvalFramework.js.map +1 -0
  91. package/dist/main/evals/GraderManager.js +285 -0
  92. package/dist/main/evals/GraderManager.js.map +1 -0
  93. package/dist/main/git/GitWorktreeManager.js +214 -0
  94. package/dist/main/git/GitWorktreeManager.js.map +1 -0
  95. package/dist/main/github/GitHubPRMonitor.js +244 -0
  96. package/dist/main/github/GitHubPRMonitor.js.map +1 -0
  97. package/dist/main/ide/ContinueInManager.js +181 -0
  98. package/dist/main/ide/ContinueInManager.js.map +1 -0
  99. package/dist/main/ide/IDEIntegration.js +277 -0
  100. package/dist/main/ide/IDEIntegration.js.map +1 -0
  101. package/dist/main/integrations/LinearManager.js +252 -0
  102. package/dist/main/integrations/LinearManager.js.map +1 -0
  103. package/dist/main/integrations/SlackBotManager.js +247 -0
  104. package/dist/main/integrations/SlackBotManager.js.map +1 -0
  105. package/dist/main/lsp/LSPManager.js +394 -0
  106. package/dist/main/lsp/LSPManager.js.map +1 -0
  107. package/dist/main/main.js +1087 -0
  108. package/dist/main/main.js.map +1 -0
  109. package/dist/main/mcp/MCPConfigurationManager.js +281 -0
  110. package/dist/main/mcp/MCPConfigurationManager.js.map +1 -0
  111. package/dist/main/mcp/MCPManager.js +710 -0
  112. package/dist/main/mcp/MCPManager.js.map +1 -0
  113. package/dist/main/mcp/MCPRegistry.js +272 -0
  114. package/dist/main/mcp/MCPRegistry.js.map +1 -0
  115. package/dist/main/monitoring/ErrorRecoveryManager.js +268 -0
  116. package/dist/main/monitoring/ErrorRecoveryManager.js.map +1 -0
  117. package/dist/main/monitoring/ErrorTracker.js +57 -0
  118. package/dist/main/monitoring/ErrorTracker.js.map +1 -0
  119. package/dist/main/monitoring/MetricsCollector.js +155 -0
  120. package/dist/main/monitoring/MetricsCollector.js.map +1 -0
  121. package/dist/main/monitoring/TraceGradingSystem.js +148 -0
  122. package/dist/main/monitoring/TraceGradingSystem.js.map +1 -0
  123. package/dist/main/notifications/NotificationManager.js +67 -0
  124. package/dist/main/notifications/NotificationManager.js.map +1 -0
  125. package/dist/main/pair/AIPairProgramming.js +200 -0
  126. package/dist/main/pair/AIPairProgramming.js.map +1 -0
  127. package/dist/main/plugins/PluginManager.js +222 -0
  128. package/dist/main/plugins/PluginManager.js.map +1 -0
  129. package/dist/main/plugins/PluginMarketplace.js +237 -0
  130. package/dist/main/plugins/PluginMarketplace.js.map +1 -0
  131. package/dist/main/preload.js +189 -0
  132. package/dist/main/preload.js.map +1 -0
  133. package/dist/main/preview/PreviewSessionManager.js +170 -0
  134. package/dist/main/preview/PreviewSessionManager.js.map +1 -0
  135. package/dist/main/providers/AIProviderManager.js +327 -0
  136. package/dist/main/providers/AIProviderManager.js.map +1 -0
  137. package/dist/main/providers/FineTuningManager.js +276 -0
  138. package/dist/main/providers/FineTuningManager.js.map +1 -0
  139. package/dist/main/providers/FreeModelsProvider.js +1104 -0
  140. package/dist/main/providers/FreeModelsProvider.js.map +1 -0
  141. package/dist/main/realtime/RealtimeManager.js +116 -0
  142. package/dist/main/realtime/RealtimeManager.js.map +1 -0
  143. package/dist/main/remote/CloudEnvironmentManager.js +232 -0
  144. package/dist/main/remote/CloudEnvironmentManager.js.map +1 -0
  145. package/dist/main/remote/RemoteSessionManager.js +255 -0
  146. package/dist/main/remote/RemoteSessionManager.js.map +1 -0
  147. package/dist/main/search/DeepResearchManager.js +335 -0
  148. package/dist/main/search/DeepResearchManager.js.map +1 -0
  149. package/dist/main/search/WebSearchIntegration.js +147 -0
  150. package/dist/main/search/WebSearchIntegration.js.map +1 -0
  151. package/dist/main/security/AdminConsoleManager.js +223 -0
  152. package/dist/main/security/AdminConsoleManager.js.map +1 -0
  153. package/dist/main/security/AuditLogger.js +136 -0
  154. package/dist/main/security/AuditLogger.js.map +1 -0
  155. package/dist/main/security/PermissionManager.js +144 -0
  156. package/dist/main/security/PermissionManager.js.map +1 -0
  157. package/dist/main/security/SSOManager.js +173 -0
  158. package/dist/main/security/SSOManager.js.map +1 -0
  159. package/dist/main/security/SecurityManager.js +152 -0
  160. package/dist/main/security/SecurityManager.js.map +1 -0
  161. package/dist/main/skills/SkillsManager.js +223 -0
  162. package/dist/main/skills/SkillsManager.js.map +1 -0
  163. package/dist/main/ssh/SSHManager.js +65 -0
  164. package/dist/main/ssh/SSHManager.js.map +1 -0
  165. package/dist/main/streaming/StreamingManager.js +225 -0
  166. package/dist/main/streaming/StreamingManager.js.map +1 -0
  167. package/dist/main/sync/CloudSyncManager.js +422 -0
  168. package/dist/main/sync/CloudSyncManager.js.map +1 -0
  169. package/dist/main/types.js +28 -0
  170. package/dist/main/types.js.map +1 -0
  171. package/dist/main/verification/AutoVerifyManager.js +235 -0
  172. package/dist/main/verification/AutoVerifyManager.js.map +1 -0
  173. package/dist/main/vision/ComputerUseManager.js +376 -0
  174. package/dist/main/vision/ComputerUseManager.js.map +1 -0
  175. package/dist/main/vision/ImageVideoGenerationManager.js +401 -0
  176. package/dist/main/vision/ImageVideoGenerationManager.js.map +1 -0
  177. package/dist/main/vision/VisionManager.js +172 -0
  178. package/dist/main/vision/VisionManager.js.map +1 -0
  179. package/dist/renderer/assets/main-DJlZQBCA.js +304 -0
  180. package/dist/renderer/assets/main-N33ZXEr8.css +1 -0
  181. package/dist/renderer/index.html +21 -0
  182. package/dist/renderer/manifest.json +42 -0
  183. package/dist/renderer/sw.ts +109 -0
  184. package/dist/shared/types.js +35 -0
  185. package/dist/shared/types.js.map +1 -0
  186. package/docker-compose.yml +65 -0
  187. package/docs/API.md +307 -0
  188. package/docs/USER_GUIDE.md +476 -0
  189. package/examples/plugins/sample-plugin/package.json +41 -0
  190. package/examples/plugins/sample-plugin/src/index.ts +75 -0
  191. package/index.html +20 -0
  192. package/jest.config.js +39 -0
  193. package/package.json +180 -0
  194. package/packages/cli/package.json +29 -0
  195. package/packages/cli/src/commands/agents.ts +199 -0
  196. package/packages/cli/src/commands/tasks.ts +61 -0
  197. package/packages/cli/src/index.ts +91 -0
  198. package/packages/cli/src/utils/api.ts +45 -0
  199. package/packages/cli/src/utils/config.ts +61 -0
  200. package/packages/npm-installer/bin/codex-linux +126 -0
  201. package/packages/npm-installer/lib/download.js +273 -0
  202. package/packages/npm-installer/package.json +42 -0
  203. package/packages/vscode-extension/package.json +167 -0
  204. package/packages/vscode-extension/src/api.ts +68 -0
  205. package/packages/vscode-extension/src/extension.ts +161 -0
  206. package/packages/vscode-extension/src/panels/chatPanel.ts +265 -0
  207. package/packages/vscode-extension/src/panels/createAgentPanel.ts +227 -0
  208. package/packages/vscode-extension/src/providers/agentsProvider.ts +80 -0
  209. package/postcss.config.js +6 -0
  210. package/public/manifest.json +42 -0
  211. package/public/sw.ts +109 -0
  212. package/scripts/install-dev.sh +103 -0
  213. package/scripts/install.sh +275 -0
  214. package/src/main/DatabaseManager.ts +950 -0
  215. package/src/main/SettingsManager.ts +63 -0
  216. package/src/main/agents/AgentOrchestrator.ts +930 -0
  217. package/src/main/agents/AgentSDK.ts +269 -0
  218. package/src/main/agents/AgentTools.ts +380 -0
  219. package/src/main/agents/CodeIndex.ts +240 -0
  220. package/src/main/agents/EmbeddingService.ts +88 -0
  221. package/src/main/agents/NativeToolCalling.ts +245 -0
  222. package/src/main/api/APIServer.ts +316 -0
  223. package/src/main/api/RateLimiter.ts +165 -0
  224. package/src/main/api/WebSocketManager.ts +398 -0
  225. package/src/main/assistant/ContextOptimizer.ts +214 -0
  226. package/src/main/assistant/PredictedOutputManager.ts +265 -0
  227. package/src/main/assistant/PromptCacheManager.ts +280 -0
  228. package/src/main/assistant/PromptOptimizer.ts +746 -0
  229. package/src/main/assistant/SmartCodeAssistant.ts +234 -0
  230. package/src/main/auth/SessionManager.ts +415 -0
  231. package/src/main/automations/AdvancedWebhookSystem.ts +281 -0
  232. package/src/main/automations/AutomationScheduler.ts +272 -0
  233. package/src/main/automations/BatchProcessingSystem.ts +207 -0
  234. package/src/main/automations/BrowserAutomationManager.ts +203 -0
  235. package/src/main/automations/GitHubActionsManager.ts +151 -0
  236. package/src/main/automations/GitLabCIManager.ts +206 -0
  237. package/src/main/automations/PriorityQueueManager.ts +328 -0
  238. package/src/main/background/BackgroundModeManager.ts +130 -0
  239. package/src/main/backup/BackupManager.ts +287 -0
  240. package/src/main/backup/MigrationManager.ts +132 -0
  241. package/src/main/commands/SlashCommandManager.ts +407 -0
  242. package/src/main/config/ClaudeMdParser.ts +539 -0
  243. package/src/main/config/CustomizationManager.ts +493 -0
  244. package/src/main/config/LaunchConfigManager.ts +212 -0
  245. package/src/main/config/SettingsManager.ts +163 -0
  246. package/src/main/connectors/ConnectorManager.ts +175 -0
  247. package/src/main/connectors/DatabaseConnector.ts +212 -0
  248. package/src/main/cowork/CoworkManager.ts +431 -0
  249. package/src/main/evals/AgentEvalFramework.ts +665 -0
  250. package/src/main/evals/GraderManager.ts +417 -0
  251. package/src/main/git/GitWorktreeManager.ts +211 -0
  252. package/src/main/github/GitHubPRMonitor.ts +317 -0
  253. package/src/main/ide/ContinueInManager.ts +180 -0
  254. package/src/main/ide/IDEIntegration.ts +288 -0
  255. package/src/main/integrations/LinearManager.ts +327 -0
  256. package/src/main/integrations/SlackBotManager.ts +312 -0
  257. package/src/main/lsp/LSPManager.ts +445 -0
  258. package/src/main/main.ts +1221 -0
  259. package/src/main/mcp/MCPConfigurationManager.ts +281 -0
  260. package/src/main/mcp/MCPManager.ts +799 -0
  261. package/src/main/mcp/MCPRegistry.ts +273 -0
  262. package/src/main/monitoring/ErrorRecoveryManager.ts +359 -0
  263. package/src/main/monitoring/ErrorTracker.ts +60 -0
  264. package/src/main/monitoring/MetricsCollector.ts +196 -0
  265. package/src/main/monitoring/TraceGradingSystem.ts +196 -0
  266. package/src/main/notifications/NotificationManager.ts +96 -0
  267. package/src/main/pair/AIPairProgramming.ts +290 -0
  268. package/src/main/plugins/PluginManager.ts +266 -0
  269. package/src/main/plugins/PluginMarketplace.ts +318 -0
  270. package/src/main/preload.ts +215 -0
  271. package/src/main/preview/PreviewSessionManager.ts +186 -0
  272. package/src/main/providers/AIProviderManager.ts +394 -0
  273. package/src/main/providers/FineTuningManager.ts +390 -0
  274. package/src/main/providers/FreeModelsProvider.ts +1156 -0
  275. package/src/main/realtime/RealtimeManager.ts +147 -0
  276. package/src/main/remote/CloudEnvironmentManager.ts +253 -0
  277. package/src/main/remote/RemoteSessionManager.ts +323 -0
  278. package/src/main/search/DeepResearchManager.ts +458 -0
  279. package/src/main/search/WebSearchIntegration.ts +203 -0
  280. package/src/main/security/AdminConsoleManager.ts +244 -0
  281. package/src/main/security/AuditLogger.ts +143 -0
  282. package/src/main/security/PermissionManager.ts +184 -0
  283. package/src/main/security/SSOManager.ts +241 -0
  284. package/src/main/security/SecurityManager.ts +139 -0
  285. package/src/main/skills/SkillsManager.ts +218 -0
  286. package/src/main/ssh/SSHManager.ts +86 -0
  287. package/src/main/streaming/StreamingManager.ts +306 -0
  288. package/src/main/sync/CloudSyncManager.ts +532 -0
  289. package/src/main/verification/AutoVerifyManager.ts +285 -0
  290. package/src/main/vision/ComputerUseManager.ts +475 -0
  291. package/src/main/vision/ImageVideoGenerationManager.ts +526 -0
  292. package/src/main/vision/VisionManager.ts +186 -0
  293. package/src/renderer/App.tsx +314 -0
  294. package/src/renderer/components/AdvancedSettingsPanel.tsx +225 -0
  295. package/src/renderer/components/AgentPanel.tsx +760 -0
  296. package/src/renderer/components/AppPreview.tsx +220 -0
  297. package/src/renderer/components/AuditTrailPanel.tsx +148 -0
  298. package/src/renderer/components/AutomationPanel.tsx +220 -0
  299. package/src/renderer/components/ChatInterface.tsx +595 -0
  300. package/src/renderer/components/ChatTab.tsx +296 -0
  301. package/src/renderer/components/CodeEditor.tsx +257 -0
  302. package/src/renderer/components/CodeReviewPanel.tsx +256 -0
  303. package/src/renderer/components/CodeWorkspace.tsx +192 -0
  304. package/src/renderer/components/CodebaseDashboard.tsx +295 -0
  305. package/src/renderer/components/ComputerUsePanel.tsx +262 -0
  306. package/src/renderer/components/ConnectorsPanel.tsx +471 -0
  307. package/src/renderer/components/ContextMenu.tsx +155 -0
  308. package/src/renderer/components/ContextUsageDisplay.tsx +248 -0
  309. package/src/renderer/components/CoworkPanel.tsx +415 -0
  310. package/src/renderer/components/DiffViewer.tsx +452 -0
  311. package/src/renderer/components/ErrorBoundary.tsx +273 -0
  312. package/src/renderer/components/ExtendedThinkingToggle.tsx +244 -0
  313. package/src/renderer/components/FileAttachments.tsx +247 -0
  314. package/src/renderer/components/FileExplorer.tsx +242 -0
  315. package/src/renderer/components/FileExplorerPanel.tsx +302 -0
  316. package/src/renderer/components/GitPanel.tsx +154 -0
  317. package/src/renderer/components/Header.tsx +113 -0
  318. package/src/renderer/components/MCPPanel.tsx +326 -0
  319. package/src/renderer/components/MentionAutocomplete.tsx +239 -0
  320. package/src/renderer/components/PermissionPanel.tsx +159 -0
  321. package/src/renderer/components/PermissionSelector.tsx +203 -0
  322. package/src/renderer/components/PluginMarketplace.tsx +325 -0
  323. package/src/renderer/components/PromptOptimizerPanel.tsx +399 -0
  324. package/src/renderer/components/SearchPanel.tsx +173 -0
  325. package/src/renderer/components/SearchReplace.tsx +284 -0
  326. package/src/renderer/components/SessionSidebar.tsx +367 -0
  327. package/src/renderer/components/SettingsPanel.tsx +426 -0
  328. package/src/renderer/components/Sidebar.tsx +100 -0
  329. package/src/renderer/components/SkillsPanel.tsx +245 -0
  330. package/src/renderer/components/SplitPane.tsx +173 -0
  331. package/src/renderer/components/Terminal.tsx +190 -0
  332. package/src/renderer/components/VoiceCommand.tsx +129 -0
  333. package/src/renderer/components/WorktreePanel.tsx +163 -0
  334. package/src/renderer/components/ui/AriaComponents.tsx +193 -0
  335. package/src/renderer/components/ui/Button.tsx +68 -0
  336. package/src/renderer/components/ui/Card.tsx +102 -0
  337. package/src/renderer/components/ui/Input.tsx +44 -0
  338. package/src/renderer/components/ui/Skeleton.tsx +55 -0
  339. package/src/renderer/components/ui/VirtualList.tsx +196 -0
  340. package/src/renderer/i18n/I18nProvider.tsx +101 -0
  341. package/src/renderer/i18n/de.ts +161 -0
  342. package/src/renderer/i18n/en.ts +163 -0
  343. package/src/renderer/i18n/es.ts +161 -0
  344. package/src/renderer/i18n/fr.ts +161 -0
  345. package/src/renderer/i18n/index.ts +44 -0
  346. package/src/renderer/index.css +129 -0
  347. package/src/renderer/lib/accessibility.tsx +287 -0
  348. package/src/renderer/lib/hooks.ts +304 -0
  349. package/src/renderer/lib/utils.ts +6 -0
  350. package/src/renderer/main.tsx +25 -0
  351. package/src/renderer/styles/minimalist.css +539 -0
  352. package/src/renderer/sw.ts +180 -0
  353. package/src/renderer/types.d.ts +138 -0
  354. package/src/shared/types.ts +813 -0
  355. package/supabase/schema.sql +234 -0
  356. package/tailwind.config.js +78 -0
  357. package/tests/e2e/package.json +15 -0
  358. package/tests/e2e/playwright.config.ts +31 -0
  359. package/tests/e2e/specs/app.spec.ts +194 -0
  360. package/tests/setup.ts +99 -0
  361. package/tests/unit/AgentOrchestrator.test.ts +274 -0
  362. package/tests/unit/DatabaseManager.test.ts +262 -0
  363. package/tests/unit/GitWorktreeManager.test.ts +150 -0
  364. package/tests/unit/SecurityManager.test.ts +110 -0
  365. package/tsconfig.main.json +22 -0
  366. package/tsconfig.renderer.json +27 -0
  367. package/vite.config.ts +28 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SSHManager.js","sourceRoot":"","sources":["../../../src/main/ssh/SSHManager.ts"],"names":[],"mappings":";;;;;;AAAA,mCAAsC;AACtC,gEAA+B;AAc/B,MAAa,UAAW,SAAQ,qBAAY;IAClC,WAAW,GAA+B,IAAI,GAAG,EAAE,CAAC;IAE5D;QACE,KAAK,EAAE,CAAC;QACR,sBAAG,CAAC,IAAI,CAAC,4DAA4D,CAAC,CAAC;IACzE,CAAC;IAED,KAAK,CAAC,aAAa,CAAC,MAA4C;QAC9D,MAAM,UAAU,GAAkB;YAChC,GAAG,MAAM;YACT,EAAE,EAAE,OAAO,IAAI,CAAC,GAAG,EAAE,EAAE;YACvB,MAAM,EAAE,cAAc;SACvB,CAAC;QAEF,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,UAAU,CAAC,EAAE,EAAE,UAAU,CAAC,CAAC;QAChD,IAAI,CAAC,IAAI,CAAC,kBAAkB,EAAE,UAAU,CAAC,CAAC;QAC1C,sBAAG,CAAC,IAAI,CAAC,yBAAyB,UAAU,CAAC,IAAI,KAAK,UAAU,CAAC,IAAI,GAAG,CAAC,CAAC;QAE1E,OAAO,UAAU,CAAC;IACpB,CAAC;IAED,KAAK,CAAC,gBAAgB,CAAC,YAAoB;QACzC,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC;QACtC,IAAI,CAAC,IAAI,CAAC,oBAAoB,EAAE,EAAE,YAAY,EAAE,CAAC,CAAC;QAClD,sBAAG,CAAC,IAAI,CAAC,2BAA2B,YAAY,EAAE,CAAC,CAAC;IACtD,CAAC;IAED,KAAK,CAAC,OAAO,CAAC,aAAqB;QACjC,MAAM,IAAI,KAAK,CAAC,kDAAkD,CAAC,CAAC;IACtE,CAAC;IAED,KAAK,CAAC,UAAU,CAAC,aAAqB;QACpC,QAAQ;IACV,CAAC;IAED,KAAK,CAAC,cAAc,CAAC,aAAqB,EAAE,QAAgB;QAC1D,MAAM,IAAI,KAAK,CAAC,kDAAkD,CAAC,CAAC;IACtE,CAAC;IAED,KAAK,CAAC,QAAQ,CAAC,aAAqB,EAAE,WAAmB;QACvD,MAAM,IAAI,KAAK,CAAC,kDAAkD,CAAC,CAAC;IACtE,CAAC;IAED,KAAK,CAAC,SAAS,CAAC,aAAqB,EAAE,WAAmB,EAAE,QAAgB;QAC1E,MAAM,IAAI,KAAK,CAAC,kDAAkD,CAAC,CAAC;IACtE,CAAC;IAED,KAAK,CAAC,aAAa,CAAC,aAAqB,EAAE,WAAmB;QAC5D,MAAM,IAAI,KAAK,CAAC,kDAAkD,CAAC,CAAC;IACtE,CAAC;IAED,cAAc;QACZ,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,CAAC,CAAC;IAC/C,CAAC;IAED,aAAa,CAAC,YAAoB;QAChC,OAAO,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC;IAC5C,CAAC;IAED,WAAW,CAAC,aAAqB;QAC/B,OAAO,KAAK,CAAC;IACf,CAAC;IAED,OAAO;QACL,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,CAAC;QACzB,IAAI,CAAC,kBAAkB,EAAE,CAAC;IAC5B,CAAC;CACF;AApED,gCAoEC;AAED,kBAAe,UAAU,CAAC"}
@@ -0,0 +1,225 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.StreamingManager = void 0;
7
+ const events_1 = require("events");
8
+ const uuid_1 = require("uuid");
9
+ const electron_log_1 = __importDefault(require("electron-log"));
10
+ const WebSocketManager_1 = require("../api/WebSocketManager");
11
+ class StreamingManager extends events_1.EventEmitter {
12
+ wsManager = null;
13
+ subscriptions = new Map();
14
+ activeStreams = new Map();
15
+ config;
16
+ constructor(config) {
17
+ super();
18
+ this.config = {
19
+ enableWebSocket: config?.enableWebSocket ?? true,
20
+ port: config?.port || 3002,
21
+ enableIPC: config?.enableIPC ?? true,
22
+ };
23
+ }
24
+ configure(config) {
25
+ this.config = { ...this.config, ...config };
26
+ electron_log_1.default.info('StreamingManager configured', this.config);
27
+ }
28
+ getConfig() {
29
+ return { ...this.config };
30
+ }
31
+ initialize(httpServer) {
32
+ if (this.config.enableWebSocket) {
33
+ this.wsManager = new WebSocketManager_1.WebSocketManager({ port: this.config.port });
34
+ this.wsManager.initialize(httpServer);
35
+ this.setupWebSocketHandlers();
36
+ electron_log_1.default.info('StreamingManager WebSocket initialized', { port: this.config.port });
37
+ }
38
+ }
39
+ setupWebSocketHandlers() {
40
+ if (!this.wsManager)
41
+ return;
42
+ this.wsManager.on('client:connected', (data) => {
43
+ this.emit('client:connected', data);
44
+ electron_log_1.default.debug(`Streaming client connected: ${data.clientId}`);
45
+ });
46
+ this.wsManager.on('client:disconnected', (data) => {
47
+ this.cleanupClientSubscriptions(data.clientId);
48
+ this.emit('client:disconnected', data);
49
+ });
50
+ this.wsManager.on('message:received', (data) => {
51
+ this.handleClientMessage(data.clientId, data.data);
52
+ });
53
+ }
54
+ handleClientMessage(clientId, data) {
55
+ const message = data;
56
+ if (message.action === 'subscribe') {
57
+ const payload = message.payload;
58
+ this.createSubscription(clientId, payload.events, payload.filters);
59
+ }
60
+ else if (message.action === 'unsubscribe') {
61
+ const subscriptionId = message.payload;
62
+ this.removeSubscription(subscriptionId);
63
+ }
64
+ }
65
+ createSubscription(subscriberId, events, filters) {
66
+ const subscription = {
67
+ id: (0, uuid_1.v4)(),
68
+ subscriberId,
69
+ events,
70
+ filters: filters,
71
+ createdAt: new Date(),
72
+ };
73
+ this.subscriptions.set(subscription.id, subscription);
74
+ if (this.wsManager) {
75
+ this.wsManager.sendToClient(subscriberId, 'subscribed', {
76
+ subscriptionId: subscription.id,
77
+ events
78
+ });
79
+ }
80
+ this.emit('subscription:created', subscription);
81
+ return subscription;
82
+ }
83
+ removeSubscription(subscriptionId) {
84
+ const deleted = this.subscriptions.delete(subscriptionId);
85
+ if (deleted) {
86
+ this.emit('subscription:removed', { subscriptionId });
87
+ }
88
+ return deleted;
89
+ }
90
+ cleanupClientSubscriptions(clientId) {
91
+ const toRemove = [];
92
+ this.subscriptions.forEach((sub, id) => {
93
+ if (sub.subscriberId === clientId) {
94
+ toRemove.push(id);
95
+ }
96
+ });
97
+ toRemove.forEach((id) => this.subscriptions.delete(id));
98
+ }
99
+ shouldSendEvent(eventType, sourceId) {
100
+ const matching = [];
101
+ this.subscriptions.forEach((sub) => {
102
+ if (sub.events.includes(eventType)) {
103
+ if (sub.filters) {
104
+ if (sub.filters.agentId && sub.filters.agentId !== sourceId)
105
+ return;
106
+ if (sub.filters.taskId && sub.filters.taskId !== sourceId)
107
+ return;
108
+ }
109
+ matching.push(sub);
110
+ }
111
+ });
112
+ return matching;
113
+ }
114
+ emitEvent(type, sourceId, data) {
115
+ const event = {
116
+ id: (0, uuid_1.v4)(),
117
+ type,
118
+ sourceId,
119
+ data,
120
+ timestamp: new Date(),
121
+ };
122
+ if (this.wsManager) {
123
+ const subscribers = this.shouldSendEvent(type, sourceId);
124
+ subscribers.forEach((sub) => {
125
+ this.wsManager?.sendToClient(sub.subscriberId, type, event);
126
+ });
127
+ }
128
+ this.emit(type, event);
129
+ }
130
+ streamAgentMessage(agentId, chunk) {
131
+ this.emitEvent('agent:chunk', agentId, { chunk, agentId });
132
+ }
133
+ streamAgentComplete(agentId, message) {
134
+ this.emitEvent('agent:complete', agentId, { message, agentId });
135
+ }
136
+ streamAgentError(agentId, error) {
137
+ this.emitEvent('agent:error', agentId, { error, agentId });
138
+ }
139
+ streamTaskProgress(taskId, progress) {
140
+ this.emitEvent('task:progress', taskId, progress);
141
+ }
142
+ streamTaskComplete(taskId, result) {
143
+ this.emitEvent('task:complete', taskId, { result, taskId });
144
+ }
145
+ streamTaskError(taskId, error) {
146
+ this.emitEvent('task:error', taskId, { error, taskId });
147
+ }
148
+ broadcastSystemStatus(status) {
149
+ this.emitEvent('system:status', 'system', status);
150
+ }
151
+ streamFileChanged(filePath, change) {
152
+ this.emitEvent('file:changed', filePath, { change, filePath });
153
+ }
154
+ streamTerminalOutput(terminalId, output) {
155
+ this.emitEvent('terminal:output', terminalId, { output, terminalId });
156
+ }
157
+ startStream(streamId) {
158
+ this.activeStreams.set(streamId, {
159
+ startTime: new Date(),
160
+ eventCount: 0,
161
+ });
162
+ electron_log_1.default.debug(`Stream started: ${streamId}`);
163
+ }
164
+ endStream(streamId) {
165
+ const stream = this.activeStreams.get(streamId);
166
+ if (stream) {
167
+ const duration = Date.now() - stream.startTime.getTime();
168
+ electron_log_1.default.debug(`Stream ended: ${streamId}`, {
169
+ duration,
170
+ events: stream.eventCount
171
+ });
172
+ this.activeStreams.delete(streamId);
173
+ }
174
+ }
175
+ subscribeToAgent(subscriberId, agentId) {
176
+ return this.createSubscription(subscriberId, [
177
+ 'agent:message',
178
+ 'agent:chunk',
179
+ 'agent:complete',
180
+ 'agent:error',
181
+ ], { agentId });
182
+ }
183
+ subscribeToTask(subscriberId, taskId) {
184
+ return this.createSubscription(subscriberId, [
185
+ 'task:progress',
186
+ 'task:complete',
187
+ 'task:error',
188
+ ], { taskId });
189
+ }
190
+ getSubscriptions(subscriberId) {
191
+ if (subscriberId) {
192
+ return Array.from(this.subscriptions.values())
193
+ .filter((s) => s.subscriberId === subscriberId);
194
+ }
195
+ return Array.from(this.subscriptions.values());
196
+ }
197
+ getActiveStreams() {
198
+ return new Map(this.activeStreams);
199
+ }
200
+ getStats() {
201
+ return {
202
+ activeStreams: this.activeStreams.size,
203
+ totalSubscriptions: this.subscriptions.size,
204
+ wsClients: this.wsManager?.getClientCount() || 0,
205
+ };
206
+ }
207
+ shutdown() {
208
+ if (this.wsManager) {
209
+ this.wsManager.shutdown();
210
+ this.wsManager = null;
211
+ }
212
+ this.subscriptions.clear();
213
+ this.activeStreams.clear();
214
+ this.emit('shutdown');
215
+ electron_log_1.default.info('StreamingManager shutdown');
216
+ }
217
+ cleanup() {
218
+ this.shutdown();
219
+ this.removeAllListeners();
220
+ electron_log_1.default.info('StreamingManager cleaned up');
221
+ }
222
+ }
223
+ exports.StreamingManager = StreamingManager;
224
+ exports.default = StreamingManager;
225
+ //# sourceMappingURL=StreamingManager.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"StreamingManager.js","sourceRoot":"","sources":["../../../src/main/streaming/StreamingManager.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,422 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.CloudSyncManager = void 0;
7
+ const events_1 = require("events");
8
+ const electron_log_1 = __importDefault(require("electron-log"));
9
+ const supabase_js_1 = require("@supabase/supabase-js");
10
+ class CloudSyncManager extends events_1.EventEmitter {
11
+ supabase = null;
12
+ config;
13
+ syncInterval = null;
14
+ pendingChanges = new Map();
15
+ lastSyncTime = 0;
16
+ isSyncing = false;
17
+ realtimeSubscription = null;
18
+ constructor(config) {
19
+ super();
20
+ this.config = config;
21
+ if (config.enabled) {
22
+ this.initializeSupabase();
23
+ }
24
+ }
25
+ initializeSupabase() {
26
+ try {
27
+ this.supabase = (0, supabase_js_1.createClient)(this.config.supabaseUrl, this.config.supabaseKey);
28
+ electron_log_1.default.info('Cloud Sync: Supabase client initialized');
29
+ }
30
+ catch (error) {
31
+ electron_log_1.default.error('Cloud Sync: Failed to initialize Supabase:', error);
32
+ this.emit('error', { type: 'init', error });
33
+ }
34
+ }
35
+ async enable() {
36
+ if (!this.supabase) {
37
+ this.initializeSupabase();
38
+ }
39
+ this.config.enabled = true;
40
+ await this.startSync();
41
+ this.setupRealtimeSubscription();
42
+ electron_log_1.default.info('Cloud Sync: Enabled');
43
+ this.emit('enabled');
44
+ }
45
+ disable() {
46
+ this.config.enabled = false;
47
+ this.stopSync();
48
+ this.removeRealtimeSubscription();
49
+ electron_log_1.default.info('Cloud Sync: Disabled');
50
+ this.emit('disabled');
51
+ }
52
+ setupRealtimeSubscription() {
53
+ if (!this.supabase)
54
+ return;
55
+ this.realtimeSubscription = this.supabase
56
+ .channel('threads_changes')
57
+ .on('postgres_changes', {
58
+ event: '*',
59
+ schema: 'public',
60
+ table: 'threads',
61
+ filter: `user_id=eq.${this.config.userId}`,
62
+ }, (payload) => {
63
+ this.handleRealtimeChange(payload);
64
+ })
65
+ .subscribe();
66
+ electron_log_1.default.info('Cloud Sync: Realtime subscription active');
67
+ }
68
+ removeRealtimeSubscription() {
69
+ if (this.realtimeSubscription) {
70
+ this.realtimeSubscription.unsubscribe();
71
+ this.realtimeSubscription = null;
72
+ }
73
+ }
74
+ async handleRealtimeChange(payload) {
75
+ const { eventType, new: newRecord, old: oldRecord } = payload;
76
+ // Ignore changes from this device
77
+ if (newRecord?.device_id === this.config.deviceId)
78
+ return;
79
+ switch (eventType) {
80
+ case 'INSERT':
81
+ case 'UPDATE':
82
+ if (newRecord) {
83
+ const remoteThread = this.deserializeThread(newRecord);
84
+ await this.handleRemoteChange(remoteThread);
85
+ }
86
+ break;
87
+ case 'DELETE':
88
+ if (oldRecord?.id) {
89
+ this.emit('thread:deleted', { threadId: oldRecord.id });
90
+ }
91
+ break;
92
+ }
93
+ }
94
+ async handleRemoteChange(remoteThread) {
95
+ const localThread = await this.getLocalThread(remoteThread.id);
96
+ if (!localThread) {
97
+ // New thread from another device
98
+ await this.saveLocalThread(remoteThread);
99
+ this.emit('thread:remote-created', { thread: remoteThread });
100
+ }
101
+ else if (remoteThread.version > localThread.version) {
102
+ // Remote has newer version
103
+ if (this.pendingChanges.has(remoteThread.id)) {
104
+ // Conflict detected
105
+ await this.resolveConflict(localThread, remoteThread);
106
+ }
107
+ else {
108
+ // No local changes, accept remote
109
+ await this.saveLocalThread(remoteThread);
110
+ this.emit('thread:updated', { thread: remoteThread, source: 'remote' });
111
+ }
112
+ }
113
+ }
114
+ async syncThread(agent) {
115
+ if (!this.config.enabled || !this.supabase)
116
+ return;
117
+ const thread = {
118
+ id: agent.id,
119
+ agentId: agent.id,
120
+ userId: this.config.userId,
121
+ deviceId: this.config.deviceId,
122
+ projectPath: agent.projectPath,
123
+ messages: agent.messages,
124
+ status: agent.status,
125
+ lastModified: Date.now(),
126
+ version: (agent.version || 0) + 1,
127
+ isDeleted: false,
128
+ };
129
+ this.pendingChanges.set(agent.id, thread);
130
+ // Immediate sync for important changes
131
+ await this.performSync();
132
+ }
133
+ async startSync() {
134
+ if (this.syncInterval)
135
+ return;
136
+ // Initial sync
137
+ await this.performSync();
138
+ // Periodic sync
139
+ this.syncInterval = setInterval(() => {
140
+ this.performSync();
141
+ }, this.config.syncInterval);
142
+ electron_log_1.default.info('Cloud Sync: Started with interval', this.config.syncInterval);
143
+ }
144
+ stopSync() {
145
+ if (this.syncInterval) {
146
+ clearInterval(this.syncInterval);
147
+ this.syncInterval = null;
148
+ }
149
+ electron_log_1.default.info('Cloud Sync: Stopped');
150
+ }
151
+ async performSync() {
152
+ if (this.isSyncing || !this.supabase || !this.config.enabled)
153
+ return;
154
+ this.isSyncing = true;
155
+ this.emit('sync:started');
156
+ try {
157
+ // Upload pending changes
158
+ for (const [threadId, thread] of this.pendingChanges) {
159
+ await this.uploadThread(thread);
160
+ this.pendingChanges.delete(threadId);
161
+ }
162
+ // Download remote changes
163
+ const remoteThreads = await this.downloadThreads();
164
+ for (const remoteThread of remoteThreads) {
165
+ if (remoteThread.deviceId !== this.config.deviceId) {
166
+ await this.handleRemoteChange(remoteThread);
167
+ }
168
+ }
169
+ this.lastSyncTime = Date.now();
170
+ this.emit('sync:completed', { timestamp: this.lastSyncTime });
171
+ }
172
+ catch (error) {
173
+ electron_log_1.default.error('Cloud Sync: Sync failed:', error);
174
+ this.emit('sync:error', { error });
175
+ }
176
+ finally {
177
+ this.isSyncing = false;
178
+ }
179
+ }
180
+ async uploadThread(thread) {
181
+ if (!this.supabase)
182
+ return;
183
+ const record = this.serializeThread(thread);
184
+ const { error } = await this.supabase
185
+ .from('threads')
186
+ .upsert(record, {
187
+ onConflict: 'id',
188
+ ignoreDuplicates: false,
189
+ });
190
+ if (error) {
191
+ throw new Error(`Failed to upload thread: ${error.message}`);
192
+ }
193
+ electron_log_1.default.debug('Cloud Sync: Uploaded thread', thread.id);
194
+ }
195
+ async downloadThreads() {
196
+ if (!this.supabase)
197
+ return [];
198
+ const { data, error } = await this.supabase
199
+ .from('threads')
200
+ .select('*')
201
+ .eq('user_id', this.config.userId)
202
+ .eq('is_deleted', false)
203
+ .gt('last_modified', this.lastSyncTime);
204
+ if (error) {
205
+ throw new Error(`Failed to download threads: ${error.message}`);
206
+ }
207
+ return (data || []).map(record => this.deserializeThread(record));
208
+ }
209
+ async resolveConflict(localVersion, remoteVersion) {
210
+ const conflict = {
211
+ threadId: localVersion.id,
212
+ localVersion,
213
+ remoteVersion,
214
+ resolution: 'merge', // Default to merge
215
+ };
216
+ // Attempt automatic merge
217
+ const mergedThread = this.mergeThreads(localVersion, remoteVersion);
218
+ if (mergedThread) {
219
+ // Save merged version
220
+ mergedThread.version = Math.max(localVersion.version, remoteVersion.version) + 1;
221
+ await this.saveLocalThread(mergedThread);
222
+ this.pendingChanges.set(mergedThread.id, mergedThread);
223
+ conflict.resolution = 'merge';
224
+ this.emit('conflict:resolved', { conflict, mergedThread });
225
+ }
226
+ else {
227
+ // Manual resolution required
228
+ this.emit('conflict:detected', { conflict });
229
+ }
230
+ }
231
+ mergeThreads(local, remote) {
232
+ // Simple merge: combine unique messages
233
+ const messageMap = new Map();
234
+ [...local.messages, ...remote.messages].forEach(msg => {
235
+ if (!messageMap.has(msg.id)) {
236
+ messageMap.set(msg.id, msg);
237
+ }
238
+ });
239
+ const mergedMessages = Array.from(messageMap.values()).sort((a, b) => new Date(a.timestamp).getTime() - new Date(b.timestamp).getTime());
240
+ return {
241
+ ...local,
242
+ messages: mergedMessages,
243
+ lastModified: Date.now(),
244
+ version: Math.max(local.version, remote.version) + 1,
245
+ };
246
+ }
247
+ async resolveConflictManually(threadId, resolution) {
248
+ const localThread = await this.getLocalThread(threadId);
249
+ const remoteThread = await this.getRemoteThread(threadId);
250
+ if (!localThread || !remoteThread) {
251
+ throw new Error('Thread not found');
252
+ }
253
+ let resolvedThread;
254
+ switch (resolution) {
255
+ case 'local':
256
+ resolvedThread = localThread;
257
+ resolvedThread.version = remoteThread.version + 1;
258
+ break;
259
+ case 'remote':
260
+ resolvedThread = remoteThread;
261
+ break;
262
+ case 'merge':
263
+ const merged = this.mergeThreads(localThread, remoteThread);
264
+ if (!merged)
265
+ throw new Error('Merge failed');
266
+ resolvedThread = merged;
267
+ break;
268
+ }
269
+ await this.saveLocalThread(resolvedThread);
270
+ this.pendingChanges.set(resolvedThread.id, resolvedThread);
271
+ await this.performSync();
272
+ this.emit('conflict:resolved', {
273
+ threadId,
274
+ resolution,
275
+ thread: resolvedThread,
276
+ });
277
+ }
278
+ serializeThread(thread) {
279
+ return {
280
+ id: thread.id,
281
+ agent_id: thread.agentId,
282
+ user_id: thread.userId,
283
+ device_id: thread.deviceId,
284
+ project_path: thread.projectPath,
285
+ messages: JSON.stringify(thread.messages),
286
+ status: thread.status,
287
+ last_modified: thread.lastModified,
288
+ version: thread.version,
289
+ is_deleted: thread.isDeleted,
290
+ };
291
+ }
292
+ deserializeThread(record) {
293
+ return {
294
+ id: record.id,
295
+ agentId: record.agent_id,
296
+ userId: record.user_id,
297
+ deviceId: record.device_id,
298
+ projectPath: record.project_path,
299
+ messages: JSON.parse(record.messages || '[]'),
300
+ status: record.status,
301
+ lastModified: record.last_modified,
302
+ version: record.version,
303
+ isDeleted: record.is_deleted,
304
+ };
305
+ }
306
+ async getLocalThread(threadId) {
307
+ // This would integrate with DatabaseManager
308
+ this.emit('thread:request-local', { threadId });
309
+ return null;
310
+ }
311
+ async saveLocalThread(thread) {
312
+ // This would integrate with DatabaseManager
313
+ this.emit('thread:save-local', { thread });
314
+ }
315
+ async getRemoteThread(threadId) {
316
+ if (!this.supabase)
317
+ return null;
318
+ const { data, error } = await this.supabase
319
+ .from('threads')
320
+ .select('*')
321
+ .eq('id', threadId)
322
+ .single();
323
+ if (error || !data)
324
+ return null;
325
+ return this.deserializeThread(data);
326
+ }
327
+ async getAllSyncedThreads() {
328
+ return this.downloadThreads();
329
+ }
330
+ async deleteThread(threadId) {
331
+ if (!this.supabase)
332
+ return;
333
+ const { error } = await this.supabase
334
+ .from('threads')
335
+ .update({ is_deleted: true, last_modified: Date.now() })
336
+ .eq('id', threadId);
337
+ if (error) {
338
+ throw new Error(`Failed to delete thread: ${error.message}`);
339
+ }
340
+ this.emit('thread:deleted', { threadId });
341
+ }
342
+ getSyncStatus() {
343
+ return {
344
+ enabled: this.config.enabled,
345
+ isSyncing: this.isSyncing,
346
+ lastSyncTime: this.lastSyncTime,
347
+ pendingChanges: this.pendingChanges.size,
348
+ deviceId: this.config.deviceId,
349
+ };
350
+ }
351
+ async forceSync() {
352
+ if (!this.config.enabled) {
353
+ throw new Error('Cloud sync is disabled');
354
+ }
355
+ await this.performSync();
356
+ }
357
+ // Teleportation - Transfer session context to another device
358
+ async teleportToDevice(targetDeviceId, projectPath) {
359
+ if (!this.supabase) {
360
+ return { success: false, message: 'Cloud sync not configured' };
361
+ }
362
+ try {
363
+ // Get current thread/agent state
364
+ const currentThread = await this.getLocalThread(projectPath);
365
+ if (!currentThread) {
366
+ return { success: false, message: 'No active session to teleport' };
367
+ }
368
+ // Create teleport record
369
+ const { error } = await this.supabase
370
+ .from('teleport_requests')
371
+ .insert({
372
+ source_device_id: this.config.deviceId,
373
+ target_device_id: targetDeviceId,
374
+ project_path: projectPath,
375
+ thread_data: JSON.stringify(currentThread),
376
+ status: 'pending',
377
+ created_at: new Date().toISOString(),
378
+ });
379
+ if (error)
380
+ throw error;
381
+ electron_log_1.default.info(`Teleport initiated: ${projectPath} to ${targetDeviceId}`);
382
+ return { success: true, message: 'Teleport request sent' };
383
+ }
384
+ catch (error) {
385
+ electron_log_1.default.error('Teleport failed:', error);
386
+ return { success: false, message: error.message };
387
+ }
388
+ }
389
+ // Get available devices for teleportation
390
+ async getAvailableDevices() {
391
+ if (!this.supabase)
392
+ return [];
393
+ try {
394
+ const { data, error } = await this.supabase
395
+ .from('devices')
396
+ .select('device_id, last_active')
397
+ .neq('device_id', this.config.deviceId)
398
+ .eq('user_id', this.config.userId)
399
+ .eq('online', true);
400
+ if (error)
401
+ throw error;
402
+ return (data || []).map(d => ({
403
+ deviceId: d.device_id,
404
+ lastActive: new Date(d.last_active),
405
+ }));
406
+ }
407
+ catch (error) {
408
+ electron_log_1.default.error('Failed to get devices:', error);
409
+ return [];
410
+ }
411
+ }
412
+ cleanup() {
413
+ this.stopSync();
414
+ this.removeRealtimeSubscription();
415
+ this.pendingChanges.clear();
416
+ this.removeAllListeners();
417
+ electron_log_1.default.info('Cloud Sync: Cleaned up');
418
+ }
419
+ }
420
+ exports.CloudSyncManager = CloudSyncManager;
421
+ exports.default = CloudSyncManager;
422
+ //# sourceMappingURL=CloudSyncManager.js.map