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
package/dist/config/settings.ts
DELETED
|
@@ -1,517 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @license
|
|
3
|
-
* Copyright 2025 Google LLC
|
|
4
|
-
* SPDX-License-Identifier: Apache-2.0
|
|
5
|
-
*/
|
|
6
|
-
|
|
7
|
-
import * as fs from 'fs';
|
|
8
|
-
import * as path from 'path';
|
|
9
|
-
import { homedir, platform } from 'os';
|
|
10
|
-
import * as dotenv from 'dotenv';
|
|
11
|
-
import {
|
|
12
|
-
FSS_LINK_CONFIG_DIR as GEMINI_DIR,
|
|
13
|
-
getErrorMessage,
|
|
14
|
-
} from 'fss-link-core';
|
|
15
|
-
import stripJsonComments from 'strip-json-comments';
|
|
16
|
-
import { DefaultLight } from '../ui/themes/default-light.js';
|
|
17
|
-
import { DefaultDark } from '../ui/themes/default.js';
|
|
18
|
-
import { Settings, MemoryImportFormat } from './settingsSchema.js';
|
|
19
|
-
import { getModelManager } from './modelManager.js';
|
|
20
|
-
|
|
21
|
-
export type { Settings, MemoryImportFormat };
|
|
22
|
-
|
|
23
|
-
export const SETTINGS_DIRECTORY_NAME = '.fss-link';
|
|
24
|
-
export const USER_SETTINGS_DIR = path.join(homedir(), SETTINGS_DIRECTORY_NAME);
|
|
25
|
-
export const USER_SETTINGS_PATH = path.join(USER_SETTINGS_DIR, 'settings.json');
|
|
26
|
-
export const DEFAULT_EXCLUDED_ENV_VARS = ['DEBUG', 'DEBUG_MODE'];
|
|
27
|
-
|
|
28
|
-
export function getSystemSettingsPath(): string {
|
|
29
|
-
if (process.env['FSS_LINK_CLI_SYSTEM_SETTINGS_PATH']) {
|
|
30
|
-
return process.env['FSS_LINK_CLI_SYSTEM_SETTINGS_PATH'];
|
|
31
|
-
}
|
|
32
|
-
if (platform() === 'darwin') {
|
|
33
|
-
return '/Library/Application Support/FSS-Link/settings.json';
|
|
34
|
-
} else if (platform() === 'win32') {
|
|
35
|
-
return 'C:\\ProgramData\\fss-link\\settings.json';
|
|
36
|
-
} else {
|
|
37
|
-
return '/etc/fss-link/settings.json';
|
|
38
|
-
}
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
export function getWorkspaceSettingsPath(workspaceDir: string): string {
|
|
42
|
-
return path.join(workspaceDir, SETTINGS_DIRECTORY_NAME, 'settings.json');
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
export type { DnsResolutionOrder } from './settingsSchema.js';
|
|
46
|
-
|
|
47
|
-
export enum SettingScope {
|
|
48
|
-
User = 'User',
|
|
49
|
-
Workspace = 'Workspace',
|
|
50
|
-
System = 'System',
|
|
51
|
-
}
|
|
52
|
-
|
|
53
|
-
export interface CheckpointingSettings {
|
|
54
|
-
enabled?: boolean;
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
export interface SummarizeToolOutputSettings {
|
|
58
|
-
tokenBudget?: number;
|
|
59
|
-
}
|
|
60
|
-
|
|
61
|
-
export interface AccessibilitySettings {
|
|
62
|
-
disableLoadingPhrases?: boolean;
|
|
63
|
-
}
|
|
64
|
-
|
|
65
|
-
export interface SettingsError {
|
|
66
|
-
message: string;
|
|
67
|
-
path: string;
|
|
68
|
-
}
|
|
69
|
-
|
|
70
|
-
export interface SettingsFile {
|
|
71
|
-
settings: Settings;
|
|
72
|
-
path: string;
|
|
73
|
-
}
|
|
74
|
-
|
|
75
|
-
function mergeSettings(
|
|
76
|
-
system: Settings,
|
|
77
|
-
user: Settings,
|
|
78
|
-
workspace: Settings,
|
|
79
|
-
): Settings {
|
|
80
|
-
// folderTrust is not supported at workspace level.
|
|
81
|
-
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
82
|
-
const { folderTrust, ...workspaceWithoutFolderTrust } = workspace;
|
|
83
|
-
|
|
84
|
-
return {
|
|
85
|
-
...user,
|
|
86
|
-
...workspaceWithoutFolderTrust,
|
|
87
|
-
...system,
|
|
88
|
-
customThemes: {
|
|
89
|
-
...(user.customThemes || {}),
|
|
90
|
-
...(workspace.customThemes || {}),
|
|
91
|
-
...(system.customThemes || {}),
|
|
92
|
-
},
|
|
93
|
-
mcpServers: {
|
|
94
|
-
...(user.mcpServers || {}),
|
|
95
|
-
...(workspace.mcpServers || {}),
|
|
96
|
-
...(system.mcpServers || {}),
|
|
97
|
-
},
|
|
98
|
-
includeDirectories: [
|
|
99
|
-
...(system.includeDirectories || []),
|
|
100
|
-
...(user.includeDirectories || []),
|
|
101
|
-
...(workspace.includeDirectories || []),
|
|
102
|
-
],
|
|
103
|
-
chatCompression: {
|
|
104
|
-
...(system.chatCompression || {}),
|
|
105
|
-
...(user.chatCompression || {}),
|
|
106
|
-
...(workspace.chatCompression || {}),
|
|
107
|
-
},
|
|
108
|
-
};
|
|
109
|
-
}
|
|
110
|
-
|
|
111
|
-
export class LoadedSettings {
|
|
112
|
-
constructor(
|
|
113
|
-
system: SettingsFile,
|
|
114
|
-
user: SettingsFile,
|
|
115
|
-
workspace: SettingsFile,
|
|
116
|
-
errors: SettingsError[],
|
|
117
|
-
) {
|
|
118
|
-
this.system = system;
|
|
119
|
-
this.user = user;
|
|
120
|
-
this.workspace = workspace;
|
|
121
|
-
this.errors = errors;
|
|
122
|
-
this._merged = this.computeMergedSettings();
|
|
123
|
-
}
|
|
124
|
-
|
|
125
|
-
readonly system: SettingsFile;
|
|
126
|
-
readonly user: SettingsFile;
|
|
127
|
-
readonly workspace: SettingsFile;
|
|
128
|
-
readonly errors: SettingsError[];
|
|
129
|
-
|
|
130
|
-
private _merged: Settings;
|
|
131
|
-
|
|
132
|
-
get merged(): Settings {
|
|
133
|
-
return this._merged;
|
|
134
|
-
}
|
|
135
|
-
|
|
136
|
-
private computeMergedSettings(): Settings {
|
|
137
|
-
return mergeSettings(
|
|
138
|
-
this.system.settings,
|
|
139
|
-
this.user.settings,
|
|
140
|
-
this.workspace.settings,
|
|
141
|
-
);
|
|
142
|
-
}
|
|
143
|
-
|
|
144
|
-
forScope(scope: SettingScope): SettingsFile {
|
|
145
|
-
switch (scope) {
|
|
146
|
-
case SettingScope.User:
|
|
147
|
-
return this.user;
|
|
148
|
-
case SettingScope.Workspace:
|
|
149
|
-
return this.workspace;
|
|
150
|
-
case SettingScope.System:
|
|
151
|
-
return this.system;
|
|
152
|
-
default:
|
|
153
|
-
throw new Error(`Invalid scope: ${scope}`);
|
|
154
|
-
}
|
|
155
|
-
}
|
|
156
|
-
|
|
157
|
-
setValue<K extends keyof Settings>(
|
|
158
|
-
scope: SettingScope,
|
|
159
|
-
key: K,
|
|
160
|
-
value: Settings[K],
|
|
161
|
-
): void {
|
|
162
|
-
const settingsFile = this.forScope(scope);
|
|
163
|
-
settingsFile.settings[key] = value;
|
|
164
|
-
this._merged = this.computeMergedSettings();
|
|
165
|
-
saveSettings(settingsFile);
|
|
166
|
-
}
|
|
167
|
-
}
|
|
168
|
-
|
|
169
|
-
function resolveEnvVarsInString(value: string): string {
|
|
170
|
-
const envVarRegex = /\$(?:(\w+)|{([^}]+)})/g; // Find $VAR_NAME or ${VAR_NAME}
|
|
171
|
-
return value.replace(envVarRegex, (match, varName1, varName2) => {
|
|
172
|
-
const varName = varName1 || varName2;
|
|
173
|
-
if (process && process.env && typeof process.env[varName] === 'string') {
|
|
174
|
-
return process.env[varName]!;
|
|
175
|
-
}
|
|
176
|
-
return match;
|
|
177
|
-
});
|
|
178
|
-
}
|
|
179
|
-
|
|
180
|
-
function resolveEnvVarsInObject<T>(obj: T): T {
|
|
181
|
-
if (
|
|
182
|
-
obj === null ||
|
|
183
|
-
obj === undefined ||
|
|
184
|
-
typeof obj === 'boolean' ||
|
|
185
|
-
typeof obj === 'number'
|
|
186
|
-
) {
|
|
187
|
-
return obj;
|
|
188
|
-
}
|
|
189
|
-
|
|
190
|
-
if (typeof obj === 'string') {
|
|
191
|
-
return resolveEnvVarsInString(obj) as unknown as T;
|
|
192
|
-
}
|
|
193
|
-
|
|
194
|
-
if (Array.isArray(obj)) {
|
|
195
|
-
return obj.map((item) => resolveEnvVarsInObject(item)) as unknown as T;
|
|
196
|
-
}
|
|
197
|
-
|
|
198
|
-
if (typeof obj === 'object') {
|
|
199
|
-
const newObj = { ...obj } as T;
|
|
200
|
-
for (const key in newObj) {
|
|
201
|
-
if (Object.prototype.hasOwnProperty.call(newObj, key)) {
|
|
202
|
-
newObj[key] = resolveEnvVarsInObject(newObj[key]);
|
|
203
|
-
}
|
|
204
|
-
}
|
|
205
|
-
return newObj;
|
|
206
|
-
}
|
|
207
|
-
|
|
208
|
-
return obj;
|
|
209
|
-
}
|
|
210
|
-
|
|
211
|
-
function findEnvFile(startDir: string): string | null {
|
|
212
|
-
let currentDir = path.resolve(startDir);
|
|
213
|
-
while (true) {
|
|
214
|
-
// prefer gemini-specific .env under GEMINI_DIR
|
|
215
|
-
const geminiEnvPath = path.join(currentDir, GEMINI_DIR, '.env');
|
|
216
|
-
if (fs.existsSync(geminiEnvPath)) {
|
|
217
|
-
return geminiEnvPath;
|
|
218
|
-
}
|
|
219
|
-
const envPath = path.join(currentDir, '.env');
|
|
220
|
-
if (fs.existsSync(envPath)) {
|
|
221
|
-
return envPath;
|
|
222
|
-
}
|
|
223
|
-
const parentDir = path.dirname(currentDir);
|
|
224
|
-
if (parentDir === currentDir || !parentDir) {
|
|
225
|
-
// check .env under home as fallback, again preferring gemini-specific .env
|
|
226
|
-
const homeGeminiEnvPath = path.join(homedir(), GEMINI_DIR, '.env');
|
|
227
|
-
if (fs.existsSync(homeGeminiEnvPath)) {
|
|
228
|
-
return homeGeminiEnvPath;
|
|
229
|
-
}
|
|
230
|
-
const homeEnvPath = path.join(homedir(), '.env');
|
|
231
|
-
if (fs.existsSync(homeEnvPath)) {
|
|
232
|
-
return homeEnvPath;
|
|
233
|
-
}
|
|
234
|
-
return null;
|
|
235
|
-
}
|
|
236
|
-
currentDir = parentDir;
|
|
237
|
-
}
|
|
238
|
-
}
|
|
239
|
-
|
|
240
|
-
export function setUpCloudShellEnvironment(envFilePath: string | null): void {
|
|
241
|
-
// Special handling for GOOGLE_CLOUD_PROJECT in Cloud Shell:
|
|
242
|
-
// Because GOOGLE_CLOUD_PROJECT in Cloud Shell tracks the project
|
|
243
|
-
// set by the user using "gcloud config set project" we do not want to
|
|
244
|
-
// use its value. So, unless the user overrides GOOGLE_CLOUD_PROJECT in
|
|
245
|
-
// one of the .env files, we set the Cloud Shell-specific default here.
|
|
246
|
-
if (envFilePath && fs.existsSync(envFilePath)) {
|
|
247
|
-
const envFileContent = fs.readFileSync(envFilePath);
|
|
248
|
-
const parsedEnv = dotenv.parse(envFileContent);
|
|
249
|
-
if (parsedEnv['GOOGLE_CLOUD_PROJECT']) {
|
|
250
|
-
// .env file takes precedence in Cloud Shell
|
|
251
|
-
process.env['GOOGLE_CLOUD_PROJECT'] = parsedEnv['GOOGLE_CLOUD_PROJECT'];
|
|
252
|
-
} else {
|
|
253
|
-
// If not in .env, set to default and override global
|
|
254
|
-
process.env['GOOGLE_CLOUD_PROJECT'] = 'cloudshell-gca';
|
|
255
|
-
}
|
|
256
|
-
} else {
|
|
257
|
-
// If no .env file, set to default and override global
|
|
258
|
-
process.env['GOOGLE_CLOUD_PROJECT'] = 'cloudshell-gca';
|
|
259
|
-
}
|
|
260
|
-
}
|
|
261
|
-
|
|
262
|
-
export function loadEnvironment(settings?: Settings): void {
|
|
263
|
-
const envFilePath = findEnvFile(process.cwd());
|
|
264
|
-
|
|
265
|
-
// Cloud Shell environment variable handling
|
|
266
|
-
if (process.env['CLOUD_SHELL'] === 'true') {
|
|
267
|
-
setUpCloudShellEnvironment(envFilePath);
|
|
268
|
-
}
|
|
269
|
-
|
|
270
|
-
// If no settings provided, try to load workspace settings for exclusions
|
|
271
|
-
let resolvedSettings = settings;
|
|
272
|
-
if (!resolvedSettings) {
|
|
273
|
-
const workspaceSettingsPath = getWorkspaceSettingsPath(process.cwd());
|
|
274
|
-
try {
|
|
275
|
-
if (fs.existsSync(workspaceSettingsPath)) {
|
|
276
|
-
const workspaceContent = fs.readFileSync(
|
|
277
|
-
workspaceSettingsPath,
|
|
278
|
-
'utf-8',
|
|
279
|
-
);
|
|
280
|
-
const parsedWorkspaceSettings = JSON.parse(
|
|
281
|
-
stripJsonComments(workspaceContent),
|
|
282
|
-
) as Settings;
|
|
283
|
-
resolvedSettings = resolveEnvVarsInObject(parsedWorkspaceSettings);
|
|
284
|
-
}
|
|
285
|
-
} catch (_e) {
|
|
286
|
-
// Ignore errors loading workspace settings
|
|
287
|
-
}
|
|
288
|
-
}
|
|
289
|
-
|
|
290
|
-
if (envFilePath) {
|
|
291
|
-
// Manually parse and load environment variables to handle exclusions correctly.
|
|
292
|
-
// This avoids modifying environment variables that were already set from the shell.
|
|
293
|
-
try {
|
|
294
|
-
const envFileContent = fs.readFileSync(envFilePath, 'utf-8');
|
|
295
|
-
const parsedEnv = dotenv.parse(envFileContent);
|
|
296
|
-
|
|
297
|
-
const excludedVars =
|
|
298
|
-
resolvedSettings?.excludedProjectEnvVars || DEFAULT_EXCLUDED_ENV_VARS;
|
|
299
|
-
const isProjectEnvFile = !envFilePath.includes(GEMINI_DIR);
|
|
300
|
-
|
|
301
|
-
for (const key in parsedEnv) {
|
|
302
|
-
if (Object.hasOwn(parsedEnv, key)) {
|
|
303
|
-
// If it's a project .env file, skip loading excluded variables.
|
|
304
|
-
if (isProjectEnvFile && excludedVars.includes(key)) {
|
|
305
|
-
continue;
|
|
306
|
-
}
|
|
307
|
-
|
|
308
|
-
// Load variable only if it's not already set in the environment.
|
|
309
|
-
if (!Object.hasOwn(process.env, key)) {
|
|
310
|
-
process.env[key] = parsedEnv[key];
|
|
311
|
-
}
|
|
312
|
-
}
|
|
313
|
-
}
|
|
314
|
-
} catch (_e) {
|
|
315
|
-
// Errors are ignored to match the behavior of `dotenv.config({ quiet: true })`.
|
|
316
|
-
}
|
|
317
|
-
}
|
|
318
|
-
}
|
|
319
|
-
|
|
320
|
-
/**
|
|
321
|
-
* Loads settings from user and workspace directories.
|
|
322
|
-
* Project settings override user settings.
|
|
323
|
-
*/
|
|
324
|
-
export function loadSettings(workspaceDir: string): LoadedSettings {
|
|
325
|
-
let systemSettings: Settings = {};
|
|
326
|
-
let userSettings: Settings = {};
|
|
327
|
-
let workspaceSettings: Settings = {};
|
|
328
|
-
const settingsErrors: SettingsError[] = [];
|
|
329
|
-
const systemSettingsPath = getSystemSettingsPath();
|
|
330
|
-
|
|
331
|
-
// Resolve paths to their canonical representation to handle symlinks
|
|
332
|
-
const resolvedWorkspaceDir = path.resolve(workspaceDir);
|
|
333
|
-
const resolvedHomeDir = path.resolve(homedir());
|
|
334
|
-
|
|
335
|
-
let realWorkspaceDir = resolvedWorkspaceDir;
|
|
336
|
-
try {
|
|
337
|
-
// fs.realpathSync gets the "true" path, resolving any symlinks
|
|
338
|
-
realWorkspaceDir = fs.realpathSync(resolvedWorkspaceDir);
|
|
339
|
-
} catch (_e) {
|
|
340
|
-
// This is okay. The path might not exist yet, and that's a valid state.
|
|
341
|
-
}
|
|
342
|
-
|
|
343
|
-
// We expect homedir to always exist and be resolvable.
|
|
344
|
-
const realHomeDir = fs.realpathSync(resolvedHomeDir);
|
|
345
|
-
|
|
346
|
-
const workspaceSettingsPath = getWorkspaceSettingsPath(workspaceDir);
|
|
347
|
-
|
|
348
|
-
// Load system settings
|
|
349
|
-
try {
|
|
350
|
-
if (fs.existsSync(systemSettingsPath)) {
|
|
351
|
-
const systemContent = fs.readFileSync(systemSettingsPath, 'utf-8');
|
|
352
|
-
systemSettings = JSON.parse(stripJsonComments(systemContent)) as Settings;
|
|
353
|
-
}
|
|
354
|
-
} catch (error: unknown) {
|
|
355
|
-
settingsErrors.push({
|
|
356
|
-
message: getErrorMessage(error),
|
|
357
|
-
path: systemSettingsPath,
|
|
358
|
-
});
|
|
359
|
-
}
|
|
360
|
-
|
|
361
|
-
// Load user settings
|
|
362
|
-
try {
|
|
363
|
-
if (fs.existsSync(USER_SETTINGS_PATH)) {
|
|
364
|
-
const userContent = fs.readFileSync(USER_SETTINGS_PATH, 'utf-8');
|
|
365
|
-
userSettings = JSON.parse(stripJsonComments(userContent)) as Settings;
|
|
366
|
-
// Support legacy theme names
|
|
367
|
-
if (userSettings.theme && userSettings.theme === 'VS') {
|
|
368
|
-
userSettings.theme = DefaultLight.name;
|
|
369
|
-
} else if (userSettings.theme && userSettings.theme === 'VS2015') {
|
|
370
|
-
userSettings.theme = DefaultDark.name;
|
|
371
|
-
}
|
|
372
|
-
}
|
|
373
|
-
} catch (error: unknown) {
|
|
374
|
-
settingsErrors.push({
|
|
375
|
-
message: getErrorMessage(error),
|
|
376
|
-
path: USER_SETTINGS_PATH,
|
|
377
|
-
});
|
|
378
|
-
}
|
|
379
|
-
|
|
380
|
-
if (realWorkspaceDir !== realHomeDir) {
|
|
381
|
-
// Load workspace settings
|
|
382
|
-
try {
|
|
383
|
-
if (fs.existsSync(workspaceSettingsPath)) {
|
|
384
|
-
const projectContent = fs.readFileSync(workspaceSettingsPath, 'utf-8');
|
|
385
|
-
workspaceSettings = JSON.parse(
|
|
386
|
-
stripJsonComments(projectContent),
|
|
387
|
-
) as Settings;
|
|
388
|
-
if (workspaceSettings.theme && workspaceSettings.theme === 'VS') {
|
|
389
|
-
workspaceSettings.theme = DefaultLight.name;
|
|
390
|
-
} else if (
|
|
391
|
-
workspaceSettings.theme &&
|
|
392
|
-
workspaceSettings.theme === 'VS2015'
|
|
393
|
-
) {
|
|
394
|
-
workspaceSettings.theme = DefaultDark.name;
|
|
395
|
-
}
|
|
396
|
-
}
|
|
397
|
-
} catch (error: unknown) {
|
|
398
|
-
settingsErrors.push({
|
|
399
|
-
message: getErrorMessage(error),
|
|
400
|
-
path: workspaceSettingsPath,
|
|
401
|
-
});
|
|
402
|
-
}
|
|
403
|
-
}
|
|
404
|
-
|
|
405
|
-
// Create a temporary merged settings object to pass to loadEnvironment.
|
|
406
|
-
const tempMergedSettings = mergeSettings(
|
|
407
|
-
systemSettings,
|
|
408
|
-
userSettings,
|
|
409
|
-
workspaceSettings,
|
|
410
|
-
);
|
|
411
|
-
|
|
412
|
-
// loadEnviroment depends on settings so we have to create a temp version of
|
|
413
|
-
// the settings to avoid a cycle
|
|
414
|
-
loadEnvironment(tempMergedSettings);
|
|
415
|
-
|
|
416
|
-
// Now that the environment is loaded, resolve variables in the settings.
|
|
417
|
-
systemSettings = resolveEnvVarsInObject(systemSettings);
|
|
418
|
-
userSettings = resolveEnvVarsInObject(userSettings);
|
|
419
|
-
workspaceSettings = resolveEnvVarsInObject(workspaceSettings);
|
|
420
|
-
|
|
421
|
-
// Create LoadedSettings first
|
|
422
|
-
const loadedSettings = new LoadedSettings(
|
|
423
|
-
{
|
|
424
|
-
path: systemSettingsPath,
|
|
425
|
-
settings: systemSettings,
|
|
426
|
-
},
|
|
427
|
-
{
|
|
428
|
-
path: USER_SETTINGS_PATH,
|
|
429
|
-
settings: userSettings,
|
|
430
|
-
},
|
|
431
|
-
{
|
|
432
|
-
path: workspaceSettingsPath,
|
|
433
|
-
settings: workspaceSettings,
|
|
434
|
-
},
|
|
435
|
-
settingsErrors,
|
|
436
|
-
);
|
|
437
|
-
|
|
438
|
-
// Validate chatCompression settings
|
|
439
|
-
const chatCompression = loadedSettings.merged.chatCompression;
|
|
440
|
-
const threshold = chatCompression?.contextPercentageThreshold;
|
|
441
|
-
if (
|
|
442
|
-
threshold != null &&
|
|
443
|
-
(typeof threshold !== 'number' || threshold < 0 || threshold > 1)
|
|
444
|
-
) {
|
|
445
|
-
console.warn(
|
|
446
|
-
`Invalid value for chatCompression.contextPercentageThreshold: "${threshold}". Please use a value between 0 and 1. Using default compression settings.`,
|
|
447
|
-
);
|
|
448
|
-
delete loadedSettings.merged.chatCompression;
|
|
449
|
-
}
|
|
450
|
-
|
|
451
|
-
// Restore authentication settings to process.env for immediate use
|
|
452
|
-
// This ensures that persisted settings are available as environment variables
|
|
453
|
-
const merged = loadedSettings.merged;
|
|
454
|
-
|
|
455
|
-
// Restore OpenAI settings
|
|
456
|
-
if (merged.openaiApiKey && !process.env['OPENAI_API_KEY']) {
|
|
457
|
-
process.env['OPENAI_API_KEY'] = merged.openaiApiKey;
|
|
458
|
-
}
|
|
459
|
-
if (merged.openaiBaseUrl && !process.env['OPENAI_BASE_URL']) {
|
|
460
|
-
process.env['OPENAI_BASE_URL'] = merged.openaiBaseUrl;
|
|
461
|
-
}
|
|
462
|
-
if (merged.openaiModel && !process.env['OPENAI_MODEL']) {
|
|
463
|
-
process.env['OPENAI_MODEL'] = merged.openaiModel;
|
|
464
|
-
}
|
|
465
|
-
|
|
466
|
-
// Restore Ollama settings
|
|
467
|
-
if (merged.ollamaApiKey && !process.env['OLLAMA_API_KEY']) {
|
|
468
|
-
process.env['OLLAMA_API_KEY'] = merged.ollamaApiKey;
|
|
469
|
-
}
|
|
470
|
-
if (merged.ollamaBaseUrl && !process.env['OLLAMA_BASE_URL']) {
|
|
471
|
-
process.env['OLLAMA_BASE_URL'] = merged.ollamaBaseUrl;
|
|
472
|
-
}
|
|
473
|
-
if (merged.ollamaModel && !process.env['OLLAMA_MODEL']) {
|
|
474
|
-
process.env['OLLAMA_MODEL'] = merged.ollamaModel;
|
|
475
|
-
}
|
|
476
|
-
|
|
477
|
-
// Restore LM Studio settings
|
|
478
|
-
if (merged.lmStudioApiKey && !process.env['LM_STUDIO_API_KEY']) {
|
|
479
|
-
process.env['LM_STUDIO_API_KEY'] = merged.lmStudioApiKey;
|
|
480
|
-
}
|
|
481
|
-
if (merged.lmStudioBaseUrl && !process.env['LM_STUDIO_BASE_URL']) {
|
|
482
|
-
process.env['LM_STUDIO_BASE_URL'] = merged.lmStudioBaseUrl;
|
|
483
|
-
}
|
|
484
|
-
if (merged.lmStudioModel && !process.env['LM_STUDIO_MODEL']) {
|
|
485
|
-
process.env['LM_STUDIO_MODEL'] = merged.lmStudioModel;
|
|
486
|
-
}
|
|
487
|
-
|
|
488
|
-
// Initialize database and restore active model environment variables
|
|
489
|
-
// This ensures database-stored model configurations are available immediately
|
|
490
|
-
try {
|
|
491
|
-
const modelManager = getModelManager();
|
|
492
|
-
modelManager.initializeFromStore();
|
|
493
|
-
} catch (error) {
|
|
494
|
-
// Database initialization errors should not prevent settings loading
|
|
495
|
-
console.warn('Failed to initialize model database:', getErrorMessage(error));
|
|
496
|
-
}
|
|
497
|
-
|
|
498
|
-
return loadedSettings;
|
|
499
|
-
}
|
|
500
|
-
|
|
501
|
-
export function saveSettings(settingsFile: SettingsFile): void {
|
|
502
|
-
try {
|
|
503
|
-
// Ensure the directory exists
|
|
504
|
-
const dirPath = path.dirname(settingsFile.path);
|
|
505
|
-
if (!fs.existsSync(dirPath)) {
|
|
506
|
-
fs.mkdirSync(dirPath, { recursive: true });
|
|
507
|
-
}
|
|
508
|
-
|
|
509
|
-
fs.writeFileSync(
|
|
510
|
-
settingsFile.path,
|
|
511
|
-
JSON.stringify(settingsFile.settings, null, 2),
|
|
512
|
-
'utf-8',
|
|
513
|
-
);
|
|
514
|
-
} catch (error) {
|
|
515
|
-
console.error('Error saving user settings file:', error);
|
|
516
|
-
}
|
|
517
|
-
}
|