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,198 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @license
|
|
3
|
-
* Copyright 2025 Google LLC
|
|
4
|
-
* SPDX-License-Identifier: Apache-2.0
|
|
5
|
-
*/
|
|
6
|
-
|
|
7
|
-
import { useState, useEffect, useRef } from 'react';
|
|
8
|
-
|
|
9
|
-
export const WITTY_LOADING_PHRASES = [
|
|
10
|
-
"I'm Feeling Lucky",
|
|
11
|
-
'Shipping awesomeness... ',
|
|
12
|
-
'Painting the serifs back on...',
|
|
13
|
-
'Navigating the slime mold...',
|
|
14
|
-
'Consulting the digital spirits...',
|
|
15
|
-
'Reticulating splines...',
|
|
16
|
-
'Warming up the AI hamsters...',
|
|
17
|
-
'Asking the magic conch shell...',
|
|
18
|
-
'Generating witty retort...',
|
|
19
|
-
'Polishing the algorithms...',
|
|
20
|
-
"Don't rush perfection (or my code)...",
|
|
21
|
-
'Brewing fresh bytes...',
|
|
22
|
-
'Counting electrons...',
|
|
23
|
-
'Engaging cognitive processors...',
|
|
24
|
-
'Checking for syntax errors in the universe...',
|
|
25
|
-
'One moment, optimizing humor...',
|
|
26
|
-
'Shuffling punchlines...',
|
|
27
|
-
'Untangling neural nets...',
|
|
28
|
-
'Compiling brilliance...',
|
|
29
|
-
'Loading wit.exe...',
|
|
30
|
-
'Summoning the cloud of wisdom...',
|
|
31
|
-
'Preparing a witty response...',
|
|
32
|
-
"Just a sec, I'm debugging reality...",
|
|
33
|
-
'Confuzzling the options...',
|
|
34
|
-
'Tuning the cosmic frequencies...',
|
|
35
|
-
'Crafting a response worthy of your patience...',
|
|
36
|
-
'Compiling the 1s and 0s...',
|
|
37
|
-
'Resolving dependencies... and existential crises...',
|
|
38
|
-
'Defragmenting memories... both RAM and personal...',
|
|
39
|
-
'Rebooting the humor module...',
|
|
40
|
-
'Caching the essentials (mostly cat memes)...',
|
|
41
|
-
'Optimizing for ludicrous speed',
|
|
42
|
-
"Swapping bits... don't tell the bytes...",
|
|
43
|
-
'Garbage collecting... be right back...',
|
|
44
|
-
'Assembling the interwebs...',
|
|
45
|
-
'Converting coffee into code...',
|
|
46
|
-
'Updating the syntax for reality...',
|
|
47
|
-
'Rewiring the synapses...',
|
|
48
|
-
'Looking for a misplaced semicolon...',
|
|
49
|
-
"Greasin' the cogs of the machine...",
|
|
50
|
-
'Pre-heating the servers...',
|
|
51
|
-
'Calibrating the flux capacitor...',
|
|
52
|
-
'Engaging the improbability drive...',
|
|
53
|
-
'Channeling the Force...',
|
|
54
|
-
'Aligning the stars for optimal response...',
|
|
55
|
-
'So say we all...',
|
|
56
|
-
'Loading the next great idea...',
|
|
57
|
-
"Just a moment, I'm in the zone...",
|
|
58
|
-
'Preparing to dazzle you with brilliance...',
|
|
59
|
-
"Just a tick, I'm polishing my wit...",
|
|
60
|
-
"Hold tight, I'm crafting a masterpiece...",
|
|
61
|
-
"Just a jiffy, I'm debugging the universe...",
|
|
62
|
-
"Just a moment, I'm aligning the pixels...",
|
|
63
|
-
"Just a sec, I'm optimizing the humor...",
|
|
64
|
-
"Just a moment, I'm tuning the algorithms...",
|
|
65
|
-
'Warp speed engaged...',
|
|
66
|
-
'Mining for more Dilithium crystals...',
|
|
67
|
-
"Don't panic...",
|
|
68
|
-
'Following the white rabbit...',
|
|
69
|
-
'The truth is in here... somewhere...',
|
|
70
|
-
'Blowing on the cartridge...',
|
|
71
|
-
'Loading... Do a barrel roll!',
|
|
72
|
-
'Waiting for the respawn...',
|
|
73
|
-
'Finishing the Kessel Run in less than 12 parsecs...',
|
|
74
|
-
"The cake is not a lie, it's just still loading...",
|
|
75
|
-
'Fiddling with the character creation screen...',
|
|
76
|
-
"Just a moment, I'm finding the right meme...",
|
|
77
|
-
"Pressing 'A' to continue...",
|
|
78
|
-
'Herding digital cats...',
|
|
79
|
-
'Polishing the pixels...',
|
|
80
|
-
'Finding a suitable loading screen pun...',
|
|
81
|
-
'Distracting you with this witty phrase...',
|
|
82
|
-
'Almost there... probably...',
|
|
83
|
-
'Our hamsters are working as fast as they can...',
|
|
84
|
-
'Giving Cloudy a pat on the head...',
|
|
85
|
-
'Petting the cat...',
|
|
86
|
-
'Rickrolling my boss...',
|
|
87
|
-
'Never gonna give you up, never gonna let you down...',
|
|
88
|
-
'Slapping the bass...',
|
|
89
|
-
'Tasting the snozberries...',
|
|
90
|
-
"I'm going the distance, I'm going for speed...",
|
|
91
|
-
'Is this the real life? Is this just fantasy?...',
|
|
92
|
-
"I've got a good feeling about this...",
|
|
93
|
-
'Poking the bear...',
|
|
94
|
-
'Doing research on the latest memes...',
|
|
95
|
-
'Figuring out how to make this more witty...',
|
|
96
|
-
'Hmmm... let me think...',
|
|
97
|
-
'What do you call a fish with no eyes? A fsh...',
|
|
98
|
-
'Why did the computer go to therapy? It had too many bytes...',
|
|
99
|
-
"Why don't programmers like nature? It has too many bugs...",
|
|
100
|
-
'Why do programmers prefer dark mode? Because light attracts bugs...',
|
|
101
|
-
'Why did the developer go broke? Because they used up all their cache...',
|
|
102
|
-
"What can you do with a broken pencil? Nothing, it's pointless...",
|
|
103
|
-
'Applying percussive maintenance...',
|
|
104
|
-
'Searching for the correct USB orientation...',
|
|
105
|
-
'Ensuring the magic smoke stays inside the wires...',
|
|
106
|
-
'Rewriting in Rust for no particular reason...',
|
|
107
|
-
'Trying to exit Vim...',
|
|
108
|
-
'Spinning up the hamster wheel...',
|
|
109
|
-
"That's not a bug, it's an undocumented feature...",
|
|
110
|
-
'Engage.',
|
|
111
|
-
"I'll be back... with an answer.",
|
|
112
|
-
'My other process is a TARDIS...',
|
|
113
|
-
'Communing with the machine spirit...',
|
|
114
|
-
'Letting the thoughts marinate...',
|
|
115
|
-
'Just remembered where I put my keys...',
|
|
116
|
-
'Pondering the orb...',
|
|
117
|
-
"I've seen things you people wouldn't believe... like a user who reads loading messages.",
|
|
118
|
-
'Initiating thoughtful gaze...',
|
|
119
|
-
"What's a computer's favorite snack? Microchips.",
|
|
120
|
-
"Why do Java developers wear glasses? Because they don't C#.",
|
|
121
|
-
'Charging the laser... pew pew!',
|
|
122
|
-
'Dividing by zero... just kidding!',
|
|
123
|
-
'Looking for an adult superviso... I mean, processing.',
|
|
124
|
-
'Making it go beep boop.',
|
|
125
|
-
'Buffering... because even AIs need a moment.',
|
|
126
|
-
'Entangling quantum particles for a faster response...',
|
|
127
|
-
'Polishing the chrome... on the algorithms.',
|
|
128
|
-
'Are you not entertained? (Working on it!)',
|
|
129
|
-
'Summoning the code gremlins... to help, of course.',
|
|
130
|
-
'Just waiting for the dial-up tone to finish...',
|
|
131
|
-
'Recalibrating the humor-o-meter.',
|
|
132
|
-
'My other loading screen is even funnier.',
|
|
133
|
-
"Pretty sure there's a cat walking on the keyboard somewhere...",
|
|
134
|
-
'Enhancing... Enhancing... Still loading.',
|
|
135
|
-
"It's not a bug, it's a feature... of this loading screen.",
|
|
136
|
-
'Have you tried turning it off and on again? (The loading screen, not me.)',
|
|
137
|
-
'Constructing additional pylons...',
|
|
138
|
-
'New line? That’s Ctrl+J.',
|
|
139
|
-
];
|
|
140
|
-
|
|
141
|
-
export const PHRASE_CHANGE_INTERVAL_MS = 15000;
|
|
142
|
-
|
|
143
|
-
/**
|
|
144
|
-
* Custom hook to manage cycling through loading phrases.
|
|
145
|
-
* @param isActive Whether the phrase cycling should be active.
|
|
146
|
-
* @param isWaiting Whether to show a specific waiting phrase.
|
|
147
|
-
* @returns The current loading phrase.
|
|
148
|
-
*/
|
|
149
|
-
export const usePhraseCycler = (isActive: boolean, isWaiting: boolean) => {
|
|
150
|
-
const [currentLoadingPhrase, setCurrentLoadingPhrase] = useState(
|
|
151
|
-
WITTY_LOADING_PHRASES[0],
|
|
152
|
-
);
|
|
153
|
-
const phraseIntervalRef = useRef<NodeJS.Timeout | null>(null);
|
|
154
|
-
|
|
155
|
-
useEffect(() => {
|
|
156
|
-
if (isWaiting) {
|
|
157
|
-
setCurrentLoadingPhrase('Waiting for user confirmation...');
|
|
158
|
-
if (phraseIntervalRef.current) {
|
|
159
|
-
clearInterval(phraseIntervalRef.current);
|
|
160
|
-
phraseIntervalRef.current = null;
|
|
161
|
-
}
|
|
162
|
-
} else if (isActive) {
|
|
163
|
-
if (phraseIntervalRef.current) {
|
|
164
|
-
clearInterval(phraseIntervalRef.current);
|
|
165
|
-
}
|
|
166
|
-
// Select an initial random phrase
|
|
167
|
-
const initialRandomIndex = Math.floor(
|
|
168
|
-
Math.random() * WITTY_LOADING_PHRASES.length,
|
|
169
|
-
);
|
|
170
|
-
setCurrentLoadingPhrase(WITTY_LOADING_PHRASES[initialRandomIndex]);
|
|
171
|
-
|
|
172
|
-
phraseIntervalRef.current = setInterval(() => {
|
|
173
|
-
// Select a new random phrase
|
|
174
|
-
const randomIndex = Math.floor(
|
|
175
|
-
Math.random() * WITTY_LOADING_PHRASES.length,
|
|
176
|
-
);
|
|
177
|
-
setCurrentLoadingPhrase(WITTY_LOADING_PHRASES[randomIndex]);
|
|
178
|
-
}, PHRASE_CHANGE_INTERVAL_MS);
|
|
179
|
-
} else {
|
|
180
|
-
// Idle or other states, clear the phrase interval
|
|
181
|
-
// and reset to the first phrase for next active state.
|
|
182
|
-
if (phraseIntervalRef.current) {
|
|
183
|
-
clearInterval(phraseIntervalRef.current);
|
|
184
|
-
phraseIntervalRef.current = null;
|
|
185
|
-
}
|
|
186
|
-
setCurrentLoadingPhrase(WITTY_LOADING_PHRASES[0]);
|
|
187
|
-
}
|
|
188
|
-
|
|
189
|
-
return () => {
|
|
190
|
-
if (phraseIntervalRef.current) {
|
|
191
|
-
clearInterval(phraseIntervalRef.current);
|
|
192
|
-
phraseIntervalRef.current = null;
|
|
193
|
-
}
|
|
194
|
-
};
|
|
195
|
-
}, [isActive, isWaiting]);
|
|
196
|
-
|
|
197
|
-
return currentLoadingPhrase;
|
|
198
|
-
};
|
|
@@ -1,242 +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, vi } from 'vitest';
|
|
8
|
-
import { renderHook, waitFor } from '@testing-library/react';
|
|
9
|
-
import {
|
|
10
|
-
Config,
|
|
11
|
-
CodeAssistServer,
|
|
12
|
-
LoggingContentGenerator,
|
|
13
|
-
UserTierId,
|
|
14
|
-
GeminiClient,
|
|
15
|
-
ContentGenerator,
|
|
16
|
-
} from 'fss-link-core';
|
|
17
|
-
import { OAuth2Client } from 'google-auth-library';
|
|
18
|
-
import { usePrivacySettings } from './usePrivacySettings.js';
|
|
19
|
-
|
|
20
|
-
// Mock the dependencies
|
|
21
|
-
vi.mock('fss-link-core', () => {
|
|
22
|
-
// Mock classes for instanceof checks
|
|
23
|
-
class MockCodeAssistServer {
|
|
24
|
-
projectId = 'test-project-id';
|
|
25
|
-
loadCodeAssist = vi.fn();
|
|
26
|
-
getCodeAssistGlobalUserSetting = vi.fn();
|
|
27
|
-
setCodeAssistGlobalUserSetting = vi.fn();
|
|
28
|
-
|
|
29
|
-
constructor(
|
|
30
|
-
_client?: GeminiClient,
|
|
31
|
-
_projectId?: string,
|
|
32
|
-
_httpOptions?: Record<string, unknown>,
|
|
33
|
-
_sessionId?: string,
|
|
34
|
-
_userTier?: UserTierId,
|
|
35
|
-
) {}
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
class MockLoggingContentGenerator {
|
|
39
|
-
getWrapped = vi.fn();
|
|
40
|
-
|
|
41
|
-
constructor(
|
|
42
|
-
_wrapped?: ContentGenerator,
|
|
43
|
-
_config?: Record<string, unknown>,
|
|
44
|
-
) {}
|
|
45
|
-
}
|
|
46
|
-
|
|
47
|
-
return {
|
|
48
|
-
Config: vi.fn(),
|
|
49
|
-
CodeAssistServer: MockCodeAssistServer,
|
|
50
|
-
LoggingContentGenerator: MockLoggingContentGenerator,
|
|
51
|
-
GeminiClient: vi.fn(),
|
|
52
|
-
UserTierId: {
|
|
53
|
-
FREE: 'free-tier',
|
|
54
|
-
LEGACY: 'legacy-tier',
|
|
55
|
-
STANDARD: 'standard-tier',
|
|
56
|
-
},
|
|
57
|
-
};
|
|
58
|
-
});
|
|
59
|
-
|
|
60
|
-
describe('usePrivacySettings', () => {
|
|
61
|
-
let mockConfig: Config;
|
|
62
|
-
let mockClient: GeminiClient;
|
|
63
|
-
let mockCodeAssistServer: CodeAssistServer;
|
|
64
|
-
let mockLoggingContentGenerator: LoggingContentGenerator;
|
|
65
|
-
|
|
66
|
-
beforeEach(() => {
|
|
67
|
-
vi.clearAllMocks();
|
|
68
|
-
|
|
69
|
-
// Create mock CodeAssistServer instance
|
|
70
|
-
mockCodeAssistServer = new CodeAssistServer(
|
|
71
|
-
null as unknown as OAuth2Client,
|
|
72
|
-
'test-project-id',
|
|
73
|
-
) as unknown as CodeAssistServer;
|
|
74
|
-
(
|
|
75
|
-
mockCodeAssistServer.loadCodeAssist as ReturnType<typeof vi.fn>
|
|
76
|
-
).mockResolvedValue({
|
|
77
|
-
currentTier: { id: UserTierId.FREE },
|
|
78
|
-
});
|
|
79
|
-
(
|
|
80
|
-
mockCodeAssistServer.getCodeAssistGlobalUserSetting as ReturnType<
|
|
81
|
-
typeof vi.fn
|
|
82
|
-
>
|
|
83
|
-
).mockResolvedValue({
|
|
84
|
-
freeTierDataCollectionOptin: true,
|
|
85
|
-
});
|
|
86
|
-
(
|
|
87
|
-
mockCodeAssistServer.setCodeAssistGlobalUserSetting as ReturnType<
|
|
88
|
-
typeof vi.fn
|
|
89
|
-
>
|
|
90
|
-
).mockResolvedValue({
|
|
91
|
-
freeTierDataCollectionOptin: false,
|
|
92
|
-
});
|
|
93
|
-
|
|
94
|
-
// Create mock LoggingContentGenerator that wraps the CodeAssistServer
|
|
95
|
-
mockLoggingContentGenerator = new LoggingContentGenerator(
|
|
96
|
-
mockCodeAssistServer,
|
|
97
|
-
null as unknown as Config,
|
|
98
|
-
) as unknown as LoggingContentGenerator;
|
|
99
|
-
(
|
|
100
|
-
mockLoggingContentGenerator.getWrapped as ReturnType<typeof vi.fn>
|
|
101
|
-
).mockReturnValue(mockCodeAssistServer);
|
|
102
|
-
|
|
103
|
-
// Create mock GeminiClient
|
|
104
|
-
mockClient = {
|
|
105
|
-
getContentGenerator: vi.fn().mockReturnValue(mockLoggingContentGenerator),
|
|
106
|
-
} as unknown as GeminiClient;
|
|
107
|
-
|
|
108
|
-
// Create mock Config
|
|
109
|
-
mockConfig = {
|
|
110
|
-
getGeminiClient: vi.fn().mockReturnValue(mockClient),
|
|
111
|
-
} as unknown as Config;
|
|
112
|
-
});
|
|
113
|
-
|
|
114
|
-
it('should handle LoggingContentGenerator wrapper correctly and not throw "Oauth not being used" error', async () => {
|
|
115
|
-
const { result } = renderHook(() => usePrivacySettings(mockConfig));
|
|
116
|
-
|
|
117
|
-
// Initial state should be loading
|
|
118
|
-
expect(result.current.privacyState.isLoading).toBe(true);
|
|
119
|
-
expect(result.current.privacyState.error).toBeUndefined();
|
|
120
|
-
|
|
121
|
-
// Wait for the hook to complete
|
|
122
|
-
await waitFor(() => {
|
|
123
|
-
expect(result.current.privacyState.isLoading).toBe(false);
|
|
124
|
-
});
|
|
125
|
-
|
|
126
|
-
// Should not have the "Oauth not being used" error
|
|
127
|
-
expect(result.current.privacyState.error).toBeUndefined();
|
|
128
|
-
expect(result.current.privacyState.isFreeTier).toBe(true);
|
|
129
|
-
expect(result.current.privacyState.dataCollectionOptIn).toBe(true);
|
|
130
|
-
|
|
131
|
-
// Verify that getWrapped was called to unwrap the LoggingContentGenerator
|
|
132
|
-
expect(mockLoggingContentGenerator.getWrapped).toHaveBeenCalled();
|
|
133
|
-
});
|
|
134
|
-
|
|
135
|
-
it('should work with direct CodeAssistServer (no wrapper)', async () => {
|
|
136
|
-
// Test case where the content generator is directly a CodeAssistServer
|
|
137
|
-
const directServer = new CodeAssistServer(
|
|
138
|
-
null as unknown as OAuth2Client,
|
|
139
|
-
'test-project-id',
|
|
140
|
-
) as unknown as CodeAssistServer;
|
|
141
|
-
(directServer.loadCodeAssist as ReturnType<typeof vi.fn>).mockResolvedValue(
|
|
142
|
-
{
|
|
143
|
-
currentTier: { id: UserTierId.FREE },
|
|
144
|
-
},
|
|
145
|
-
);
|
|
146
|
-
(
|
|
147
|
-
directServer.getCodeAssistGlobalUserSetting as ReturnType<typeof vi.fn>
|
|
148
|
-
).mockResolvedValue({
|
|
149
|
-
freeTierDataCollectionOptin: true,
|
|
150
|
-
});
|
|
151
|
-
|
|
152
|
-
mockClient.getContentGenerator = vi.fn().mockReturnValue(directServer);
|
|
153
|
-
|
|
154
|
-
const { result } = renderHook(() => usePrivacySettings(mockConfig));
|
|
155
|
-
|
|
156
|
-
await waitFor(() => {
|
|
157
|
-
expect(result.current.privacyState.isLoading).toBe(false);
|
|
158
|
-
});
|
|
159
|
-
|
|
160
|
-
expect(result.current.privacyState.error).toBeUndefined();
|
|
161
|
-
expect(result.current.privacyState.isFreeTier).toBe(true);
|
|
162
|
-
expect(result.current.privacyState.dataCollectionOptIn).toBe(true);
|
|
163
|
-
});
|
|
164
|
-
|
|
165
|
-
it('should handle paid tier users correctly', async () => {
|
|
166
|
-
// Mock paid tier response
|
|
167
|
-
(
|
|
168
|
-
mockCodeAssistServer.loadCodeAssist as ReturnType<typeof vi.fn>
|
|
169
|
-
).mockResolvedValue({
|
|
170
|
-
currentTier: { id: UserTierId.STANDARD },
|
|
171
|
-
});
|
|
172
|
-
|
|
173
|
-
const { result } = renderHook(() => usePrivacySettings(mockConfig));
|
|
174
|
-
|
|
175
|
-
await waitFor(() => {
|
|
176
|
-
expect(result.current.privacyState.isLoading).toBe(false);
|
|
177
|
-
});
|
|
178
|
-
|
|
179
|
-
expect(result.current.privacyState.error).toBeUndefined();
|
|
180
|
-
expect(result.current.privacyState.isFreeTier).toBe(false);
|
|
181
|
-
expect(result.current.privacyState.dataCollectionOptIn).toBeUndefined();
|
|
182
|
-
});
|
|
183
|
-
|
|
184
|
-
it('should throw error when content generator is not a CodeAssistServer', async () => {
|
|
185
|
-
// Mock a non-CodeAssistServer content generator
|
|
186
|
-
const mockOtherGenerator = { someOtherMethod: vi.fn() };
|
|
187
|
-
(
|
|
188
|
-
mockLoggingContentGenerator.getWrapped as ReturnType<typeof vi.fn>
|
|
189
|
-
).mockReturnValue(mockOtherGenerator);
|
|
190
|
-
|
|
191
|
-
const { result } = renderHook(() => usePrivacySettings(mockConfig));
|
|
192
|
-
|
|
193
|
-
await waitFor(() => {
|
|
194
|
-
expect(result.current.privacyState.isLoading).toBe(false);
|
|
195
|
-
});
|
|
196
|
-
|
|
197
|
-
expect(result.current.privacyState.error).toBe('Oauth not being used');
|
|
198
|
-
});
|
|
199
|
-
|
|
200
|
-
it('should throw error when CodeAssistServer has no projectId', async () => {
|
|
201
|
-
// Mock CodeAssistServer without projectId
|
|
202
|
-
const mockServerNoProject = {
|
|
203
|
-
...mockCodeAssistServer,
|
|
204
|
-
projectId: undefined,
|
|
205
|
-
};
|
|
206
|
-
(
|
|
207
|
-
mockLoggingContentGenerator.getWrapped as ReturnType<typeof vi.fn>
|
|
208
|
-
).mockReturnValue(mockServerNoProject);
|
|
209
|
-
|
|
210
|
-
const { result } = renderHook(() => usePrivacySettings(mockConfig));
|
|
211
|
-
|
|
212
|
-
await waitFor(() => {
|
|
213
|
-
expect(result.current.privacyState.isLoading).toBe(false);
|
|
214
|
-
});
|
|
215
|
-
|
|
216
|
-
expect(result.current.privacyState.error).toBe('Oauth not being used');
|
|
217
|
-
});
|
|
218
|
-
|
|
219
|
-
it('should update data collection opt-in setting', async () => {
|
|
220
|
-
const { result } = renderHook(() => usePrivacySettings(mockConfig));
|
|
221
|
-
|
|
222
|
-
// Wait for initial load
|
|
223
|
-
await waitFor(() => {
|
|
224
|
-
expect(result.current.privacyState.isLoading).toBe(false);
|
|
225
|
-
});
|
|
226
|
-
|
|
227
|
-
// Update the setting
|
|
228
|
-
await result.current.updateDataCollectionOptIn(false);
|
|
229
|
-
|
|
230
|
-
// Wait for update to complete
|
|
231
|
-
await waitFor(() => {
|
|
232
|
-
expect(result.current.privacyState.dataCollectionOptIn).toBe(false);
|
|
233
|
-
});
|
|
234
|
-
|
|
235
|
-
expect(
|
|
236
|
-
mockCodeAssistServer.setCodeAssistGlobalUserSetting,
|
|
237
|
-
).toHaveBeenCalledWith({
|
|
238
|
-
cloudaicompanionProject: 'test-project-id',
|
|
239
|
-
freeTierDataCollectionOptin: false,
|
|
240
|
-
});
|
|
241
|
-
});
|
|
242
|
-
});
|
|
@@ -1,150 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @license
|
|
3
|
-
* Copyright 2025 Google LLC
|
|
4
|
-
* SPDX-License-Identifier: Apache-2.0
|
|
5
|
-
*/
|
|
6
|
-
|
|
7
|
-
import { useState, useEffect, useCallback } from 'react';
|
|
8
|
-
import {
|
|
9
|
-
Config,
|
|
10
|
-
CodeAssistServer,
|
|
11
|
-
UserTierId,
|
|
12
|
-
LoggingContentGenerator,
|
|
13
|
-
} from 'fss-link-core';
|
|
14
|
-
|
|
15
|
-
export interface PrivacyState {
|
|
16
|
-
isLoading: boolean;
|
|
17
|
-
error?: string;
|
|
18
|
-
isFreeTier?: boolean;
|
|
19
|
-
dataCollectionOptIn?: boolean;
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
export const usePrivacySettings = (config: Config) => {
|
|
23
|
-
const [privacyState, setPrivacyState] = useState<PrivacyState>({
|
|
24
|
-
isLoading: true,
|
|
25
|
-
});
|
|
26
|
-
|
|
27
|
-
useEffect(() => {
|
|
28
|
-
const fetchInitialState = async () => {
|
|
29
|
-
setPrivacyState({
|
|
30
|
-
isLoading: true,
|
|
31
|
-
});
|
|
32
|
-
try {
|
|
33
|
-
const server = getCodeAssistServer(config);
|
|
34
|
-
const tier = await getTier(server);
|
|
35
|
-
if (tier !== UserTierId.FREE) {
|
|
36
|
-
// We don't need to fetch opt-out info since non-free tier
|
|
37
|
-
// data gathering is already worked out some other way.
|
|
38
|
-
setPrivacyState({
|
|
39
|
-
isLoading: false,
|
|
40
|
-
isFreeTier: false,
|
|
41
|
-
});
|
|
42
|
-
return;
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
const optIn = await getRemoteDataCollectionOptIn(server);
|
|
46
|
-
setPrivacyState({
|
|
47
|
-
isLoading: false,
|
|
48
|
-
isFreeTier: true,
|
|
49
|
-
dataCollectionOptIn: optIn,
|
|
50
|
-
});
|
|
51
|
-
} catch (e) {
|
|
52
|
-
setPrivacyState({
|
|
53
|
-
isLoading: false,
|
|
54
|
-
error: e instanceof Error ? e.message : String(e),
|
|
55
|
-
});
|
|
56
|
-
}
|
|
57
|
-
};
|
|
58
|
-
fetchInitialState();
|
|
59
|
-
}, [config]);
|
|
60
|
-
|
|
61
|
-
const updateDataCollectionOptIn = useCallback(
|
|
62
|
-
async (optIn: boolean) => {
|
|
63
|
-
try {
|
|
64
|
-
const server = getCodeAssistServer(config);
|
|
65
|
-
const updatedOptIn = await setRemoteDataCollectionOptIn(server, optIn);
|
|
66
|
-
setPrivacyState({
|
|
67
|
-
isLoading: false,
|
|
68
|
-
isFreeTier: true,
|
|
69
|
-
dataCollectionOptIn: updatedOptIn,
|
|
70
|
-
});
|
|
71
|
-
} catch (e) {
|
|
72
|
-
setPrivacyState({
|
|
73
|
-
isLoading: false,
|
|
74
|
-
error: e instanceof Error ? e.message : String(e),
|
|
75
|
-
});
|
|
76
|
-
}
|
|
77
|
-
},
|
|
78
|
-
[config],
|
|
79
|
-
);
|
|
80
|
-
|
|
81
|
-
return {
|
|
82
|
-
privacyState,
|
|
83
|
-
updateDataCollectionOptIn,
|
|
84
|
-
};
|
|
85
|
-
};
|
|
86
|
-
|
|
87
|
-
function getCodeAssistServer(config: Config): CodeAssistServer {
|
|
88
|
-
let server = config.getGeminiClient().getContentGenerator();
|
|
89
|
-
|
|
90
|
-
// Unwrap LoggingContentGenerator if present
|
|
91
|
-
if (server instanceof LoggingContentGenerator) {
|
|
92
|
-
server = server.getWrapped();
|
|
93
|
-
}
|
|
94
|
-
|
|
95
|
-
// Neither of these cases should ever happen.
|
|
96
|
-
if (!(server instanceof CodeAssistServer)) {
|
|
97
|
-
throw new Error('Oauth not being used');
|
|
98
|
-
} else if (!server.projectId) {
|
|
99
|
-
throw new Error('Oauth not being used');
|
|
100
|
-
}
|
|
101
|
-
return server;
|
|
102
|
-
}
|
|
103
|
-
|
|
104
|
-
async function getTier(server: CodeAssistServer): Promise<UserTierId> {
|
|
105
|
-
const loadRes = await server.loadCodeAssist({
|
|
106
|
-
cloudaicompanionProject: server.projectId,
|
|
107
|
-
metadata: {
|
|
108
|
-
ideType: 'IDE_UNSPECIFIED',
|
|
109
|
-
platform: 'PLATFORM_UNSPECIFIED',
|
|
110
|
-
pluginType: 'GEMINI',
|
|
111
|
-
duetProject: server.projectId,
|
|
112
|
-
},
|
|
113
|
-
});
|
|
114
|
-
if (!loadRes.currentTier) {
|
|
115
|
-
throw new Error('User does not have a current tier');
|
|
116
|
-
}
|
|
117
|
-
return loadRes.currentTier.id;
|
|
118
|
-
}
|
|
119
|
-
|
|
120
|
-
async function getRemoteDataCollectionOptIn(
|
|
121
|
-
server: CodeAssistServer,
|
|
122
|
-
): Promise<boolean> {
|
|
123
|
-
try {
|
|
124
|
-
const resp = await server.getCodeAssistGlobalUserSetting();
|
|
125
|
-
return resp.freeTierDataCollectionOptin;
|
|
126
|
-
} catch (error: unknown) {
|
|
127
|
-
if (error && typeof error === 'object' && 'response' in error) {
|
|
128
|
-
const gaxiosError = error as {
|
|
129
|
-
response?: {
|
|
130
|
-
status?: unknown;
|
|
131
|
-
};
|
|
132
|
-
};
|
|
133
|
-
if (gaxiosError.response?.status === 404) {
|
|
134
|
-
return true;
|
|
135
|
-
}
|
|
136
|
-
}
|
|
137
|
-
throw error;
|
|
138
|
-
}
|
|
139
|
-
}
|
|
140
|
-
|
|
141
|
-
async function setRemoteDataCollectionOptIn(
|
|
142
|
-
server: CodeAssistServer,
|
|
143
|
-
optIn: boolean,
|
|
144
|
-
): Promise<boolean> {
|
|
145
|
-
const resp = await server.setCodeAssistGlobalUserSetting({
|
|
146
|
-
cloudaicompanionProject: server.projectId,
|
|
147
|
-
freeTierDataCollectionOptin: optIn,
|
|
148
|
-
});
|
|
149
|
-
return resp.freeTierDataCollectionOptin;
|
|
150
|
-
}
|