windmill-components 1.655.2 → 1.665.1
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/package/components/ApiConnectForm.svelte +6 -6
- package/package/components/ApiConnectForm.svelte.d.ts +3 -2
- package/package/components/AppConnectDrawer.svelte +3 -1
- package/package/components/AppConnectDrawer.svelte.d.ts +2 -0
- package/package/components/AppConnectInner.svelte +137 -72
- package/package/components/AppConnectInner.svelte.d.ts +1 -0
- package/package/components/CompareWorkspaces.svelte +32 -24
- package/package/components/DBManager.svelte +7 -13
- package/package/components/DBTable.svelte +2 -2
- package/package/components/DBTableEditor.svelte +39 -31
- package/package/components/DBTableEditor.svelte.d.ts +2 -2
- package/package/components/DedicatedWorkersSelector.svelte +292 -85
- package/package/components/DeployWorkspace.svelte +30 -26
- package/package/components/Dev.svelte +7 -2
- package/package/components/Dev.svelte.d.ts +3 -0
- package/package/components/Editor.svelte +17 -13
- package/package/components/EditorBar.svelte.d.ts +1 -1
- package/package/components/FilterSearchbar.svelte +1 -1
- package/package/components/FirstStepInputs.svelte +0 -1
- package/package/components/FlowBuilder.svelte +5 -0
- package/package/components/FlowGraphDiffViewer.svelte +3 -0
- package/package/components/FlowGraphViewer.svelte +7 -4
- package/package/components/FlowGraphViewer.svelte.d.ts +1 -0
- package/package/components/FlowGraphViewerStep.svelte +3 -3
- package/package/components/FlowGraphViewerStep.svelte.d.ts +1 -0
- package/package/components/FlowPreviewContent.svelte +11 -1
- package/package/components/FlowStatusViewer.svelte +4 -1
- package/package/components/FlowStatusViewer.svelte.d.ts +3 -1
- package/package/components/FlowStatusViewerInner.svelte +46 -11
- package/package/components/FlowStatusViewerInner.svelte.d.ts +4 -1
- package/package/components/FlowStatusWaitingForEvents.svelte +48 -103
- package/package/components/FlowTimeline.svelte +76 -84
- package/package/components/FlowViewer.svelte +40 -22
- package/package/components/FlowViewer.svelte.d.ts +8 -2
- package/package/components/GroupEditor.svelte +7 -9
- package/package/components/HistoricList.svelte +12 -4
- package/package/components/InstanceGroupEditor.svelte +92 -19
- package/package/components/InstanceSetting.svelte +16 -6
- package/package/components/InstanceSettings.svelte +51 -7
- package/package/components/InstanceSettings.svelte.d.ts +2 -1
- package/package/components/JobLoader.svelte +5 -4
- package/package/components/JobLoader.svelte.d.ts +1 -1
- package/package/components/Login.svelte +9 -1
- package/package/components/NoMainFuncBadge.svelte +2 -2
- package/package/components/OnBehalfOfSelector.svelte +49 -37
- package/package/components/OnBehalfOfSelector.svelte.d.ts +16 -6
- package/package/components/ResourceEditor.svelte +16 -11
- package/package/components/ResourceEditor.svelte.d.ts +1 -0
- package/package/components/ResourceEditorDrawer.svelte +3 -1
- package/package/components/ResourceEditorDrawer.svelte.d.ts +6 -2
- package/package/components/ResourcePicker.svelte +10 -5
- package/package/components/ResourcePicker.svelte.d.ts +2 -0
- package/package/components/S3FilePickerInner.svelte +12 -4
- package/package/components/SchemaForm.svelte +20 -14
- package/package/components/SchemaForm.svelte.d.ts +2 -2
- package/package/components/ScriptBuilder.svelte +158 -18
- package/package/components/ScriptEditor.svelte +674 -150
- package/package/components/ScriptEditor.svelte.d.ts +7 -3
- package/package/components/SuperadminSettings.svelte +4 -1
- package/package/components/SuperadminSettingsInner.svelte +176 -67
- package/package/components/SuperadminSettingsInner.svelte.d.ts +3 -1
- package/package/components/SyncResourceTypes.svelte +31 -0
- package/package/components/SyncResourceTypes.svelte.d.ts +6 -0
- package/package/components/TimelineBar.svelte +14 -8
- package/package/components/TimelineBar.svelte.d.ts +1 -0
- package/package/components/WorkerGroup.svelte +11 -4
- package/package/components/WorkflowTimeline.svelte +386 -58
- package/package/components/WorkflowTimeline.svelte.d.ts +6 -1
- package/package/components/WorkspaceDependenciesEditor.svelte +32 -2
- package/package/components/apps/components/display/dbtable/DeleteRow.svelte +2 -2
- package/package/components/apps/components/display/dbtable/InsertRowRunnable.svelte +2 -2
- package/package/components/apps/components/display/dbtable/UpdateCell.svelte +2 -2
- package/package/components/apps/components/display/dbtable/metadata.js +44 -222
- package/package/components/apps/components/display/dbtable/queries/count.d.ts +9 -0
- package/package/components/apps/components/display/dbtable/queries/delete.d.ts +9 -0
- package/package/components/apps/components/display/dbtable/queries/insert.d.ts +9 -0
- package/package/components/apps/components/display/dbtable/queries/relationalKeys.d.ts +7 -0
- package/package/components/apps/components/display/dbtable/queries/relationalKeys.js +1 -1
- package/package/components/apps/components/display/dbtable/queries/select.d.ts +9 -0
- package/package/components/apps/components/display/dbtable/queries/update.d.ts +9 -0
- package/package/components/apps/editor/AppEditorHeaderDeploy.svelte +11 -9
- package/package/components/apps/editor/appUtilsS3.js +2 -2
- package/package/components/apps/editor/inlineScriptsPanel/InlineScriptsPanel.svelte +53 -10
- package/package/components/common/clearableInput/ClearableInput.svelte +3 -7
- package/package/components/common/confirmationModal/ConfirmationModal.svelte +7 -1
- package/package/components/common/confirmationModal/ConfirmationModal.svelte.d.ts +1 -0
- package/package/components/common/drawer/Disposable.svelte +24 -2
- package/package/components/common/drawer/Disposable.svelte.d.ts +5 -0
- package/package/components/common/modal/Modal.svelte +84 -58
- package/package/components/common/table/AppRow.svelte.d.ts +1 -1
- package/package/components/common/table/FlowRow.svelte.d.ts +1 -1
- package/package/components/common/table/ScriptRow.svelte +31 -3
- package/package/components/common/table/ScriptRow.svelte.d.ts +1 -1
- package/package/components/copilot/MetadataGen.svelte +8 -5
- package/package/components/copilot/MetadataGen.svelte.d.ts +1 -0
- package/package/components/copilot/TestAIKey.svelte +2 -1
- package/package/components/copilot/TestAIKey.svelte.d.ts +1 -0
- package/package/components/copilot/chat/AIChatManager.svelte.js +62 -80
- package/package/components/copilot/chat/HistoryManager.svelte.d.ts +1 -0
- package/package/components/copilot/chat/HistoryManager.svelte.js +3 -0
- package/package/components/copilot/chat/__tests__/app/appChat.eval.test.js +47 -31
- package/package/components/copilot/chat/__tests__/app/appEvalComparison.d.ts +1 -6
- package/package/components/copilot/chat/__tests__/app/appEvalComparison.js +18 -13
- package/package/components/copilot/chat/__tests__/app/appEvalRunner.d.ts +14 -5
- package/package/components/copilot/chat/__tests__/app/appEvalRunner.js +13 -12
- package/package/components/copilot/chat/__tests__/flow/flowChat.eval.test.js +46 -29
- package/package/components/copilot/chat/__tests__/flow/flowEvalComparison.js +1 -4
- package/package/components/copilot/chat/__tests__/flow/flowEvalRunner.d.ts +14 -5
- package/package/components/copilot/chat/__tests__/flow/flowEvalRunner.js +13 -12
- package/package/components/copilot/chat/__tests__/shared/baseEvalRunner.d.ts +5 -8
- package/package/components/copilot/chat/__tests__/shared/baseEvalRunner.js +82 -108
- package/package/components/copilot/chat/__tests__/shared/baseLLMEvaluator.d.ts +4 -7
- package/package/components/copilot/chat/__tests__/shared/baseLLMEvaluator.js +19 -11
- package/package/components/copilot/chat/__tests__/shared/types.d.ts +3 -0
- package/package/components/copilot/chat/anthropic.d.ts +9 -2
- package/package/components/copilot/chat/anthropic.js +12 -6
- package/package/components/copilot/chat/app/core.js +5 -12
- package/package/components/copilot/chat/chatLoop.d.ts +40 -0
- package/package/components/copilot/chat/chatLoop.js +97 -0
- package/package/components/copilot/chat/openai-responses.d.ts +8 -2
- package/package/components/copilot/chat/openai-responses.js +17 -17
- package/package/components/copilot/chat/shared.d.ts +2 -1
- package/package/components/copilot/chat/shared.js +2 -2
- package/package/components/copilot/lib.d.ts +14 -5
- package/package/components/copilot/lib.js +68 -48
- package/package/components/dbOps.d.ts +2 -2
- package/package/components/dbOps.js +129 -53
- package/package/components/debug/debugUtils.d.ts +5 -0
- package/package/components/debug/debugUtils.js +20 -0
- package/package/components/debug/index.d.ts +1 -1
- package/package/components/debug/index.js +3 -7
- package/package/components/flows/CreateActionsFlow.svelte +221 -43
- package/package/components/flows/DebounceLimit.svelte +42 -9
- package/package/components/flows/common/FlowCard.svelte +2 -1
- package/package/components/flows/common/FlowCard.svelte.d.ts +1 -0
- package/package/components/flows/common/FlowCardHeader.svelte +14 -10
- package/package/components/flows/common/FlowCardHeader.svelte.d.ts +1 -0
- package/package/components/flows/content/AgentToolWrapper.svelte +2 -1
- package/package/components/flows/content/AgentToolWrapper.svelte.d.ts +1 -0
- package/package/components/flows/content/FlowEditorPanel.svelte +1 -0
- package/package/components/flows/content/FlowModuleComponent.svelte +32 -18
- package/package/components/flows/content/FlowModuleComponent.svelte.d.ts +1 -0
- package/package/components/flows/content/FlowModuleDebounce.svelte +46 -0
- package/package/components/flows/content/FlowModuleDebounce.svelte.d.ts +8 -0
- package/package/components/flows/content/FlowModuleEarlyStop.svelte +26 -5
- package/package/components/flows/content/FlowModuleWrapper.svelte +1 -0
- package/package/components/flows/content/FlowRetries.svelte +57 -57
- package/package/components/flows/content/FlowSelectionPanel.svelte +9 -14
- package/package/components/flows/content/FlowSelectionPanel.svelte.d.ts +1 -0
- package/package/components/flows/content/FlowSettings.svelte +6 -6
- package/package/components/flows/content/ScriptEditorDrawer.svelte +1 -1
- package/package/components/flows/content/SuspendDrawer.svelte +0 -18
- package/package/components/flows/header/FlowYamlEditor.svelte +20 -4
- package/package/components/flows/map/FlowErrorHandlerItem.svelte +32 -14
- package/package/components/flows/map/FlowErrorHandlerItem.svelte.d.ts +1 -0
- package/package/components/flows/map/FlowModuleSchemaItem.svelte +7 -10
- package/package/components/flows/map/FlowModuleSchemaItemViewer.svelte +1 -8
- package/package/components/flows/map/FlowModuleSchemaItemViewer.svelte.d.ts +0 -2
- package/package/components/flows/map/FlowModuleSchemaMap.svelte +343 -137
- package/package/components/flows/map/FlowModuleSchemaMap.svelte.d.ts +1 -0
- package/package/components/flows/map/FlowStickyNode.svelte +24 -16
- package/package/components/flows/map/FlowStickyNode.svelte.d.ts +1 -0
- package/package/components/flows/map/VirtualItemWrapper.svelte +1 -1
- package/package/components/flows/pickers/PickHubScriptQuick.svelte.d.ts +1 -1
- package/package/components/flows/propPicker/OutputPickerInner.svelte +5 -1
- package/package/components/flows/scheduleUtils.js +3 -1
- package/package/components/flows/utils.svelte.js +6 -1
- package/package/components/git_sync/GitSyncContext.svelte.js +13 -2
- package/package/components/git_sync/GitSyncSection.svelte +135 -99
- package/package/components/graph/DragGhost.svelte +11 -2
- package/package/components/graph/FlowGraphV2.svelte +138 -42
- package/package/components/graph/FlowGraphV2.svelte.d.ts +15 -1
- package/package/components/graph/GroupActionBar.svelte +124 -0
- package/package/components/graph/GroupActionBar.svelte.d.ts +20 -0
- package/package/components/graph/GroupHeader.svelte +98 -0
- package/package/components/graph/GroupHeader.svelte.d.ts +11 -0
- package/package/components/graph/GroupHeaderBlock.svelte +58 -0
- package/package/components/graph/GroupHeaderBlock.svelte.d.ts +13 -0
- package/package/components/graph/GroupModuleIcons.svelte +163 -0
- package/package/components/graph/GroupModuleIcons.svelte.d.ts +11 -0
- package/package/components/graph/GroupNodeCard.svelte +127 -0
- package/package/components/graph/GroupNodeCard.svelte.d.ts +18 -0
- package/package/components/graph/GroupNoteArea.svelte +132 -0
- package/package/components/graph/GroupNoteArea.svelte.d.ts +11 -0
- package/package/components/graph/GroupOverlay.svelte +71 -0
- package/package/components/graph/GroupOverlay.svelte.d.ts +12 -0
- package/package/components/graph/MiniFlowGraph.svelte +17 -2
- package/package/components/graph/SelectionBoundingBox.svelte +14 -14
- package/package/components/graph/compoundLayout.d.ts +17 -1
- package/package/components/graph/compoundLayout.js +129 -14
- package/package/components/graph/flowStructure.d.ts +63 -0
- package/package/components/graph/flowStructure.js +422 -0
- package/package/components/graph/flowStructure.test.d.ts +1 -0
- package/package/components/graph/flowStructure.test.js +205 -0
- package/package/components/graph/graphBuilder.svelte.d.ts +52 -3
- package/package/components/graph/graphBuilder.svelte.js +170 -67
- package/package/components/graph/graphContext.d.ts +7 -0
- package/package/components/graph/groupDetectionUtils.d.ts +24 -1
- package/package/components/graph/groupDetectionUtils.js +101 -1
- package/package/components/graph/groupEditor.svelte.d.ts +105 -0
- package/package/components/graph/groupEditor.svelte.js +253 -0
- package/package/components/graph/groupedModulesProxy.svelte.d.ts +55 -0
- package/package/components/graph/groupedModulesProxy.svelte.js +130 -0
- package/package/components/graph/model.d.ts +2 -1
- package/package/components/graph/moveManager.svelte.js +0 -3
- package/package/components/graph/nodeExtraSpace.d.ts +32 -0
- package/package/components/graph/nodeExtraSpace.js +113 -0
- package/package/components/graph/noteColors.d.ts +1 -0
- package/package/components/graph/noteColors.js +20 -10
- package/package/components/graph/noteUtils.svelte.d.ts +0 -18
- package/package/components/graph/noteUtils.svelte.js +6 -41
- package/package/components/graph/renderers/edges/BaseEdge.svelte +26 -11
- package/package/components/graph/renderers/nodes/AIToolNode.svelte +24 -49
- package/package/components/graph/renderers/nodes/AIToolNode.svelte.d.ts +1 -4
- package/package/components/graph/renderers/nodes/AssetNode.svelte +1 -27
- package/package/components/graph/renderers/nodes/AssetNode.svelte.d.ts +0 -4
- package/package/components/graph/renderers/nodes/CollapsedGroupNode.svelte +85 -0
- package/package/components/graph/renderers/nodes/CollapsedGroupNode.svelte.d.ts +8 -0
- package/package/components/graph/renderers/nodes/ForLoopStartNode.svelte +3 -2
- package/package/components/graph/renderers/nodes/GroupEndNode.svelte +9 -0
- package/package/components/graph/renderers/nodes/GroupEndNode.svelte.d.ts +6 -0
- package/package/components/graph/renderers/nodes/GroupHeadNode.svelte +20 -0
- package/package/components/graph/renderers/nodes/GroupHeadNode.svelte.d.ts +8 -0
- package/package/components/graph/renderers/nodes/ModuleNode.svelte +8 -5
- package/package/components/graph/renderers/triggers/TriggersWrapper.svelte +1 -1
- package/package/components/graph/util.d.ts +5 -1
- package/package/components/graph/util.js +7 -5
- package/package/components/home/Item.svelte +1 -0
- package/package/components/home/ItemsList.svelte +1 -1
- package/package/components/icons/ActiveCampaignIcon.svelte +10 -0
- package/package/components/icons/ActiveCampaignIcon.svelte.d.ts +7 -0
- package/package/components/icons/AlgoliaIcon.svelte +7 -0
- package/package/components/icons/AlgoliaIcon.svelte.d.ts +7 -0
- package/package/components/icons/ApolloIcon.svelte +7 -0
- package/package/components/icons/ApolloIcon.svelte.d.ts +7 -0
- package/package/components/icons/BambooHrIcon.svelte +7 -0
- package/package/components/icons/BambooHrIcon.svelte.d.ts +7 -0
- package/package/components/icons/BaremetricsIcon.svelte +7 -0
- package/package/components/icons/BaremetricsIcon.svelte.d.ts +7 -0
- package/package/components/icons/BitlyIcon.svelte +7 -0
- package/package/components/icons/BitlyIcon.svelte.d.ts +7 -0
- package/package/components/icons/BloggerIcon.svelte +7 -0
- package/package/components/icons/BloggerIcon.svelte.d.ts +7 -0
- package/package/components/icons/BlueskyIcon.svelte +7 -0
- package/package/components/icons/BlueskyIcon.svelte.d.ts +7 -0
- package/package/components/icons/BoxIcon.svelte +7 -0
- package/package/components/icons/BoxIcon.svelte.d.ts +7 -0
- package/package/components/icons/BrevoIcon.svelte +7 -0
- package/package/components/icons/BrevoIcon.svelte.d.ts +7 -0
- package/package/components/icons/BrexIcon.svelte +7 -0
- package/package/components/icons/BrexIcon.svelte.d.ts +7 -0
- package/package/components/icons/BrowserlessIcon.svelte +7 -0
- package/package/components/icons/BrowserlessIcon.svelte.d.ts +7 -0
- package/package/components/icons/BubbleIcon.svelte +11 -0
- package/package/components/icons/BubbleIcon.svelte.d.ts +7 -0
- package/package/components/icons/BuildkiteIcon.svelte +7 -0
- package/package/components/icons/BuildkiteIcon.svelte.d.ts +7 -0
- package/package/components/icons/CalcomIcon.svelte +1 -1
- package/package/components/icons/CalendlyIcon.svelte +7 -0
- package/package/components/icons/CalendlyIcon.svelte.d.ts +7 -0
- package/package/components/icons/CircleCiIcon.svelte +7 -0
- package/package/components/icons/CircleCiIcon.svelte.d.ts +7 -0
- package/package/components/icons/CiscoIcon.svelte +7 -0
- package/package/components/icons/CiscoIcon.svelte.d.ts +7 -0
- package/package/components/icons/ClearbitIcon.svelte +7 -0
- package/package/components/icons/ClearbitIcon.svelte.d.ts +7 -0
- package/package/components/icons/ClerkIcon.svelte +7 -0
- package/package/components/icons/ClerkIcon.svelte.d.ts +7 -0
- package/package/components/icons/CloseIcon.svelte +37 -0
- package/package/components/icons/CloseIcon.svelte.d.ts +7 -0
- package/package/components/icons/CloudinaryIcon.svelte +7 -0
- package/package/components/icons/CloudinaryIcon.svelte.d.ts +7 -0
- package/package/components/icons/CockroachDbIcon.svelte +7 -0
- package/package/components/icons/CockroachDbIcon.svelte.d.ts +7 -0
- package/package/components/icons/CodaIcon.svelte +7 -0
- package/package/components/icons/CodaIcon.svelte.d.ts +7 -0
- package/package/components/icons/CohereIcon.svelte +16 -0
- package/package/components/icons/CohereIcon.svelte.d.ts +7 -0
- package/package/components/icons/CoinMarketCapIcon.svelte +7 -0
- package/package/components/icons/CoinMarketCapIcon.svelte.d.ts +7 -0
- package/package/components/icons/CoinbaseIcon.svelte +7 -0
- package/package/components/icons/CoinbaseIcon.svelte.d.ts +7 -0
- package/package/components/icons/ConfluenceIcon.svelte +7 -0
- package/package/components/icons/ConfluenceIcon.svelte.d.ts +7 -0
- package/package/components/icons/ContentfulIcon.svelte +7 -0
- package/package/components/icons/ContentfulIcon.svelte.d.ts +7 -0
- package/package/components/icons/ConvertKitIcon.svelte +7 -0
- package/package/components/icons/ConvertKitIcon.svelte.d.ts +7 -0
- package/package/components/icons/DatoCmsIcon.svelte +7 -0
- package/package/components/icons/DatoCmsIcon.svelte.d.ts +7 -0
- package/package/components/icons/DeelIcon.svelte +7 -0
- package/package/components/icons/DeelIcon.svelte.d.ts +7 -0
- package/package/components/icons/DeepLIcon.svelte +7 -0
- package/package/components/icons/DeepLIcon.svelte.d.ts +7 -0
- package/package/components/icons/DigitalOceanIcon.svelte +7 -0
- package/package/components/icons/DigitalOceanIcon.svelte.d.ts +7 -0
- package/package/components/icons/DiscourseIcon.svelte +7 -0
- package/package/components/icons/DiscourseIcon.svelte.d.ts +7 -0
- package/package/components/icons/DocusignIcon.svelte +7 -0
- package/package/components/icons/DocusignIcon.svelte.d.ts +7 -0
- package/package/components/icons/DropboxIcon.svelte +7 -0
- package/package/components/icons/DropboxIcon.svelte.d.ts +7 -0
- package/package/components/icons/EdgeDbIcon.svelte +16 -20
- package/package/components/icons/EventbriteIcon.svelte +10 -0
- package/package/components/icons/EventbriteIcon.svelte.d.ts +7 -0
- package/package/components/icons/FigmaIcon.svelte +7 -0
- package/package/components/icons/FigmaIcon.svelte.d.ts +7 -0
- package/package/components/icons/FlyIcon.svelte +7 -0
- package/package/components/icons/FlyIcon.svelte.d.ts +7 -0
- package/package/components/icons/FreshdeskIcon.svelte +7 -0
- package/package/components/icons/FreshdeskIcon.svelte.d.ts +7 -0
- package/package/components/icons/FrontAppIcon.svelte +7 -0
- package/package/components/icons/FrontAppIcon.svelte.d.ts +7 -0
- package/package/components/icons/GhostCmsIcon.svelte +7 -0
- package/package/components/icons/GhostCmsIcon.svelte.d.ts +7 -0
- package/package/components/icons/GiphyIcon.svelte +7 -0
- package/package/components/icons/GiphyIcon.svelte.d.ts +7 -0
- package/package/components/icons/GitBookIcon.svelte +7 -0
- package/package/components/icons/GitBookIcon.svelte.d.ts +7 -0
- package/package/components/icons/GroqIcon.svelte +7 -0
- package/package/components/icons/GroqIcon.svelte.d.ts +7 -0
- package/package/components/icons/HoneybadgerIcon.svelte +7 -0
- package/package/components/icons/HoneybadgerIcon.svelte.d.ts +7 -0
- package/package/components/icons/HttpIcon.svelte +1 -0
- package/package/components/icons/IftttIcon.svelte +7 -0
- package/package/components/icons/IftttIcon.svelte.d.ts +7 -0
- package/package/components/icons/IntercomIcon.svelte +7 -0
- package/package/components/icons/IntercomIcon.svelte.d.ts +7 -0
- package/package/components/icons/JoomlaIcon.svelte +7 -0
- package/package/components/icons/JoomlaIcon.svelte.d.ts +7 -0
- package/package/components/icons/LineIcon.svelte +7 -0
- package/package/components/icons/LineIcon.svelte.d.ts +7 -0
- package/package/components/icons/LinearIcon.svelte +7 -0
- package/package/components/icons/LinearIcon.svelte.d.ts +7 -0
- package/package/components/icons/LinodeIcon.svelte +7 -0
- package/package/components/icons/LinodeIcon.svelte.d.ts +7 -0
- package/package/components/icons/LumaAiIcon.svelte +39 -0
- package/package/components/icons/LumaAiIcon.svelte.d.ts +7 -0
- package/package/components/icons/MSTeamsIcon.svelte +20 -38
- package/package/components/icons/MSTeamsIcon.svelte.d.ts +2 -0
- package/package/components/icons/MagentoIcon.svelte +7 -0
- package/package/components/icons/MagentoIcon.svelte.d.ts +7 -0
- package/package/components/icons/MailchimpIcon.svelte +25 -13
- package/package/components/icons/MandrillIcon.svelte +7 -0
- package/package/components/icons/MandrillIcon.svelte.d.ts +7 -0
- package/package/components/icons/MauticIcon.svelte +7 -0
- package/package/components/icons/MauticIcon.svelte.d.ts +7 -0
- package/package/components/icons/MediumIcon.svelte +7 -0
- package/package/components/icons/MediumIcon.svelte.d.ts +7 -0
- package/package/components/icons/MiroIcon.svelte +7 -0
- package/package/components/icons/MiroIcon.svelte.d.ts +7 -0
- package/package/components/icons/MistralIcon.svelte +7 -0
- package/package/components/icons/MistralIcon.svelte.d.ts +7 -0
- package/package/components/icons/MixpanelIcon.svelte +7 -0
- package/package/components/icons/MixpanelIcon.svelte.d.ts +7 -0
- package/package/components/icons/MondayIcon.svelte +7 -0
- package/package/components/icons/MondayIcon.svelte.d.ts +7 -0
- package/package/components/icons/NeonDbIcon.svelte +23 -0
- package/package/components/icons/NeonDbIcon.svelte.d.ts +7 -0
- package/package/components/icons/NetlifyIcon.svelte +7 -0
- package/package/components/icons/NetlifyIcon.svelte.d.ts +7 -0
- package/package/components/icons/OneSignalIcon.svelte +9 -0
- package/package/components/icons/OneSignalIcon.svelte.d.ts +7 -0
- package/package/components/icons/OpenWeatherIcon.svelte +7 -0
- package/package/components/icons/OpenWeatherIcon.svelte.d.ts +7 -0
- package/package/components/icons/PagerDutyIcon.svelte +7 -0
- package/package/components/icons/PagerDutyIcon.svelte.d.ts +7 -0
- package/package/components/icons/PandaDocIcon.svelte +7 -0
- package/package/components/icons/PandaDocIcon.svelte.d.ts +7 -0
- package/package/components/icons/PaypalIcon.svelte +7 -0
- package/package/components/icons/PaypalIcon.svelte.d.ts +7 -0
- package/package/components/icons/PersonioIcon.svelte +7 -0
- package/package/components/icons/PersonioIcon.svelte.d.ts +7 -0
- package/package/components/icons/PinterestIcon.svelte +7 -0
- package/package/components/icons/PinterestIcon.svelte.d.ts +7 -0
- package/package/components/icons/PipedriveIcon.svelte +11 -0
- package/package/components/icons/PipedriveIcon.svelte.d.ts +7 -0
- package/package/components/icons/PlanetScaleIcon.svelte +7 -0
- package/package/components/icons/PlanetScaleIcon.svelte.d.ts +7 -0
- package/package/components/icons/PostmarkIcon.svelte +7 -0
- package/package/components/icons/PostmarkIcon.svelte.d.ts +7 -0
- package/package/components/icons/PusherIcon.svelte +7 -0
- package/package/components/icons/PusherIcon.svelte.d.ts +7 -0
- package/package/components/icons/QuickbooksIcon.svelte +13 -1
- package/package/components/icons/RaindropIcon.svelte +27 -0
- package/package/components/icons/RaindropIcon.svelte.d.ts +7 -0
- package/package/components/icons/ReadwiseIcon.svelte +12 -0
- package/package/components/icons/ReadwiseIcon.svelte.d.ts +7 -0
- package/package/components/icons/RenderIcon.svelte +7 -0
- package/package/components/icons/RenderIcon.svelte.d.ts +7 -0
- package/package/components/icons/ReplicateIcon.svelte +7 -0
- package/package/components/icons/ReplicateIcon.svelte.d.ts +7 -0
- package/package/components/icons/ResendIcon.svelte +1 -1
- package/package/components/icons/RestIcon.svelte +1 -0
- package/package/components/icons/RingCentralIcon.svelte +7 -0
- package/package/components/icons/RingCentralIcon.svelte.d.ts +7 -0
- package/package/components/icons/RocketChatIcon.svelte +7 -0
- package/package/components/icons/RocketChatIcon.svelte.d.ts +7 -0
- package/package/components/icons/RunPodIcon.svelte +8 -0
- package/package/components/icons/RunPodIcon.svelte.d.ts +7 -0
- package/package/components/icons/RustIcon.svelte +74 -56
- package/package/components/icons/SalesforceIcon.svelte +7 -0
- package/package/components/icons/SalesforceIcon.svelte.d.ts +7 -0
- package/package/components/icons/SegmentIcon.svelte +7 -0
- package/package/components/icons/SegmentIcon.svelte.d.ts +7 -0
- package/package/components/icons/SentryIcon.svelte +7 -0
- package/package/components/icons/SentryIcon.svelte.d.ts +7 -0
- package/package/components/icons/ServiceNowIcon.svelte +7 -0
- package/package/components/icons/ServiceNowIcon.svelte.d.ts +7 -0
- package/package/components/icons/ShortcutIcon.svelte +7 -0
- package/package/components/icons/ShortcutIcon.svelte.d.ts +7 -0
- package/package/components/icons/SigNozIcon.svelte +8 -0
- package/package/components/icons/SigNozIcon.svelte.d.ts +7 -0
- package/package/components/icons/SmartsheetIcon.svelte +7 -0
- package/package/components/icons/SmartsheetIcon.svelte.d.ts +7 -0
- package/package/components/icons/SpeechifyIcon.svelte +7 -0
- package/package/components/icons/SpeechifyIcon.svelte.d.ts +7 -0
- package/package/components/icons/SplitwiseIcon.svelte +7 -0
- package/package/components/icons/SplitwiseIcon.svelte.d.ts +7 -0
- package/package/components/icons/StravaIcon.svelte +7 -0
- package/package/components/icons/StravaIcon.svelte.d.ts +7 -0
- package/package/components/icons/TallyIcon.svelte +7 -0
- package/package/components/icons/TallyIcon.svelte.d.ts +7 -0
- package/package/components/icons/TelnyxIcon.svelte +19 -0
- package/package/components/icons/TelnyxIcon.svelte.d.ts +7 -0
- package/package/components/icons/ThreadsIcon.svelte +7 -0
- package/package/components/icons/ThreadsIcon.svelte.d.ts +7 -0
- package/package/components/icons/TodoistIcon.svelte +7 -0
- package/package/components/icons/TodoistIcon.svelte.d.ts +7 -0
- package/package/components/icons/TogetherAiIcon.svelte +23 -0
- package/package/components/icons/TogetherAiIcon.svelte.d.ts +7 -0
- package/package/components/icons/TrelloIcon.svelte +22 -1
- package/package/components/icons/TursoIcon.svelte +7 -0
- package/package/components/icons/TursoIcon.svelte.d.ts +7 -0
- package/package/components/icons/TwitchIcon.svelte +7 -0
- package/package/components/icons/TwitchIcon.svelte.d.ts +7 -0
- package/package/components/icons/TwitterIcon.svelte +7 -0
- package/package/components/icons/TwitterIcon.svelte.d.ts +7 -0
- package/package/components/icons/TypeformIcon.svelte +1 -1
- package/package/components/icons/VercelIcon.svelte +7 -0
- package/package/components/icons/VercelIcon.svelte.d.ts +7 -0
- package/package/components/icons/WebflowIcon.svelte +7 -0
- package/package/components/icons/WebflowIcon.svelte.d.ts +7 -0
- package/package/components/icons/WooCommerceIcon.svelte +7 -0
- package/package/components/icons/WooCommerceIcon.svelte.d.ts +7 -0
- package/package/components/icons/WordpressIcon.svelte +7 -0
- package/package/components/icons/WordpressIcon.svelte.d.ts +7 -0
- package/package/components/icons/XataIcon.svelte +13 -0
- package/package/components/icons/XataIcon.svelte.d.ts +7 -0
- package/package/components/icons/YelpIcon.svelte +7 -0
- package/package/components/icons/YelpIcon.svelte.d.ts +7 -0
- package/package/components/icons/YnabIcon.svelte +7 -0
- package/package/components/icons/YnabIcon.svelte.d.ts +7 -0
- package/package/components/icons/YoutubeIcon.svelte +7 -0
- package/package/components/icons/YoutubeIcon.svelte.d.ts +7 -0
- package/package/components/icons/ZendeskIcon.svelte +1 -1
- package/package/components/icons/ZeroTierIcon.svelte +7 -0
- package/package/components/icons/ZeroTierIcon.svelte.d.ts +7 -0
- package/package/components/icons/ZoomIcon.svelte +7 -0
- package/package/components/icons/ZoomIcon.svelte.d.ts +7 -0
- package/package/components/icons/index.d.ts +111 -1
- package/package/components/icons/index.js +225 -2
- package/package/components/instanceSettings/GhesAppSettings.svelte +161 -0
- package/package/components/instanceSettings/GhesAppSettings.svelte.d.ts +8 -0
- package/package/components/instanceSettings/IndexerMemorySettings.svelte +19 -8
- package/package/components/instanceSettings/InstanceAISettings.svelte +132 -0
- package/package/components/instanceSettings/InstanceAISettings.svelte.d.ts +10 -0
- package/package/components/instanceSettings/WorkspaceRegistries.svelte +293 -0
- package/package/components/instanceSettings/WorkspaceRegistries.svelte.d.ts +8 -0
- package/package/components/instanceSettings/WsConnectivityTest.svelte +177 -0
- package/package/components/instanceSettings/WsConnectivityTest.svelte.d.ts +7 -0
- package/package/components/instanceSettings.d.ts +3 -1
- package/package/components/instanceSettings.js +92 -2
- package/package/components/mcp/McpScopeSelector.svelte +408 -0
- package/package/components/mcp/McpScopeSelector.svelte.d.ts +7 -0
- package/package/components/meltComponents/Popover.svelte +0 -1
- package/package/components/raw_apps/RawAppPreview.svelte +6 -2
- package/package/components/recording/FlowRecordingReplay.svelte +94 -52
- package/package/components/recording/FlowRecordingReplay.svelte.d.ts +10 -1
- package/package/components/recording/ScriptRecordingReplay.svelte +139 -76
- package/package/components/recording/ScriptRecordingReplay.svelte.d.ts +10 -1
- package/package/components/runs/JobRunsPreview.svelte +8 -1
- package/package/components/runs/TimeframeSelect.svelte +0 -1
- package/package/components/schema/JobSchemaPicker.svelte +8 -2
- package/package/components/schema/JobSchemaPicker.svelte.d.ts +1 -0
- package/package/components/schema/SchemaFormDND.svelte +15 -3
- package/package/components/scriptEditor/LogPanel.svelte +78 -68
- package/package/components/script_builder.d.ts +1 -1
- package/package/components/scripts/CreateActionsScript.svelte +3 -3
- package/package/components/scripts/WacExportDrawer.svelte +127 -0
- package/package/components/scripts/WacExportDrawer.svelte.d.ts +8 -0
- package/package/components/scripts/scriptStore.svelte.d.ts +2 -0
- package/package/components/scripts/scriptStore.svelte.js +2 -0
- package/package/components/select/SelectDropdown.svelte +1 -1
- package/package/components/settings/AIPromptsModal.svelte +5 -2
- package/package/components/settings/AIPromptsModal.svelte.d.ts +1 -1
- package/package/components/settings/CloudQuotas.svelte +152 -0
- package/package/components/settings/CloudQuotas.svelte.d.ts +3 -0
- package/package/components/settings/CreateToken.svelte +15 -430
- package/package/components/settings/Trashbin.svelte +248 -0
- package/package/components/settings/Trashbin.svelte.d.ts +3 -0
- package/package/components/sidebar/MultiplayerMenu.svelte +14 -4
- package/package/components/triggers/DeleteTriggerButton.svelte +1 -0
- package/package/components/triggers/PermissionedAsLine.svelte +66 -0
- package/package/components/triggers/PermissionedAsLine.svelte.d.ts +9 -0
- package/package/components/triggers/TriggerEditorToolbar.svelte +2 -2
- package/package/components/triggers/TriggerTokens.svelte +3 -3
- package/package/components/triggers/email/EmailTriggerEditorInner.svelte +19 -1
- package/package/components/triggers/email/utils.js +3 -1
- package/package/components/triggers/gcp/GcpTriggerEditorInner.svelte +24 -4
- package/package/components/triggers/gcp/utils.js +2 -0
- package/package/components/triggers/http/RouteEditorConfigSection.svelte +22 -3
- package/package/components/triggers/http/RouteEditorInner.svelte +28 -6
- package/package/components/triggers/http/RoutesGenerator.svelte +13 -2
- package/package/components/triggers/http/utils.js +3 -1
- package/package/components/triggers/kafka/KafkaTriggerEditorInner.svelte +23 -6
- package/package/components/triggers/kafka/utils.js +3 -1
- package/package/components/triggers/mqtt/MqttTriggerEditorInner.svelte +27 -5
- package/package/components/triggers/mqtt/utils.js +2 -0
- package/package/components/triggers/native/NativeTriggerEditor.svelte +23 -1
- package/package/components/triggers/native/NativeTriggerTable.svelte +14 -3
- package/package/components/triggers/native/utils.js +3 -2
- package/package/components/triggers/nats/NatsTriggerEditorInner.svelte +19 -1
- package/package/components/triggers/nats/utils.js +2 -0
- package/package/components/triggers/postgres/PostgresTriggerEditorInner.svelte +19 -1
- package/package/components/triggers/postgres/utils.js +2 -0
- package/package/components/triggers/schedules/ScheduleEditorInner.svelte +29 -7
- package/package/components/triggers/sqs/SqsTriggerEditorInner.svelte +19 -1
- package/package/components/triggers/sqs/utils.js +2 -0
- package/package/components/triggers/utils.js +9 -2
- package/package/components/triggers/websocket/WebsocketTriggerEditorInner.svelte +24 -4
- package/package/components/triggers/websocket/utils.js +3 -1
- package/package/components/workspaceSettings/AISettings.svelte +342 -214
- package/package/components/workspaceSettings/AISettings.svelte.d.ts +18 -10
- package/package/components/workspaceSettings/CreateWorkspace.svelte +304 -196
- package/package/components/workspaceSettings/CustomInstanceDbWizardModal.svelte +1 -2
- package/package/components/workspaceSettings/DucklakeSettings.svelte +1 -1
- package/package/components/workspaceSettings/InstanceFallbackSettings.svelte +75 -0
- package/package/components/workspaceSettings/InstanceFallbackSettings.svelte.d.ts +9 -0
- package/package/components/workspaceSettings/StorageSettings.svelte +4 -35
- package/package/components/workspaceSettings/VolumeStorageSettings.svelte +80 -0
- package/package/components/workspaceSettings/VolumeStorageSettings.svelte.d.ts +10 -0
- package/package/components/workspaceSettings/WorkspaceIntegrations.svelte +4 -1
- package/package/forLater.js +4 -0
- package/package/gen/core/OpenAPI.js +1 -1
- package/package/gen/schemas.gen.d.ts +294 -94
- package/package/gen/schemas.gen.js +294 -94
- package/package/gen/services.gen.d.ts +121 -5
- package/package/gen/services.gen.js +237 -5
- package/package/gen/types.gen.d.ts +715 -91
- package/package/githubApp.js +19 -1
- package/package/hubPaths.json +8 -4
- package/package/infer.d.ts +1 -1
- package/package/infer.js +5 -1
- package/package/logoutRedirect.d.ts +1 -0
- package/package/logoutRedirect.js +24 -0
- package/package/script_helpers.d.ts +8 -2
- package/package/script_helpers.js +15 -1
- package/package/services/trashService.d.ts +28 -0
- package/package/services/trashService.js +47 -0
- package/package/stores.d.ts +1 -0
- package/package/stores.js +1 -0
- package/package/system_prompts/index.d.ts +1 -0
- package/package/system_prompts/index.js +7 -0
- package/package/system_prompts/prompts.d.ts +7 -5
- package/package/system_prompts/prompts.js +182 -11
- package/package/templates/wac_python.py.template +42 -0
- package/package/templates/wac_typescript.ts.template +48 -0
- package/package/utils_deployable.d.ts +22 -21
- package/package/utils_deployable.js +58 -25
- package/package/utils_workspace_deploy.d.ts +15 -4
- package/package/utils_workspace_deploy.js +19 -15
- package/package/wsUrl.d.ts +1 -0
- package/package/wsUrl.js +15 -0
- package/package.json +13 -5
- package/dist/sharedUtils/assets/tokens/colorTokensConfig.d.ts +0 -2
- package/dist/sharedUtils/base.d.ts +0 -1
- package/dist/sharedUtils/cloud.d.ts +0 -1
- package/dist/sharedUtils/common.d.ts +0 -111
- package/dist/sharedUtils/components/apps/components/display/dbtable/queries/count.d.ts +0 -5
- package/dist/sharedUtils/components/apps/components/display/dbtable/queries/delete.d.ts +0 -5
- package/dist/sharedUtils/components/apps/components/display/dbtable/queries/insert.d.ts +0 -5
- package/dist/sharedUtils/components/apps/components/display/dbtable/queries/select.d.ts +0 -13
- package/dist/sharedUtils/components/apps/components/display/dbtable/queries/update.d.ts +0 -11
- package/dist/sharedUtils/components/apps/components/display/dbtable/utils.d.ts +0 -95
- package/dist/sharedUtils/components/apps/editor/appPolicy.d.ts +0 -6
- package/dist/sharedUtils/components/apps/editor/appUtilsCore.d.ts +0 -7
- package/dist/sharedUtils/components/apps/editor/appUtilsS3.d.ts +0 -33
- package/dist/sharedUtils/components/apps/editor/commonAppUtils.d.ts +0 -10
- package/dist/sharedUtils/components/apps/editor/component/components.d.ts +0 -5371
- package/dist/sharedUtils/components/apps/editor/component/default-codes.d.ts +0 -3
- package/dist/sharedUtils/components/apps/editor/component/index.d.ts +0 -3
- package/dist/sharedUtils/components/apps/editor/component/sets.d.ts +0 -7
- package/dist/sharedUtils/components/apps/editor/componentsPanel/componentDefaultProps.d.ts +0 -3
- package/dist/sharedUtils/components/apps/gridUtils.d.ts +0 -14
- package/dist/sharedUtils/components/apps/inputType.d.ts +0 -178
- package/dist/sharedUtils/components/apps/rx.d.ts +0 -29
- package/dist/sharedUtils/components/apps/sharedTypes.d.ts +0 -21
- package/dist/sharedUtils/components/apps/types.d.ts +0 -274
- package/dist/sharedUtils/components/assets/lib.d.ts +0 -25
- package/dist/sharedUtils/components/common/alert/model.d.ts +0 -2
- package/dist/sharedUtils/components/common/badge/model.d.ts +0 -8
- package/dist/sharedUtils/components/common/button/model.d.ts +0 -45
- package/dist/sharedUtils/components/common/fileInput/model.d.ts +0 -1
- package/dist/sharedUtils/components/common/index.d.ts +0 -24
- package/dist/sharedUtils/components/common/skeleton/model.d.ts +0 -21
- package/dist/sharedUtils/components/dbTypes.d.ts +0 -14
- package/dist/sharedUtils/components/diff_drawer.d.ts +0 -26
- package/dist/sharedUtils/components/ducklake.d.ts +0 -1
- package/dist/sharedUtils/components/flows/scheduleUtils.d.ts +0 -7
- package/dist/sharedUtils/components/icons/index.d.ts +0 -101
- package/dist/sharedUtils/components/random_positive_adjetive.d.ts +0 -1
- package/dist/sharedUtils/components/raw_apps/rawAppPolicy.d.ts +0 -10
- package/dist/sharedUtils/components/raw_apps/utils.d.ts +0 -15
- package/dist/sharedUtils/components/triggers/email/utils.d.ts +0 -4
- package/dist/sharedUtils/components/triggers/gcp/utils.d.ts +0 -2
- package/dist/sharedUtils/components/triggers/http/utils.d.ts +0 -11
- package/dist/sharedUtils/components/triggers/kafka/utils.d.ts +0 -2
- package/dist/sharedUtils/components/triggers/mqtt/utils.d.ts +0 -2
- package/dist/sharedUtils/components/triggers/nats/utils.d.ts +0 -2
- package/dist/sharedUtils/components/triggers/postgres/utils.d.ts +0 -8
- package/dist/sharedUtils/components/triggers/sqs/utils.d.ts +0 -2
- package/dist/sharedUtils/components/triggers/triggers.svelte.d.ts +0 -32
- package/dist/sharedUtils/components/triggers/utils.d.ts +0 -80
- package/dist/sharedUtils/components/triggers/websocket/utils.d.ts +0 -2
- package/dist/sharedUtils/components/triggers.d.ts +0 -20
- package/dist/sharedUtils/gen/core/ApiError.d.ts +0 -10
- package/dist/sharedUtils/gen/core/ApiRequestOptions.d.ts +0 -13
- package/dist/sharedUtils/gen/core/ApiResult.d.ts +0 -7
- package/dist/sharedUtils/gen/core/CancelablePromise.d.ts +0 -26
- package/dist/sharedUtils/gen/core/OpenAPI.d.ts +0 -27
- package/dist/sharedUtils/gen/core/request.d.ts +0 -29
- package/dist/sharedUtils/gen/index.d.ts +0 -6
- package/dist/sharedUtils/gen/schemas.gen.d.ts +0 -7036
- package/dist/sharedUtils/gen/services.gen.d.ts +0 -6047
- package/dist/sharedUtils/gen/types.gen.d.ts +0 -21881
- package/dist/sharedUtils/history.svelte.d.ts +0 -9
- package/dist/sharedUtils/hub.d.ts +0 -49
- package/dist/sharedUtils/jsr.json +0 -6
- package/dist/sharedUtils/lib.d.ts +0 -5
- package/dist/sharedUtils/lib.es.js +0 -1588
- package/dist/sharedUtils/package.json +0 -12
- package/dist/sharedUtils/schema.d.ts +0 -3
- package/dist/sharedUtils/stores.d.ts +0 -97
- package/dist/sharedUtils/svelte5Utils.svelte.d.ts +0 -80
- package/dist/sharedUtils/toast.d.ts +0 -8
- package/dist/sharedUtils/utils.d.ts +0 -265
- package/package/components/graph/NodeContextMenu.svelte +0 -36
- package/package/components/graph/NodeContextMenu.svelte.d.ts +0 -8
- package/package/svelte5Utils.svelte.d.ts +0 -184
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
import OpenAI, { OpenAIError } from 'openai';
|
|
2
|
-
import { getProviderAndCompletionConfig, workspaceAIClients } from '../lib';
|
|
2
|
+
import { createOpenAIProxyClient, getAiProxyBaseURL, getProviderAndCompletionConfig, workspaceAIClients } from '../lib';
|
|
3
3
|
import { processToolCall } from './shared';
|
|
4
|
-
import { OpenAPI } from '../../../gen';
|
|
5
4
|
// Conversion utilities for Responses API
|
|
6
5
|
function convertMessagesToResponsesInput(messages) {
|
|
7
6
|
const systemMessage = messages.find((m) => m.role === 'system');
|
|
@@ -94,12 +93,17 @@ function convertCompletionConfigToResponsesConfig(config) {
|
|
|
94
93
|
}
|
|
95
94
|
return responsesConfig;
|
|
96
95
|
}
|
|
97
|
-
export async function getOpenAIResponsesCompletion(messages, abortController, tools) {
|
|
98
|
-
const { provider, config } = getProviderAndCompletionConfig({
|
|
96
|
+
export async function getOpenAIResponsesCompletion(messages, abortController, tools, options) {
|
|
97
|
+
const { provider, config } = getProviderAndCompletionConfig({
|
|
98
|
+
messages,
|
|
99
|
+
stream: true,
|
|
100
|
+
tools,
|
|
101
|
+
forceModelProvider: options?.forceModelProvider
|
|
102
|
+
});
|
|
99
103
|
const { instructions, input } = convertMessagesToResponsesInput(messages);
|
|
100
104
|
const responsesConfig = convertCompletionConfigToResponsesConfig(config);
|
|
101
|
-
const
|
|
102
|
-
const runner =
|
|
105
|
+
const client = options?.openaiClient ?? workspaceAIClients.getOpenaiClient();
|
|
106
|
+
const runner = client.responses.stream({
|
|
103
107
|
...responsesConfig,
|
|
104
108
|
input,
|
|
105
109
|
...(instructions ? { instructions } : {})
|
|
@@ -149,7 +153,7 @@ export async function* getOpenAIResponsesCompletionStream(messages, abortControl
|
|
|
149
153
|
}
|
|
150
154
|
}
|
|
151
155
|
}
|
|
152
|
-
export async function parseOpenAIResponsesCompletion(runner, callbacks, messages, addedMessages, tools, helpers) {
|
|
156
|
+
export async function parseOpenAIResponsesCompletion(runner, callbacks, messages, addedMessages, tools, helpers, options) {
|
|
153
157
|
let toolCallsToProcess = [];
|
|
154
158
|
let error = null;
|
|
155
159
|
let textContent = '';
|
|
@@ -264,7 +268,8 @@ export async function parseOpenAIResponsesCompletion(runner, callbacks, messages
|
|
|
264
268
|
tools,
|
|
265
269
|
toolCall,
|
|
266
270
|
helpers,
|
|
267
|
-
toolCallbacks: callbacks
|
|
271
|
+
toolCallbacks: callbacks,
|
|
272
|
+
workspace: options?.workspace
|
|
268
273
|
});
|
|
269
274
|
messages.push(messageToAdd);
|
|
270
275
|
addedMessages.push(messageToAdd);
|
|
@@ -300,15 +305,10 @@ export async function getNonStreamingOpenAIResponsesCompletion(messages, abortCo
|
|
|
300
305
|
};
|
|
301
306
|
}
|
|
302
307
|
const openaiClient = testOptions?.apiKey
|
|
303
|
-
?
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
|
|
307
|
-
Authorization: '' // a non empty string will be unable to access Windmill backend proxy
|
|
308
|
-
},
|
|
309
|
-
dangerouslyAllowBrowser: true
|
|
310
|
-
})
|
|
311
|
-
: workspaceAIClients.getOpenaiClient();
|
|
308
|
+
? createOpenAIProxyClient(getAiProxyBaseURL())
|
|
309
|
+
: testOptions?.workspace
|
|
310
|
+
? workspaceAIClients.createOpenaiClient(testOptions.workspace)
|
|
311
|
+
: workspaceAIClients.getOpenaiClient();
|
|
312
312
|
const response = await openaiClient.responses.create({
|
|
313
313
|
...responsesConfig,
|
|
314
314
|
input,
|
|
@@ -64,11 +64,12 @@ export type AssistantDisplayMessage = BaseDisplayMessage & {
|
|
|
64
64
|
role: 'assistant';
|
|
65
65
|
};
|
|
66
66
|
export type DisplayMessage = UserDisplayMessage | ToolDisplayMessage | AssistantDisplayMessage;
|
|
67
|
-
export declare function processToolCall<T>({ tools, toolCall, helpers, toolCallbacks }: {
|
|
67
|
+
export declare function processToolCall<T>({ tools, toolCall, helpers, toolCallbacks, workspace }: {
|
|
68
68
|
tools: Tool<T>[];
|
|
69
69
|
toolCall: ChatCompletionMessageFunctionToolCall;
|
|
70
70
|
helpers: T;
|
|
71
71
|
toolCallbacks: ToolCallbacks;
|
|
72
|
+
workspace?: string;
|
|
72
73
|
}): Promise<ChatCompletionMessageParam>;
|
|
73
74
|
export interface Tool<T> {
|
|
74
75
|
def: ChatCompletionFunctionTool;
|
|
@@ -310,7 +310,7 @@ async function callTool({ tools, functionName, args, workspace, helpers, toolCal
|
|
|
310
310
|
}
|
|
311
311
|
return tool.fn({ args, workspace, helpers, toolCallbacks, toolId });
|
|
312
312
|
}
|
|
313
|
-
export async function processToolCall({ tools, toolCall, helpers, toolCallbacks }) {
|
|
313
|
+
export async function processToolCall({ tools, toolCall, helpers, toolCallbacks, workspace }) {
|
|
314
314
|
try {
|
|
315
315
|
const args = JSON.parse(toolCall.function.arguments || '{}');
|
|
316
316
|
const tool = tools.find((t) => t.def.function.name === toolCall.function.name);
|
|
@@ -353,7 +353,7 @@ export async function processToolCall({ tools, toolCall, helpers, toolCallbacks
|
|
|
353
353
|
tools,
|
|
354
354
|
functionName: toolCall.function.name,
|
|
355
355
|
args,
|
|
356
|
-
workspace: get(workspaceStore) ?? '',
|
|
356
|
+
workspace: workspace ?? get(workspaceStore) ?? '',
|
|
357
357
|
helpers,
|
|
358
358
|
toolCallbacks,
|
|
359
359
|
toolId: toolCall.id
|
|
@@ -28,19 +28,22 @@ export declare function fetchAvailableModels(resourcePath: string, workspace: st
|
|
|
28
28
|
export declare function getModelMaxTokens(provider: AIProvider, model: string): 100000 | 128000 | 32000 | 64000 | 32768 | 16384 | 4096 | 8192;
|
|
29
29
|
export declare function getModelContextWindow(model: string): 1000000 | 400000 | 128000 | 200000 | 32000;
|
|
30
30
|
export declare const PROVIDER_COMPLETION_CONFIG_MAP: Record<AIProvider, ChatCompletionCreateParams>;
|
|
31
|
+
export declare function getAiProxyBaseURL(workspace?: string): string;
|
|
32
|
+
export declare function createOpenAIProxyClient(baseURL: string): OpenAI;
|
|
33
|
+
export declare function createAnthropicProxyClient(baseURL: string): Anthropic;
|
|
31
34
|
declare class WorkspacedAIClients {
|
|
32
35
|
private openaiClient;
|
|
33
36
|
private anthropicClient;
|
|
34
37
|
init(workspace: string): void;
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
private initAnthropic;
|
|
38
|
+
createOpenaiClient(workspace: string): OpenAI;
|
|
39
|
+
createAnthropicClient(workspace: string): Anthropic;
|
|
38
40
|
getOpenaiClient(): OpenAI;
|
|
39
41
|
getAnthropicClient(): Anthropic;
|
|
40
42
|
}
|
|
41
43
|
export declare const workspaceAIClients: WorkspacedAIClients;
|
|
42
|
-
export declare function testKey({ apiKey, resourcePath, model, abortController, messages, aiProvider }: {
|
|
44
|
+
export declare function testKey({ apiKey, workspace, resourcePath, model, abortController, messages, aiProvider }: {
|
|
43
45
|
apiKey?: string;
|
|
46
|
+
workspace?: string;
|
|
44
47
|
resourcePath?: string;
|
|
45
48
|
model: string | undefined;
|
|
46
49
|
messages: ChatCompletionMessageParam[];
|
|
@@ -84,17 +87,23 @@ export declare function getProviderAndCompletionConfig<K extends boolean>({ mess
|
|
|
84
87
|
export declare function getNonStreamingCompletion(messages: ChatCompletionMessageParam[], abortController: AbortController, testOptions?: {
|
|
85
88
|
apiKey?: string;
|
|
86
89
|
resourcePath?: string;
|
|
90
|
+
workspace?: string;
|
|
87
91
|
forceModelProvider: AIProviderModel;
|
|
88
92
|
}): Promise<string>;
|
|
89
93
|
export declare const FIM_MAX_TOKENS = 256;
|
|
90
94
|
export declare function getFimCompletion(prompt: string, suffix: string, providerModel: AIProviderModel, abortController: AbortController): Promise<string | undefined>;
|
|
91
95
|
export declare function getCompletion(messages: ChatCompletionMessageParam[], abortController: AbortController, tools?: OpenAI.Chat.Completions.ChatCompletionTool[], options?: {
|
|
92
96
|
forceCompletions?: boolean;
|
|
97
|
+
forceModelProvider?: AIProviderModel;
|
|
98
|
+
openaiClient?: OpenAI;
|
|
93
99
|
}): Promise<Stream<ChatCompletionChunk>>;
|
|
94
100
|
export declare function parseOpenAICompletion(completion: Stream<ChatCompletionChunk>, callbacks: ToolCallbacks & {
|
|
95
101
|
onNewToken: (token: string) => void;
|
|
96
102
|
onMessageEnd: () => void;
|
|
97
|
-
}, messages: ChatCompletionMessageParam[], addedMessages: ChatCompletionMessageParam[], tools: Tool<any>[], helpers: any, _abortController?: AbortController
|
|
103
|
+
}, messages: ChatCompletionMessageParam[], addedMessages: ChatCompletionMessageParam[], tools: Tool<any>[], helpers: any, _abortController?: AbortController, // unused, for signature compatibility with parseAnthropicCompletion
|
|
104
|
+
options?: {
|
|
105
|
+
workspace?: string;
|
|
106
|
+
}): Promise<boolean>;
|
|
98
107
|
export declare function getResponseFromEvent(part: OpenAI.Chat.Completions.ChatCompletionChunk): string;
|
|
99
108
|
export declare function copilot(scriptOptions: CopilotOptions, generatedCode: Writable<string>, abortController: AbortController, generatedExplanation?: Writable<string>): Promise<string>;
|
|
100
109
|
export {};
|
|
@@ -45,7 +45,14 @@ export const AI_PROVIDERS = {
|
|
|
45
45
|
},
|
|
46
46
|
googleai: {
|
|
47
47
|
label: 'Google AI',
|
|
48
|
-
defaultModels: [
|
|
48
|
+
defaultModels: [
|
|
49
|
+
'gemini-2.5-flash',
|
|
50
|
+
'gemini-2.5-pro',
|
|
51
|
+
'gemini-2.5-flash-lite',
|
|
52
|
+
'gemini-3-flash',
|
|
53
|
+
'gemini-3.1-pro',
|
|
54
|
+
'gemini-3.1-flash-lite'
|
|
55
|
+
]
|
|
49
56
|
},
|
|
50
57
|
groq: {
|
|
51
58
|
label: 'Groq',
|
|
@@ -216,7 +223,13 @@ export function getModelContextWindow(model) {
|
|
|
216
223
|
function getModelSpecificConfig(modelProvider, tools) {
|
|
217
224
|
const defaultMaxTokens = getModelMaxTokens(modelProvider.provider, modelProvider.model);
|
|
218
225
|
const modelKey = `${modelProvider.provider}:${modelProvider.model}`;
|
|
219
|
-
|
|
226
|
+
let customMaxTokensStore;
|
|
227
|
+
try {
|
|
228
|
+
customMaxTokensStore = get(copilotInfo)?.maxTokensPerModel;
|
|
229
|
+
}
|
|
230
|
+
catch {
|
|
231
|
+
// copilotInfo store may not be initialized in vitest
|
|
232
|
+
}
|
|
220
233
|
const maxTokens = customMaxTokensStore?.[modelKey] ?? defaultMaxTokens;
|
|
221
234
|
if ((modelProvider.provider === 'openai' || modelProvider.provider === 'azure_openai') &&
|
|
222
235
|
(modelProvider.model.startsWith('o') || modelProvider.model.startsWith('gpt-5'))) {
|
|
@@ -286,34 +299,40 @@ export const PROVIDER_COMPLETION_CONFIG_MAP = {
|
|
|
286
299
|
anthropic: DEFAULT_COMPLETION_CONFIG,
|
|
287
300
|
aws_bedrock: DEFAULT_COMPLETION_CONFIG
|
|
288
301
|
};
|
|
302
|
+
export function getAiProxyBaseURL(workspace) {
|
|
303
|
+
return workspace
|
|
304
|
+
? `${location.origin}${OpenAPI.BASE}/w/${workspace}/ai/proxy`
|
|
305
|
+
: `${location.origin}${OpenAPI.BASE}/ai/proxy`;
|
|
306
|
+
}
|
|
307
|
+
export function createOpenAIProxyClient(baseURL) {
|
|
308
|
+
return new OpenAI({
|
|
309
|
+
baseURL,
|
|
310
|
+
apiKey: 'fake-key',
|
|
311
|
+
defaultHeaders: {
|
|
312
|
+
Authorization: '' // a non empty string will be unable to access Windmill backend proxy
|
|
313
|
+
},
|
|
314
|
+
dangerouslyAllowBrowser: true
|
|
315
|
+
});
|
|
316
|
+
}
|
|
317
|
+
export function createAnthropicProxyClient(baseURL) {
|
|
318
|
+
return new Anthropic({
|
|
319
|
+
baseURL,
|
|
320
|
+
apiKey: 'fake-key',
|
|
321
|
+
dangerouslyAllowBrowser: true
|
|
322
|
+
});
|
|
323
|
+
}
|
|
289
324
|
class WorkspacedAIClients {
|
|
290
325
|
openaiClient;
|
|
291
326
|
anthropicClient;
|
|
292
327
|
init(workspace) {
|
|
293
|
-
this.
|
|
294
|
-
this.
|
|
295
|
-
}
|
|
296
|
-
getBaseURL(workspace) {
|
|
297
|
-
return `${location.origin}${OpenAPI.BASE}/w/${workspace}/ai/proxy`;
|
|
298
|
-
}
|
|
299
|
-
initOpenai(workspace) {
|
|
300
|
-
const baseURL = this.getBaseURL(workspace);
|
|
301
|
-
this.openaiClient = new OpenAI({
|
|
302
|
-
baseURL,
|
|
303
|
-
apiKey: 'fake-key',
|
|
304
|
-
defaultHeaders: {
|
|
305
|
-
Authorization: '' // a non empty string will be unable to access Windmill backend proxy
|
|
306
|
-
},
|
|
307
|
-
dangerouslyAllowBrowser: true
|
|
308
|
-
});
|
|
328
|
+
this.openaiClient = this.createOpenaiClient(workspace);
|
|
329
|
+
this.anthropicClient = this.createAnthropicClient(workspace);
|
|
309
330
|
}
|
|
310
|
-
|
|
311
|
-
|
|
312
|
-
|
|
313
|
-
|
|
314
|
-
|
|
315
|
-
dangerouslyAllowBrowser: true
|
|
316
|
-
});
|
|
331
|
+
createOpenaiClient(workspace) {
|
|
332
|
+
return createOpenAIProxyClient(getAiProxyBaseURL(workspace));
|
|
333
|
+
}
|
|
334
|
+
createAnthropicClient(workspace) {
|
|
335
|
+
return createAnthropicProxyClient(getAiProxyBaseURL(workspace));
|
|
317
336
|
}
|
|
318
337
|
getOpenaiClient() {
|
|
319
338
|
if (!this.openaiClient) {
|
|
@@ -329,7 +348,7 @@ class WorkspacedAIClients {
|
|
|
329
348
|
}
|
|
330
349
|
}
|
|
331
350
|
export const workspaceAIClients = new WorkspacedAIClients();
|
|
332
|
-
export async function testKey({ apiKey, resourcePath, model, abortController, messages, aiProvider }) {
|
|
351
|
+
export async function testKey({ apiKey, workspace, resourcePath, model, abortController, messages, aiProvider }) {
|
|
333
352
|
if (!apiKey && !resourcePath) {
|
|
334
353
|
throw new Error('API key or resource path is required');
|
|
335
354
|
}
|
|
@@ -341,6 +360,7 @@ export async function testKey({ apiKey, resourcePath, model, abortController, me
|
|
|
341
360
|
if (aiProvider === 'anthropic') {
|
|
342
361
|
await testAnthropicKey({
|
|
343
362
|
apiKey,
|
|
363
|
+
workspace,
|
|
344
364
|
resourcePath,
|
|
345
365
|
model: modelToTest,
|
|
346
366
|
abortController,
|
|
@@ -350,6 +370,7 @@ export async function testKey({ apiKey, resourcePath, model, abortController, me
|
|
|
350
370
|
}
|
|
351
371
|
await getNonStreamingCompletion(messages, abortController, {
|
|
352
372
|
apiKey,
|
|
373
|
+
workspace,
|
|
353
374
|
resourcePath,
|
|
354
375
|
forceModelProvider: {
|
|
355
376
|
model: modelToTest,
|
|
@@ -357,7 +378,7 @@ export async function testKey({ apiKey, resourcePath, model, abortController, me
|
|
|
357
378
|
}
|
|
358
379
|
});
|
|
359
380
|
}
|
|
360
|
-
async function testAnthropicKey({ apiKey, resourcePath, model, abortController, messages }) {
|
|
381
|
+
async function testAnthropicKey({ apiKey, workspace, resourcePath, model, abortController, messages }) {
|
|
361
382
|
const { system, messages: anthropicMessages } = convertOpenAIToAnthropicMessages(messages);
|
|
362
383
|
const headers = {
|
|
363
384
|
'X-Provider': 'anthropic',
|
|
@@ -371,12 +392,10 @@ async function testAnthropicKey({ apiKey, resourcePath, model, abortController,
|
|
|
371
392
|
headers['X-API-Key'] = apiKey;
|
|
372
393
|
}
|
|
373
394
|
const anthropicClient = apiKey
|
|
374
|
-
?
|
|
375
|
-
|
|
376
|
-
|
|
377
|
-
|
|
378
|
-
})
|
|
379
|
-
: workspaceAIClients.getAnthropicClient();
|
|
395
|
+
? createAnthropicProxyClient(getAiProxyBaseURL())
|
|
396
|
+
: workspace
|
|
397
|
+
? workspaceAIClients.createAnthropicClient(workspace)
|
|
398
|
+
: workspaceAIClients.getAnthropicClient();
|
|
380
399
|
await anthropicClient.messages.create({
|
|
381
400
|
model,
|
|
382
401
|
max_tokens: 100,
|
|
@@ -556,15 +575,10 @@ export async function getNonStreamingCompletion(messages, abortController, testO
|
|
|
556
575
|
};
|
|
557
576
|
}
|
|
558
577
|
const openaiClient = testOptions?.apiKey
|
|
559
|
-
?
|
|
560
|
-
|
|
561
|
-
|
|
562
|
-
|
|
563
|
-
Authorization: '' // a non empty string will be unable to access Windmill backend proxy
|
|
564
|
-
},
|
|
565
|
-
dangerouslyAllowBrowser: true
|
|
566
|
-
})
|
|
567
|
-
: workspaceAIClients.getOpenaiClient();
|
|
578
|
+
? createOpenAIProxyClient(getAiProxyBaseURL())
|
|
579
|
+
: testOptions?.workspace
|
|
580
|
+
? workspaceAIClients.createOpenaiClient(testOptions.workspace)
|
|
581
|
+
: workspaceAIClients.getOpenaiClient();
|
|
568
582
|
const completion = await openaiClient.chat.completions.create(config, fetchOptions);
|
|
569
583
|
response = completion.choices?.[0]?.message.content || '';
|
|
570
584
|
return response;
|
|
@@ -621,7 +635,12 @@ export async function getFimCompletion(prompt, suffix, providerModel, abortContr
|
|
|
621
635
|
}
|
|
622
636
|
}
|
|
623
637
|
export async function getCompletion(messages, abortController, tools, options) {
|
|
624
|
-
const { provider, config } = getProviderAndCompletionConfig({
|
|
638
|
+
const { provider, config } = getProviderAndCompletionConfig({
|
|
639
|
+
messages,
|
|
640
|
+
stream: true,
|
|
641
|
+
tools,
|
|
642
|
+
forceModelProvider: options?.forceModelProvider
|
|
643
|
+
});
|
|
625
644
|
// Use Responses API for OpenAI and Azure OpenAI
|
|
626
645
|
if ((provider === 'openai' || provider === 'azure_openai') && !options?.forceCompletions) {
|
|
627
646
|
try {
|
|
@@ -633,8 +652,8 @@ export async function getCompletion(messages, abortController, tools, options) {
|
|
|
633
652
|
}
|
|
634
653
|
}
|
|
635
654
|
// Use Completions API for other providers
|
|
636
|
-
const
|
|
637
|
-
const completion =
|
|
655
|
+
const client = options?.openaiClient ?? workspaceAIClients.getOpenaiClient();
|
|
656
|
+
const completion = client.chat.completions.create(config, {
|
|
638
657
|
signal: abortController.signal,
|
|
639
658
|
headers: {
|
|
640
659
|
'X-Provider': provider
|
|
@@ -652,8 +671,8 @@ function extractFirstJSON(str) {
|
|
|
652
671
|
}
|
|
653
672
|
return str.slice(0, i + 1);
|
|
654
673
|
}
|
|
655
|
-
export async function parseOpenAICompletion(completion, callbacks, messages, addedMessages, tools, helpers, _abortController // unused, for signature compatibility with parseAnthropicCompletion
|
|
656
|
-
) {
|
|
674
|
+
export async function parseOpenAICompletion(completion, callbacks, messages, addedMessages, tools, helpers, _abortController, // unused, for signature compatibility with parseAnthropicCompletion
|
|
675
|
+
options) {
|
|
657
676
|
const finalToolCalls = {};
|
|
658
677
|
let malformedFunctionCallError = false;
|
|
659
678
|
let answer = '';
|
|
@@ -773,7 +792,8 @@ export async function parseOpenAICompletion(completion, callbacks, messages, add
|
|
|
773
792
|
tools,
|
|
774
793
|
toolCall,
|
|
775
794
|
helpers,
|
|
776
|
-
toolCallbacks: callbacks
|
|
795
|
+
toolCallbacks: callbacks,
|
|
796
|
+
workspace: options?.workspace
|
|
777
797
|
});
|
|
778
798
|
messages.push(messageToAdd);
|
|
779
799
|
addedMessages.push(messageToAdd);
|
|
@@ -48,7 +48,7 @@ export type IDbSchemaOps = {
|
|
|
48
48
|
previewCreateSql: (params: {
|
|
49
49
|
values: TableEditorValues;
|
|
50
50
|
schema?: string;
|
|
51
|
-
}) => string
|
|
51
|
+
}) => Promise<string>;
|
|
52
52
|
onAlter: (params: {
|
|
53
53
|
values: AlterTableValues;
|
|
54
54
|
schema?: string;
|
|
@@ -56,7 +56,7 @@ export type IDbSchemaOps = {
|
|
|
56
56
|
previewAlterSql: (params: {
|
|
57
57
|
values: AlterTableValues;
|
|
58
58
|
schema?: string;
|
|
59
|
-
}) => string
|
|
59
|
+
}) => Promise<string>;
|
|
60
60
|
onCreateSchema: (params: {
|
|
61
61
|
schema: string;
|
|
62
62
|
}) => Promise<void>;
|
|
@@ -1,46 +1,42 @@
|
|
|
1
1
|
import { getLanguageByResourceType } from './apps/components/display/dbtable/utils';
|
|
2
|
-
import { makeSelectQuery } from './apps/components/display/dbtable/queries/select';
|
|
3
2
|
import { runScriptAndPollResult } from './jobs/utils';
|
|
4
|
-
import { makeCountQuery } from './apps/components/display/dbtable/queries/count';
|
|
5
|
-
import { makeUpdateQuery } from './apps/components/display/dbtable/queries/update';
|
|
6
|
-
import { makeDeleteQuery } from './apps/components/display/dbtable/queries/delete';
|
|
7
|
-
import { makeInsertQuery } from './apps/components/display/dbtable/queries/insert';
|
|
8
|
-
import { makeDeleteTableQuery } from './apps/components/display/dbtable/queries/deleteTable';
|
|
9
3
|
import { stringifySchema } from './copilot/lib';
|
|
10
|
-
import { wrapDucklakeQuery } from './ducklake';
|
|
11
4
|
import { assert } from '../utils';
|
|
12
5
|
import { buildTableEditorValues } from './apps/components/display/dbtable/tableEditor';
|
|
13
|
-
import {
|
|
14
|
-
import {
|
|
15
|
-
import { fetchTableRelationalKeys } from './apps/components/display/dbtable/queries/relationalKeys';
|
|
6
|
+
import {} from './apps/components/display/dbtable/queries/alterTable';
|
|
7
|
+
import { transformForeignKeys, transformSnowflakeForeignKeys } from './apps/components/display/dbtable/queries/relationalKeys';
|
|
16
8
|
export function dbTableOpsWithPreviewScripts({ input, tableKey, colDefs, workspace }) {
|
|
17
9
|
const dbType = getDbType(input);
|
|
18
10
|
const language = getLanguageByResourceType(dbType);
|
|
19
11
|
const dbArg = getDatabaseArg(input);
|
|
12
|
+
const ducklake = input.type === 'ducklake' ? input.ducklake : undefined;
|
|
13
|
+
function makeMarker(op, payload) {
|
|
14
|
+
if (ducklake)
|
|
15
|
+
payload.ducklake = ducklake;
|
|
16
|
+
return `-- WM_INTERNAL_DB_${op} ${JSON.stringify(payload)}`;
|
|
17
|
+
}
|
|
20
18
|
return {
|
|
21
19
|
dbType,
|
|
22
20
|
tableKey,
|
|
23
21
|
colDefs,
|
|
24
22
|
getCount: async ({ quicksearch }) => {
|
|
25
|
-
|
|
26
|
-
if (input.type === 'ducklake')
|
|
27
|
-
countQuery = wrapDucklakeQuery(countQuery, input.ducklake);
|
|
23
|
+
const content = makeMarker('COUNT', { table: tableKey, columnDefs: colDefs });
|
|
28
24
|
const result = await runScriptAndPollResult({
|
|
29
25
|
workspace,
|
|
30
|
-
requestBody: { args: { ...dbArg, quicksearch }, language, content
|
|
26
|
+
requestBody: { args: { ...dbArg, quicksearch }, language, content }
|
|
31
27
|
});
|
|
32
28
|
const count = result?.[0].count;
|
|
33
29
|
return count;
|
|
34
30
|
},
|
|
35
31
|
getRows: async (params) => {
|
|
36
|
-
|
|
32
|
+
const content = makeMarker('SELECT', {
|
|
33
|
+
table: tableKey,
|
|
34
|
+
columnDefs: colDefs,
|
|
37
35
|
fixPgIntTypes: true
|
|
38
36
|
});
|
|
39
|
-
if (input.type === 'ducklake')
|
|
40
|
-
query = wrapDucklakeQuery(query, input.ducklake);
|
|
41
37
|
let items = (await runScriptAndPollResult({
|
|
42
38
|
workspace,
|
|
43
|
-
requestBody: { args: { ...dbArg, ...params }, language, content
|
|
39
|
+
requestBody: { args: { ...dbArg, ...params }, language, content }
|
|
44
40
|
}));
|
|
45
41
|
if (!items || !Array.isArray(items)) {
|
|
46
42
|
throw 'items is not an array';
|
|
@@ -48,34 +44,32 @@ export function dbTableOpsWithPreviewScripts({ input, tableKey, colDefs, workspa
|
|
|
48
44
|
return items;
|
|
49
45
|
},
|
|
50
46
|
onUpdate: async ({ values }, colDef, newValue) => {
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
47
|
+
const content = makeMarker('UPDATE', {
|
|
48
|
+
table: tableKey,
|
|
49
|
+
column: colDef,
|
|
50
|
+
columns: colDefs
|
|
51
|
+
});
|
|
54
52
|
await runScriptAndPollResult({
|
|
55
53
|
workspace,
|
|
56
54
|
requestBody: {
|
|
57
55
|
args: { ...dbArg, value_to_update: newValue, ...values },
|
|
58
56
|
language,
|
|
59
|
-
content
|
|
57
|
+
content
|
|
60
58
|
}
|
|
61
59
|
});
|
|
62
60
|
},
|
|
63
61
|
onDelete: async ({ values }) => {
|
|
64
|
-
|
|
65
|
-
if (input.type === 'ducklake')
|
|
66
|
-
deleteQuery = wrapDucklakeQuery(deleteQuery, input.ducklake);
|
|
62
|
+
const content = makeMarker('DELETE', { table: tableKey, columns: colDefs });
|
|
67
63
|
await runScriptAndPollResult({
|
|
68
64
|
workspace,
|
|
69
|
-
requestBody: { args: { ...dbArg, ...values }, language, content
|
|
65
|
+
requestBody: { args: { ...dbArg, ...values }, language, content }
|
|
70
66
|
});
|
|
71
67
|
},
|
|
72
68
|
onInsert: async ({ values }) => {
|
|
73
|
-
|
|
74
|
-
if (input.type === 'ducklake')
|
|
75
|
-
insertQuery = wrapDucklakeQuery(insertQuery, input.ducklake);
|
|
69
|
+
const content = makeMarker('INSERT', { table: tableKey, columns: colDefs });
|
|
76
70
|
await runScriptAndPollResult({
|
|
77
71
|
workspace,
|
|
78
|
-
requestBody: { args: { ...dbArg, ...values }, language, content
|
|
72
|
+
requestBody: { args: { ...dbArg, ...values }, language, content }
|
|
79
73
|
});
|
|
80
74
|
}
|
|
81
75
|
};
|
|
@@ -84,56 +78,126 @@ export function dbSchemaOpsWithPreviewScripts({ workspace, input }) {
|
|
|
84
78
|
const dbType = getDbType(input);
|
|
85
79
|
const dbArg = getDatabaseArg(input);
|
|
86
80
|
const language = getLanguageByResourceType(dbType);
|
|
81
|
+
const ducklake = input.type === 'ducklake' ? input.ducklake : undefined;
|
|
82
|
+
function makeMarker(op, payload) {
|
|
83
|
+
if (ducklake)
|
|
84
|
+
payload.ducklake = ducklake;
|
|
85
|
+
return `-- WM_INTERNAL_DB_${op} ${JSON.stringify(payload)}`;
|
|
86
|
+
}
|
|
87
87
|
return {
|
|
88
88
|
onDelete: async ({ tableKey, schema }) => {
|
|
89
|
-
|
|
90
|
-
if (input.type === 'ducklake')
|
|
91
|
-
deleteQuery = wrapDucklakeQuery(deleteQuery, input.ducklake);
|
|
89
|
+
const content = makeMarker('DROP_TABLE', { table: tableKey, schema });
|
|
92
90
|
await runScriptAndPollResult({
|
|
93
91
|
workspace,
|
|
94
|
-
requestBody: { args: { ...dbArg }, language, content
|
|
92
|
+
requestBody: { args: { ...dbArg }, language, content }
|
|
95
93
|
});
|
|
96
94
|
},
|
|
97
95
|
onCreate: async ({ values, schema }) => {
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
96
|
+
const content = makeMarker('CREATE_TABLE', {
|
|
97
|
+
name: values.name,
|
|
98
|
+
columns: values.columns,
|
|
99
|
+
foreignKeys: values.foreignKeys,
|
|
100
|
+
schema
|
|
101
|
+
});
|
|
101
102
|
await runScriptAndPollResult({
|
|
102
103
|
workspace,
|
|
103
|
-
requestBody: { args: dbArg, content
|
|
104
|
+
requestBody: { args: dbArg, content, language }
|
|
104
105
|
});
|
|
105
106
|
},
|
|
106
|
-
previewCreateSql: ({ values, schema }) =>
|
|
107
|
+
previewCreateSql: async ({ values, schema }) => {
|
|
108
|
+
const content = makeMarker('CREATE_TABLE', {
|
|
109
|
+
name: values.name,
|
|
110
|
+
columns: values.columns,
|
|
111
|
+
foreignKeys: values.foreignKeys,
|
|
112
|
+
schema
|
|
113
|
+
});
|
|
114
|
+
return expandMarker(workspace, language, content);
|
|
115
|
+
},
|
|
107
116
|
onAlter: async ({ values, schema }) => {
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
117
|
+
const content = makeMarker('ALTER_TABLE', {
|
|
118
|
+
name: values.name,
|
|
119
|
+
operations: values.operations,
|
|
120
|
+
schema
|
|
121
|
+
});
|
|
111
122
|
await runScriptAndPollResult({
|
|
112
123
|
workspace,
|
|
113
|
-
requestBody: { args: dbArg, content
|
|
124
|
+
requestBody: { args: dbArg, content, language }
|
|
125
|
+
});
|
|
126
|
+
},
|
|
127
|
+
previewAlterSql: async ({ values, schema }) => {
|
|
128
|
+
const content = makeMarker('ALTER_TABLE', {
|
|
129
|
+
name: values.name,
|
|
130
|
+
operations: values.operations,
|
|
131
|
+
schema
|
|
114
132
|
});
|
|
133
|
+
return expandMarker(workspace, language, content);
|
|
115
134
|
},
|
|
116
|
-
previewAlterSql: ({ values, schema }) => makeAlterTableQueries(values, dbType, schema),
|
|
117
135
|
onCreateSchema: async ({ schema }) => {
|
|
118
|
-
|
|
119
|
-
if (input.type === 'ducklake')
|
|
120
|
-
createSchemaQuery = wrapDucklakeQuery(createSchemaQuery, input.ducklake);
|
|
136
|
+
const content = makeMarker('CREATE_SCHEMA', { schema });
|
|
121
137
|
await runScriptAndPollResult({
|
|
122
138
|
workspace,
|
|
123
|
-
requestBody: { args: { ...dbArg }, language, content
|
|
139
|
+
requestBody: { args: { ...dbArg }, language, content }
|
|
124
140
|
});
|
|
125
141
|
},
|
|
126
142
|
onDeleteSchema: async ({ schema }) => {
|
|
127
|
-
|
|
128
|
-
if (input.type === 'ducklake')
|
|
129
|
-
dropSchemaQuery = wrapDucklakeQuery(dropSchemaQuery, input.ducklake);
|
|
143
|
+
const content = makeMarker('DROP_SCHEMA', { schema });
|
|
130
144
|
await runScriptAndPollResult({
|
|
131
145
|
workspace,
|
|
132
|
-
requestBody: { args: { ...dbArg }, language, content
|
|
146
|
+
requestBody: { args: { ...dbArg }, language, content }
|
|
133
147
|
});
|
|
134
148
|
},
|
|
135
149
|
onFetchTableEditorDefinition: async ({ table, schema, colDefs }) => {
|
|
136
|
-
let
|
|
150
|
+
let foreignKeys = [];
|
|
151
|
+
let pk_constraint_name;
|
|
152
|
+
// Fetch foreign keys (not supported for BigQuery)
|
|
153
|
+
if (dbType !== 'bigquery') {
|
|
154
|
+
try {
|
|
155
|
+
const fkContent = makeMarker('FOREIGN_KEYS', { table, schema });
|
|
156
|
+
const fkResult = await runScriptAndPollResult({
|
|
157
|
+
workspace,
|
|
158
|
+
requestBody: { args: dbArg, content: fkContent, language }
|
|
159
|
+
});
|
|
160
|
+
let rawForeignKeys;
|
|
161
|
+
if (dbType === 'snowflake') {
|
|
162
|
+
rawForeignKeys = transformSnowflakeForeignKeys(fkResult);
|
|
163
|
+
}
|
|
164
|
+
else {
|
|
165
|
+
rawForeignKeys = fkResult;
|
|
166
|
+
if (rawForeignKeys && Array.isArray(rawForeignKeys)) {
|
|
167
|
+
rawForeignKeys = rawForeignKeys.map((fk) => {
|
|
168
|
+
const lowerFk = {};
|
|
169
|
+
Object.keys(fk).forEach((key) => {
|
|
170
|
+
lowerFk[key.toLowerCase()] = fk[key];
|
|
171
|
+
});
|
|
172
|
+
return lowerFk;
|
|
173
|
+
});
|
|
174
|
+
}
|
|
175
|
+
}
|
|
176
|
+
if (rawForeignKeys && Array.isArray(rawForeignKeys)) {
|
|
177
|
+
foreignKeys = transformForeignKeys(rawForeignKeys);
|
|
178
|
+
}
|
|
179
|
+
}
|
|
180
|
+
catch (e) {
|
|
181
|
+
console.warn('Failed to fetch foreign keys:', e);
|
|
182
|
+
}
|
|
183
|
+
}
|
|
184
|
+
// Fetch primary key constraint name (not supported for BigQuery/MySQL)
|
|
185
|
+
if (dbType !== 'bigquery' && dbType !== 'mysql') {
|
|
186
|
+
try {
|
|
187
|
+
const pkContent = makeMarker('PRIMARY_KEY_CONSTRAINT', { table, schema });
|
|
188
|
+
const pkResult = (await runScriptAndPollResult({
|
|
189
|
+
workspace,
|
|
190
|
+
requestBody: { args: dbArg, content: pkContent, language }
|
|
191
|
+
}));
|
|
192
|
+
if (pkResult && Array.isArray(pkResult) && pkResult.length > 0) {
|
|
193
|
+
const pkRecord = pkResult[0];
|
|
194
|
+
pk_constraint_name = pkRecord?.constraint_name || pkRecord?.CONSTRAINT_NAME || '';
|
|
195
|
+
}
|
|
196
|
+
}
|
|
197
|
+
catch (e) {
|
|
198
|
+
console.warn('Failed to fetch primary key constraint:', e);
|
|
199
|
+
}
|
|
200
|
+
}
|
|
137
201
|
return buildTableEditorValues({
|
|
138
202
|
tableName: table,
|
|
139
203
|
metadata: colDefs,
|
|
@@ -201,3 +265,15 @@ export function getDatabaseArg(input) {
|
|
|
201
265
|
}
|
|
202
266
|
return {};
|
|
203
267
|
}
|
|
268
|
+
async function expandMarker(workspace, language, content) {
|
|
269
|
+
const response = await fetch(`/api/w/${workspace}/internal_db/expand_marker`, {
|
|
270
|
+
method: 'POST',
|
|
271
|
+
headers: { 'Content-Type': 'application/json' },
|
|
272
|
+
body: JSON.stringify({ language, content })
|
|
273
|
+
});
|
|
274
|
+
if (!response.ok) {
|
|
275
|
+
throw new Error(await response.text());
|
|
276
|
+
}
|
|
277
|
+
const result = (await response.json());
|
|
278
|
+
return result.code;
|
|
279
|
+
}
|