whale-code 6.5.6 → 6.5.7
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/README.md +1 -1
- package/bin/whale-code.js +23 -0
- package/dist/cli/__tests__/print-mode-streaming.test.js +270 -0
- package/dist/cli/__tests__/print-mode.basic-output.test.js +230 -0
- package/dist/cli/__tests__/print-mode.session-errors.test.js +252 -0
- package/dist/cli/__tests__/print-mode.test.js +273 -0
- package/dist/cli/__tests__/serve-mode-messages.test.js +338 -0
- package/dist/cli/__tests__/serve-mode.messages.part2.test.js +266 -0
- package/dist/cli/__tests__/serve-mode.messages.test.js +277 -0
- package/dist/cli/__tests__/serve-mode.startup-http.test.js +279 -0
- package/dist/cli/__tests__/serve-mode.test.js +345 -0
- package/dist/cli/app.d.ts +1 -0
- package/dist/cli/app.js +8 -2
- package/dist/cli/app.js.map +1 -1
- package/dist/cli/chat/ChatApp.d.ts +8 -36
- package/dist/cli/chat/ChatApp.js +135 -450
- package/dist/cli/chat/ChatApp.js.map +1 -1
- package/dist/cli/chat/ChatInput.d.ts +3 -2
- package/dist/cli/chat/ChatInput.js +37 -14
- package/dist/cli/chat/ChatInput.js.map +1 -1
- package/dist/cli/chat/ImsgManager.d.ts +20 -0
- package/dist/cli/chat/ImsgManager.js +341 -0
- package/dist/cli/chat/ImsgManager.js.map +1 -0
- package/dist/cli/chat/MarkdownText.d.ts +2 -1
- package/dist/cli/chat/MarkdownText.js +12 -8
- package/dist/cli/chat/MarkdownText.js.map +1 -1
- package/dist/cli/chat/MemoryManager.js +3 -2
- package/dist/cli/chat/MemoryManager.js.map +1 -1
- package/dist/cli/chat/MessageList.d.ts +1 -1
- package/dist/cli/chat/MessageList.js +119 -114
- package/dist/cli/chat/MessageList.js.map +1 -1
- package/dist/cli/chat/NodeManager.js +57 -170
- package/dist/cli/chat/NodeManager.js.map +1 -1
- package/dist/cli/chat/OverlayContext.d.ts +27 -0
- package/dist/cli/chat/OverlayContext.js +2 -0
- package/dist/cli/chat/OverlayContext.js.map +1 -0
- package/dist/cli/chat/PlanApproval.js +3 -2
- package/dist/cli/chat/PlanApproval.js.map +1 -1
- package/dist/cli/chat/RewindConfirmation.d.ts +12 -0
- package/dist/cli/chat/RewindConfirmation.js +243 -0
- package/dist/cli/chat/RewindConfirmation.js.map +1 -0
- package/dist/cli/chat/RewindViewer.js +5 -4
- package/dist/cli/chat/RewindViewer.js.map +1 -1
- package/dist/cli/chat/SessionManager.js +3 -2
- package/dist/cli/chat/SessionManager.js.map +1 -1
- package/dist/cli/chat/SlashMenu.d.ts +7 -24
- package/dist/cli/chat/SlashMenu.js +14 -183
- package/dist/cli/chat/SlashMenu.js.map +1 -1
- package/dist/cli/chat/StatusBar.d.ts +5 -2
- package/dist/cli/chat/StatusBar.js +80 -65
- package/dist/cli/chat/StatusBar.js.map +1 -1
- package/dist/cli/chat/StreamingText.d.ts +2 -1
- package/dist/cli/chat/StreamingText.js +2 -2
- package/dist/cli/chat/StreamingText.js.map +1 -1
- package/dist/cli/chat/SubagentPanel.d.ts +6 -6
- package/dist/cli/chat/SubagentPanel.js +159 -537
- package/dist/cli/chat/SubagentPanel.js.map +1 -1
- package/dist/cli/chat/TeamPanel.js +2 -30
- package/dist/cli/chat/TeamPanel.js.map +1 -1
- package/dist/cli/chat/ToolIndicator.d.ts +7 -23
- package/dist/cli/chat/ToolIndicator.js +543 -1443
- package/dist/cli/chat/ToolIndicator.js.map +1 -1
- package/dist/cli/chat/chat-input-menu-handler.d.ts +32 -0
- package/dist/cli/chat/components/LiveArea.d.ts +12 -0
- package/dist/cli/chat/components/LiveArea.js +252 -0
- package/dist/cli/chat/components/LiveArea.js.map +1 -0
- package/dist/cli/chat/components/OverlayRouter.d.ts +13 -0
- package/dist/cli/chat/components/OverlayRouter.js +257 -0
- package/dist/cli/chat/components/OverlayRouter.js.map +1 -0
- package/dist/cli/chat/components/StaticMessages.d.ts +9 -0
- package/dist/cli/chat/components/StaticMessages.js +132 -0
- package/dist/cli/chat/components/StaticMessages.js.map +1 -0
- package/dist/cli/chat/hooks/agent-loop-events.d.ts +77 -0
- package/dist/cli/chat/hooks/agent-loop-events.js +171 -0
- package/dist/cli/chat/hooks/agent-loop-events.js.map +1 -0
- package/dist/cli/chat/hooks/slash-command-config-system.d.ts +11 -0
- package/dist/cli/chat/hooks/slash-command-config-system.js +177 -0
- package/dist/cli/chat/hooks/slash-command-config-system.js.map +1 -0
- package/dist/cli/chat/hooks/slash-command-handlers-system.d.ts +12 -0
- package/dist/cli/chat/hooks/slash-command-handlers-system.js +127 -0
- package/dist/cli/chat/hooks/slash-command-handlers-system.js.map +1 -0
- package/dist/cli/chat/hooks/slash-command-handlers.d.ts +21 -0
- package/dist/cli/chat/hooks/slash-command-handlers.js +222 -0
- package/dist/cli/chat/hooks/slash-command-handlers.js.map +1 -0
- package/dist/cli/chat/hooks/slash-imsg-handlers.js +148 -0
- package/dist/cli/chat/hooks/slash-imsg-handlers.js.map +1 -0
- package/dist/cli/chat/hooks/slash-node-handlers.d.ts +26 -0
- package/dist/cli/chat/hooks/slash-node-handlers.js +226 -0
- package/dist/cli/chat/hooks/slash-node-handlers.js.map +1 -0
- package/dist/cli/chat/hooks/useAgentLoop.d.ts +2 -21
- package/dist/cli/chat/hooks/useAgentLoop.js +258 -401
- package/dist/cli/chat/hooks/useAgentLoop.js.map +1 -1
- package/dist/cli/chat/hooks/useElapsedClock.d.ts +19 -0
- package/dist/cli/chat/hooks/useElapsedClock.js +80 -0
- package/dist/cli/chat/hooks/useElapsedClock.js.map +1 -0
- package/dist/cli/chat/hooks/useOverlayHandlers.d.ts +23 -0
- package/dist/cli/chat/hooks/useOverlayHandlers.js +125 -0
- package/dist/cli/chat/hooks/useOverlayHandlers.js.map +1 -0
- package/dist/cli/chat/hooks/useSlashCommands.d.ts +14 -22
- package/dist/cli/chat/hooks/useSlashCommands.js +99 -720
- package/dist/cli/chat/hooks/useSlashCommands.js.map +1 -1
- package/dist/cli/chat/hooks/useStreamingReducer.d.ts +66 -0
- package/dist/cli/chat/imsg-manager-render.d.ts +29 -0
- package/dist/cli/chat/imsg-manager-render.js +294 -0
- package/dist/cli/chat/imsg-manager-render.js.map +1 -0
- package/dist/cli/chat/slash-commands.d.ts +37 -0
- package/dist/cli/chat/slash-commands.js +194 -0
- package/dist/cli/chat/slash-commands.js.map +1 -0
- package/dist/cli/chat/store.d.ts +115 -0
- package/dist/cli/chat/store.js +177 -0
- package/dist/cli/chat/store.js.map +1 -0
- package/dist/cli/chat/tool-indicator-helpers.d.ts +14 -0
- package/dist/cli/chat/tool-indicator-helpers.js +167 -0
- package/dist/cli/chat/tool-indicator-helpers.js.map +1 -0
- package/dist/cli/chat/tool-indicator-summary.d.ts +6 -0
- package/dist/cli/chat/tool-indicator-summary.js +103 -0
- package/dist/cli/chat/tool-indicator-summary.js.map +1 -0
- package/dist/cli/chat/tool-indicator-types.d.ts +66 -0
- package/dist/cli/chat/tool-indicator-types.js +177 -0
- package/dist/cli/chat/tool-indicator-types.js.map +1 -0
- package/dist/cli/commands/__tests__/config-cmd.test.js +270 -0
- package/dist/cli/commands/__tests__/doctor.test.js +257 -0
- package/dist/cli/commands/__tests__/imsg-node-bridge.test.js +99 -0
- package/dist/cli/commands/__tests__/imsg-utils.test.js +73 -0
- package/dist/cli/commands/__tests__/init.test.js +214 -0
- package/dist/cli/commands/__tests__/mcp.test.js +287 -0
- package/dist/cli/commands/imsg-config.d.ts +31 -0
- package/dist/cli/commands/imsg-config.js +104 -0
- package/dist/cli/commands/imsg-config.js.map +1 -0
- package/dist/cli/commands/imsg-node-bridge.d.ts +25 -0
- package/dist/cli/commands/imsg-node-bridge.js +229 -0
- package/dist/cli/commands/imsg-node-bridge.js.map +1 -0
- package/dist/cli/commands/imsg-utils.d.ts +14 -0
- package/dist/cli/commands/imsg-utils.js +42 -0
- package/dist/cli/commands/imsg-utils.js.map +1 -0
- package/dist/cli/commands/imsg-watcher-helpers.d.ts +40 -0
- package/dist/cli/commands/imsg-watcher-helpers.js +184 -0
- package/dist/cli/commands/imsg-watcher-helpers.js.map +1 -0
- package/dist/cli/commands/imsg-watcher.d.ts +11 -0
- package/dist/cli/commands/imsg-watcher.js +230 -0
- package/dist/cli/commands/imsg-watcher.js.map +1 -0
- package/dist/cli/commands/imsg.d.ts +14 -0
- package/dist/cli/commands/imsg.js +181 -0
- package/dist/cli/commands/imsg.js.map +1 -0
- package/dist/cli/commands/sessions.d.ts +9 -0
- package/dist/cli/commands/sessions.js +93 -0
- package/dist/cli/commands/sessions.js.map +1 -0
- package/dist/cli/login/LoginApp.js +3 -0
- package/dist/cli/login/LoginApp.js.map +1 -1
- package/dist/cli/serve-mode-persistence.d.ts +18 -0
- package/dist/cli/serve-mode-persistence.js +157 -0
- package/dist/cli/serve-mode-persistence.js.map +1 -0
- package/dist/cli/serve-mode-query.d.ts +9 -0
- package/dist/cli/serve-mode-query.js +247 -0
- package/dist/cli/serve-mode-query.js.map +1 -0
- package/dist/cli/serve-mode-types.d.ts +29 -0
- package/dist/cli/serve-mode-types.js +56 -0
- package/dist/cli/serve-mode-types.js.map +1 -0
- package/dist/cli/services/__tests__/agent-definitions.test.js +153 -0
- package/dist/cli/services/__tests__/agent-events-global.test.js +39 -0
- package/dist/cli/services/__tests__/agent-events.part2.test.js +113 -0
- package/dist/cli/services/__tests__/agent-events.test.js +157 -0
- package/dist/cli/services/__tests__/agent-loop-auth.test.js +392 -0
- package/dist/cli/services/__tests__/agent-loop-budget.test.js +389 -0
- package/dist/cli/services/__tests__/agent-loop-tools-lifecycle.test.js +430 -0
- package/dist/cli/services/__tests__/agent-loop-tools-maxturns.test.js +486 -0
- package/dist/cli/services/__tests__/agent-loop-utils-execution.test.js +528 -0
- package/dist/cli/services/__tests__/agent-loop-utils-helpers.test.js +466 -0
- package/dist/cli/services/__tests__/agent-worker-base-execute.test.js +257 -0
- package/dist/cli/services/__tests__/agent-worker-base-helpers.test.js +198 -0
- package/dist/cli/services/__tests__/agent-worker-base.test.js +278 -0
- package/dist/cli/services/__tests__/auth-service-exports.test.js +41 -0
- package/dist/cli/services/__tests__/auth-service.part2.test.js +169 -0
- package/dist/cli/services/__tests__/auth-service.test.js +242 -0
- package/dist/cli/services/__tests__/background-processes.test.js +282 -0
- package/dist/cli/services/__tests__/claude-md-loader.test.js +134 -0
- package/dist/cli/services/__tests__/config-store.test.js +247 -0
- package/dist/cli/services/__tests__/debug-log.test.js +199 -0
- package/dist/cli/services/__tests__/edge-cases-caching.test.js +174 -0
- package/dist/cli/services/__tests__/edge-cases-compaction-core.test.js +226 -0
- package/dist/cli/services/__tests__/edge-cases-compaction-openai.test.js +152 -0
- package/dist/cli/services/__tests__/edge-cases-compaction-shapes.test.js +53 -0
- package/dist/cli/services/__tests__/edge-cases-compaction-thinking.test.js +226 -0
- package/dist/cli/services/__tests__/edge-cases-compaction.test.js +131 -0
- package/dist/cli/services/__tests__/edge-cases-paths.test.js +86 -0
- package/dist/cli/services/__tests__/error-logger-messages.test.js +81 -0
- package/dist/cli/services/__tests__/error-logger-transport.test.js +119 -0
- package/dist/cli/services/__tests__/error-logger.test.js +264 -0
- package/dist/cli/services/__tests__/file-history.test.js +136 -0
- package/dist/cli/services/__tests__/git-context-cache-reset.test.js +223 -0
- package/dist/cli/services/__tests__/git-context.test.js +241 -0
- package/dist/cli/services/__tests__/interactive-tools-execute.test.js +166 -0
- package/dist/cli/services/__tests__/interactive-tools-plan.test.js +197 -0
- package/dist/cli/services/__tests__/interactive-tools.part2.test.js +168 -0
- package/dist/cli/services/__tests__/interactive-tools.test.js +179 -0
- package/dist/cli/services/__tests__/keybinding-manager.test.js +205 -0
- package/dist/cli/services/__tests__/local-tools-dispatch.test.js +404 -0
- package/dist/cli/services/__tests__/local-tools.test.js +238 -0
- package/dist/cli/services/__tests__/lsp-manager.test.js +364 -0
- package/dist/cli/services/__tests__/mcp-client-connect-disconnect.test.js +310 -0
- package/dist/cli/services/__tests__/mcp-client.test.js +93 -0
- package/dist/cli/services/__tests__/memory-manager.test.js +154 -0
- package/dist/cli/services/__tests__/model-manager-utils.test.js +154 -0
- package/dist/cli/services/__tests__/model-manager.test.js +175 -0
- package/dist/cli/services/__tests__/permission-modes.test.js +222 -0
- package/dist/cli/services/__tests__/ripgrep.test.js +328 -0
- package/dist/cli/services/__tests__/server-tools-execute.test.js +317 -0
- package/dist/cli/services/__tests__/server-tools.test.js +272 -0
- package/dist/cli/services/__tests__/session-persistence.test.js +245 -0
- package/dist/cli/services/__tests__/subagent-basic.test.js +489 -0
- package/dist/cli/services/__tests__/subagent-edge.test.js +545 -0
- package/dist/cli/services/__tests__/subagent-prompts.test.js +558 -0
- package/dist/cli/services/__tests__/subagent-worker-errors.test.js +255 -0
- package/dist/cli/services/__tests__/subagent-worker.test.js +242 -0
- package/dist/cli/services/__tests__/system-prompt.test.js +210 -0
- package/dist/cli/services/__tests__/team-lead-comms-messaging.test.js +250 -0
- package/dist/cli/services/__tests__/team-lead-comms-result.test.js +232 -0
- package/dist/cli/services/__tests__/team-lead-comms-stop.test.js +344 -0
- package/dist/cli/services/__tests__/team-lead-comms.test.js +285 -0
- package/dist/cli/services/__tests__/team-lead-create.test.js +327 -0
- package/dist/cli/services/__tests__/team-lead-run.test.js +318 -0
- package/dist/cli/services/__tests__/team-lead-stop.test.js +199 -0
- package/dist/cli/services/__tests__/team-state-comms.test.js +240 -0
- package/dist/cli/services/__tests__/team-state-core.test.js +230 -0
- package/dist/cli/services/__tests__/team-state-tasks-complete-fail-available.test.js +224 -0
- package/dist/cli/services/__tests__/team-state-tasks.test.js +184 -0
- package/dist/cli/services/__tests__/telemetry-ai-metadata.test.js +116 -0
- package/dist/cli/services/__tests__/telemetry.part2.test.js +195 -0
- package/dist/cli/services/__tests__/telemetry.test.js +176 -0
- package/dist/cli/services/agent-event-types.d.ts +148 -0
- package/dist/cli/services/agent-event-types.js +2 -0
- package/dist/cli/services/agent-event-types.js.map +1 -0
- package/dist/cli/services/agent-loop-iteration.d.ts +13 -0
- package/dist/cli/services/agent-loop-setup.d.ts +32 -0
- package/dist/cli/services/agent-loop-shell-summarize.d.ts +11 -0
- package/dist/cli/services/agent-loop-shell-summarize.js +94 -0
- package/dist/cli/services/agent-loop-shell-summarize.js.map +1 -0
- package/dist/cli/services/agent-loop-tools.d.ts +37 -0
- package/dist/cli/services/agent-loop-tools.js +243 -0
- package/dist/cli/services/agent-loop-tools.js.map +1 -0
- package/dist/cli/services/agent-loop-types.d.ts +52 -0
- package/dist/cli/services/agent-loop-types.js +25 -0
- package/dist/cli/services/agent-loop-types.js.map +1 -0
- package/dist/cli/services/agent-loop.d.ts +2 -2
- package/dist/cli/services/agent-loop.js +162 -17
- package/dist/cli/services/agent-loop.js.map +1 -1
- package/dist/cli/services/agent-worker-base-api.d.ts +19 -0
- package/dist/cli/services/agent-worker-base-helpers.d.ts +27 -0
- package/dist/cli/services/agent-worker-base-tools.d.ts +16 -0
- package/dist/cli/services/agent-worker-base-types.d.ts +81 -0
- package/dist/cli/services/agent-worker-base.js +1 -1
- package/dist/cli/services/agent-worker-base.js.map +1 -1
- package/dist/cli/services/auth-service.js +19 -19
- package/dist/cli/services/auth-service.js.map +1 -1
- package/dist/cli/services/background-agents.d.ts +26 -0
- package/dist/cli/services/background-processes-ops.d.ts +24 -0
- package/dist/cli/services/background-processes.d.ts +2 -1
- package/dist/cli/services/background-processes.js +7 -3
- package/dist/cli/services/background-processes.js.map +1 -1
- package/dist/cli/services/background-tool-defs.d.ts +50 -0
- package/dist/cli/services/cli-agent-loop.d.ts +41 -0
- package/dist/cli/services/cli-agent-loop.js +104 -0
- package/dist/cli/services/cli-agent-loop.js.map +1 -0
- package/dist/cli/services/config-modules-model.test.js +133 -0
- package/dist/cli/services/config-modules-permission.test.js +85 -0
- package/dist/cli/services/config-modules-permissions.test.js +85 -0
- package/dist/cli/services/config-modules-session.test.js +297 -0
- package/dist/cli/services/config-store.d.ts +5 -0
- package/dist/cli/services/config-store.js +90 -5
- package/dist/cli/services/config-store.js.map +1 -1
- package/dist/cli/services/error-logger-internals.d.ts +25 -0
- package/dist/cli/services/error-logger-internals.js +111 -0
- package/dist/cli/services/error-logger-internals.js.map +1 -0
- package/dist/cli/services/format-server-response-columns.test.js +265 -0
- package/dist/cli/services/format-server-response-fallback.test.js +65 -0
- package/dist/cli/services/format-server-response-formatters.d.ts +18 -0
- package/dist/cli/services/format-server-response-formatters.js +195 -0
- package/dist/cli/services/format-server-response-formatters.js.map +1 -0
- package/dist/cli/services/format-server-response-primitives-basic.test.js +261 -0
- package/dist/cli/services/format-server-response-primitives-nested.test.js +188 -0
- package/dist/cli/services/format-server-response-primitives.test.js +300 -0
- package/dist/cli/services/format-server-response-realworld.test.js +248 -0
- package/dist/cli/services/format-server-response-values.test.js +247 -0
- package/dist/cli/services/format-server-response.js +5 -3
- package/dist/cli/services/format-server-response.js.map +1 -1
- package/dist/cli/services/hooks-execute.d.ts +47 -0
- package/dist/cli/services/hooks-execute.js +181 -0
- package/dist/cli/services/hooks-execute.js.map +1 -0
- package/dist/cli/services/hooks-runners.test.js +184 -0
- package/dist/cli/services/hooks.glob-load.test.js +233 -0
- package/dist/cli/services/hooks.run-hooks.test.js +184 -0
- package/dist/cli/services/hooks.test.js +233 -0
- package/dist/cli/services/interactive-tool-defs.d.ts +80 -0
- package/dist/cli/services/interactive-tools.d.ts +5 -2
- package/dist/cli/services/interactive-tools.js +47 -33
- package/dist/cli/services/interactive-tools.js.map +1 -1
- package/dist/cli/services/keybinding-manager.d.ts +2 -0
- package/dist/cli/services/keybinding-manager.js +5 -0
- package/dist/cli/services/keybinding-manager.js.map +1 -1
- package/dist/cli/services/local-tools-agent-defs-tasks.d.ts +6 -0
- package/dist/cli/services/local-tools-agent-defs-tasks.js +245 -0
- package/dist/cli/services/local-tools-agent-defs-tasks.js.map +1 -0
- package/dist/cli/services/local-tools-agent-defs-utils.d.ts +6 -0
- package/dist/cli/services/local-tools-agent-defs-utils.js +198 -0
- package/dist/cli/services/local-tools-agent-defs-utils.js.map +1 -0
- package/dist/cli/services/local-tools-agent-defs.d.ts +10 -0
- package/dist/cli/services/local-tools-agent-defs.js +13 -0
- package/dist/cli/services/local-tools-agent-defs.js.map +1 -0
- package/dist/cli/services/local-tools-definitions.d.ts +6 -0
- package/dist/cli/services/local-tools-files.test.js +256 -0
- package/dist/cli/services/local-tools-read-many.d.ts +6 -0
- package/dist/cli/services/local-tools.js +7 -9
- package/dist/cli/services/local-tools.js.map +1 -1
- package/dist/cli/services/lsp-config.d.ts +13 -0
- package/dist/cli/services/lsp-config.js +72 -0
- package/dist/cli/services/lsp-config.js.map +1 -0
- package/dist/cli/services/lsp-formatters.d.ts +11 -0
- package/dist/cli/services/lsp-formatters.js +209 -0
- package/dist/cli/services/lsp-formatters.js.map +1 -0
- package/dist/cli/services/lsp-protocol.d.ts +9 -0
- package/dist/cli/services/lsp-protocol.js +40 -0
- package/dist/cli/services/lsp-protocol.js.map +1 -0
- package/dist/cli/services/lsp-server-docs.d.ts +8 -0
- package/dist/cli/services/lsp-server-docs.js +132 -0
- package/dist/cli/services/lsp-server-docs.js.map +1 -0
- package/dist/cli/services/lsp-server-documents.d.ts +8 -0
- package/dist/cli/services/lsp-server-documents.js +132 -0
- package/dist/cli/services/lsp-server-documents.js.map +1 -0
- package/dist/cli/services/lsp-server.d.ts +40 -0
- package/dist/cli/services/lsp-server.js +270 -0
- package/dist/cli/services/lsp-server.js.map +1 -0
- package/dist/cli/services/model-router.test.js +245 -0
- package/dist/cli/services/permission-modes.js +16 -3
- package/dist/cli/services/permission-modes.js.map +1 -1
- package/dist/cli/services/project-index.d.ts +41 -0
- package/dist/cli/services/project-index.js +286 -0
- package/dist/cli/services/project-index.js.map +1 -0
- package/dist/cli/services/rewind-rewindTo.test.js +202 -0
- package/dist/cli/services/rewind.test.js +175 -0
- package/dist/cli/services/sandbox.test.js +198 -0
- package/dist/cli/services/server-tools-client.d.ts +46 -0
- package/dist/cli/services/server-tools-client.js +211 -0
- package/dist/cli/services/server-tools-client.js.map +1 -0
- package/dist/cli/services/server-tools-media.d.ts +21 -0
- package/dist/cli/services/server-tools-media.js +163 -0
- package/dist/cli/services/server-tools-media.js.map +1 -0
- package/dist/cli/services/server-tools-preprocess.d.ts +23 -0
- package/dist/cli/services/server-tools-preprocess.js +386 -0
- package/dist/cli/services/server-tools-preprocess.js.map +1 -0
- package/dist/cli/services/server-tools.d.ts +2 -0
- package/dist/cli/services/server-tools.js +40 -15
- package/dist/cli/services/server-tools.js.map +1 -1
- package/dist/cli/services/session-client.d.ts +78 -0
- package/dist/cli/services/session-client.js +197 -0
- package/dist/cli/services/session-client.js.map +1 -0
- package/dist/cli/services/session-persistence.d.ts +3 -0
- package/dist/cli/services/session-persistence.js +12 -0
- package/dist/cli/services/session-persistence.js.map +1 -1
- package/dist/cli/services/subagent-execution.d.ts +12 -0
- package/dist/cli/services/subagent-loop-v2.d.ts +36 -0
- package/dist/cli/services/subagent-loop-v2.js +238 -0
- package/dist/cli/services/subagent-loop-v2.js.map +1 -0
- package/dist/cli/services/subagent-tools.d.ts +10 -0
- package/dist/cli/services/subagent-tools.js +96 -0
- package/dist/cli/services/subagent-tools.js.map +1 -0
- package/dist/cli/services/subagent-types.d.ts +57 -0
- package/dist/cli/services/subagent-types.js +218 -0
- package/dist/cli/services/subagent-types.js.map +1 -0
- package/dist/cli/services/subagent.js +3 -2
- package/dist/cli/services/subagent.js.map +1 -1
- package/dist/cli/services/system-prompt.js +26 -3
- package/dist/cli/services/system-prompt.js.map +1 -1
- package/dist/cli/services/team-lead-auto.d.ts +11 -0
- package/dist/cli/services/team-lead-execution.d.ts +28 -0
- package/dist/cli/services/team-lead-types.d.ts +37 -0
- package/dist/cli/services/team-lead-types.js +2 -0
- package/dist/cli/services/team-lead-types.js.map +1 -0
- package/dist/cli/services/team-lead.d.ts +60 -0
- package/dist/cli/services/team-lead.js +148 -11
- package/dist/cli/services/team-lead.js.map +1 -1
- package/dist/cli/services/team-state-members.d.ts +11 -0
- package/dist/cli/services/team-state-members.js +185 -0
- package/dist/cli/services/team-state-members.js.map +1 -0
- package/dist/cli/services/team-state-messaging.d.ts +16 -0
- package/dist/cli/services/team-state-messaging.js +90 -0
- package/dist/cli/services/team-state-messaging.js.map +1 -0
- package/dist/cli/services/team-state-tasks.d.ts +12 -0
- package/dist/cli/services/team-state-tasks.js +23 -0
- package/dist/cli/services/team-state-tasks.js.map +1 -0
- package/dist/cli/services/team-state-types.d.ts +54 -0
- package/dist/cli/services/team-state-types.js +129 -0
- package/dist/cli/services/team-state-types.js.map +1 -0
- package/dist/cli/services/team-state.d.ts +5 -0
- package/dist/cli/services/team-state.js +29 -0
- package/dist/cli/services/team-state.js.map +1 -1
- package/dist/cli/services/teammate-loop.js +557 -0
- package/dist/cli/services/teammate-loop.js.map +1 -0
- package/dist/cli/services/teammate-prompt.d.ts +2 -0
- package/dist/cli/services/teammate-prompt.js +68 -0
- package/dist/cli/services/teammate-prompt.js.map +1 -0
- package/dist/cli/services/teammate-tools.d.ts +6 -0
- package/dist/cli/services/teammate-tools.js +158 -0
- package/dist/cli/services/teammate-tools.js.map +1 -0
- package/dist/cli/services/teammate-types.d.ts +36 -0
- package/dist/cli/services/teammate-types.js +43 -0
- package/dist/cli/services/teammate-types.js.map +1 -0
- package/dist/cli/services/teammate-worker-helpers.d.ts +71 -0
- package/dist/cli/services/teammate-worker-helpers.js +183 -0
- package/dist/cli/services/teammate-worker-helpers.js.map +1 -0
- package/dist/cli/services/teammate-worker-task-cleanup.d.ts +27 -0
- package/dist/cli/services/teammate-worker-task-cleanup.js +91 -0
- package/dist/cli/services/teammate-worker-task-cleanup.js.map +1 -0
- package/dist/cli/services/teammate-worker-task-loop.d.ts +35 -0
- package/dist/cli/services/teammate-worker-task-loop.js +273 -0
- package/dist/cli/services/teammate-worker-task-loop.js.map +1 -0
- package/dist/cli/services/teammate-worker.d.ts +13 -0
- package/dist/cli/services/teammate-worker.js +294 -0
- package/dist/cli/services/teammate-worker.js.map +1 -0
- package/dist/cli/services/telemetry-spans.d.ts +17 -0
- package/dist/cli/services/telemetry-spans.js +172 -0
- package/dist/cli/services/telemetry-spans.js.map +1 -0
- package/dist/cli/services/tools/__tests__/agent-tools-tasks-teams.test.js +250 -0
- package/dist/cli/services/tools/__tests__/agent-tools-teams.test.js +200 -0
- package/dist/cli/services/tools/__tests__/agent-tools.test.js +340 -0
- package/dist/cli/services/tools/__tests__/file-ops-cache.test.js +152 -0
- package/dist/cli/services/tools/__tests__/file-ops-notebook.test.js +249 -0
- package/dist/cli/services/tools/__tests__/file-ops-read.test.js +261 -0
- package/dist/cli/services/tools/__tests__/file-ops-write.test.js +292 -0
- package/dist/cli/services/tools/__tests__/search-tools-rg.test.js +92 -0
- package/dist/cli/services/tools/__tests__/search-tools.part2.test.js +174 -0
- package/dist/cli/services/tools/__tests__/search-tools.test.js +227 -0
- package/dist/cli/services/tools/__tests__/shell-exec-allowed-core.test.js +163 -0
- package/dist/cli/services/tools/__tests__/shell-exec-allowed-extended.test.js +220 -0
- package/dist/cli/services/tools/__tests__/shell-exec-allowed.part2.test.js +215 -0
- package/dist/cli/services/tools/__tests__/shell-exec-allowed.test.js +154 -0
- package/dist/cli/services/tools/__tests__/shell-exec-blocked.test.js +132 -0
- package/dist/cli/services/tools/__tests__/shell-exec-execution.test.js +245 -0
- package/dist/cli/services/tools/__tests__/task-manager-create.test.js +110 -0
- package/dist/cli/services/tools/__tests__/task-manager-crud.test.js +339 -0
- package/dist/cli/services/tools/__tests__/task-manager-list-get.test.js +343 -0
- package/dist/cli/services/tools/__tests__/task-manager-query.test.js +346 -0
- package/dist/cli/services/tools/__tests__/task-manager-routing.test.js +58 -0
- package/dist/cli/services/tools/__tests__/task-manager-update.test.js +224 -0
- package/dist/cli/services/tools/__tests__/task-manager.test.js +159 -0
- package/dist/cli/services/tools/__tests__/web-tools-html-search.test.js +227 -0
- package/dist/cli/services/tools/__tests__/web-tools.test.js +285 -0
- package/dist/cli/services/tools/agent-tools-tasks.d.ts +10 -0
- package/dist/cli/services/tools/agent-tools-tasks.js +216 -0
- package/dist/cli/services/tools/agent-tools-tasks.js.map +1 -0
- package/dist/cli/services/tools/agent-tools-team.d.ts +8 -0
- package/dist/cli/services/tools/agent-tools-team.js +101 -0
- package/dist/cli/services/tools/agent-tools-team.js.map +1 -0
- package/dist/cli/services/tools/agent-tools.js +115 -42
- package/dist/cli/services/tools/agent-tools.js.map +1 -1
- package/dist/cli/services/tools/file-ops-notebook.d.ts +9 -0
- package/dist/cli/services/tools/file-ops-notebook.js +186 -0
- package/dist/cli/services/tools/file-ops-notebook.js.map +1 -0
- package/dist/cli/services/tools/file-ops-read.d.ts +11 -0
- package/dist/cli/services/tools/file-ops-read.js +237 -0
- package/dist/cli/services/tools/file-ops-read.js.map +1 -0
- package/dist/cli/services/tools/file-ops-write.d.ts +8 -0
- package/dist/cli/services/tools/file-ops-write.js +260 -0
- package/dist/cli/services/tools/file-ops-write.js.map +1 -0
- package/dist/cli/services/tools/file-ops.d.ts +1 -0
- package/dist/cli/services/tools/file-ops.js +167 -0
- package/dist/cli/services/tools/file-ops.js.map +1 -1
- package/dist/cli/services/tools/html-to-text.d.ts +6 -0
- package/dist/cli/services/tools/html-to-text.js +118 -0
- package/dist/cli/services/tools/html-to-text.js.map +1 -0
- package/dist/cli/services/tools/shell-exec.test.js +148 -0
- package/dist/cli/services/tools/ssrf-guard.d.ts +6 -0
- package/dist/cli/services/tools/ssrf-guard.js +80 -0
- package/dist/cli/services/tools/ssrf-guard.js.map +1 -0
- package/dist/cli/setup/SetupComponents.d.ts +10 -0
- package/dist/cli/setup/SetupComponents.js +144 -0
- package/dist/cli/setup/SetupComponents.js.map +1 -0
- package/dist/cli/setup/setup-cli-targets.d.ts +9 -0
- package/dist/cli/setup/setup-cli-targets.js +49 -0
- package/dist/cli/setup/setup-cli-targets.js.map +1 -0
- package/dist/cli/shared/InlineErrorBoundary.d.ts +22 -0
- package/dist/cli/shared/InlineErrorBoundary.js +35 -0
- package/dist/cli/shared/InlineErrorBoundary.js.map +1 -0
- package/dist/cli/shared/MatrixIntro.js +2 -1
- package/dist/cli/shared/MatrixIntro.js.map +1 -1
- package/dist/cli/shared/SharedTick.d.ts +10 -0
- package/dist/cli/shared/SpinnerSlot.d.ts +16 -8
- package/dist/cli/shared/SpinnerSlot.js +122 -29
- package/dist/cli/shared/SpinnerSlot.js.map +1 -1
- package/dist/cli/shared/WhaleBanner.js +3 -2
- package/dist/cli/shared/WhaleBanner.js.map +1 -1
- package/dist/cli/shared/__tests__/markdown.test.js +188 -0
- package/dist/cli/shared/format-utils.d.ts +16 -0
- package/dist/cli/shared/format-utils.js +121 -0
- package/dist/cli/shared/format-utils.js.map +1 -0
- package/dist/cli/shared/markdown-chart.d.ts +8 -0
- package/dist/cli/shared/markdown-chart.js +92 -0
- package/dist/cli/shared/markdown-chart.js.map +1 -0
- package/dist/cli/shared/markdown-diff.d.ts +15 -0
- package/dist/cli/shared/markdown-diff.js +205 -0
- package/dist/cli/shared/markdown-diff.js.map +1 -0
- package/dist/cli/shared/markdown-helpers.d.ts +33 -0
- package/dist/cli/shared/markdown-helpers.js +129 -0
- package/dist/cli/shared/markdown-helpers.js.map +1 -0
- package/dist/cli/shared/markdown-table.d.ts +10 -0
- package/dist/cli/shared/markdown-table.js +227 -0
- package/dist/cli/shared/markdown-table.js.map +1 -0
- package/dist/cli/shared/markdown.d.ts +2 -6
- package/dist/cli/shared/markdown.js +8 -115
- package/dist/cli/shared/markdown.js.map +1 -1
- package/dist/cli/shared/useLatestRef.d.ts +11 -0
- package/dist/cli/shared/useLatestRef.js +34 -0
- package/dist/cli/shared/useLatestRef.js.map +1 -0
- package/dist/cli/shared/useSyncState.d.ts +11 -0
- package/dist/cli/shared/useSyncState.js +39 -0
- package/dist/cli/shared/useSyncState.js.map +1 -0
- package/dist/cli/stores/StoreApp.js +3 -1
- package/dist/cli/stores/StoreApp.js.map +1 -1
- package/dist/index-agent.d.ts +11 -0
- package/dist/index-agent.js +83 -0
- package/dist/index-agent.js.map +1 -0
- package/dist/index-auth.d.ts +22 -0
- package/dist/index-auth.js +114 -0
- package/dist/index-auth.js.map +1 -0
- package/dist/index-handlers.d.ts +25 -0
- package/dist/index-handlers.js +164 -0
- package/dist/index-handlers.js.map +1 -0
- package/dist/index-tools.d.ts +22 -0
- package/dist/index-tools.js +115 -0
- package/dist/index-tools.js.map +1 -0
- package/dist/local-agent/__tests__/connection-disconnect.test.js +201 -0
- package/dist/local-agent/__tests__/connection-lifecycle.test.js +289 -0
- package/dist/local-agent/__tests__/connection-msghandling.test.js +311 -0
- package/dist/local-agent/__tests__/connection-reconnect.test.js +230 -0
- package/dist/local-agent/__tests__/connection-toolexec.test.js +253 -0
- package/dist/local-agent/__tests__/discovery.test.js +328 -0
- package/dist/local-agent/__tests__/executor-background.test.js +219 -0
- package/dist/local-agent/__tests__/executor-exec.test.js +221 -0
- package/dist/local-agent/__tests__/executor-jobs-sessions.test.js +220 -0
- package/dist/local-agent/__tests__/executor-system-info.test.js +133 -0
- package/dist/local-agent/__tests__/executor-systeminfo.test.js +109 -0
- package/dist/local-agent/__tests__/executor.test.js +235 -0
- package/dist/local-agent/__tests__/index.test.js +139 -0
- package/dist/local-agent/connection-handlers.d.ts +8 -0
- package/dist/local-agent/connection-handlers.js +112 -0
- package/dist/local-agent/connection-handlers.js.map +1 -0
- package/dist/local-agent/connection-tools.d.ts +8 -0
- package/dist/local-agent/connection-tools.js +111 -0
- package/dist/local-agent/connection-tools.js.map +1 -0
- package/dist/local-agent/executor-jobs.d.ts +12 -0
- package/dist/local-agent/executor-jobs.js +143 -0
- package/dist/local-agent/executor-jobs.js.map +1 -0
- package/dist/local-agent/executor.d.ts +3 -0
- package/dist/local-agent/executor.js +2 -2
- package/dist/local-agent/executor.js.map +1 -1
- package/dist/node/__tests__/cli-channels.test.js +293 -0
- package/dist/node/__tests__/cli-config-edge.test.js +154 -0
- package/dist/node/__tests__/cli-config.test.js +215 -0
- package/dist/node/__tests__/config.test.js +292 -0
- package/dist/node/__tests__/runtime-heartbeat.test.js +153 -0
- package/dist/node/__tests__/runtime-lifecycle-init.test.js +263 -0
- package/dist/node/__tests__/runtime-lifecycle-stats.test.js +180 -0
- package/dist/node/__tests__/runtime-lifecycle.test.js +305 -0
- package/dist/node/__tests__/runtime-relay.test.js +341 -0
- package/dist/node/adapters/__tests__/base.test.js +286 -0
- package/dist/node/adapters/__tests__/discord.test.js +284 -0
- package/dist/node/adapters/__tests__/email-send.test.js +295 -0
- package/dist/node/adapters/__tests__/email.inbound-send.test.js +217 -0
- package/dist/node/adapters/__tests__/email.lifecycle.test.js +211 -0
- package/dist/node/adapters/__tests__/email.test.js +290 -0
- package/dist/node/adapters/__tests__/email.webhook-send.test.js +251 -0
- package/dist/node/adapters/__tests__/imessage-filter.test.js +183 -0
- package/dist/node/adapters/__tests__/imessage-lifecycle.test.js +215 -0
- package/dist/node/adapters/__tests__/imessage-send-restart.test.js +227 -0
- package/dist/node/adapters/__tests__/slack.part2.test.js +135 -0
- package/dist/node/adapters/__tests__/slack.test.js +241 -0
- package/dist/node/adapters/__tests__/sms-extras.test.js +108 -0
- package/dist/node/adapters/__tests__/sms-lifecycle.test.js +203 -0
- package/dist/node/adapters/__tests__/sms-messaging.test.js +266 -0
- package/dist/node/adapters/__tests__/sms.part2.test.js +174 -0
- package/dist/node/adapters/__tests__/sms.test.js +253 -0
- package/dist/node/adapters/__tests__/telegram-polling.test.js +256 -0
- package/dist/node/adapters/__tests__/telegram-send.test.js +166 -0
- package/dist/node/adapters/__tests__/webchat-inbound.test.js +188 -0
- package/dist/node/adapters/__tests__/webchat-outbound.test.js +178 -0
- package/dist/node/adapters/__tests__/whatsapp-inbound.test.js +200 -0
- package/dist/node/adapters/__tests__/whatsapp-send.test.js +212 -0
- package/dist/node/adapters/__tests__/whatsapp.test.js +280 -0
- package/dist/node/adapters/discord-gateway.d.ts +42 -0
- package/dist/node/adapters/discord-gateway.js +169 -0
- package/dist/node/adapters/discord-gateway.js.map +1 -0
- package/dist/node/adapters/imessage.d.ts +11 -0
- package/dist/node/adapters/imessage.js +23 -6
- package/dist/node/adapters/imessage.js.map +1 -1
- package/dist/node/cli-channels.d.ts +6 -0
- package/dist/node/cli-channels.js +229 -0
- package/dist/node/cli-channels.js.map +1 -0
- package/dist/node/cli-node.d.ts +9 -0
- package/dist/node/cli-node.js +186 -0
- package/dist/node/cli-node.js.map +1 -0
- package/dist/node/cli-portal.d.ts +11 -0
- package/dist/node/cli-portal.js +503 -0
- package/dist/node/cli-portal.js.map +1 -0
- package/dist/node/portal/portal-target.d.ts +16 -0
- package/dist/node/portal/portal-target.js +102 -0
- package/dist/node/portal/portal-target.js.map +1 -0
- package/dist/node/portal/protocol-frames.d.ts +33 -0
- package/dist/node/portal/protocol-frames.js +170 -0
- package/dist/node/portal/protocol-frames.js.map +1 -0
- package/dist/node/runtime-network.d.ts +25 -0
- package/dist/node/runtime-network.js +226 -0
- package/dist/node/runtime-network.js.map +1 -0
- package/dist/node/runtime-utils.d.ts +27 -0
- package/dist/node/runtime-utils.js +99 -0
- package/dist/node/runtime-utils.js.map +1 -0
- package/dist/node/runtime.d.ts +1 -0
- package/dist/node/runtime.js +71 -1
- package/dist/node/runtime.js.map +1 -1
- package/dist/node/task-runner.d.ts +33 -0
- package/dist/node/task-runner.js +276 -0
- package/dist/node/task-runner.js.map +1 -0
- package/dist/server/__tests__/gateway-fast-fail.test.js +160 -0
- package/dist/server/__tests__/local-agent-gateway.test.js +186 -0
- package/dist/server/__tests__/proxy-handlers-delegation.test.js +240 -0
- package/dist/server/__tests__/proxy-handlers-validation.test.js +211 -0
- package/dist/server/__tests__/proxy-handlers.part2.test.js +240 -0
- package/dist/server/__tests__/proxy-handlers.test.js +213 -0
- package/dist/server/__tests__/strip-base64-e2e.test.js +303 -0
- package/dist/server/__tests__/strip-base64.test.js +256 -0
- package/dist/server/__tests__/tool-router-agent-tools.test.js +324 -0
- package/dist/server/__tests__/tool-router-execute-core.test.js +357 -0
- package/dist/server/__tests__/tool-router-execute-permissions.test.js +332 -0
- package/dist/server/__tests__/tool-router-execute.test.js +348 -0
- package/dist/server/__tests__/tool-router-load.test.js +432 -0
- package/dist/server/__tests__/tool-router-permissions.test.js +359 -0
- package/dist/server/__tests__/tool-router-registry-cache.test.js +383 -0
- package/dist/server/__tests__/tool-router-registry-handlers.test.js +272 -0
- package/dist/server/__tests__/tool-router-registry.test.js +331 -0
- package/dist/server/__tests__/validation-inventory.test.js +250 -0
- package/dist/server/__tests__/validation-misc.test.js +243 -0
- package/dist/server/__tests__/validation-supply-chain.test.js +188 -0
- package/dist/server/__tests__/worker.test.js +265 -0
- package/dist/server/handlers/__test-utils__/test-db.d.ts +2 -0
- package/dist/server/handlers/__test-utils__/test-db.js +14 -1
- package/dist/server/handlers/__test-utils__/test-db.js.map +1 -1
- package/dist/server/handlers/__tests__/conversation-lock.test.js +117 -0
- package/dist/server/handlers/__tests__/e2e/auth-cross-platform-login.e2e.test.js +268 -0
- package/dist/server/handlers/__tests__/e2e/auth-cross-platform-tokens.e2e.test.js +264 -0
- package/dist/server/handlers/__tests__/e2e/email-pipeline-send.e2e.test.js +214 -0
- package/dist/server/handlers/__tests__/e2e/email-pipeline-threads.e2e.test.js +168 -0
- package/dist/server/handlers/__tests__/e2e/error-logging-pipeline-dedup.e2e.test.js +229 -0
- package/dist/server/handlers/__tests__/e2e/error-logging-pipeline.e2e.test.js +239 -0
- package/dist/server/handlers/__tests__/e2e/error-logging-rate-limit.e2e.test.js +150 -0
- package/dist/server/handlers/__tests__/e2e/inventory-sync-guards.e2e.test.js +177 -0
- package/dist/server/handlers/__tests__/e2e/inventory-sync.e2e.test.js +228 -0
- package/dist/server/handlers/__tests__/e2e/inventory-sync.part2.e2e.test.js +188 -0
- package/dist/server/handlers/__tests__/e2e/order-lifecycle-fulfillment.e2e.test.js +295 -0
- package/dist/server/handlers/__tests__/e2e/order-lifecycle.e2e.test.js +277 -0
- package/dist/server/handlers/__tests__/e2e/order-lifecycle.fulfillment.e2e.test.js +307 -0
- package/dist/server/handlers/__tests__/e2e/order-lifecycle.setup.e2e.test.js +177 -0
- package/dist/server/handlers/__tests__/e2e/storefront-checkout-cart.e2e.test.js +255 -0
- package/dist/server/handlers/__tests__/e2e/storefront-checkout-webhook.e2e.test.js +231 -0
- package/dist/server/handlers/__tests__/e2e/workflow-execution-failures.e2e.test.js +235 -0
- package/dist/server/handlers/__tests__/e2e/workflow-execution.e2e.test.js +294 -0
- package/dist/server/handlers/__tests__/e2e/workflow-security.e2e.test.js +311 -0
- package/dist/server/handlers/__tests__/e2e/workflow-security.part2.e2e.test.js +267 -0
- package/dist/server/handlers/__tests__/workflow-cache.test.js +237 -0
- package/dist/server/handlers/analytics-errors-edge.test.js +173 -0
- package/dist/server/handlers/analytics.js +88 -1
- package/dist/server/handlers/analytics.js.map +1 -1
- package/dist/server/handlers/analytics.test.js +280 -0
- package/dist/server/handlers/api-docs-examples-ext.d.ts +9 -0
- package/dist/server/handlers/api-docs-examples-ext.js +278 -0
- package/dist/server/handlers/api-docs-examples-ext.js.map +1 -0
- package/dist/server/handlers/api-docs-examples.d.ts +8 -0
- package/dist/server/handlers/api-docs-examples.js +221 -0
- package/dist/server/handlers/api-docs-examples.js.map +1 -0
- package/dist/server/handlers/api-docs-sections-ext.d.ts +2 -0
- package/dist/server/handlers/api-docs-sections-ext.js +497 -0
- package/dist/server/handlers/api-docs-sections-ext.js.map +1 -0
- package/dist/server/handlers/api-docs-sections.d.ts +21 -0
- package/dist/server/handlers/api-docs-sections.js +293 -0
- package/dist/server/handlers/api-docs-sections.js.map +1 -0
- package/dist/server/handlers/api-docs.d.ts +2 -0
- package/dist/server/handlers/api-docs.js +177 -0
- package/dist/server/handlers/api-docs.js.map +1 -1
- package/dist/server/handlers/api-keys.part2.test.js +157 -0
- package/dist/server/handlers/api-keys.test.js +161 -0
- package/dist/server/handlers/billing-core.d.ts +28 -0
- package/dist/server/handlers/billing-core.js +126 -0
- package/dist/server/handlers/billing-core.js.map +1 -0
- package/dist/server/handlers/billing-routes.d.ts +9 -0
- package/dist/server/handlers/billing-routes.js +243 -0
- package/dist/server/handlers/billing-routes.js.map +1 -0
- package/dist/server/handlers/billing-routes.test.js +123 -0
- package/dist/server/handlers/billing.test.js +215 -0
- package/dist/server/handlers/browser-actions-errors.test.js +94 -0
- package/dist/server/handlers/browser-actions.d.ts +35 -0
- package/dist/server/handlers/browser-actions.js +171 -0
- package/dist/server/handlers/browser-actions.js.map +1 -0
- package/dist/server/handlers/browser-actions.part2.test.js +190 -0
- package/dist/server/handlers/browser-actions.test.js +190 -0
- package/dist/server/handlers/browser-captcha.d.ts +6 -0
- package/dist/server/handlers/browser-captcha.js +172 -0
- package/dist/server/handlers/browser-captcha.js.map +1 -0
- package/dist/server/handlers/browser-lifecycle.d.ts +9 -0
- package/dist/server/handlers/browser-lifecycle.js +142 -0
- package/dist/server/handlers/browser-lifecycle.js.map +1 -0
- package/dist/server/handlers/browser-validation.test.js +257 -0
- package/dist/server/handlers/catalog-advanced.d.ts +9 -0
- package/dist/server/handlers/catalog-advanced.js +352 -0
- package/dist/server/handlers/catalog-advanced.js.map +1 -0
- package/dist/server/handlers/catalog-categories.d.ts +5 -0
- package/dist/server/handlers/catalog-categories.js +181 -0
- package/dist/server/handlers/catalog-categories.js.map +1 -0
- package/dist/server/handlers/catalog-products.d.ts +5 -0
- package/dist/server/handlers/catalog-products.js +404 -0
- package/dist/server/handlers/catalog-products.js.map +1 -0
- package/dist/server/handlers/catalog-schemas.d.ts +5 -0
- package/dist/server/handlers/catalog-schemas.js +426 -0
- package/dist/server/handlers/catalog-schemas.js.map +1 -0
- package/dist/server/handlers/catalog.test.js +297 -0
- package/dist/server/handlers/comms-documents-advanced.d.ts +8 -0
- package/dist/server/handlers/comms-documents-advanced.js +159 -0
- package/dist/server/handlers/comms-documents-advanced.js.map +1 -0
- package/dist/server/handlers/comms-documents.d.ts +10 -0
- package/dist/server/handlers/comms-documents.js +445 -0
- package/dist/server/handlers/comms-documents.js.map +1 -0
- package/dist/server/handlers/comms-email.d.ts +10 -0
- package/dist/server/handlers/comms-email.js +492 -0
- package/dist/server/handlers/comms-email.js.map +1 -0
- package/dist/server/handlers/comms-pdf-generation.d.ts +8 -0
- package/dist/server/handlers/comms-pdf-generation.js +327 -0
- package/dist/server/handlers/comms-pdf-generation.js.map +1 -0
- package/dist/server/handlers/comms-pdf-helpers.d.ts +9 -0
- package/dist/server/handlers/comms-pdf-helpers.js +126 -0
- package/dist/server/handlers/comms-pdf-helpers.js.map +1 -0
- package/dist/server/handlers/comms-shared.d.ts +3 -0
- package/dist/server/handlers/comms-shared.js +28 -0
- package/dist/server/handlers/comms-shared.js.map +1 -0
- package/dist/server/handlers/comms.test.js +289 -0
- package/dist/server/handlers/creations-actions.d.ts +21 -0
- package/dist/server/handlers/creations-actions.js +250 -0
- package/dist/server/handlers/creations-actions.js.map +1 -0
- package/dist/server/handlers/creations-advanced-collections.test.js +214 -0
- package/dist/server/handlers/creations-advanced-generate.test.js +142 -0
- package/dist/server/handlers/creations-advanced.test.js +171 -0
- package/dist/server/handlers/creations-collections-preview.test.js +214 -0
- package/dist/server/handlers/creations-crud.d.ts +35 -0
- package/dist/server/handlers/creations-crud.js +248 -0
- package/dist/server/handlers/creations-crud.js.map +1 -0
- package/dist/server/handlers/creations-crud.test.js +260 -0
- package/dist/server/handlers/creations-generate.d.ts +21 -0
- package/dist/server/handlers/creations-generate.js +256 -0
- package/dist/server/handlers/creations-generate.js.map +1 -0
- package/dist/server/handlers/creations-mutations.test.js +197 -0
- package/dist/server/handlers/crm-customers-read.d.ts +58 -0
- package/dist/server/handlers/crm-customers-read.js +208 -0
- package/dist/server/handlers/crm-customers-read.js.map +1 -0
- package/dist/server/handlers/crm-customers-write.d.ts +54 -0
- package/dist/server/handlers/crm-customers-write.js +414 -0
- package/dist/server/handlers/crm-customers-write.js.map +1 -0
- package/dist/server/handlers/crm-utils.d.ts +6 -0
- package/dist/server/handlers/crm-utils.js +19 -0
- package/dist/server/handlers/crm-utils.js.map +1 -0
- package/dist/server/handlers/crm.test.js +179 -0
- package/dist/server/handlers/discovery-advertise.d.ts +18 -0
- package/dist/server/handlers/discovery-advertise.js +101 -0
- package/dist/server/handlers/discovery-advertise.js.map +1 -0
- package/dist/server/handlers/discovery-advertise.test.js +185 -0
- package/dist/server/handlers/discovery-scan.d.ts +19 -0
- package/dist/server/handlers/discovery-scan.js +107 -0
- package/dist/server/handlers/discovery-scan.js.map +1 -0
- package/dist/server/handlers/discovery-scan.test.js +233 -0
- package/dist/server/handlers/embeddings-embed-search.test.js +196 -0
- package/dist/server/handlers/embeddings-index-delete-stats.test.js +140 -0
- package/dist/server/handlers/embeddings-search.test.js +221 -0
- package/dist/server/handlers/embeddings.test.js +137 -0
- package/dist/server/handlers/enrichment-breach.d.ts +8 -0
- package/dist/server/handlers/enrichment-breach.js +266 -0
- package/dist/server/handlers/enrichment-breach.js.map +1 -0
- package/dist/server/handlers/enrichment-data.d.ts +13 -0
- package/dist/server/handlers/enrichment-data.js +145 -0
- package/dist/server/handlers/enrichment-data.js.map +1 -0
- package/dist/server/handlers/enrichment-enrich.d.ts +6 -0
- package/dist/server/handlers/enrichment-enrich.js +235 -0
- package/dist/server/handlers/enrichment-enrich.js.map +1 -0
- package/dist/server/handlers/enrichment-helpers.d.ts +10 -0
- package/dist/server/handlers/enrichment-helpers.js +17 -0
- package/dist/server/handlers/enrichment-helpers.js.map +1 -0
- package/dist/server/handlers/enrichment-mutations.test.js +240 -0
- package/dist/server/handlers/enrichment-queries.test.js +181 -0
- package/dist/server/handlers/enrichment-validation.test.js +177 -0
- package/dist/server/handlers/enrichment-writes.d.ts +16 -0
- package/dist/server/handlers/enrichment-writes.js +226 -0
- package/dist/server/handlers/enrichment-writes.js.map +1 -0
- package/dist/server/handlers/image-gen-actions.d.ts +18 -0
- package/dist/server/handlers/image-gen-actions.js +183 -0
- package/dist/server/handlers/image-gen-actions.js.map +1 -0
- package/dist/server/handlers/image-gen-providers.d.ts +29 -0
- package/dist/server/handlers/image-gen-providers.js +161 -0
- package/dist/server/handlers/image-gen-providers.js.map +1 -0
- package/dist/server/handlers/image-gen.test.js +205 -0
- package/dist/server/handlers/inventory-audit.d.ts +10 -0
- package/dist/server/handlers/inventory-audit.js +90 -0
- package/dist/server/handlers/inventory-audit.js.map +1 -0
- package/dist/server/handlers/inventory-helpers.d.ts +8 -0
- package/dist/server/handlers/inventory-helpers.js +19 -0
- package/dist/server/handlers/inventory-helpers.js.map +1 -0
- package/dist/server/handlers/inventory-query.d.ts +67 -0
- package/dist/server/handlers/inventory-query.js +299 -0
- package/dist/server/handlers/inventory-query.js.map +1 -0
- package/dist/server/handlers/inventory.test.js +380 -0
- package/dist/server/handlers/kali-background.test.js +222 -0
- package/dist/server/handlers/kali-errors.test.js +92 -0
- package/dist/server/handlers/kali-validation.test.js +234 -0
- package/dist/server/handlers/llm-providers-actions.test.js +220 -0
- package/dist/server/handlers/llm-providers-anthropic.test.js +239 -0
- package/dist/server/handlers/llm-providers-clients.d.ts +6 -0
- package/dist/server/handlers/llm-providers-clients.js +296 -0
- package/dist/server/handlers/llm-providers-clients.js.map +1 -0
- package/dist/server/handlers/llm-providers-credentials.d.ts +3 -0
- package/dist/server/handlers/llm-providers-credentials.js +109 -0
- package/dist/server/handlers/llm-providers-credentials.js.map +1 -0
- package/dist/server/handlers/llm-providers-failover.test.js +232 -0
- package/dist/server/handlers/llm-providers-models.d.ts +67 -0
- package/dist/server/handlers/llm-providers-models.js +213 -0
- package/dist/server/handlers/llm-providers-models.js.map +1 -0
- package/dist/server/handlers/llm-providers-providers.test.js +300 -0
- package/dist/server/handlers/llm-providers-validation.test.js +239 -0
- package/dist/server/handlers/local-agent-tools.test.js +224 -0
- package/dist/server/handlers/local-agent.test.js +198 -0
- package/dist/server/handlers/local-agent.tools-status.test.js +204 -0
- package/dist/server/handlers/local-agent.validation-exec.test.js +182 -0
- package/dist/server/handlers/media-actions.d.ts +14 -0
- package/dist/server/handlers/media-actions.js +398 -0
- package/dist/server/handlers/media-actions.js.map +1 -0
- package/dist/server/handlers/media-crud.d.ts +9 -0
- package/dist/server/handlers/media-crud.js +365 -0
- package/dist/server/handlers/media-crud.js.map +1 -0
- package/dist/server/handlers/media-upload.d.ts +4 -0
- package/dist/server/handlers/media-upload.js +179 -0
- package/dist/server/handlers/media-upload.js.map +1 -0
- package/dist/server/handlers/media-utils.d.ts +14 -0
- package/dist/server/handlers/media-utils.js +33 -0
- package/dist/server/handlers/media-utils.js.map +1 -0
- package/dist/server/handlers/meta-ads-advanced.d.ts +46 -0
- package/dist/server/handlers/meta-ads-advanced.js +222 -0
- package/dist/server/handlers/meta-ads-advanced.js.map +1 -0
- package/dist/server/handlers/meta-ads-audience-rules.test.js +243 -0
- package/dist/server/handlers/meta-ads-audience-targeting.test.js +205 -0
- package/dist/server/handlers/meta-ads-audiences-targeting.test.js +383 -0
- package/dist/server/handlers/meta-ads-audiences.d.ts +48 -0
- package/dist/server/handlers/meta-ads-audiences.js +214 -0
- package/dist/server/handlers/meta-ads-audiences.js.map +1 -0
- package/dist/server/handlers/meta-ads-crud-ads.test.js +136 -0
- package/dist/server/handlers/meta-ads-crud-campaigns.test.js +189 -0
- package/dist/server/handlers/meta-ads-crud-create.test.js +303 -0
- package/dist/server/handlers/meta-ads-crud-list-update.test.js +259 -0
- package/dist/server/handlers/meta-ads-crud-read.d.ts +78 -0
- package/dist/server/handlers/meta-ads-crud-read.js +204 -0
- package/dist/server/handlers/meta-ads-crud-read.js.map +1 -0
- package/dist/server/handlers/meta-ads-crud-write.d.ts +105 -0
- package/dist/server/handlers/meta-ads-crud-write.js +390 -0
- package/dist/server/handlers/meta-ads-crud-write.js.map +1 -0
- package/dist/server/handlers/meta-ads-crud.d.ts +9 -0
- package/dist/server/handlers/meta-ads-crud.js +12 -0
- package/dist/server/handlers/meta-ads-crud.js.map +1 -0
- package/dist/server/handlers/meta-ads-delete-publish-sync.test.js +282 -0
- package/dist/server/handlers/meta-ads-graph-api.d.ts +25 -0
- package/dist/server/handlers/meta-ads-graph-api.js +155 -0
- package/dist/server/handlers/meta-ads-graph-api.js.map +1 -0
- package/dist/server/handlers/meta-ads-insights.test.js +80 -0
- package/dist/server/handlers/meta-ads-list-get.test.js +237 -0
- package/dist/server/handlers/meta-ads-media.d.ts +16 -0
- package/dist/server/handlers/meta-ads-media.js +205 -0
- package/dist/server/handlers/meta-ads-media.js.map +1 -0
- package/dist/server/handlers/meta-ads-pixels-rules.d.ts +127 -0
- package/dist/server/handlers/meta-ads-pixels-rules.js +463 -0
- package/dist/server/handlers/meta-ads-pixels-rules.js.map +1 -0
- package/dist/server/handlers/meta-ads-publish-ad.d.ts +11 -0
- package/dist/server/handlers/meta-ads-publish-ad.js +229 -0
- package/dist/server/handlers/meta-ads-publish-ad.js.map +1 -0
- package/dist/server/handlers/meta-ads-publish-delete.test.js +254 -0
- package/dist/server/handlers/meta-ads-publish-helpers.js +117 -0
- package/dist/server/handlers/meta-ads-publish-helpers.js.map +1 -0
- package/dist/server/handlers/meta-ads-publish-sync.test.js +205 -0
- package/dist/server/handlers/meta-ads-publish.d.ts +14 -0
- package/dist/server/handlers/meta-ads-publish.js +194 -0
- package/dist/server/handlers/meta-ads-publish.js.map +1 -0
- package/dist/server/handlers/meta-ads-publish.test.js +254 -0
- package/dist/server/handlers/meta-ads-sync-insights.test.js +184 -0
- package/dist/server/handlers/meta-ads-targeting.d.ts +27 -0
- package/dist/server/handlers/meta-ads-targeting.js +323 -0
- package/dist/server/handlers/meta-ads-targeting.js.map +1 -0
- package/dist/server/handlers/meta-ads-types.d.ts +49 -0
- package/dist/server/handlers/meta-ads-types.js +59 -0
- package/dist/server/handlers/meta-ads-types.js.map +1 -0
- package/dist/server/handlers/meta-ads-update.test.js +117 -0
- package/dist/server/handlers/meta-ads.d.ts +25 -0
- package/dist/server/handlers/meta-ads.js +392 -3
- package/dist/server/handlers/meta-ads.js.map +1 -1
- package/dist/server/handlers/nodes-channels.test.js +413 -0
- package/dist/server/handlers/nodes-events.test.js +131 -0
- package/dist/server/handlers/nodes-handlers-channels-messages.d.ts +20 -0
- package/dist/server/handlers/nodes-handlers-channels-messages.js +314 -0
- package/dist/server/handlers/nodes-handlers-channels-messages.js.map +1 -0
- package/dist/server/handlers/nodes-handlers-channels.d.ts +19 -0
- package/dist/server/handlers/nodes-handlers-channels.js +225 -0
- package/dist/server/handlers/nodes-handlers-channels.js.map +1 -0
- package/dist/server/handlers/nodes-handlers-mgmt.d.ts +33 -0
- package/dist/server/handlers/nodes-handlers-mgmt.js +418 -0
- package/dist/server/handlers/nodes-handlers-mgmt.js.map +1 -0
- package/dist/server/handlers/nodes-list-delete.test.js +171 -0
- package/dist/server/handlers/nodes-messages-delivery.test.js +208 -0
- package/dist/server/handlers/nodes-messages.test.js +211 -0
- package/dist/server/handlers/nodes-register.test.js +277 -0
- package/dist/server/handlers/nodes-routes-channels.d.ts +9 -0
- package/dist/server/handlers/nodes-routes-channels.js +217 -0
- package/dist/server/handlers/nodes-routes-channels.js.map +1 -0
- package/dist/server/handlers/nodes-routes-crud.d.ts +9 -0
- package/dist/server/handlers/nodes-routes-crud.js +290 -0
- package/dist/server/handlers/nodes-routes-crud.js.map +1 -0
- package/dist/server/handlers/nodes-routes-delivery.d.ts +9 -0
- package/dist/server/handlers/nodes-routes-delivery.js +226 -0
- package/dist/server/handlers/nodes-routes-delivery.js.map +1 -0
- package/dist/server/handlers/nodes-routes-messages.d.ts +9 -0
- package/dist/server/handlers/nodes-routes-messages.js +218 -0
- package/dist/server/handlers/nodes-routes-messages.js.map +1 -0
- package/dist/server/handlers/nodes-routes-register.d.ts +9 -0
- package/dist/server/handlers/nodes-routes-register.js +239 -0
- package/dist/server/handlers/nodes-routes-register.js.map +1 -0
- package/dist/server/handlers/nodes-types.d.ts +82 -0
- package/dist/server/handlers/nodes-types.js +220 -0
- package/dist/server/handlers/nodes-types.js.map +1 -0
- package/dist/server/handlers/nodes-utils.d.ts +70 -0
- package/dist/server/handlers/nodes-utils.js +214 -0
- package/dist/server/handlers/nodes-utils.js.map +1 -0
- package/dist/server/handlers/nodes.test.js +353 -0
- package/dist/server/handlers/operations.test.js +136 -0
- package/dist/server/handlers/platform-telemetry.d.ts +10 -0
- package/dist/server/handlers/platform-telemetry.js +372 -0
- package/dist/server/handlers/platform-telemetry.js.map +1 -0
- package/dist/server/handlers/platform-telemetry.test.js +200 -0
- package/dist/server/handlers/platform-websearch.test.js +160 -0
- package/dist/server/handlers/sessions-handlers.d.ts +23 -0
- package/dist/server/handlers/sessions-handlers.js +374 -0
- package/dist/server/handlers/sessions-handlers.js.map +1 -0
- package/dist/server/handlers/storefront-cart.d.ts +31 -0
- package/dist/server/handlers/storefront-cart.js +381 -0
- package/dist/server/handlers/storefront-cart.js.map +1 -0
- package/dist/server/handlers/storefront.test.js +329 -0
- package/dist/server/handlers/supply-chain-transfers.d.ts +10 -0
- package/dist/server/handlers/supply-chain-transfers.js +214 -0
- package/dist/server/handlers/supply-chain-transfers.js.map +1 -0
- package/dist/server/handlers/supply-chain-utils.d.ts +2 -0
- package/dist/server/handlers/supply-chain-utils.js +21 -0
- package/dist/server/handlers/supply-chain-utils.js.map +1 -0
- package/dist/server/handlers/supply-chain.test.js +347 -0
- package/dist/server/handlers/transcription.test.js +118 -0
- package/dist/server/handlers/video-gen-providers.d.ts +30 -0
- package/dist/server/handlers/video-gen-providers.js +205 -0
- package/dist/server/handlers/video-gen-providers.js.map +1 -0
- package/dist/server/handlers/video-gen-sora.d.ts +5 -0
- package/dist/server/handlers/video-gen-sora.js +87 -0
- package/dist/server/handlers/video-gen-sora.js.map +1 -0
- package/dist/server/handlers/video-gen-veo.js +114 -0
- package/dist/server/handlers/video-gen-veo.js.map +1 -0
- package/dist/server/handlers/video-gen.test.js +146 -0
- package/dist/server/handlers/voice-handlers-audio.d.ts +9 -0
- package/dist/server/handlers/voice-handlers-audio.js +229 -0
- package/dist/server/handlers/voice-handlers-audio.js.map +1 -0
- package/dist/server/handlers/voice-handlers-music.d.ts +5 -0
- package/dist/server/handlers/voice-handlers-music.js +124 -0
- package/dist/server/handlers/voice-handlers-music.js.map +1 -0
- package/dist/server/handlers/voice-handlers-pvc.d.ts +8 -0
- package/dist/server/handlers/voice-handlers-pvc.js +345 -0
- package/dist/server/handlers/voice-handlers-pvc.js.map +1 -0
- package/dist/server/handlers/voice-handlers-tts.d.ts +5 -0
- package/dist/server/handlers/voice-handlers-tts.js +142 -0
- package/dist/server/handlers/voice-handlers-tts.js.map +1 -0
- package/dist/server/handlers/voice-handlers-voices.d.ts +8 -0
- package/dist/server/handlers/voice-handlers-voices.js +321 -0
- package/dist/server/handlers/voice-handlers-voices.js.map +1 -0
- package/dist/server/handlers/voice-utils.d.ts +32 -0
- package/dist/server/handlers/voice-utils.js +281 -0
- package/dist/server/handlers/voice-utils.js.map +1 -0
- package/dist/server/handlers/voice.test.js +153 -0
- package/dist/server/handlers/workflow-crud-advanced.d.ts +8 -0
- package/dist/server/handlers/workflow-crud-advanced.js +275 -0
- package/dist/server/handlers/workflow-crud-advanced.js.map +1 -0
- package/dist/server/handlers/workflow-crud-core.d.ts +8 -0
- package/dist/server/handlers/workflow-crud-core.js +286 -0
- package/dist/server/handlers/workflow-crud-core.js.map +1 -0
- package/dist/server/handlers/workflow-crud-events.d.ts +8 -0
- package/dist/server/handlers/workflow-crud-events.js +483 -0
- package/dist/server/handlers/workflow-crud-events.js.map +1 -0
- package/dist/server/handlers/workflow-crud-runs-lifecycle.d.ts +8 -0
- package/dist/server/handlers/workflow-crud-runs-lifecycle.js +231 -0
- package/dist/server/handlers/workflow-crud-runs-lifecycle.js.map +1 -0
- package/dist/server/handlers/workflow-crud-runs-versioning.d.ts +8 -0
- package/dist/server/handlers/workflow-crud-runs-versioning.js +319 -0
- package/dist/server/handlers/workflow-crud-runs-versioning.js.map +1 -0
- package/dist/server/handlers/workflow-crud-runs.d.ts +8 -0
- package/dist/server/handlers/workflow-crud-runs.js +18 -0
- package/dist/server/handlers/workflow-crud-runs.js.map +1 -0
- package/dist/server/handlers/workflow-steps-advancement.d.ts +13 -0
- package/dist/server/handlers/workflow-steps-advancement.js +197 -0
- package/dist/server/handlers/workflow-steps-advancement.js.map +1 -0
- package/dist/server/handlers/workflow-steps-circuit-breaker.d.ts +7 -0
- package/dist/server/handlers/workflow-steps-circuit-breaker.js +131 -0
- package/dist/server/handlers/workflow-steps-circuit-breaker.js.map +1 -0
- package/dist/server/handlers/workflow-steps-completion.d.ts +5 -0
- package/dist/server/handlers/workflow-steps-completion.js +254 -0
- package/dist/server/handlers/workflow-steps-completion.js.map +1 -0
- package/dist/server/handlers/workflow-steps-cron.d.ts +4 -0
- package/dist/server/handlers/workflow-steps-cron.js +259 -0
- package/dist/server/handlers/workflow-steps-cron.js.map +1 -0
- package/dist/server/handlers/workflow-steps-engine-execute.d.ts +3 -0
- package/dist/server/handlers/workflow-steps-engine-execute.js +388 -0
- package/dist/server/handlers/workflow-steps-engine-execute.js.map +1 -0
- package/dist/server/handlers/workflow-steps-engine-inline.d.ts +2 -0
- package/dist/server/handlers/workflow-steps-engine-inline.js +91 -0
- package/dist/server/handlers/workflow-steps-engine-inline.js.map +1 -0
- package/dist/server/handlers/workflow-steps-engine-persist.d.ts +5 -0
- package/dist/server/handlers/workflow-steps-engine-persist.js +192 -0
- package/dist/server/handlers/workflow-steps-engine-persist.js.map +1 -0
- package/dist/server/handlers/workflow-steps-engine-process.d.ts +7 -0
- package/dist/server/handlers/workflow-steps-engine-process.js +290 -0
- package/dist/server/handlers/workflow-steps-engine-process.js.map +1 -0
- package/dist/server/handlers/workflow-steps-engine.d.ts +3 -0
- package/dist/server/handlers/workflow-steps-engine.js +10 -0
- package/dist/server/handlers/workflow-steps-engine.js.map +1 -0
- package/dist/server/handlers/workflow-steps-executors-llm.d.ts +7 -0
- package/dist/server/handlers/workflow-steps-executors-llm.js +265 -0
- package/dist/server/handlers/workflow-steps-executors-llm.js.map +1 -0
- package/dist/server/handlers/workflow-steps-executors.d.ts +9 -0
- package/dist/server/handlers/workflow-steps-executors.js +188 -0
- package/dist/server/handlers/workflow-steps-executors.js.map +1 -0
- package/dist/server/handlers/workflow-steps-maintenance.d.ts +4 -0
- package/dist/server/handlers/workflow-steps-maintenance.js +256 -0
- package/dist/server/handlers/workflow-steps-maintenance.js.map +1 -0
- package/dist/server/handlers/workflow-steps-types.d.ts +84 -0
- package/dist/server/handlers/workflow-steps-types.js +179 -0
- package/dist/server/handlers/workflow-steps-types.js.map +1 -0
- package/dist/server/handlers/workflow-steps-webhook.d.ts +5 -0
- package/dist/server/handlers/workflow-steps-webhook.js +179 -0
- package/dist/server/handlers/workflow-steps-webhook.js.map +1 -0
- package/dist/server/handlers/workflow-steps.test.js +330 -0
- package/dist/server/handlers/workflows-extras.test.js +65 -0
- package/dist/server/handlers/workflows.part2.test.js +170 -0
- package/dist/server/handlers/workflows.test.js +281 -0
- package/dist/server/index.js +81 -1720
- package/dist/server/index.js.map +1 -1
- package/dist/server/lib/__tests__/batch-client-conversion-jsonl.test.js +171 -0
- package/dist/server/lib/__tests__/batch-client-polling.test.js +292 -0
- package/dist/server/lib/__tests__/batch-client-queue.test.js +270 -0
- package/dist/server/lib/__tests__/clickhouse-buffer.test.js +236 -0
- package/dist/server/lib/__tests__/code-worker-edge-cases.test.js +118 -0
- package/dist/server/lib/__tests__/code-worker-pool-execute.test.js +193 -0
- package/dist/server/lib/__tests__/code-worker-pool-execution.test.js +165 -0
- package/dist/server/lib/__tests__/code-worker-pool-init.test.js +131 -0
- package/dist/server/lib/__tests__/code-worker-pool.test.js +194 -0
- package/dist/server/lib/__tests__/code-worker-sandbox-ops.test.js +123 -0
- package/dist/server/lib/__tests__/code-worker-sandbox.test.js +217 -0
- package/dist/server/lib/__tests__/code-worker.test.js +179 -0
- package/dist/server/lib/__tests__/compaction-service-generate.test.js +229 -0
- package/dist/server/lib/__tests__/compaction-service.test.js +319 -0
- package/dist/server/lib/__tests__/otel.test.js +146 -0
- package/dist/server/lib/__tests__/prompt-sanitizer-validation.test.js +165 -0
- package/dist/server/lib/__tests__/prompt-sanitizer.sanitize.test.js +343 -0
- package/dist/server/lib/__tests__/prompt-sanitizer.test.js +328 -0
- package/dist/server/lib/__tests__/prompt-sanitizer.validate-tool.test.js +145 -0
- package/dist/server/lib/__tests__/provider-capabilities.test.js +263 -0
- package/dist/server/lib/__tests__/provider-failover-routing.test.js +145 -0
- package/dist/server/lib/__tests__/provider-failover-state.test.js +131 -0
- package/dist/server/lib/__tests__/rate-limiter-budgets.test.js +216 -0
- package/dist/server/lib/__tests__/rate-limiter.budgets-tools.test.js +113 -0
- package/dist/server/lib/__tests__/rate-limiter.check-request.test.js +141 -0
- package/dist/server/lib/__tests__/rate-limiter.stats-lifecycle.test.js +135 -0
- package/dist/server/lib/__tests__/rate-limiter.test.js +207 -0
- package/dist/server/lib/__tests__/server-agent-loop-abort-conditions.test.js +544 -0
- package/dist/server/lib/__tests__/server-agent-loop-abort.part2.test.js +504 -0
- package/dist/server/lib/__tests__/server-agent-loop-abort.test.js +396 -0
- package/dist/server/lib/__tests__/server-agent-loop-compaction.test.js +397 -0
- package/dist/server/lib/__tests__/server-agent-loop-failover.test.js +356 -0
- package/dist/server/lib/__tests__/server-agent-loop-features-caching.test.js +519 -0
- package/dist/server/lib/__tests__/server-agent-loop-features-edges.test.js +512 -0
- package/dist/server/lib/__tests__/server-subagent-bailout.test.js +194 -0
- package/dist/server/lib/__tests__/server-subagent-basics.test.js +348 -0
- package/dist/server/lib/__tests__/server-subagent-errors-abort.test.js +319 -0
- package/dist/server/lib/__tests__/server-subagent-errors-progress.test.js +253 -0
- package/dist/server/lib/__tests__/server-subagent-errors.part2.test.js +253 -0
- package/dist/server/lib/__tests__/server-subagent-errors.test.js +319 -0
- package/dist/server/lib/__tests__/session-checkpoint-load.test.js +275 -0
- package/dist/server/lib/__tests__/session-checkpoint-save.test.js +159 -0
- package/dist/server/lib/__tests__/ssrf-guard.test.js +93 -0
- package/dist/server/lib/__tests__/supabase-client.test.js +111 -0
- package/dist/server/lib/__tests__/template-resolver.test.js +317 -0
- package/dist/server/lib/__tests__/utils-timeout.test.js +49 -0
- package/dist/server/lib/__tests__/utils.test.js +322 -0
- package/dist/server/lib/agent-loop-executor.d.ts +7 -0
- package/dist/server/lib/agent-loop-executor.js +224 -0
- package/dist/server/lib/agent-loop-executor.js.map +1 -0
- package/dist/server/lib/agent-loop-turn.d.ts +53 -0
- package/dist/server/lib/agent-loop-turn.js +166 -0
- package/dist/server/lib/agent-loop-turn.js.map +1 -0
- package/dist/server/lib/agent-loop-types.d.ts +118 -0
- package/dist/server/lib/agent-loop-types.js +53 -0
- package/dist/server/lib/agent-loop-types.js.map +1 -0
- package/dist/server/lib/batch-client-anthropic.d.ts +10 -0
- package/dist/server/lib/batch-client-anthropic.js +144 -0
- package/dist/server/lib/batch-client-anthropic.js.map +1 -0
- package/dist/server/lib/batch-client-openai.d.ts +10 -0
- package/dist/server/lib/batch-client-openai.js +172 -0
- package/dist/server/lib/batch-client-openai.js.map +1 -0
- package/dist/server/lib/batch-client-types.d.ts +54 -0
- package/dist/server/lib/batch-client-types.js +27 -0
- package/dist/server/lib/batch-client-types.js.map +1 -0
- package/dist/server/lib/coa-renderer-components.d.ts +15 -0
- package/dist/server/lib/coa-renderer-components.js +361 -0
- package/dist/server/lib/coa-renderer-components.js.map +1 -0
- package/dist/server/lib/coa-renderer-pages.d.ts +15 -0
- package/dist/server/lib/coa-renderer-pages.js +467 -0
- package/dist/server/lib/coa-renderer-pages.js.map +1 -0
- package/dist/server/lib/coa-renderer-styles.d.ts +525 -0
- package/dist/server/lib/coa-renderer-styles.js +540 -0
- package/dist/server/lib/coa-renderer-styles.js.map +1 -0
- package/dist/server/lib/coa-renderer-tokens.d.ts +107 -0
- package/dist/server/lib/coa-renderer-tokens.js +46 -0
- package/dist/server/lib/coa-renderer-tokens.js.map +1 -0
- package/dist/server/lib/pdf-renderer-calc.d.ts +7 -0
- package/dist/server/lib/pdf-renderer-calc.js +272 -0
- package/dist/server/lib/pdf-renderer-calc.js.map +1 -0
- package/dist/server/lib/pdf-renderer-generation.d.ts +73 -0
- package/dist/server/lib/pdf-renderer-generation.js +298 -0
- package/dist/server/lib/pdf-renderer-generation.js.map +1 -0
- package/dist/server/lib/pdf-renderer-layout.d.ts +2 -0
- package/dist/server/lib/pdf-renderer-layout.js +144 -0
- package/dist/server/lib/pdf-renderer-layout.js.map +1 -0
- package/dist/server/lib/pdf-renderer-validation.d.ts +14 -0
- package/dist/server/lib/pdf-renderer-validation.js +220 -0
- package/dist/server/lib/pdf-renderer-validation.js.map +1 -0
- package/dist/server/lib/react-pdf-layout-elements.d.ts +8 -0
- package/dist/server/lib/react-pdf-layout-elements.js +366 -0
- package/dist/server/lib/react-pdf-layout-elements.js.map +1 -0
- package/dist/server/lib/react-pdf-layout-labels.d.ts +38 -0
- package/dist/server/lib/react-pdf-layout-labels.js +217 -0
- package/dist/server/lib/react-pdf-layout-labels.js.map +1 -0
- package/dist/server/lib/server-agent-loop-init.d.ts +28 -0
- package/dist/server/lib/server-agent-loop-init.js +138 -0
- package/dist/server/lib/server-agent-loop-init.js.map +1 -0
- package/dist/server/lib/server-agent-loop-v2.d.ts +110 -0
- package/dist/server/lib/server-agent-loop-v2.js +340 -0
- package/dist/server/lib/server-agent-loop-v2.js.map +1 -0
- package/dist/server/lib/server-agent-loop.js +2 -1
- package/dist/server/lib/server-agent-loop.js.map +1 -1
- package/dist/server/lib/server-subagent-loop.d.ts +3 -0
- package/dist/server/lib/server-subagent-loop.js +267 -0
- package/dist/server/lib/server-subagent-loop.js.map +1 -0
- package/dist/server/lib/session-types.d.ts +106 -0
- package/dist/server/lib/session-types.js +2 -0
- package/dist/server/lib/session-types.js.map +1 -0
- package/dist/server/local-agent-gateway-api.d.ts +34 -0
- package/dist/server/local-agent-gateway-api.js +156 -0
- package/dist/server/local-agent-gateway-api.js.map +1 -0
- package/dist/server/local-agent-gateway-handler.d.ts +3 -0
- package/dist/server/local-agent-gateway-handler.js +292 -0
- package/dist/server/local-agent-gateway-handler.js.map +1 -0
- package/dist/server/local-agent-gateway-init.d.ts +21 -0
- package/dist/server/local-agent-gateway-init.js +143 -0
- package/dist/server/local-agent-gateway-init.js.map +1 -0
- package/dist/server/local-agent-gateway-messages.d.ts +12 -0
- package/dist/server/local-agent-gateway-messages.js +108 -0
- package/dist/server/local-agent-gateway-messages.js.map +1 -0
- package/dist/server/local-agent-gateway-stats.d.ts +53 -0
- package/dist/server/local-agent-gateway-stats.js +129 -0
- package/dist/server/local-agent-gateway-stats.js.map +1 -0
- package/dist/server/local-agent-gateway-types.d.ts +94 -0
- package/dist/server/local-agent-gateway-types.js +78 -0
- package/dist/server/local-agent-gateway-types.js.map +1 -0
- package/dist/server/local-agent-gateway.d.ts +6 -0
- package/dist/server/local-agent-gateway.js +40 -0
- package/dist/server/local-agent-gateway.js.map +1 -1
- package/dist/server/providers/__tests__/anthropic-adapter.test.js +228 -0
- package/dist/server/providers/__tests__/anthropic-betas-toolchoice.test.js +257 -0
- package/dist/server/providers/__tests__/anthropic-errors.test.js +262 -0
- package/dist/server/providers/__tests__/anthropic-stream-core.test.js +275 -0
- package/dist/server/providers/__tests__/anthropic-streaming-betas.test.js +247 -0
- package/dist/server/providers/__tests__/anthropic-streaming-core.test.js +275 -0
- package/dist/server/providers/__tests__/bedrock-config.test.js +177 -0
- package/dist/server/providers/__tests__/bedrock-stream-behavior-streaming.test.js +272 -0
- package/dist/server/providers/__tests__/bedrock-stream-behavior-toolchoice.test.js +214 -0
- package/dist/server/providers/__tests__/bedrock-stream-behavior.part2.test.js +165 -0
- package/dist/server/providers/__tests__/bedrock-stream-behavior.test.js +309 -0
- package/dist/server/providers/__tests__/bedrock-stream-body-credentials.test.js +170 -0
- package/dist/server/providers/__tests__/bedrock-stream-body-extras.test.js +183 -0
- package/dist/server/providers/__tests__/bedrock-stream-body-request.test.js +305 -0
- package/dist/server/providers/__tests__/bedrock-stream-body.part2.test.js +305 -0
- package/dist/server/providers/__tests__/bedrock-stream-body.test.js +175 -0
- package/dist/server/providers/__tests__/bedrock-stream-errors.test.js +165 -0
- package/dist/server/providers/__tests__/gemini-config-methods.test.js +182 -0
- package/dist/server/providers/__tests__/gemini-config-streaming.test.js +257 -0
- package/dist/server/providers/__tests__/gemini-conversion-messages.test.js +247 -0
- package/dist/server/providers/__tests__/gemini-conversion-schema.test.js +365 -0
- package/dist/server/providers/__tests__/gemini-tools-choice.test.js +221 -0
- package/dist/server/providers/__tests__/gemini-tools-fn.test.js +252 -0
- package/dist/server/providers/__tests__/openai-config.test.js +194 -0
- package/dist/server/providers/__tests__/openai-conversion.test.js +276 -0
- package/dist/server/providers/__tests__/openai-messages.test.js +261 -0
- package/dist/server/providers/__tests__/openai-streaming.test.js +394 -0
- package/dist/server/providers/__tests__/openai-tools-cache.test.js +227 -0
- package/dist/server/providers/__tests__/registry.test.js +183 -0
- package/dist/server/providers/__tests__/shared.test.js +297 -0
- package/dist/server/providers/gemini-conversion.d.ts +17 -0
- package/dist/server/providers/gemini-conversion.js +185 -0
- package/dist/server/providers/gemini-conversion.js.map +1 -0
- package/dist/server/providers/gemini-streaming.d.ts +18 -0
- package/dist/server/providers/gemini-streaming.js +187 -0
- package/dist/server/providers/gemini-streaming.js.map +1 -0
- package/dist/server/providers/openai-adapter.d.ts +15 -0
- package/dist/server/providers/openai-adapter.js +423 -0
- package/dist/server/providers/openai-adapter.js.map +1 -0
- package/dist/server/providers/openai-conversion.d.ts +21 -0
- package/dist/server/providers/openai-conversion.js +191 -0
- package/dist/server/providers/openai-conversion.js.map +1 -0
- package/dist/server/server-agent.d.ts +21 -0
- package/dist/server/server-agent.js +162 -0
- package/dist/server/server-agent.js.map +1 -0
- package/dist/server/server-chat.d.ts +6 -0
- package/dist/server/server-chat.js +210 -0
- package/dist/server/server-chat.js.map +1 -0
- package/dist/server/server-cost-guard.d.ts +16 -0
- package/dist/server/server-cost-guard.js +141 -0
- package/dist/server/server-cost-guard.js.map +1 -0
- package/dist/server/server-executors.d.ts +10 -0
- package/dist/server/server-executors.js +110 -0
- package/dist/server/server-executors.js.map +1 -0
- package/dist/server/server-helpers.d.ts +49 -0
- package/dist/server/server-helpers.js +210 -0
- package/dist/server/server-helpers.js.map +1 -0
- package/dist/server/server-persist.d.ts +43 -0
- package/dist/server/server-persist.js +249 -0
- package/dist/server/server-persist.js.map +1 -0
- package/dist/server/server-rate-limit.d.ts +9 -0
- package/dist/server/server-rate-limit.js +77 -0
- package/dist/server/server-rate-limit.js.map +1 -0
- package/dist/server/server-routes-approvals.d.ts +4 -0
- package/dist/server/server-routes-approvals.js +238 -0
- package/dist/server/server-routes-approvals.js.map +1 -0
- package/dist/server/server-routes-auth.d.ts +7 -0
- package/dist/server/server-routes-auth.js +532 -0
- package/dist/server/server-routes-auth.js.map +1 -0
- package/dist/server/server-routes-events.d.ts +4 -0
- package/dist/server/server-routes-events.js +167 -0
- package/dist/server/server-routes-events.js.map +1 -0
- package/dist/server/server-routes-public.d.ts +24 -0
- package/dist/server/server-routes-public.js +453 -0
- package/dist/server/server-routes-public.js.map +1 -0
- package/dist/server/server-routes-waitpoints.d.ts +4 -0
- package/dist/server/server-routes-waitpoints.js +190 -0
- package/dist/server/server-routes-waitpoints.js.map +1 -0
- package/dist/server/server-routes-webchat.d.ts +14 -0
- package/dist/server/server-routes-webchat.js +307 -0
- package/dist/server/server-routes-webchat.js.map +1 -0
- package/dist/server/server-routes-workflows.d.ts +5 -0
- package/dist/server/server-routes-workflows.js +289 -0
- package/dist/server/server-routes-workflows.js.map +1 -0
- package/dist/server/server-sse.d.ts +13 -0
- package/dist/server/server-sse.js +197 -0
- package/dist/server/server-sse.js.map +1 -0
- package/dist/server/server-store-circuit-breaker.d.ts +32 -0
- package/dist/server/server-store-circuit-breaker.js +211 -0
- package/dist/server/server-store-circuit-breaker.js.map +1 -0
- package/dist/server/server-store.d.ts +5 -0
- package/dist/server/server-store.js +71 -0
- package/dist/server/server-store.js.map +1 -0
- package/dist/server/server-trace.d.ts +41 -0
- package/dist/server/server-trace.js +133 -0
- package/dist/server/server-trace.js.map +1 -0
- package/dist/server/server-worker.d.ts +4 -0
- package/dist/server/server-worker.js +127 -0
- package/dist/server/server-worker.js.map +1 -0
- package/dist/server/session-events.d.ts +27 -0
- package/dist/server/session-events.js +69 -0
- package/dist/server/session-events.js.map +1 -0
- package/dist/server/session-manager.d.ts +52 -0
- package/dist/server/session-manager.js +502 -0
- package/dist/server/session-manager.js.map +1 -0
- package/dist/server/tool-router-discovery.d.ts +33 -0
- package/dist/server/tool-router-discovery.js +218 -0
- package/dist/server/tool-router-discovery.js.map +1 -0
- package/dist/server/tool-router-types.d.ts +91 -0
- package/dist/server/tool-router-types.js +336 -0
- package/dist/server/tool-router-types.js.map +1 -0
- package/dist/server/tool-router-user-tools.d.ts +16 -0
- package/dist/server/tool-router-user-tools.js +269 -0
- package/dist/server/tool-router-user-tools.js.map +1 -0
- package/dist/server/validation-schemas.d.ts +12 -0
- package/dist/server/validation-schemas.js +251 -0
- package/dist/server/validation-schemas.js.map +1 -0
- package/dist/shared/agent-core-config.d.ts +12 -0
- package/dist/shared/agent-core-config.js +77 -0
- package/dist/shared/agent-core-config.js.map +1 -0
- package/dist/shared/agent-core-config.test.js +132 -0
- package/dist/shared/agent-core-context-thinking.test.js +293 -0
- package/dist/shared/agent-core-loop-calls.test.js +174 -0
- package/dist/shared/agent-core-loop-detector-bail.test.js +201 -0
- package/dist/shared/agent-core-loop-detector.test.js +195 -0
- package/dist/shared/agent-core-loop-errors.test.js +258 -0
- package/dist/shared/agent-core-loop.d.ts +53 -0
- package/dist/shared/agent-core-loop.js +251 -0
- package/dist/shared/agent-core-loop.js.map +1 -0
- package/dist/shared/agent-core-pricing.test.js +191 -0
- package/dist/shared/agent-core-sanitize-retry.test.js +129 -0
- package/dist/shared/agent-core-tools.d.ts +32 -0
- package/dist/shared/agent-core-tools.js +323 -0
- package/dist/shared/agent-core-tools.js.map +1 -0
- package/dist/shared/agent-core-types.d.ts +182 -0
- package/dist/shared/agent-core-types.js +265 -0
- package/dist/shared/agent-core-types.js.map +1 -0
- package/dist/shared/agent-core.js +1 -1
- package/dist/shared/agent-core.js.map +1 -1
- package/dist/shared/agent-loop-base.d.ts +130 -0
- package/dist/shared/agent-loop-base.js +347 -0
- package/dist/shared/agent-loop-base.js.map +1 -0
- package/dist/shared/api-client-build-request.test.js +228 -0
- package/dist/shared/api-client-build-system-caching.test.js +107 -0
- package/dist/shared/api-client-build.test.js +223 -0
- package/dist/shared/api-client-config.d.ts +21 -0
- package/dist/shared/api-client-helpers.d.ts +57 -0
- package/dist/shared/api-client-helpers.test.js +261 -0
- package/dist/shared/api-client-proxy-happy.test.js +255 -0
- package/dist/shared/api-client-proxy-retry.test.js +307 -0
- package/dist/shared/api-client-proxy.d.ts +26 -0
- package/dist/shared/api-client-proxy.test.js +255 -0
- package/dist/shared/api-client-retry.test.js +307 -0
- package/dist/shared/api-client-system-trimming.test.js +261 -0
- package/dist/shared/api-client-trimming.d.ts +36 -0
- package/dist/shared/api-client.js.map +1 -1
- package/dist/shared/api-client.test.js +228 -0
- package/dist/shared/compaction-thinking.test.js +315 -0
- package/dist/shared/compaction-trimming.test.js +223 -0
- package/dist/shared/exec-validator.d.ts +29 -0
- package/dist/shared/exec-validator.js +106 -0
- package/dist/shared/exec-validator.js.map +1 -0
- package/dist/shared/imsg-constants.d.ts +8 -0
- package/dist/shared/imsg-constants.js +13 -0
- package/dist/shared/imsg-constants.js.map +1 -0
- package/dist/shared/sse-parser-callbacks.test.js +422 -0
- package/dist/shared/sse-parser-collect.test.js +252 -0
- package/dist/shared/sse-parser-e2e.test.js +558 -0
- package/dist/shared/sse-parser-parse.test.js +253 -0
- package/dist/shared/tool-dispatch-advanced-batch-build.test.js +405 -0
- package/dist/shared/tool-dispatch-advanced.test.js +320 -0
- package/dist/shared/tool-dispatch-basic.test.js +278 -0
- package/dist/shared/tool-dispatch-content.d.ts +14 -0
- package/dist/shared/tool-dispatch-parallel.test.js +378 -0
- package/dist/shared/tool-dispatch.js +1 -1
- package/dist/shared/tool-dispatch.js.map +1 -1
- package/dist/webchat/__tests__/widget-messaging.test.js +323 -0
- package/dist/webchat/__tests__/widget.test.js +273 -0
- package/dist/webchat/widget-styles.d.ts +7 -0
- package/dist/webchat/widget-styles.js +11 -0
- package/dist/webchat/widget-styles.js.map +1 -0
- package/package.json +5 -4
- package/src/cli/services/builtin-skills/verify.md +72 -0
- package/vendor/ink/build/ink.js +33 -10
- package/vendor/ink/build/log-update.js +11 -4
|
@@ -0,0 +1,192 @@
|
|
|
1
|
+
// workflow-steps-engine-persist.ts — persistStepResult, retry logic, checkpoint creation
|
|
2
|
+
// Split from workflow-steps-engine-execute.ts for single-responsibility.
|
|
3
|
+
|
|
4
|
+
import { queueSpan, auditRowToSpan, classifyErrorType } from "../lib/clickhouse-buffer.js";
|
|
5
|
+
import { log, logWorkflowEvent, surfaceStepError } from "./workflow-steps-types.js";
|
|
6
|
+
import { createNextStepRunByKey } from "./workflow-steps-advancement.js";
|
|
7
|
+
import { checkWorkflowCompletion, completeWorkflowRun } from "./workflow-steps-completion.js";
|
|
8
|
+
|
|
9
|
+
/** Persist step result, accumulate output, handle retries, and advance the workflow. */
|
|
10
|
+
export async function persistStepResult(supabase, step, result, startTime, span, traceId) {
|
|
11
|
+
const durationMs = Date.now() - startTime;
|
|
12
|
+
if (result.success) {
|
|
13
|
+
span.end({
|
|
14
|
+
"workflow.duration_ms": durationMs,
|
|
15
|
+
"workflow.status": "success"
|
|
16
|
+
});
|
|
17
|
+
} else {
|
|
18
|
+
span.setError(result.error || "step failed");
|
|
19
|
+
span.end({
|
|
20
|
+
"workflow.duration_ms": durationMs,
|
|
21
|
+
"workflow.status": "failed"
|
|
22
|
+
});
|
|
23
|
+
}
|
|
24
|
+
await logWorkflowEvent(supabase, step.run_id, result.success ? "step_completed" : "step_failed", {
|
|
25
|
+
step_key: step.step_key,
|
|
26
|
+
duration_ms: durationMs,
|
|
27
|
+
...(result.error ? {
|
|
28
|
+
error: result.error
|
|
29
|
+
} : {}),
|
|
30
|
+
...(result.branch ? {
|
|
31
|
+
branch: result.branch
|
|
32
|
+
} : {})
|
|
33
|
+
}, step.step_run_id);
|
|
34
|
+
await supabase.from("workflow_step_runs").update({
|
|
35
|
+
status: result.success ? "success" : "failed",
|
|
36
|
+
output: result.output || null,
|
|
37
|
+
error_message: result.error || null,
|
|
38
|
+
completed_at: new Date().toISOString(),
|
|
39
|
+
duration_ms: durationMs
|
|
40
|
+
}).eq("id", step.step_run_id);
|
|
41
|
+
const stepOutput = {
|
|
42
|
+
output: result.output,
|
|
43
|
+
status: result.success ? "success" : "failed",
|
|
44
|
+
duration_ms: durationMs
|
|
45
|
+
};
|
|
46
|
+
const {
|
|
47
|
+
error: rpcError
|
|
48
|
+
} = await supabase.rpc("accumulate_step_output", {
|
|
49
|
+
p_run_id: step.run_id,
|
|
50
|
+
p_step_key: step.step_key,
|
|
51
|
+
p_step_output: stepOutput
|
|
52
|
+
});
|
|
53
|
+
if (rpcError) {
|
|
54
|
+
log.warn({
|
|
55
|
+
err: rpcError.message,
|
|
56
|
+
runId: step.run_id,
|
|
57
|
+
stepKey: step.step_key
|
|
58
|
+
}, "accumulate_step_output RPC error, retrying once");
|
|
59
|
+
const {
|
|
60
|
+
error: retryError
|
|
61
|
+
} = await supabase.rpc("accumulate_step_output", {
|
|
62
|
+
p_run_id: step.run_id,
|
|
63
|
+
p_step_key: step.step_key,
|
|
64
|
+
p_step_output: stepOutput
|
|
65
|
+
});
|
|
66
|
+
if (retryError) {
|
|
67
|
+
log.warn({
|
|
68
|
+
err: retryError.message
|
|
69
|
+
}, "accumulate_step_output retry failed, using locked fallback");
|
|
70
|
+
const {
|
|
71
|
+
error: lockError
|
|
72
|
+
} = await supabase.rpc("accumulate_step_output_locked", {
|
|
73
|
+
p_run_id: step.run_id,
|
|
74
|
+
p_step_key: step.step_key,
|
|
75
|
+
p_step_output: stepOutput
|
|
76
|
+
});
|
|
77
|
+
if (lockError) throw new Error(`Failed to accumulate step output after all fallbacks: ${lockError.message}`);
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
if (result.success) {
|
|
81
|
+
await supabase.from("workflow_checkpoints").insert({
|
|
82
|
+
run_id: step.run_id,
|
|
83
|
+
step_run_id: step.step_run_id,
|
|
84
|
+
step_key: step.step_key,
|
|
85
|
+
step_outputs: {
|
|
86
|
+
...(step.step_outputs || {}),
|
|
87
|
+
[step.step_key]: {
|
|
88
|
+
output: result.output,
|
|
89
|
+
status: "success",
|
|
90
|
+
duration_ms: durationMs
|
|
91
|
+
}
|
|
92
|
+
},
|
|
93
|
+
trigger_payload: step.trigger_payload,
|
|
94
|
+
sequence_number: Object.keys(step.step_outputs || {}).length + 1
|
|
95
|
+
}).then(({
|
|
96
|
+
error: cpError
|
|
97
|
+
}) => {
|
|
98
|
+
if (cpError) log.warn({
|
|
99
|
+
err: cpError.message
|
|
100
|
+
}, "checkpoint insert failed");
|
|
101
|
+
});
|
|
102
|
+
}
|
|
103
|
+
queueSpan(auditRowToSpan({
|
|
104
|
+
action: `workflow.step.${result.success ? "completed" : "failed"}`,
|
|
105
|
+
severity: result.success ? "info" : "error",
|
|
106
|
+
store_id: step.store_id,
|
|
107
|
+
resource_type: "workflow_step_run",
|
|
108
|
+
resource_id: step.step_run_id,
|
|
109
|
+
source: "workflow_engine",
|
|
110
|
+
duration_ms: durationMs,
|
|
111
|
+
request_id: traceId || null,
|
|
112
|
+
service_name: "workflow-engine",
|
|
113
|
+
span_kind: "INTERNAL",
|
|
114
|
+
status_code: result.success ? "OK" : "ERROR",
|
|
115
|
+
start_time: new Date(Date.now() - durationMs).toISOString(),
|
|
116
|
+
end_time: new Date().toISOString(),
|
|
117
|
+
error_type: result.error ? classifyErrorType(result.error) : undefined,
|
|
118
|
+
details: {
|
|
119
|
+
workflow_id: step.workflow_id,
|
|
120
|
+
run_id: step.run_id,
|
|
121
|
+
step_key: step.step_key,
|
|
122
|
+
step_type: step.step_type,
|
|
123
|
+
attempt: step.attempt_count
|
|
124
|
+
},
|
|
125
|
+
error_message: result.error || null
|
|
126
|
+
}));
|
|
127
|
+
if (!result.success && result.error) await surfaceStepError(supabase, step, result.error);
|
|
128
|
+
if (step.parent_step_run_id) {
|
|
129
|
+
if (!result.success && step.attempt_count < step.max_attempts) {
|
|
130
|
+
const backoffDelay = computeBackoff(step);
|
|
131
|
+
await supabase.from("workflow_step_runs").update({
|
|
132
|
+
status: "retrying",
|
|
133
|
+
next_retry_at: new Date(Date.now() + backoffDelay * 1000).toISOString()
|
|
134
|
+
}).eq("id", step.step_run_id);
|
|
135
|
+
}
|
|
136
|
+
return;
|
|
137
|
+
}
|
|
138
|
+
if (!result.success) {
|
|
139
|
+
if (step.attempt_count < step.max_attempts) {
|
|
140
|
+
const retryPolicy = step.step_config.retry_policy;
|
|
141
|
+
const retryOn = retryPolicy?.retry_on;
|
|
142
|
+
const shouldRetry = !retryOn?.length || retryOn.some(pattern => result.error?.includes(pattern));
|
|
143
|
+
if (shouldRetry) {
|
|
144
|
+
const backoffDelay = computeBackoff(step);
|
|
145
|
+
await supabase.from("workflow_step_runs").update({
|
|
146
|
+
status: "retrying",
|
|
147
|
+
next_retry_at: new Date(Date.now() + backoffDelay * 1000).toISOString()
|
|
148
|
+
}).eq("id", step.step_run_id);
|
|
149
|
+
await logWorkflowEvent(supabase, step.run_id, "step_retrying", {
|
|
150
|
+
step_key: step.step_key,
|
|
151
|
+
attempt: step.attempt_count,
|
|
152
|
+
delay_seconds: backoffDelay
|
|
153
|
+
}, step.step_run_id);
|
|
154
|
+
return;
|
|
155
|
+
}
|
|
156
|
+
}
|
|
157
|
+
if (step.on_failure) {
|
|
158
|
+
await createNextStepRunByKey(supabase, step.run_id, step.workflow_id, step.on_failure);
|
|
159
|
+
} else {
|
|
160
|
+
await completeWorkflowRun(supabase, step.run_id, step.workflow_id, step.store_id, "failed", result.error, step.step_key);
|
|
161
|
+
}
|
|
162
|
+
return;
|
|
163
|
+
}
|
|
164
|
+
const nextStepKey = result.branch || step.on_success;
|
|
165
|
+
if (!nextStepKey) {
|
|
166
|
+
await checkWorkflowCompletion(supabase, step.run_id, step.workflow_id);
|
|
167
|
+
return;
|
|
168
|
+
}
|
|
169
|
+
await createNextStepRunByKey(supabase, step.run_id, step.workflow_id, nextStepKey);
|
|
170
|
+
}
|
|
171
|
+
|
|
172
|
+
/** Compute backoff delay with jitter for retry. */
|
|
173
|
+
function computeBackoff(step) {
|
|
174
|
+
const retryPolicy = step.step_config.retry_policy;
|
|
175
|
+
const backoffType = retryPolicy?.backoff_type || "exponential";
|
|
176
|
+
const baseDelay = retryPolicy?.backoff_base_seconds || step.retry_delay_seconds || 10;
|
|
177
|
+
const maxBackoff = retryPolicy?.max_backoff_seconds || 300;
|
|
178
|
+
let backoffDelay;
|
|
179
|
+
switch (backoffType) {
|
|
180
|
+
case "fixed":
|
|
181
|
+
backoffDelay = baseDelay;
|
|
182
|
+
break;
|
|
183
|
+
case "linear":
|
|
184
|
+
backoffDelay = baseDelay * step.attempt_count;
|
|
185
|
+
break;
|
|
186
|
+
default:
|
|
187
|
+
backoffDelay = baseDelay * Math.pow(2, step.attempt_count - 1);
|
|
188
|
+
break;
|
|
189
|
+
}
|
|
190
|
+
return Math.min(backoffDelay, maxBackoff) * (0.5 + Math.random() * 0.5);
|
|
191
|
+
}
|
|
192
|
+
//# sourceMappingURL=workflow-steps-engine-persist.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"workflow-steps-engine-persist.js","names":["queueSpan","auditRowToSpan","classifyErrorType","log","logWorkflowEvent","surfaceStepError","createNextStepRunByKey","checkWorkflowCompletion","completeWorkflowRun","persistStepResult","supabase","step","result","startTime","span","traceId","durationMs","Date","now","success","end","setError","error","run_id","step_key","duration_ms","branch","step_run_id","from","update","status","output","error_message","completed_at","toISOString","eq","stepOutput","rpcError","rpc","p_run_id","p_step_key","p_step_output","warn","err","message","runId","stepKey","retryError","lockError","Error","insert","step_outputs","trigger_payload","sequence_number","Object","keys","length","then","cpError","action","severity","store_id","resource_type","resource_id","source","request_id","service_name","span_kind","status_code","start_time","end_time","error_type","undefined","details","workflow_id","step_type","attempt","attempt_count","parent_step_run_id","max_attempts","backoffDelay","computeBackoff","next_retry_at","retryPolicy","step_config","retry_policy","retryOn","retry_on","shouldRetry","some","pattern","includes","delay_seconds","on_failure","nextStepKey","on_success","backoffType","backoff_type","baseDelay","backoff_base_seconds","retry_delay_seconds","maxBackoff","max_backoff_seconds","Math","pow","min","random"],"sources":["../../../src/server/handlers/workflow-steps-engine-persist.ts"],"sourcesContent":["// workflow-steps-engine-persist.ts — persistStepResult, retry logic, checkpoint creation\n// Split from workflow-steps-engine-execute.ts for single-responsibility.\n\nimport type { SupabaseClient } from \"@supabase/supabase-js\";\nimport type { startSpan } from \"../lib/otel.js\";\nimport { queueSpan, auditRowToSpan, classifyErrorType } from \"../lib/clickhouse-buffer.js\";\nimport {\n log, type StepClaim, type StepResult,\n logWorkflowEvent, surfaceStepError,\n} from \"./workflow-steps-types.js\";\nimport { createNextStepRunByKey } from \"./workflow-steps-advancement.js\";\nimport { checkWorkflowCompletion, completeWorkflowRun } from \"./workflow-steps-completion.js\";\n\n/** Persist step result, accumulate output, handle retries, and advance the workflow. */\nexport async function persistStepResult(\n supabase: SupabaseClient, step: StepClaim, result: StepResult,\n startTime: number, span: ReturnType<typeof startSpan>, traceId?: string,\n): Promise<void> {\n const durationMs = Date.now() - startTime;\n\n if (result.success) { span.end({ \"workflow.duration_ms\": durationMs, \"workflow.status\": \"success\" }); }\n else { span.setError(result.error || \"step failed\"); span.end({ \"workflow.duration_ms\": durationMs, \"workflow.status\": \"failed\" }); }\n\n await logWorkflowEvent(supabase, step.run_id, result.success ? \"step_completed\" : \"step_failed\", {\n step_key: step.step_key, duration_ms: durationMs,\n ...(result.error ? { error: result.error } : {}),\n ...(result.branch ? { branch: result.branch } : {}),\n }, step.step_run_id);\n\n await supabase.from(\"workflow_step_runs\").update({\n status: result.success ? \"success\" : \"failed\",\n output: result.output || null, error_message: result.error || null,\n completed_at: new Date().toISOString(), duration_ms: durationMs,\n }).eq(\"id\", step.step_run_id);\n\n const stepOutput = { output: result.output, status: result.success ? \"success\" : \"failed\", duration_ms: durationMs };\n const { error: rpcError } = await supabase.rpc(\"accumulate_step_output\", { p_run_id: step.run_id, p_step_key: step.step_key, p_step_output: stepOutput });\n if (rpcError) {\n log.warn({ err: rpcError.message, runId: step.run_id, stepKey: step.step_key }, \"accumulate_step_output RPC error, retrying once\");\n const { error: retryError } = await supabase.rpc(\"accumulate_step_output\", { p_run_id: step.run_id, p_step_key: step.step_key, p_step_output: stepOutput });\n if (retryError) {\n log.warn({ err: retryError.message }, \"accumulate_step_output retry failed, using locked fallback\");\n const { error: lockError } = await supabase.rpc(\"accumulate_step_output_locked\", { p_run_id: step.run_id, p_step_key: step.step_key, p_step_output: stepOutput });\n if (lockError) throw new Error(`Failed to accumulate step output after all fallbacks: ${lockError.message}`);\n }\n }\n\n if (result.success) {\n await supabase.from(\"workflow_checkpoints\").insert({\n run_id: step.run_id, step_run_id: step.step_run_id, step_key: step.step_key,\n step_outputs: { ...(step.step_outputs || {}), [step.step_key]: { output: result.output, status: \"success\", duration_ms: durationMs } },\n trigger_payload: step.trigger_payload, sequence_number: Object.keys(step.step_outputs || {}).length + 1,\n }).then(({ error: cpError }) => { if (cpError) log.warn({ err: cpError.message }, \"checkpoint insert failed\"); });\n }\n\n queueSpan(auditRowToSpan({\n action: `workflow.step.${result.success ? \"completed\" : \"failed\"}`,\n severity: result.success ? \"info\" : \"error\",\n store_id: step.store_id, resource_type: \"workflow_step_run\",\n resource_id: step.step_run_id, source: \"workflow_engine\", duration_ms: durationMs,\n request_id: traceId || null, service_name: \"workflow-engine\", span_kind: \"INTERNAL\",\n status_code: result.success ? \"OK\" : \"ERROR\",\n start_time: new Date(Date.now() - durationMs).toISOString(), end_time: new Date().toISOString(),\n error_type: result.error ? classifyErrorType(result.error) : undefined,\n details: { workflow_id: step.workflow_id, run_id: step.run_id, step_key: step.step_key, step_type: step.step_type, attempt: step.attempt_count },\n error_message: result.error || null,\n }));\n\n if (!result.success && result.error) await surfaceStepError(supabase, step, result.error);\n\n if (step.parent_step_run_id) {\n if (!result.success && step.attempt_count < step.max_attempts) {\n const backoffDelay = computeBackoff(step);\n await supabase.from(\"workflow_step_runs\").update({ status: \"retrying\", next_retry_at: new Date(Date.now() + backoffDelay * 1000).toISOString() }).eq(\"id\", step.step_run_id);\n }\n return;\n }\n\n if (!result.success) {\n if (step.attempt_count < step.max_attempts) {\n const retryPolicy = step.step_config.retry_policy as { backoff_type?: string; backoff_base_seconds?: number; max_backoff_seconds?: number; retry_on?: string[] } | undefined;\n const retryOn = retryPolicy?.retry_on;\n const shouldRetry = !retryOn?.length || retryOn.some(pattern => result.error?.includes(pattern));\n if (shouldRetry) {\n const backoffDelay = computeBackoff(step);\n await supabase.from(\"workflow_step_runs\").update({ status: \"retrying\", next_retry_at: new Date(Date.now() + backoffDelay * 1000).toISOString() }).eq(\"id\", step.step_run_id);\n await logWorkflowEvent(supabase, step.run_id, \"step_retrying\", { step_key: step.step_key, attempt: step.attempt_count, delay_seconds: backoffDelay }, step.step_run_id);\n return;\n }\n }\n if (step.on_failure) { await createNextStepRunByKey(supabase, step.run_id, step.workflow_id, step.on_failure); }\n else { await completeWorkflowRun(supabase, step.run_id, step.workflow_id, step.store_id, \"failed\", result.error, step.step_key); }\n return;\n }\n\n const nextStepKey = result.branch || step.on_success;\n if (!nextStepKey) { await checkWorkflowCompletion(supabase, step.run_id, step.workflow_id); return; }\n await createNextStepRunByKey(supabase, step.run_id, step.workflow_id, nextStepKey);\n}\n\n/** Compute backoff delay with jitter for retry. */\nfunction computeBackoff(step: StepClaim): number {\n const retryPolicy = step.step_config.retry_policy as { backoff_type?: string; backoff_base_seconds?: number; max_backoff_seconds?: number } | undefined;\n const backoffType = retryPolicy?.backoff_type || \"exponential\";\n const baseDelay = retryPolicy?.backoff_base_seconds || step.retry_delay_seconds || 10;\n const maxBackoff = retryPolicy?.max_backoff_seconds || 300;\n let backoffDelay: number;\n switch (backoffType) { case \"fixed\": backoffDelay = baseDelay; break; case \"linear\": backoffDelay = baseDelay * step.attempt_count; break; default: backoffDelay = baseDelay * Math.pow(2, step.attempt_count - 1); break; }\n return Math.min(backoffDelay, maxBackoff) * (0.5 + Math.random() * 0.5);\n}\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { SupabaseClient } from "@supabase/supabase-js";
|
|
2
|
+
export declare function processWorkflowSteps(supabase: SupabaseClient, batchSize?: number): Promise<{
|
|
3
|
+
processed: number;
|
|
4
|
+
errors: number;
|
|
5
|
+
reclaimed?: number;
|
|
6
|
+
}>;
|
|
7
|
+
export declare function processWaitingSteps(supabase: SupabaseClient): Promise<number>;
|
|
@@ -0,0 +1,290 @@
|
|
|
1
|
+
// workflow-steps-engine-process.ts — processWorkflowSteps and processWaitingSteps
|
|
2
|
+
// Split from workflow-steps-engine.ts for single-responsibility.
|
|
3
|
+
|
|
4
|
+
import { sanitizeError } from "../../shared/agent-core.js";
|
|
5
|
+
import { log, surfaceStepError } from "./workflow-steps-types.js";
|
|
6
|
+
import { applyVersionOverrides } from "./workflow-steps-advancement.js";
|
|
7
|
+
import { accumulateAndAdvance } from "./workflow-steps-advancement.js";
|
|
8
|
+
import { checkWorkflowCompletion } from "./workflow-steps-completion.js";
|
|
9
|
+
import { executeAndAdvance } from "./workflow-steps-engine-execute.js";
|
|
10
|
+
|
|
11
|
+
// ============================================================================
|
|
12
|
+
// RECLAIM STALE STEPS
|
|
13
|
+
// ============================================================================
|
|
14
|
+
|
|
15
|
+
async function reclaimStaleSteps(supabase) {
|
|
16
|
+
const MIN_STALE_THRESHOLD_MS = 300_000;
|
|
17
|
+
const MAX_STALE_AGE_MS = 1_200_000;
|
|
18
|
+
const {
|
|
19
|
+
data: staleSteps
|
|
20
|
+
} = await supabase.from("workflow_step_runs").select(`id, step_key, run_id, attempt_count, max_attempts, started_at, workflow_steps!inner(timeout_seconds)`).eq("status", "running").not("started_at", "is", null).limit(50);
|
|
21
|
+
if (!staleSteps?.length) return 0;
|
|
22
|
+
let reclaimed = 0;
|
|
23
|
+
const now = Date.now();
|
|
24
|
+
for (const step of staleSteps) {
|
|
25
|
+
const timeoutSec = step.workflow_steps?.timeout_seconds || 120;
|
|
26
|
+
const staleThreshold = Math.min(Math.max(MIN_STALE_THRESHOLD_MS, timeoutSec * 2000), MAX_STALE_AGE_MS);
|
|
27
|
+
const elapsed = now - new Date(step.started_at).getTime();
|
|
28
|
+
if (elapsed < staleThreshold) continue;
|
|
29
|
+
const exhaustedRetries = step.attempt_count >= step.max_attempts;
|
|
30
|
+
if (exhaustedRetries) {
|
|
31
|
+
await supabase.from("workflow_step_runs").update({
|
|
32
|
+
status: "failed",
|
|
33
|
+
error_message: `Step stale: running for ${Math.round(elapsed / 1000)}s with no response (retries exhausted)`,
|
|
34
|
+
completed_at: new Date().toISOString()
|
|
35
|
+
}).eq("id", step.id);
|
|
36
|
+
} else {
|
|
37
|
+
await supabase.from("workflow_step_runs").update({
|
|
38
|
+
status: "retrying",
|
|
39
|
+
error_message: `Step stale: running for ${Math.round(elapsed / 1000)}s with no response (auto-reclaimed)`,
|
|
40
|
+
next_retry_at: new Date(now + 5000).toISOString()
|
|
41
|
+
}).eq("id", step.id);
|
|
42
|
+
}
|
|
43
|
+
reclaimed++;
|
|
44
|
+
log.warn({
|
|
45
|
+
stepRunId: step.id,
|
|
46
|
+
stepKey: step.step_key,
|
|
47
|
+
runId: step.run_id,
|
|
48
|
+
elapsedSec: Math.round(elapsed / 1000),
|
|
49
|
+
exhaustedRetries
|
|
50
|
+
}, "reclaimed stale step");
|
|
51
|
+
}
|
|
52
|
+
return reclaimed;
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
// ============================================================================
|
|
56
|
+
// processWorkflowSteps — main worker loop entry point
|
|
57
|
+
// ============================================================================
|
|
58
|
+
|
|
59
|
+
export async function processWorkflowSteps(supabase, batchSize = 10) {
|
|
60
|
+
const reclaimed = await reclaimStaleSteps(supabase).catch(e => {
|
|
61
|
+
log.warn({
|
|
62
|
+
err: e.message
|
|
63
|
+
}, "reclaimStaleSteps failed");
|
|
64
|
+
return 0;
|
|
65
|
+
});
|
|
66
|
+
const {
|
|
67
|
+
data: claimedRaw,
|
|
68
|
+
error: claimErr
|
|
69
|
+
} = await supabase.rpc("claim_pending_steps", {
|
|
70
|
+
batch_size: batchSize
|
|
71
|
+
});
|
|
72
|
+
if (claimErr) {
|
|
73
|
+
log.error({
|
|
74
|
+
err: claimErr.message
|
|
75
|
+
}, "workflow claim error");
|
|
76
|
+
return {
|
|
77
|
+
processed: 0,
|
|
78
|
+
errors: 1,
|
|
79
|
+
reclaimed
|
|
80
|
+
};
|
|
81
|
+
}
|
|
82
|
+
let claimed = Array.isArray(claimedRaw) ? claimedRaw : [];
|
|
83
|
+
if (claimed.length === 0) return {
|
|
84
|
+
processed: 0,
|
|
85
|
+
errors: 0,
|
|
86
|
+
reclaimed
|
|
87
|
+
};
|
|
88
|
+
|
|
89
|
+
// Circuit breaker enforcement
|
|
90
|
+
const workflowIds = [...new Set(claimed.map(s => s.workflow_id))];
|
|
91
|
+
const {
|
|
92
|
+
data: openBreakers
|
|
93
|
+
} = await supabase.from("workflows").select("id").in("id", workflowIds).eq("circuit_breaker_state", "open");
|
|
94
|
+
if (openBreakers?.length) {
|
|
95
|
+
const blockedIds = new Set(openBreakers.map(w => w.id));
|
|
96
|
+
const blocked = claimed.filter(s => blockedIds.has(s.workflow_id));
|
|
97
|
+
claimed = claimed.filter(s => !blockedIds.has(s.workflow_id));
|
|
98
|
+
const affectedRuns = new Map();
|
|
99
|
+
for (const step of blocked) {
|
|
100
|
+
await supabase.from("workflow_step_runs").update({
|
|
101
|
+
status: "skipped",
|
|
102
|
+
error_message: "Workflow circuit breaker is open — step skipped",
|
|
103
|
+
completed_at: new Date().toISOString()
|
|
104
|
+
}).eq("id", step.step_run_id);
|
|
105
|
+
affectedRuns.set(step.run_id, step.workflow_id);
|
|
106
|
+
}
|
|
107
|
+
for (const [runId, workflowId] of affectedRuns) {
|
|
108
|
+
await checkWorkflowCompletion(supabase, runId, workflowId).catch(e => log.warn({
|
|
109
|
+
runId,
|
|
110
|
+
err: e.message
|
|
111
|
+
}, "completion check after circuit breaker skip failed"));
|
|
112
|
+
}
|
|
113
|
+
if (blocked.length) log.warn({
|
|
114
|
+
skippedSteps: blocked.length,
|
|
115
|
+
blockedWorkflows: blockedIds.size
|
|
116
|
+
}, "circuit breaker skipped steps");
|
|
117
|
+
if (claimed.length === 0) return {
|
|
118
|
+
processed: blocked.length,
|
|
119
|
+
errors: 0,
|
|
120
|
+
reclaimed
|
|
121
|
+
};
|
|
122
|
+
}
|
|
123
|
+
log.info({
|
|
124
|
+
stepCount: claimed.length
|
|
125
|
+
}, "processing workflow steps");
|
|
126
|
+
let errors = 0;
|
|
127
|
+
const runIds = [...new Set(claimed.map(s => s.run_id))];
|
|
128
|
+
const {
|
|
129
|
+
data: runTraces
|
|
130
|
+
} = await supabase.from("workflow_runs").select("id, trace_id").in("id", runIds);
|
|
131
|
+
const traceMap = new Map((runTraces || []).map(r => [r.id, r.trace_id]));
|
|
132
|
+
const isForEachEmailStep = s => s.parent_step_run_id && s.step_type === "tool" && String(s.step_config?.tool_name || "").includes("email");
|
|
133
|
+
const emailForEachSteps = claimed.filter(isForEachEmailStep);
|
|
134
|
+
const otherSteps = claimed.filter(s => !isForEachEmailStep(s));
|
|
135
|
+
const processStep = async step => {
|
|
136
|
+
try {
|
|
137
|
+
await applyVersionOverrides(supabase, step);
|
|
138
|
+
await executeAndAdvance(supabase, step, traceMap.get(step.run_id));
|
|
139
|
+
} catch (err) {
|
|
140
|
+
errors++;
|
|
141
|
+
const errMsg = sanitizeError(err);
|
|
142
|
+
log.error({
|
|
143
|
+
stepKey: step.step_key,
|
|
144
|
+
runId: step.run_id,
|
|
145
|
+
err: errMsg
|
|
146
|
+
}, "step execution error");
|
|
147
|
+
await supabase.from("workflow_step_runs").update({
|
|
148
|
+
status: "failed",
|
|
149
|
+
error_message: errMsg,
|
|
150
|
+
completed_at: new Date().toISOString(),
|
|
151
|
+
duration_ms: 0
|
|
152
|
+
}).eq("id", step.step_run_id);
|
|
153
|
+
await surfaceStepError(supabase, step, errMsg);
|
|
154
|
+
await checkWorkflowCompletion(supabase, step.run_id, step.workflow_id).catch(e => log.warn({
|
|
155
|
+
runId: step.run_id,
|
|
156
|
+
err: e.message
|
|
157
|
+
}, "completion check after step error failed"));
|
|
158
|
+
}
|
|
159
|
+
};
|
|
160
|
+
await Promise.all(otherSteps.map(processStep));
|
|
161
|
+
for (let i = 0; i < emailForEachSteps.length; i++) {
|
|
162
|
+
if (i > 0) await new Promise(r => setTimeout(r, 550));
|
|
163
|
+
await processStep(emailForEachSteps[i]);
|
|
164
|
+
}
|
|
165
|
+
return {
|
|
166
|
+
processed: claimed.length,
|
|
167
|
+
errors
|
|
168
|
+
};
|
|
169
|
+
}
|
|
170
|
+
|
|
171
|
+
// ============================================================================
|
|
172
|
+
// processWaitingSteps
|
|
173
|
+
// ============================================================================
|
|
174
|
+
|
|
175
|
+
export async function processWaitingSteps(supabase) {
|
|
176
|
+
let resolved = 0;
|
|
177
|
+
try {
|
|
178
|
+
await supabase.rpc("expire_pending_approvals");
|
|
179
|
+
} catch (err) {
|
|
180
|
+
log.warn({
|
|
181
|
+
err: sanitizeError(err)
|
|
182
|
+
}, "expire_pending_approvals error");
|
|
183
|
+
}
|
|
184
|
+
|
|
185
|
+
// 1. Sub-workflow steps
|
|
186
|
+
const {
|
|
187
|
+
data: subWfSteps
|
|
188
|
+
} = await supabase.from("workflow_step_runs").select("id, run_id, step_key, child_run_id, step_type").eq("status", "waiting").eq("step_type", "sub_workflow").not("child_run_id", "is", null).limit(50);
|
|
189
|
+
if (subWfSteps?.length) {
|
|
190
|
+
const childRunIds = subWfSteps.map(s => s.child_run_id).filter(Boolean);
|
|
191
|
+
const {
|
|
192
|
+
data: childRuns
|
|
193
|
+
} = await supabase.from("workflow_runs").select("id, status, step_outputs, error_message").in("id", childRunIds).in("status", ["success", "failed"]);
|
|
194
|
+
if (childRuns?.length) {
|
|
195
|
+
const runMap = new Map(childRuns.map(r => [r.id, r]));
|
|
196
|
+
for (const step of subWfSteps) {
|
|
197
|
+
const childRun = runMap.get(step.child_run_id);
|
|
198
|
+
if (!childRun) continue;
|
|
199
|
+
const success = childRun.status === "success";
|
|
200
|
+
await supabase.from("workflow_step_runs").update({
|
|
201
|
+
status: success ? "success" : "failed",
|
|
202
|
+
output: childRun.step_outputs,
|
|
203
|
+
error_message: success ? null : childRun.error_message,
|
|
204
|
+
completed_at: new Date().toISOString()
|
|
205
|
+
}).eq("id", step.id);
|
|
206
|
+
await accumulateAndAdvance(supabase, step.id, step.run_id, step.step_key, success, childRun.step_outputs, childRun.error_message);
|
|
207
|
+
resolved++;
|
|
208
|
+
}
|
|
209
|
+
}
|
|
210
|
+
}
|
|
211
|
+
|
|
212
|
+
// 2. Parallel/for_each parents
|
|
213
|
+
const {
|
|
214
|
+
data: aggregatedParents,
|
|
215
|
+
error: aggErr
|
|
216
|
+
} = await supabase.rpc("get_waiting_parents_with_children");
|
|
217
|
+
if (aggErr) {
|
|
218
|
+
log.debug({
|
|
219
|
+
err: aggErr.message
|
|
220
|
+
}, "get_waiting_parents_with_children RPC unavailable, using fallback");
|
|
221
|
+
const {
|
|
222
|
+
data: waitingParents
|
|
223
|
+
} = await supabase.from("workflow_step_runs").select("id, run_id, step_key, step_type, output").eq("status", "waiting").in("step_type", ["parallel", "for_each"]).limit(50);
|
|
224
|
+
if (waitingParents?.length) {
|
|
225
|
+
for (const parent of waitingParents) {
|
|
226
|
+
const {
|
|
227
|
+
count: totalChildren
|
|
228
|
+
} = await supabase.from("workflow_step_runs").select("id", {
|
|
229
|
+
count: "exact",
|
|
230
|
+
head: true
|
|
231
|
+
}).eq("parent_step_run_id", parent.id);
|
|
232
|
+
const {
|
|
233
|
+
count: doneChildren
|
|
234
|
+
} = await supabase.from("workflow_step_runs").select("id", {
|
|
235
|
+
count: "exact",
|
|
236
|
+
head: true
|
|
237
|
+
}).eq("parent_step_run_id", parent.id).in("status", ["success", "failed", "skipped", "cancelled"]);
|
|
238
|
+
if (totalChildren && doneChildren && doneChildren >= totalChildren) {
|
|
239
|
+
const {
|
|
240
|
+
data: childOutputs
|
|
241
|
+
} = await supabase.from("workflow_step_runs").select("step_key, output, status, error_message").eq("parent_step_run_id", parent.id).order("created_at", {
|
|
242
|
+
ascending: true
|
|
243
|
+
});
|
|
244
|
+
const outputs = (childOutputs || []).map(c => c.output);
|
|
245
|
+
const failedKids = (childOutputs || []).filter(c => c.status === "failed");
|
|
246
|
+
const allSuccess = failedKids.length === 0;
|
|
247
|
+
await supabase.from("workflow_step_runs").update({
|
|
248
|
+
status: allSuccess ? "success" : "failed",
|
|
249
|
+
output: {
|
|
250
|
+
children: outputs,
|
|
251
|
+
total: totalChildren,
|
|
252
|
+
failed: failedKids.length
|
|
253
|
+
},
|
|
254
|
+
error_message: allSuccess ? null : failedKids[0]?.error_message,
|
|
255
|
+
completed_at: new Date().toISOString()
|
|
256
|
+
}).eq("id", parent.id);
|
|
257
|
+
await accumulateAndAdvance(supabase, parent.id, parent.run_id, parent.step_key, allSuccess, {
|
|
258
|
+
children: outputs
|
|
259
|
+
}, allSuccess ? null : failedKids[0]?.error_message);
|
|
260
|
+
resolved++;
|
|
261
|
+
}
|
|
262
|
+
}
|
|
263
|
+
}
|
|
264
|
+
} else if (aggregatedParents?.length) {
|
|
265
|
+
for (const parent of aggregatedParents) {
|
|
266
|
+
if (parent.total_children > 0 && parent.done_children >= parent.total_children) {
|
|
267
|
+
const childOutputsArr = parent.child_outputs || [];
|
|
268
|
+
const outputs = childOutputsArr.map(c => c.output);
|
|
269
|
+
const allSuccess = parent.failed_children === 0;
|
|
270
|
+
const firstError = childOutputsArr.find(c => c.status === "failed")?.error_message;
|
|
271
|
+
await supabase.from("workflow_step_runs").update({
|
|
272
|
+
status: allSuccess ? "success" : "failed",
|
|
273
|
+
output: {
|
|
274
|
+
children: outputs,
|
|
275
|
+
total: parent.total_children,
|
|
276
|
+
failed: parent.failed_children
|
|
277
|
+
},
|
|
278
|
+
error_message: allSuccess ? null : firstError,
|
|
279
|
+
completed_at: new Date().toISOString()
|
|
280
|
+
}).eq("id", parent.parent_id);
|
|
281
|
+
await accumulateAndAdvance(supabase, parent.parent_id, parent.parent_run_id, parent.parent_step_key, allSuccess, {
|
|
282
|
+
children: outputs
|
|
283
|
+
}, allSuccess ? null : firstError);
|
|
284
|
+
resolved++;
|
|
285
|
+
}
|
|
286
|
+
}
|
|
287
|
+
}
|
|
288
|
+
return resolved;
|
|
289
|
+
}
|
|
290
|
+
//# sourceMappingURL=workflow-steps-engine-process.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"workflow-steps-engine-process.js","names":["sanitizeError","log","surfaceStepError","applyVersionOverrides","accumulateAndAdvance","checkWorkflowCompletion","executeAndAdvance","reclaimStaleSteps","supabase","MIN_STALE_THRESHOLD_MS","MAX_STALE_AGE_MS","data","staleSteps","from","select","eq","not","limit","length","reclaimed","now","Date","step","timeoutSec","workflow_steps","timeout_seconds","staleThreshold","Math","min","max","elapsed","started_at","getTime","exhaustedRetries","attempt_count","max_attempts","update","status","error_message","round","completed_at","toISOString","id","next_retry_at","warn","stepRunId","stepKey","step_key","runId","run_id","elapsedSec","processWorkflowSteps","batchSize","catch","e","err","message","claimedRaw","error","claimErr","rpc","batch_size","processed","errors","claimed","Array","isArray","workflowIds","Set","map","s","workflow_id","openBreakers","in","blockedIds","w","blocked","filter","has","affectedRuns","Map","step_run_id","set","workflowId","skippedSteps","blockedWorkflows","size","info","stepCount","runIds","runTraces","traceMap","r","trace_id","isForEachEmailStep","parent_step_run_id","step_type","String","step_config","tool_name","includes","emailForEachSteps","otherSteps","processStep","get","errMsg","duration_ms","Promise","all","i","setTimeout","processWaitingSteps","resolved","subWfSteps","childRunIds","child_run_id","Boolean","childRuns","runMap","childRun","success","output","step_outputs","aggregatedParents","aggErr","debug","waitingParents","parent","count","totalChildren","head","doneChildren","childOutputs","order","ascending","outputs","c","failedKids","allSuccess","children","total","failed","total_children","done_children","childOutputsArr","child_outputs","failed_children","firstError","find","parent_id","parent_run_id","parent_step_key"],"sources":["../../../src/server/handlers/workflow-steps-engine-process.ts"],"sourcesContent":["// workflow-steps-engine-process.ts — processWorkflowSteps and processWaitingSteps\n// Split from workflow-steps-engine.ts for single-responsibility.\n\nimport type { SupabaseClient } from \"@supabase/supabase-js\";\nimport { sanitizeError } from \"../../shared/agent-core.js\";\nimport {\n log, type StepClaim,\n surfaceStepError,\n} from \"./workflow-steps-types.js\";\nimport { applyVersionOverrides } from \"./workflow-steps-advancement.js\";\nimport { accumulateAndAdvance } from \"./workflow-steps-advancement.js\";\nimport { checkWorkflowCompletion } from \"./workflow-steps-completion.js\";\nimport { executeAndAdvance } from \"./workflow-steps-engine-execute.js\";\n\n// ============================================================================\n// RECLAIM STALE STEPS\n// ============================================================================\n\nasync function reclaimStaleSteps(supabase: SupabaseClient): Promise<number> {\n const MIN_STALE_THRESHOLD_MS = 300_000;\n const MAX_STALE_AGE_MS = 1_200_000;\n\n const { data: staleSteps } = await supabase.from(\"workflow_step_runs\")\n .select(`id, step_key, run_id, attempt_count, max_attempts, started_at, workflow_steps!inner(timeout_seconds)`)\n .eq(\"status\", \"running\")\n .not(\"started_at\", \"is\", null)\n .limit(50);\n\n if (!staleSteps?.length) return 0;\n\n let reclaimed = 0;\n const now = Date.now();\n\n for (const step of staleSteps) {\n const timeoutSec = (step as any).workflow_steps?.timeout_seconds || 120;\n const staleThreshold = Math.min(Math.max(MIN_STALE_THRESHOLD_MS, timeoutSec * 2000), MAX_STALE_AGE_MS);\n const elapsed = now - new Date(step.started_at).getTime();\n if (elapsed < staleThreshold) continue;\n\n const exhaustedRetries = step.attempt_count >= step.max_attempts;\n if (exhaustedRetries) {\n await supabase.from(\"workflow_step_runs\").update({\n status: \"failed\",\n error_message: `Step stale: running for ${Math.round(elapsed / 1000)}s with no response (retries exhausted)`,\n completed_at: new Date().toISOString(),\n }).eq(\"id\", step.id);\n } else {\n await supabase.from(\"workflow_step_runs\").update({\n status: \"retrying\",\n error_message: `Step stale: running for ${Math.round(elapsed / 1000)}s with no response (auto-reclaimed)`,\n next_retry_at: new Date(now + 5000).toISOString(),\n }).eq(\"id\", step.id);\n }\n reclaimed++;\n log.warn({ stepRunId: step.id, stepKey: step.step_key, runId: step.run_id, elapsedSec: Math.round(elapsed / 1000), exhaustedRetries }, \"reclaimed stale step\");\n }\n return reclaimed;\n}\n\n// ============================================================================\n// processWorkflowSteps — main worker loop entry point\n// ============================================================================\n\nexport async function processWorkflowSteps(\n supabase: SupabaseClient, batchSize: number = 10,\n): Promise<{ processed: number; errors: number; reclaimed?: number }> {\n const reclaimed = await reclaimStaleSteps(supabase).catch(e => {\n log.warn({ err: (e as Error).message }, \"reclaimStaleSteps failed\"); return 0;\n });\n\n const { data: claimedRaw, error: claimErr } = await supabase.rpc(\"claim_pending_steps\", { batch_size: batchSize });\n if (claimErr) {\n log.error({ err: claimErr.message }, \"workflow claim error\");\n return { processed: 0, errors: 1, reclaimed };\n }\n\n let claimed: StepClaim[] = Array.isArray(claimedRaw) ? claimedRaw : [];\n if (claimed.length === 0) return { processed: 0, errors: 0, reclaimed };\n\n // Circuit breaker enforcement\n const workflowIds = [...new Set(claimed.map(s => s.workflow_id))];\n const { data: openBreakers } = await supabase.from(\"workflows\")\n .select(\"id\").in(\"id\", workflowIds).eq(\"circuit_breaker_state\", \"open\");\n if (openBreakers?.length) {\n const blockedIds = new Set(openBreakers.map(w => w.id));\n const blocked = claimed.filter(s => blockedIds.has(s.workflow_id));\n claimed = claimed.filter(s => !blockedIds.has(s.workflow_id));\n const affectedRuns = new Map<string, string>();\n for (const step of blocked) {\n await supabase.from(\"workflow_step_runs\").update({\n status: \"skipped\", error_message: \"Workflow circuit breaker is open — step skipped\",\n completed_at: new Date().toISOString(),\n }).eq(\"id\", step.step_run_id);\n affectedRuns.set(step.run_id, step.workflow_id);\n }\n for (const [runId, workflowId] of affectedRuns) {\n await checkWorkflowCompletion(supabase, runId, workflowId).catch(e =>\n log.warn({ runId, err: (e as Error).message }, \"completion check after circuit breaker skip failed\"));\n }\n if (blocked.length) log.warn({ skippedSteps: blocked.length, blockedWorkflows: blockedIds.size }, \"circuit breaker skipped steps\");\n if (claimed.length === 0) return { processed: blocked.length, errors: 0, reclaimed };\n }\n\n log.info({ stepCount: claimed.length }, \"processing workflow steps\");\n let errors = 0;\n\n const runIds = [...new Set(claimed.map(s => s.run_id))];\n const { data: runTraces } = await supabase.from(\"workflow_runs\").select(\"id, trace_id\").in(\"id\", runIds);\n const traceMap = new Map((runTraces || []).map(r => [r.id, r.trace_id as string | undefined]));\n\n const isForEachEmailStep = (s: StepClaim) =>\n s.parent_step_run_id && s.step_type === \"tool\" &&\n String(s.step_config?.tool_name || \"\").includes(\"email\");\n\n const emailForEachSteps = claimed.filter(isForEachEmailStep);\n const otherSteps = claimed.filter(s => !isForEachEmailStep(s));\n\n const processStep = async (step: StepClaim) => {\n try {\n await applyVersionOverrides(supabase, step);\n await executeAndAdvance(supabase, step, traceMap.get(step.run_id));\n } catch (err) {\n errors++;\n const errMsg = sanitizeError(err);\n log.error({ stepKey: step.step_key, runId: step.run_id, err: errMsg }, \"step execution error\");\n await supabase.from(\"workflow_step_runs\").update({\n status: \"failed\", error_message: errMsg,\n completed_at: new Date().toISOString(), duration_ms: 0,\n }).eq(\"id\", step.step_run_id);\n await surfaceStepError(supabase, step, errMsg);\n await checkWorkflowCompletion(supabase, step.run_id, step.workflow_id).catch(e =>\n log.warn({ runId: step.run_id, err: (e as Error).message }, \"completion check after step error failed\"));\n }\n };\n\n await Promise.all(otherSteps.map(processStep));\n\n for (let i = 0; i < emailForEachSteps.length; i++) {\n if (i > 0) await new Promise(r => setTimeout(r, 550));\n await processStep(emailForEachSteps[i]);\n }\n\n return { processed: claimed.length, errors };\n}\n\n// ============================================================================\n// processWaitingSteps\n// ============================================================================\n\nexport async function processWaitingSteps(supabase: SupabaseClient): Promise<number> {\n let resolved = 0;\n\n try { await supabase.rpc(\"expire_pending_approvals\"); } catch (err) {\n log.warn({ err: sanitizeError(err) }, \"expire_pending_approvals error\");\n }\n\n // 1. Sub-workflow steps\n const { data: subWfSteps } = await supabase.from(\"workflow_step_runs\")\n .select(\"id, run_id, step_key, child_run_id, step_type\")\n .eq(\"status\", \"waiting\").eq(\"step_type\", \"sub_workflow\")\n .not(\"child_run_id\", \"is\", null).limit(50);\n\n if (subWfSteps?.length) {\n const childRunIds = subWfSteps.map(s => s.child_run_id).filter(Boolean) as string[];\n const { data: childRuns } = await supabase.from(\"workflow_runs\")\n .select(\"id, status, step_outputs, error_message\")\n .in(\"id\", childRunIds).in(\"status\", [\"success\", \"failed\"]);\n\n if (childRuns?.length) {\n const runMap = new Map(childRuns.map(r => [r.id, r]));\n for (const step of subWfSteps) {\n const childRun = runMap.get(step.child_run_id!);\n if (!childRun) continue;\n const success = childRun.status === \"success\";\n await supabase.from(\"workflow_step_runs\").update({\n status: success ? \"success\" : \"failed\",\n output: childRun.step_outputs,\n error_message: success ? null : childRun.error_message,\n completed_at: new Date().toISOString(),\n }).eq(\"id\", step.id);\n await accumulateAndAdvance(supabase, step.id, step.run_id, step.step_key,\n success, childRun.step_outputs, childRun.error_message);\n resolved++;\n }\n }\n }\n\n // 2. Parallel/for_each parents\n const { data: aggregatedParents, error: aggErr } = await supabase.rpc(\"get_waiting_parents_with_children\");\n\n if (aggErr) {\n log.debug({ err: aggErr.message }, \"get_waiting_parents_with_children RPC unavailable, using fallback\");\n const { data: waitingParents } = await supabase.from(\"workflow_step_runs\")\n .select(\"id, run_id, step_key, step_type, output\")\n .eq(\"status\", \"waiting\").in(\"step_type\", [\"parallel\", \"for_each\"]).limit(50);\n\n if (waitingParents?.length) {\n for (const parent of waitingParents) {\n const { count: totalChildren } = await supabase.from(\"workflow_step_runs\")\n .select(\"id\", { count: \"exact\", head: true }).eq(\"parent_step_run_id\", parent.id);\n const { count: doneChildren } = await supabase.from(\"workflow_step_runs\")\n .select(\"id\", { count: \"exact\", head: true }).eq(\"parent_step_run_id\", parent.id)\n .in(\"status\", [\"success\", \"failed\", \"skipped\", \"cancelled\"]);\n if (totalChildren && doneChildren && doneChildren >= totalChildren) {\n const { data: childOutputs } = await supabase.from(\"workflow_step_runs\")\n .select(\"step_key, output, status, error_message\")\n .eq(\"parent_step_run_id\", parent.id).order(\"created_at\", { ascending: true });\n const outputs = (childOutputs || []).map(c => c.output);\n const failedKids = (childOutputs || []).filter(c => c.status === \"failed\");\n const allSuccess = failedKids.length === 0;\n await supabase.from(\"workflow_step_runs\").update({\n status: allSuccess ? \"success\" : \"failed\",\n output: { children: outputs, total: totalChildren, failed: failedKids.length },\n error_message: allSuccess ? null : failedKids[0]?.error_message,\n completed_at: new Date().toISOString(),\n }).eq(\"id\", parent.id);\n await accumulateAndAdvance(supabase, parent.id, parent.run_id, parent.step_key,\n allSuccess, { children: outputs }, allSuccess ? null : failedKids[0]?.error_message);\n resolved++;\n }\n }\n }\n } else if (aggregatedParents?.length) {\n for (const parent of aggregatedParents) {\n if (parent.total_children > 0 && parent.done_children >= parent.total_children) {\n const childOutputsArr = (parent.child_outputs || []) as any[];\n const outputs = childOutputsArr.map((c: any) => c.output);\n const allSuccess = parent.failed_children === 0;\n const firstError = childOutputsArr.find((c: any) => c.status === \"failed\")?.error_message;\n await supabase.from(\"workflow_step_runs\").update({\n status: allSuccess ? \"success\" : \"failed\",\n output: { children: outputs, total: parent.total_children, failed: parent.failed_children },\n error_message: allSuccess ? null : firstError,\n completed_at: new Date().toISOString(),\n }).eq(\"id\", parent.parent_id);\n await accumulateAndAdvance(supabase, parent.parent_id, parent.parent_run_id, parent.parent_step_key,\n allSuccess, { children: outputs }, allSuccess ? null : firstError);\n resolved++;\n }\n }\n }\n\n return resolved;\n}\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
// workflow-steps-engine.ts — Re-export hub
|
|
2
|
+
// Split into:
|
|
3
|
+
// workflow-steps-engine-process.ts (processWorkflowSteps, processWaitingSteps)
|
|
4
|
+
// workflow-steps-engine-execute.ts (executeAndAdvance)
|
|
5
|
+
// workflow-steps-engine-inline.ts (executeInlineChain)
|
|
6
|
+
|
|
7
|
+
export { processWorkflowSteps, processWaitingSteps } from "./workflow-steps-engine-process.js";
|
|
8
|
+
export { executeAndAdvance } from "./workflow-steps-engine-execute.js";
|
|
9
|
+
export { executeInlineChain } from "./workflow-steps-engine-inline.js";
|
|
10
|
+
//# sourceMappingURL=workflow-steps-engine.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"workflow-steps-engine.js","names":["processWorkflowSteps","processWaitingSteps","executeAndAdvance","executeInlineChain"],"sources":["../../../src/server/handlers/workflow-steps-engine.ts"],"sourcesContent":["// workflow-steps-engine.ts — Re-export hub\n// Split into:\n// workflow-steps-engine-process.ts (processWorkflowSteps, processWaitingSteps)\n// workflow-steps-engine-execute.ts (executeAndAdvance)\n// workflow-steps-engine-inline.ts (executeInlineChain)\n\nexport { processWorkflowSteps, processWaitingSteps } from \"./workflow-steps-engine-process.js\";\nexport { executeAndAdvance } from \"./workflow-steps-engine-execute.js\";\nexport { executeInlineChain } from \"./workflow-steps-engine-inline.js\";\n"],"mappings":"AAAA;AACA;AACA;AACA;AACA;;AAEA,SAASA,oBAAoB,EAAEC,mBAAmB,QAAQ,oCAAoC;AAC9F,SAASC,iBAAiB,QAAQ,oCAAoC;AACtE,SAASC,kBAAkB,QAAQ,mCAAmC","ignoreList":[]}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { SupabaseClient } from "@supabase/supabase-js";
|
|
2
|
+
import { type TemplateContext } from "../lib/template-resolver.js";
|
|
3
|
+
import { type StepClaim, type StepResult } from "./workflow-steps-types.js";
|
|
4
|
+
export declare function executeAgentStep(config: Record<string, unknown>, ctx: TemplateContext, storeId: string, supabase: SupabaseClient, step?: StepClaim, traceId?: string): Promise<StepResult>;
|
|
5
|
+
export declare function executeLlmBatchStep(config: Record<string, unknown>, ctx: TemplateContext): Promise<StepResult>;
|
|
6
|
+
export declare function executeApprovalStep(supabase: SupabaseClient, step: StepClaim, ctx: TemplateContext): Promise<StepResult | "waiting">;
|
|
7
|
+
export declare function executeCodeStepIsolated(config: Record<string, unknown>, ctx: TemplateContext): Promise<StepResult>;
|