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,69 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @license
|
|
3
|
-
* Copyright 2025 Google LLC
|
|
4
|
-
* SPDX-License-Identifier: Apache-2.0
|
|
5
|
-
*/
|
|
6
|
-
|
|
7
|
-
import { vi, describe, it, expect, beforeEach } from 'vitest';
|
|
8
|
-
import yargs from 'yargs';
|
|
9
|
-
import { loadSettings, SettingScope } from '../../config/settings.js';
|
|
10
|
-
import { removeCommand } from './remove.js';
|
|
11
|
-
|
|
12
|
-
vi.mock('fs/promises', () => ({
|
|
13
|
-
readFile: vi.fn(),
|
|
14
|
-
writeFile: vi.fn(),
|
|
15
|
-
}));
|
|
16
|
-
|
|
17
|
-
vi.mock('../../config/settings.js', async () => {
|
|
18
|
-
const actual = await vi.importActual('../../config/settings.js');
|
|
19
|
-
return {
|
|
20
|
-
...actual,
|
|
21
|
-
loadSettings: vi.fn(),
|
|
22
|
-
};
|
|
23
|
-
});
|
|
24
|
-
|
|
25
|
-
const mockedLoadSettings = loadSettings as vi.Mock;
|
|
26
|
-
|
|
27
|
-
describe('mcp remove command', () => {
|
|
28
|
-
let parser: yargs.Argv;
|
|
29
|
-
let mockSetValue: vi.Mock;
|
|
30
|
-
let mockSettings: Record<string, unknown>;
|
|
31
|
-
|
|
32
|
-
beforeEach(() => {
|
|
33
|
-
vi.resetAllMocks();
|
|
34
|
-
const yargsInstance = yargs([]).command(removeCommand);
|
|
35
|
-
parser = yargsInstance;
|
|
36
|
-
mockSetValue = vi.fn();
|
|
37
|
-
mockSettings = {
|
|
38
|
-
mcpServers: {
|
|
39
|
-
'test-server': {
|
|
40
|
-
command: 'echo "hello"',
|
|
41
|
-
},
|
|
42
|
-
},
|
|
43
|
-
};
|
|
44
|
-
mockedLoadSettings.mockReturnValue({
|
|
45
|
-
forScope: () => ({ settings: mockSettings }),
|
|
46
|
-
setValue: mockSetValue,
|
|
47
|
-
});
|
|
48
|
-
});
|
|
49
|
-
|
|
50
|
-
it('should remove a server from project settings', async () => {
|
|
51
|
-
await parser.parseAsync('remove test-server');
|
|
52
|
-
|
|
53
|
-
expect(mockSetValue).toHaveBeenCalledWith(
|
|
54
|
-
SettingScope.Workspace,
|
|
55
|
-
'mcpServers',
|
|
56
|
-
{},
|
|
57
|
-
);
|
|
58
|
-
});
|
|
59
|
-
|
|
60
|
-
it('should show a message if server not found', async () => {
|
|
61
|
-
const consoleSpy = vi.spyOn(console, 'log').mockImplementation(() => {});
|
|
62
|
-
await parser.parseAsync('remove non-existent-server');
|
|
63
|
-
|
|
64
|
-
expect(mockSetValue).not.toHaveBeenCalled();
|
|
65
|
-
expect(consoleSpy).toHaveBeenCalledWith(
|
|
66
|
-
'Server "non-existent-server" not found in project settings.',
|
|
67
|
-
);
|
|
68
|
-
});
|
|
69
|
-
});
|
|
@@ -1,60 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @license
|
|
3
|
-
* Copyright 2025 Google LLC
|
|
4
|
-
* SPDX-License-Identifier: Apache-2.0
|
|
5
|
-
*/
|
|
6
|
-
|
|
7
|
-
// File for 'gemini mcp remove' command
|
|
8
|
-
import type { CommandModule } from 'yargs';
|
|
9
|
-
import { loadSettings, SettingScope } from '../../config/settings.js';
|
|
10
|
-
|
|
11
|
-
async function removeMcpServer(
|
|
12
|
-
name: string,
|
|
13
|
-
options: {
|
|
14
|
-
scope: string;
|
|
15
|
-
},
|
|
16
|
-
) {
|
|
17
|
-
const { scope } = options;
|
|
18
|
-
const settingsScope =
|
|
19
|
-
scope === 'user' ? SettingScope.User : SettingScope.Workspace;
|
|
20
|
-
const settings = loadSettings(process.cwd());
|
|
21
|
-
|
|
22
|
-
const existingSettings = settings.forScope(settingsScope).settings;
|
|
23
|
-
const mcpServers = existingSettings.mcpServers || {};
|
|
24
|
-
|
|
25
|
-
if (!mcpServers[name]) {
|
|
26
|
-
console.log(`Server "${name}" not found in ${scope} settings.`);
|
|
27
|
-
return;
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
delete mcpServers[name];
|
|
31
|
-
|
|
32
|
-
settings.setValue(settingsScope, 'mcpServers', mcpServers);
|
|
33
|
-
|
|
34
|
-
console.log(`Server "${name}" removed from ${scope} settings.`);
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
export const removeCommand: CommandModule = {
|
|
38
|
-
command: 'remove <name>',
|
|
39
|
-
describe: 'Remove a server',
|
|
40
|
-
builder: (yargs) =>
|
|
41
|
-
yargs
|
|
42
|
-
.usage('Usage: gemini mcp remove [options] <name>')
|
|
43
|
-
.positional('name', {
|
|
44
|
-
describe: 'Name of the server',
|
|
45
|
-
type: 'string',
|
|
46
|
-
demandOption: true,
|
|
47
|
-
})
|
|
48
|
-
.option('scope', {
|
|
49
|
-
alias: 's',
|
|
50
|
-
describe: 'Configuration scope (user or project)',
|
|
51
|
-
type: 'string',
|
|
52
|
-
default: 'project',
|
|
53
|
-
choices: ['user', 'project'],
|
|
54
|
-
}),
|
|
55
|
-
handler: async (argv) => {
|
|
56
|
-
await removeMcpServer(argv['name'] as string, {
|
|
57
|
-
scope: argv['scope'] as string,
|
|
58
|
-
});
|
|
59
|
-
},
|
|
60
|
-
};
|
|
@@ -1,55 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @license
|
|
3
|
-
* Copyright 2025 Google LLC
|
|
4
|
-
* SPDX-License-Identifier: Apache-2.0
|
|
5
|
-
*/
|
|
6
|
-
|
|
7
|
-
import { describe, it, expect, vi } from 'vitest';
|
|
8
|
-
import { mcpCommand } from './mcp.js';
|
|
9
|
-
import { type Argv } from 'yargs';
|
|
10
|
-
import yargs from 'yargs';
|
|
11
|
-
|
|
12
|
-
describe('mcp command', () => {
|
|
13
|
-
it('should have correct command definition', () => {
|
|
14
|
-
expect(mcpCommand.command).toBe('mcp');
|
|
15
|
-
expect(mcpCommand.describe).toBe('Manage MCP servers');
|
|
16
|
-
expect(typeof mcpCommand.builder).toBe('function');
|
|
17
|
-
expect(typeof mcpCommand.handler).toBe('function');
|
|
18
|
-
});
|
|
19
|
-
|
|
20
|
-
it('should have exactly one option (help flag)', () => {
|
|
21
|
-
// Test to ensure that the global 'gemini' flags are not added to the mcp command
|
|
22
|
-
const yargsInstance = yargs();
|
|
23
|
-
const builtYargs = mcpCommand.builder(yargsInstance);
|
|
24
|
-
const options = builtYargs.getOptions();
|
|
25
|
-
|
|
26
|
-
// Should have exactly 1 option (help flag)
|
|
27
|
-
expect(Object.keys(options.key).length).toBe(1);
|
|
28
|
-
expect(options.key).toHaveProperty('help');
|
|
29
|
-
});
|
|
30
|
-
|
|
31
|
-
it('should register add, remove, and list subcommands', () => {
|
|
32
|
-
const mockYargs = {
|
|
33
|
-
command: vi.fn().mockReturnThis(),
|
|
34
|
-
demandCommand: vi.fn().mockReturnThis(),
|
|
35
|
-
version: vi.fn().mockReturnThis(),
|
|
36
|
-
};
|
|
37
|
-
|
|
38
|
-
mcpCommand.builder(mockYargs as unknown as Argv);
|
|
39
|
-
|
|
40
|
-
expect(mockYargs.command).toHaveBeenCalledTimes(3);
|
|
41
|
-
|
|
42
|
-
// Verify that the specific subcommands are registered
|
|
43
|
-
const commandCalls = mockYargs.command.mock.calls;
|
|
44
|
-
const commandNames = commandCalls.map((call) => call[0].command);
|
|
45
|
-
|
|
46
|
-
expect(commandNames).toContain('add <name> <commandOrUrl> [args...]');
|
|
47
|
-
expect(commandNames).toContain('remove <name>');
|
|
48
|
-
expect(commandNames).toContain('list');
|
|
49
|
-
|
|
50
|
-
expect(mockYargs.demandCommand).toHaveBeenCalledWith(
|
|
51
|
-
1,
|
|
52
|
-
'You need at least one command before continuing.',
|
|
53
|
-
);
|
|
54
|
-
});
|
|
55
|
-
});
|
package/dist/commands/mcp.ts
DELETED
|
@@ -1,27 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @license
|
|
3
|
-
* Copyright 2025 Google LLC
|
|
4
|
-
* SPDX-License-Identifier: Apache-2.0
|
|
5
|
-
*/
|
|
6
|
-
|
|
7
|
-
// File for 'gemini mcp' command
|
|
8
|
-
import type { CommandModule, Argv } from 'yargs';
|
|
9
|
-
import { addCommand } from './mcp/add.js';
|
|
10
|
-
import { removeCommand } from './mcp/remove.js';
|
|
11
|
-
import { listCommand } from './mcp/list.js';
|
|
12
|
-
|
|
13
|
-
export const mcpCommand: CommandModule = {
|
|
14
|
-
command: 'mcp',
|
|
15
|
-
describe: 'Manage MCP servers',
|
|
16
|
-
builder: (yargs: Argv) =>
|
|
17
|
-
yargs
|
|
18
|
-
.command(addCommand)
|
|
19
|
-
.command(removeCommand)
|
|
20
|
-
.command(listCommand)
|
|
21
|
-
.demandCommand(1, 'You need at least one command before continuing.')
|
|
22
|
-
.version(false),
|
|
23
|
-
handler: () => {
|
|
24
|
-
// yargs will automatically show help if no subcommand is provided
|
|
25
|
-
// thanks to demandCommand(1) in the builder.
|
|
26
|
-
},
|
|
27
|
-
};
|
|
@@ -1,118 +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 { validateAuthMethod } from './auth.js';
|
|
9
|
-
import { AuthType } from 'fss-link-core';
|
|
10
|
-
|
|
11
|
-
describe('API Key Validation Edge Cases', () => {
|
|
12
|
-
let originalEnv: NodeJS.ProcessEnv;
|
|
13
|
-
|
|
14
|
-
beforeEach(() => {
|
|
15
|
-
// Save original environment
|
|
16
|
-
originalEnv = { ...process.env };
|
|
17
|
-
});
|
|
18
|
-
|
|
19
|
-
afterEach(() => {
|
|
20
|
-
// Restore original environment
|
|
21
|
-
process.env = originalEnv;
|
|
22
|
-
});
|
|
23
|
-
|
|
24
|
-
describe('Required API Key Validation', () => {
|
|
25
|
-
it('should require GEMINI_API_KEY for Gemini auth', () => {
|
|
26
|
-
delete process.env['GEMINI_API_KEY'];
|
|
27
|
-
const result = validateAuthMethod(AuthType.USE_GEMINI);
|
|
28
|
-
expect(result).toBe('GEMINI_API_KEY environment variable not found. Add that to your environment and try again (no reload needed if using .env)!');
|
|
29
|
-
});
|
|
30
|
-
|
|
31
|
-
it('should pass with valid GEMINI_API_KEY', () => {
|
|
32
|
-
process.env['GEMINI_API_KEY'] = 'test-gemini-key';
|
|
33
|
-
const result = validateAuthMethod(AuthType.USE_GEMINI);
|
|
34
|
-
expect(result).toBeNull();
|
|
35
|
-
});
|
|
36
|
-
|
|
37
|
-
it('should require OPENAI_API_KEY for OpenAI auth', () => {
|
|
38
|
-
delete process.env['OPENAI_API_KEY'];
|
|
39
|
-
const result = validateAuthMethod(AuthType.USE_OPENAI);
|
|
40
|
-
expect(result).toBe('OPENAI_API_KEY environment variable not found. You can enter it interactively or add it to your .env file.');
|
|
41
|
-
});
|
|
42
|
-
|
|
43
|
-
it('should pass with valid OPENAI_API_KEY', () => {
|
|
44
|
-
process.env['OPENAI_API_KEY'] = 'test-openai-key';
|
|
45
|
-
const result = validateAuthMethod(AuthType.USE_OPENAI);
|
|
46
|
-
expect(result).toBeNull();
|
|
47
|
-
});
|
|
48
|
-
});
|
|
49
|
-
|
|
50
|
-
describe('Optional API Key Validation', () => {
|
|
51
|
-
it('should not require API key for Ollama', () => {
|
|
52
|
-
delete process.env['OLLAMA_API_KEY']; // Even if this existed, it shouldn't be required
|
|
53
|
-
const result = validateAuthMethod(AuthType.OLLAMA);
|
|
54
|
-
expect(result).toBeNull();
|
|
55
|
-
});
|
|
56
|
-
|
|
57
|
-
it('should not require API key for LM Studio', () => {
|
|
58
|
-
delete process.env['LM_STUDIO_API_KEY']; // Even if this existed, it shouldn't be required
|
|
59
|
-
const result = validateAuthMethod(AuthType.LM_STUDIO);
|
|
60
|
-
expect(result).toBeNull();
|
|
61
|
-
});
|
|
62
|
-
|
|
63
|
-
it('should not require API key for Qwen OAuth', () => {
|
|
64
|
-
// OAuth flow handles its own authentication
|
|
65
|
-
const result = validateAuthMethod(AuthType.QWEN_OAUTH);
|
|
66
|
-
expect(result).toBeNull();
|
|
67
|
-
});
|
|
68
|
-
});
|
|
69
|
-
|
|
70
|
-
describe('Complex Vertex AI Validation', () => {
|
|
71
|
-
it('should require either project/location or API key for Vertex AI', () => {
|
|
72
|
-
delete process.env['GOOGLE_CLOUD_PROJECT'];
|
|
73
|
-
delete process.env['GOOGLE_CLOUD_LOCATION'];
|
|
74
|
-
delete process.env['GOOGLE_API_KEY'];
|
|
75
|
-
|
|
76
|
-
const result = validateAuthMethod(AuthType.USE_VERTEX_AI);
|
|
77
|
-
expect(result).toContain('When using Vertex AI, you must specify either');
|
|
78
|
-
});
|
|
79
|
-
|
|
80
|
-
it('should pass with project and location', () => {
|
|
81
|
-
process.env['GOOGLE_CLOUD_PROJECT'] = 'test-project';
|
|
82
|
-
process.env['GOOGLE_CLOUD_LOCATION'] = 'us-central1';
|
|
83
|
-
delete process.env['GOOGLE_API_KEY'];
|
|
84
|
-
|
|
85
|
-
const result = validateAuthMethod(AuthType.USE_VERTEX_AI);
|
|
86
|
-
expect(result).toBeNull();
|
|
87
|
-
});
|
|
88
|
-
|
|
89
|
-
it('should pass with Google API key', () => {
|
|
90
|
-
delete process.env['GOOGLE_CLOUD_PROJECT'];
|
|
91
|
-
delete process.env['GOOGLE_CLOUD_LOCATION'];
|
|
92
|
-
process.env['GOOGLE_API_KEY'] = 'test-google-key';
|
|
93
|
-
|
|
94
|
-
const result = validateAuthMethod(AuthType.USE_VERTEX_AI);
|
|
95
|
-
expect(result).toBeNull();
|
|
96
|
-
});
|
|
97
|
-
});
|
|
98
|
-
|
|
99
|
-
describe('Edge Case Scenarios', () => {
|
|
100
|
-
it('should handle empty string API keys as missing', () => {
|
|
101
|
-
process.env['GEMINI_API_KEY'] = '';
|
|
102
|
-
const result = validateAuthMethod(AuthType.USE_GEMINI);
|
|
103
|
-
expect(result).toBe('GEMINI_API_KEY environment variable not found. Add that to your environment and try again (no reload needed if using .env)!');
|
|
104
|
-
});
|
|
105
|
-
|
|
106
|
-
it('should handle whitespace-only API keys as missing', () => {
|
|
107
|
-
process.env['OPENAI_API_KEY'] = ' ';
|
|
108
|
-
// const _result = validateAuthMethod(AuthType.USE_OPENAI);
|
|
109
|
-
// The current implementation might not handle this edge case
|
|
110
|
-
// This test documents the expected behavior
|
|
111
|
-
});
|
|
112
|
-
|
|
113
|
-
it('should reject invalid auth methods', () => {
|
|
114
|
-
const result = validateAuthMethod('invalid_auth_method');
|
|
115
|
-
expect(result).toBe('Invalid auth method selected.');
|
|
116
|
-
});
|
|
117
|
-
});
|
|
118
|
-
});
|
package/dist/config/auth.test.ts
DELETED
|
@@ -1,79 +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
|
-
import { vi } from 'vitest';
|
|
9
|
-
import { validateAuthMethod } from './auth.js';
|
|
10
|
-
|
|
11
|
-
vi.mock('./settings.js', async (importOriginal) => {
|
|
12
|
-
const actual = await importOriginal<typeof import('./settings.js')>();
|
|
13
|
-
return {
|
|
14
|
-
...actual,
|
|
15
|
-
loadEnvironment: vi.fn(),
|
|
16
|
-
};
|
|
17
|
-
});
|
|
18
|
-
|
|
19
|
-
describe('validateAuthMethod', () => {
|
|
20
|
-
const originalEnv = process.env;
|
|
21
|
-
|
|
22
|
-
beforeEach(() => {
|
|
23
|
-
vi.resetModules();
|
|
24
|
-
process.env = {};
|
|
25
|
-
});
|
|
26
|
-
|
|
27
|
-
afterEach(() => {
|
|
28
|
-
process.env = originalEnv;
|
|
29
|
-
});
|
|
30
|
-
|
|
31
|
-
it('should return null for LOGIN_WITH_GOOGLE', () => {
|
|
32
|
-
expect(validateAuthMethod(AuthType.LOGIN_WITH_GOOGLE)).toBeNull();
|
|
33
|
-
});
|
|
34
|
-
|
|
35
|
-
it('should return null for CLOUD_SHELL', () => {
|
|
36
|
-
expect(validateAuthMethod(AuthType.CLOUD_SHELL)).toBeNull();
|
|
37
|
-
});
|
|
38
|
-
|
|
39
|
-
describe('USE_GEMINI', () => {
|
|
40
|
-
it('should return null if GEMINI_API_KEY is set', () => {
|
|
41
|
-
process.env['GEMINI_API_KEY'] = 'test-key';
|
|
42
|
-
expect(validateAuthMethod(AuthType.USE_GEMINI)).toBeNull();
|
|
43
|
-
});
|
|
44
|
-
|
|
45
|
-
it('should return an error message if GEMINI_API_KEY is not set', () => {
|
|
46
|
-
expect(validateAuthMethod(AuthType.USE_GEMINI)).toBe(
|
|
47
|
-
'GEMINI_API_KEY environment variable not found. Add that to your environment and try again (no reload needed if using .env)!',
|
|
48
|
-
);
|
|
49
|
-
});
|
|
50
|
-
});
|
|
51
|
-
|
|
52
|
-
describe('USE_VERTEX_AI', () => {
|
|
53
|
-
it('should return null if GOOGLE_CLOUD_PROJECT and GOOGLE_CLOUD_LOCATION are set', () => {
|
|
54
|
-
process.env['GOOGLE_CLOUD_PROJECT'] = 'test-project';
|
|
55
|
-
process.env['GOOGLE_CLOUD_LOCATION'] = 'test-location';
|
|
56
|
-
expect(validateAuthMethod(AuthType.USE_VERTEX_AI)).toBeNull();
|
|
57
|
-
});
|
|
58
|
-
|
|
59
|
-
it('should return null if GOOGLE_API_KEY is set', () => {
|
|
60
|
-
process.env['GOOGLE_API_KEY'] = 'test-api-key';
|
|
61
|
-
expect(validateAuthMethod(AuthType.USE_VERTEX_AI)).toBeNull();
|
|
62
|
-
});
|
|
63
|
-
|
|
64
|
-
it('should return an error message if no required environment variables are set', () => {
|
|
65
|
-
expect(validateAuthMethod(AuthType.USE_VERTEX_AI)).toBe(
|
|
66
|
-
'When using Vertex AI, you must specify either:\n' +
|
|
67
|
-
'• GOOGLE_CLOUD_PROJECT and GOOGLE_CLOUD_LOCATION environment variables.\n' +
|
|
68
|
-
'• GOOGLE_API_KEY environment variable (if using express mode).\n' +
|
|
69
|
-
'Update your environment and try again (no reload needed if using .env)!',
|
|
70
|
-
);
|
|
71
|
-
});
|
|
72
|
-
});
|
|
73
|
-
|
|
74
|
-
it('should return an error message for an invalid auth method', () => {
|
|
75
|
-
expect(validateAuthMethod('invalid-method')).toBe(
|
|
76
|
-
'Invalid auth method selected.',
|
|
77
|
-
);
|
|
78
|
-
});
|
|
79
|
-
});
|
package/dist/config/auth.ts
DELETED
|
@@ -1,100 +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
|
-
import { loadEnvironment } from './settings.js';
|
|
9
|
-
import { getModelManager } from './modelManager.js';
|
|
10
|
-
|
|
11
|
-
export const validateAuthMethod = (authMethod: string): string | null => {
|
|
12
|
-
loadEnvironment();
|
|
13
|
-
|
|
14
|
-
// Initialize environment from database if we have an active model
|
|
15
|
-
const modelManager = getModelManager();
|
|
16
|
-
modelManager.initializeFromStore();
|
|
17
|
-
|
|
18
|
-
if (
|
|
19
|
-
authMethod === AuthType.LOGIN_WITH_GOOGLE ||
|
|
20
|
-
authMethod === AuthType.CLOUD_SHELL
|
|
21
|
-
) {
|
|
22
|
-
return null;
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
if (authMethod === AuthType.USE_GEMINI) {
|
|
26
|
-
if (!process.env['GEMINI_API_KEY']) {
|
|
27
|
-
return 'GEMINI_API_KEY environment variable not found. Add that to your environment and try again (no reload needed if using .env)!';
|
|
28
|
-
}
|
|
29
|
-
return null;
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
if (authMethod === AuthType.USE_VERTEX_AI) {
|
|
33
|
-
const hasVertexProjectLocationConfig =
|
|
34
|
-
!!process.env['GOOGLE_CLOUD_PROJECT'] &&
|
|
35
|
-
!!process.env['GOOGLE_CLOUD_LOCATION'];
|
|
36
|
-
const hasGoogleApiKey = !!process.env['GOOGLE_API_KEY'];
|
|
37
|
-
if (!hasVertexProjectLocationConfig && !hasGoogleApiKey) {
|
|
38
|
-
return (
|
|
39
|
-
'When using Vertex AI, you must specify either:\n' +
|
|
40
|
-
'• GOOGLE_CLOUD_PROJECT and GOOGLE_CLOUD_LOCATION environment variables.\n' +
|
|
41
|
-
'• GOOGLE_API_KEY environment variable (if using express mode).\n' +
|
|
42
|
-
'Update your environment and try again (no reload needed if using .env)!'
|
|
43
|
-
);
|
|
44
|
-
}
|
|
45
|
-
return null;
|
|
46
|
-
}
|
|
47
|
-
|
|
48
|
-
if (authMethod === AuthType.USE_OPENAI) {
|
|
49
|
-
if (!process.env['OPENAI_API_KEY']) {
|
|
50
|
-
return 'OPENAI_API_KEY environment variable not found. You can enter it interactively or add it to your .env file.';
|
|
51
|
-
}
|
|
52
|
-
return null;
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
if (authMethod === AuthType.QWEN_OAUTH) {
|
|
56
|
-
// FSS Link OAuth doesn't require any environment variables for basic setup
|
|
57
|
-
// The OAuth flow will handle authentication
|
|
58
|
-
return null;
|
|
59
|
-
}
|
|
60
|
-
|
|
61
|
-
if (authMethod === AuthType.OLLAMA) {
|
|
62
|
-
// Ollama doesn't require API key - local endpoint
|
|
63
|
-
return null;
|
|
64
|
-
}
|
|
65
|
-
|
|
66
|
-
if (authMethod === AuthType.LM_STUDIO) {
|
|
67
|
-
// LM Studio doesn't require API key - local endpoint
|
|
68
|
-
return null;
|
|
69
|
-
}
|
|
70
|
-
|
|
71
|
-
return 'Invalid auth method selected.';
|
|
72
|
-
};
|
|
73
|
-
|
|
74
|
-
export const setOpenAIApiKey = (apiKey: string): void => {
|
|
75
|
-
process.env['OPENAI_API_KEY'] = apiKey;
|
|
76
|
-
};
|
|
77
|
-
|
|
78
|
-
export const setOpenAIBaseUrl = (baseUrl: string): void => {
|
|
79
|
-
process.env['OPENAI_BASE_URL'] = baseUrl;
|
|
80
|
-
};
|
|
81
|
-
|
|
82
|
-
export const setOpenAIModel = (model: string): void => {
|
|
83
|
-
process.env['OPENAI_MODEL'] = model;
|
|
84
|
-
};
|
|
85
|
-
|
|
86
|
-
export const setOllamaBaseUrl = (baseUrl: string): void => {
|
|
87
|
-
process.env['OLLAMA_BASE_URL'] = baseUrl || 'http://localhost:11434/v1';
|
|
88
|
-
};
|
|
89
|
-
|
|
90
|
-
export const setOllamaModel = (model: string): void => {
|
|
91
|
-
process.env['OLLAMA_MODEL'] = model;
|
|
92
|
-
};
|
|
93
|
-
|
|
94
|
-
export const setLMStudioBaseUrl = (baseUrl: string): void => {
|
|
95
|
-
process.env['LM_STUDIO_BASE_URL'] = baseUrl || 'http://localhost:1234/v1';
|
|
96
|
-
};
|
|
97
|
-
|
|
98
|
-
export const setLMStudioModel = (model: string): void => {
|
|
99
|
-
process.env['LM_STUDIO_MODEL'] = model;
|
|
100
|
-
};
|