fss-link 1.0.49 → 1.0.51
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.
- package/dist/index.js +0 -0
- package/dist/package.json +2 -2
- package/dist/src/config/auth.js +8 -5
- package/dist/src/config/auth.js.map +1 -1
- package/dist/src/config/database.d.ts +103 -11
- package/dist/src/config/database.js +301 -59
- package/dist/src/config/database.js.map +1 -1
- package/dist/src/config/databaseBackup.d.ts +114 -0
- package/dist/src/config/databaseBackup.js +334 -0
- package/dist/src/config/databaseBackup.js.map +1 -0
- package/dist/src/config/databaseMigrations.d.ts +63 -0
- package/dist/src/config/databaseMigrations.js +379 -0
- package/dist/src/config/databaseMigrations.js.map +1 -0
- package/dist/src/config/databasePool.d.ts +70 -0
- package/dist/src/config/databasePool.js +193 -0
- package/dist/src/config/databasePool.js.map +1 -0
- package/dist/src/config/queryOptimizer.d.ts +127 -0
- package/dist/src/config/queryOptimizer.js +309 -0
- package/dist/src/config/queryOptimizer.js.map +1 -0
- package/dist/src/utils/sandbox.js +2 -8
- package/dist/src/utils/sandbox.js.map +1 -1
- package/dist/src/validateNonInterActiveAuth.js +3 -7
- package/dist/src/validateNonInterActiveAuth.js.map +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +2 -2
- package/dist/commands/mcp/add.test.ts +0 -122
- package/dist/commands/mcp/add.ts +0 -222
- package/dist/commands/mcp/list.test.ts +0 -154
- package/dist/commands/mcp/list.ts +0 -139
- package/dist/commands/mcp/remove.test.ts +0 -69
- package/dist/commands/mcp/remove.ts +0 -60
- package/dist/commands/mcp.test.ts +0 -55
- package/dist/commands/mcp.ts +0 -27
- package/dist/config/apiValidation.test.ts +0 -118
- package/dist/config/auth.test.ts +0 -79
- package/dist/config/auth.ts +0 -100
- package/dist/config/config.integration.test.ts +0 -407
- package/dist/config/config.test.ts +0 -1952
- package/dist/config/config.ts +0 -690
- package/dist/config/database.test.ts +0 -96
- package/dist/config/database.ts +0 -824
- package/dist/config/extension.test.ts +0 -236
- package/dist/config/extension.ts +0 -180
- package/dist/config/keyBindings.test.ts +0 -62
- package/dist/config/keyBindings.ts +0 -184
- package/dist/config/modelManager.ts +0 -326
- package/dist/config/providerManager.ts +0 -244
- package/dist/config/providerPersistence.test.ts +0 -377
- package/dist/config/providerPersistence.ts +0 -105
- package/dist/config/sandboxConfig.ts +0 -107
- package/dist/config/settings.test.ts +0 -1424
- package/dist/config/settings.ts +0 -517
- package/dist/config/settingsSchema.test.ts +0 -252
- package/dist/config/settingsSchema.ts +0 -728
- package/dist/config/trustedFolders.test.ts +0 -208
- package/dist/config/trustedFolders.ts +0 -167
- package/dist/gemini.test.tsx +0 -252
- package/dist/gemini.tsx +0 -357
- package/dist/generated/git-commit.ts +0 -10
- package/dist/index.ts +0 -21
- package/dist/nonInteractiveCli.test.ts +0 -276
- package/dist/nonInteractiveCli.ts +0 -143
- package/dist/patches/is-in-ci.ts +0 -17
- package/dist/services/BuiltinCommandLoader.test.ts +0 -127
- package/dist/services/BuiltinCommandLoader.ts +0 -95
- package/dist/services/CommandService.test.ts +0 -352
- package/dist/services/CommandService.ts +0 -103
- package/dist/services/FileCommandLoader.test.ts +0 -1002
- package/dist/services/FileCommandLoader.ts +0 -289
- package/dist/services/McpPromptLoader.ts +0 -231
- package/dist/services/SearchEngineConfigProvider.ts +0 -100
- package/dist/services/prompt-processors/argumentProcessor.test.ts +0 -41
- package/dist/services/prompt-processors/argumentProcessor.ts +0 -23
- package/dist/services/prompt-processors/shellProcessor.test.ts +0 -709
- package/dist/services/prompt-processors/shellProcessor.ts +0 -248
- package/dist/services/prompt-processors/types.ts +0 -44
- package/dist/services/types.ts +0 -24
- package/dist/src/config/apiValidation.test.d.ts +0 -6
- package/dist/src/config/apiValidation.test.js +0 -99
- package/dist/src/config/apiValidation.test.js.map +0 -1
- package/dist/src/config/database.test.d.ts +0 -6
- package/dist/src/config/database.test.js +0 -80
- package/dist/src/config/database.test.js.map +0 -1
- package/dist/src/config/providerManager.d.ts +0 -74
- package/dist/src/config/providerManager.js +0 -203
- package/dist/src/config/providerManager.js.map +0 -1
- package/dist/src/config/providerPersistence.test.d.ts +0 -6
- package/dist/src/config/providerPersistence.test.js +0 -283
- package/dist/src/config/providerPersistence.test.js.map +0 -1
- package/dist/src/ui/components/GeminiKeyDialog.d.ts +0 -11
- package/dist/src/ui/components/GeminiKeyDialog.js +0 -156
- package/dist/src/ui/components/GeminiKeyDialog.js.map +0 -1
- package/dist/src/ui/components/OpenAIEndpointDialog.d.ts +0 -19
- package/dist/src/ui/components/OpenAIEndpointDialog.js +0 -163
- package/dist/src/ui/components/OpenAIEndpointDialog.js.map +0 -1
- package/dist/test-setup.ts +0 -12
- package/dist/test-utils/customMatchers.ts +0 -65
- package/dist/test-utils/mockCommandContext.test.ts +0 -62
- package/dist/test-utils/mockCommandContext.ts +0 -105
- package/dist/test-utils/render.tsx +0 -18
- package/dist/ui/App.test.tsx +0 -2181
- package/dist/ui/App.tsx +0 -1344
- package/dist/ui/IdeIntegrationNudge.tsx +0 -98
- package/dist/ui/__snapshots__/App.test.tsx.snap +0 -124
- package/dist/ui/colors.ts +0 -56
- package/dist/ui/commands/aboutCommand.test.ts +0 -153
- package/dist/ui/commands/aboutCommand.ts +0 -49
- package/dist/ui/commands/authCommand.test.ts +0 -36
- package/dist/ui/commands/authCommand.ts +0 -17
- package/dist/ui/commands/bugCommand.test.ts +0 -114
- package/dist/ui/commands/bugCommand.ts +0 -92
- package/dist/ui/commands/chatCommand.test.ts +0 -414
- package/dist/ui/commands/chatCommand.ts +0 -280
- package/dist/ui/commands/clearCommand.test.ts +0 -100
- package/dist/ui/commands/clearCommand.ts +0 -29
- package/dist/ui/commands/compressCommand.test.ts +0 -129
- package/dist/ui/commands/compressCommand.ts +0 -78
- package/dist/ui/commands/contextCommand.ts +0 -132
- package/dist/ui/commands/copyCommand.test.ts +0 -296
- package/dist/ui/commands/copyCommand.ts +0 -67
- package/dist/ui/commands/corgiCommand.test.ts +0 -34
- package/dist/ui/commands/corgiCommand.ts +0 -16
- package/dist/ui/commands/directoryCommand.test.tsx +0 -185
- package/dist/ui/commands/directoryCommand.tsx +0 -179
- package/dist/ui/commands/docsCommand.test.ts +0 -99
- package/dist/ui/commands/docsCommand.ts +0 -42
- package/dist/ui/commands/editorCommand.test.ts +0 -30
- package/dist/ui/commands/editorCommand.ts +0 -21
- package/dist/ui/commands/extensionsCommand.test.ts +0 -67
- package/dist/ui/commands/extensionsCommand.ts +0 -46
- package/dist/ui/commands/helpCommand.test.ts +0 -52
- package/dist/ui/commands/helpCommand.ts +0 -23
- package/dist/ui/commands/ideCommand.test.ts +0 -255
- package/dist/ui/commands/ideCommand.ts +0 -283
- package/dist/ui/commands/initCommand.test.ts +0 -127
- package/dist/ui/commands/initCommand.ts +0 -117
- package/dist/ui/commands/mcpCommand.test.ts +0 -1057
- package/dist/ui/commands/mcpCommand.ts +0 -531
- package/dist/ui/commands/memoryCommand.test.ts +0 -344
- package/dist/ui/commands/memoryCommand.ts +0 -305
- package/dist/ui/commands/privacyCommand.test.ts +0 -38
- package/dist/ui/commands/privacyCommand.ts +0 -17
- package/dist/ui/commands/quitCommand.test.ts +0 -55
- package/dist/ui/commands/quitCommand.ts +0 -36
- package/dist/ui/commands/restoreCommand.test.ts +0 -250
- package/dist/ui/commands/restoreCommand.ts +0 -157
- package/dist/ui/commands/searchEngineSetupCommand.ts +0 -18
- package/dist/ui/commands/settingsCommand.test.ts +0 -36
- package/dist/ui/commands/settingsCommand.ts +0 -17
- package/dist/ui/commands/setupGithubCommand.test.ts +0 -238
- package/dist/ui/commands/setupGithubCommand.ts +0 -212
- package/dist/ui/commands/speakCommand.ts +0 -175
- package/dist/ui/commands/statsCommand.test.ts +0 -78
- package/dist/ui/commands/statsCommand.ts +0 -70
- package/dist/ui/commands/terminalSetupCommand.test.ts +0 -85
- package/dist/ui/commands/terminalSetupCommand.ts +0 -45
- package/dist/ui/commands/themeCommand.test.ts +0 -38
- package/dist/ui/commands/themeCommand.ts +0 -17
- package/dist/ui/commands/toolsCommand.test.ts +0 -105
- package/dist/ui/commands/toolsCommand.ts +0 -71
- package/dist/ui/commands/ttsCommand.ts +0 -143
- package/dist/ui/commands/types.ts +0 -204
- package/dist/ui/commands/vimCommand.ts +0 -25
- package/dist/ui/commands/voiceCommand.ts +0 -125
- package/dist/ui/components/AboutBox.tsx +0 -133
- package/dist/ui/components/AsciiArt.ts +0 -54
- package/dist/ui/components/AuthDialog.test.tsx +0 -334
- package/dist/ui/components/AuthDialog.tsx +0 -289
- package/dist/ui/components/AuthInProgress.tsx +0 -62
- package/dist/ui/components/AutoAcceptIndicator.tsx +0 -47
- package/dist/ui/components/ConsoleSummaryDisplay.tsx +0 -35
- package/dist/ui/components/ContextSummaryDisplay.test.tsx +0 -85
- package/dist/ui/components/ContextSummaryDisplay.tsx +0 -120
- package/dist/ui/components/ContextUsageDisplay.tsx +0 -77
- package/dist/ui/components/DebugProfiler.tsx +0 -36
- package/dist/ui/components/DetailedMessagesDisplay.tsx +0 -82
- package/dist/ui/components/EditorSettingsDialog.tsx +0 -172
- package/dist/ui/components/FolderTrustDialog.test.tsx +0 -36
- package/dist/ui/components/FolderTrustDialog.tsx +0 -74
- package/dist/ui/components/Footer.test.tsx +0 -159
- package/dist/ui/components/Footer.tsx +0 -158
- package/dist/ui/components/GeminiKeyDialog.tsx +0 -252
- package/dist/ui/components/GeminiRespondingSpinner.tsx +0 -34
- package/dist/ui/components/Header.test.tsx +0 -44
- package/dist/ui/components/Header.tsx +0 -70
- package/dist/ui/components/Help.tsx +0 -174
- package/dist/ui/components/HistoryItemDisplay.test.tsx +0 -125
- package/dist/ui/components/HistoryItemDisplay.tsx +0 -98
- package/dist/ui/components/InputPrompt.test.tsx +0 -1467
- package/dist/ui/components/InputPrompt.tsx +0 -641
- package/dist/ui/components/LMStudioModelPrompt.tsx +0 -215
- package/dist/ui/components/LoadingIndicator.test.tsx +0 -296
- package/dist/ui/components/LoadingIndicator.tsx +0 -82
- package/dist/ui/components/MemoryUsageDisplay.tsx +0 -36
- package/dist/ui/components/ModelStatsDisplay.test.tsx +0 -252
- package/dist/ui/components/ModelStatsDisplay.tsx +0 -197
- package/dist/ui/components/OllamaModelPrompt.tsx +0 -206
- package/dist/ui/components/OpenAIEndpointDialog.tsx +0 -261
- package/dist/ui/components/OpenAIKeyPrompt.test.tsx +0 -64
- package/dist/ui/components/OpenAIKeyPrompt.tsx +0 -197
- package/dist/ui/components/PrepareLabel.tsx +0 -48
- package/dist/ui/components/SearchEngineConfigDialog.tsx +0 -280
- package/dist/ui/components/SessionSummaryDisplay.test.tsx +0 -75
- package/dist/ui/components/SessionSummaryDisplay.tsx +0 -18
- package/dist/ui/components/SettingsDialog.test.tsx +0 -865
- package/dist/ui/components/SettingsDialog.tsx +0 -753
- package/dist/ui/components/ShellConfirmationDialog.test.tsx +0 -53
- package/dist/ui/components/ShellConfirmationDialog.tsx +0 -103
- package/dist/ui/components/ShellModeIndicator.tsx +0 -18
- package/dist/ui/components/ShowMoreLines.tsx +0 -40
- package/dist/ui/components/StatsDisplay.test.tsx +0 -401
- package/dist/ui/components/StatsDisplay.tsx +0 -273
- package/dist/ui/components/SuggestionsDisplay.tsx +0 -102
- package/dist/ui/components/ThemeDialog.tsx +0 -310
- package/dist/ui/components/Tips.tsx +0 -45
- package/dist/ui/components/TodoDisplay.test.tsx +0 -97
- package/dist/ui/components/TodoDisplay.tsx +0 -72
- package/dist/ui/components/ToolStatsDisplay.test.tsx +0 -180
- package/dist/ui/components/ToolStatsDisplay.tsx +0 -208
- package/dist/ui/components/UpdateNotification.tsx +0 -23
- package/dist/ui/components/WelcomeBackDialog.tsx +0 -290
- package/dist/ui/components/__snapshots__/IDEContextDetailDisplay.test.tsx.snap +0 -24
- package/dist/ui/components/__snapshots__/ModelStatsDisplay.test.tsx.snap +0 -121
- package/dist/ui/components/__snapshots__/SessionSummaryDisplay.test.tsx.snap +0 -30
- package/dist/ui/components/__snapshots__/ShellConfirmationDialog.test.tsx.snap +0 -21
- package/dist/ui/components/__snapshots__/StatsDisplay.test.tsx.snap +0 -264
- package/dist/ui/components/__snapshots__/ToolStatsDisplay.test.tsx.snap +0 -91
- package/dist/ui/components/messages/CompressionMessage.tsx +0 -49
- package/dist/ui/components/messages/DiffRenderer.test.tsx +0 -365
- package/dist/ui/components/messages/DiffRenderer.tsx +0 -358
- package/dist/ui/components/messages/ErrorMessage.tsx +0 -31
- package/dist/ui/components/messages/GeminiMessage.tsx +0 -43
- package/dist/ui/components/messages/GeminiMessageContent.tsx +0 -43
- package/dist/ui/components/messages/InfoMessage.tsx +0 -32
- package/dist/ui/components/messages/ToolConfirmationMessage.test.tsx +0 -58
- package/dist/ui/components/messages/ToolConfirmationMessage.tsx +0 -297
- package/dist/ui/components/messages/ToolGroupMessage.tsx +0 -126
- package/dist/ui/components/messages/ToolMessage.test.tsx +0 -183
- package/dist/ui/components/messages/ToolMessage.tsx +0 -296
- package/dist/ui/components/messages/UserMessage.tsx +0 -43
- package/dist/ui/components/messages/UserShellMessage.tsx +0 -25
- package/dist/ui/components/shared/MaxSizedBox.test.tsx +0 -425
- package/dist/ui/components/shared/MaxSizedBox.tsx +0 -624
- package/dist/ui/components/shared/RadioButtonSelect.test.tsx +0 -181
- package/dist/ui/components/shared/RadioButtonSelect.tsx +0 -234
- package/dist/ui/components/shared/__snapshots__/RadioButtonSelect.test.tsx.snap +0 -47
- package/dist/ui/components/shared/text-buffer.test.ts +0 -1728
- package/dist/ui/components/shared/text-buffer.ts +0 -2227
- package/dist/ui/components/shared/vim-buffer-actions.test.ts +0 -1119
- package/dist/ui/components/shared/vim-buffer-actions.ts +0 -814
- package/dist/ui/constants.ts +0 -17
- package/dist/ui/contexts/KeypressContext.test.tsx +0 -391
- package/dist/ui/contexts/KeypressContext.tsx +0 -440
- package/dist/ui/contexts/OverflowContext.tsx +0 -87
- package/dist/ui/contexts/SessionContext.test.tsx +0 -132
- package/dist/ui/contexts/SessionContext.tsx +0 -143
- package/dist/ui/contexts/SettingsContext.tsx +0 -20
- package/dist/ui/contexts/StreamingContext.tsx +0 -22
- package/dist/ui/contexts/VimModeContext.tsx +0 -79
- package/dist/ui/editors/editorSettingsManager.ts +0 -66
- package/dist/ui/hooks/atCommandProcessor.test.ts +0 -1102
- package/dist/ui/hooks/atCommandProcessor.ts +0 -485
- package/dist/ui/hooks/shellCommandProcessor.test.ts +0 -481
- package/dist/ui/hooks/shellCommandProcessor.ts +0 -314
- package/dist/ui/hooks/slashCommandProcessor.test.ts +0 -1044
- package/dist/ui/hooks/slashCommandProcessor.ts +0 -595
- package/dist/ui/hooks/useAtCompletion.test.ts +0 -497
- package/dist/ui/hooks/useAtCompletion.ts +0 -244
- package/dist/ui/hooks/useAuthCommand.ts +0 -129
- package/dist/ui/hooks/useAutoAcceptIndicator.test.ts +0 -300
- package/dist/ui/hooks/useAutoAcceptIndicator.ts +0 -52
- package/dist/ui/hooks/useBracketedPaste.ts +0 -37
- package/dist/ui/hooks/useCommandCompletion.test.ts +0 -518
- package/dist/ui/hooks/useCommandCompletion.tsx +0 -238
- package/dist/ui/hooks/useCompletion.ts +0 -128
- package/dist/ui/hooks/useConsoleMessages.test.ts +0 -147
- package/dist/ui/hooks/useConsoleMessages.ts +0 -110
- package/dist/ui/hooks/useEditorSettings.test.ts +0 -283
- package/dist/ui/hooks/useEditorSettings.ts +0 -75
- package/dist/ui/hooks/useFocus.test.ts +0 -119
- package/dist/ui/hooks/useFocus.ts +0 -48
- package/dist/ui/hooks/useFolderTrust.test.ts +0 -159
- package/dist/ui/hooks/useFolderTrust.ts +0 -72
- package/dist/ui/hooks/useGeminiStream.test.tsx +0 -1998
- package/dist/ui/hooks/useGeminiStream.ts +0 -1017
- package/dist/ui/hooks/useGitBranchName.test.ts +0 -280
- package/dist/ui/hooks/useGitBranchName.ts +0 -79
- package/dist/ui/hooks/useHistoryManager.test.ts +0 -202
- package/dist/ui/hooks/useHistoryManager.ts +0 -111
- package/dist/ui/hooks/useInputHistory.test.ts +0 -261
- package/dist/ui/hooks/useInputHistory.ts +0 -111
- package/dist/ui/hooks/useKeypress.test.ts +0 -280
- package/dist/ui/hooks/useKeypress.ts +0 -39
- package/dist/ui/hooks/useKittyKeyboardProtocol.ts +0 -31
- package/dist/ui/hooks/useLoadingIndicator.test.ts +0 -139
- package/dist/ui/hooks/useLoadingIndicator.ts +0 -57
- package/dist/ui/hooks/useLogger.ts +0 -32
- package/dist/ui/hooks/useMessageQueue.test.ts +0 -226
- package/dist/ui/hooks/useMessageQueue.ts +0 -69
- package/dist/ui/hooks/usePhraseCycler.test.ts +0 -145
- package/dist/ui/hooks/usePhraseCycler.ts +0 -198
- package/dist/ui/hooks/usePrivacySettings.test.ts +0 -242
- package/dist/ui/hooks/usePrivacySettings.ts +0 -150
- package/dist/ui/hooks/useReactToolScheduler.ts +0 -309
- package/dist/ui/hooks/useRefreshMemoryCommand.ts +0 -7
- package/dist/ui/hooks/useReverseSearchCompletion.test.tsx +0 -260
- package/dist/ui/hooks/useReverseSearchCompletion.tsx +0 -95
- package/dist/ui/hooks/useSettingsCommand.ts +0 -25
- package/dist/ui/hooks/useShellHistory.test.ts +0 -219
- package/dist/ui/hooks/useShellHistory.ts +0 -133
- package/dist/ui/hooks/useShowMemoryCommand.ts +0 -75
- package/dist/ui/hooks/useSlashCompletion.test.ts +0 -434
- package/dist/ui/hooks/useSlashCompletion.ts +0 -187
- package/dist/ui/hooks/useStateAndRef.ts +0 -36
- package/dist/ui/hooks/useTerminalSize.ts +0 -32
- package/dist/ui/hooks/useThemeCommand.ts +0 -110
- package/dist/ui/hooks/useTimer.test.ts +0 -120
- package/dist/ui/hooks/useTimer.ts +0 -65
- package/dist/ui/hooks/useToolScheduler.test.ts +0 -1123
- package/dist/ui/hooks/useWelcomeBack.ts +0 -253
- package/dist/ui/hooks/vim.test.ts +0 -1691
- package/dist/ui/hooks/vim.ts +0 -784
- package/dist/ui/keyMatchers.test.ts +0 -337
- package/dist/ui/keyMatchers.ts +0 -105
- package/dist/ui/privacy/CloudFreePrivacyNotice.tsx +0 -117
- package/dist/ui/privacy/CloudPaidPrivacyNotice.tsx +0 -59
- package/dist/ui/privacy/GeminiPrivacyNotice.tsx +0 -62
- package/dist/ui/privacy/PrivacyNotice.tsx +0 -42
- package/dist/ui/semantic-colors.ts +0 -26
- package/dist/ui/themes/ansi-light.ts +0 -150
- package/dist/ui/themes/ansi.ts +0 -159
- package/dist/ui/themes/atom-one-dark.ts +0 -147
- package/dist/ui/themes/ayu-light.ts +0 -139
- package/dist/ui/themes/ayu.ts +0 -113
- package/dist/ui/themes/color-utils.test.ts +0 -221
- package/dist/ui/themes/color-utils.ts +0 -231
- package/dist/ui/themes/default-light.ts +0 -108
- package/dist/ui/themes/default.ts +0 -151
- package/dist/ui/themes/dracula.ts +0 -124
- package/dist/ui/themes/fss-code-dark.ts +0 -156
- package/dist/ui/themes/fss-dark.ts +0 -113
- package/dist/ui/themes/fss-light.ts +0 -139
- package/dist/ui/themes/github-dark.ts +0 -147
- package/dist/ui/themes/github-light.ts +0 -149
- package/dist/ui/themes/googlecode.ts +0 -146
- package/dist/ui/themes/no-color.ts +0 -125
- package/dist/ui/themes/qwen-dark.ts +0 -118
- package/dist/ui/themes/qwen-light.ts +0 -144
- package/dist/ui/themes/semantic-tokens.ts +0 -127
- package/dist/ui/themes/shades-of-purple.ts +0 -352
- package/dist/ui/themes/theme-manager.test.ts +0 -99
- package/dist/ui/themes/theme-manager.ts +0 -257
- package/dist/ui/themes/theme.test.ts +0 -97
- package/dist/ui/themes/theme.ts +0 -451
- package/dist/ui/themes/xcode.ts +0 -154
- package/dist/ui/types.ts +0 -255
- package/dist/ui/utils/CodeColorizer.tsx +0 -217
- package/dist/ui/utils/ConsolePatcher.ts +0 -71
- package/dist/ui/utils/InlineMarkdownRenderer.tsx +0 -173
- package/dist/ui/utils/MarkdownDisplay.test.tsx +0 -244
- package/dist/ui/utils/MarkdownDisplay.tsx +0 -415
- package/dist/ui/utils/TableRenderer.tsx +0 -159
- package/dist/ui/utils/__snapshots__/MarkdownDisplay.test.tsx.snap +0 -93
- package/dist/ui/utils/clipboardUtils.test.ts +0 -76
- package/dist/ui/utils/clipboardUtils.ts +0 -149
- package/dist/ui/utils/commandUtils.test.ts +0 -384
- package/dist/ui/utils/commandUtils.ts +0 -106
- package/dist/ui/utils/computeStats.test.ts +0 -292
- package/dist/ui/utils/computeStats.ts +0 -86
- package/dist/ui/utils/displayUtils.test.ts +0 -58
- package/dist/ui/utils/displayUtils.ts +0 -32
- package/dist/ui/utils/formatters.test.ts +0 -72
- package/dist/ui/utils/formatters.ts +0 -63
- package/dist/ui/utils/isNarrowWidth.ts +0 -9
- package/dist/ui/utils/kittyProtocolDetector.ts +0 -105
- package/dist/ui/utils/markdownUtilities.test.ts +0 -50
- package/dist/ui/utils/markdownUtilities.ts +0 -125
- package/dist/ui/utils/platformConstants.ts +0 -52
- package/dist/ui/utils/terminalSetup.ts +0 -342
- package/dist/ui/utils/textUtils.ts +0 -40
- package/dist/ui/utils/updateCheck.test.ts +0 -163
- package/dist/ui/utils/updateCheck.ts +0 -100
- package/dist/utils/checks.ts +0 -28
- package/dist/utils/cleanup.test.ts +0 -68
- package/dist/utils/cleanup.ts +0 -36
- package/dist/utils/dialogScopeUtils.ts +0 -64
- package/dist/utils/events.ts +0 -14
- package/dist/utils/gitUtils.test.ts +0 -149
- package/dist/utils/gitUtils.ts +0 -116
- package/dist/utils/handleAutoUpdate.test.ts +0 -272
- package/dist/utils/handleAutoUpdate.ts +0 -145
- package/dist/utils/installationInfo.test.ts +0 -315
- package/dist/utils/installationInfo.ts +0 -176
- package/dist/utils/package.ts +0 -38
- package/dist/utils/readStdin.ts +0 -51
- package/dist/utils/resolvePath.ts +0 -21
- package/dist/utils/sandbox-macos-permissive-closed.sb +0 -32
- package/dist/utils/sandbox-macos-permissive-open.sb +0 -25
- package/dist/utils/sandbox-macos-permissive-proxied.sb +0 -37
- package/dist/utils/sandbox-macos-restrictive-closed.sb +0 -93
- package/dist/utils/sandbox-macos-restrictive-open.sb +0 -96
- package/dist/utils/sandbox-macos-restrictive-proxied.sb +0 -98
- package/dist/utils/sandbox.ts +0 -962
- package/dist/utils/settingsUtils.test.ts +0 -797
- package/dist/utils/settingsUtils.ts +0 -489
- package/dist/utils/spawnWrapper.ts +0 -9
- package/dist/utils/startupWarnings.test.ts +0 -83
- package/dist/utils/startupWarnings.ts +0 -40
- package/dist/utils/updateEventEmitter.ts +0 -13
- package/dist/utils/userStartupWarnings.test.ts +0 -87
- package/dist/utils/userStartupWarnings.ts +0 -69
- package/dist/utils/version.ts +0 -12
- package/dist/validateNonInterActiveAuth.test.ts +0 -260
- package/dist/validateNonInterActiveAuth.ts +0 -51
- package/dist/vitest.config.ts +0 -37
- package/dist/zed-integration/acp.ts +0 -366
- package/dist/zed-integration/fileSystemService.ts +0 -47
- package/dist/zed-integration/schema.ts +0 -466
- package/dist/zed-integration/zedIntegration.ts +0 -944
|
@@ -1,377 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @license
|
|
3
|
-
* Copyright 2025 Google LLC
|
|
4
|
-
* SPDX-License-Identifier: Apache-2.0
|
|
5
|
-
*/
|
|
6
|
-
|
|
7
|
-
import { describe, it, expect, beforeEach, afterEach } from 'vitest';
|
|
8
|
-
import { AuthType, ModelConfig } from 'fss-link-core';
|
|
9
|
-
import { ProviderManager } from './providerManager.js';
|
|
10
|
-
import { getFSSLinkDatabase, closeFSSLinkDatabase } from './database.js';
|
|
11
|
-
import * as fs from 'fs';
|
|
12
|
-
import * as path from 'path';
|
|
13
|
-
import * as os from 'os';
|
|
14
|
-
|
|
15
|
-
describe('Provider Persistence System', () => {
|
|
16
|
-
let providerManager: ProviderManager;
|
|
17
|
-
let testDbPath: string;
|
|
18
|
-
|
|
19
|
-
beforeEach(async () => {
|
|
20
|
-
// Create temporary database for testing
|
|
21
|
-
testDbPath = path.join(os.tmpdir(), `test-fss-link-${Date.now()}.db`);
|
|
22
|
-
|
|
23
|
-
// Override the database path for testing
|
|
24
|
-
process.env.FSS_LINK_TEST_DB = testDbPath;
|
|
25
|
-
|
|
26
|
-
providerManager = ProviderManager.getInstance();
|
|
27
|
-
|
|
28
|
-
// Initialize clean database
|
|
29
|
-
const db = await getFSSLinkDatabase();
|
|
30
|
-
await db.initialize();
|
|
31
|
-
});
|
|
32
|
-
|
|
33
|
-
afterEach(async () => {
|
|
34
|
-
// Clean up test database
|
|
35
|
-
closeFSSLinkDatabase();
|
|
36
|
-
if (fs.existsSync(testDbPath)) {
|
|
37
|
-
fs.unlinkSync(testDbPath);
|
|
38
|
-
}
|
|
39
|
-
delete process.env.FSS_LINK_TEST_DB;
|
|
40
|
-
});
|
|
41
|
-
|
|
42
|
-
describe('Provider Configuration Management', () => {
|
|
43
|
-
it('should save and retrieve provider configurations', async () => {
|
|
44
|
-
const testConfig: ModelConfig = {
|
|
45
|
-
authType: AuthType.OPENAI_API_KEY,
|
|
46
|
-
modelName: 'gpt-4',
|
|
47
|
-
endpointUrl: 'https://api.openai.com/v1',
|
|
48
|
-
apiKey: 'test-key-123',
|
|
49
|
-
displayName: 'GPT-4 Test',
|
|
50
|
-
isFavorite: false,
|
|
51
|
-
isActive: true
|
|
52
|
-
};
|
|
53
|
-
|
|
54
|
-
const providerId = await providerManager.saveProvider(testConfig);
|
|
55
|
-
expect(providerId).toBeGreaterThan(0);
|
|
56
|
-
|
|
57
|
-
const allProviders = await providerManager.getAllProviders();
|
|
58
|
-
expect(allProviders).toHaveLength(1);
|
|
59
|
-
expect(allProviders[0].modelName).toBe('gpt-4');
|
|
60
|
-
expect(allProviders[0].displayName).toBe('GPT-4 Test');
|
|
61
|
-
});
|
|
62
|
-
|
|
63
|
-
it('should handle provider updates correctly', async () => {
|
|
64
|
-
const testConfig: ModelConfig = {
|
|
65
|
-
authType: AuthType.OLLAMA,
|
|
66
|
-
modelName: 'llama2',
|
|
67
|
-
endpointUrl: 'http://localhost:11434/v1',
|
|
68
|
-
displayName: 'Llama 2 Local',
|
|
69
|
-
isFavorite: false,
|
|
70
|
-
isActive: true
|
|
71
|
-
};
|
|
72
|
-
|
|
73
|
-
const providerId = await providerManager.saveProvider(testConfig);
|
|
74
|
-
|
|
75
|
-
// Update the provider
|
|
76
|
-
await providerManager.updateProvider(providerId, {
|
|
77
|
-
modelName: 'llama2-updated',
|
|
78
|
-
isFavorite: true
|
|
79
|
-
});
|
|
80
|
-
|
|
81
|
-
const allProviders = await providerManager.getAllProviders();
|
|
82
|
-
const updated = allProviders.find(p => p.id === providerId);
|
|
83
|
-
|
|
84
|
-
expect(updated?.modelName).toBe('llama2-updated');
|
|
85
|
-
expect(updated?.isFavorite).toBe(true);
|
|
86
|
-
expect(updated?.displayName).toBe('Llama 2 Local'); // Should remain unchanged
|
|
87
|
-
});
|
|
88
|
-
|
|
89
|
-
it('should track usage statistics correctly', async () => {
|
|
90
|
-
const testConfig: ModelConfig = {
|
|
91
|
-
authType: AuthType.OPENAI_API_KEY,
|
|
92
|
-
modelName: 'gpt-3.5-turbo',
|
|
93
|
-
displayName: 'GPT-3.5 Test',
|
|
94
|
-
isActive: true
|
|
95
|
-
};
|
|
96
|
-
|
|
97
|
-
const providerId = await providerManager.saveProvider(testConfig);
|
|
98
|
-
|
|
99
|
-
// Record multiple usage sessions
|
|
100
|
-
await providerManager.recordUsage(providerId, 1000, 30000); // 1000 tokens, 30 seconds
|
|
101
|
-
await providerManager.recordUsage(providerId, 500, 15000); // 500 tokens, 15 seconds
|
|
102
|
-
await providerManager.recordUsage(providerId, 2000, 60000); // 2000 tokens, 60 seconds
|
|
103
|
-
|
|
104
|
-
const stats = await providerManager.getUsageStatistics();
|
|
105
|
-
expect(stats[providerId]).toBeDefined();
|
|
106
|
-
// Note: Actual validation depends on database implementation
|
|
107
|
-
});
|
|
108
|
-
});
|
|
109
|
-
|
|
110
|
-
describe('Custom Endpoints Management', () => {
|
|
111
|
-
it('should save and retrieve custom endpoints', async () => {
|
|
112
|
-
const testConfig: ModelConfig = {
|
|
113
|
-
authType: AuthType.OPENAI_API_KEY,
|
|
114
|
-
modelName: 'custom-model',
|
|
115
|
-
displayName: 'Custom Provider',
|
|
116
|
-
isActive: true
|
|
117
|
-
};
|
|
118
|
-
|
|
119
|
-
const providerId = await providerManager.saveProvider(testConfig);
|
|
120
|
-
|
|
121
|
-
// Add custom endpoints
|
|
122
|
-
const endpoint1Id = await providerManager.saveCustomEndpoint(
|
|
123
|
-
providerId,
|
|
124
|
-
'Production API',
|
|
125
|
-
'https://api.custom.com/v1',
|
|
126
|
-
'Production endpoint',
|
|
127
|
-
true
|
|
128
|
-
);
|
|
129
|
-
|
|
130
|
-
const endpoint2Id = await providerManager.saveCustomEndpoint(
|
|
131
|
-
providerId,
|
|
132
|
-
'Staging API',
|
|
133
|
-
'https://staging-api.custom.com/v1',
|
|
134
|
-
'Staging endpoint',
|
|
135
|
-
false
|
|
136
|
-
);
|
|
137
|
-
|
|
138
|
-
expect(endpoint1Id).toBeGreaterThan(0);
|
|
139
|
-
expect(endpoint2Id).toBeGreaterThan(0);
|
|
140
|
-
|
|
141
|
-
const endpoints = await providerManager.getCustomEndpoints(providerId);
|
|
142
|
-
expect(endpoints).toHaveLength(2);
|
|
143
|
-
|
|
144
|
-
const defaultEndpoint = endpoints.find(e => e.is_default);
|
|
145
|
-
expect(defaultEndpoint?.name).toBe('Production API');
|
|
146
|
-
});
|
|
147
|
-
|
|
148
|
-
it('should handle default endpoint switching', async () => {
|
|
149
|
-
const testConfig: ModelConfig = {
|
|
150
|
-
authType: AuthType.OPENAI_API_KEY,
|
|
151
|
-
modelName: 'test-model',
|
|
152
|
-
isActive: true
|
|
153
|
-
};
|
|
154
|
-
|
|
155
|
-
const providerId = await providerManager.saveProvider(testConfig);
|
|
156
|
-
|
|
157
|
-
// Add first endpoint as default
|
|
158
|
-
await providerManager.saveCustomEndpoint(
|
|
159
|
-
providerId,
|
|
160
|
-
'Endpoint 1',
|
|
161
|
-
'https://api1.com/v1',
|
|
162
|
-
undefined,
|
|
163
|
-
true
|
|
164
|
-
);
|
|
165
|
-
|
|
166
|
-
// Add second endpoint as default (should unset first)
|
|
167
|
-
await providerManager.saveCustomEndpoint(
|
|
168
|
-
providerId,
|
|
169
|
-
'Endpoint 2',
|
|
170
|
-
'https://api2.com/v1',
|
|
171
|
-
undefined,
|
|
172
|
-
true
|
|
173
|
-
);
|
|
174
|
-
|
|
175
|
-
const endpoints = await providerManager.getCustomEndpoints(providerId);
|
|
176
|
-
const defaultEndpoints = endpoints.filter(e => e.is_default);
|
|
177
|
-
|
|
178
|
-
expect(defaultEndpoints).toHaveLength(1);
|
|
179
|
-
expect(defaultEndpoints[0].name).toBe('Endpoint 2');
|
|
180
|
-
});
|
|
181
|
-
});
|
|
182
|
-
|
|
183
|
-
describe('Provider Settings Management', () => {
|
|
184
|
-
it('should save and retrieve provider-specific settings', async () => {
|
|
185
|
-
const testConfig: ModelConfig = {
|
|
186
|
-
authType: AuthType.OLLAMA,
|
|
187
|
-
modelName: 'test-model',
|
|
188
|
-
isActive: true
|
|
189
|
-
};
|
|
190
|
-
|
|
191
|
-
const providerId = await providerManager.saveProvider(testConfig);
|
|
192
|
-
|
|
193
|
-
// Save various settings
|
|
194
|
-
await providerManager.saveProviderSetting(providerId, 'num_ctx', 32768);
|
|
195
|
-
await providerManager.saveProviderSetting(providerId, 'temperature', 0.7);
|
|
196
|
-
await providerManager.saveProviderSetting(providerId, 'custom_prompt', 'You are a helpful assistant');
|
|
197
|
-
|
|
198
|
-
const settings = await providerManager.getProviderSettings(providerId);
|
|
199
|
-
|
|
200
|
-
expect(settings.num_ctx).toBe(32768);
|
|
201
|
-
expect(settings.temperature).toBe(0.7);
|
|
202
|
-
expect(settings.custom_prompt).toBe('You are a helpful assistant');
|
|
203
|
-
});
|
|
204
|
-
|
|
205
|
-
it('should handle complex setting values', async () => {
|
|
206
|
-
const testConfig: ModelConfig = {
|
|
207
|
-
authType: AuthType.OPENAI_API_KEY,
|
|
208
|
-
modelName: 'complex-config',
|
|
209
|
-
isActive: true
|
|
210
|
-
};
|
|
211
|
-
|
|
212
|
-
const providerId = await providerManager.saveProvider(testConfig);
|
|
213
|
-
|
|
214
|
-
const complexSetting = {
|
|
215
|
-
samplingParams: {
|
|
216
|
-
temperature: 0.8,
|
|
217
|
-
max_tokens: 2000,
|
|
218
|
-
top_p: 0.9
|
|
219
|
-
},
|
|
220
|
-
customHeaders: {
|
|
221
|
-
'X-Custom-Header': 'value'
|
|
222
|
-
}
|
|
223
|
-
};
|
|
224
|
-
|
|
225
|
-
await providerManager.saveProviderSetting(providerId, 'advanced_config', complexSetting);
|
|
226
|
-
|
|
227
|
-
const settings = await providerManager.getProviderSettings(providerId);
|
|
228
|
-
expect(settings.advanced_config).toEqual(complexSetting);
|
|
229
|
-
});
|
|
230
|
-
});
|
|
231
|
-
|
|
232
|
-
describe('Smart Default Selection', () => {
|
|
233
|
-
it('should select favorite provider as default', async () => {
|
|
234
|
-
// Create multiple providers
|
|
235
|
-
const _provider1Id = await providerManager.saveProvider({
|
|
236
|
-
authType: AuthType.OPENAI_API_KEY,
|
|
237
|
-
modelName: 'gpt-4',
|
|
238
|
-
displayName: 'GPT-4',
|
|
239
|
-
isFavorite: false,
|
|
240
|
-
isActive: true
|
|
241
|
-
});
|
|
242
|
-
|
|
243
|
-
const _provider2Id = await providerManager.saveProvider({
|
|
244
|
-
authType: AuthType.OLLAMA,
|
|
245
|
-
modelName: 'llama2',
|
|
246
|
-
displayName: 'Llama 2',
|
|
247
|
-
isFavorite: true, // This should be selected as default
|
|
248
|
-
isActive: true
|
|
249
|
-
});
|
|
250
|
-
|
|
251
|
-
const provider3Id = await providerManager.saveProvider({
|
|
252
|
-
authType: AuthType.LM_STUDIO,
|
|
253
|
-
modelName: 'local-model',
|
|
254
|
-
displayName: 'Local Model',
|
|
255
|
-
isFavorite: false,
|
|
256
|
-
isActive: true
|
|
257
|
-
});
|
|
258
|
-
|
|
259
|
-
// Record usage for provider3 to make it most used
|
|
260
|
-
await providerManager.recordUsage(provider3Id, 5000, 120000);
|
|
261
|
-
await providerManager.recordUsage(provider3Id, 3000, 90000);
|
|
262
|
-
|
|
263
|
-
const defaultProvider = await providerManager.getDefaultProvider();
|
|
264
|
-
expect(defaultProvider?.displayName).toBe('Llama 2'); // Should prefer favorite over usage
|
|
265
|
-
});
|
|
266
|
-
|
|
267
|
-
it('should select most used provider when no favorite is set', async () => {
|
|
268
|
-
const provider1Id = await providerManager.saveProvider({
|
|
269
|
-
authType: AuthType.OPENAI_API_KEY,
|
|
270
|
-
modelName: 'gpt-4',
|
|
271
|
-
displayName: 'GPT-4',
|
|
272
|
-
isActive: true
|
|
273
|
-
});
|
|
274
|
-
|
|
275
|
-
const provider2Id = await providerManager.saveProvider({
|
|
276
|
-
authType: AuthType.OLLAMA,
|
|
277
|
-
modelName: 'llama2',
|
|
278
|
-
displayName: 'Llama 2',
|
|
279
|
-
isActive: true
|
|
280
|
-
});
|
|
281
|
-
|
|
282
|
-
// Make provider2 most used
|
|
283
|
-
await providerManager.recordUsage(provider2Id, 10000, 300000);
|
|
284
|
-
await providerManager.recordUsage(provider2Id, 8000, 200000);
|
|
285
|
-
await providerManager.recordUsage(provider1Id, 2000, 60000);
|
|
286
|
-
|
|
287
|
-
const defaultProvider = await providerManager.getDefaultProvider();
|
|
288
|
-
expect(defaultProvider?.displayName).toBe('Llama 2');
|
|
289
|
-
});
|
|
290
|
-
});
|
|
291
|
-
|
|
292
|
-
describe('Provider Filtering and Querying', () => {
|
|
293
|
-
it('should filter providers by type correctly', async () => {
|
|
294
|
-
// Create providers of different types
|
|
295
|
-
await providerManager.saveProvider({
|
|
296
|
-
authType: AuthType.OPENAI_API_KEY,
|
|
297
|
-
modelName: 'gpt-4',
|
|
298
|
-
isActive: true
|
|
299
|
-
});
|
|
300
|
-
|
|
301
|
-
await providerManager.saveProvider({
|
|
302
|
-
authType: AuthType.OLLAMA,
|
|
303
|
-
modelName: 'llama2',
|
|
304
|
-
isActive: true
|
|
305
|
-
});
|
|
306
|
-
|
|
307
|
-
await providerManager.saveProvider({
|
|
308
|
-
authType: AuthType.OPENAI_API_KEY,
|
|
309
|
-
modelName: 'gpt-3.5-turbo',
|
|
310
|
-
isActive: true
|
|
311
|
-
});
|
|
312
|
-
|
|
313
|
-
const openaiProviders = await providerManager.getProvidersByType(AuthType.OPENAI_API_KEY);
|
|
314
|
-
const ollamaProviders = await providerManager.getProvidersByType(AuthType.OLLAMA);
|
|
315
|
-
|
|
316
|
-
expect(openaiProviders).toHaveLength(2);
|
|
317
|
-
expect(ollamaProviders).toHaveLength(1);
|
|
318
|
-
expect(ollamaProviders[0].modelName).toBe('llama2');
|
|
319
|
-
});
|
|
320
|
-
|
|
321
|
-
it('should get recommended providers based on usage', async () => {
|
|
322
|
-
// Create several providers with different usage patterns
|
|
323
|
-
const providers = [];
|
|
324
|
-
for (let i = 0; i < 8; i++) {
|
|
325
|
-
const id = await providerManager.saveProvider({
|
|
326
|
-
authType: AuthType.OPENAI_API_KEY,
|
|
327
|
-
modelName: `model-${i}`,
|
|
328
|
-
displayName: `Model ${i}`,
|
|
329
|
-
isActive: true,
|
|
330
|
-
isFavorite: i === 2 // Make one a favorite
|
|
331
|
-
});
|
|
332
|
-
providers.push(id);
|
|
333
|
-
|
|
334
|
-
// Record different amounts of usage
|
|
335
|
-
if (i < 5) {
|
|
336
|
-
await providerManager.recordUsage(id, i * 1000, i * 30000);
|
|
337
|
-
}
|
|
338
|
-
}
|
|
339
|
-
|
|
340
|
-
const recommended = await providerManager.getRecommendedProviders(3);
|
|
341
|
-
expect(recommended).toHaveLength(3);
|
|
342
|
-
|
|
343
|
-
// First should be the favorite
|
|
344
|
-
expect(recommended[0].displayName).toBe('Model 2');
|
|
345
|
-
});
|
|
346
|
-
});
|
|
347
|
-
|
|
348
|
-
describe('Auto-Configuration', () => {
|
|
349
|
-
it('should auto-configure provider from successful authentication', async () => {
|
|
350
|
-
const providerId = await providerManager.autoConfigureFromSuccess(
|
|
351
|
-
AuthType.USE_GEMINI,
|
|
352
|
-
'gemini-2.0-flash',
|
|
353
|
-
undefined,
|
|
354
|
-
'test-gemini-key',
|
|
355
|
-
{
|
|
356
|
-
temperature: 0.7,
|
|
357
|
-
max_tokens: 2048
|
|
358
|
-
}
|
|
359
|
-
);
|
|
360
|
-
|
|
361
|
-
expect(providerId).toBeGreaterThan(0);
|
|
362
|
-
|
|
363
|
-
const allProviders = await providerManager.getAllProviders();
|
|
364
|
-
const newProvider = allProviders.find(p => p.id === providerId);
|
|
365
|
-
|
|
366
|
-
expect(newProvider?.authType).toBe(AuthType.USE_GEMINI);
|
|
367
|
-
expect(newProvider?.modelName).toBe('gemini-2.0-flash');
|
|
368
|
-
expect(newProvider?.apiKey).toBe('test-gemini-key');
|
|
369
|
-
expect(newProvider?.displayName).toContain('gemini-2.0-flash');
|
|
370
|
-
|
|
371
|
-
// Check additional settings were saved
|
|
372
|
-
const settings = await providerManager.getProviderSettings(providerId);
|
|
373
|
-
expect(settings.temperature).toBe(0.7);
|
|
374
|
-
expect(settings.max_tokens).toBe(2048);
|
|
375
|
-
});
|
|
376
|
-
});
|
|
377
|
-
});
|
|
@@ -1,105 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @license
|
|
3
|
-
* Copyright 2025 Google LLC
|
|
4
|
-
* SPDX-License-Identifier: Apache-2.0
|
|
5
|
-
*/
|
|
6
|
-
|
|
7
|
-
import { AuthType } from 'fss-link-core';
|
|
8
|
-
|
|
9
|
-
/**
|
|
10
|
-
* Provider configuration with full persistence support
|
|
11
|
-
*/
|
|
12
|
-
export interface ProviderConfig {
|
|
13
|
-
id?: number;
|
|
14
|
-
provider: AuthType;
|
|
15
|
-
displayName: string;
|
|
16
|
-
baseUrl?: string;
|
|
17
|
-
apiKey?: string;
|
|
18
|
-
model?: string;
|
|
19
|
-
isDefault: boolean;
|
|
20
|
-
usageCount: number;
|
|
21
|
-
lastUsed: Date;
|
|
22
|
-
customEndpoints?: CustomEndpoint[];
|
|
23
|
-
additionalSettings?: Record<string, unknown>;
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
/**
|
|
27
|
-
* Custom endpoint configuration
|
|
28
|
-
*/
|
|
29
|
-
export interface CustomEndpoint {
|
|
30
|
-
id?: number;
|
|
31
|
-
providerId: number;
|
|
32
|
-
name: string;
|
|
33
|
-
url: string;
|
|
34
|
-
description?: string;
|
|
35
|
-
isDefault: boolean;
|
|
36
|
-
created: Date;
|
|
37
|
-
}
|
|
38
|
-
|
|
39
|
-
/**
|
|
40
|
-
* Provider usage tracking
|
|
41
|
-
*/
|
|
42
|
-
export interface ProviderUsage {
|
|
43
|
-
providerId: number;
|
|
44
|
-
sessionCount: number;
|
|
45
|
-
totalTokens: number;
|
|
46
|
-
lastSession: Date;
|
|
47
|
-
averageSessionLength: number;
|
|
48
|
-
}
|
|
49
|
-
|
|
50
|
-
/**
|
|
51
|
-
* Enhanced provider persistence manager
|
|
52
|
-
*/
|
|
53
|
-
export class ProviderPersistenceManager {
|
|
54
|
-
private static instance: ProviderPersistenceManager;
|
|
55
|
-
|
|
56
|
-
static getInstance(): ProviderPersistenceManager {
|
|
57
|
-
if (!ProviderPersistenceManager.instance) {
|
|
58
|
-
ProviderPersistenceManager.instance = new ProviderPersistenceManager();
|
|
59
|
-
}
|
|
60
|
-
return ProviderPersistenceManager.instance;
|
|
61
|
-
}
|
|
62
|
-
|
|
63
|
-
/**
|
|
64
|
-
* Save provider configuration with usage tracking
|
|
65
|
-
*/
|
|
66
|
-
async saveProviderConfig(_config: ProviderConfig): Promise<number> {
|
|
67
|
-
// Implementation will integrate with existing database
|
|
68
|
-
throw new Error('Implementation pending');
|
|
69
|
-
}
|
|
70
|
-
|
|
71
|
-
/**
|
|
72
|
-
* Get all saved providers with usage statistics
|
|
73
|
-
*/
|
|
74
|
-
async getAllProviders(): Promise<ProviderConfig[]> {
|
|
75
|
-
throw new Error('Implementation pending');
|
|
76
|
-
}
|
|
77
|
-
|
|
78
|
-
/**
|
|
79
|
-
* Get smart default provider based on usage and configuration
|
|
80
|
-
*/
|
|
81
|
-
async getDefaultProvider(): Promise<ProviderConfig | null> {
|
|
82
|
-
throw new Error('Implementation pending');
|
|
83
|
-
}
|
|
84
|
-
|
|
85
|
-
/**
|
|
86
|
-
* Track provider usage for intelligent defaults
|
|
87
|
-
*/
|
|
88
|
-
async recordProviderUsage(_providerId: number, _tokens: number, _sessionDuration: number): Promise<void> {
|
|
89
|
-
throw new Error('Implementation pending');
|
|
90
|
-
}
|
|
91
|
-
|
|
92
|
-
/**
|
|
93
|
-
* Get custom endpoints for a provider
|
|
94
|
-
*/
|
|
95
|
-
async getCustomEndpoints(_providerId: number): Promise<CustomEndpoint[]> {
|
|
96
|
-
throw new Error('Implementation pending');
|
|
97
|
-
}
|
|
98
|
-
|
|
99
|
-
/**
|
|
100
|
-
* Save custom endpoint
|
|
101
|
-
*/
|
|
102
|
-
async saveCustomEndpoint(_endpoint: CustomEndpoint): Promise<number> {
|
|
103
|
-
throw new Error('Implementation pending');
|
|
104
|
-
}
|
|
105
|
-
}
|
|
@@ -1,107 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @license
|
|
3
|
-
* Copyright 2025 Google LLC
|
|
4
|
-
* SPDX-License-Identifier: Apache-2.0
|
|
5
|
-
*/
|
|
6
|
-
|
|
7
|
-
import { SandboxConfig } from 'fss-link-core';
|
|
8
|
-
import commandExists from 'command-exists';
|
|
9
|
-
import * as os from 'node:os';
|
|
10
|
-
import { getPackageJson } from '../utils/package.js';
|
|
11
|
-
import { Settings } from './settings.js';
|
|
12
|
-
|
|
13
|
-
// This is a stripped-down version of the CliArgs interface from config.ts
|
|
14
|
-
// to avoid circular dependencies.
|
|
15
|
-
interface SandboxCliArgs {
|
|
16
|
-
sandbox?: boolean | string;
|
|
17
|
-
sandboxImage?: string;
|
|
18
|
-
}
|
|
19
|
-
|
|
20
|
-
const VALID_SANDBOX_COMMANDS: ReadonlyArray<SandboxConfig['command']> = [
|
|
21
|
-
'docker',
|
|
22
|
-
'podman',
|
|
23
|
-
'sandbox-exec',
|
|
24
|
-
];
|
|
25
|
-
|
|
26
|
-
function isSandboxCommand(value: string): value is SandboxConfig['command'] {
|
|
27
|
-
return (VALID_SANDBOX_COMMANDS as readonly string[]).includes(value);
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
function getSandboxCommand(
|
|
31
|
-
sandbox?: boolean | string,
|
|
32
|
-
): SandboxConfig['command'] | '' {
|
|
33
|
-
// If the SANDBOX env var is set, we're already inside the sandbox.
|
|
34
|
-
if (process.env['SANDBOX']) {
|
|
35
|
-
return '';
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
// note environment variable takes precedence over argument (from command line or settings)
|
|
39
|
-
const environmentConfiguredSandbox =
|
|
40
|
-
process.env['GEMINI_SANDBOX']?.toLowerCase().trim() ?? '';
|
|
41
|
-
sandbox =
|
|
42
|
-
environmentConfiguredSandbox?.length > 0
|
|
43
|
-
? environmentConfiguredSandbox
|
|
44
|
-
: sandbox;
|
|
45
|
-
if (sandbox === '1' || sandbox === 'true') sandbox = true;
|
|
46
|
-
else if (sandbox === '0' || sandbox === 'false' || !sandbox) sandbox = false;
|
|
47
|
-
|
|
48
|
-
if (sandbox === false) {
|
|
49
|
-
return '';
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
if (typeof sandbox === 'string' && sandbox) {
|
|
53
|
-
if (!isSandboxCommand(sandbox)) {
|
|
54
|
-
console.error(
|
|
55
|
-
`ERROR: invalid sandbox command '${sandbox}'. Must be one of ${VALID_SANDBOX_COMMANDS.join(
|
|
56
|
-
', ',
|
|
57
|
-
)}`,
|
|
58
|
-
);
|
|
59
|
-
process.exit(1);
|
|
60
|
-
}
|
|
61
|
-
// confirm that specified command exists
|
|
62
|
-
if (commandExists.sync(sandbox)) {
|
|
63
|
-
return sandbox;
|
|
64
|
-
}
|
|
65
|
-
console.error(
|
|
66
|
-
`ERROR: missing sandbox command '${sandbox}' (from GEMINI_SANDBOX)`,
|
|
67
|
-
);
|
|
68
|
-
process.exit(1);
|
|
69
|
-
}
|
|
70
|
-
|
|
71
|
-
// look for seatbelt, docker, or podman, in that order
|
|
72
|
-
// for container-based sandboxing, require sandbox to be enabled explicitly
|
|
73
|
-
if (os.platform() === 'darwin' && commandExists.sync('sandbox-exec')) {
|
|
74
|
-
return 'sandbox-exec';
|
|
75
|
-
} else if (commandExists.sync('docker') && sandbox === true) {
|
|
76
|
-
return 'docker';
|
|
77
|
-
} else if (commandExists.sync('podman') && sandbox === true) {
|
|
78
|
-
return 'podman';
|
|
79
|
-
}
|
|
80
|
-
|
|
81
|
-
// throw an error if user requested sandbox but no command was found
|
|
82
|
-
if (sandbox === true) {
|
|
83
|
-
console.error(
|
|
84
|
-
'ERROR: GEMINI_SANDBOX is true but failed to determine command for sandbox; ' +
|
|
85
|
-
'install docker or podman or specify command in GEMINI_SANDBOX',
|
|
86
|
-
);
|
|
87
|
-
process.exit(1);
|
|
88
|
-
}
|
|
89
|
-
|
|
90
|
-
return '';
|
|
91
|
-
}
|
|
92
|
-
|
|
93
|
-
export async function loadSandboxConfig(
|
|
94
|
-
settings: Settings,
|
|
95
|
-
argv: SandboxCliArgs,
|
|
96
|
-
): Promise<SandboxConfig | undefined> {
|
|
97
|
-
const sandboxOption = argv.sandbox ?? settings.sandbox;
|
|
98
|
-
const command = getSandboxCommand(sandboxOption);
|
|
99
|
-
|
|
100
|
-
const packageJson = await getPackageJson();
|
|
101
|
-
const image =
|
|
102
|
-
argv.sandboxImage ??
|
|
103
|
-
process.env['GEMINI_SANDBOX_IMAGE'] ??
|
|
104
|
-
packageJson?.config?.sandboxImageUri;
|
|
105
|
-
|
|
106
|
-
return command && image ? { command, image } : undefined;
|
|
107
|
-
}
|