@ottocode/web-sdk 0.1.226 → 0.1.228
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/components/chat/FileMentionPopup.d.ts.map +1 -1
- package/dist/components/index.js +25158 -80
- package/dist/components/index.js.map +180 -1
- package/dist/components/messages/AssistantMessageGroup.d.ts.map +1 -1
- package/dist/components/messages/CompactActivityGroup.d.ts +10 -0
- package/dist/components/messages/CompactActivityGroup.d.ts.map +1 -0
- package/dist/components/messages/MessagePartItem.d.ts.map +1 -1
- package/dist/components/messages/MessageThread.d.ts +1 -0
- package/dist/components/messages/MessageThread.d.ts.map +1 -1
- package/dist/components/messages/MessageThreadContainer.d.ts.map +1 -1
- package/dist/components/messages/compactActivity.d.ts +34 -0
- package/dist/components/messages/compactActivity.d.ts.map +1 -0
- package/dist/components/messages/renderers/EditRenderer.d.ts +1 -1
- package/dist/components/messages/renderers/EditRenderer.d.ts.map +1 -1
- package/dist/components/messages/renderers/index.d.ts.map +1 -1
- package/dist/components/messages/renderers/types.d.ts +3 -1
- package/dist/components/messages/renderers/types.d.ts.map +1 -1
- package/dist/components/settings/SettingsSidebar.d.ts.map +1 -1
- package/dist/components/settings/SetuTopupModal.d.ts.map +1 -1
- package/dist/hooks/index.js +4821 -29
- package/dist/hooks/index.js.map +67 -1
- package/dist/hooks/useAuthStatus.d.ts.map +1 -1
- package/dist/hooks/useMCP.d.ts +9 -0
- package/dist/hooks/useMCP.d.ts.map +1 -1
- package/dist/hooks/usePreferences.d.ts +1 -0
- package/dist/hooks/usePreferences.d.ts.map +1 -1
- package/dist/hooks/useSessionStream.d.ts.map +1 -1
- package/dist/index.js +25928 -7
- package/dist/index.js.map +185 -1
- package/dist/lib/api-client/approval.d.ts.map +1 -1
- package/dist/lib/api-client/utils.d.ts.map +1 -1
- package/dist/lib/index.js +1016 -5
- package/dist/lib/index.js.map +22 -1
- package/dist/stores/index.js +693 -22
- package/dist/stores/index.js.map +30 -1
- package/dist/stores/toastStore.d.ts +1 -0
- package/dist/stores/toastStore.d.ts.map +1 -1
- package/dist/types/api.js +2 -2
- package/dist/types/api.js.map +9 -1
- package/package.json +4 -4
- package/dist/assets/provider-logos.js +0 -43
- package/dist/assets/provider-logos.js.map +0 -1
- package/dist/components/branch/BranchModal.js +0 -45
- package/dist/components/branch/BranchModal.js.map +0 -1
- package/dist/components/chat/ChatInput.js +0 -267
- package/dist/components/chat/ChatInput.js.map +0 -1
- package/dist/components/chat/ChatInputContainer.js +0 -295
- package/dist/components/chat/ChatInputContainer.js.map +0 -1
- package/dist/components/chat/ChatInputKeyHandler.js +0 -75
- package/dist/components/chat/ChatInputKeyHandler.js.map +0 -1
- package/dist/components/chat/CommandSuggestionsPopup.js +0 -45
- package/dist/components/chat/CommandSuggestionsPopup.js.map +0 -1
- package/dist/components/chat/ConfigModal.js +0 -46
- package/dist/components/chat/ConfigModal.js.map +0 -1
- package/dist/components/chat/ConfigSelector.js +0 -47
- package/dist/components/chat/ConfigSelector.js.map +0 -1
- package/dist/components/chat/FileMentionPopup.js +0 -138
- package/dist/components/chat/FileMentionPopup.js.map +0 -1
- package/dist/components/chat/ShortcutsModal.js +0 -275
- package/dist/components/chat/ShortcutsModal.js.map +0 -1
- package/dist/components/chat/StopButton.js +0 -25
- package/dist/components/chat/StopButton.js.map +0 -1
- package/dist/components/chat/UnifiedAgentSelector.js +0 -107
- package/dist/components/chat/UnifiedAgentSelector.js.map +0 -1
- package/dist/components/chat/UnifiedModelSelector.js +0 -209
- package/dist/components/chat/UnifiedModelSelector.js.map +0 -1
- package/dist/components/common/ProviderLogo.js +0 -30
- package/dist/components/common/ProviderLogo.js.map +0 -1
- package/dist/components/common/StatusIndicator.js +0 -54
- package/dist/components/common/StatusIndicator.js.map +0 -1
- package/dist/components/common/UsageModal.js +0 -55
- package/dist/components/common/UsageModal.js.map +0 -1
- package/dist/components/common/UsageRing.js +0 -22
- package/dist/components/common/UsageRing.js.map +0 -1
- package/dist/components/file-browser/FileBrowserSidebar.js +0 -50
- package/dist/components/file-browser/FileBrowserSidebar.js.map +0 -1
- package/dist/components/file-browser/FileBrowserSidebarToggle.js +0 -12
- package/dist/components/file-browser/FileBrowserSidebarToggle.js.map +0 -1
- package/dist/components/file-browser/FileViewerPanel.js +0 -85
- package/dist/components/file-browser/FileViewerPanel.js.map +0 -1
- package/dist/components/file-browser/QuickFilePicker.js +0 -118
- package/dist/components/file-browser/QuickFilePicker.js.map +0 -1
- package/dist/components/git/GitCommitModal.js +0 -70
- package/dist/components/git/GitCommitModal.js.map +0 -1
- package/dist/components/git/GitDiffPanel.js +0 -60
- package/dist/components/git/GitDiffPanel.js.map +0 -1
- package/dist/components/git/GitDiffViewer.js +0 -224
- package/dist/components/git/GitDiffViewer.js.map +0 -1
- package/dist/components/git/GitFileItem.js +0 -145
- package/dist/components/git/GitFileItem.js.map +0 -1
- package/dist/components/git/GitFileList.js +0 -108
- package/dist/components/git/GitFileList.js.map +0 -1
- package/dist/components/git/GitSidebar.js +0 -156
- package/dist/components/git/GitSidebar.js.map +0 -1
- package/dist/components/git/GitSidebarToggle.js +0 -18
- package/dist/components/git/GitSidebarToggle.js.map +0 -1
- package/dist/components/mcp/AddMCPServerModal.js +0 -166
- package/dist/components/mcp/AddMCPServerModal.js.map +0 -1
- package/dist/components/mcp/MCPSidebar.js +0 -192
- package/dist/components/mcp/MCPSidebar.js.map +0 -1
- package/dist/components/mcp/MCPSidebarToggle.js +0 -14
- package/dist/components/mcp/MCPSidebarToggle.js.map +0 -1
- package/dist/components/mcp/index.js +0 -4
- package/dist/components/mcp/index.js.map +0 -1
- package/dist/components/messages/AssistantMessageGroup.js +0 -176
- package/dist/components/messages/AssistantMessageGroup.js.map +0 -1
- package/dist/components/messages/MessagePartItem.js +0 -362
- package/dist/components/messages/MessagePartItem.js.map +0 -1
- package/dist/components/messages/MessageThread.js +0 -239
- package/dist/components/messages/MessageThread.js.map +0 -1
- package/dist/components/messages/MessageThreadContainer.js +0 -22
- package/dist/components/messages/MessageThreadContainer.js.map +0 -1
- package/dist/components/messages/ToolApprovalCard.js +0 -143
- package/dist/components/messages/ToolApprovalCard.js.map +0 -1
- package/dist/components/messages/TopupApprovalCard.js +0 -52
- package/dist/components/messages/TopupApprovalCard.js.map +0 -1
- package/dist/components/messages/UserMessageGroup.js +0 -132
- package/dist/components/messages/UserMessageGroup.js.map +0 -1
- package/dist/components/messages/renderers/ApplyPatchRenderer.js +0 -55
- package/dist/components/messages/renderers/ApplyPatchRenderer.js.map +0 -1
- package/dist/components/messages/renderers/BashRenderer.js +0 -55
- package/dist/components/messages/renderers/BashRenderer.js.map +0 -1
- package/dist/components/messages/renderers/DatabaseToolRenderer.js +0 -151
- package/dist/components/messages/renderers/DatabaseToolRenderer.js.map +0 -1
- package/dist/components/messages/renderers/DebugRenderer.js +0 -5
- package/dist/components/messages/renderers/DebugRenderer.js.map +0 -1
- package/dist/components/messages/renderers/DiffView.js +0 -206
- package/dist/components/messages/renderers/DiffView.js.map +0 -1
- package/dist/components/messages/renderers/EditRenderer.js +0 -25
- package/dist/components/messages/renderers/EditRenderer.js.map +0 -1
- package/dist/components/messages/renderers/ErrorRenderer.js +0 -162
- package/dist/components/messages/renderers/ErrorRenderer.js.map +0 -1
- package/dist/components/messages/renderers/FinishRenderer.js +0 -7
- package/dist/components/messages/renderers/FinishRenderer.js.map +0 -1
- package/dist/components/messages/renderers/GenericRenderer.js +0 -50
- package/dist/components/messages/renderers/GenericRenderer.js.map +0 -1
- package/dist/components/messages/renderers/GitCommitRenderer.js +0 -21
- package/dist/components/messages/renderers/GitCommitRenderer.js.map +0 -1
- package/dist/components/messages/renderers/GitDiffRenderer.js +0 -34
- package/dist/components/messages/renderers/GitDiffRenderer.js.map +0 -1
- package/dist/components/messages/renderers/GitStatusRenderer.js +0 -60
- package/dist/components/messages/renderers/GitStatusRenderer.js.map +0 -1
- package/dist/components/messages/renderers/ListRenderer.js +0 -28
- package/dist/components/messages/renderers/ListRenderer.js.map +0 -1
- package/dist/components/messages/renderers/LoadMcpToolsRenderer.js +0 -20
- package/dist/components/messages/renderers/LoadMcpToolsRenderer.js.map +0 -1
- package/dist/components/messages/renderers/McpToolRenderer.js +0 -68
- package/dist/components/messages/renderers/McpToolRenderer.js.map +0 -1
- package/dist/components/messages/renderers/ProgressUpdateRenderer.js +0 -9
- package/dist/components/messages/renderers/ProgressUpdateRenderer.js.map +0 -1
- package/dist/components/messages/renderers/ReadRenderer.js +0 -87
- package/dist/components/messages/renderers/ReadRenderer.js.map +0 -1
- package/dist/components/messages/renderers/ReasoningRenderer.js +0 -34
- package/dist/components/messages/renderers/ReasoningRenderer.js.map +0 -1
- package/dist/components/messages/renderers/SearchRenderer.js +0 -52
- package/dist/components/messages/renderers/SearchRenderer.js.map +0 -1
- package/dist/components/messages/renderers/SkillRenderer.js +0 -36
- package/dist/components/messages/renderers/SkillRenderer.js.map +0 -1
- package/dist/components/messages/renderers/TerminalRenderer.js +0 -84
- package/dist/components/messages/renderers/TerminalRenderer.js.map +0 -1
- package/dist/components/messages/renderers/TodosRenderer.js +0 -15
- package/dist/components/messages/renderers/TodosRenderer.js.map +0 -1
- package/dist/components/messages/renderers/ToolErrorDisplay.js +0 -10
- package/dist/components/messages/renderers/ToolErrorDisplay.js.map +0 -1
- package/dist/components/messages/renderers/TreeRenderer.js +0 -33
- package/dist/components/messages/renderers/TreeRenderer.js.map +0 -1
- package/dist/components/messages/renderers/WebSearchRenderer.js +0 -29
- package/dist/components/messages/renderers/WebSearchRenderer.js.map +0 -1
- package/dist/components/messages/renderers/WriteRenderer.js +0 -28
- package/dist/components/messages/renderers/WriteRenderer.js.map +0 -1
- package/dist/components/messages/renderers/index.js +0 -129
- package/dist/components/messages/renderers/index.js.map +0 -1
- package/dist/components/messages/renderers/shared/CopyButton.js +0 -27
- package/dist/components/messages/renderers/shared/CopyButton.js.map +0 -1
- package/dist/components/messages/renderers/shared/ImagePreview.js +0 -14
- package/dist/components/messages/renderers/shared/ImagePreview.js.map +0 -1
- package/dist/components/messages/renderers/shared/ToolContentBox.js +0 -9
- package/dist/components/messages/renderers/shared/ToolContentBox.js.map +0 -1
- package/dist/components/messages/renderers/shared/ToolHeader.js +0 -69
- package/dist/components/messages/renderers/shared/ToolHeader.js.map +0 -1
- package/dist/components/messages/renderers/shared/index.js +0 -5
- package/dist/components/messages/renderers/shared/index.js.map +0 -1
- package/dist/components/messages/renderers/types.js +0 -2
- package/dist/components/messages/renderers/types.js.map +0 -1
- package/dist/components/messages/renderers/utils.js +0 -60
- package/dist/components/messages/renderers/utils.js.map +0 -1
- package/dist/components/onboarding/OnboardingModal.js +0 -22
- package/dist/components/onboarding/OnboardingModal.js.map +0 -1
- package/dist/components/onboarding/index.js +0 -4
- package/dist/components/onboarding/index.js.map +0 -1
- package/dist/components/onboarding/steps/DefaultsStep.js +0 -104
- package/dist/components/onboarding/steps/DefaultsStep.js.map +0 -1
- package/dist/components/onboarding/steps/ProviderSetupStep.js +0 -398
- package/dist/components/onboarding/steps/ProviderSetupStep.js.map +0 -1
- package/dist/components/research/ResearchSidebar.js +0 -288
- package/dist/components/research/ResearchSidebar.js.map +0 -1
- package/dist/components/research/ResearchSidebarToggle.js +0 -15
- package/dist/components/research/ResearchSidebarToggle.js.map +0 -1
- package/dist/components/research/index.js +0 -3
- package/dist/components/research/index.js.map +0 -1
- package/dist/components/session-files/SessionFilesDiffPanel.js +0 -345
- package/dist/components/session-files/SessionFilesDiffPanel.js.map +0 -1
- package/dist/components/session-files/SessionFilesSidebar.js +0 -87
- package/dist/components/session-files/SessionFilesSidebar.js.map +0 -1
- package/dist/components/session-files/SessionFilesSidebarToggle.js +0 -15
- package/dist/components/session-files/SessionFilesSidebarToggle.js.map +0 -1
- package/dist/components/session-files/index.js +0 -4
- package/dist/components/session-files/index.js.map +0 -1
- package/dist/components/sessions/EditableTitle.js +0 -40
- package/dist/components/sessions/EditableTitle.js.map +0 -1
- package/dist/components/sessions/LeanHeader.js +0 -70
- package/dist/components/sessions/LeanHeader.js.map +0 -1
- package/dist/components/sessions/SessionHeader.js +0 -75
- package/dist/components/sessions/SessionHeader.js.map +0 -1
- package/dist/components/sessions/SessionItem.js +0 -28
- package/dist/components/sessions/SessionItem.js.map +0 -1
- package/dist/components/sessions/SessionListContainer.js +0 -86
- package/dist/components/sessions/SessionListContainer.js.map +0 -1
- package/dist/components/settings/SettingsSidebar.js +0 -212
- package/dist/components/settings/SettingsSidebar.js.map +0 -1
- package/dist/components/settings/SettingsSidebarToggle.js +0 -12
- package/dist/components/settings/SettingsSidebarToggle.js.map +0 -1
- package/dist/components/settings/SetuTopupModal.js +0 -306
- package/dist/components/settings/SetuTopupModal.js.map +0 -1
- package/dist/components/skills/SkillViewerPanel.js +0 -89
- package/dist/components/skills/SkillViewerPanel.js.map +0 -1
- package/dist/components/skills/SkillsSidebar.js +0 -59
- package/dist/components/skills/SkillsSidebar.js.map +0 -1
- package/dist/components/skills/SkillsSidebarToggle.js +0 -12
- package/dist/components/skills/SkillsSidebarToggle.js.map +0 -1
- package/dist/components/skills/index.js +0 -4
- package/dist/components/skills/index.js.map +0 -1
- package/dist/components/terminals/TerminalPanelToggle.js +0 -13
- package/dist/components/terminals/TerminalPanelToggle.js.map +0 -1
- package/dist/components/terminals/TerminalTabBar.js +0 -22
- package/dist/components/terminals/TerminalTabBar.js.map +0 -1
- package/dist/components/terminals/TerminalViewer.js +0 -371
- package/dist/components/terminals/TerminalViewer.js.map +0 -1
- package/dist/components/terminals/TerminalsPanel.js +0 -134
- package/dist/components/terminals/TerminalsPanel.js.map +0 -1
- package/dist/components/terminals/index.js +0 -11
- package/dist/components/terminals/index.js.map +0 -1
- package/dist/components/tunnel/TunnelSidebar.js +0 -55
- package/dist/components/tunnel/TunnelSidebar.js.map +0 -1
- package/dist/components/tunnel/TunnelSidebarToggle.js +0 -14
- package/dist/components/tunnel/TunnelSidebarToggle.js.map +0 -1
- package/dist/components/tunnel/index.js +0 -3
- package/dist/components/tunnel/index.js.map +0 -1
- package/dist/components/ui/Button.js +0 -19
- package/dist/components/ui/Button.js.map +0 -1
- package/dist/components/ui/Card.js +0 -7
- package/dist/components/ui/Card.js.map +0 -1
- package/dist/components/ui/ConfirmationDialog.js +0 -72
- package/dist/components/ui/ConfirmationDialog.js.map +0 -1
- package/dist/components/ui/Input.js +0 -7
- package/dist/components/ui/Input.js.map +0 -1
- package/dist/components/ui/Modal.js +0 -51
- package/dist/components/ui/Modal.js.map +0 -1
- package/dist/components/ui/ResizeHandle.js +0 -39
- package/dist/components/ui/ResizeHandle.js.map +0 -1
- package/dist/components/ui/Textarea.js +0 -7
- package/dist/components/ui/Textarea.js.map +0 -1
- package/dist/components/ui/Toaster.js +0 -41
- package/dist/components/ui/Toaster.js.map +0 -1
- package/dist/components/ui/ToolApprovalDialog.js +0 -57
- package/dist/components/ui/ToolApprovalDialog.js.map +0 -1
- package/dist/hooks/useAuthStatus.js +0 -287
- package/dist/hooks/useAuthStatus.js.map +0 -1
- package/dist/hooks/useBranch.js +0 -44
- package/dist/hooks/useBranch.js.map +0 -1
- package/dist/hooks/useCommandSuggestions.js +0 -86
- package/dist/hooks/useCommandSuggestions.js.map +0 -1
- package/dist/hooks/useConfig.js +0 -32
- package/dist/hooks/useConfig.js.map +0 -1
- package/dist/hooks/useFileBrowser.js +0 -30
- package/dist/hooks/useFileBrowser.js.map +0 -1
- package/dist/hooks/useFileMention.js +0 -56
- package/dist/hooks/useFileMention.js.map +0 -1
- package/dist/hooks/useFileUpload.js +0 -317
- package/dist/hooks/useFileUpload.js.map +0 -1
- package/dist/hooks/useFiles.js +0 -15
- package/dist/hooks/useFiles.js.map +0 -1
- package/dist/hooks/useGit.js +0 -149
- package/dist/hooks/useGit.js.map +0 -1
- package/dist/hooks/useImageUpload.js +0 -197
- package/dist/hooks/useImageUpload.js.map +0 -1
- package/dist/hooks/useKeyboardShortcuts.js +0 -249
- package/dist/hooks/useKeyboardShortcuts.js.map +0 -1
- package/dist/hooks/useMCP.js +0 -202
- package/dist/hooks/useMCP.js.map +0 -1
- package/dist/hooks/useMessages.js +0 -26
- package/dist/hooks/useMessages.js.map +0 -1
- package/dist/hooks/usePreferences.js +0 -61
- package/dist/hooks/usePreferences.js.map +0 -1
- package/dist/hooks/useProviderUsage.js +0 -44
- package/dist/hooks/useProviderUsage.js.map +0 -1
- package/dist/hooks/useQueueState.js +0 -31
- package/dist/hooks/useQueueState.js.map +0 -1
- package/dist/hooks/useResearch.js +0 -139
- package/dist/hooks/useResearch.js.map +0 -1
- package/dist/hooks/useSessionFiles.js +0 -15
- package/dist/hooks/useSessionFiles.js.map +0 -1
- package/dist/hooks/useSessionStream.js +0 -572
- package/dist/hooks/useSessionStream.js.map +0 -1
- package/dist/hooks/useSessions.js +0 -83
- package/dist/hooks/useSessions.js.map +0 -1
- package/dist/hooks/useSetuBalance.js +0 -71
- package/dist/hooks/useSetuBalance.js.map +0 -1
- package/dist/hooks/useSetuPayments.js +0 -171
- package/dist/hooks/useSetuPayments.js.map +0 -1
- package/dist/hooks/useShareStatus.js +0 -12
- package/dist/hooks/useShareStatus.js.map +0 -1
- package/dist/hooks/useSkills.js +0 -54
- package/dist/hooks/useSkills.js.map +0 -1
- package/dist/hooks/useTerminals.js +0 -67
- package/dist/hooks/useTerminals.js.map +0 -1
- package/dist/hooks/useTheme.js +0 -57
- package/dist/hooks/useTheme.js.map +0 -1
- package/dist/hooks/useToolApprovalShortcuts.js +0 -88
- package/dist/hooks/useToolApprovalShortcuts.js.map +0 -1
- package/dist/hooks/useTopupCallback.js +0 -74
- package/dist/hooks/useTopupCallback.js.map +0 -1
- package/dist/hooks/useTunnel.js +0 -158
- package/dist/hooks/useTunnel.js.map +0 -1
- package/dist/hooks/useVimMode.js +0 -298
- package/dist/hooks/useVimMode.js.map +0 -1
- package/dist/hooks/useWorkingDirectory.js +0 -34
- package/dist/hooks/useWorkingDirectory.js.map +0 -1
- package/dist/lib/api-client/approval.js +0 -25
- package/dist/lib/api-client/approval.js.map +0 -1
- package/dist/lib/api-client/auth.js +0 -139
- package/dist/lib/api-client/auth.js.map +0 -1
- package/dist/lib/api-client/branches.js +0 -45
- package/dist/lib/api-client/branches.js.map +0 -1
- package/dist/lib/api-client/config.js +0 -38
- package/dist/lib/api-client/config.js.map +0 -1
- package/dist/lib/api-client/files.js +0 -35
- package/dist/lib/api-client/files.js.map +0 -1
- package/dist/lib/api-client/git.js +0 -154
- package/dist/lib/api-client/git.js.map +0 -1
- package/dist/lib/api-client/index.js +0 -92
- package/dist/lib/api-client/index.js.map +0 -1
- package/dist/lib/api-client/sessions.js +0 -106
- package/dist/lib/api-client/sessions.js.map +0 -1
- package/dist/lib/api-client/setu.js +0 -144
- package/dist/lib/api-client/setu.js.map +0 -1
- package/dist/lib/api-client/skills.js +0 -31
- package/dist/lib/api-client/skills.js.map +0 -1
- package/dist/lib/api-client/utils.js +0 -65
- package/dist/lib/api-client/utils.js.map +0 -1
- package/dist/lib/commands.js +0 -124
- package/dist/lib/commands.js.map +0 -1
- package/dist/lib/config.js +0 -28
- package/dist/lib/config.js.map +0 -1
- package/dist/lib/nerd-font.js +0 -55
- package/dist/lib/nerd-font.js.map +0 -1
- package/dist/lib/open-url.js +0 -9
- package/dist/lib/open-url.js.map +0 -1
- package/dist/lib/parseResearchContext.js +0 -30
- package/dist/lib/parseResearchContext.js.map +0 -1
- package/dist/lib/sse-client.js +0 -113
- package/dist/lib/sse-client.js.map +0 -1
- package/dist/stores/confirmationStore.js +0 -27
- package/dist/stores/confirmationStore.js.map +0 -1
- package/dist/stores/fileBrowserStore.js +0 -63
- package/dist/stores/fileBrowserStore.js.map +0 -1
- package/dist/stores/filePickerStore.js +0 -8
- package/dist/stores/filePickerStore.js.map +0 -1
- package/dist/stores/focusStore.js +0 -12
- package/dist/stores/focusStore.js.map +0 -1
- package/dist/stores/gitStore.js +0 -63
- package/dist/stores/gitStore.js.map +0 -1
- package/dist/stores/mcpStore.js +0 -63
- package/dist/stores/mcpStore.js.map +0 -1
- package/dist/stores/onboardingStore.js +0 -38
- package/dist/stores/onboardingStore.js.map +0 -1
- package/dist/stores/panelWidthStore.js +0 -12
- package/dist/stores/panelWidthStore.js.map +0 -1
- package/dist/stores/pendingResearchStore.js +0 -38
- package/dist/stores/pendingResearchStore.js.map +0 -1
- package/dist/stores/queueStore.js +0 -11
- package/dist/stores/queueStore.js.map +0 -1
- package/dist/stores/researchStore.js +0 -54
- package/dist/stores/researchStore.js.map +0 -1
- package/dist/stores/sessionFilesStore.js +0 -62
- package/dist/stores/sessionFilesStore.js.map +0 -1
- package/dist/stores/settingsStore.js +0 -29
- package/dist/stores/settingsStore.js.map +0 -1
- package/dist/stores/setuStore.js +0 -29
- package/dist/stores/setuStore.js.map +0 -1
- package/dist/stores/sidebarStore.js +0 -10
- package/dist/stores/sidebarStore.js.map +0 -1
- package/dist/stores/skillsStore.js +0 -46
- package/dist/stores/skillsStore.js.map +0 -1
- package/dist/stores/terminalStore.js +0 -32
- package/dist/stores/terminalStore.js.map +0 -1
- package/dist/stores/toastStore.js +0 -46
- package/dist/stores/toastStore.js.map +0 -1
- package/dist/stores/toolApprovalStore.js +0 -16
- package/dist/stores/toolApprovalStore.js.map +0 -1
- package/dist/stores/topupApprovalStore.js +0 -11
- package/dist/stores/topupApprovalStore.js.map +0 -1
- package/dist/stores/tunnelStore.js +0 -55
- package/dist/stores/tunnelStore.js.map +0 -1
- package/dist/stores/usageStore.js +0 -14
- package/dist/stores/usageStore.js.map +0 -1
package/dist/lib/index.js
CHANGED
|
@@ -1,5 +1,1016 @@
|
|
|
1
|
-
//
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
1
|
+
// src/lib/api-client/sessions.ts
|
|
2
|
+
import {
|
|
3
|
+
createSession as apiCreateSession,
|
|
4
|
+
listSessions as apiListSessions,
|
|
5
|
+
listMessages as apiListMessages,
|
|
6
|
+
createMessage as apiCreateMessage,
|
|
7
|
+
abortSession as apiAbortSession,
|
|
8
|
+
deleteSession as apiDeleteSession,
|
|
9
|
+
updateSession as apiUpdateSession,
|
|
10
|
+
getSessionQueue as apiGetSessionQueue,
|
|
11
|
+
removeFromQueue as apiRemoveFromQueue,
|
|
12
|
+
retryMessage as apiRetryMessage
|
|
13
|
+
} from "@ottocode/api";
|
|
14
|
+
|
|
15
|
+
// src/lib/api-client/utils.ts
|
|
16
|
+
import { client } from "@ottocode/api";
|
|
17
|
+
|
|
18
|
+
// src/lib/config.ts
|
|
19
|
+
function computeApiBaseUrl() {
|
|
20
|
+
const envUrl = import.meta.env?.VITE_API_BASE_URL;
|
|
21
|
+
if (envUrl) {
|
|
22
|
+
return envUrl;
|
|
23
|
+
}
|
|
24
|
+
if (typeof window !== "undefined") {
|
|
25
|
+
const win = window;
|
|
26
|
+
if (win.OTTO_SERVER_URL) {
|
|
27
|
+
return win.OTTO_SERVER_URL;
|
|
28
|
+
}
|
|
29
|
+
if (win.__OTTO_API_URL__) {
|
|
30
|
+
return win.__OTTO_API_URL__;
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
return "http://localhost:9100";
|
|
34
|
+
}
|
|
35
|
+
function getRuntimeApiBaseUrl() {
|
|
36
|
+
return computeApiBaseUrl();
|
|
37
|
+
}
|
|
38
|
+
var API_BASE_URL = computeApiBaseUrl();
|
|
39
|
+
var config = {
|
|
40
|
+
apiBaseUrl: API_BASE_URL
|
|
41
|
+
};
|
|
42
|
+
|
|
43
|
+
// src/lib/api-client/utils.ts
|
|
44
|
+
function getClientAdapter() {
|
|
45
|
+
if (typeof window !== "undefined" && typeof window.fetch === "function") {
|
|
46
|
+
return "fetch";
|
|
47
|
+
}
|
|
48
|
+
return;
|
|
49
|
+
}
|
|
50
|
+
function extractErrorMessage(error) {
|
|
51
|
+
if (!error)
|
|
52
|
+
return "Unknown error";
|
|
53
|
+
if (typeof error === "string")
|
|
54
|
+
return error;
|
|
55
|
+
if (error && typeof error === "object") {
|
|
56
|
+
const errObj = error;
|
|
57
|
+
if (errObj.error && typeof errObj.error === "object") {
|
|
58
|
+
const innerError = errObj.error;
|
|
59
|
+
if (typeof innerError.message === "string")
|
|
60
|
+
return innerError.message;
|
|
61
|
+
}
|
|
62
|
+
if (typeof errObj.error === "string")
|
|
63
|
+
return errObj.error;
|
|
64
|
+
if (typeof errObj.message === "string")
|
|
65
|
+
return errObj.message;
|
|
66
|
+
try {
|
|
67
|
+
return JSON.stringify(error);
|
|
68
|
+
} catch {
|
|
69
|
+
return "Error occurred (unable to parse)";
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
return "Unknown error";
|
|
73
|
+
}
|
|
74
|
+
function configureApiClient() {
|
|
75
|
+
const win = window;
|
|
76
|
+
const baseURL = win.OTTO_SERVER_URL || API_BASE_URL;
|
|
77
|
+
client.setConfig({
|
|
78
|
+
baseURL,
|
|
79
|
+
adapter: getClientAdapter()
|
|
80
|
+
});
|
|
81
|
+
}
|
|
82
|
+
configureApiClient();
|
|
83
|
+
function getBaseUrl() {
|
|
84
|
+
const win = window;
|
|
85
|
+
if (win.OTTO_SERVER_URL)
|
|
86
|
+
return win.OTTO_SERVER_URL;
|
|
87
|
+
return API_BASE_URL;
|
|
88
|
+
}
|
|
89
|
+
function convertSession(apiSession) {
|
|
90
|
+
return {
|
|
91
|
+
...apiSession,
|
|
92
|
+
title: apiSession.title ?? null,
|
|
93
|
+
createdAt: typeof apiSession.createdAt === "string" ? new Date(apiSession.createdAt).getTime() : apiSession.createdAt,
|
|
94
|
+
lastActiveAt: typeof apiSession.lastActiveAt === "string" ? new Date(apiSession.lastActiveAt).getTime() : apiSession.lastActiveAt
|
|
95
|
+
};
|
|
96
|
+
}
|
|
97
|
+
function convertMessage(apiMessage) {
|
|
98
|
+
return {
|
|
99
|
+
...apiMessage,
|
|
100
|
+
createdAt: typeof apiMessage.createdAt === "string" ? new Date(apiMessage.createdAt).getTime() : apiMessage.createdAt,
|
|
101
|
+
completedAt: apiMessage.completedAt ? typeof apiMessage.completedAt === "string" ? new Date(apiMessage.completedAt).getTime() : apiMessage.completedAt : null
|
|
102
|
+
};
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
// src/lib/api-client/sessions.ts
|
|
106
|
+
var sessionsMixin = {
|
|
107
|
+
async getSessions() {
|
|
108
|
+
const page = await this.getSessionsPage({ limit: 200 });
|
|
109
|
+
return page.items;
|
|
110
|
+
},
|
|
111
|
+
async getSessionsPage(params = {}) {
|
|
112
|
+
const { limit = 50, offset = 0 } = params;
|
|
113
|
+
const response = await apiListSessions({
|
|
114
|
+
query: { limit, offset }
|
|
115
|
+
});
|
|
116
|
+
if (response.error)
|
|
117
|
+
throw new Error(extractErrorMessage(response.error));
|
|
118
|
+
const data = response.data;
|
|
119
|
+
return {
|
|
120
|
+
items: (data?.items ?? []).map((s) => convertSession(s)),
|
|
121
|
+
hasMore: data?.hasMore ?? false,
|
|
122
|
+
nextOffset: data?.nextOffset ?? null
|
|
123
|
+
};
|
|
124
|
+
},
|
|
125
|
+
async createSession(data) {
|
|
126
|
+
const response = await apiCreateSession({
|
|
127
|
+
body: data
|
|
128
|
+
});
|
|
129
|
+
if (response.error)
|
|
130
|
+
throw new Error(extractErrorMessage(response.error));
|
|
131
|
+
if (!response.data)
|
|
132
|
+
throw new Error("No data returned from create session");
|
|
133
|
+
return convertSession(response.data);
|
|
134
|
+
},
|
|
135
|
+
async updateSession(sessionId, data) {
|
|
136
|
+
const response = await apiUpdateSession({
|
|
137
|
+
path: { sessionId },
|
|
138
|
+
body: data
|
|
139
|
+
});
|
|
140
|
+
if (response.error)
|
|
141
|
+
throw new Error(extractErrorMessage(response.error));
|
|
142
|
+
return convertSession(response.data);
|
|
143
|
+
},
|
|
144
|
+
async deleteSession(sessionId) {
|
|
145
|
+
const response = await apiDeleteSession({ path: { sessionId } });
|
|
146
|
+
if (response.error)
|
|
147
|
+
throw new Error(extractErrorMessage(response.error));
|
|
148
|
+
return response.data;
|
|
149
|
+
},
|
|
150
|
+
async abortSession(sessionId) {
|
|
151
|
+
const response = await apiAbortSession({ path: { sessionId } });
|
|
152
|
+
if (response.error)
|
|
153
|
+
throw new Error(extractErrorMessage(response.error));
|
|
154
|
+
return response.data;
|
|
155
|
+
},
|
|
156
|
+
async abortMessage(sessionId, _messageId) {
|
|
157
|
+
const response = await apiAbortSession({
|
|
158
|
+
path: { sessionId }
|
|
159
|
+
});
|
|
160
|
+
if (response.error)
|
|
161
|
+
throw new Error("Failed to abort message");
|
|
162
|
+
return response.data;
|
|
163
|
+
},
|
|
164
|
+
async getQueueState(sessionId) {
|
|
165
|
+
const response = await apiGetSessionQueue({ path: { sessionId } });
|
|
166
|
+
if (response.error)
|
|
167
|
+
throw new Error("Failed to get queue state");
|
|
168
|
+
return response.data;
|
|
169
|
+
},
|
|
170
|
+
async removeFromQueue(sessionId, messageId) {
|
|
171
|
+
const response = await apiRemoveFromQueue({
|
|
172
|
+
path: { sessionId, messageId }
|
|
173
|
+
});
|
|
174
|
+
if (response.error)
|
|
175
|
+
throw new Error("Failed to remove from queue");
|
|
176
|
+
return response.data;
|
|
177
|
+
},
|
|
178
|
+
async getMessages(sessionId) {
|
|
179
|
+
const response = await apiListMessages({ path: { id: sessionId } });
|
|
180
|
+
if (response.error)
|
|
181
|
+
throw new Error(extractErrorMessage(response.error));
|
|
182
|
+
return (response.data || []).map(convertMessage);
|
|
183
|
+
},
|
|
184
|
+
async sendMessage(sessionId, data) {
|
|
185
|
+
const response = await apiCreateMessage({
|
|
186
|
+
path: { id: sessionId },
|
|
187
|
+
body: data
|
|
188
|
+
});
|
|
189
|
+
if (response.error)
|
|
190
|
+
throw new Error(extractErrorMessage(response.error));
|
|
191
|
+
return response.data;
|
|
192
|
+
},
|
|
193
|
+
getStreamUrl(sessionId) {
|
|
194
|
+
return `${getBaseUrl()}/v1/sessions/${sessionId}/stream`;
|
|
195
|
+
},
|
|
196
|
+
async retryMessage(sessionId, messageId) {
|
|
197
|
+
const response = await apiRetryMessage({
|
|
198
|
+
path: { sessionId, messageId }
|
|
199
|
+
});
|
|
200
|
+
if (response.error)
|
|
201
|
+
throw new Error(extractErrorMessage(response.error));
|
|
202
|
+
return response.data;
|
|
203
|
+
}
|
|
204
|
+
};
|
|
205
|
+
|
|
206
|
+
// src/lib/api-client/git.ts
|
|
207
|
+
import {
|
|
208
|
+
getGitStatus as apiGetGitStatus,
|
|
209
|
+
getGitDiff as apiGetGitDiff,
|
|
210
|
+
getGitBranch as apiGetGitBranch,
|
|
211
|
+
stageFiles as apiStageFiles,
|
|
212
|
+
unstageFiles as apiUnstageFiles,
|
|
213
|
+
restoreFiles as apiRestoreFiles,
|
|
214
|
+
deleteFiles as apiDeleteFiles,
|
|
215
|
+
commitChanges as apiCommitChanges,
|
|
216
|
+
generateCommitMessage as apiGenerateCommitMessage,
|
|
217
|
+
pushCommits as apiPushCommits,
|
|
218
|
+
pullChanges as apiPullChanges,
|
|
219
|
+
initGitRepo as apiInitGitRepo,
|
|
220
|
+
getGitRemotes as apiGetGitRemotes,
|
|
221
|
+
addGitRemote as apiAddGitRemote,
|
|
222
|
+
removeGitRemote as apiRemoveGitRemote
|
|
223
|
+
} from "@ottocode/api";
|
|
224
|
+
var gitMixin = {
|
|
225
|
+
async initGitRepo() {
|
|
226
|
+
const response = await apiInitGitRepo();
|
|
227
|
+
if (response.error)
|
|
228
|
+
throw new Error(extractErrorMessage(response.error));
|
|
229
|
+
return response.data?.data;
|
|
230
|
+
},
|
|
231
|
+
async getGitStatus() {
|
|
232
|
+
const response = await apiGetGitStatus();
|
|
233
|
+
if (response.error)
|
|
234
|
+
throw new Error(extractErrorMessage(response.error));
|
|
235
|
+
return response.data?.data;
|
|
236
|
+
},
|
|
237
|
+
async getGitDiff(file, staged = false) {
|
|
238
|
+
const response = await apiGetGitDiff({
|
|
239
|
+
query: { file, staged: staged ? "true" : "false" }
|
|
240
|
+
});
|
|
241
|
+
if (response.error)
|
|
242
|
+
throw new Error(extractErrorMessage(response.error));
|
|
243
|
+
return response.data?.data;
|
|
244
|
+
},
|
|
245
|
+
async getGitDiffFullFile(file, staged = false) {
|
|
246
|
+
const response = await apiGetGitDiff({
|
|
247
|
+
query: {
|
|
248
|
+
file,
|
|
249
|
+
staged: staged ? "true" : "false",
|
|
250
|
+
fullFile: "true"
|
|
251
|
+
}
|
|
252
|
+
});
|
|
253
|
+
if (response.error)
|
|
254
|
+
throw new Error(extractErrorMessage(response.error));
|
|
255
|
+
return response.data?.data;
|
|
256
|
+
},
|
|
257
|
+
async generateCommitMessage(sessionId) {
|
|
258
|
+
const response = await apiGenerateCommitMessage({
|
|
259
|
+
body: sessionId ? { sessionId } : {}
|
|
260
|
+
});
|
|
261
|
+
if (response.error)
|
|
262
|
+
throw new Error(extractErrorMessage(response.error));
|
|
263
|
+
return response.data?.data;
|
|
264
|
+
},
|
|
265
|
+
async stageFiles(files) {
|
|
266
|
+
const response = await apiStageFiles({
|
|
267
|
+
body: { files }
|
|
268
|
+
});
|
|
269
|
+
if (response.error)
|
|
270
|
+
throw new Error(extractErrorMessage(response.error));
|
|
271
|
+
return response.data?.data;
|
|
272
|
+
},
|
|
273
|
+
async unstageFiles(files) {
|
|
274
|
+
const response = await apiUnstageFiles({
|
|
275
|
+
body: { files }
|
|
276
|
+
});
|
|
277
|
+
if (response.error)
|
|
278
|
+
throw new Error(extractErrorMessage(response.error));
|
|
279
|
+
return response.data?.data;
|
|
280
|
+
},
|
|
281
|
+
async restoreFiles(files) {
|
|
282
|
+
const response = await apiRestoreFiles({
|
|
283
|
+
body: { files }
|
|
284
|
+
});
|
|
285
|
+
if (response.error)
|
|
286
|
+
throw new Error(extractErrorMessage(response.error));
|
|
287
|
+
return response.data?.data;
|
|
288
|
+
},
|
|
289
|
+
async deleteFiles(files) {
|
|
290
|
+
const response = await apiDeleteFiles({
|
|
291
|
+
body: { files }
|
|
292
|
+
});
|
|
293
|
+
if (response.error)
|
|
294
|
+
throw new Error(extractErrorMessage(response.error));
|
|
295
|
+
return response.data?.data;
|
|
296
|
+
},
|
|
297
|
+
async commitChanges(message) {
|
|
298
|
+
const response = await apiCommitChanges({
|
|
299
|
+
body: { message }
|
|
300
|
+
});
|
|
301
|
+
if (response.error)
|
|
302
|
+
throw new Error(extractErrorMessage(response.error));
|
|
303
|
+
return response.data?.data;
|
|
304
|
+
},
|
|
305
|
+
async getGitBranch() {
|
|
306
|
+
const response = await apiGetGitBranch();
|
|
307
|
+
if (response.error)
|
|
308
|
+
throw new Error(extractErrorMessage(response.error));
|
|
309
|
+
return response.data?.data;
|
|
310
|
+
},
|
|
311
|
+
async pushCommits() {
|
|
312
|
+
const response = await apiPushCommits({
|
|
313
|
+
body: {}
|
|
314
|
+
});
|
|
315
|
+
if (response.error)
|
|
316
|
+
throw new Error(extractErrorMessage(response.error));
|
|
317
|
+
return response.data?.data;
|
|
318
|
+
},
|
|
319
|
+
async pullChanges() {
|
|
320
|
+
const response = await apiPullChanges({
|
|
321
|
+
body: {}
|
|
322
|
+
});
|
|
323
|
+
if (response.error)
|
|
324
|
+
throw new Error(extractErrorMessage(response.error));
|
|
325
|
+
return response.data?.data;
|
|
326
|
+
},
|
|
327
|
+
async getRemotes() {
|
|
328
|
+
const response = await apiGetGitRemotes();
|
|
329
|
+
if (response.error)
|
|
330
|
+
throw new Error(extractErrorMessage(response.error));
|
|
331
|
+
return response.data?.data?.remotes;
|
|
332
|
+
},
|
|
333
|
+
async addRemote(name, url) {
|
|
334
|
+
const response = await apiAddGitRemote({
|
|
335
|
+
body: { name, url }
|
|
336
|
+
});
|
|
337
|
+
if (response.error)
|
|
338
|
+
throw new Error(extractErrorMessage(response.error));
|
|
339
|
+
return response.data?.data;
|
|
340
|
+
},
|
|
341
|
+
async removeRemote(name) {
|
|
342
|
+
const response = await apiRemoveGitRemote({
|
|
343
|
+
body: { name }
|
|
344
|
+
});
|
|
345
|
+
if (response.error)
|
|
346
|
+
throw new Error(extractErrorMessage(response.error));
|
|
347
|
+
return response.data?.data;
|
|
348
|
+
}
|
|
349
|
+
};
|
|
350
|
+
|
|
351
|
+
// src/lib/api-client/config.ts
|
|
352
|
+
import {
|
|
353
|
+
getConfig as apiGetConfig,
|
|
354
|
+
getProviderModels as apiGetProviderModels,
|
|
355
|
+
getAllModels as apiGetAllModels,
|
|
356
|
+
updateDefaults as apiUpdateDefaults
|
|
357
|
+
} from "@ottocode/api";
|
|
358
|
+
var configMixin = {
|
|
359
|
+
async getConfig() {
|
|
360
|
+
const response = await apiGetConfig();
|
|
361
|
+
if (response.error)
|
|
362
|
+
throw new Error(extractErrorMessage(response.error));
|
|
363
|
+
return response.data;
|
|
364
|
+
},
|
|
365
|
+
async getModels(providerId) {
|
|
366
|
+
const response = await apiGetProviderModels({
|
|
367
|
+
path: { provider: providerId }
|
|
368
|
+
});
|
|
369
|
+
if (response.error)
|
|
370
|
+
throw new Error(extractErrorMessage(response.error));
|
|
371
|
+
return response.data;
|
|
372
|
+
},
|
|
373
|
+
async getAllModels() {
|
|
374
|
+
const response = await apiGetAllModels();
|
|
375
|
+
if (response.error)
|
|
376
|
+
throw new Error(extractErrorMessage(response.error));
|
|
377
|
+
return response.data;
|
|
378
|
+
},
|
|
379
|
+
async updateDefaults(data) {
|
|
380
|
+
const response = await apiUpdateDefaults({
|
|
381
|
+
body: data
|
|
382
|
+
});
|
|
383
|
+
if (response.error)
|
|
384
|
+
throw new Error(extractErrorMessage(response.error));
|
|
385
|
+
return response.data;
|
|
386
|
+
}
|
|
387
|
+
};
|
|
388
|
+
|
|
389
|
+
// src/lib/api-client/files.ts
|
|
390
|
+
import {
|
|
391
|
+
listFiles as apiListFiles,
|
|
392
|
+
getFileTree as apiGetFileTree,
|
|
393
|
+
readFile as apiReadFile,
|
|
394
|
+
getSessionFiles as apiGetSessionFiles
|
|
395
|
+
} from "@ottocode/api";
|
|
396
|
+
var filesMixin = {
|
|
397
|
+
async listFiles() {
|
|
398
|
+
const response = await apiListFiles();
|
|
399
|
+
if (response.error)
|
|
400
|
+
throw new Error(extractErrorMessage(response.error));
|
|
401
|
+
return response.data;
|
|
402
|
+
},
|
|
403
|
+
async getFileTree(dirPath = ".") {
|
|
404
|
+
const response = await apiGetFileTree({
|
|
405
|
+
query: { path: dirPath }
|
|
406
|
+
});
|
|
407
|
+
if (response.error)
|
|
408
|
+
throw new Error(extractErrorMessage(response.error));
|
|
409
|
+
return response.data;
|
|
410
|
+
},
|
|
411
|
+
async readFileContent(filePath) {
|
|
412
|
+
const response = await apiReadFile({
|
|
413
|
+
query: { path: filePath }
|
|
414
|
+
});
|
|
415
|
+
if (response.error)
|
|
416
|
+
throw new Error(extractErrorMessage(response.error));
|
|
417
|
+
return response.data;
|
|
418
|
+
},
|
|
419
|
+
async getSessionFiles(sessionId) {
|
|
420
|
+
const response = await apiGetSessionFiles({ path: { sessionId } });
|
|
421
|
+
if (response.error)
|
|
422
|
+
throw new Error(extractErrorMessage(response.error));
|
|
423
|
+
return response.data;
|
|
424
|
+
}
|
|
425
|
+
};
|
|
426
|
+
|
|
427
|
+
// src/lib/api-client/branches.ts
|
|
428
|
+
import {
|
|
429
|
+
createBranch as apiCreateBranch,
|
|
430
|
+
listBranches as apiListBranches,
|
|
431
|
+
getParentSession as apiGetParentSession,
|
|
432
|
+
getShareStatus as apiGetShareStatus,
|
|
433
|
+
shareSession as apiShareSession,
|
|
434
|
+
syncShare as apiSyncShare
|
|
435
|
+
} from "@ottocode/api";
|
|
436
|
+
var branchesMixin = {
|
|
437
|
+
async createBranch(sessionId, data) {
|
|
438
|
+
const response = await apiCreateBranch({
|
|
439
|
+
path: { sessionId },
|
|
440
|
+
body: data
|
|
441
|
+
});
|
|
442
|
+
if (response.error)
|
|
443
|
+
throw new Error(extractErrorMessage(response.error));
|
|
444
|
+
return response.data;
|
|
445
|
+
},
|
|
446
|
+
async listBranches(sessionId) {
|
|
447
|
+
const response = await apiListBranches({ path: { sessionId } });
|
|
448
|
+
if (response.error)
|
|
449
|
+
throw new Error(extractErrorMessage(response.error));
|
|
450
|
+
return response.data;
|
|
451
|
+
},
|
|
452
|
+
async getParentSession(sessionId) {
|
|
453
|
+
const response = await apiGetParentSession({ path: { sessionId } });
|
|
454
|
+
if (response.error)
|
|
455
|
+
throw new Error(extractErrorMessage(response.error));
|
|
456
|
+
return response.data;
|
|
457
|
+
},
|
|
458
|
+
async getShareStatus(sessionId) {
|
|
459
|
+
const response = await apiGetShareStatus({ path: { sessionId } });
|
|
460
|
+
if (response.error)
|
|
461
|
+
return { shared: false };
|
|
462
|
+
return response.data;
|
|
463
|
+
},
|
|
464
|
+
async shareSession(sessionId) {
|
|
465
|
+
const response = await apiShareSession({ path: { sessionId } });
|
|
466
|
+
if (response.error)
|
|
467
|
+
throw new Error(extractErrorMessage(response.error));
|
|
468
|
+
return response.data;
|
|
469
|
+
},
|
|
470
|
+
async syncSession(sessionId) {
|
|
471
|
+
const response = await apiSyncShare({ path: { sessionId } });
|
|
472
|
+
if (response.error)
|
|
473
|
+
throw new Error(extractErrorMessage(response.error));
|
|
474
|
+
return response.data;
|
|
475
|
+
}
|
|
476
|
+
};
|
|
477
|
+
|
|
478
|
+
// src/lib/api-client/approval.ts
|
|
479
|
+
import {
|
|
480
|
+
resolveApproval as apiResolveApproval,
|
|
481
|
+
getPendingApprovals as apiGetPendingApprovals
|
|
482
|
+
} from "@ottocode/api";
|
|
483
|
+
var approvalMixin = {
|
|
484
|
+
async approveToolCall(sessionId, callId, approved) {
|
|
485
|
+
const response = await apiResolveApproval({
|
|
486
|
+
path: { id: sessionId },
|
|
487
|
+
body: { callId, approved, sessionId }
|
|
488
|
+
});
|
|
489
|
+
if (response.error)
|
|
490
|
+
throw new Error("Failed to send tool approval");
|
|
491
|
+
return response.data;
|
|
492
|
+
},
|
|
493
|
+
async getPendingApprovals(sessionId) {
|
|
494
|
+
const response = await apiGetPendingApprovals({
|
|
495
|
+
path: { id: sessionId }
|
|
496
|
+
});
|
|
497
|
+
if (response.error)
|
|
498
|
+
return { ok: false, pending: [] };
|
|
499
|
+
return response.data;
|
|
500
|
+
}
|
|
501
|
+
};
|
|
502
|
+
|
|
503
|
+
// src/lib/api-client/setu.ts
|
|
504
|
+
import {
|
|
505
|
+
getSetuBalance as apiGetSetuBalance,
|
|
506
|
+
getSetuWallet as apiGetSetuWallet,
|
|
507
|
+
getSetuUsdcBalance as apiGetSetuUsdcBalance,
|
|
508
|
+
createPolarCheckout as apiCreatePolarCheckout,
|
|
509
|
+
getPolarTopupEstimate as apiGetPolarTopupEstimate,
|
|
510
|
+
getPolarTopupStatus as apiGetPolarTopupStatus,
|
|
511
|
+
getRazorpayTopupEstimate as apiGetRazorpayTopupEstimate,
|
|
512
|
+
createRazorpayOrder as apiCreateRazorpayOrder,
|
|
513
|
+
verifyRazorpayPayment as apiVerifyRazorpayPayment,
|
|
514
|
+
selectTopupMethod as apiSelectTopupMethod,
|
|
515
|
+
cancelTopup as apiCancelTopup,
|
|
516
|
+
getPendingTopup as apiGetPendingTopup
|
|
517
|
+
} from "@ottocode/api";
|
|
518
|
+
var setuMixin = {
|
|
519
|
+
async getSetuBalance() {
|
|
520
|
+
try {
|
|
521
|
+
const response = await apiGetSetuBalance();
|
|
522
|
+
if (response.error)
|
|
523
|
+
return null;
|
|
524
|
+
return response.data;
|
|
525
|
+
} catch {
|
|
526
|
+
return null;
|
|
527
|
+
}
|
|
528
|
+
},
|
|
529
|
+
async getSetuWallet() {
|
|
530
|
+
try {
|
|
531
|
+
const response = await apiGetSetuWallet();
|
|
532
|
+
if (response.error)
|
|
533
|
+
return { configured: false };
|
|
534
|
+
return response.data;
|
|
535
|
+
} catch {
|
|
536
|
+
return { configured: false };
|
|
537
|
+
}
|
|
538
|
+
},
|
|
539
|
+
async getSetuUsdcBalance(network = "mainnet") {
|
|
540
|
+
try {
|
|
541
|
+
const response = await apiGetSetuUsdcBalance({
|
|
542
|
+
query: { network }
|
|
543
|
+
});
|
|
544
|
+
if (response.error)
|
|
545
|
+
return null;
|
|
546
|
+
return response.data;
|
|
547
|
+
} catch {
|
|
548
|
+
return null;
|
|
549
|
+
}
|
|
550
|
+
},
|
|
551
|
+
async getPolarTopupEstimate(amount) {
|
|
552
|
+
try {
|
|
553
|
+
const response = await apiGetPolarTopupEstimate({
|
|
554
|
+
query: { amount }
|
|
555
|
+
});
|
|
556
|
+
if (response.error)
|
|
557
|
+
return null;
|
|
558
|
+
return response.data;
|
|
559
|
+
} catch {
|
|
560
|
+
return null;
|
|
561
|
+
}
|
|
562
|
+
},
|
|
563
|
+
async createPolarCheckout(amount, successUrl) {
|
|
564
|
+
const response = await apiCreatePolarCheckout({
|
|
565
|
+
body: { amount, successUrl }
|
|
566
|
+
});
|
|
567
|
+
if (response.error)
|
|
568
|
+
throw new Error(extractErrorMessage(response.error));
|
|
569
|
+
return response.data;
|
|
570
|
+
},
|
|
571
|
+
async selectTopupMethod(sessionId, method) {
|
|
572
|
+
const response = await apiSelectTopupMethod({
|
|
573
|
+
body: { sessionId, method }
|
|
574
|
+
});
|
|
575
|
+
if (response.error)
|
|
576
|
+
throw new Error(extractErrorMessage(response.error));
|
|
577
|
+
return response.data;
|
|
578
|
+
},
|
|
579
|
+
async cancelTopup(sessionId, reason) {
|
|
580
|
+
const response = await apiCancelTopup({
|
|
581
|
+
body: { sessionId, reason }
|
|
582
|
+
});
|
|
583
|
+
if (response.error)
|
|
584
|
+
throw new Error(extractErrorMessage(response.error));
|
|
585
|
+
return response.data;
|
|
586
|
+
},
|
|
587
|
+
async getPendingTopup(sessionId) {
|
|
588
|
+
try {
|
|
589
|
+
const response = await apiGetPendingTopup({
|
|
590
|
+
query: { sessionId }
|
|
591
|
+
});
|
|
592
|
+
if (response.error)
|
|
593
|
+
return { hasPending: false };
|
|
594
|
+
return response.data;
|
|
595
|
+
} catch {
|
|
596
|
+
return { hasPending: false };
|
|
597
|
+
}
|
|
598
|
+
},
|
|
599
|
+
async getPolarTopupStatus(checkoutId) {
|
|
600
|
+
try {
|
|
601
|
+
const response = await apiGetPolarTopupStatus({
|
|
602
|
+
query: { checkoutId }
|
|
603
|
+
});
|
|
604
|
+
if (response.error)
|
|
605
|
+
return null;
|
|
606
|
+
return response.data;
|
|
607
|
+
} catch {
|
|
608
|
+
return null;
|
|
609
|
+
}
|
|
610
|
+
},
|
|
611
|
+
async getRazorpayTopupEstimate(amount) {
|
|
612
|
+
try {
|
|
613
|
+
const response = await apiGetRazorpayTopupEstimate({
|
|
614
|
+
query: { amount }
|
|
615
|
+
});
|
|
616
|
+
if (response.error)
|
|
617
|
+
return null;
|
|
618
|
+
return response.data;
|
|
619
|
+
} catch {
|
|
620
|
+
return null;
|
|
621
|
+
}
|
|
622
|
+
},
|
|
623
|
+
async createRazorpayOrder(amount) {
|
|
624
|
+
const response = await apiCreateRazorpayOrder({
|
|
625
|
+
body: { amount }
|
|
626
|
+
});
|
|
627
|
+
if (response.error)
|
|
628
|
+
throw new Error(extractErrorMessage(response.error));
|
|
629
|
+
return response.data;
|
|
630
|
+
},
|
|
631
|
+
async verifyRazorpayPayment(params) {
|
|
632
|
+
const response = await apiVerifyRazorpayPayment({
|
|
633
|
+
body: params
|
|
634
|
+
});
|
|
635
|
+
if (response.error)
|
|
636
|
+
throw new Error(extractErrorMessage(response.error));
|
|
637
|
+
return response.data;
|
|
638
|
+
}
|
|
639
|
+
};
|
|
640
|
+
|
|
641
|
+
// src/lib/api-client/auth.ts
|
|
642
|
+
import {
|
|
643
|
+
getAuthStatus as apiGetAuthStatus,
|
|
644
|
+
setupSetuWallet as apiSetupSetuWallet,
|
|
645
|
+
importSetuWallet as apiImportSetuWallet,
|
|
646
|
+
exportSetuWallet as apiExportSetuWallet,
|
|
647
|
+
addProviderApiKey as apiAddProviderApiKey,
|
|
648
|
+
removeProvider as apiRemoveProvider,
|
|
649
|
+
completeOnboarding as apiCompleteOnboarding,
|
|
650
|
+
getOAuthUrl as apiGetOAuthUrl,
|
|
651
|
+
exchangeOAuthCode as apiExchangeOAuthCode,
|
|
652
|
+
startCopilotDeviceFlow as apiStartCopilotDeviceFlow,
|
|
653
|
+
pollCopilotDeviceFlow as apiPollCopilotDeviceFlow,
|
|
654
|
+
getCopilotAuthMethods as apiGetCopilotAuthMethods,
|
|
655
|
+
saveCopilotToken as apiSaveCopilotToken,
|
|
656
|
+
importCopilotTokenFromGh as apiImportCopilotTokenFromGh,
|
|
657
|
+
getCopilotDiagnostics as apiGetCopilotDiagnostics,
|
|
658
|
+
getProviderUsage as apiGetProviderUsage
|
|
659
|
+
} from "@ottocode/api";
|
|
660
|
+
var authMixin = {
|
|
661
|
+
async getAuthStatus() {
|
|
662
|
+
const response = await apiGetAuthStatus();
|
|
663
|
+
if (response.error)
|
|
664
|
+
throw new Error(extractErrorMessage(response.error));
|
|
665
|
+
return response.data;
|
|
666
|
+
},
|
|
667
|
+
async setupSetuWallet() {
|
|
668
|
+
const response = await apiSetupSetuWallet();
|
|
669
|
+
if (response.error)
|
|
670
|
+
throw new Error(extractErrorMessage(response.error));
|
|
671
|
+
return response.data;
|
|
672
|
+
},
|
|
673
|
+
async importSetuWallet(privateKey) {
|
|
674
|
+
const response = await apiImportSetuWallet({
|
|
675
|
+
body: { privateKey }
|
|
676
|
+
});
|
|
677
|
+
if (response.error)
|
|
678
|
+
throw new Error(extractErrorMessage(response.error));
|
|
679
|
+
return response.data;
|
|
680
|
+
},
|
|
681
|
+
async exportSetuWallet() {
|
|
682
|
+
const response = await apiExportSetuWallet();
|
|
683
|
+
if (response.error)
|
|
684
|
+
throw new Error(extractErrorMessage(response.error));
|
|
685
|
+
return response.data;
|
|
686
|
+
},
|
|
687
|
+
async addProvider(provider, apiKey) {
|
|
688
|
+
const response = await apiAddProviderApiKey({
|
|
689
|
+
path: { provider },
|
|
690
|
+
body: { apiKey }
|
|
691
|
+
});
|
|
692
|
+
if (response.error)
|
|
693
|
+
throw new Error(extractErrorMessage(response.error));
|
|
694
|
+
return response.data;
|
|
695
|
+
},
|
|
696
|
+
async removeProvider(provider) {
|
|
697
|
+
const response = await apiRemoveProvider({ path: { provider } });
|
|
698
|
+
if (response.error)
|
|
699
|
+
throw new Error(extractErrorMessage(response.error));
|
|
700
|
+
return response.data;
|
|
701
|
+
},
|
|
702
|
+
async completeOnboarding() {
|
|
703
|
+
const response = await apiCompleteOnboarding();
|
|
704
|
+
if (response.error)
|
|
705
|
+
throw new Error(extractErrorMessage(response.error));
|
|
706
|
+
return response.data;
|
|
707
|
+
},
|
|
708
|
+
getOAuthStartUrl(provider, mode) {
|
|
709
|
+
const baseUrl = `${getBaseUrl()}/v1/auth/${provider}/oauth/start`;
|
|
710
|
+
if (mode)
|
|
711
|
+
return `${baseUrl}?mode=${mode}`;
|
|
712
|
+
return baseUrl;
|
|
713
|
+
},
|
|
714
|
+
async getOAuthUrl(provider, mode) {
|
|
715
|
+
const response = await apiGetOAuthUrl({
|
|
716
|
+
path: { provider },
|
|
717
|
+
body: { mode }
|
|
718
|
+
});
|
|
719
|
+
if (response.error)
|
|
720
|
+
throw new Error(extractErrorMessage(response.error));
|
|
721
|
+
return response.data;
|
|
722
|
+
},
|
|
723
|
+
async exchangeOAuthCode(provider, code, sessionId) {
|
|
724
|
+
const response = await apiExchangeOAuthCode({
|
|
725
|
+
path: { provider },
|
|
726
|
+
body: { code, sessionId }
|
|
727
|
+
});
|
|
728
|
+
if (response.error)
|
|
729
|
+
throw new Error(extractErrorMessage(response.error));
|
|
730
|
+
return response.data;
|
|
731
|
+
},
|
|
732
|
+
async startCopilotDeviceFlow() {
|
|
733
|
+
const response = await apiStartCopilotDeviceFlow();
|
|
734
|
+
if (response.error)
|
|
735
|
+
throw new Error(extractErrorMessage(response.error));
|
|
736
|
+
return response.data;
|
|
737
|
+
},
|
|
738
|
+
async pollCopilotDeviceFlow(sessionId) {
|
|
739
|
+
const response = await apiPollCopilotDeviceFlow({
|
|
740
|
+
body: { sessionId }
|
|
741
|
+
});
|
|
742
|
+
if (response.error)
|
|
743
|
+
throw new Error(extractErrorMessage(response.error));
|
|
744
|
+
return response.data;
|
|
745
|
+
},
|
|
746
|
+
async getCopilotAuthMethods() {
|
|
747
|
+
const response = await apiGetCopilotAuthMethods();
|
|
748
|
+
if (response.error)
|
|
749
|
+
throw new Error(extractErrorMessage(response.error));
|
|
750
|
+
return response.data;
|
|
751
|
+
},
|
|
752
|
+
async saveCopilotToken(token) {
|
|
753
|
+
const response = await apiSaveCopilotToken({ body: { token } });
|
|
754
|
+
if (response.error)
|
|
755
|
+
throw new Error(extractErrorMessage(response.error));
|
|
756
|
+
return response.data;
|
|
757
|
+
},
|
|
758
|
+
async importCopilotTokenFromGh() {
|
|
759
|
+
const response = await apiImportCopilotTokenFromGh();
|
|
760
|
+
if (response.error)
|
|
761
|
+
throw new Error(extractErrorMessage(response.error));
|
|
762
|
+
return response.data;
|
|
763
|
+
},
|
|
764
|
+
async getCopilotDiagnostics() {
|
|
765
|
+
const response = await apiGetCopilotDiagnostics();
|
|
766
|
+
if (response.error)
|
|
767
|
+
throw new Error(extractErrorMessage(response.error));
|
|
768
|
+
return response.data;
|
|
769
|
+
},
|
|
770
|
+
async getProviderUsage(provider) {
|
|
771
|
+
const response = await apiGetProviderUsage({
|
|
772
|
+
path: { provider }
|
|
773
|
+
});
|
|
774
|
+
if (response.error)
|
|
775
|
+
throw new Error(extractErrorMessage(response.error));
|
|
776
|
+
return response.data;
|
|
777
|
+
}
|
|
778
|
+
};
|
|
779
|
+
|
|
780
|
+
// src/lib/api-client/skills.ts
|
|
781
|
+
import {
|
|
782
|
+
listSkills as apiListSkills,
|
|
783
|
+
getSkill as apiGetSkill,
|
|
784
|
+
listSkillFiles as apiListSkillFiles,
|
|
785
|
+
getSkillFile as apiGetSkillFile
|
|
786
|
+
} from "@ottocode/api";
|
|
787
|
+
var skillsMixin = {
|
|
788
|
+
async listSkills() {
|
|
789
|
+
const response = await apiListSkills();
|
|
790
|
+
if (response.error)
|
|
791
|
+
throw new Error(extractErrorMessage(response.error));
|
|
792
|
+
return response.data;
|
|
793
|
+
},
|
|
794
|
+
async getSkill(name) {
|
|
795
|
+
const response = await apiGetSkill({ path: { name } });
|
|
796
|
+
if (response.error)
|
|
797
|
+
throw new Error(extractErrorMessage(response.error));
|
|
798
|
+
return response.data;
|
|
799
|
+
},
|
|
800
|
+
async getSkillFiles(name) {
|
|
801
|
+
const response = await apiListSkillFiles({ path: { name } });
|
|
802
|
+
if (response.error)
|
|
803
|
+
throw new Error(extractErrorMessage(response.error));
|
|
804
|
+
return response.data;
|
|
805
|
+
},
|
|
806
|
+
async getSkillFileContent(name, filePath) {
|
|
807
|
+
const response = await apiGetSkillFile({
|
|
808
|
+
path: { name, filePath }
|
|
809
|
+
});
|
|
810
|
+
if (response.error)
|
|
811
|
+
throw new Error(extractErrorMessage(response.error));
|
|
812
|
+
return response.data;
|
|
813
|
+
}
|
|
814
|
+
};
|
|
815
|
+
|
|
816
|
+
// src/lib/api-client/index.ts
|
|
817
|
+
class ApiClient {
|
|
818
|
+
getSessions = sessionsMixin.getSessions;
|
|
819
|
+
getSessionsPage = sessionsMixin.getSessionsPage;
|
|
820
|
+
createSession = sessionsMixin.createSession;
|
|
821
|
+
updateSession = sessionsMixin.updateSession;
|
|
822
|
+
deleteSession = sessionsMixin.deleteSession;
|
|
823
|
+
abortSession = sessionsMixin.abortSession;
|
|
824
|
+
abortMessage = sessionsMixin.abortMessage;
|
|
825
|
+
getQueueState = sessionsMixin.getQueueState;
|
|
826
|
+
removeFromQueue = sessionsMixin.removeFromQueue;
|
|
827
|
+
getMessages = sessionsMixin.getMessages;
|
|
828
|
+
sendMessage = sessionsMixin.sendMessage;
|
|
829
|
+
getStreamUrl = sessionsMixin.getStreamUrl;
|
|
830
|
+
retryMessage = sessionsMixin.retryMessage;
|
|
831
|
+
initGitRepo = gitMixin.initGitRepo;
|
|
832
|
+
getGitStatus = gitMixin.getGitStatus;
|
|
833
|
+
getGitDiff = gitMixin.getGitDiff;
|
|
834
|
+
getGitDiffFullFile = gitMixin.getGitDiffFullFile;
|
|
835
|
+
generateCommitMessage = gitMixin.generateCommitMessage;
|
|
836
|
+
stageFiles = gitMixin.stageFiles;
|
|
837
|
+
unstageFiles = gitMixin.unstageFiles;
|
|
838
|
+
restoreFiles = gitMixin.restoreFiles;
|
|
839
|
+
deleteFiles = gitMixin.deleteFiles;
|
|
840
|
+
commitChanges = gitMixin.commitChanges;
|
|
841
|
+
getGitBranch = gitMixin.getGitBranch;
|
|
842
|
+
pushCommits = gitMixin.pushCommits;
|
|
843
|
+
pullChanges = gitMixin.pullChanges;
|
|
844
|
+
getRemotes = gitMixin.getRemotes;
|
|
845
|
+
addRemote = gitMixin.addRemote;
|
|
846
|
+
removeRemote = gitMixin.removeRemote;
|
|
847
|
+
getConfig = configMixin.getConfig;
|
|
848
|
+
getModels = configMixin.getModels;
|
|
849
|
+
getAllModels = configMixin.getAllModels;
|
|
850
|
+
updateDefaults = configMixin.updateDefaults;
|
|
851
|
+
listFiles = filesMixin.listFiles;
|
|
852
|
+
getFileTree = filesMixin.getFileTree;
|
|
853
|
+
readFileContent = filesMixin.readFileContent;
|
|
854
|
+
getSessionFiles = filesMixin.getSessionFiles;
|
|
855
|
+
createBranch = branchesMixin.createBranch;
|
|
856
|
+
listBranches = branchesMixin.listBranches;
|
|
857
|
+
getParentSession = branchesMixin.getParentSession;
|
|
858
|
+
getShareStatus = branchesMixin.getShareStatus;
|
|
859
|
+
shareSession = branchesMixin.shareSession;
|
|
860
|
+
syncSession = branchesMixin.syncSession;
|
|
861
|
+
approveToolCall = approvalMixin.approveToolCall;
|
|
862
|
+
getPendingApprovals = approvalMixin.getPendingApprovals;
|
|
863
|
+
getSetuBalance = setuMixin.getSetuBalance;
|
|
864
|
+
getSetuWallet = setuMixin.getSetuWallet;
|
|
865
|
+
getSetuUsdcBalance = setuMixin.getSetuUsdcBalance;
|
|
866
|
+
getPolarTopupEstimate = setuMixin.getPolarTopupEstimate;
|
|
867
|
+
createPolarCheckout = setuMixin.createPolarCheckout;
|
|
868
|
+
selectTopupMethod = setuMixin.selectTopupMethod;
|
|
869
|
+
cancelTopup = setuMixin.cancelTopup;
|
|
870
|
+
getPendingTopup = setuMixin.getPendingTopup;
|
|
871
|
+
getPolarTopupStatus = setuMixin.getPolarTopupStatus;
|
|
872
|
+
getRazorpayTopupEstimate = setuMixin.getRazorpayTopupEstimate;
|
|
873
|
+
createRazorpayOrder = setuMixin.createRazorpayOrder;
|
|
874
|
+
verifyRazorpayPayment = setuMixin.verifyRazorpayPayment;
|
|
875
|
+
getAuthStatus = authMixin.getAuthStatus;
|
|
876
|
+
setupSetuWallet = authMixin.setupSetuWallet;
|
|
877
|
+
importSetuWallet = authMixin.importSetuWallet;
|
|
878
|
+
exportSetuWallet = authMixin.exportSetuWallet;
|
|
879
|
+
addProvider = authMixin.addProvider;
|
|
880
|
+
removeProvider = authMixin.removeProvider;
|
|
881
|
+
completeOnboarding = authMixin.completeOnboarding;
|
|
882
|
+
getOAuthStartUrl = authMixin.getOAuthStartUrl;
|
|
883
|
+
getOAuthUrl = authMixin.getOAuthUrl;
|
|
884
|
+
exchangeOAuthCode = authMixin.exchangeOAuthCode;
|
|
885
|
+
startCopilotDeviceFlow = authMixin.startCopilotDeviceFlow;
|
|
886
|
+
pollCopilotDeviceFlow = authMixin.pollCopilotDeviceFlow;
|
|
887
|
+
getCopilotAuthMethods = authMixin.getCopilotAuthMethods;
|
|
888
|
+
saveCopilotToken = authMixin.saveCopilotToken;
|
|
889
|
+
importCopilotTokenFromGh = authMixin.importCopilotTokenFromGh;
|
|
890
|
+
getCopilotDiagnostics = authMixin.getCopilotDiagnostics;
|
|
891
|
+
getProviderUsage = authMixin.getProviderUsage;
|
|
892
|
+
listSkills = skillsMixin.listSkills;
|
|
893
|
+
getSkill = skillsMixin.getSkill;
|
|
894
|
+
getSkillFiles = skillsMixin.getSkillFiles;
|
|
895
|
+
getSkillFileContent = skillsMixin.getSkillFileContent;
|
|
896
|
+
}
|
|
897
|
+
var apiClient = new ApiClient;
|
|
898
|
+
// src/lib/sse-client.ts
|
|
899
|
+
class SSEClient {
|
|
900
|
+
abortController = null;
|
|
901
|
+
handlers = new Map;
|
|
902
|
+
running = false;
|
|
903
|
+
async connect(url) {
|
|
904
|
+
if (this.abortController) {
|
|
905
|
+
this.abortController.abort();
|
|
906
|
+
}
|
|
907
|
+
this.abortController = new AbortController;
|
|
908
|
+
this.running = true;
|
|
909
|
+
try {
|
|
910
|
+
const response = await fetch(url, {
|
|
911
|
+
headers: { Accept: "text/event-stream" },
|
|
912
|
+
signal: this.abortController.signal
|
|
913
|
+
});
|
|
914
|
+
if (!response.ok) {
|
|
915
|
+
console.error("[SSE] Connection failed:", response.status);
|
|
916
|
+
return;
|
|
917
|
+
}
|
|
918
|
+
const reader = response.body?.getReader();
|
|
919
|
+
if (!reader) {
|
|
920
|
+
console.error("[SSE] No response body");
|
|
921
|
+
return;
|
|
922
|
+
}
|
|
923
|
+
const decoder = new TextDecoder;
|
|
924
|
+
let buffer = "";
|
|
925
|
+
while (this.running) {
|
|
926
|
+
const { done, value } = await reader.read();
|
|
927
|
+
if (done)
|
|
928
|
+
break;
|
|
929
|
+
buffer += decoder.decode(value, { stream: true });
|
|
930
|
+
let idx = buffer.indexOf(`
|
|
931
|
+
|
|
932
|
+
`);
|
|
933
|
+
while (idx !== -1) {
|
|
934
|
+
const raw = buffer.slice(0, idx);
|
|
935
|
+
buffer = buffer.slice(idx + 2);
|
|
936
|
+
const lines = raw.split(`
|
|
937
|
+
`);
|
|
938
|
+
let eventType = "message";
|
|
939
|
+
let data = "";
|
|
940
|
+
for (const line of lines) {
|
|
941
|
+
if (line.startsWith("event: ")) {
|
|
942
|
+
eventType = line.slice(7).trim();
|
|
943
|
+
} else if (line.startsWith("data: ")) {
|
|
944
|
+
data += (data ? `
|
|
945
|
+
` : "") + line.slice(6);
|
|
946
|
+
} else if (line.startsWith(":")) {}
|
|
947
|
+
}
|
|
948
|
+
if (data) {
|
|
949
|
+
try {
|
|
950
|
+
const payload = JSON.parse(data);
|
|
951
|
+
this.emit({ type: eventType, payload });
|
|
952
|
+
} catch (error) {
|
|
953
|
+
console.error(`[SSE] Failed to parse ${eventType}:`, error);
|
|
954
|
+
}
|
|
955
|
+
}
|
|
956
|
+
idx = buffer.indexOf(`
|
|
957
|
+
|
|
958
|
+
`);
|
|
959
|
+
}
|
|
960
|
+
}
|
|
961
|
+
} catch (error) {
|
|
962
|
+
if (error instanceof Error && error.name === "AbortError") {} else if (error instanceof TypeError && error.message === "Load failed") {} else {
|
|
963
|
+
console.error("[SSE] Connection error:", error);
|
|
964
|
+
}
|
|
965
|
+
}
|
|
966
|
+
}
|
|
967
|
+
disconnect() {
|
|
968
|
+
this.running = false;
|
|
969
|
+
if (this.abortController) {
|
|
970
|
+
this.abortController.abort();
|
|
971
|
+
this.abortController = null;
|
|
972
|
+
}
|
|
973
|
+
}
|
|
974
|
+
on(eventType, handler) {
|
|
975
|
+
if (!this.handlers.has(eventType)) {
|
|
976
|
+
this.handlers.set(eventType, new Set);
|
|
977
|
+
}
|
|
978
|
+
this.handlers.get(eventType)?.add(handler);
|
|
979
|
+
return () => {
|
|
980
|
+
this.off(eventType, handler);
|
|
981
|
+
};
|
|
982
|
+
}
|
|
983
|
+
off(eventType, handler) {
|
|
984
|
+
const handlers = this.handlers.get(eventType);
|
|
985
|
+
if (handlers) {
|
|
986
|
+
handlers.delete(handler);
|
|
987
|
+
if (handlers.size === 0) {
|
|
988
|
+
this.handlers.delete(eventType);
|
|
989
|
+
}
|
|
990
|
+
}
|
|
991
|
+
}
|
|
992
|
+
emit(event) {
|
|
993
|
+
const handlers = this.handlers.get(event.type);
|
|
994
|
+
if (handlers) {
|
|
995
|
+
for (const handler of handlers) {
|
|
996
|
+
handler(event);
|
|
997
|
+
}
|
|
998
|
+
}
|
|
999
|
+
const allHandlers = this.handlers.get("*");
|
|
1000
|
+
if (allHandlers) {
|
|
1001
|
+
for (const handler of allHandlers) {
|
|
1002
|
+
handler(event);
|
|
1003
|
+
}
|
|
1004
|
+
}
|
|
1005
|
+
}
|
|
1006
|
+
}
|
|
1007
|
+
export {
|
|
1008
|
+
getRuntimeApiBaseUrl,
|
|
1009
|
+
configureApiClient,
|
|
1010
|
+
config,
|
|
1011
|
+
apiClient,
|
|
1012
|
+
SSEClient,
|
|
1013
|
+
API_BASE_URL
|
|
1014
|
+
};
|
|
1015
|
+
|
|
1016
|
+
//# debugId=BED770B2FEE5457A64756E2164756E21
|