whale-code 6.5.6 → 6.5.8
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 +15 -3
- 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 +7 -5
- 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
- package/whale-logo.png +0 -0
|
@@ -0,0 +1,148 @@
|
|
|
1
|
+
import { describe, it, expect, vi } from "vitest";
|
|
2
|
+
// Mock child_process.spawn so commands are NOT actually executed.
|
|
3
|
+
// We only need to test the safety filter (blocked vs allowed), not run real commands.
|
|
4
|
+
vi.mock("child_process", async () => {
|
|
5
|
+
const actual = await vi.importActual("child_process");
|
|
6
|
+
return {
|
|
7
|
+
...actual,
|
|
8
|
+
spawn: vi.fn(() => {
|
|
9
|
+
// Return a fake child process that immediately exits with code 0
|
|
10
|
+
const {
|
|
11
|
+
EventEmitter
|
|
12
|
+
} = require("events");
|
|
13
|
+
const {
|
|
14
|
+
Readable
|
|
15
|
+
} = require("stream");
|
|
16
|
+
const child = new EventEmitter();
|
|
17
|
+
child.stdout = new Readable({
|
|
18
|
+
read() {
|
|
19
|
+
this.push(null);
|
|
20
|
+
}
|
|
21
|
+
});
|
|
22
|
+
child.stderr = new Readable({
|
|
23
|
+
read() {
|
|
24
|
+
this.push(null);
|
|
25
|
+
}
|
|
26
|
+
});
|
|
27
|
+
child.stdin = {
|
|
28
|
+
write: vi.fn(),
|
|
29
|
+
end: vi.fn()
|
|
30
|
+
};
|
|
31
|
+
child.pid = 99999;
|
|
32
|
+
child.kill = vi.fn();
|
|
33
|
+
// Emit close on next tick so the promise resolves
|
|
34
|
+
setTimeout(() => child.emit("exit", 0), 5);
|
|
35
|
+
return child;
|
|
36
|
+
})
|
|
37
|
+
};
|
|
38
|
+
});
|
|
39
|
+
vi.mock("../sandbox.js", () => ({
|
|
40
|
+
sandboxCommand: vi.fn(cmd => ({
|
|
41
|
+
wrapped: cmd,
|
|
42
|
+
profilePath: null
|
|
43
|
+
})),
|
|
44
|
+
cleanupSandbox: vi.fn()
|
|
45
|
+
}));
|
|
46
|
+
vi.mock("../background-processes.js", () => ({
|
|
47
|
+
spawnBackground: vi.fn(async () => ({
|
|
48
|
+
status: "running",
|
|
49
|
+
message: "ok"
|
|
50
|
+
})),
|
|
51
|
+
readProcessOutput: vi.fn(() => ({
|
|
52
|
+
status: "completed",
|
|
53
|
+
exitCode: 0,
|
|
54
|
+
newOutput: "ok",
|
|
55
|
+
newErrors: ""
|
|
56
|
+
})),
|
|
57
|
+
killProcess: vi.fn(() => ({
|
|
58
|
+
success: true,
|
|
59
|
+
message: "killed"
|
|
60
|
+
})),
|
|
61
|
+
listProcesses: vi.fn(() => [])
|
|
62
|
+
}));
|
|
63
|
+
vi.mock("../agent-events.js", () => ({
|
|
64
|
+
getGlobalEmitter: vi.fn(() => ({
|
|
65
|
+
emitToolOutput: vi.fn()
|
|
66
|
+
}))
|
|
67
|
+
}));
|
|
68
|
+
vi.mock("../debug-log.js", () => ({
|
|
69
|
+
debugLog: vi.fn()
|
|
70
|
+
}));
|
|
71
|
+
import { runCommand } from "./shell-exec.js";
|
|
72
|
+
async function allowed(cmd) {
|
|
73
|
+
const r = await runCommand({
|
|
74
|
+
command: cmd,
|
|
75
|
+
timeout: 2000
|
|
76
|
+
});
|
|
77
|
+
return !r.output.includes("blocked for safety");
|
|
78
|
+
}
|
|
79
|
+
async function blocked(cmd) {
|
|
80
|
+
const r = await runCommand({
|
|
81
|
+
command: cmd,
|
|
82
|
+
timeout: 2000
|
|
83
|
+
});
|
|
84
|
+
return r.output.includes("blocked for safety");
|
|
85
|
+
}
|
|
86
|
+
describe("BLOCKED — catastrophic", () => {
|
|
87
|
+
it("rm -rf /", async () => expect(await blocked("rm -rf /")).toBe(true));
|
|
88
|
+
it("rm -rf /*", async () => expect(await blocked("rm -rf /*")).toBe(true));
|
|
89
|
+
it("rm -fr /", async () => expect(await blocked("rm -fr /")).toBe(true));
|
|
90
|
+
it("rm -r -f /", async () => expect(await blocked("rm -r -f /")).toBe(true));
|
|
91
|
+
it("rm -rf / chained", async () => expect(await blocked("rm -rf / && echo done")).toBe(true));
|
|
92
|
+
it("rm -rf / ; cmd", async () => expect(await blocked("rm -rf / ; echo hi")).toBe(true));
|
|
93
|
+
it("rm -rf ~", async () => expect(await blocked("rm -rf ~")).toBe(true));
|
|
94
|
+
it("rm -rf ~/", async () => expect(await blocked("rm -rf ~/")).toBe(true));
|
|
95
|
+
it("rm -rf ~/*", async () => expect(await blocked("rm -rf ~/*")).toBe(true));
|
|
96
|
+
it("rm -rf ~ chained", async () => expect(await blocked("rm -rf ~ && echo done")).toBe(true));
|
|
97
|
+
it("mkfs", async () => expect(await blocked("mkfs /dev/sda1")).toBe(true));
|
|
98
|
+
it("mkfs.ext4", async () => expect(await blocked("mkfs.ext4 /dev/sda1")).toBe(true));
|
|
99
|
+
it("dd to /dev/sda", async () => expect(await blocked("dd if=/dev/zero of=/dev/sda")).toBe(true));
|
|
100
|
+
it("dd to /dev/disk0", async () => expect(await blocked("dd if=x of=/dev/disk0")).toBe(true));
|
|
101
|
+
it("dd to /dev/nvme0n1", async () => expect(await blocked("dd if=/dev/zero of=/dev/nvme0n1")).toBe(true));
|
|
102
|
+
it("> /dev/sda", async () => expect(await blocked("echo x > /dev/sda")).toBe(true));
|
|
103
|
+
it("> /dev/disk0", async () => expect(await blocked("echo x > /dev/disk0")).toBe(true));
|
|
104
|
+
it("fork bomb", async () => expect(await blocked(":(){ :|:& };:")).toBe(true));
|
|
105
|
+
});
|
|
106
|
+
describe("ALLOWED — full developer access", () => {
|
|
107
|
+
// rm on specific paths
|
|
108
|
+
it("rm -rf node_modules", async () => expect(await allowed("rm -rf node_modules")).toBe(true));
|
|
109
|
+
it("rm -rf /tmp/build", async () => expect(await allowed("rm -rf /tmp/build")).toBe(true));
|
|
110
|
+
it("rm -rf /Users/whale/project/nm", async () => expect(await allowed("rm -rf /Users/whale/project/node_modules")).toBe(true));
|
|
111
|
+
it("rm -rf ~/project/dist", async () => expect(await allowed("rm -rf ~/project/dist")).toBe(true));
|
|
112
|
+
it("rm -rf ~/Downloads/old", async () => expect(await allowed("rm -rf ~/Downloads/old-stuff")).toBe(true));
|
|
113
|
+
it("rm -rf ~/.npm-cache", async () => expect(await allowed("rm -rf ~/.npm-cache")).toBe(true));
|
|
114
|
+
it("rm -rf /var/tmp/cache", async () => expect(await allowed("rm -rf /var/tmp/cache")).toBe(true));
|
|
115
|
+
it("rm file.txt", async () => expect(await allowed("rm file.txt")).toBe(true));
|
|
116
|
+
// chmod / chown
|
|
117
|
+
it("chmod 777 /tmp/test", async () => expect(await allowed("chmod 777 /tmp/test")).toBe(true));
|
|
118
|
+
it("chmod -R 777 /tmp/test", async () => expect(await allowed("chmod -R 777 /tmp/test")).toBe(true));
|
|
119
|
+
it("chown -R user ~/.npm", async () => expect(await allowed("chown -R whale ~/.npm")).toBe(true));
|
|
120
|
+
it("chown -R user /Users/.npm-cache", async () => expect(await allowed("chown -R whale /Users/whale/.npm-cache")).toBe(true));
|
|
121
|
+
it("sudo chown -R $(whoami) ~/.npm", async () => expect(await allowed("sudo chown -R $(whoami) ~/.npm")).toBe(true));
|
|
122
|
+
// npm / node
|
|
123
|
+
it("npm install", async () => expect(await allowed("npm install")).toBe(true));
|
|
124
|
+
it("npm run build", async () => expect(await allowed("npm run build")).toBe(true));
|
|
125
|
+
it("npm run dev", async () => expect(await allowed("npm run dev")).toBe(true));
|
|
126
|
+
it("npm test", async () => expect(await allowed("npm test")).toBe(true));
|
|
127
|
+
it("npm cache clean --force", async () => expect(await allowed("npm cache clean --force")).toBe(true));
|
|
128
|
+
it("node -e with require+exec", async () => expect(await allowed("node -e 'require(\"child_process\").execSync(\"ls\")'")).toBe(true));
|
|
129
|
+
// curl/wget including pipe to bash
|
|
130
|
+
it("curl | bash install", async () => expect(await allowed("curl -fsSL https://bun.sh/install | bash")).toBe(true));
|
|
131
|
+
it("wget | bash", async () => expect(await allowed("wget -qO- https://example.com/install.sh | bash")).toBe(true));
|
|
132
|
+
// python
|
|
133
|
+
it("python -e with os.system", async () => expect(await allowed("python -e 'import os; os.system(\"ls\")'")).toBe(true));
|
|
134
|
+
// git
|
|
135
|
+
it("git push", async () => expect(await allowed("git push")).toBe(true));
|
|
136
|
+
it("git push --force", async () => expect(await allowed("git push --force")).toBe(true));
|
|
137
|
+
it("git reset --hard", async () => expect(await allowed("git reset --hard HEAD~1")).toBe(true));
|
|
138
|
+
// dd on regular files
|
|
139
|
+
it("dd to regular file", async () => expect(await allowed("dd if=/dev/urandom of=./random.bin bs=1024 count=1")).toBe(true));
|
|
140
|
+
it("dd to /dev/null", async () => expect(await allowed("dd if=./bigfile of=/dev/null bs=1M")).toBe(true));
|
|
141
|
+
it("dd to /tmp", async () => expect(await allowed("dd if=/dev/zero of=/tmp/testfile bs=1M count=10")).toBe(true));
|
|
142
|
+
// base64
|
|
143
|
+
it("base64 -d | bash", async () => expect(await allowed("base64 -d | bash")).toBe(true));
|
|
144
|
+
// system tools
|
|
145
|
+
it("brew install", async () => expect(await allowed("brew install postgresql")).toBe(true));
|
|
146
|
+
it("terraform apply", async () => expect(await allowed("terraform apply -auto-approve")).toBe(true));
|
|
147
|
+
it("docker system prune -af", async () => expect(await allowed("docker system prune -af")).toBe(true));
|
|
148
|
+
});
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* SSRF Protection — URL validation and DNS resolution checks.
|
|
3
|
+
* Extracted from web-tools.ts for single-responsibility.
|
|
4
|
+
*/
|
|
5
|
+
export declare function isBlockedUrl(urlStr: string): boolean;
|
|
6
|
+
export declare function resolveAndCheckUrl(url: string): Promise<boolean>;
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* SSRF Protection — URL validation and DNS resolution checks.
|
|
3
|
+
* Extracted from web-tools.ts for single-responsibility.
|
|
4
|
+
*/
|
|
5
|
+
|
|
6
|
+
import { lookup } from "node:dns/promises";
|
|
7
|
+
export function isBlockedUrl(urlStr) {
|
|
8
|
+
try {
|
|
9
|
+
const u = new URL(urlStr);
|
|
10
|
+
const host = u.hostname.toLowerCase();
|
|
11
|
+
|
|
12
|
+
// Block localhost
|
|
13
|
+
if (host === "localhost" || host === "127.0.0.1" || host === "::1" || host === "[::1]" || host === "0.0.0.0") return true;
|
|
14
|
+
|
|
15
|
+
// Block private IPv4 ranges
|
|
16
|
+
if (/^10\./.test(host)) return true;
|
|
17
|
+
if (/^172\.(1[6-9]|2\d|3[01])\./.test(host)) return true;
|
|
18
|
+
if (/^192\.168\./.test(host)) return true;
|
|
19
|
+
|
|
20
|
+
// Block IPv6 private
|
|
21
|
+
if (/^fe80:/i.test(host) || /^\[fe80:/i.test(host)) return true;
|
|
22
|
+
if (/^fc00:/i.test(host) || /^\[fc00:/i.test(host)) return true;
|
|
23
|
+
if (/^fd/i.test(host) || /^\[fd/i.test(host)) return true;
|
|
24
|
+
|
|
25
|
+
// Block cloud metadata
|
|
26
|
+
if (host === "169.254.169.254" || /^169\.254\./.test(host)) return true;
|
|
27
|
+
|
|
28
|
+
// Block IPv6-mapped IPv4 (e.g. ::ffff:127.0.0.1, ::ffff:169.254.169.254)
|
|
29
|
+
if (host.includes("::ffff:")) return true;
|
|
30
|
+
|
|
31
|
+
// Block decimal/hex IP representations (e.g. 2130706433 = 127.0.0.1, 0x7f000001)
|
|
32
|
+
if (/^\d+$/.test(host) || /^0x[0-9a-f]+$/i.test(host)) return true;
|
|
33
|
+
|
|
34
|
+
// Block octal IPs (e.g., 0177.0.0.1 = 127.0.0.1)
|
|
35
|
+
if (/^0\d+\./.test(host)) return true;
|
|
36
|
+
|
|
37
|
+
// Block short zero address forms (e.g. 0, 0.0, 0.0.0)
|
|
38
|
+
if (/^0(\.0)*$/.test(host)) return true;
|
|
39
|
+
|
|
40
|
+
// Block internal TLDs
|
|
41
|
+
if (host.endsWith(".internal") || host.endsWith(".local")) return true;
|
|
42
|
+
|
|
43
|
+
// Block non-HTTP(S)
|
|
44
|
+
if (u.protocol !== "http:" && u.protocol !== "https:") return true;
|
|
45
|
+
return false;
|
|
46
|
+
} catch {
|
|
47
|
+
return true;
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
export async function resolveAndCheckUrl(url) {
|
|
51
|
+
if (isBlockedUrl(url)) return true;
|
|
52
|
+
try {
|
|
53
|
+
const {
|
|
54
|
+
hostname
|
|
55
|
+
} = new URL(url);
|
|
56
|
+
// Skip IP-based hostnames (already checked by isBlockedUrl)
|
|
57
|
+
if (/^[\d.]+$/.test(hostname) || hostname.includes(":")) return false;
|
|
58
|
+
const {
|
|
59
|
+
address
|
|
60
|
+
} = await lookup(hostname);
|
|
61
|
+
// IPv6 private/loopback detection
|
|
62
|
+
if (address.includes(":")) {
|
|
63
|
+
const lower = address.toLowerCase();
|
|
64
|
+
if (lower === "::1" || lower === "::" || lower.startsWith("fe80") || lower.startsWith("fc") || lower.startsWith("fd") || lower.startsWith("::ffff:")) return true;
|
|
65
|
+
return false;
|
|
66
|
+
}
|
|
67
|
+
// IPv4 private/internal ranges
|
|
68
|
+
const parts = address.split(".").map(Number);
|
|
69
|
+
if (parts[0] === 10) return true; // 10.0.0.0/8
|
|
70
|
+
if (parts[0] === 172 && parts[1] >= 16 && parts[1] <= 31) return true; // 172.16.0.0/12
|
|
71
|
+
if (parts[0] === 192 && parts[1] === 168) return true; // 192.168.0.0/16
|
|
72
|
+
if (parts[0] === 127) return true; // 127.0.0.0/8
|
|
73
|
+
if (parts[0] === 169 && parts[1] === 254) return true; // link-local
|
|
74
|
+
if (address === "0.0.0.0") return true;
|
|
75
|
+
return false;
|
|
76
|
+
} catch {
|
|
77
|
+
return true; // DNS resolution failed — block by default (fail-closed)
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
//# sourceMappingURL=ssrf-guard.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ssrf-guard.js","names":["lookup","isBlockedUrl","urlStr","u","URL","host","hostname","toLowerCase","test","includes","endsWith","protocol","resolveAndCheckUrl","url","address","lower","startsWith","parts","split","map","Number"],"sources":["../../../../src/cli/services/tools/ssrf-guard.ts"],"sourcesContent":["/**\n * SSRF Protection — URL validation and DNS resolution checks.\n * Extracted from web-tools.ts for single-responsibility.\n */\n\nimport { lookup } from \"node:dns/promises\";\n\nexport function isBlockedUrl(urlStr: string): boolean {\n try {\n const u = new URL(urlStr);\n const host = u.hostname.toLowerCase();\n\n // Block localhost\n if (host === \"localhost\" || host === \"127.0.0.1\" || host === \"::1\" || host === \"[::1]\" || host === \"0.0.0.0\") return true;\n\n // Block private IPv4 ranges\n if (/^10\\./.test(host)) return true;\n if (/^172\\.(1[6-9]|2\\d|3[01])\\./.test(host)) return true;\n if (/^192\\.168\\./.test(host)) return true;\n\n // Block IPv6 private\n if (/^fe80:/i.test(host) || /^\\[fe80:/i.test(host)) return true;\n if (/^fc00:/i.test(host) || /^\\[fc00:/i.test(host)) return true;\n if (/^fd/i.test(host) || /^\\[fd/i.test(host)) return true;\n\n // Block cloud metadata\n if (host === \"169.254.169.254\" || /^169\\.254\\./.test(host)) return true;\n\n // Block IPv6-mapped IPv4 (e.g. ::ffff:127.0.0.1, ::ffff:169.254.169.254)\n if (host.includes(\"::ffff:\")) return true;\n\n // Block decimal/hex IP representations (e.g. 2130706433 = 127.0.0.1, 0x7f000001)\n if (/^\\d+$/.test(host) || /^0x[0-9a-f]+$/i.test(host)) return true;\n\n // Block octal IPs (e.g., 0177.0.0.1 = 127.0.0.1)\n if (/^0\\d+\\./.test(host)) return true;\n\n // Block short zero address forms (e.g. 0, 0.0, 0.0.0)\n if (/^0(\\.0)*$/.test(host)) return true;\n\n // Block internal TLDs\n if (host.endsWith(\".internal\") || host.endsWith(\".local\")) return true;\n\n // Block non-HTTP(S)\n if (u.protocol !== \"http:\" && u.protocol !== \"https:\") return true;\n\n return false;\n } catch {\n return true;\n }\n}\n\nexport async function resolveAndCheckUrl(url: string): Promise<boolean> {\n if (isBlockedUrl(url)) return true;\n try {\n const { hostname } = new URL(url);\n // Skip IP-based hostnames (already checked by isBlockedUrl)\n if (/^[\\d.]+$/.test(hostname) || hostname.includes(\":\")) return false;\n const { address } = await lookup(hostname);\n // IPv6 private/loopback detection\n if (address.includes(\":\")) {\n const lower = address.toLowerCase();\n if (lower === \"::1\" || lower === \"::\" || lower.startsWith(\"fe80\") ||\n lower.startsWith(\"fc\") || lower.startsWith(\"fd\") ||\n lower.startsWith(\"::ffff:\")) return true;\n return false;\n }\n // IPv4 private/internal ranges\n const parts = address.split(\".\").map(Number);\n if (parts[0] === 10) return true; // 10.0.0.0/8\n if (parts[0] === 172 && parts[1] >= 16 && parts[1] <= 31) return true; // 172.16.0.0/12\n if (parts[0] === 192 && parts[1] === 168) return true; // 192.168.0.0/16\n if (parts[0] === 127) return true; // 127.0.0.0/8\n if (parts[0] === 169 && parts[1] === 254) return true; // link-local\n if (address === \"0.0.0.0\") return true;\n return false;\n } catch {\n return true; // DNS resolution failed — block by default (fail-closed)\n }\n}\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import type { CLITarget } from "./setup-cli-targets.js";
|
|
2
|
+
export declare function CLISelector({ clis, selected, onToggle, onConfirm, }: {
|
|
3
|
+
clis: CLITarget[];
|
|
4
|
+
selected: Set<string>;
|
|
5
|
+
onToggle: (name: string) => void;
|
|
6
|
+
onConfirm: () => void;
|
|
7
|
+
}): import("react/jsx-runtime").JSX.Element;
|
|
8
|
+
export declare function ConfirmButton({ onConfirm }: {
|
|
9
|
+
onConfirm: () => void;
|
|
10
|
+
}): import("react/jsx-runtime").JSX.Element;
|
|
@@ -0,0 +1,144 @@
|
|
|
1
|
+
import { c as _c } from "react/compiler-runtime";
|
|
2
|
+
// SetupComponents.tsx — CLISelector and ConfirmButton sub-components for setup wizard
|
|
3
|
+
|
|
4
|
+
import React, { useState } from "react";
|
|
5
|
+
import { Box, Text, useInput } from "ink";
|
|
6
|
+
import { colors, symbols } from "../shared/Theme.js";
|
|
7
|
+
import { jsxs as _jsxs, jsx as _jsx } from "react/jsx-runtime";
|
|
8
|
+
export function CLISelector(t0) {
|
|
9
|
+
const $ = _c(20);
|
|
10
|
+
const {
|
|
11
|
+
clis,
|
|
12
|
+
selected,
|
|
13
|
+
onToggle,
|
|
14
|
+
onConfirm
|
|
15
|
+
} = t0;
|
|
16
|
+
const [cursor, setCursor] = useState(0);
|
|
17
|
+
let t1;
|
|
18
|
+
if ($[0] !== clis || $[1] !== cursor || $[2] !== onConfirm || $[3] !== onToggle) {
|
|
19
|
+
t1 = (input, key) => {
|
|
20
|
+
if (key.upArrow) {
|
|
21
|
+
setCursor(_temp);
|
|
22
|
+
} else {
|
|
23
|
+
if (key.downArrow) {
|
|
24
|
+
setCursor(c_0 => Math.min(clis.length, c_0 + 1));
|
|
25
|
+
} else {
|
|
26
|
+
if (input === " " && cursor < clis.length) {
|
|
27
|
+
onToggle(clis[cursor].name);
|
|
28
|
+
} else {
|
|
29
|
+
if (key.return) {
|
|
30
|
+
onConfirm();
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
};
|
|
36
|
+
$[0] = clis;
|
|
37
|
+
$[1] = cursor;
|
|
38
|
+
$[2] = onConfirm;
|
|
39
|
+
$[3] = onToggle;
|
|
40
|
+
$[4] = t1;
|
|
41
|
+
} else {
|
|
42
|
+
t1 = $[4];
|
|
43
|
+
}
|
|
44
|
+
useInput(t1);
|
|
45
|
+
let t2;
|
|
46
|
+
if ($[5] !== clis || $[6] !== cursor || $[7] !== selected) {
|
|
47
|
+
let t3;
|
|
48
|
+
if ($[9] !== cursor || $[10] !== selected) {
|
|
49
|
+
t3 = (cli, i) => /*#__PURE__*/_jsxs(Text, {
|
|
50
|
+
color: i === cursor ? colors.brand : colors.text,
|
|
51
|
+
children: [i === cursor ? symbols.chevron : " ", " [", selected.has(cli.name) ? "x" : " ", "] ", cli.name]
|
|
52
|
+
}, cli.name);
|
|
53
|
+
$[9] = cursor;
|
|
54
|
+
$[10] = selected;
|
|
55
|
+
$[11] = t3;
|
|
56
|
+
} else {
|
|
57
|
+
t3 = $[11];
|
|
58
|
+
}
|
|
59
|
+
t2 = clis.map(t3);
|
|
60
|
+
$[5] = clis;
|
|
61
|
+
$[6] = cursor;
|
|
62
|
+
$[7] = selected;
|
|
63
|
+
$[8] = t2;
|
|
64
|
+
} else {
|
|
65
|
+
t2 = $[8];
|
|
66
|
+
}
|
|
67
|
+
const t3 = cursor === clis.length ? colors.brand : colors.success;
|
|
68
|
+
const t4 = cursor === clis.length ? symbols.chevron : " ";
|
|
69
|
+
let t5;
|
|
70
|
+
if ($[12] !== t3 || $[13] !== t4) {
|
|
71
|
+
t5 = /*#__PURE__*/_jsxs(Text, {
|
|
72
|
+
color: t3,
|
|
73
|
+
children: [t4, " ", symbols.arrow, " Confirm & Install"]
|
|
74
|
+
});
|
|
75
|
+
$[12] = t3;
|
|
76
|
+
$[13] = t4;
|
|
77
|
+
$[14] = t5;
|
|
78
|
+
} else {
|
|
79
|
+
t5 = $[14];
|
|
80
|
+
}
|
|
81
|
+
let t6;
|
|
82
|
+
let t7;
|
|
83
|
+
if ($[15] === Symbol.for("react.memo_cache_sentinel")) {
|
|
84
|
+
t6 = /*#__PURE__*/_jsx(Box, {
|
|
85
|
+
height: 1
|
|
86
|
+
});
|
|
87
|
+
t7 = /*#__PURE__*/_jsx(Text, {
|
|
88
|
+
color: colors.dim,
|
|
89
|
+
children: "Space to toggle, Enter to confirm"
|
|
90
|
+
});
|
|
91
|
+
$[15] = t6;
|
|
92
|
+
$[16] = t7;
|
|
93
|
+
} else {
|
|
94
|
+
t6 = $[15];
|
|
95
|
+
t7 = $[16];
|
|
96
|
+
}
|
|
97
|
+
let t8;
|
|
98
|
+
if ($[17] !== t2 || $[18] !== t5) {
|
|
99
|
+
t8 = /*#__PURE__*/_jsxs(Box, {
|
|
100
|
+
flexDirection: "column",
|
|
101
|
+
children: [t2, t5, t6, t7]
|
|
102
|
+
});
|
|
103
|
+
$[17] = t2;
|
|
104
|
+
$[18] = t5;
|
|
105
|
+
$[19] = t8;
|
|
106
|
+
} else {
|
|
107
|
+
t8 = $[19];
|
|
108
|
+
}
|
|
109
|
+
return t8;
|
|
110
|
+
}
|
|
111
|
+
function _temp(c) {
|
|
112
|
+
return Math.max(0, c - 1);
|
|
113
|
+
}
|
|
114
|
+
export function ConfirmButton(t0) {
|
|
115
|
+
const $ = _c(3);
|
|
116
|
+
const {
|
|
117
|
+
onConfirm
|
|
118
|
+
} = t0;
|
|
119
|
+
let t1;
|
|
120
|
+
if ($[0] !== onConfirm) {
|
|
121
|
+
t1 = (_input, key) => {
|
|
122
|
+
if (key.return) {
|
|
123
|
+
onConfirm();
|
|
124
|
+
}
|
|
125
|
+
};
|
|
126
|
+
$[0] = onConfirm;
|
|
127
|
+
$[1] = t1;
|
|
128
|
+
} else {
|
|
129
|
+
t1 = $[1];
|
|
130
|
+
}
|
|
131
|
+
useInput(t1);
|
|
132
|
+
let t2;
|
|
133
|
+
if ($[2] === Symbol.for("react.memo_cache_sentinel")) {
|
|
134
|
+
t2 = /*#__PURE__*/_jsx(Text, {
|
|
135
|
+
color: colors.muted,
|
|
136
|
+
children: "Press Enter to save config..."
|
|
137
|
+
});
|
|
138
|
+
$[2] = t2;
|
|
139
|
+
} else {
|
|
140
|
+
t2 = $[2];
|
|
141
|
+
}
|
|
142
|
+
return t2;
|
|
143
|
+
}
|
|
144
|
+
//# sourceMappingURL=SetupComponents.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SetupComponents.js","names":["React","useState","Box","Text","useInput","colors","symbols","jsxs","_jsxs","jsx","_jsx","CLISelector","t0","$","_c","clis","selected","onToggle","onConfirm","cursor","setCursor","t1","input","key","upArrow","_temp","downArrow","c_0","Math","min","length","c","name","return","t2","t3","cli","i","color","brand","text","children","chevron","has","map","success","t4","t5","arrow","t6","t7","Symbol","for","height","dim","t8","flexDirection","max","ConfirmButton","_input","muted"],"sources":["../../../src/cli/setup/SetupComponents.tsx"],"sourcesContent":["// SetupComponents.tsx — CLISelector and ConfirmButton sub-components for setup wizard\n\nimport React, { useState } from \"react\";\nimport { Box, Text, useInput } from \"ink\";\nimport { colors, symbols } from \"../shared/Theme.js\";\nimport type { CLITarget } from \"./setup-cli-targets.js\";\n\nexport function CLISelector({\n clis,\n selected,\n onToggle,\n onConfirm,\n}: {\n clis: CLITarget[];\n selected: Set<string>;\n onToggle: (name: string) => void;\n onConfirm: () => void;\n}) {\n const [cursor, setCursor] = useState(0);\n\n useInput((input, key) => {\n if (key.upArrow) setCursor(c => Math.max(0, c - 1));\n else if (key.downArrow) setCursor(c => Math.min(clis.length, c + 1));\n else if (input === \" \" && cursor < clis.length) onToggle(clis[cursor].name);\n else if (key.return) onConfirm();\n });\n\n return (\n <Box flexDirection=\"column\">\n {clis.map((cli, i) => (\n <Text key={cli.name} color={i === cursor ? colors.brand : colors.text}>\n {i === cursor ? symbols.chevron : \" \"} [{selected.has(cli.name) ? \"x\" : \" \"}] {cli.name}\n </Text>\n ))}\n <Text color={cursor === clis.length ? colors.brand : colors.success}>\n {cursor === clis.length ? symbols.chevron : \" \"} {symbols.arrow} Confirm & Install\n </Text>\n <Box height={1} />\n <Text color={colors.dim}>Space to toggle, Enter to confirm</Text>\n </Box>\n );\n}\n\nexport function ConfirmButton({ onConfirm }: { onConfirm: () => void }) {\n useInput((_input, key) => {\n if (key.return) onConfirm();\n });\n\n return <Text color={colors.muted}>Press Enter to save config...</Text>;\n}\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
export interface CLITarget {
|
|
2
|
+
name: string;
|
|
3
|
+
configPath: string;
|
|
4
|
+
configKey: string;
|
|
5
|
+
detected: boolean;
|
|
6
|
+
}
|
|
7
|
+
export declare function detectCLIs(): CLITarget[];
|
|
8
|
+
export declare function readJSON(path: string): Record<string, any>;
|
|
9
|
+
export declare function writeJSON(path: string, data: Record<string, any>): void;
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
// setup-cli-targets.ts — CLI detection and JSON config helpers for setup wizard
|
|
2
|
+
|
|
3
|
+
import { existsSync, mkdirSync, readFileSync, writeFileSync } from "fs";
|
|
4
|
+
import { homedir } from "os";
|
|
5
|
+
import { dirname, join } from "path";
|
|
6
|
+
const home = homedir();
|
|
7
|
+
export function detectCLIs() {
|
|
8
|
+
return [{
|
|
9
|
+
name: "Claude Code",
|
|
10
|
+
configPath: join(home, ".claude", "settings.json"),
|
|
11
|
+
configKey: "mcpServers",
|
|
12
|
+
detected: existsSync(join(home, ".claude"))
|
|
13
|
+
}, {
|
|
14
|
+
name: "Claude Desktop",
|
|
15
|
+
configPath: process.platform === "darwin" ? join(home, "Library", "Application Support", "Claude", "claude_desktop_config.json") : join(home, "AppData", "Roaming", "Claude", "claude_desktop_config.json"),
|
|
16
|
+
configKey: "mcpServers",
|
|
17
|
+
detected: existsSync(process.platform === "darwin" ? join(home, "Library", "Application Support", "Claude") : join(home, "AppData", "Roaming", "Claude"))
|
|
18
|
+
}, {
|
|
19
|
+
name: "Cursor",
|
|
20
|
+
configPath: join(home, ".cursor", "mcp.json"),
|
|
21
|
+
configKey: "mcpServers",
|
|
22
|
+
detected: existsSync(join(home, ".cursor"))
|
|
23
|
+
}, {
|
|
24
|
+
name: "Windsurf",
|
|
25
|
+
configPath: join(home, ".codeium", "windsurf", "mcp_config.json"),
|
|
26
|
+
configKey: "mcpServers",
|
|
27
|
+
detected: existsSync(join(home, ".codeium", "windsurf"))
|
|
28
|
+
}, {
|
|
29
|
+
name: "Gemini CLI",
|
|
30
|
+
configPath: join(home, ".gemini", "settings.json"),
|
|
31
|
+
configKey: "mcpServers",
|
|
32
|
+
detected: existsSync(join(home, ".gemini"))
|
|
33
|
+
}];
|
|
34
|
+
}
|
|
35
|
+
export function readJSON(path) {
|
|
36
|
+
try {
|
|
37
|
+
return JSON.parse(readFileSync(path, "utf-8"));
|
|
38
|
+
} catch {
|
|
39
|
+
return {};
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
export function writeJSON(path, data) {
|
|
43
|
+
const dir = dirname(path);
|
|
44
|
+
if (!existsSync(dir)) mkdirSync(dir, {
|
|
45
|
+
recursive: true
|
|
46
|
+
});
|
|
47
|
+
writeFileSync(path, JSON.stringify(data, null, 2) + "\n", "utf-8");
|
|
48
|
+
}
|
|
49
|
+
//# sourceMappingURL=setup-cli-targets.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"setup-cli-targets.js","names":["existsSync","mkdirSync","readFileSync","writeFileSync","homedir","dirname","join","home","detectCLIs","name","configPath","configKey","detected","process","platform","readJSON","path","JSON","parse","writeJSON","data","dir","recursive","stringify"],"sources":["../../../src/cli/setup/setup-cli-targets.ts"],"sourcesContent":["// setup-cli-targets.ts — CLI detection and JSON config helpers for setup wizard\n\nimport { existsSync, mkdirSync, readFileSync, writeFileSync } from \"fs\";\nimport { homedir } from \"os\";\nimport { dirname, join } from \"path\";\n\nexport interface CLITarget {\n name: string;\n configPath: string;\n configKey: string;\n detected: boolean;\n}\n\nconst home = homedir();\n\nexport function detectCLIs(): CLITarget[] {\n return [\n {\n name: \"Claude Code\",\n configPath: join(home, \".claude\", \"settings.json\"),\n configKey: \"mcpServers\",\n detected: existsSync(join(home, \".claude\")),\n },\n {\n name: \"Claude Desktop\",\n configPath:\n process.platform === \"darwin\"\n ? join(home, \"Library\", \"Application Support\", \"Claude\", \"claude_desktop_config.json\")\n : join(home, \"AppData\", \"Roaming\", \"Claude\", \"claude_desktop_config.json\"),\n configKey: \"mcpServers\",\n detected: existsSync(\n process.platform === \"darwin\"\n ? join(home, \"Library\", \"Application Support\", \"Claude\")\n : join(home, \"AppData\", \"Roaming\", \"Claude\")\n ),\n },\n {\n name: \"Cursor\",\n configPath: join(home, \".cursor\", \"mcp.json\"),\n configKey: \"mcpServers\",\n detected: existsSync(join(home, \".cursor\")),\n },\n {\n name: \"Windsurf\",\n configPath: join(home, \".codeium\", \"windsurf\", \"mcp_config.json\"),\n configKey: \"mcpServers\",\n detected: existsSync(join(home, \".codeium\", \"windsurf\")),\n },\n {\n name: \"Gemini CLI\",\n configPath: join(home, \".gemini\", \"settings.json\"),\n configKey: \"mcpServers\",\n detected: existsSync(join(home, \".gemini\")),\n },\n ];\n}\n\nexport function readJSON(path: string): Record<string, any> {\n try {\n return JSON.parse(readFileSync(path, \"utf-8\"));\n } catch {\n return {};\n }\n}\n\nexport function writeJSON(path: string, data: Record<string, any>): void {\n const dir = dirname(path);\n if (!existsSync(dir)) mkdirSync(dir, { recursive: true });\n writeFileSync(path, JSON.stringify(data, null, 2) + \"\\n\", \"utf-8\");\n}\n"],"mappings":"AAAA;;AAEA,SAASA,UAAU,EAAEC,SAAS,EAAEC,YAAY,EAAEC,aAAa,QAAQ,IAAI;AACvE,SAASC,OAAO,QAAQ,IAAI;AAC5B,SAASC,OAAO,EAAEC,IAAI,QAAQ,MAAM;AASpC,MAAMC,IAAI,GAAGH,OAAO,CAAC,CAAC;AAEtB,OAAO,SAASI,UAAUA,CAAA,EAAgB;EACxC,OAAO,CACL;IACEC,IAAI,EAAE,aAAa;IACnBC,UAAU,EAAEJ,IAAI,CAACC,IAAI,EAAE,SAAS,EAAE,eAAe,CAAC;IAClDI,SAAS,EAAE,YAAY;IACvBC,QAAQ,EAAEZ,UAAU,CAACM,IAAI,CAACC,IAAI,EAAE,SAAS,CAAC;EAC5C,CAAC,EACD;IACEE,IAAI,EAAE,gBAAgB;IACtBC,UAAU,EACRG,OAAO,CAACC,QAAQ,KAAK,QAAQ,GACzBR,IAAI,CAACC,IAAI,EAAE,SAAS,EAAE,qBAAqB,EAAE,QAAQ,EAAE,4BAA4B,CAAC,GACpFD,IAAI,CAACC,IAAI,EAAE,SAAS,EAAE,SAAS,EAAE,QAAQ,EAAE,4BAA4B,CAAC;IAC9EI,SAAS,EAAE,YAAY;IACvBC,QAAQ,EAAEZ,UAAU,CAClBa,OAAO,CAACC,QAAQ,KAAK,QAAQ,GACzBR,IAAI,CAACC,IAAI,EAAE,SAAS,EAAE,qBAAqB,EAAE,QAAQ,CAAC,GACtDD,IAAI,CAACC,IAAI,EAAE,SAAS,EAAE,SAAS,EAAE,QAAQ,CAC/C;EACF,CAAC,EACD;IACEE,IAAI,EAAE,QAAQ;IACdC,UAAU,EAAEJ,IAAI,CAACC,IAAI,EAAE,SAAS,EAAE,UAAU,CAAC;IAC7CI,SAAS,EAAE,YAAY;IACvBC,QAAQ,EAAEZ,UAAU,CAACM,IAAI,CAACC,IAAI,EAAE,SAAS,CAAC;EAC5C,CAAC,EACD;IACEE,IAAI,EAAE,UAAU;IAChBC,UAAU,EAAEJ,IAAI,CAACC,IAAI,EAAE,UAAU,EAAE,UAAU,EAAE,iBAAiB,CAAC;IACjEI,SAAS,EAAE,YAAY;IACvBC,QAAQ,EAAEZ,UAAU,CAACM,IAAI,CAACC,IAAI,EAAE,UAAU,EAAE,UAAU,CAAC;EACzD,CAAC,EACD;IACEE,IAAI,EAAE,YAAY;IAClBC,UAAU,EAAEJ,IAAI,CAACC,IAAI,EAAE,SAAS,EAAE,eAAe,CAAC;IAClDI,SAAS,EAAE,YAAY;IACvBC,QAAQ,EAAEZ,UAAU,CAACM,IAAI,CAACC,IAAI,EAAE,SAAS,CAAC;EAC5C,CAAC,CACF;AACH;AAEA,OAAO,SAASQ,QAAQA,CAACC,IAAY,EAAuB;EAC1D,IAAI;IACF,OAAOC,IAAI,CAACC,KAAK,CAAChB,YAAY,CAACc,IAAI,EAAE,OAAO,CAAC,CAAC;EAChD,CAAC,CAAC,MAAM;IACN,OAAO,CAAC,CAAC;EACX;AACF;AAEA,OAAO,SAASG,SAASA,CAACH,IAAY,EAAEI,IAAyB,EAAQ;EACvE,MAAMC,GAAG,GAAGhB,OAAO,CAACW,IAAI,CAAC;EACzB,IAAI,CAAChB,UAAU,CAACqB,GAAG,CAAC,EAAEpB,SAAS,CAACoB,GAAG,EAAE;IAAEC,SAAS,EAAE;EAAK,CAAC,CAAC;EACzDnB,aAAa,CAACa,IAAI,EAAEC,IAAI,CAACM,SAAS,CAACH,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC,GAAG,IAAI,EAAE,OAAO,CAAC;AACpE","ignoreList":[]}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* InlineErrorBoundary — lightweight sub-tree error boundary
|
|
3
|
+
*
|
|
4
|
+
* Shows an inline error message instead of crashing the entire app.
|
|
5
|
+
*/
|
|
6
|
+
import React from "react";
|
|
7
|
+
interface Props {
|
|
8
|
+
label: string;
|
|
9
|
+
children: React.ReactNode;
|
|
10
|
+
onError?: (error: Error) => void;
|
|
11
|
+
}
|
|
12
|
+
interface State {
|
|
13
|
+
hasError: boolean;
|
|
14
|
+
error: Error | null;
|
|
15
|
+
}
|
|
16
|
+
export declare class InlineErrorBoundary extends React.Component<Props, State> {
|
|
17
|
+
state: State;
|
|
18
|
+
static getDerivedStateFromError(error: Error): State;
|
|
19
|
+
componentDidCatch(error: Error): void;
|
|
20
|
+
render(): string | number | bigint | boolean | import("react/jsx-runtime").JSX.Element | Iterable<React.ReactNode> | Promise<string | number | bigint | boolean | React.ReactPortal | React.ReactElement<unknown, string | React.JSXElementConstructor<any>> | Iterable<React.ReactNode> | null | undefined> | null | undefined;
|
|
21
|
+
}
|
|
22
|
+
export {};
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* InlineErrorBoundary — lightweight sub-tree error boundary
|
|
3
|
+
*
|
|
4
|
+
* Shows an inline error message instead of crashing the entire app.
|
|
5
|
+
*/
|
|
6
|
+
|
|
7
|
+
import React from "react";
|
|
8
|
+
import { Text } from "ink";
|
|
9
|
+
import { jsxs as _jsxs } from "react/jsx-runtime";
|
|
10
|
+
export class InlineErrorBoundary extends React.Component {
|
|
11
|
+
state = {
|
|
12
|
+
hasError: false,
|
|
13
|
+
error: null
|
|
14
|
+
};
|
|
15
|
+
static getDerivedStateFromError(error) {
|
|
16
|
+
return {
|
|
17
|
+
hasError: true,
|
|
18
|
+
error
|
|
19
|
+
};
|
|
20
|
+
}
|
|
21
|
+
componentDidCatch(error) {
|
|
22
|
+
process.stderr.write(`[InlineErrorBoundary:${this.props.label}] ${error.message}\n`);
|
|
23
|
+
this.props.onError?.(error);
|
|
24
|
+
}
|
|
25
|
+
render() {
|
|
26
|
+
if (this.state.hasError) {
|
|
27
|
+
return /*#__PURE__*/_jsxs(Text, {
|
|
28
|
+
color: "#FF453A",
|
|
29
|
+
children: [" [", this.props.label, " error: ", this.state.error?.message, "]"]
|
|
30
|
+
});
|
|
31
|
+
}
|
|
32
|
+
return this.props.children;
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
//# sourceMappingURL=InlineErrorBoundary.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"InlineErrorBoundary.js","names":["React","Text","jsxs","_jsxs","InlineErrorBoundary","Component","state","hasError","error","getDerivedStateFromError","componentDidCatch","process","stderr","write","props","label","message","onError","render","color","children"],"sources":["../../../src/cli/shared/InlineErrorBoundary.tsx"],"sourcesContent":["/**\n * InlineErrorBoundary — lightweight sub-tree error boundary\n *\n * Shows an inline error message instead of crashing the entire app.\n */\n\nimport React from \"react\";\nimport { Text } from \"ink\";\n\ninterface Props {\n label: string;\n children: React.ReactNode;\n onError?: (error: Error) => void;\n}\n\ninterface State {\n hasError: boolean;\n error: Error | null;\n}\n\nexport class InlineErrorBoundary extends React.Component<Props, State> {\n state: State = { hasError: false, error: null };\n\n static getDerivedStateFromError(error: Error): State {\n return { hasError: true, error };\n }\n\n componentDidCatch(error: Error) {\n process.stderr.write(`[InlineErrorBoundary:${this.props.label}] ${error.message}\\n`);\n this.props.onError?.(error);\n }\n\n render() {\n if (this.state.hasError) {\n return <Text color=\"#FF453A\"> [{this.props.label} error: {this.state.error?.message}]</Text>;\n }\n return this.props.children;\n }\n}\n"],"mappings":"AAAA;AACA;AACA;AACA;AACA;;AAEA,OAAOA,KAAK,MAAM,OAAO;AACzB,SAASC,IAAI,QAAQ,KAAK;AAAC,SAAAC,IAAA,IAAAC,KAAA;AAa3B,OAAO,MAAMC,mBAAmB,SAASJ,KAAK,CAACK,SAAS,CAAe;EACrEC,KAAK,GAAU;IAAEC,QAAQ,EAAE,KAAK;IAAEC,KAAK,EAAE;EAAK,CAAC;EAE/C,OAAOC,wBAAwBA,CAACD,KAAY,EAAS;IACnD,OAAO;MAAED,QAAQ,EAAE,IAAI;MAAEC;IAAM,CAAC;EAClC;EAEAE,iBAAiBA,CAACF,KAAY,EAAE;IAC9BG,OAAO,CAACC,MAAM,CAACC,KAAK,CAAC,wBAAwB,IAAI,CAACC,KAAK,CAACC,KAAK,KAAKP,KAAK,CAACQ,OAAO,IAAI,CAAC;IACpF,IAAI,CAACF,KAAK,CAACG,OAAO,GAAGT,KAAK,CAAC;EAC7B;EAEAU,MAAMA,CAAA,EAAG;IACP,IAAI,IAAI,CAACZ,KAAK,CAACC,QAAQ,EAAE;MACvB,oBAAOJ,KAAA,CAACF,IAAI;QAACkB,KAAK,EAAC,SAAS;QAAAC,QAAA,GAAC,KAAG,EAAC,IAAI,CAACN,KAAK,CAACC,KAAK,EAAC,UAAQ,EAAC,IAAI,CAACT,KAAK,CAACE,KAAK,EAAEQ,OAAO,EAAC,GAAC;MAAA,CAAM,CAAC;IAC/F;IACA,OAAO,IAAI,CAACF,KAAK,CAACM,QAAQ;EAC5B;AACF","ignoreList":[]}
|
|
@@ -3,6 +3,7 @@
|
|
|
3
3
|
*/
|
|
4
4
|
|
|
5
5
|
import chalk from "chalk";
|
|
6
|
+
import { termWidth as getTermWidth } from "./markdown.js";
|
|
6
7
|
const CHARS = "ハミヒーウシナモニサワツオリアホテマケメエカキムユラセネスタヌヘ0123456789ABCDEFZ";
|
|
7
8
|
const green0 = chalk.hex("#003B00");
|
|
8
9
|
const green1 = chalk.hex("#008F11");
|
|
@@ -14,7 +15,7 @@ function randChar() {
|
|
|
14
15
|
}
|
|
15
16
|
export async function matrixIntro(durationMs = 2200) {
|
|
16
17
|
return new Promise(resolve => {
|
|
17
|
-
const cols =
|
|
18
|
+
const cols = getTermWidth();
|
|
18
19
|
const rows = Math.min((process.stdout.rows || 24) - 1, 24);
|
|
19
20
|
const drops = Array.from({
|
|
20
21
|
length: cols
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MatrixIntro.js","names":["chalk","CHARS","green0","hex","green1","green2","white","brand","bold","randChar","Math","floor","random","length","matrixIntro","durationMs","Promise","resolve","cols","
|
|
1
|
+
{"version":3,"file":"MatrixIntro.js","names":["chalk","termWidth","getTermWidth","CHARS","green0","hex","green1","green2","white","brand","bold","randChar","Math","floor","random","length","matrixIntro","durationMs","Promise","resolve","cols","rows","min","process","stdout","drops","Array","from","y","speed","trail","write","start","Date","now","fadeStart","tick","setInterval","elapsed","fading","output","d","r","line","c","dist","ch","clearInterval","label","brandRow","brandCol","max","setTimeout"],"sources":["../../../src/cli/shared/MatrixIntro.ts"],"sourcesContent":["/**\n * Matrix Rain Intro — green digital rain before chat starts\n */\n\nimport chalk from \"chalk\";\nimport { termWidth as getTermWidth } from \"./markdown.js\";\n\nconst CHARS = \"ハミヒーウシナモニサワツオリアホテマケメエカキムユラセネスタヌヘ0123456789ABCDEFZ\";\n\nconst green0 = chalk.hex(\"#003B00\");\nconst green1 = chalk.hex(\"#008F11\");\nconst green2 = chalk.hex(\"#00FF41\");\nconst white = chalk.hex(\"#FFFFFF\");\nconst brand = chalk.hex(\"#00FF41\").bold;\n\ninterface Drop {\n y: number;\n speed: number;\n trail: number;\n}\n\nfunction randChar(): string {\n return CHARS[Math.floor(Math.random() * CHARS.length)];\n}\n\nexport async function matrixIntro(durationMs = 2200): Promise<void> {\n return new Promise((resolve) => {\n const cols = getTermWidth();\n const rows = Math.min((process.stdout.rows || 24) - 1, 24);\n\n const drops: Drop[] = Array.from({ length: cols }, () => ({\n y: Math.random() * -rows * 1.5,\n speed: 0.3 + Math.random() * 0.7,\n trail: 4 + Math.floor(Math.random() * 10),\n }));\n\n // Hide cursor, clear screen\n process.stdout.write(\"\\x1b[?25l\\x1b[2J\\x1b[H\");\n\n const start = Date.now();\n const fadeStart = durationMs * 0.65;\n\n const tick = setInterval(() => {\n const elapsed = Date.now() - start;\n const fading = elapsed > fadeStart;\n\n let output = \"\\x1b[H\";\n\n for (const d of drops) {\n d.y += d.speed;\n if (d.y - d.trail > rows + 5) {\n if (fading) {\n d.y = -999;\n } else {\n d.y = Math.random() * -8;\n d.speed = 0.3 + Math.random() * 0.7;\n d.trail = 4 + Math.floor(Math.random() * 10);\n }\n }\n }\n\n for (let r = 0; r < rows; r++) {\n let line = \"\";\n for (let c = 0; c < cols; c++) {\n const d = drops[c];\n const dist = Math.floor(d.y) - r;\n\n if (dist < 0 || dist > d.trail) {\n line += \" \";\n } else {\n const ch = randChar();\n if (dist === 0) line += white(ch);\n else if (dist < d.trail * 0.3) line += green2(ch);\n else if (dist < d.trail * 0.6) line += green1(ch);\n else line += green0(ch);\n }\n }\n output += line + (r < rows - 1 ? \"\\n\" : \"\");\n }\n\n process.stdout.write(output);\n\n if (elapsed >= durationMs) {\n clearInterval(tick);\n\n // Flash brand in center\n process.stdout.write(\"\\x1b[2J\\x1b[H\");\n const label = \"◆ whale code\";\n const brandRow = Math.floor(rows / 2);\n const brandCol = Math.max(1, Math.floor((cols - label.length) / 2));\n process.stdout.write(`\\x1b[${brandRow};${brandCol}H`);\n process.stdout.write(brand(label));\n\n setTimeout(() => {\n process.stdout.write(\"\\x1b[2J\\x1b[H\\x1b[?25h\");\n resolve();\n }, 700);\n }\n }, 50);\n });\n}\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* SharedTick — single 120ms interval powering all periodic UI updates
|
|
3
|
+
*
|
|
4
|
+
* Spinner listeners notified every tick (120ms).
|
|
5
|
+
* Elapsed listeners notified every 8th tick (~960ms).
|
|
6
|
+
* Auto-start/stop based on listener count.
|
|
7
|
+
*/
|
|
8
|
+
export declare function useSpinner(): string;
|
|
9
|
+
export declare function useSharedElapsed(): number;
|
|
10
|
+
export declare function useSharedElapsedSince(startTime: number): number;
|