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,1156 @@
1
+ import OpenAI from 'openai';
2
+ import log from 'electron-log';
3
+ import { ProviderConfig, ProviderModel } from '../../shared/types';
4
+
5
+ interface FreeModelConfig {
6
+ provider: string;
7
+ baseUrl: string;
8
+ requiresApiKey: boolean;
9
+ defaultApiKey?: string;
10
+ description: string;
11
+ }
12
+
13
+ const FREE_MODEL_CONFIGS: Record<string, FreeModelConfig> = {
14
+ openrouter: {
15
+ provider: 'OpenRouter',
16
+ baseUrl: 'https://openrouter.ai/api/v1',
17
+ requiresApiKey: false,
18
+ defaultApiKey: '',
19
+ description: 'Free models via OpenRouter (no API key required for free tier)'
20
+ },
21
+ ollama: {
22
+ provider: 'Ollama',
23
+ baseUrl: 'http://localhost:11434/v1',
24
+ requiresApiKey: false,
25
+ defaultApiKey: '',
26
+ description: 'Local Ollama server - runs models locally on your machine'
27
+ },
28
+ nvidia: {
29
+ provider: 'NVIDIA NIM',
30
+ baseUrl: 'https://integrate.api.nvidia.com/v1',
31
+ requiresApiKey: true,
32
+ description: 'NVIDIA NIM API - Free tier with phone verification (40 req/min)'
33
+ },
34
+ groq: {
35
+ provider: 'Groq',
36
+ baseUrl: 'https://api.groq.com/openai/v1',
37
+ requiresApiKey: true,
38
+ description: 'Fast inference with Llama/Mixtral models (free tier available)'
39
+ },
40
+ google: {
41
+ provider: 'Google AI Studio',
42
+ baseUrl: 'https://generativelanguage.googleapis.com/v1beta/openai',
43
+ requiresApiKey: true,
44
+ description: 'Gemini models free tier (requires Google AI Studio API key)'
45
+ },
46
+ cerebras: {
47
+ provider: 'Cerebras',
48
+ baseUrl: 'https://api.cerebras.ai/v1',
49
+ requiresApiKey: true,
50
+ description: 'Ultra-fast inference (free tier available)'
51
+ },
52
+ cloudflare: {
53
+ provider: 'Cloudflare Workers AI',
54
+ baseUrl: 'https://api.cloudflare.com/client/v4/accounts/{account_id}/ai/v1',
55
+ requiresApiKey: true,
56
+ description: 'Edge AI with free tier (10,000 neurons/day)'
57
+ }
58
+ };
59
+
60
+ const FREE_MODELS: ProviderModel[] = [
61
+ {
62
+ id: 'meta-llama/llama-3.3-70b-instruct:free',
63
+ name: 'Llama 3.3 70B (Free)',
64
+ description: 'Meta Llama 3.3 70B - GPT-4 level performance, via OpenRouter',
65
+ maxTokens: 8192,
66
+ contextWindow: 128000,
67
+ supportsTools: true,
68
+ supportsVision: false,
69
+ pricing: { input: 0, output: 0 },
70
+ isFree: true,
71
+ backend: 'openrouter'
72
+ },
73
+ {
74
+ id: 'google/gemini-2.0-flash-exp:free',
75
+ name: 'Gemini 2.0 Flash (Free)',
76
+ description: 'Google Gemini 2.0 Flash - 1M context, via OpenRouter',
77
+ maxTokens: 8192,
78
+ contextWindow: 1000000,
79
+ supportsTools: true,
80
+ supportsVision: true,
81
+ pricing: { input: 0, output: 0 },
82
+ isFree: true,
83
+ backend: 'openrouter'
84
+ },
85
+ {
86
+ id: 'google/gemini-2.5-flash-preview:free',
87
+ name: 'Gemini 2.5 Flash Preview (Free)',
88
+ description: 'Google Gemini 2.5 Flash Preview - via OpenRouter',
89
+ maxTokens: 8192,
90
+ contextWindow: 1000000,
91
+ supportsTools: true,
92
+ supportsVision: true,
93
+ pricing: { input: 0, output: 0 },
94
+ isFree: true,
95
+ backend: 'openrouter'
96
+ },
97
+ {
98
+ id: 'google/gemma-3-27b-it:free',
99
+ name: 'Gemma 3 27B (Free)',
100
+ description: 'Google Gemma 3 27B Instruct, via OpenRouter',
101
+ maxTokens: 8192,
102
+ contextWindow: 32768,
103
+ supportsTools: true,
104
+ supportsVision: false,
105
+ pricing: { input: 0, output: 0 },
106
+ isFree: true,
107
+ backend: 'openrouter'
108
+ },
109
+ {
110
+ id: 'google/gemma-3-12b-it:free',
111
+ name: 'Gemma 3 12B (Free)',
112
+ description: 'Google Gemma 3 12B Instruct, via OpenRouter',
113
+ maxTokens: 4096,
114
+ contextWindow: 32768,
115
+ supportsTools: true,
116
+ supportsVision: false,
117
+ pricing: { input: 0, output: 0 },
118
+ isFree: true,
119
+ backend: 'openrouter'
120
+ },
121
+ {
122
+ id: 'mistralai/mistral-small-3.1-24b-instruct:free',
123
+ name: 'Mistral Small 3.1 24B (Free)',
124
+ description: 'Mistral Small 3.1 24B Instruct, via OpenRouter',
125
+ maxTokens: 8192,
126
+ contextWindow: 128000,
127
+ supportsTools: true,
128
+ supportsVision: true,
129
+ pricing: { input: 0, output: 0 },
130
+ isFree: true,
131
+ backend: 'openrouter'
132
+ },
133
+ {
134
+ id: 'deepseek/deepseek-r1-0528:free',
135
+ name: 'DeepSeek R1 (Free)',
136
+ description: 'DeepSeek R1 reasoning model, via OpenRouter',
137
+ maxTokens: 8192,
138
+ contextWindow: 128000,
139
+ supportsTools: true,
140
+ supportsVision: false,
141
+ pricing: { input: 0, output: 0 },
142
+ isFree: true,
143
+ backend: 'openrouter'
144
+ },
145
+ {
146
+ id: 'qwen/qwen3-4b:free',
147
+ name: 'Qwen 3 4B (Free)',
148
+ description: 'Alibaba Qwen 3 4B, via OpenRouter',
149
+ maxTokens: 4096,
150
+ contextWindow: 32768,
151
+ supportsTools: true,
152
+ supportsVision: false,
153
+ pricing: { input: 0, output: 0 },
154
+ isFree: true,
155
+ backend: 'openrouter'
156
+ },
157
+ {
158
+ id: 'qwen/qwen3-coder:free',
159
+ name: 'Qwen 3 Coder (Free)',
160
+ description: 'Alibaba Qwen 3 Coder - optimized for code, via OpenRouter',
161
+ maxTokens: 8192,
162
+ contextWindow: 32768,
163
+ supportsTools: true,
164
+ supportsVision: false,
165
+ pricing: { input: 0, output: 0 },
166
+ isFree: true,
167
+ backend: 'openrouter'
168
+ },
169
+ {
170
+ id: 'qwen/qwen3-next-80b-a3b-instruct:free',
171
+ name: 'Qwen 3 Next 80B (Free)',
172
+ description: 'Alibaba Qwen 3 Next 80B, via OpenRouter',
173
+ maxTokens: 8192,
174
+ contextWindow: 32768,
175
+ supportsTools: true,
176
+ supportsVision: false,
177
+ pricing: { input: 0, output: 0 },
178
+ isFree: true,
179
+ backend: 'openrouter'
180
+ },
181
+ {
182
+ id: 'nvidia/nemotron-nano-12b-v2-vl:free',
183
+ name: 'Nemotron Nano 12B VL (Free)',
184
+ description: 'NVIDIA Nemotron Nano 12B Vision Language, via OpenRouter',
185
+ maxTokens: 4096,
186
+ contextWindow: 32768,
187
+ supportsTools: true,
188
+ supportsVision: true,
189
+ pricing: { input: 0, output: 0 },
190
+ isFree: true,
191
+ backend: 'openrouter'
192
+ },
193
+ {
194
+ id: 'nousresearch/hermes-3-llama-3.1-405b:free',
195
+ name: 'Hermes 3 Llama 405B (Free)',
196
+ description: 'Nous Hermes 3 Llama 3.1 405B, via OpenRouter',
197
+ maxTokens: 8192,
198
+ contextWindow: 128000,
199
+ supportsTools: true,
200
+ supportsVision: false,
201
+ pricing: { input: 0, output: 0 },
202
+ isFree: true,
203
+ backend: 'openrouter'
204
+ },
205
+ {
206
+ id: 'openai/gpt-oss-120b:free',
207
+ name: 'GPT-OSS 120B (Free)',
208
+ description: 'OpenAI OSS 120B model, via OpenRouter',
209
+ maxTokens: 8192,
210
+ contextWindow: 128000,
211
+ supportsTools: true,
212
+ supportsVision: false,
213
+ pricing: { input: 0, output: 0 },
214
+ isFree: true,
215
+ backend: 'openrouter'
216
+ },
217
+ {
218
+ id: 'z-ai/glm-4.5-air:free',
219
+ name: 'GLM 4.5 Air (Free)',
220
+ description: 'Z.ai GLM 4.5 Air, via OpenRouter',
221
+ maxTokens: 4096,
222
+ contextWindow: 128000,
223
+ supportsTools: true,
224
+ supportsVision: false,
225
+ pricing: { input: 0, output: 0 },
226
+ isFree: true,
227
+ backend: 'openrouter'
228
+ },
229
+ {
230
+ id: 'liquid/lfm-2.5-1.2b-instruct:free',
231
+ name: 'LFM 2.5 1.2B (Free)',
232
+ description: 'Liquid LFM 2.5 1.2B Instruct, via OpenRouter',
233
+ maxTokens: 2048,
234
+ contextWindow: 8192,
235
+ supportsTools: false,
236
+ supportsVision: false,
237
+ pricing: { input: 0, output: 0 },
238
+ isFree: true,
239
+ backend: 'openrouter'
240
+ },
241
+ {
242
+ id: 'upstage/solar-pro-3:free',
243
+ name: 'Solar Pro 3 (Free)',
244
+ description: 'Upstage Solar Pro 3, via OpenRouter',
245
+ maxTokens: 4096,
246
+ contextWindow: 32768,
247
+ supportsTools: true,
248
+ supportsVision: false,
249
+ pricing: { input: 0, output: 0 },
250
+ isFree: true,
251
+ backend: 'openrouter'
252
+ },
253
+ {
254
+ id: 'moonshotai/kimi-k2.5',
255
+ name: 'Kimi K2.5 (NVIDIA)',
256
+ description: 'Moonshot Kimi K2.5 - Advanced reasoning, via NVIDIA NIM',
257
+ maxTokens: 16384,
258
+ contextWindow: 128000,
259
+ supportsTools: true,
260
+ supportsVision: false,
261
+ pricing: { input: 0, output: 0 },
262
+ isFree: true,
263
+ backend: 'nvidia'
264
+ },
265
+ {
266
+ id: 'deepseek-ai/deepseek-r1',
267
+ name: 'DeepSeek R1 (NVIDIA)',
268
+ description: 'DeepSeek R1 reasoning model, via NVIDIA NIM',
269
+ maxTokens: 16384,
270
+ contextWindow: 128000,
271
+ supportsTools: true,
272
+ supportsVision: false,
273
+ pricing: { input: 0, output: 0 },
274
+ isFree: true,
275
+ backend: 'nvidia'
276
+ },
277
+ {
278
+ id: 'meta/llama-3.3-70b-instruct',
279
+ name: 'Llama 3.3 70B (NVIDIA)',
280
+ description: 'Meta Llama 3.3 70B Instruct, via NVIDIA NIM',
281
+ maxTokens: 16384,
282
+ contextWindow: 128000,
283
+ supportsTools: true,
284
+ supportsVision: false,
285
+ pricing: { input: 0, output: 0 },
286
+ isFree: true,
287
+ backend: 'nvidia'
288
+ },
289
+ {
290
+ id: 'meta/llama-3.1-405b-instruct',
291
+ name: 'Llama 3.1 405B (NVIDIA)',
292
+ description: 'Meta Llama 3.1 405B Instruct, via NVIDIA NIM',
293
+ maxTokens: 16384,
294
+ contextWindow: 128000,
295
+ supportsTools: true,
296
+ supportsVision: false,
297
+ pricing: { input: 0, output: 0 },
298
+ isFree: true,
299
+ backend: 'nvidia'
300
+ },
301
+ {
302
+ id: 'meta/llama-3.1-8b-instruct',
303
+ name: 'Llama 3.1 8B (NVIDIA)',
304
+ description: 'Meta Llama 3.1 8B Instruct, via NVIDIA NIM',
305
+ maxTokens: 16384,
306
+ contextWindow: 128000,
307
+ supportsTools: true,
308
+ supportsVision: false,
309
+ pricing: { input: 0, output: 0 },
310
+ isFree: true,
311
+ backend: 'nvidia'
312
+ },
313
+ {
314
+ id: 'mistralai/mistral-large',
315
+ name: 'Mistral Large (NVIDIA)',
316
+ description: 'Mistral Large model, via NVIDIA NIM',
317
+ maxTokens: 16384,
318
+ contextWindow: 128000,
319
+ supportsTools: true,
320
+ supportsVision: false,
321
+ pricing: { input: 0, output: 0 },
322
+ isFree: true,
323
+ backend: 'nvidia'
324
+ },
325
+ {
326
+ id: 'mistralai/codestral-22b',
327
+ name: 'Codestral 22B (NVIDIA)',
328
+ description: 'Mistral Codestral - Code generation, via NVIDIA NIM',
329
+ maxTokens: 16384,
330
+ contextWindow: 32768,
331
+ supportsTools: true,
332
+ supportsVision: false,
333
+ pricing: { input: 0, output: 0 },
334
+ isFree: true,
335
+ backend: 'nvidia'
336
+ },
337
+ {
338
+ id: 'mistralai/mathstral-7b-v0.1',
339
+ name: 'Mathstral 7B (NVIDIA)',
340
+ description: 'Mistral Mathstral - Math reasoning, via NVIDIA NIM',
341
+ maxTokens: 16384,
342
+ contextWindow: 32768,
343
+ supportsTools: true,
344
+ supportsVision: false,
345
+ pricing: { input: 0, output: 0 },
346
+ isFree: true,
347
+ backend: 'nvidia'
348
+ },
349
+ {
350
+ id: 'nvidia/llama-3.1-nemotron-70b-ultra',
351
+ name: 'Nemotron 70B Ultra (NVIDIA)',
352
+ description: 'NVIDIA Nemotron 70B Ultra, via NVIDIA NIM',
353
+ maxTokens: 16384,
354
+ contextWindow: 128000,
355
+ supportsTools: true,
356
+ supportsVision: false,
357
+ pricing: { input: 0, output: 0 },
358
+ isFree: true,
359
+ backend: 'nvidia'
360
+ },
361
+ {
362
+ id: 'nvidia/llama-3.1-nemotron-51b-instruct',
363
+ name: 'Nemotron 51B (NVIDIA)',
364
+ description: 'NVIDIA Nemotron 51B Instruct, via NVIDIA NIM',
365
+ maxTokens: 16384,
366
+ contextWindow: 128000,
367
+ supportsTools: true,
368
+ supportsVision: false,
369
+ pricing: { input: 0, output: 0 },
370
+ isFree: true,
371
+ backend: 'nvidia'
372
+ },
373
+ {
374
+ id: 'google/gemma-2-27b-it',
375
+ name: 'Gemma 2 27B (NVIDIA)',
376
+ description: 'Google Gemma 2 27B Instruct, via NVIDIA NIM',
377
+ maxTokens: 8192,
378
+ contextWindow: 8192,
379
+ supportsTools: true,
380
+ supportsVision: false,
381
+ pricing: { input: 0, output: 0 },
382
+ isFree: true,
383
+ backend: 'nvidia'
384
+ },
385
+ {
386
+ id: 'google/gemma-2-9b-it',
387
+ name: 'Gemma 2 9B (NVIDIA)',
388
+ description: 'Google Gemma 2 9B Instruct, via NVIDIA NIM',
389
+ maxTokens: 8192,
390
+ contextWindow: 8192,
391
+ supportsTools: true,
392
+ supportsVision: false,
393
+ pricing: { input: 0, output: 0 },
394
+ isFree: true,
395
+ backend: 'nvidia'
396
+ },
397
+ {
398
+ id: 'google/gemma-2-2b-it',
399
+ name: 'Gemma 2 2B (NVIDIA)',
400
+ description: 'Google Gemma 2 2B Instruct, via NVIDIA NIM',
401
+ maxTokens: 8192,
402
+ contextWindow: 8192,
403
+ supportsTools: true,
404
+ supportsVision: false,
405
+ pricing: { input: 0, output: 0 },
406
+ isFree: true,
407
+ backend: 'nvidia'
408
+ },
409
+ {
410
+ id: 'qwen/qwen2.5-72b-instruct',
411
+ name: 'Qwen 2.5 72B (NVIDIA)',
412
+ description: 'Alibaba Qwen 2.5 72B Instruct, via NVIDIA NIM',
413
+ maxTokens: 16384,
414
+ contextWindow: 128000,
415
+ supportsTools: true,
416
+ supportsVision: false,
417
+ pricing: { input: 0, output: 0 },
418
+ isFree: true,
419
+ backend: 'nvidia'
420
+ },
421
+ {
422
+ id: 'qwen/qwen2.5-math-72b-instruct',
423
+ name: 'Qwen 2.5 Math 72B (NVIDIA)',
424
+ description: 'Qwen 2.5 Math 72B - Math reasoning, via NVIDIA NIM',
425
+ maxTokens: 16384,
426
+ contextWindow: 4096,
427
+ supportsTools: true,
428
+ supportsVision: false,
429
+ pricing: { input: 0, output: 0 },
430
+ isFree: true,
431
+ backend: 'nvidia'
432
+ },
433
+ {
434
+ id: 'qwen/qwen2.5-coder-32b-instruct',
435
+ name: 'Qwen 2.5 Coder 32B (NVIDIA)',
436
+ description: 'Qwen 2.5 Coder - Code generation, via NVIDIA NIM',
437
+ maxTokens: 16384,
438
+ contextWindow: 32768,
439
+ supportsTools: true,
440
+ supportsVision: false,
441
+ pricing: { input: 0, output: 0 },
442
+ isFree: true,
443
+ backend: 'nvidia'
444
+ },
445
+ {
446
+ id: 'microsoft/phi-3-medium-128k-instruct',
447
+ name: 'Phi-3 Medium 128K (NVIDIA)',
448
+ description: 'Microsoft Phi-3 Medium 128K context, via NVIDIA NIM',
449
+ maxTokens: 8192,
450
+ contextWindow: 128000,
451
+ supportsTools: true,
452
+ supportsVision: false,
453
+ pricing: { input: 0, output: 0 },
454
+ isFree: true,
455
+ backend: 'nvidia'
456
+ },
457
+ {
458
+ id: 'microsoft/phi-3-mini-128k-instruct',
459
+ name: 'Phi-3 Mini 128K (NVIDIA)',
460
+ description: 'Microsoft Phi-3 Mini 128K context, via NVIDIA NIM',
461
+ maxTokens: 4096,
462
+ contextWindow: 128000,
463
+ supportsTools: true,
464
+ supportsVision: false,
465
+ pricing: { input: 0, output: 0 },
466
+ isFree: true,
467
+ backend: 'nvidia'
468
+ },
469
+ {
470
+ id: 'snowflake/arctic',
471
+ name: 'Arctic (NVIDIA)',
472
+ description: 'Snowflake Arctic - Enterprise LLM, via NVIDIA NIM',
473
+ maxTokens: 4096,
474
+ contextWindow: 4096,
475
+ supportsTools: true,
476
+ supportsVision: false,
477
+ pricing: { input: 0, output: 0 },
478
+ isFree: true,
479
+ backend: 'nvidia'
480
+ },
481
+ {
482
+ id: 'upstage/solar-10.7b-instruct',
483
+ name: 'Solar 10.7B (NVIDIA)',
484
+ description: 'Upstage Solar 10.7B Instruct, via NVIDIA NIM',
485
+ maxTokens: 4096,
486
+ contextWindow: 4096,
487
+ supportsTools: true,
488
+ supportsVision: false,
489
+ pricing: { input: 0, output: 0 },
490
+ isFree: true,
491
+ backend: 'nvidia'
492
+ },
493
+ {
494
+ id: 'llama3.2:latest',
495
+ name: 'Llama 3.2 (Ollama)',
496
+ description: 'Meta Llama 3.2 - Local via Ollama',
497
+ maxTokens: 8192,
498
+ contextWindow: 128000,
499
+ supportsTools: true,
500
+ supportsVision: true,
501
+ pricing: { input: 0, output: 0 },
502
+ isFree: true,
503
+ backend: 'ollama'
504
+ },
505
+ {
506
+ id: 'llama3.2:1b',
507
+ name: 'Llama 3.2 1B (Ollama)',
508
+ description: 'Meta Llama 3.2 1B - Lightweight, via Ollama',
509
+ maxTokens: 4096,
510
+ contextWindow: 128000,
511
+ supportsTools: true,
512
+ supportsVision: false,
513
+ pricing: { input: 0, output: 0 },
514
+ isFree: true,
515
+ backend: 'ollama'
516
+ },
517
+ {
518
+ id: 'llama3.2:3b',
519
+ name: 'Llama 3.2 3B (Ollama)',
520
+ description: 'Meta Llama 3.2 3B - Compact, via Ollama',
521
+ maxTokens: 4096,
522
+ contextWindow: 128000,
523
+ supportsTools: true,
524
+ supportsVision: false,
525
+ pricing: { input: 0, output: 0 },
526
+ isFree: true,
527
+ backend: 'ollama'
528
+ },
529
+ {
530
+ id: 'llama3.3:latest',
531
+ name: 'Llama 3.3 70B (Ollama)',
532
+ description: 'Meta Llama 3.3 70B - Full size, via Ollama',
533
+ maxTokens: 8192,
534
+ contextWindow: 128000,
535
+ supportsTools: true,
536
+ supportsVision: false,
537
+ pricing: { input: 0, output: 0 },
538
+ isFree: true,
539
+ backend: 'ollama'
540
+ },
541
+ {
542
+ id: 'llama3.1:8b',
543
+ name: 'Llama 3.1 8B (Ollama)',
544
+ description: 'Meta Llama 3.1 8B - Balanced, via Ollama',
545
+ maxTokens: 8192,
546
+ contextWindow: 128000,
547
+ supportsTools: true,
548
+ supportsVision: false,
549
+ pricing: { input: 0, output: 0 },
550
+ isFree: true,
551
+ backend: 'ollama'
552
+ },
553
+ {
554
+ id: 'llama3.1:70b',
555
+ name: 'Llama 3.1 70B (Ollama)',
556
+ description: 'Meta Llama 3.1 70B - Large, via Ollama',
557
+ maxTokens: 8192,
558
+ contextWindow: 128000,
559
+ supportsTools: true,
560
+ supportsVision: false,
561
+ pricing: { input: 0, output: 0 },
562
+ isFree: true,
563
+ backend: 'ollama'
564
+ },
565
+ {
566
+ id: 'mistral:latest',
567
+ name: 'Mistral (Ollama)',
568
+ description: 'Mistral 7B - Fast and efficient, via Ollama',
569
+ maxTokens: 8192,
570
+ contextWindow: 32768,
571
+ supportsTools: true,
572
+ supportsVision: false,
573
+ pricing: { input: 0, output: 0 },
574
+ isFree: true,
575
+ backend: 'ollama'
576
+ },
577
+ {
578
+ id: 'mistral-nemo:latest',
579
+ name: 'Mistral NeMo (Ollama)',
580
+ description: 'Mistral NeMo 12B - via Ollama',
581
+ maxTokens: 8192,
582
+ contextWindow: 128000,
583
+ supportsTools: true,
584
+ supportsVision: false,
585
+ pricing: { input: 0, output: 0 },
586
+ isFree: true,
587
+ backend: 'ollama'
588
+ },
589
+ {
590
+ id: 'codellama:latest',
591
+ name: 'Code Llama (Ollama)',
592
+ description: 'Meta Code Llama - Code generation, via Ollama',
593
+ maxTokens: 8192,
594
+ contextWindow: 16384,
595
+ supportsTools: true,
596
+ supportsVision: false,
597
+ pricing: { input: 0, output: 0 },
598
+ isFree: true,
599
+ backend: 'ollama'
600
+ },
601
+ {
602
+ id: 'deepseek-coder:latest',
603
+ name: 'DeepSeek Coder (Ollama)',
604
+ description: 'DeepSeek Coder - Code generation, via Ollama',
605
+ maxTokens: 8192,
606
+ contextWindow: 16384,
607
+ supportsTools: true,
608
+ supportsVision: false,
609
+ pricing: { input: 0, output: 0 },
610
+ isFree: true,
611
+ backend: 'ollama'
612
+ },
613
+ {
614
+ id: 'deepseek-r1:latest',
615
+ name: 'DeepSeek R1 (Ollama)',
616
+ description: 'DeepSeek R1 - Reasoning model, via Ollama',
617
+ maxTokens: 16384,
618
+ contextWindow: 128000,
619
+ supportsTools: true,
620
+ supportsVision: false,
621
+ pricing: { input: 0, output: 0 },
622
+ isFree: true,
623
+ backend: 'ollama'
624
+ },
625
+ {
626
+ id: 'qwen2.5:latest',
627
+ name: 'Qwen 2.5 (Ollama)',
628
+ description: 'Alibaba Qwen 2.5 - General purpose, via Ollama',
629
+ maxTokens: 8192,
630
+ contextWindow: 128000,
631
+ supportsTools: true,
632
+ supportsVision: false,
633
+ pricing: { input: 0, output: 0 },
634
+ isFree: true,
635
+ backend: 'ollama'
636
+ },
637
+ {
638
+ id: 'qwen2.5-coder:latest',
639
+ name: 'Qwen 2.5 Coder (Ollama)',
640
+ description: 'Qwen 2.5 Coder - Code generation, via Ollama',
641
+ maxTokens: 8192,
642
+ contextWindow: 32768,
643
+ supportsTools: true,
644
+ supportsVision: false,
645
+ pricing: { input: 0, output: 0 },
646
+ isFree: true,
647
+ backend: 'ollama'
648
+ },
649
+ {
650
+ id: 'gemma2:latest',
651
+ name: 'Gemma 2 (Ollama)',
652
+ description: 'Google Gemma 2 - via Ollama',
653
+ maxTokens: 8192,
654
+ contextWindow: 8192,
655
+ supportsTools: true,
656
+ supportsVision: false,
657
+ pricing: { input: 0, output: 0 },
658
+ isFree: true,
659
+ backend: 'ollama'
660
+ },
661
+ {
662
+ id: 'gemma3:latest',
663
+ name: 'Gemma 3 (Ollama)',
664
+ description: 'Google Gemma 3 - Latest, via Ollama',
665
+ maxTokens: 8192,
666
+ contextWindow: 32768,
667
+ supportsTools: true,
668
+ supportsVision: true,
669
+ pricing: { input: 0, output: 0 },
670
+ isFree: true,
671
+ backend: 'ollama'
672
+ },
673
+ {
674
+ id: 'phi3:latest',
675
+ name: 'Phi-3 (Ollama)',
676
+ description: 'Microsoft Phi-3 Mini - Compact, via Ollama',
677
+ maxTokens: 4096,
678
+ contextWindow: 128000,
679
+ supportsTools: true,
680
+ supportsVision: false,
681
+ pricing: { input: 0, output: 0 },
682
+ isFree: true,
683
+ backend: 'ollama'
684
+ },
685
+ {
686
+ id: 'phi3.5:latest',
687
+ name: 'Phi-3.5 (Ollama)',
688
+ description: 'Microsoft Phi-3.5 - Latest compact, via Ollama',
689
+ maxTokens: 4096,
690
+ contextWindow: 128000,
691
+ supportsTools: true,
692
+ supportsVision: false,
693
+ pricing: { input: 0, output: 0 },
694
+ isFree: true,
695
+ backend: 'ollama'
696
+ },
697
+ {
698
+ id: 'cogito:latest',
699
+ name: 'Cogito (Ollama)',
700
+ description: 'Cogito - Reasoning model, via Ollama',
701
+ maxTokens: 8192,
702
+ contextWindow: 32768,
703
+ supportsTools: true,
704
+ supportsVision: false,
705
+ pricing: { input: 0, output: 0 },
706
+ isFree: true,
707
+ backend: 'ollama'
708
+ },
709
+ {
710
+ id: 'minimax-m2.5:cloud',
711
+ name: 'Minimax M2.5 (Ollama Cloud)',
712
+ description: 'Minimax M2.5 - Cloud via Ollama',
713
+ maxTokens: 16384,
714
+ contextWindow: 128000,
715
+ supportsTools: true,
716
+ supportsVision: false,
717
+ pricing: { input: 0, output: 0 },
718
+ isFree: true,
719
+ backend: 'ollama'
720
+ },
721
+ {
722
+ id: 'llama-3.3-70b-versatile',
723
+ name: 'Llama 3.3 70B (Groq)',
724
+ description: 'Llama 3.3 70B via Groq - ultra fast inference',
725
+ maxTokens: 8192,
726
+ contextWindow: 128000,
727
+ supportsTools: true,
728
+ supportsVision: false,
729
+ pricing: { input: 0, output: 0 },
730
+ isFree: true,
731
+ backend: 'groq'
732
+ },
733
+ {
734
+ id: 'llama-3.1-8b-instant',
735
+ name: 'Llama 3.1 8B (Groq)',
736
+ description: 'Llama 3.1 8B via Groq - ultra fast inference',
737
+ maxTokens: 8192,
738
+ contextWindow: 128000,
739
+ supportsTools: true,
740
+ supportsVision: false,
741
+ pricing: { input: 0, output: 0 },
742
+ isFree: true,
743
+ backend: 'groq'
744
+ },
745
+ {
746
+ id: 'llama-4-maverick-17b-128e-instruct',
747
+ name: 'Llama 4 Maverick (Groq)',
748
+ description: 'Llama 4 Maverick 17B via Groq',
749
+ maxTokens: 8192,
750
+ contextWindow: 128000,
751
+ supportsTools: true,
752
+ supportsVision: false,
753
+ pricing: { input: 0, output: 0 },
754
+ isFree: true,
755
+ backend: 'groq'
756
+ },
757
+ {
758
+ id: 'llama-4-scout-17b-16e-instruct',
759
+ name: 'Llama 4 Scout (Groq)',
760
+ description: 'Llama 4 Scout 17B via Groq',
761
+ maxTokens: 8192,
762
+ contextWindow: 128000,
763
+ supportsTools: true,
764
+ supportsVision: false,
765
+ pricing: { input: 0, output: 0 },
766
+ isFree: true,
767
+ backend: 'groq'
768
+ },
769
+ {
770
+ id: 'mixtral-8x7b-32768',
771
+ name: 'Mixtral 8x7B (Groq)',
772
+ description: 'Mixtral 8x7B via Groq - ultra fast inference',
773
+ maxTokens: 8192,
774
+ contextWindow: 32768,
775
+ supportsTools: true,
776
+ supportsVision: false,
777
+ pricing: { input: 0, output: 0 },
778
+ isFree: true,
779
+ backend: 'groq'
780
+ },
781
+ {
782
+ id: 'gemma2-9b-it',
783
+ name: 'Gemma 2 9B (Groq)',
784
+ description: 'Google Gemma 2 9B via Groq',
785
+ maxTokens: 8192,
786
+ contextWindow: 8192,
787
+ supportsTools: true,
788
+ supportsVision: false,
789
+ pricing: { input: 0, output: 0 },
790
+ isFree: true,
791
+ backend: 'groq'
792
+ },
793
+ {
794
+ id: 'qwen/qwen3-32b',
795
+ name: 'Qwen 3 32B (Groq)',
796
+ description: 'Alibaba Qwen 3 32B via Groq',
797
+ maxTokens: 8192,
798
+ contextWindow: 128000,
799
+ supportsTools: true,
800
+ supportsVision: false,
801
+ pricing: { input: 0, output: 0 },
802
+ isFree: true,
803
+ backend: 'groq'
804
+ },
805
+ {
806
+ id: 'moonshotai/kimi-k2-instruct',
807
+ name: 'Kimi K2 (Groq)',
808
+ description: 'Moonshot Kimi K2 Instruct via Groq',
809
+ maxTokens: 8192,
810
+ contextWindow: 128000,
811
+ supportsTools: true,
812
+ supportsVision: false,
813
+ pricing: { input: 0, output: 0 },
814
+ isFree: true,
815
+ backend: 'groq'
816
+ },
817
+ {
818
+ id: 'gemini-2.0-flash',
819
+ name: 'Gemini 2.0 Flash',
820
+ description: 'Google Gemini 2.0 Flash - 1M context (Google AI Studio)',
821
+ maxTokens: 8192,
822
+ contextWindow: 1000000,
823
+ supportsTools: true,
824
+ supportsVision: true,
825
+ pricing: { input: 0, output: 0 },
826
+ isFree: true,
827
+ backend: 'google'
828
+ },
829
+ {
830
+ id: 'gemini-2.5-flash-preview-05-20',
831
+ name: 'Gemini 2.5 Flash Preview',
832
+ description: 'Google Gemini 2.5 Flash Preview (Google AI Studio)',
833
+ maxTokens: 8192,
834
+ contextWindow: 1000000,
835
+ supportsTools: true,
836
+ supportsVision: true,
837
+ pricing: { input: 0, output: 0 },
838
+ isFree: true,
839
+ backend: 'google'
840
+ },
841
+ {
842
+ id: 'gemini-2.5-pro-preview-05-06',
843
+ name: 'Gemini 2.5 Pro Preview',
844
+ description: 'Google Gemini 2.5 Pro Preview (Google AI Studio)',
845
+ maxTokens: 8192,
846
+ contextWindow: 1000000,
847
+ supportsTools: true,
848
+ supportsVision: true,
849
+ pricing: { input: 0, output: 0 },
850
+ isFree: true,
851
+ backend: 'google'
852
+ },
853
+ {
854
+ id: 'llama-3.3-70b',
855
+ name: 'Llama 3.3 70B (Cerebras)',
856
+ description: 'Llama 3.3 70B via Cerebras - ultra fast',
857
+ maxTokens: 8192,
858
+ contextWindow: 128000,
859
+ supportsTools: true,
860
+ supportsVision: false,
861
+ pricing: { input: 0, output: 0 },
862
+ isFree: true,
863
+ backend: 'cerebras'
864
+ },
865
+ {
866
+ id: 'llama3.1-8b',
867
+ name: 'Llama 3.1 8B (Cerebras)',
868
+ description: 'Llama 3.1 8B via Cerebras - ultra fast',
869
+ maxTokens: 8192,
870
+ contextWindow: 128000,
871
+ supportsTools: true,
872
+ supportsVision: false,
873
+ pricing: { input: 0, output: 0 },
874
+ isFree: true,
875
+ backend: 'cerebras'
876
+ },
877
+ {
878
+ id: 'qwen-3-235b-a22b-instruct',
879
+ name: 'Qwen 3 235B (Cerebras)',
880
+ description: 'Qwen 3 235B A22B Instruct via Cerebras',
881
+ maxTokens: 8192,
882
+ contextWindow: 128000,
883
+ supportsTools: true,
884
+ supportsVision: false,
885
+ pricing: { input: 0, output: 0 },
886
+ isFree: true,
887
+ backend: 'cerebras'
888
+ }
889
+ ];
890
+
891
+ export class FreeModelsProvider {
892
+ private client: OpenAI | null = null;
893
+ private config: ProviderConfig;
894
+ private activeBackend: string = 'openrouter';
895
+ private apiKeys: Record<string, string> = {};
896
+
897
+ constructor(config: ProviderConfig = {}) {
898
+ this.config = config;
899
+ this.loadApiKeys();
900
+ this.initializeClient();
901
+ }
902
+
903
+ private loadApiKeys(): void {
904
+ this.apiKeys = {
905
+ openrouter: this.config.apiKey || process.env.OPENROUTER_API_KEY || '',
906
+ ollama: process.env.OLLAMA_API_KEY || '',
907
+ nvidia: process.env.NVIDIA_API_KEY || '',
908
+ groq: process.env.GROQ_API_KEY || '',
909
+ google: process.env.GOOGLE_API_KEY || '',
910
+ cerebras: process.env.CEREBRAS_API_KEY || '',
911
+ cloudflare: process.env.CLOUDFLARE_API_KEY || '',
912
+ };
913
+ }
914
+
915
+ setApiKey(backend: string, apiKey: string): void {
916
+ this.apiKeys[backend] = apiKey;
917
+ if (this.activeBackend === backend) {
918
+ this.initializeClient();
919
+ }
920
+ }
921
+
922
+ getApiKey(backend: string): string {
923
+ return this.apiKeys[backend] || '';
924
+ }
925
+
926
+ private initializeClient(): void {
927
+ const backendConfig = FREE_MODEL_CONFIGS[this.activeBackend];
928
+ const baseUrl = this.config.baseUrl || backendConfig?.baseUrl || FREE_MODEL_CONFIGS.openrouter.baseUrl;
929
+
930
+ let apiKey = this.config.apiKey || this.apiKeys[this.activeBackend] || '';
931
+
932
+ const headers: Record<string, string> = {
933
+ ...(this.config.customHeaders || {})
934
+ };
935
+
936
+ if (this.activeBackend === 'openrouter') {
937
+ headers['HTTP-Referer'] = 'https://codex-linux.app';
938
+ headers['X-Title'] = 'Codex Linux';
939
+ }
940
+
941
+ this.client = new OpenAI({
942
+ apiKey: apiKey || 'sk-dummy-key',
943
+ baseURL: baseUrl,
944
+ timeout: this.config.timeout || 60000,
945
+ maxRetries: this.config.maxRetries || 3,
946
+ defaultHeaders: headers
947
+ });
948
+ }
949
+
950
+ setBackend(backend: string, apiKey?: string): void {
951
+ const backendConfig = FREE_MODEL_CONFIGS[backend];
952
+ if (!backendConfig) {
953
+ throw new Error(`Unknown backend: ${backend}`);
954
+ }
955
+
956
+ this.activeBackend = backend;
957
+ if (apiKey) {
958
+ this.apiKeys[backend] = apiKey;
959
+ }
960
+ this.config.baseUrl = backendConfig.baseUrl;
961
+ this.config.apiKey = this.apiKeys[backend] || '';
962
+ this.initializeClient();
963
+ }
964
+
965
+ async sendMessage(
966
+ model: string,
967
+ messages: Array<{ role: string; content: string }>,
968
+ options?: {
969
+ signal?: AbortSignal;
970
+ onProgress?: (progress: number) => void;
971
+ extendedThinking?: boolean;
972
+ reasoningEffort?: 'low' | 'medium' | 'high';
973
+ }
974
+ ): Promise<{ content: string; metadata?: Record<string, any> }> {
975
+ if (!this.client) {
976
+ throw new Error('Client not initialized');
977
+ }
978
+
979
+ const openaiMessages = messages.map(m => ({
980
+ role: m.role as 'user' | 'assistant' | 'system',
981
+ content: m.content
982
+ }));
983
+
984
+ const requestParams: any = {
985
+ model,
986
+ messages: openaiMessages,
987
+ stream: false
988
+ };
989
+
990
+ const isNvidiaBackend = this.activeBackend === 'nvidia';
991
+ const supportsThinking = model.includes('kimi-k2') || model.includes('deepseek-r1');
992
+
993
+ if (options?.extendedThinking) {
994
+ if (isNvidiaBackend && supportsThinking) {
995
+ requestParams.chat_template_kwargs = { thinking: true };
996
+ } else if (model.includes('deepseek-r1') || model.includes('qwq')) {
997
+ requestParams.reasoning_effort = options.reasoningEffort || 'medium';
998
+ }
999
+ }
1000
+
1001
+ if (isNvidiaBackend) {
1002
+ requestParams.max_tokens = requestParams.max_tokens || 16384;
1003
+ requestParams.temperature = 1.0;
1004
+ requestParams.top_p = 1.0;
1005
+ }
1006
+
1007
+ try {
1008
+ const response = await this.client.chat.completions.create(requestParams, {
1009
+ signal: options?.signal
1010
+ });
1011
+
1012
+ const content = response.choices[0]?.message?.content || '';
1013
+ const reasoning = (response.choices[0]?.message as any)?.reasoning_content;
1014
+
1015
+ return {
1016
+ content,
1017
+ metadata: {
1018
+ model: response.model,
1019
+ usage: response.usage,
1020
+ finishReason: response.choices[0]?.finish_reason,
1021
+ reasoning: reasoning || null,
1022
+ extendedThinking: options?.extendedThinking || false,
1023
+ reasoningEffort: options?.reasoningEffort,
1024
+ backend: this.activeBackend
1025
+ }
1026
+ };
1027
+ } catch (error: any) {
1028
+ log.error('FreeModelsProvider sendMessage error:', error);
1029
+ throw error;
1030
+ }
1031
+ }
1032
+
1033
+ async sendMessageStream(
1034
+ model: string,
1035
+ messages: Array<{ role: string; content: string }>,
1036
+ callbacks?: {
1037
+ onChunk?: (chunk: string) => void;
1038
+ onComplete?: () => void;
1039
+ onError?: (error: Error) => void;
1040
+ }
1041
+ ): Promise<{ content: string }> {
1042
+ if (!this.client) {
1043
+ throw new Error('Client not initialized');
1044
+ }
1045
+
1046
+ const openaiMessages = messages.map(m => ({
1047
+ role: m.role as 'user' | 'assistant' | 'system',
1048
+ content: m.content
1049
+ }));
1050
+
1051
+ let fullContent = '';
1052
+
1053
+ try {
1054
+ const stream = await this.client.chat.completions.create({
1055
+ model,
1056
+ messages: openaiMessages,
1057
+ stream: true
1058
+ });
1059
+
1060
+ for await (const chunk of stream) {
1061
+ const content = chunk.choices[0]?.delta?.content || '';
1062
+ if (content) {
1063
+ fullContent += content;
1064
+ callbacks?.onChunk?.(content);
1065
+ }
1066
+ }
1067
+
1068
+ callbacks?.onComplete?.();
1069
+ return { content: fullContent };
1070
+ } catch (error: any) {
1071
+ callbacks?.onError?.(error);
1072
+ throw error;
1073
+ }
1074
+ }
1075
+
1076
+ listModels(): ProviderModel[] {
1077
+ return FREE_MODELS;
1078
+ }
1079
+
1080
+ async fetchOllamaModels(): Promise<ProviderModel[]> {
1081
+ const ollamaUrl = this.config.baseUrl?.replace('/v1', '') || 'http://localhost:11434';
1082
+ const headers: Record<string, string> = {};
1083
+ if (this.apiKeys.ollama) {
1084
+ headers['Authorization'] = `Bearer ${this.apiKeys.ollama}`;
1085
+ }
1086
+
1087
+ try {
1088
+ const response = await fetch(`${ollamaUrl}/api/tags`, {
1089
+ headers,
1090
+ signal: AbortSignal.timeout(5000)
1091
+ });
1092
+
1093
+ if (!response.ok) {
1094
+ return [];
1095
+ }
1096
+
1097
+ const data = await response.json() as { models: Array<{ name: string; details?: any }> };
1098
+
1099
+ return (data.models || []).map(model => ({
1100
+ id: model.name,
1101
+ name: `${model.name} (Ollama Local)`,
1102
+ description: `Local Ollama model: ${model.name}`,
1103
+ maxTokens: 8192,
1104
+ contextWindow: 32768,
1105
+ supportsTools: true,
1106
+ supportsVision: false,
1107
+ pricing: { input: 0, output: 0 },
1108
+ isFree: true,
1109
+ backend: 'ollama'
1110
+ }));
1111
+ } catch (error) {
1112
+ log.warn('Failed to fetch Ollama models:', error);
1113
+ return [];
1114
+ }
1115
+ }
1116
+
1117
+ getBackends(): { id: string; name: string; requiresApiKey: boolean; description: string }[] {
1118
+ return Object.entries(FREE_MODEL_CONFIGS).map(([id, config]) => ({
1119
+ id,
1120
+ name: config.provider,
1121
+ requiresApiKey: config.requiresApiKey,
1122
+ description: config.description
1123
+ }));
1124
+ }
1125
+
1126
+ async testConnection(): Promise<boolean> {
1127
+ if (!this.client) {
1128
+ return false;
1129
+ }
1130
+
1131
+ const testModels: Record<string, string> = {
1132
+ openrouter: 'meta-llama/llama-3.3-70b-instruct:free',
1133
+ ollama: 'llama3.2:latest',
1134
+ nvidia: 'meta/llama-3.3-70b-instruct',
1135
+ groq: 'llama-3.1-8b-instant',
1136
+ google: 'gemini-2.0-flash',
1137
+ cerebras: 'llama-3.3-70b',
1138
+ cloudflare: '@cf/meta/llama-3.1-8b-instruct'
1139
+ };
1140
+
1141
+ try {
1142
+ const testModel = testModels[this.activeBackend] || 'meta-llama/llama-3.3-70b-instruct:free';
1143
+ const response = await this.client.chat.completions.create({
1144
+ model: testModel,
1145
+ messages: [{ role: 'user', content: 'test' }],
1146
+ max_tokens: 1
1147
+ });
1148
+ return true;
1149
+ } catch (error: any) {
1150
+ log.warn('FreeModelsProvider connection test failed:', error.message);
1151
+ return error.status !== 401;
1152
+ }
1153
+ }
1154
+ }
1155
+
1156
+ export { FREE_MODELS, FREE_MODEL_CONFIGS };