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,813 @@
1
+ export enum PermissionMode {
2
+ ASK = 'ask',
3
+ AUTO_ACCEPT_EDITS = 'auto_accept_edits',
4
+ PLAN = 'plan',
5
+ BYPASS = 'bypass'
6
+ }
7
+
8
+ export interface ExtendedThinkingConfig {
9
+ enabled: boolean;
10
+ maxTokens: number;
11
+ budgetTokens?: number;
12
+ reasoningEffort?: 'low' | 'medium' | 'high';
13
+ }
14
+
15
+ export interface AgentMessage {
16
+ id: string;
17
+ role: 'user' | 'assistant' | 'system' | 'tool';
18
+ content: string;
19
+ timestamp: Date;
20
+ metadata?: {
21
+ reasoning?: string;
22
+ extendedThinking?: boolean;
23
+ reasoningEffort?: 'low' | 'medium' | 'high';
24
+ tokensUsed?: number;
25
+ [key: string]: any;
26
+ };
27
+ }
28
+
29
+ export interface PermissionRequest {
30
+ id: string;
31
+ agentId: string;
32
+ type: 'edit' | 'command' | 'tool';
33
+ action: string;
34
+ details: Record<string, any>;
35
+ status: 'pending' | 'approved' | 'rejected';
36
+ createdAt: Date;
37
+ resolvedAt?: Date;
38
+ }
39
+
40
+ export interface Agent {
41
+ id: string;
42
+ name: string;
43
+ status: AgentStatus;
44
+ projectPath: string;
45
+ worktreeName: string;
46
+ worktreePath?: string;
47
+ providerId: string;
48
+ model: string;
49
+ skills: string[];
50
+ permissionMode: PermissionMode;
51
+ createdAt: Date;
52
+ updatedAt: Date;
53
+ lastActiveAt: Date | null;
54
+ messages: AgentMessage[];
55
+ tasks: AgentTask[];
56
+ metadata: Record<string, any>;
57
+ version?: number;
58
+ }
59
+
60
+ export enum AgentStatus {
61
+ IDLE = 'idle',
62
+ RUNNING = 'running',
63
+ PAUSED = 'paused',
64
+ ERROR = 'error',
65
+ COMPLETED = 'completed'
66
+ }
67
+
68
+ export interface AgentMessage {
69
+ id: string;
70
+ role: 'user' | 'assistant' | 'system' | 'tool';
71
+ content: string;
72
+ timestamp: Date;
73
+ metadata?: {
74
+ reasoning?: string;
75
+ extendedThinking?: boolean;
76
+ reasoningEffort?: 'low' | 'medium' | 'high';
77
+ tokensUsed?: number;
78
+ [key: string]: any;
79
+ };
80
+ }
81
+
82
+ export interface AgentTask {
83
+ id: string;
84
+ description: string;
85
+ status: TaskStatus;
86
+ progress: number;
87
+ startedAt: Date;
88
+ completedAt?: Date;
89
+ result?: string;
90
+ error?: string;
91
+ }
92
+
93
+ export enum TaskStatus {
94
+ PENDING = 'pending',
95
+ RUNNING = 'running',
96
+ PAUSED = 'paused',
97
+ COMPLETED = 'completed',
98
+ FAILED = 'failed',
99
+ CANCELLED = 'cancelled'
100
+ }
101
+
102
+ export interface Worktree {
103
+ name: string;
104
+ path: string;
105
+ commit: string;
106
+ branch: string;
107
+ isMain: boolean;
108
+ agents: string[];
109
+ createdAt: Date;
110
+ }
111
+
112
+ export interface Skill {
113
+ id: string;
114
+ name: string;
115
+ description: string;
116
+ version: string;
117
+ author: string;
118
+ tags: string[];
119
+ files: SkillFile[];
120
+ config: SkillConfig;
121
+ createdAt: Date;
122
+ updatedAt: Date;
123
+ }
124
+
125
+ export interface SkillFile {
126
+ path: string;
127
+ content: string;
128
+ type: 'instruction' | 'template' | 'tool' | 'config';
129
+ }
130
+
131
+ export interface SkillConfig {
132
+ entryPoint: string;
133
+ parameters: SkillParameter[];
134
+ dependencies: string[];
135
+ permissions: string[];
136
+ }
137
+
138
+ export interface SkillParameter {
139
+ name: string;
140
+ type: 'string' | 'number' | 'boolean' | 'array' | 'object';
141
+ required: boolean;
142
+ default?: any;
143
+ description: string;
144
+ }
145
+
146
+ export interface Automation {
147
+ id: string;
148
+ name: string;
149
+ description: string;
150
+ enabled: boolean;
151
+ trigger: AutomationTrigger;
152
+ actions: AutomationAction[];
153
+ createdAt: Date;
154
+ updatedAt: Date;
155
+ lastRunAt?: Date;
156
+ runCount: number;
157
+ }
158
+
159
+ export interface AutomationTrigger {
160
+ type: 'schedule' | 'event' | 'webhook' | 'manual';
161
+ config: Record<string, any>;
162
+ }
163
+
164
+ export interface AutomationAction {
165
+ type: 'createAgent' | 'sendMessage' | 'executeCommand' | 'runSkill' | 'notify';
166
+ config: Record<string, any>;
167
+ }
168
+
169
+ export interface AIProvider {
170
+ id: string;
171
+ name: string;
172
+ description: string;
173
+ enabled: boolean;
174
+ config: ProviderConfig;
175
+ models: ProviderModel[];
176
+ requiresApiKey?: boolean;
177
+ isFree?: boolean;
178
+ }
179
+
180
+ export interface ProviderConfig {
181
+ apiKey?: string;
182
+ baseUrl?: string;
183
+ organizationId?: string;
184
+ timeout?: number;
185
+ maxRetries?: number;
186
+ customHeaders?: Record<string, string>;
187
+ }
188
+
189
+ export interface ProviderModel {
190
+ id: string;
191
+ name: string;
192
+ description: string;
193
+ maxTokens: number;
194
+ contextWindow: number;
195
+ supportsTools: boolean;
196
+ supportsVision: boolean;
197
+ pricing: {
198
+ input: number;
199
+ output: number;
200
+ };
201
+ isFree?: boolean;
202
+ backend?: string;
203
+ }
204
+
205
+ export interface Settings {
206
+ theme: 'light' | 'dark' | 'system';
207
+ fontSize: number;
208
+ fontFamily: string;
209
+ autoSave: boolean;
210
+ autoSaveInterval: number;
211
+ defaultProvider: string;
212
+ defaultModel: string;
213
+ maxParallelAgents: number;
214
+ showNotifications: boolean;
215
+ confirmDestructiveActions: boolean;
216
+ gitAuthorName: string;
217
+ gitAuthorEmail: string;
218
+ customSkillsPath: string;
219
+ shortcuts: Record<string, string>;
220
+ sentryDsn?: string;
221
+ githubToken?: string;
222
+ extendedThinking?: ExtendedThinkingConfig;
223
+ allowBypassMode?: boolean;
224
+ }
225
+
226
+ export interface CodeChange {
227
+ id: string;
228
+ filePath: string;
229
+ originalContent: string;
230
+ newContent: string;
231
+ diff: string;
232
+ agentId: string;
233
+ taskId: string;
234
+ status: ChangeStatus;
235
+ createdAt: Date;
236
+ reviewedAt?: Date;
237
+ reviewedBy?: string;
238
+ comment?: string;
239
+ }
240
+
241
+ export enum ChangeStatus {
242
+ PENDING = 'pending',
243
+ APPROVED = 'approved',
244
+ REJECTED = 'rejected',
245
+ APPLIED = 'applied'
246
+ }
247
+
248
+ export interface Checkpoint {
249
+ id: string;
250
+ agentId: string;
251
+ changeId: string;
252
+ filePath: string;
253
+ content: string;
254
+ createdAt: Date;
255
+ restoredAt?: Date;
256
+ }
257
+
258
+ export interface Project {
259
+ id: string;
260
+ name: string;
261
+ path: string;
262
+ gitRemote?: string;
263
+ agents: string[];
264
+ worktrees: Worktree[];
265
+ createdAt: Date;
266
+ updatedAt: Date;
267
+ }
268
+
269
+ // Computer Using Agent (CUA) Types
270
+ export interface UIElement {
271
+ id?: string;
272
+ type: 'button' | 'input' | 'link' | 'text' | 'image' | 'container' | 'other';
273
+ text?: string;
274
+ coordinates: {
275
+ x: number;
276
+ y: number;
277
+ width: number;
278
+ height: number;
279
+ };
280
+ confidence: number;
281
+ attributes?: Record<string, string>;
282
+ }
283
+
284
+ export interface ComputerAction {
285
+ type: 'click' | 'doubleClick' | 'rightClick' | 'type' | 'scroll' | 'drag' | 'wait' | 'key' | 'screenshot';
286
+ target?: {
287
+ element?: UIElement;
288
+ coordinates?: { x: number; y: number };
289
+ selector?: string;
290
+ };
291
+ value?: string;
292
+ delay?: number;
293
+ metadata?: Record<string, any>;
294
+ }
295
+
296
+ export interface ComputerTask {
297
+ id: string;
298
+ description: string;
299
+ goal: string;
300
+ maxSteps: number;
301
+ currentStep: number;
302
+ status: 'pending' | 'running' | 'completed' | 'failed' | 'cancelled';
303
+ actions: ComputerAction[];
304
+ results: string[];
305
+ error?: string;
306
+ }
307
+
308
+ export interface ComputerUseSession {
309
+ id: string;
310
+ taskId: string;
311
+ startTime: Date;
312
+ endTime?: Date;
313
+ screenshots: string[];
314
+ actions: ComputerAction[];
315
+ currentUrl?: string;
316
+ currentApp?: string;
317
+ }
318
+
319
+ // CLAUDE.md Configuration Types
320
+ export interface ClaudeMdConfig {
321
+ version: string;
322
+ project: {
323
+ name: string;
324
+ description?: string;
325
+ language?: string;
326
+ framework?: string;
327
+ };
328
+ codingStandards: {
329
+ style?: string;
330
+ linter?: string;
331
+ formatter?: string;
332
+ maxLineLength?: number;
333
+ indentSize?: number;
334
+ useTabs?: boolean;
335
+ };
336
+ architecture: {
337
+ patterns?: string[];
338
+ conventions?: string[];
339
+ folderStructure?: string;
340
+ designPrinciples?: string[];
341
+ };
342
+ libraries: {
343
+ preferred?: string[];
344
+ avoid?: string[];
345
+ testing?: string[];
346
+ utilities?: string[];
347
+ };
348
+ reviewChecklist: {
349
+ required?: string[];
350
+ recommended?: string[];
351
+ security?: string[];
352
+ performance?: string[];
353
+ };
354
+ tools: {
355
+ build?: string;
356
+ test?: string;
357
+ lint?: string;
358
+ typecheck?: string;
359
+ };
360
+ customPrompts: {
361
+ systemPrompt?: string;
362
+ beforeAction?: string;
363
+ afterAction?: string;
364
+ commitMessage?: string;
365
+ prDescription?: string;
366
+ };
367
+ agents?: {
368
+ defaultModel?: string;
369
+ defaultProvider?: string;
370
+ skills?: string[];
371
+ permissionMode?: PermissionMode;
372
+ };
373
+ mcp?: {
374
+ servers?: Array<{
375
+ name: string;
376
+ command?: string;
377
+ url?: string;
378
+ env?: Record<string, string>;
379
+ }>;
380
+ };
381
+ hooks?: {
382
+ preEdit?: string;
383
+ postEdit?: string;
384
+ preCommit?: string;
385
+ postCommit?: string;
386
+ };
387
+ ignore?: string[];
388
+ metadata?: Record<string, any>;
389
+ }
390
+
391
+ // MCP Advanced Types
392
+ export type MCPTransportType = 'stdio' | 'http' | 'streamable-http' | 'sse' | 'websocket';
393
+ export type MCPScope = 'local' | 'project' | 'user' | 'managed';
394
+
395
+ export interface MCPServerDefinition {
396
+ id: string;
397
+ name: string;
398
+ description?: string;
399
+ transport: MCPTransportType;
400
+ command?: string;
401
+ args?: string[];
402
+ url?: string;
403
+ env?: Record<string, string>;
404
+ headers?: Record<string, string>;
405
+ oauth?: {
406
+ clientId?: string;
407
+ clientSecret?: string;
408
+ callbackPort?: number;
409
+ };
410
+ scope: MCPScope;
411
+ disabled?: boolean;
412
+ metadata?: {
413
+ category?: string;
414
+ tags?: string[];
415
+ author?: string;
416
+ version?: string;
417
+ homepage?: string;
418
+ };
419
+ }
420
+
421
+ export interface MCPRegistryEntry {
422
+ id: string;
423
+ name: string;
424
+ description: string;
425
+ publisher: string;
426
+ version: string;
427
+ transport: MCPTransportType[];
428
+ categories: string[];
429
+ tags: string[];
430
+ installs: number;
431
+ rating: number;
432
+ documentation?: string;
433
+ repository?: string;
434
+ command?: string;
435
+ packages?: Array<{
436
+ registryType: 'npm' | 'pip' | 'docker';
437
+ identifier: string;
438
+ }>;
439
+ remotes?: Array<{
440
+ type: 'streamable-http' | 'sse' | 'websocket';
441
+ url: string;
442
+ }>;
443
+ environmentVariables?: Array<{
444
+ name: string;
445
+ description?: string;
446
+ required?: boolean;
447
+ }>;
448
+ }
449
+
450
+ export interface MCPTool {
451
+ name: string;
452
+ description: string;
453
+ inputSchema: any;
454
+ serverId?: string;
455
+ }
456
+
457
+ export interface MCPResource {
458
+ uri: string;
459
+ name: string;
460
+ description?: string;
461
+ mimeType?: string;
462
+ serverId?: string;
463
+ }
464
+
465
+ export interface MCPPrompt {
466
+ name: string;
467
+ description?: string;
468
+ arguments?: Array<{
469
+ name: string;
470
+ description?: string;
471
+ required?: boolean;
472
+ }>;
473
+ serverId?: string;
474
+ }
475
+
476
+ export interface MCPConfiguration {
477
+ mcpServers: Record<string, MCPServerDefinition>;
478
+ settings?: {
479
+ maxOutputTokens?: number;
480
+ timeout?: number;
481
+ enableToolSearch?: boolean | 'auto' | string;
482
+ allowedServers?: string[];
483
+ deniedServers?: string[];
484
+ };
485
+ }
486
+
487
+ export interface MCPSearchResult {
488
+ query: string;
489
+ tools: MCPTool[];
490
+ resources: MCPResource[];
491
+ prompts: MCPPrompt[];
492
+ }
493
+
494
+ export interface MCPAuthToken {
495
+ serverId: string;
496
+ accessToken: string;
497
+ refreshToken?: string;
498
+ expiresAt?: Date;
499
+ scope?: string[];
500
+ }
501
+
502
+ // Prompt Optimizer Types
503
+ export interface PromptAnalysis {
504
+ originalPrompt: string;
505
+ optimizedPrompt: string;
506
+ improvements: PromptImprovement[];
507
+ metrics: {
508
+ clarity: number;
509
+ specificity: number;
510
+ context: number;
511
+ structure: number;
512
+ overall: number;
513
+ };
514
+ estimatedTokens: number;
515
+ suggestions: string[];
516
+ }
517
+
518
+ export interface PromptImprovement {
519
+ type: 'clarity' | 'specificity' | 'context' | 'structure' | 'examples' | 'constraints';
520
+ description: string;
521
+ before: string;
522
+ after: string;
523
+ impact: 'high' | 'medium' | 'low';
524
+ }
525
+
526
+ export interface PromptTemplate {
527
+ id: string;
528
+ name: string;
529
+ description: string;
530
+ category: string;
531
+ template: string;
532
+ variables: string[];
533
+ exampleInput?: string;
534
+ exampleOutput?: string;
535
+ tags: string[];
536
+ }
537
+
538
+ export interface PromptOptimizationOptions {
539
+ goal?: string;
540
+ targetModel?: string;
541
+ maxLength?: number;
542
+ style?: 'concise' | 'detailed' | 'technical' | 'conversational';
543
+ addExamples?: boolean;
544
+ addConstraints?: boolean;
545
+ improveStructure?: boolean;
546
+ }
547
+
548
+ export interface PromptTestResult {
549
+ prompt: string;
550
+ response: string;
551
+ metrics: {
552
+ responseQuality: number;
553
+ relevance: number;
554
+ completeness: number;
555
+ tokenUsage: number;
556
+ latency: number;
557
+ };
558
+ timestamp: Date;
559
+ }
560
+
561
+ export interface PromptVersion {
562
+ id: string;
563
+ prompt: string;
564
+ version: number;
565
+ timestamp: Date;
566
+ tags: string[];
567
+ testResults?: PromptTestResult[];
568
+ notes?: string;
569
+ }
570
+
571
+ // Cloud Sync Types
572
+ export type SyncProvider = 'supabase' | 'custom' | 'none';
573
+
574
+ export interface CloudSyncConfig {
575
+ provider: SyncProvider;
576
+ enabled: boolean;
577
+ autoSync: boolean;
578
+ syncInterval: number; // in seconds
579
+ lastSyncAt?: Date;
580
+ syncDirection: 'upload' | 'download' | 'bidirectional';
581
+ excludedPaths?: string[];
582
+ }
583
+
584
+ export interface SyncStatus {
585
+ status: 'idle' | 'syncing' | 'error' | 'offline';
586
+ progress?: number;
587
+ lastSync?: Date;
588
+ error?: string;
589
+ pendingChanges: number;
590
+ }
591
+
592
+ export interface SyncItem {
593
+ id: string;
594
+ path: string;
595
+ type: 'file' | 'directory' | 'setting' | 'agent' | 'project';
596
+ action: 'create' | 'update' | 'delete';
597
+ localVersion: string;
598
+ remoteVersion?: string;
599
+ status: 'pending' | 'syncing' | 'synced' | 'conflict' | 'error';
600
+ timestamp: Date;
601
+ deviceId: string;
602
+ }
603
+
604
+ export interface CloudSession {
605
+ id: string;
606
+ deviceId: string;
607
+ deviceName: string;
608
+ platform: string;
609
+ lastActiveAt: Date;
610
+ currentProject?: string;
611
+ status: 'active' | 'idle' | 'disconnected';
612
+ }
613
+
614
+ export interface TeleportRequest {
615
+ id: string;
616
+ sourceDeviceId: string;
617
+ targetDeviceId: string;
618
+ projectPath: string;
619
+ status: 'pending' | 'accepted' | 'rejected' | 'completed' | 'failed';
620
+ createdAt: Date;
621
+ completedAt?: Date;
622
+ error?: string;
623
+ }
624
+
625
+ // Realtime API Types (Voice/Audio)
626
+ export interface RealtimeConfig {
627
+ provider: 'openai' | 'custom';
628
+ apiKey?: string;
629
+ voice?: string;
630
+ model?: string;
631
+ language?: string;
632
+ enableSTT: boolean;
633
+ enableTTS: boolean;
634
+ }
635
+
636
+ export interface SpeechRecognitionResult {
637
+ transcript: string;
638
+ confidence: number;
639
+ isFinal: boolean;
640
+ timestamp: Date;
641
+ }
642
+
643
+ export interface SpeechSynthesisOptions {
644
+ text: string;
645
+ voice?: string;
646
+ rate?: number;
647
+ pitch?: number;
648
+ volume?: number;
649
+ }
650
+
651
+ export interface AudioStream {
652
+ data: string; // base64
653
+ format: 'mp3' | 'wav' | 'opus';
654
+ sampleRate: number;
655
+ channels: number;
656
+ }
657
+
658
+ // Agent SDK Types
659
+ export interface AgentDefinition {
660
+ id: string;
661
+ name: string;
662
+ description: string;
663
+ version: string;
664
+ author?: string;
665
+ model?: string;
666
+ provider?: string;
667
+ systemPrompt?: string;
668
+ tools?: string[];
669
+ skills?: string[];
670
+ guardrails?: AgentGuardrail[];
671
+ }
672
+
673
+ export interface AgentGuardrail {
674
+ type: 'input_filter' | 'output_filter' | 'tool_restriction';
675
+ config: Record<string, any>;
676
+ enabled: boolean;
677
+ }
678
+
679
+ export interface AgentExecutionContext {
680
+ agentId: string;
681
+ sessionId: string;
682
+ messages: AgentMessage[];
683
+ metadata: Record<string, any>;
684
+ }
685
+
686
+ export interface AgentHandler {
687
+ name: string;
688
+ description: string;
689
+ parameters?: Record<string, any>;
690
+ execute: (context: AgentExecutionContext, params: any) => Promise<any>;
691
+ }
692
+
693
+ // Slash Commands Types
694
+ export interface SlashCommand {
695
+ id: string;
696
+ name: string;
697
+ description: string;
698
+ usage: string;
699
+ aliases?: string[];
700
+ execute: (args: string, context: any) => Promise<SlashCommandResult>;
701
+ }
702
+
703
+ export interface SlashCommandResult {
704
+ success: boolean;
705
+ message?: string;
706
+ output?: any;
707
+ error?: string;
708
+ }
709
+
710
+ // Hook Types
711
+ export interface Hook {
712
+ id: string;
713
+ name: string;
714
+ trigger: 'pre' | 'post';
715
+ event: string;
716
+ command: string;
717
+ enabled: boolean;
718
+ timeout?: number;
719
+ }
720
+
721
+ export interface HookExecution {
722
+ hookId: string;
723
+ event: string;
724
+ trigger: 'pre' | 'post';
725
+ startTime: Date;
726
+ endTime?: Date;
727
+ success: boolean;
728
+ output?: string;
729
+ error?: string;
730
+ }
731
+
732
+ // GitHub Actions / CI-CD Types
733
+ export interface CICDConfig {
734
+ provider: 'github' | 'gitlab' | 'custom';
735
+ enabled: boolean;
736
+ workflowPath?: string;
737
+ triggers?: string[];
738
+ }
739
+
740
+ export interface WorkflowRun {
741
+ id: string;
742
+ workflowId: string;
743
+ status: 'queued' | 'running' | 'completed' | 'failed';
744
+ conclusion?: 'success' | 'failure' | 'cancelled';
745
+ logs?: string;
746
+ startedAt: Date;
747
+ completedAt?: Date;
748
+ url?: string;
749
+ }
750
+
751
+ export interface CIAction {
752
+ type: 'run_workflow' | 'cancel_run' | 'get_logs' | 'get_status';
753
+ workflowId?: string;
754
+ runId?: string;
755
+ }
756
+
757
+ // Context Optimization Types
758
+ export interface ContextCompactionConfig {
759
+ enabled: boolean;
760
+ threshold: number; // tokens
761
+ strategy: 'summarize' | 'prune' | 'hybrid';
762
+ }
763
+
764
+ export interface PromptCacheConfig {
765
+ enabled: boolean;
766
+ ttl: number; // seconds
767
+ maxSize: number; // entries
768
+ }
769
+
770
+ export interface CompactionResult {
771
+ originalTokens: number;
772
+ compactedTokens: number;
773
+ removedMessages: number;
774
+ summary?: string;
775
+ }
776
+
777
+ // Enterprise Types
778
+ export interface SSOConfig {
779
+ provider: 'okta' | 'azure-ad' | 'google' | 'custom';
780
+ enabled: boolean;
781
+ metadataUrl?: string;
782
+ clientId?: string;
783
+ }
784
+
785
+ export interface RBACRole {
786
+ id: string;
787
+ name: string;
788
+ permissions: string[];
789
+ description?: string;
790
+ }
791
+
792
+ export interface RBACUser {
793
+ id: string;
794
+ email: string;
795
+ roles: string[];
796
+ lastLogin?: Date;
797
+ }
798
+
799
+ // Connector Types
800
+ export interface ConnectorConfig {
801
+ id: string;
802
+ type: 'jira' | 'notion' | 'sentry' | 'linear' | 'slack';
803
+ enabled: boolean;
804
+ config: Record<string, any>;
805
+ }
806
+
807
+ export interface ConnectorCredentials {
808
+ connectorId: string;
809
+ apiKey?: string;
810
+ accessToken?: string;
811
+ refreshToken?: string;
812
+ expiresAt?: Date;
813
+ }