whale-code 6.5.5 → 6.5.6
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 +39 -31
- package/bin/{swagmanager-mcp.js → whale-code.js} +17 -2
- package/dist/cli/app.js +148 -72
- package/dist/cli/app.js.map +1 -0
- package/dist/cli/chat/AgentSelector.js +105 -10
- package/dist/cli/chat/AgentSelector.js.map +1 -0
- package/dist/cli/chat/ChatApp.d.ts +31 -0
- package/dist/cli/chat/ChatApp.js +539 -286
- package/dist/cli/chat/ChatApp.js.map +1 -0
- package/dist/cli/chat/ChatInput.js +1088 -770
- package/dist/cli/chat/ChatInput.js.map +1 -0
- package/dist/cli/chat/MarkdownText.js +39 -14
- package/dist/cli/chat/MarkdownText.js.map +1 -0
- package/dist/cli/chat/MemoryManager.js +181 -46
- package/dist/cli/chat/MemoryManager.js.map +1 -0
- package/dist/cli/chat/MessageList.d.ts +2 -3
- package/dist/cli/chat/MessageList.js +186 -45
- package/dist/cli/chat/MessageList.js.map +1 -0
- package/dist/cli/chat/ModelSelector.js +282 -63
- package/dist/cli/chat/ModelSelector.js.map +1 -0
- package/dist/cli/chat/NodeManager.js +165 -75
- package/dist/cli/chat/NodeManager.js.map +1 -0
- package/dist/cli/chat/NodeSelector.js +171 -30
- package/dist/cli/chat/NodeSelector.js.map +1 -0
- package/dist/cli/chat/PlanApproval.js +281 -57
- package/dist/cli/chat/PlanApproval.js.map +1 -0
- package/dist/cli/chat/RewindViewer.js +559 -144
- package/dist/cli/chat/RewindViewer.js.map +1 -0
- package/dist/cli/chat/SessionManager.js +137 -30
- package/dist/cli/chat/SessionManager.js.map +1 -0
- package/dist/cli/chat/SlashMenu.js +293 -164
- package/dist/cli/chat/SlashMenu.js.map +1 -0
- package/dist/cli/chat/StatusBar.js +172 -9
- package/dist/cli/chat/StatusBar.js.map +1 -0
- package/dist/cli/chat/StoreSelector.js +147 -18
- package/dist/cli/chat/StoreSelector.js.map +1 -0
- package/dist/cli/chat/StreamingText.d.ts +1 -5
- package/dist/cli/chat/StreamingText.js +22 -7
- package/dist/cli/chat/StreamingText.js.map +1 -0
- package/dist/cli/chat/SubagentPanel.d.ts +1 -2
- package/dist/cli/chat/SubagentPanel.js +612 -72
- package/dist/cli/chat/SubagentPanel.js.map +1 -0
- package/dist/cli/chat/TeamPanel.d.ts +1 -0
- package/dist/cli/chat/TeamPanel.js +230 -30
- package/dist/cli/chat/TeamPanel.js.map +1 -0
- package/dist/cli/chat/ThemeSelector.js +84 -24
- package/dist/cli/chat/ThemeSelector.js.map +1 -0
- package/dist/cli/chat/ToolIndicator.js +1476 -371
- package/dist/cli/chat/ToolIndicator.js.map +1 -0
- package/dist/cli/chat/hooks/useAgentLoop.d.ts +1 -0
- package/dist/cli/chat/hooks/useAgentLoop.js +481 -367
- package/dist/cli/chat/hooks/useAgentLoop.js.map +1 -0
- package/dist/cli/chat/hooks/useSlashCommands.d.ts +3 -14
- package/dist/cli/chat/hooks/useSlashCommands.js +744 -572
- package/dist/cli/chat/hooks/useSlashCommands.js.map +1 -0
- package/dist/cli/commands/config-cmd.js +56 -57
- package/dist/cli/commands/config-cmd.js.map +1 -0
- package/dist/cli/commands/db.js +184 -169
- package/dist/cli/commands/db.js.map +1 -0
- package/dist/cli/commands/doctor.js +212 -122
- package/dist/cli/commands/doctor.js.map +1 -0
- package/dist/cli/commands/init.js +211 -244
- package/dist/cli/commands/init.js.map +1 -0
- package/dist/cli/commands/mcp.js +127 -122
- package/dist/cli/commands/mcp.js.map +1 -0
- package/dist/cli/login/LoginApp.js +355 -141
- package/dist/cli/login/LoginApp.js.map +1 -0
- package/dist/cli/print-mode.js +196 -177
- package/dist/cli/print-mode.js.map +1 -0
- package/dist/cli/serve-mode.js +615 -530
- package/dist/cli/serve-mode.js.map +1 -0
- package/dist/cli/services/agent-config.d.ts +5 -1
- package/dist/cli/services/agent-config.js +66 -36
- package/dist/cli/services/agent-config.js.map +1 -0
- package/dist/cli/services/agent-definitions.d.ts +4 -1
- package/dist/cli/services/agent-definitions.js +97 -56
- package/dist/cli/services/agent-definitions.js.map +1 -0
- package/dist/cli/services/agent-events.js +225 -162
- package/dist/cli/services/agent-events.js.map +1 -0
- package/dist/cli/services/agent-loop.js +976 -688
- package/dist/cli/services/agent-loop.js.map +1 -0
- package/dist/cli/services/agent-worker-base.d.ts +35 -5
- package/dist/cli/services/agent-worker-base.js +337 -153
- package/dist/cli/services/agent-worker-base.js.map +1 -0
- package/dist/cli/services/api-retry.js +69 -64
- package/dist/cli/services/api-retry.js.map +1 -0
- package/dist/cli/services/auth-service.d.ts +3 -3
- package/dist/cli/services/auth-service.js +209 -132
- package/dist/cli/services/auth-service.js.map +1 -0
- package/dist/cli/services/background-processes.js +343 -267
- package/dist/cli/services/background-processes.js.map +1 -0
- package/dist/cli/services/browser-auth.d.ts +2 -2
- package/dist/cli/services/browser-auth.js +159 -118
- package/dist/cli/services/browser-auth.js.map +1 -0
- package/dist/cli/services/claude-md-loader.js +40 -36
- package/dist/cli/services/claude-md-loader.js.map +1 -0
- package/dist/cli/services/config-store.d.ts +9 -4
- package/dist/cli/services/config-store.js +164 -117
- package/dist/cli/services/config-store.js.map +1 -0
- package/dist/cli/services/debug-log.d.ts +1 -1
- package/dist/cli/services/debug-log.js +34 -35
- package/dist/cli/services/debug-log.js.map +1 -0
- package/dist/cli/services/env-detect.d.ts +7 -0
- package/dist/cli/services/env-detect.js +9 -0
- package/dist/cli/services/env-detect.js.map +1 -0
- package/dist/cli/services/error-logger.js +187 -169
- package/dist/cli/services/error-logger.js.map +1 -0
- package/dist/cli/services/file-history.d.ts +1 -1
- package/dist/cli/services/file-history.js +50 -54
- package/dist/cli/services/file-history.js.map +1 -0
- package/dist/cli/services/format-server-response.js +332 -372
- package/dist/cli/services/format-server-response.js.map +1 -0
- package/dist/cli/services/git-context.js +61 -45
- package/dist/cli/services/git-context.js.map +1 -0
- package/dist/cli/services/hooks.d.ts +2 -2
- package/dist/cli/services/hooks.js +195 -180
- package/dist/cli/services/hooks.js.map +1 -0
- package/dist/cli/services/ink-incremental.d.ts +19 -0
- package/dist/cli/services/ink-incremental.js +59 -0
- package/dist/cli/services/ink-incremental.js.map +1 -0
- package/dist/cli/services/ink-resize-fix.js +54 -44
- package/dist/cli/services/ink-resize-fix.js.map +1 -0
- package/dist/cli/services/ink-sync-output.d.ts +12 -0
- package/dist/cli/services/ink-sync-output.js +16 -0
- package/dist/cli/services/ink-sync-output.js.map +1 -0
- package/dist/cli/services/interactive-tools.js +268 -212
- package/dist/cli/services/interactive-tools.js.map +1 -0
- package/dist/cli/services/keybinding-manager.d.ts +11 -1
- package/dist/cli/services/keybinding-manager.js +126 -63
- package/dist/cli/services/keybinding-manager.js.map +1 -0
- package/dist/cli/services/local-tools.d.ts +1 -1
- package/dist/cli/services/local-tools.js +939 -656
- package/dist/cli/services/local-tools.js.map +1 -0
- package/dist/cli/services/lsp-manager.js +757 -594
- package/dist/cli/services/lsp-manager.js.map +1 -0
- package/dist/cli/services/mcp-client.d.ts +1 -1
- package/dist/cli/services/mcp-client.js +173 -134
- package/dist/cli/services/mcp-client.js.map +1 -0
- package/dist/cli/services/memory-manager.js +53 -40
- package/dist/cli/services/memory-manager.js.map +1 -0
- package/dist/cli/services/model-manager.js +55 -40
- package/dist/cli/services/model-manager.js.map +1 -0
- package/dist/cli/services/model-router.js +115 -85
- package/dist/cli/services/model-router.js.map +1 -0
- package/dist/cli/services/paths.d.ts +30 -0
- package/dist/cli/services/paths.js +81 -0
- package/dist/cli/services/paths.js.map +1 -0
- package/dist/cli/services/permission-modes.js +32 -25
- package/dist/cli/services/permission-modes.js.map +1 -0
- package/dist/cli/services/rewind.js +182 -168
- package/dist/cli/services/rewind.js.map +1 -0
- package/dist/cli/services/ripgrep.js +115 -115
- package/dist/cli/services/ripgrep.js.map +1 -0
- package/dist/cli/services/sandbox.d.ts +1 -1
- package/dist/cli/services/sandbox.js +58 -37
- package/dist/cli/services/sandbox.js.map +1 -0
- package/dist/cli/services/server-tools.js +738 -565
- package/dist/cli/services/server-tools.js.map +1 -0
- package/dist/cli/services/session-persistence.js +69 -74
- package/dist/cli/services/session-persistence.js.map +1 -0
- package/dist/cli/services/subagent-worker.js +42 -27
- package/dist/cli/services/subagent-worker.js.map +1 -0
- package/dist/cli/services/subagent.d.ts +2 -0
- package/dist/cli/services/subagent.js +605 -433
- package/dist/cli/services/subagent.js.map +1 -0
- package/dist/cli/services/system-prompt.js +86 -78
- package/dist/cli/services/system-prompt.js.map +1 -0
- package/dist/cli/services/task-decomposer.d.ts +1 -1
- package/dist/cli/services/task-decomposer.js +172 -139
- package/dist/cli/services/task-decomposer.js.map +1 -0
- package/dist/cli/services/team-lead.d.ts +2 -2
- package/dist/cli/services/team-lead.js +727 -529
- package/dist/cli/services/team-lead.js.map +1 -0
- package/dist/cli/services/team-state.js +319 -319
- package/dist/cli/services/team-state.js.map +1 -0
- package/dist/cli/services/teammate.d.ts +8 -2
- package/dist/cli/services/teammate.js +857 -569
- package/dist/cli/services/teammate.js.map +1 -0
- package/dist/cli/services/telemetry.d.ts +6 -1
- package/dist/cli/services/telemetry.js +180 -157
- package/dist/cli/services/telemetry.js.map +1 -0
- package/dist/cli/services/tools/agent-tools.d.ts +3 -3
- package/dist/cli/services/tools/agent-tools.js +480 -322
- package/dist/cli/services/tools/agent-tools.js.map +1 -0
- package/dist/cli/services/tools/file-ops.js +563 -450
- package/dist/cli/services/tools/file-ops.js.map +1 -0
- package/dist/cli/services/tools/search-tools.js +231 -162
- package/dist/cli/services/tools/search-tools.js.map +1 -0
- package/dist/cli/services/tools/shell-exec.js +197 -151
- package/dist/cli/services/tools/shell-exec.js.map +1 -0
- package/dist/cli/services/tools/task-manager.js +206 -173
- package/dist/cli/services/tools/task-manager.js.map +1 -0
- package/dist/cli/services/tools/web-tools.js +388 -341
- package/dist/cli/services/tools/web-tools.js.map +1 -0
- package/dist/cli/setup/SetupApp.d.ts +2 -2
- package/dist/cli/setup/SetupApp.js +608 -160
- package/dist/cli/setup/SetupApp.js.map +1 -0
- package/dist/cli/shared/ErrorBoundary.d.ts +22 -0
- package/dist/cli/shared/ErrorBoundary.js +73 -0
- package/dist/cli/shared/ErrorBoundary.js.map +1 -0
- package/dist/cli/shared/MatrixIntro.js +66 -69
- package/dist/cli/shared/MatrixIntro.js.map +1 -0
- package/dist/cli/shared/SpinnerSlot.d.ts +14 -0
- package/dist/cli/shared/SpinnerSlot.js +63 -0
- package/dist/cli/shared/SpinnerSlot.js.map +1 -0
- package/dist/cli/shared/Theme.d.ts +1 -1
- package/dist/cli/shared/Theme.js +136 -92
- package/dist/cli/shared/Theme.js.map +1 -0
- package/dist/cli/shared/WhaleBanner.js +99 -11
- package/dist/cli/shared/WhaleBanner.js.map +1 -0
- package/dist/cli/shared/markdown.d.ts +3 -1
- package/dist/cli/shared/markdown.js +736 -674
- package/dist/cli/shared/markdown.js.map +1 -0
- package/dist/cli/shared/marked-terminal.d.js +2 -0
- package/dist/cli/shared/marked-terminal.d.js.map +1 -0
- package/dist/cli/shared/theme-manager.js +99 -90
- package/dist/cli/shared/theme-manager.js.map +1 -0
- package/dist/cli/shared/theme-presets.js +256 -254
- package/dist/cli/shared/theme-presets.js.map +1 -0
- package/dist/cli/status/StatusApp.js +235 -86
- package/dist/cli/status/StatusApp.js.map +1 -0
- package/dist/cli/stores/StoreApp.js +275 -65
- package/dist/cli/stores/StoreApp.js.map +1 -0
- package/dist/index.d.ts +2 -2
- package/dist/index.js +509 -396
- package/dist/index.js.map +1 -0
- package/dist/local-agent/connection.d.ts +2 -2
- package/dist/local-agent/connection.js +352 -293
- package/dist/local-agent/connection.js.map +1 -0
- package/dist/local-agent/discovery.js +259 -122
- package/dist/local-agent/discovery.js.map +1 -0
- package/dist/local-agent/executor.js +216 -193
- package/dist/local-agent/executor.js.map +1 -0
- package/dist/local-agent/index.d.ts +2 -2
- package/dist/local-agent/index.js +156 -156
- package/dist/local-agent/index.js.map +1 -0
- package/dist/node/adapters/base.js +18 -8
- package/dist/node/adapters/base.js.map +1 -0
- package/dist/node/adapters/discord.js +286 -275
- package/dist/node/adapters/discord.js.map +1 -0
- package/dist/node/adapters/email.js +189 -202
- package/dist/node/adapters/email.js.map +1 -0
- package/dist/node/adapters/imessage.js +145 -142
- package/dist/node/adapters/imessage.js.map +1 -0
- package/dist/node/adapters/slack.js +237 -236
- package/dist/node/adapters/slack.js.map +1 -0
- package/dist/node/adapters/sms.js +149 -151
- package/dist/node/adapters/sms.js.map +1 -0
- package/dist/node/adapters/telegram.js +88 -92
- package/dist/node/adapters/telegram.js.map +1 -0
- package/dist/node/adapters/webchat.js +160 -136
- package/dist/node/adapters/webchat.js.map +1 -0
- package/dist/node/adapters/whatsapp.js +212 -215
- package/dist/node/adapters/whatsapp.js.map +1 -0
- package/dist/node/cli.js +884 -653
- package/dist/node/cli.js.map +1 -0
- package/dist/node/config.js +20 -18
- package/dist/node/config.js.map +1 -0
- package/dist/node/gateway-client.js +191 -181
- package/dist/node/gateway-client.js.map +1 -0
- package/dist/node/portal/clipboard.js +161 -130
- package/dist/node/portal/clipboard.js.map +1 -0
- package/dist/node/portal/discovery.js +51 -45
- package/dist/node/portal/discovery.js.map +1 -0
- package/dist/node/portal/forward.js +64 -58
- package/dist/node/portal/forward.js.map +1 -0
- package/dist/node/portal/index.js +246 -221
- package/dist/node/portal/index.js.map +1 -0
- package/dist/node/portal/multiplexer.js +192 -182
- package/dist/node/portal/multiplexer.js.map +1 -0
- package/dist/node/portal/permissions.js +102 -70
- package/dist/node/portal/permissions.js.map +1 -0
- package/dist/node/portal/protocol.js +153 -116
- package/dist/node/portal/protocol.js.map +1 -0
- package/dist/node/portal/screen.js +80 -69
- package/dist/node/portal/screen.js.map +1 -0
- package/dist/node/portal/session.js +124 -117
- package/dist/node/portal/session.js.map +1 -0
- package/dist/node/portal/shell.js +140 -113
- package/dist/node/portal/shell.js.map +1 -0
- package/dist/node/portal/stream.js +77 -75
- package/dist/node/portal/stream.js.map +1 -0
- package/dist/node/portal/transfer.js +190 -167
- package/dist/node/portal/transfer.js.map +1 -0
- package/dist/node/portal/ui.js +124 -99
- package/dist/node/portal/ui.js.map +1 -0
- package/dist/node/remote-desktop/compile-helper.js +50 -45
- package/dist/node/remote-desktop/compile-helper.js.map +1 -0
- package/dist/node/remote-desktop/index.js +215 -187
- package/dist/node/remote-desktop/index.js.map +1 -0
- package/dist/node/remote-desktop/protocol.js +45 -29
- package/dist/node/remote-desktop/protocol.js.map +1 -0
- package/dist/node/runtime.js +493 -410
- package/dist/node/runtime.js.map +1 -0
- package/dist/server/handlers/__test-utils__/test-db.js +39 -89
- package/dist/server/handlers/__test-utils__/test-db.js.map +1 -0
- package/dist/server/handlers/analytics.js +467 -261
- package/dist/server/handlers/analytics.js.map +1 -0
- package/dist/server/handlers/api-docs.js +1030 -895
- package/dist/server/handlers/api-docs.js.map +1 -0
- package/dist/server/handlers/api-keys.js +291 -242
- package/dist/server/handlers/api-keys.js.map +1 -0
- package/dist/server/handlers/billing.js +330 -239
- package/dist/server/handlers/billing.js.map +1 -0
- package/dist/server/handlers/browser.js +468 -395
- package/dist/server/handlers/browser.js.map +1 -0
- package/dist/server/handlers/catalog.js +1377 -978
- package/dist/server/handlers/catalog.js.map +1 -0
- package/dist/server/handlers/clickhouse.js +157 -109
- package/dist/server/handlers/clickhouse.js.map +1 -0
- package/dist/server/handlers/comms.js +1439 -984
- package/dist/server/handlers/comms.js.map +1 -0
- package/dist/server/handlers/creations.js +461 -394
- package/dist/server/handlers/creations.js.map +1 -0
- package/dist/server/handlers/crm.js +1082 -791
- package/dist/server/handlers/crm.js.map +1 -0
- package/dist/server/handlers/discovery.js +251 -232
- package/dist/server/handlers/discovery.js.map +1 -0
- package/dist/server/handlers/embeddings.js +241 -164
- package/dist/server/handlers/embeddings.js.map +1 -0
- package/dist/server/handlers/enrichment.js +887 -718
- package/dist/server/handlers/enrichment.js.map +1 -0
- package/dist/server/handlers/image-gen.js +467 -376
- package/dist/server/handlers/image-gen.js.map +1 -0
- package/dist/server/handlers/inventory.js +797 -424
- package/dist/server/handlers/inventory.js.map +1 -0
- package/dist/server/handlers/kali.js +272 -230
- package/dist/server/handlers/kali.js.map +1 -0
- package/dist/server/handlers/llm-providers.js +803 -580
- package/dist/server/handlers/llm-providers.js.map +1 -0
- package/dist/server/handlers/local-agent.js +133 -105
- package/dist/server/handlers/local-agent.js.map +1 -0
- package/dist/server/handlers/media.js +1179 -857
- package/dist/server/handlers/media.js.map +1 -0
- package/dist/server/handlers/meta-ads.js +2669 -2093
- package/dist/server/handlers/meta-ads.js.map +1 -0
- package/dist/server/handlers/nodes.js +1321 -913
- package/dist/server/handlers/nodes.js.map +1 -0
- package/dist/server/handlers/operations.js +183 -157
- package/dist/server/handlers/operations.js.map +1 -0
- package/dist/server/handlers/platform.js +346 -210
- package/dist/server/handlers/platform.js.map +1 -0
- package/dist/server/handlers/remove-bg.js +118 -86
- package/dist/server/handlers/remove-bg.js.map +1 -0
- package/dist/server/handlers/storefront.js +586 -446
- package/dist/server/handlers/storefront.js.map +1 -0
- package/dist/server/handlers/supply-chain.js +546 -326
- package/dist/server/handlers/supply-chain.js.map +1 -0
- package/dist/server/handlers/transcription.js +106 -97
- package/dist/server/handlers/transcription.js.map +1 -0
- package/dist/server/handlers/video-gen.js +593 -424
- package/dist/server/handlers/video-gen.js.map +1 -0
- package/dist/server/handlers/voice.js +1458 -1039
- package/dist/server/handlers/voice.js.map +1 -0
- package/dist/server/handlers/workflow-steps.js +2837 -2116
- package/dist/server/handlers/workflow-steps.js.map +1 -0
- package/dist/server/handlers/workflows.js +1630 -933
- package/dist/server/handlers/workflows.js.map +1 -0
- package/dist/server/index.js +3167 -2422
- package/dist/server/index.js.map +1 -0
- package/dist/server/lib/batch-client.js +471 -409
- package/dist/server/lib/batch-client.js.map +1 -0
- package/dist/server/lib/clickhouse-buffer.js +118 -104
- package/dist/server/lib/clickhouse-buffer.js.map +1 -0
- package/dist/server/lib/clickhouse-client.js +107 -107
- package/dist/server/lib/clickhouse-client.js.map +1 -0
- package/dist/server/lib/coa-renderer.js +1786 -356
- package/dist/server/lib/coa-renderer.js.map +1 -0
- package/dist/server/lib/code-worker-pool.js +227 -177
- package/dist/server/lib/code-worker-pool.js.map +1 -0
- package/dist/server/lib/code-worker.js +174 -164
- package/dist/server/lib/code-worker.js.map +1 -0
- package/dist/server/lib/compaction-service.d.ts +2 -12
- package/dist/server/lib/compaction-service.js +74 -184
- package/dist/server/lib/compaction-service.js.map +1 -0
- package/dist/server/lib/logger.js +36 -24
- package/dist/server/lib/logger.js.map +1 -0
- package/dist/server/lib/otel.js +101 -80
- package/dist/server/lib/otel.js.map +1 -0
- package/dist/server/lib/pdf-renderer.js +952 -788
- package/dist/server/lib/pdf-renderer.js.map +1 -0
- package/dist/server/lib/prompt-sanitizer.js +188 -108
- package/dist/server/lib/prompt-sanitizer.js.map +1 -0
- package/dist/server/lib/provider-capabilities.js +136 -138
- package/dist/server/lib/provider-capabilities.js.map +1 -0
- package/dist/server/lib/provider-failover.js +190 -168
- package/dist/server/lib/provider-failover.js.map +1 -0
- package/dist/server/lib/rate-limiter.js +186 -117
- package/dist/server/lib/rate-limiter.js.map +1 -0
- package/dist/server/lib/react-pdf-layout.js +551 -382
- package/dist/server/lib/react-pdf-layout.js.map +1 -0
- package/dist/server/lib/server-agent-loop.d.ts +4 -1
- package/dist/server/lib/server-agent-loop.js +906 -634
- package/dist/server/lib/server-agent-loop.js.map +1 -0
- package/dist/server/lib/server-subagent.js +260 -164
- package/dist/server/lib/server-subagent.js.map +1 -0
- package/dist/server/lib/session-checkpoint.js +105 -96
- package/dist/server/lib/session-checkpoint.js.map +1 -0
- package/dist/server/lib/ssrf-guard.js +193 -184
- package/dist/server/lib/ssrf-guard.js.map +1 -0
- package/dist/server/lib/supabase-client.js +94 -82
- package/dist/server/lib/supabase-client.js.map +1 -0
- package/dist/server/lib/template-resolver.js +154 -176
- package/dist/server/lib/template-resolver.js.map +1 -0
- package/dist/server/lib/utils.js +242 -133
- package/dist/server/lib/utils.js.map +1 -0
- package/dist/server/local-agent-gateway.d.ts +2 -2
- package/dist/server/local-agent-gateway.js +785 -627
- package/dist/server/local-agent-gateway.js.map +1 -0
- package/dist/server/providers/anthropic.js +250 -172
- package/dist/server/providers/anthropic.js.map +1 -0
- package/dist/server/providers/bedrock.js +217 -158
- package/dist/server/providers/bedrock.js.map +1 -0
- package/dist/server/providers/gemini.js +548 -418
- package/dist/server/providers/gemini.js.map +1 -0
- package/dist/server/providers/openai.js +571 -437
- package/dist/server/providers/openai.js.map +1 -0
- package/dist/server/providers/registry.js +23 -18
- package/dist/server/providers/registry.js.map +1 -0
- package/dist/server/providers/shared.js +123 -95
- package/dist/server/providers/shared.js.map +1 -0
- package/dist/server/providers/types.js +1 -11
- package/dist/server/providers/types.js.map +1 -0
- package/dist/server/proxy-handlers.js +209 -165
- package/dist/server/proxy-handlers.js.map +1 -0
- package/dist/server/tool-router.js +959 -599
- package/dist/server/tool-router.js.map +1 -0
- package/dist/server/validation.js +248 -188
- package/dist/server/validation.js.map +1 -0
- package/dist/server/worker.js +202 -133
- package/dist/server/worker.js.map +1 -0
- package/dist/setup.d.ts +2 -2
- package/dist/setup.js +151 -147
- package/dist/setup.js.map +1 -0
- package/dist/shared/agent-core.d.ts +115 -26
- package/dist/shared/agent-core.js +956 -522
- package/dist/shared/agent-core.js.map +1 -0
- package/dist/shared/anthropic-types.js +1 -6
- package/dist/shared/anthropic-types.js.map +1 -0
- package/dist/shared/api-client.d.ts +16 -9
- package/dist/shared/api-client.js +419 -327
- package/dist/shared/api-client.js.map +1 -0
- package/dist/shared/compaction.d.ts +36 -0
- package/dist/shared/compaction.js +138 -0
- package/dist/shared/compaction.js.map +1 -0
- package/dist/shared/constants.js +67 -64
- package/dist/shared/constants.js.map +1 -0
- package/dist/shared/sse-parser.js +221 -219
- package/dist/shared/sse-parser.js.map +1 -0
- package/dist/shared/tool-dispatch.d.ts +4 -0
- package/dist/shared/tool-dispatch.js +226 -165
- package/dist/shared/tool-dispatch.js.map +1 -0
- package/dist/shared/types.js +1 -6
- package/dist/shared/types.js.map +1 -0
- package/dist/types/cli-highlight.d.js +2 -0
- package/dist/types/cli-highlight.d.js.map +1 -0
- package/dist/types/diff.d.js +2 -0
- package/dist/types/diff.d.js.map +1 -0
- package/dist/types/pdf-parse.d.js +2 -0
- package/dist/types/pdf-parse.d.js.map +1 -0
- package/dist/updater.d.ts +1 -1
- package/dist/updater.js +118 -92
- package/dist/updater.js.map +1 -0
- package/dist/webchat/widget.js +227 -380
- package/dist/webchat/widget.js.map +1 -0
- package/package.json +22 -10
- package/vendor/ink/build/ansi-tokenizer.d.ts +38 -0
- package/vendor/ink/build/ansi-tokenizer.js +316 -0
- package/vendor/ink/build/ansi-tokenizer.js.map +1 -0
- package/vendor/ink/build/apply-styles.js +175 -0
- package/vendor/ink/build/build-layout.js +77 -0
- package/vendor/ink/build/calculate-wrapped-text.js +53 -0
- package/vendor/ink/build/colorize.d.ts +3 -0
- package/vendor/ink/build/colorize.js +48 -0
- package/vendor/ink/build/colorize.js.map +1 -0
- package/vendor/ink/build/components/AccessibilityContext.d.ts +3 -0
- package/vendor/ink/build/components/AccessibilityContext.js +5 -0
- package/vendor/ink/build/components/AccessibilityContext.js.map +1 -0
- package/vendor/ink/build/components/App.d.ts +18 -0
- package/vendor/ink/build/components/App.js +351 -0
- package/vendor/ink/build/components/App.js.map +1 -0
- package/vendor/ink/build/components/AppContext.d.ts +15 -0
- package/vendor/ink/build/components/AppContext.js +11 -0
- package/vendor/ink/build/components/AppContext.js.map +1 -0
- package/vendor/ink/build/components/BackgroundContext.d.ts +4 -0
- package/vendor/ink/build/components/BackgroundContext.js +3 -0
- package/vendor/ink/build/components/BackgroundContext.js.map +1 -0
- package/vendor/ink/build/components/Box.d.ts +117 -0
- package/vendor/ink/build/components/Box.js +34 -0
- package/vendor/ink/build/components/Box.js.map +1 -0
- package/vendor/ink/build/components/Color.js +62 -0
- package/vendor/ink/build/components/Cursor.d.ts +83 -0
- package/vendor/ink/build/components/Cursor.js +53 -0
- package/vendor/ink/build/components/Cursor.js.map +1 -0
- package/vendor/ink/build/components/CursorContext.d.ts +11 -0
- package/vendor/ink/build/components/CursorContext.js +8 -0
- package/vendor/ink/build/components/CursorContext.js.map +1 -0
- package/vendor/ink/build/components/ErrorBoundary.d.ts +18 -0
- package/vendor/ink/build/components/ErrorBoundary.js +23 -0
- package/vendor/ink/build/components/ErrorBoundary.js.map +1 -0
- package/vendor/ink/build/components/ErrorOverview.d.ts +6 -0
- package/vendor/ink/build/components/ErrorOverview.js +84 -0
- package/vendor/ink/build/components/ErrorOverview.js.map +1 -0
- package/vendor/ink/build/components/FocusContext.d.ts +16 -0
- package/vendor/ink/build/components/FocusContext.js +17 -0
- package/vendor/ink/build/components/FocusContext.js.map +1 -0
- package/vendor/ink/build/components/Newline.d.ts +13 -0
- package/vendor/ink/build/components/Newline.js +8 -0
- package/vendor/ink/build/components/Newline.js.map +1 -0
- package/vendor/ink/build/components/Spacer.d.ts +7 -0
- package/vendor/ink/build/components/Spacer.js +11 -0
- package/vendor/ink/build/components/Spacer.js.map +1 -0
- package/vendor/ink/build/components/Static.d.ts +24 -0
- package/vendor/ink/build/components/Static.js +28 -0
- package/vendor/ink/build/components/Static.js.map +1 -0
- package/vendor/ink/build/components/StderrContext.d.ts +15 -0
- package/vendor/ink/build/components/StderrContext.js +13 -0
- package/vendor/ink/build/components/StderrContext.js.map +1 -0
- package/vendor/ink/build/components/StdinContext.d.ts +22 -0
- package/vendor/ink/build/components/StdinContext.js +19 -0
- package/vendor/ink/build/components/StdinContext.js.map +1 -0
- package/vendor/ink/build/components/StdoutContext.d.ts +15 -0
- package/vendor/ink/build/components/StdoutContext.js +13 -0
- package/vendor/ink/build/components/StdoutContext.js.map +1 -0
- package/vendor/ink/build/components/Text.d.ts +55 -0
- package/vendor/ink/build/components/Text.js +50 -0
- package/vendor/ink/build/components/Text.js.map +1 -0
- package/vendor/ink/build/components/Transform.d.ts +16 -0
- package/vendor/ink/build/components/Transform.js +15 -0
- package/vendor/ink/build/components/Transform.js.map +1 -0
- package/vendor/ink/build/cursor-helpers.d.ts +38 -0
- package/vendor/ink/build/cursor-helpers.js +56 -0
- package/vendor/ink/build/cursor-helpers.js.map +1 -0
- package/vendor/ink/build/devtools-window-polyfill.d.ts +1 -0
- package/vendor/ink/build/devtools-window-polyfill.js +65 -0
- package/vendor/ink/build/devtools-window-polyfill.js.map +1 -0
- package/vendor/ink/build/devtools.d.ts +1 -0
- package/vendor/ink/build/devtools.js +11 -0
- package/vendor/ink/build/devtools.js.map +1 -0
- package/vendor/ink/build/dom.d.ts +56 -0
- package/vendor/ink/build/dom.js +124 -0
- package/vendor/ink/build/dom.js.map +1 -0
- package/vendor/ink/build/experimental/apply-style.js +140 -0
- package/vendor/ink/build/experimental/dom.js +123 -0
- package/vendor/ink/build/experimental/output.js +91 -0
- package/vendor/ink/build/experimental/reconciler.js +141 -0
- package/vendor/ink/build/experimental/renderer.js +81 -0
- package/vendor/ink/build/get-max-width.d.ts +3 -0
- package/vendor/ink/build/get-max-width.js +10 -0
- package/vendor/ink/build/get-max-width.js.map +1 -0
- package/vendor/ink/build/hooks/use-app.d.ts +5 -0
- package/vendor/ink/build/hooks/use-app.js +8 -0
- package/vendor/ink/build/hooks/use-app.js.map +1 -0
- package/vendor/ink/build/hooks/use-cursor.d.ts +12 -0
- package/vendor/ink/build/hooks/use-cursor.js +29 -0
- package/vendor/ink/build/hooks/use-cursor.js.map +1 -0
- package/vendor/ink/build/hooks/use-focus-manager.d.ts +28 -0
- package/vendor/ink/build/hooks/use-focus-manager.js +17 -0
- package/vendor/ink/build/hooks/use-focus-manager.js.map +1 -0
- package/vendor/ink/build/hooks/use-focus.d.ts +29 -0
- package/vendor/ink/build/hooks/use-focus.js +42 -0
- package/vendor/ink/build/hooks/use-focus.js.map +1 -0
- package/vendor/ink/build/hooks/use-input.d.ts +131 -0
- package/vendor/ink/build/hooks/use-input.js +124 -0
- package/vendor/ink/build/hooks/use-input.js.map +1 -0
- package/vendor/ink/build/hooks/use-is-screen-reader-enabled.d.ts +5 -0
- package/vendor/ink/build/hooks/use-is-screen-reader-enabled.js +11 -0
- package/vendor/ink/build/hooks/use-is-screen-reader-enabled.js.map +1 -0
- package/vendor/ink/build/hooks/use-stderr.d.ts +5 -0
- package/vendor/ink/build/hooks/use-stderr.js +8 -0
- package/vendor/ink/build/hooks/use-stderr.js.map +1 -0
- package/vendor/ink/build/hooks/use-stdin.d.ts +5 -0
- package/vendor/ink/build/hooks/use-stdin.js +8 -0
- package/vendor/ink/build/hooks/use-stdin.js.map +1 -0
- package/vendor/ink/build/hooks/use-stdout.d.ts +5 -0
- package/vendor/ink/build/hooks/use-stdout.js +8 -0
- package/vendor/ink/build/hooks/use-stdout.js.map +1 -0
- package/vendor/ink/build/hooks/useInput.js +38 -0
- package/vendor/ink/build/index.d.ts +34 -0
- package/vendor/ink/build/index.js +20 -0
- package/vendor/ink/build/index.js.map +1 -0
- package/vendor/ink/build/ink.d.ts +90 -0
- package/vendor/ink/build/ink.js +654 -0
- package/vendor/ink/build/ink.js.map +1 -0
- package/vendor/ink/build/input-parser.d.ts +7 -0
- package/vendor/ink/build/input-parser.js +154 -0
- package/vendor/ink/build/input-parser.js.map +1 -0
- package/vendor/ink/build/instance.js +205 -0
- package/vendor/ink/build/instances.d.ts +3 -0
- package/vendor/ink/build/instances.js +8 -0
- package/vendor/ink/build/instances.js.map +1 -0
- package/vendor/ink/build/kitty-keyboard.d.ts +23 -0
- package/vendor/ink/build/kitty-keyboard.js +32 -0
- package/vendor/ink/build/kitty-keyboard.js.map +1 -0
- package/vendor/ink/build/layout.d.ts +7 -0
- package/vendor/ink/build/layout.js +33 -0
- package/vendor/ink/build/layout.js.map +1 -0
- package/vendor/ink/build/log-update.d.ts +19 -0
- package/vendor/ink/build/log-update.js +243 -0
- package/vendor/ink/build/log-update.js.map +1 -0
- package/vendor/ink/build/measure-element.d.ts +16 -0
- package/vendor/ink/build/measure-element.js +9 -0
- package/vendor/ink/build/measure-element.js.map +1 -0
- package/vendor/ink/build/measure-text.d.ts +6 -0
- package/vendor/ink/build/measure-text.js +21 -0
- package/vendor/ink/build/measure-text.js.map +1 -0
- package/vendor/ink/build/options.d.ts +52 -0
- package/vendor/ink/build/options.js +2 -0
- package/vendor/ink/build/options.js.map +1 -0
- package/vendor/ink/build/output.d.ts +35 -0
- package/vendor/ink/build/output.js +183 -0
- package/vendor/ink/build/output.js.map +1 -0
- package/vendor/ink/build/parse-keypress.d.ts +22 -0
- package/vendor/ink/build/parse-keypress.js +493 -0
- package/vendor/ink/build/parse-keypress.js.map +1 -0
- package/vendor/ink/build/reconciler.d.ts +4 -0
- package/vendor/ink/build/reconciler.js +274 -0
- package/vendor/ink/build/reconciler.js.map +1 -0
- package/vendor/ink/build/render-background.d.ts +4 -0
- package/vendor/ink/build/render-background.js +25 -0
- package/vendor/ink/build/render-background.js.map +1 -0
- package/vendor/ink/build/render-border.d.ts +4 -0
- package/vendor/ink/build/render-border.js +73 -0
- package/vendor/ink/build/render-border.js.map +1 -0
- package/vendor/ink/build/render-node-to-output.d.ts +14 -0
- package/vendor/ink/build/render-node-to-output.js +147 -0
- package/vendor/ink/build/render-node-to-output.js.map +1 -0
- package/vendor/ink/build/render-to-string.d.ts +38 -0
- package/vendor/ink/build/render-to-string.js +115 -0
- package/vendor/ink/build/render-to-string.js.map +1 -0
- package/vendor/ink/build/render.d.ts +121 -0
- package/vendor/ink/build/render.js +55 -0
- package/vendor/ink/build/render.js.map +1 -0
- package/vendor/ink/build/renderer.d.ts +8 -0
- package/vendor/ink/build/renderer.js +55 -0
- package/vendor/ink/build/renderer.js.map +1 -0
- package/vendor/ink/build/sanitize-ansi.d.ts +2 -0
- package/vendor/ink/build/sanitize-ansi.js +27 -0
- package/vendor/ink/build/sanitize-ansi.js.map +1 -0
- package/vendor/ink/build/screen-reader-update.d.ts +13 -0
- package/vendor/ink/build/screen-reader-update.js +38 -0
- package/vendor/ink/build/screen-reader-update.js.map +1 -0
- package/vendor/ink/build/squash-text-nodes.d.ts +3 -0
- package/vendor/ink/build/squash-text-nodes.js +36 -0
- package/vendor/ink/build/squash-text-nodes.js.map +1 -0
- package/vendor/ink/build/styles.d.ts +240 -0
- package/vendor/ink/build/styles.js +232 -0
- package/vendor/ink/build/styles.js.map +1 -0
- package/vendor/ink/build/utils.d.ts +2 -0
- package/vendor/ink/build/utils.js +4 -0
- package/vendor/ink/build/utils.js.map +1 -0
- package/vendor/ink/build/wrap-text.d.ts +3 -0
- package/vendor/ink/build/wrap-text.js +31 -0
- package/vendor/ink/build/wrap-text.js.map +1 -0
- package/vendor/ink/build/write-synchronized.d.ts +4 -0
- package/vendor/ink/build/write-synchronized.js +7 -0
- package/vendor/ink/build/write-synchronized.js.map +1 -0
- package/vendor/ink/license +10 -0
- package/vendor/ink/node_modules/@types/node/LICENSE +21 -0
- package/vendor/ink/node_modules/@types/node/README.md +15 -0
- package/vendor/ink/node_modules/@types/node/assert/strict.d.ts +105 -0
- package/vendor/ink/node_modules/@types/node/assert.d.ts +955 -0
- package/vendor/ink/node_modules/@types/node/async_hooks.d.ts +623 -0
- package/vendor/ink/node_modules/@types/node/buffer.buffer.d.ts +466 -0
- package/vendor/ink/node_modules/@types/node/buffer.d.ts +1810 -0
- package/vendor/ink/node_modules/@types/node/child_process.d.ts +1428 -0
- package/vendor/ink/node_modules/@types/node/cluster.d.ts +486 -0
- package/vendor/ink/node_modules/@types/node/compatibility/iterators.d.ts +21 -0
- package/vendor/ink/node_modules/@types/node/console.d.ts +151 -0
- package/vendor/ink/node_modules/@types/node/constants.d.ts +20 -0
- package/vendor/ink/node_modules/@types/node/crypto.d.ts +4065 -0
- package/vendor/ink/node_modules/@types/node/dgram.d.ts +564 -0
- package/vendor/ink/node_modules/@types/node/diagnostics_channel.d.ts +576 -0
- package/vendor/ink/node_modules/@types/node/dns/promises.d.ts +503 -0
- package/vendor/ink/node_modules/@types/node/dns.d.ts +922 -0
- package/vendor/ink/node_modules/@types/node/domain.d.ts +166 -0
- package/vendor/ink/node_modules/@types/node/events.d.ts +1054 -0
- package/vendor/ink/node_modules/@types/node/fs/promises.d.ts +1329 -0
- package/vendor/ink/node_modules/@types/node/fs.d.ts +4676 -0
- package/vendor/ink/node_modules/@types/node/globals.d.ts +150 -0
- package/vendor/ink/node_modules/@types/node/globals.typedarray.d.ts +101 -0
- package/vendor/ink/node_modules/@types/node/http.d.ts +2167 -0
- package/vendor/ink/node_modules/@types/node/http2.d.ts +2480 -0
- package/vendor/ink/node_modules/@types/node/https.d.ts +405 -0
- package/vendor/ink/node_modules/@types/node/index.d.ts +115 -0
- package/vendor/ink/node_modules/@types/node/inspector/promises.d.ts +41 -0
- package/vendor/ink/node_modules/@types/node/inspector.d.ts +224 -0
- package/vendor/ink/node_modules/@types/node/inspector.generated.d.ts +4226 -0
- package/vendor/ink/node_modules/@types/node/module.d.ts +819 -0
- package/vendor/ink/node_modules/@types/node/net.d.ts +933 -0
- package/vendor/ink/node_modules/@types/node/os.d.ts +507 -0
- package/vendor/ink/node_modules/@types/node/package.json +155 -0
- package/vendor/ink/node_modules/@types/node/path/posix.d.ts +8 -0
- package/vendor/ink/node_modules/@types/node/path/win32.d.ts +8 -0
- package/vendor/ink/node_modules/@types/node/path.d.ts +187 -0
- package/vendor/ink/node_modules/@types/node/perf_hooks.d.ts +643 -0
- package/vendor/ink/node_modules/@types/node/process.d.ts +2156 -0
- package/vendor/ink/node_modules/@types/node/punycode.d.ts +117 -0
- package/vendor/ink/node_modules/@types/node/querystring.d.ts +152 -0
- package/vendor/ink/node_modules/@types/node/quic.d.ts +910 -0
- package/vendor/ink/node_modules/@types/node/readline/promises.d.ts +161 -0
- package/vendor/ink/node_modules/@types/node/readline.d.ts +541 -0
- package/vendor/ink/node_modules/@types/node/repl.d.ts +415 -0
- package/vendor/ink/node_modules/@types/node/sea.d.ts +162 -0
- package/vendor/ink/node_modules/@types/node/sqlite.d.ts +955 -0
- package/vendor/ink/node_modules/@types/node/stream/consumers.d.ts +38 -0
- package/vendor/ink/node_modules/@types/node/stream/promises.d.ts +211 -0
- package/vendor/ink/node_modules/@types/node/stream/web.d.ts +296 -0
- package/vendor/ink/node_modules/@types/node/stream.d.ts +1760 -0
- package/vendor/ink/node_modules/@types/node/string_decoder.d.ts +67 -0
- package/vendor/ink/node_modules/@types/node/test/reporters.d.ts +96 -0
- package/vendor/ink/node_modules/@types/node/test.d.ts +2240 -0
- package/vendor/ink/node_modules/@types/node/timers/promises.d.ts +108 -0
- package/vendor/ink/node_modules/@types/node/timers.d.ts +159 -0
- package/vendor/ink/node_modules/@types/node/tls.d.ts +1198 -0
- package/vendor/ink/node_modules/@types/node/trace_events.d.ts +197 -0
- package/vendor/ink/node_modules/@types/node/ts5.6/buffer.buffer.d.ts +462 -0
- package/vendor/ink/node_modules/@types/node/ts5.6/compatibility/float16array.d.ts +71 -0
- package/vendor/ink/node_modules/@types/node/ts5.6/globals.typedarray.d.ts +36 -0
- package/vendor/ink/node_modules/@types/node/ts5.6/index.d.ts +117 -0
- package/vendor/ink/node_modules/@types/node/ts5.7/compatibility/float16array.d.ts +72 -0
- package/vendor/ink/node_modules/@types/node/ts5.7/index.d.ts +117 -0
- package/vendor/ink/node_modules/@types/node/tty.d.ts +250 -0
- package/vendor/ink/node_modules/@types/node/url.d.ts +519 -0
- package/vendor/ink/node_modules/@types/node/util/types.d.ts +558 -0
- package/vendor/ink/node_modules/@types/node/util.d.ts +1662 -0
- package/vendor/ink/node_modules/@types/node/v8.d.ts +983 -0
- package/vendor/ink/node_modules/@types/node/vm.d.ts +1208 -0
- package/vendor/ink/node_modules/@types/node/wasi.d.ts +202 -0
- package/vendor/ink/node_modules/@types/node/web-globals/abortcontroller.d.ts +59 -0
- package/vendor/ink/node_modules/@types/node/web-globals/blob.d.ts +23 -0
- package/vendor/ink/node_modules/@types/node/web-globals/console.d.ts +9 -0
- package/vendor/ink/node_modules/@types/node/web-globals/crypto.d.ts +39 -0
- package/vendor/ink/node_modules/@types/node/web-globals/domexception.d.ts +68 -0
- package/vendor/ink/node_modules/@types/node/web-globals/encoding.d.ts +11 -0
- package/vendor/ink/node_modules/@types/node/web-globals/events.d.ts +106 -0
- package/vendor/ink/node_modules/@types/node/web-globals/fetch.d.ts +69 -0
- package/vendor/ink/node_modules/@types/node/web-globals/importmeta.d.ts +13 -0
- package/vendor/ink/node_modules/@types/node/web-globals/messaging.d.ts +23 -0
- package/vendor/ink/node_modules/@types/node/web-globals/navigator.d.ts +25 -0
- package/vendor/ink/node_modules/@types/node/web-globals/performance.d.ts +45 -0
- package/vendor/ink/node_modules/@types/node/web-globals/storage.d.ts +24 -0
- package/vendor/ink/node_modules/@types/node/web-globals/streams.d.ts +115 -0
- package/vendor/ink/node_modules/@types/node/web-globals/timers.d.ts +44 -0
- package/vendor/ink/node_modules/@types/node/web-globals/url.d.ts +24 -0
- package/vendor/ink/node_modules/@types/node/worker_threads.d.ts +717 -0
- package/vendor/ink/node_modules/@types/node/zlib.d.ts +618 -0
- package/vendor/ink/node_modules/node-pty/LICENSE +69 -0
- package/vendor/ink/node_modules/node-pty/README.md +164 -0
- package/vendor/ink/node_modules/node-pty/binding.gyp +150 -0
- package/vendor/ink/node_modules/node-pty/lib/conpty_console_list_agent.js +25 -0
- package/vendor/ink/node_modules/node-pty/lib/eventEmitter2.js +47 -0
- package/vendor/ink/node_modules/node-pty/lib/index.js +52 -0
- package/vendor/ink/node_modules/node-pty/lib/interfaces.js +7 -0
- package/vendor/ink/node_modules/node-pty/lib/shared/conout.js +11 -0
- package/vendor/ink/node_modules/node-pty/lib/terminal.js +190 -0
- package/vendor/ink/node_modules/node-pty/lib/types.js +7 -0
- package/vendor/ink/node_modules/node-pty/lib/unixTerminal.js +349 -0
- package/vendor/ink/node_modules/node-pty/lib/utils.js +39 -0
- package/vendor/ink/node_modules/node-pty/lib/windowsConoutConnection.js +125 -0
- package/vendor/ink/node_modules/node-pty/lib/windowsPtyAgent.js +287 -0
- package/vendor/ink/node_modules/node-pty/lib/windowsTerminal.js +201 -0
- package/vendor/ink/node_modules/node-pty/lib/worker/conoutSocketWorker.js +22 -0
- package/vendor/ink/node_modules/node-pty/package.json +65 -0
- package/vendor/ink/node_modules/node-pty/prebuilds/darwin-arm64/pty.node +0 -0
- package/vendor/ink/node_modules/node-pty/prebuilds/darwin-arm64/spawn-helper +0 -0
- package/vendor/ink/node_modules/node-pty/prebuilds/darwin-x64/pty.node +0 -0
- package/vendor/ink/node_modules/node-pty/prebuilds/darwin-x64/spawn-helper +0 -0
- package/vendor/ink/node_modules/node-pty/prebuilds/linux-arm64/pty.node +0 -0
- package/vendor/ink/node_modules/node-pty/prebuilds/linux-x64/pty.node +0 -0
- package/vendor/ink/node_modules/node-pty/prebuilds/win32-arm64/conpty/OpenConsole.exe +0 -0
- package/vendor/ink/node_modules/node-pty/prebuilds/win32-arm64/conpty/conpty.dll +0 -0
- package/vendor/ink/node_modules/node-pty/prebuilds/win32-arm64/conpty.node +0 -0
- package/vendor/ink/node_modules/node-pty/prebuilds/win32-arm64/conpty.pdb +0 -0
- package/vendor/ink/node_modules/node-pty/prebuilds/win32-arm64/conpty_console_list.node +0 -0
- package/vendor/ink/node_modules/node-pty/prebuilds/win32-arm64/conpty_console_list.pdb +0 -0
- package/vendor/ink/node_modules/node-pty/prebuilds/win32-x64/conpty/OpenConsole.exe +0 -0
- package/vendor/ink/node_modules/node-pty/prebuilds/win32-x64/conpty/conpty.dll +0 -0
- package/vendor/ink/node_modules/node-pty/prebuilds/win32-x64/conpty.node +0 -0
- package/vendor/ink/node_modules/node-pty/prebuilds/win32-x64/conpty.pdb +0 -0
- package/vendor/ink/node_modules/node-pty/prebuilds/win32-x64/conpty_console_list.node +0 -0
- package/vendor/ink/node_modules/node-pty/prebuilds/win32-x64/conpty_console_list.pdb +0 -0
- package/vendor/ink/node_modules/node-pty/scripts/post-install.js +76 -0
- package/vendor/ink/node_modules/node-pty/scripts/prebuild.js +34 -0
- package/vendor/ink/node_modules/node-pty/src/unix/pty.cc +875 -0
- package/vendor/ink/node_modules/node-pty/src/unix/spawn-helper.cc +23 -0
- package/vendor/ink/node_modules/node-pty/src/win/conpty.cc +582 -0
- package/vendor/ink/node_modules/node-pty/src/win/conpty.h +41 -0
- package/vendor/ink/node_modules/node-pty/src/win/conpty_console_list.cc +44 -0
- package/vendor/ink/node_modules/node-pty/src/win/path_util.cc +95 -0
- package/vendor/ink/node_modules/node-pty/src/win/path_util.h +26 -0
- package/vendor/ink/node_modules/node-pty/third_party/conpty/1.23.251008001/win10-arm64/OpenConsole.exe +0 -0
- package/vendor/ink/node_modules/node-pty/third_party/conpty/1.23.251008001/win10-arm64/conpty.dll +0 -0
- package/vendor/ink/node_modules/node-pty/third_party/conpty/1.23.251008001/win10-x64/OpenConsole.exe +0 -0
- package/vendor/ink/node_modules/node-pty/third_party/conpty/1.23.251008001/win10-x64/conpty.dll +0 -0
- package/vendor/ink/node_modules/node-pty/typings/node-pty.d.ts +215 -0
- package/vendor/ink/node_modules/undici-types/LICENSE +21 -0
- package/vendor/ink/node_modules/undici-types/README.md +6 -0
- package/vendor/ink/node_modules/undici-types/agent.d.ts +32 -0
- package/vendor/ink/node_modules/undici-types/api.d.ts +43 -0
- package/vendor/ink/node_modules/undici-types/balanced-pool.d.ts +30 -0
- package/vendor/ink/node_modules/undici-types/cache-interceptor.d.ts +173 -0
- package/vendor/ink/node_modules/undici-types/cache.d.ts +36 -0
- package/vendor/ink/node_modules/undici-types/client-stats.d.ts +15 -0
- package/vendor/ink/node_modules/undici-types/client.d.ts +108 -0
- package/vendor/ink/node_modules/undici-types/connector.d.ts +34 -0
- package/vendor/ink/node_modules/undici-types/content-type.d.ts +21 -0
- package/vendor/ink/node_modules/undici-types/cookies.d.ts +30 -0
- package/vendor/ink/node_modules/undici-types/diagnostics-channel.d.ts +74 -0
- package/vendor/ink/node_modules/undici-types/dispatcher.d.ts +276 -0
- package/vendor/ink/node_modules/undici-types/env-http-proxy-agent.d.ts +22 -0
- package/vendor/ink/node_modules/undici-types/errors.d.ts +161 -0
- package/vendor/ink/node_modules/undici-types/eventsource.d.ts +66 -0
- package/vendor/ink/node_modules/undici-types/fetch.d.ts +211 -0
- package/vendor/ink/node_modules/undici-types/formdata.d.ts +108 -0
- package/vendor/ink/node_modules/undici-types/global-dispatcher.d.ts +9 -0
- package/vendor/ink/node_modules/undici-types/global-origin.d.ts +7 -0
- package/vendor/ink/node_modules/undici-types/h2c-client.d.ts +73 -0
- package/vendor/ink/node_modules/undici-types/handlers.d.ts +15 -0
- package/vendor/ink/node_modules/undici-types/header.d.ts +160 -0
- package/vendor/ink/node_modules/undici-types/index.d.ts +88 -0
- package/vendor/ink/node_modules/undici-types/interceptors.d.ts +73 -0
- package/vendor/ink/node_modules/undici-types/mock-agent.d.ts +68 -0
- package/vendor/ink/node_modules/undici-types/mock-call-history.d.ts +111 -0
- package/vendor/ink/node_modules/undici-types/mock-client.d.ts +27 -0
- package/vendor/ink/node_modules/undici-types/mock-errors.d.ts +12 -0
- package/vendor/ink/node_modules/undici-types/mock-interceptor.d.ts +94 -0
- package/vendor/ink/node_modules/undici-types/mock-pool.d.ts +27 -0
- package/vendor/ink/node_modules/undici-types/package.json +55 -0
- package/vendor/ink/node_modules/undici-types/patch.d.ts +29 -0
- package/vendor/ink/node_modules/undici-types/pool-stats.d.ts +19 -0
- package/vendor/ink/node_modules/undici-types/pool.d.ts +41 -0
- package/vendor/ink/node_modules/undici-types/proxy-agent.d.ts +29 -0
- package/vendor/ink/node_modules/undici-types/readable.d.ts +68 -0
- package/vendor/ink/node_modules/undici-types/retry-agent.d.ts +8 -0
- package/vendor/ink/node_modules/undici-types/retry-handler.d.ts +125 -0
- package/vendor/ink/node_modules/undici-types/round-robin-pool.d.ts +41 -0
- package/vendor/ink/node_modules/undici-types/snapshot-agent.d.ts +109 -0
- package/vendor/ink/node_modules/undici-types/util.d.ts +18 -0
- package/vendor/ink/node_modules/undici-types/utility.d.ts +7 -0
- package/vendor/ink/node_modules/undici-types/webidl.d.ts +341 -0
- package/vendor/ink/node_modules/undici-types/websocket.d.ts +186 -0
- package/vendor/ink/package.json +201 -0
- package/vendor/ink/readme.md +2636 -0
- package/bin/swag-agent.js +0 -9
- package/dist/server/lib/pg-rate-limiter.d.ts +0 -21
- package/dist/server/lib/pg-rate-limiter.js +0 -86
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
#include <errno.h>
|
|
2
|
+
#include <fcntl.h>
|
|
3
|
+
#include <string.h>
|
|
4
|
+
#include <unistd.h>
|
|
5
|
+
|
|
6
|
+
int main (int argc, char** argv) {
|
|
7
|
+
char *slave_path = ttyname(STDIN_FILENO);
|
|
8
|
+
// open implicit attaches a process to a terminal device if:
|
|
9
|
+
// - process has no controlling terminal yet
|
|
10
|
+
// - O_NOCTTY is not set
|
|
11
|
+
close(open(slave_path, O_RDWR));
|
|
12
|
+
|
|
13
|
+
char *cwd = argv[1];
|
|
14
|
+
char *file = argv[2];
|
|
15
|
+
argv = &argv[2];
|
|
16
|
+
|
|
17
|
+
if (strlen(cwd) && chdir(cwd) == -1) {
|
|
18
|
+
_exit(1);
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
execvp(file, argv);
|
|
22
|
+
return 1;
|
|
23
|
+
}
|
|
@@ -0,0 +1,582 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Copyright (c) 2013-2015, Christopher Jeffrey, Peter Sunde (MIT License)
|
|
3
|
+
* Copyright (c) 2016, Daniel Imms (MIT License).
|
|
4
|
+
* Copyright (c) 2018, Microsoft Corporation (MIT License).
|
|
5
|
+
*
|
|
6
|
+
* pty.cc:
|
|
7
|
+
* This file is responsible for starting processes
|
|
8
|
+
* with pseudo-terminal file descriptors.
|
|
9
|
+
*/
|
|
10
|
+
|
|
11
|
+
#define _WIN32_WINNT 0x600
|
|
12
|
+
|
|
13
|
+
#define NODE_ADDON_API_DISABLE_DEPRECATED
|
|
14
|
+
#include <node_api.h>
|
|
15
|
+
#include <assert.h>
|
|
16
|
+
#include <Shlwapi.h> // PathCombine, PathIsRelative
|
|
17
|
+
#include <sstream>
|
|
18
|
+
#include <iostream>
|
|
19
|
+
#include <string>
|
|
20
|
+
#include <thread>
|
|
21
|
+
#include <vector>
|
|
22
|
+
#include <Windows.h>
|
|
23
|
+
#include <strsafe.h>
|
|
24
|
+
#include "path_util.h"
|
|
25
|
+
#include "conpty.h"
|
|
26
|
+
|
|
27
|
+
// Taken from the RS5 Windows SDK, but redefined here in case we're targeting <= 17134
|
|
28
|
+
#ifndef PROC_THREAD_ATTRIBUTE_PSEUDOCONSOLE
|
|
29
|
+
#define PROC_THREAD_ATTRIBUTE_PSEUDOCONSOLE \
|
|
30
|
+
ProcThreadAttributeValue(22, FALSE, TRUE, FALSE)
|
|
31
|
+
|
|
32
|
+
typedef VOID* HPCON;
|
|
33
|
+
typedef HRESULT (__stdcall *PFNCREATEPSEUDOCONSOLE)(COORD c, HANDLE hIn, HANDLE hOut, DWORD dwFlags, HPCON* phpcon);
|
|
34
|
+
typedef HRESULT (__stdcall *PFNRESIZEPSEUDOCONSOLE)(HPCON hpc, COORD newSize);
|
|
35
|
+
typedef HRESULT (__stdcall *PFNCLEARPSEUDOCONSOLE)(HPCON hpc);
|
|
36
|
+
typedef void (__stdcall *PFNCLOSEPSEUDOCONSOLE)(HPCON hpc);
|
|
37
|
+
typedef void (__stdcall *PFNRELEASEPSEUDOCONSOLE)(HPCON hpc);
|
|
38
|
+
|
|
39
|
+
#endif
|
|
40
|
+
|
|
41
|
+
struct pty_baton {
|
|
42
|
+
int id;
|
|
43
|
+
HANDLE hIn;
|
|
44
|
+
HANDLE hOut;
|
|
45
|
+
HPCON hpc;
|
|
46
|
+
|
|
47
|
+
HANDLE hShell;
|
|
48
|
+
|
|
49
|
+
pty_baton(int _id, HANDLE _hIn, HANDLE _hOut, HPCON _hpc) : id(_id), hIn(_hIn), hOut(_hOut), hpc(_hpc) {};
|
|
50
|
+
};
|
|
51
|
+
|
|
52
|
+
static std::vector<std::unique_ptr<pty_baton>> ptyHandles;
|
|
53
|
+
static volatile LONG ptyCounter;
|
|
54
|
+
|
|
55
|
+
static pty_baton* get_pty_baton(int id) {
|
|
56
|
+
auto it = std::find_if(ptyHandles.begin(), ptyHandles.end(), [id](const auto& ptyHandle) {
|
|
57
|
+
return ptyHandle->id == id;
|
|
58
|
+
});
|
|
59
|
+
if (it != ptyHandles.end()) {
|
|
60
|
+
return it->get();
|
|
61
|
+
}
|
|
62
|
+
return nullptr;
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
static bool remove_pty_baton(int id) {
|
|
66
|
+
auto it = std::remove_if(ptyHandles.begin(), ptyHandles.end(), [id](const auto& ptyHandle) {
|
|
67
|
+
return ptyHandle->id == id;
|
|
68
|
+
});
|
|
69
|
+
if (it != ptyHandles.end()) {
|
|
70
|
+
ptyHandles.erase(it);
|
|
71
|
+
return true;
|
|
72
|
+
}
|
|
73
|
+
return false;
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
struct ExitEvent {
|
|
77
|
+
int exit_code = 0;
|
|
78
|
+
};
|
|
79
|
+
|
|
80
|
+
void SetupExitCallback(Napi::Env env, Napi::Function cb, pty_baton* baton) {
|
|
81
|
+
std::thread *th = new std::thread;
|
|
82
|
+
// Don't use Napi::AsyncWorker which is limited by UV_THREADPOOL_SIZE.
|
|
83
|
+
auto tsfn = Napi::ThreadSafeFunction::New(
|
|
84
|
+
env,
|
|
85
|
+
cb, // JavaScript function called asynchronously
|
|
86
|
+
"SetupExitCallback_resource", // Name
|
|
87
|
+
0, // Unlimited queue
|
|
88
|
+
1, // Only one thread will use this initially
|
|
89
|
+
[th](Napi::Env) { // Finalizer used to clean threads up
|
|
90
|
+
th->join();
|
|
91
|
+
delete th;
|
|
92
|
+
});
|
|
93
|
+
*th = std::thread([tsfn = std::move(tsfn), baton] {
|
|
94
|
+
auto callback = [](Napi::Env env, Napi::Function cb, ExitEvent *exit_event) {
|
|
95
|
+
cb.Call({Napi::Number::New(env, exit_event->exit_code)});
|
|
96
|
+
delete exit_event;
|
|
97
|
+
};
|
|
98
|
+
|
|
99
|
+
ExitEvent *exit_event = new ExitEvent;
|
|
100
|
+
// Wait for process to complete.
|
|
101
|
+
WaitForSingleObject(baton->hShell, INFINITE);
|
|
102
|
+
// Get process exit code.
|
|
103
|
+
GetExitCodeProcess(baton->hShell, (LPDWORD)(&exit_event->exit_code));
|
|
104
|
+
// Clean up handles
|
|
105
|
+
CloseHandle(baton->hShell);
|
|
106
|
+
assert(remove_pty_baton(baton->id));
|
|
107
|
+
|
|
108
|
+
auto status = tsfn.BlockingCall(exit_event, callback); // In main thread
|
|
109
|
+
switch (status) {
|
|
110
|
+
case napi_closing:
|
|
111
|
+
break;
|
|
112
|
+
|
|
113
|
+
case napi_queue_full:
|
|
114
|
+
Napi::Error::Fatal("SetupExitCallback", "Queue was full");
|
|
115
|
+
|
|
116
|
+
case napi_ok:
|
|
117
|
+
if (tsfn.Release() != napi_ok) {
|
|
118
|
+
Napi::Error::Fatal("SetupExitCallback", "ThreadSafeFunction.Release() failed");
|
|
119
|
+
}
|
|
120
|
+
break;
|
|
121
|
+
|
|
122
|
+
default:
|
|
123
|
+
Napi::Error::Fatal("SetupExitCallback", "ThreadSafeFunction.BlockingCall() failed");
|
|
124
|
+
}
|
|
125
|
+
});
|
|
126
|
+
}
|
|
127
|
+
|
|
128
|
+
Napi::Error errorWithCode(const Napi::CallbackInfo& info, const char* text) {
|
|
129
|
+
std::stringstream errorText;
|
|
130
|
+
errorText << text;
|
|
131
|
+
errorText << ", error code: " << GetLastError();
|
|
132
|
+
return Napi::Error::New(info.Env(), errorText.str());
|
|
133
|
+
}
|
|
134
|
+
|
|
135
|
+
// Returns a new server named pipe. It has not yet been connected.
|
|
136
|
+
bool createDataServerPipe(bool write,
|
|
137
|
+
std::wstring kind,
|
|
138
|
+
HANDLE* hServer,
|
|
139
|
+
std::wstring &name,
|
|
140
|
+
const std::wstring &pipeName)
|
|
141
|
+
{
|
|
142
|
+
*hServer = INVALID_HANDLE_VALUE;
|
|
143
|
+
|
|
144
|
+
name = L"\\\\.\\pipe\\" + pipeName + L"-" + kind;
|
|
145
|
+
|
|
146
|
+
const DWORD winOpenMode = PIPE_ACCESS_INBOUND | PIPE_ACCESS_OUTBOUND | FILE_FLAG_FIRST_PIPE_INSTANCE/* | FILE_FLAG_OVERLAPPED */;
|
|
147
|
+
|
|
148
|
+
SECURITY_ATTRIBUTES sa = {};
|
|
149
|
+
sa.nLength = sizeof(sa);
|
|
150
|
+
|
|
151
|
+
*hServer = CreateNamedPipeW(
|
|
152
|
+
name.c_str(),
|
|
153
|
+
/*dwOpenMode=*/winOpenMode,
|
|
154
|
+
/*dwPipeMode=*/PIPE_TYPE_BYTE | PIPE_READMODE_BYTE | PIPE_WAIT,
|
|
155
|
+
/*nMaxInstances=*/1,
|
|
156
|
+
/*nOutBufferSize=*/128 * 1024,
|
|
157
|
+
/*nInBufferSize=*/128 * 1024,
|
|
158
|
+
/*nDefaultTimeOut=*/30000,
|
|
159
|
+
&sa);
|
|
160
|
+
|
|
161
|
+
return *hServer != INVALID_HANDLE_VALUE;
|
|
162
|
+
}
|
|
163
|
+
|
|
164
|
+
HANDLE LoadConptyDll(const Napi::CallbackInfo& info,
|
|
165
|
+
const bool useConptyDll)
|
|
166
|
+
{
|
|
167
|
+
if (!useConptyDll) {
|
|
168
|
+
return LoadLibraryExW(L"kernel32.dll", 0, 0);
|
|
169
|
+
}
|
|
170
|
+
wchar_t currentDir[MAX_PATH];
|
|
171
|
+
HMODULE hModule = GetModuleHandleA("conpty.node");
|
|
172
|
+
if (hModule == NULL) {
|
|
173
|
+
throw errorWithCode(info, "Failed to get conpty.node module handle");
|
|
174
|
+
}
|
|
175
|
+
DWORD result = GetModuleFileNameW(hModule, currentDir, MAX_PATH);
|
|
176
|
+
if (result == 0) {
|
|
177
|
+
throw errorWithCode(info, "Failed to get conpty.node module file name");
|
|
178
|
+
}
|
|
179
|
+
PathRemoveFileSpecW(currentDir);
|
|
180
|
+
wchar_t conptyDllPath[MAX_PATH];
|
|
181
|
+
PathCombineW(conptyDllPath, currentDir, L"conpty\\conpty.dll");
|
|
182
|
+
if (!path_util::file_exists(conptyDllPath)) {
|
|
183
|
+
std::wstring errorMessage = L"Cannot find conpty.dll at " + std::wstring(conptyDllPath);
|
|
184
|
+
std::string errorMessageStr = path_util::wstring_to_string(errorMessage);
|
|
185
|
+
throw errorWithCode(info, errorMessageStr.c_str());
|
|
186
|
+
}
|
|
187
|
+
|
|
188
|
+
return LoadLibraryW(conptyDllPath);
|
|
189
|
+
}
|
|
190
|
+
|
|
191
|
+
HRESULT CreateNamedPipesAndPseudoConsole(const Napi::CallbackInfo& info,
|
|
192
|
+
COORD size,
|
|
193
|
+
DWORD dwFlags,
|
|
194
|
+
HANDLE *phInput,
|
|
195
|
+
HANDLE *phOutput,
|
|
196
|
+
HPCON* phPC,
|
|
197
|
+
std::wstring& inName,
|
|
198
|
+
std::wstring& outName,
|
|
199
|
+
const std::wstring& pipeName,
|
|
200
|
+
const bool useConptyDll)
|
|
201
|
+
{
|
|
202
|
+
HANDLE hLibrary = LoadConptyDll(info, useConptyDll);
|
|
203
|
+
DWORD error = GetLastError();
|
|
204
|
+
bool fLoadedDll = hLibrary != nullptr;
|
|
205
|
+
if (fLoadedDll)
|
|
206
|
+
{
|
|
207
|
+
PFNCREATEPSEUDOCONSOLE const pfnCreate = (PFNCREATEPSEUDOCONSOLE)GetProcAddress(
|
|
208
|
+
(HMODULE)hLibrary,
|
|
209
|
+
useConptyDll ? "ConptyCreatePseudoConsole" : "CreatePseudoConsole");
|
|
210
|
+
if (pfnCreate)
|
|
211
|
+
{
|
|
212
|
+
if (phPC == NULL || phInput == NULL || phOutput == NULL)
|
|
213
|
+
{
|
|
214
|
+
return E_INVALIDARG;
|
|
215
|
+
}
|
|
216
|
+
|
|
217
|
+
bool success = createDataServerPipe(true, L"in", phInput, inName, pipeName);
|
|
218
|
+
if (!success)
|
|
219
|
+
{
|
|
220
|
+
return HRESULT_FROM_WIN32(GetLastError());
|
|
221
|
+
}
|
|
222
|
+
success = createDataServerPipe(false, L"out", phOutput, outName, pipeName);
|
|
223
|
+
if (!success)
|
|
224
|
+
{
|
|
225
|
+
return HRESULT_FROM_WIN32(GetLastError());
|
|
226
|
+
}
|
|
227
|
+
return pfnCreate(size, *phInput, *phOutput, dwFlags, phPC);
|
|
228
|
+
}
|
|
229
|
+
else
|
|
230
|
+
{
|
|
231
|
+
// Failed to find CreatePseudoConsole in kernel32. This is likely because
|
|
232
|
+
// the user is not running a build of Windows that supports that API.
|
|
233
|
+
return HRESULT_FROM_WIN32(GetLastError());
|
|
234
|
+
}
|
|
235
|
+
} else {
|
|
236
|
+
throw errorWithCode(info, "Failed to load conpty.dll");
|
|
237
|
+
}
|
|
238
|
+
|
|
239
|
+
// Failed to find kernel32. This is realy unlikely - honestly no idea how
|
|
240
|
+
// this is even possible to hit.
|
|
241
|
+
return HRESULT_FROM_WIN32(GetLastError());
|
|
242
|
+
}
|
|
243
|
+
|
|
244
|
+
static Napi::Value PtyStartProcess(const Napi::CallbackInfo& info) {
|
|
245
|
+
Napi::Env env(info.Env());
|
|
246
|
+
Napi::HandleScope scope(env);
|
|
247
|
+
|
|
248
|
+
Napi::Object marshal;
|
|
249
|
+
std::wstring inName, outName;
|
|
250
|
+
BOOL fSuccess = FALSE;
|
|
251
|
+
std::unique_ptr<wchar_t[]> mutableCommandline;
|
|
252
|
+
PROCESS_INFORMATION _piClient{};
|
|
253
|
+
|
|
254
|
+
if (info.Length() != 7 ||
|
|
255
|
+
!info[0].IsString() ||
|
|
256
|
+
!info[1].IsNumber() ||
|
|
257
|
+
!info[2].IsNumber() ||
|
|
258
|
+
!info[3].IsBoolean() ||
|
|
259
|
+
!info[4].IsString() ||
|
|
260
|
+
!info[5].IsBoolean() ||
|
|
261
|
+
!info[6].IsBoolean()) {
|
|
262
|
+
throw Napi::Error::New(env, "Usage: pty.startProcess(file, cols, rows, debug, pipeName, inheritCursor, useConptyDll)");
|
|
263
|
+
}
|
|
264
|
+
|
|
265
|
+
const std::wstring filename(path_util::to_wstring(info[0].As<Napi::String>()));
|
|
266
|
+
const SHORT cols = static_cast<SHORT>(info[1].As<Napi::Number>().Uint32Value());
|
|
267
|
+
const SHORT rows = static_cast<SHORT>(info[2].As<Napi::Number>().Uint32Value());
|
|
268
|
+
const bool debug = info[3].As<Napi::Boolean>().Value();
|
|
269
|
+
const std::wstring pipeName(path_util::to_wstring(info[4].As<Napi::String>()));
|
|
270
|
+
const bool inheritCursor = info[5].As<Napi::Boolean>().Value();
|
|
271
|
+
const bool useConptyDll = info[6].As<Napi::Boolean>().Value();
|
|
272
|
+
|
|
273
|
+
// use environment 'Path' variable to determine location of
|
|
274
|
+
// the relative path that we have recieved (e.g cmd.exe)
|
|
275
|
+
std::wstring shellpath;
|
|
276
|
+
if (::PathIsRelativeW(filename.c_str())) {
|
|
277
|
+
shellpath = path_util::get_shell_path(filename.c_str());
|
|
278
|
+
} else {
|
|
279
|
+
shellpath = filename;
|
|
280
|
+
}
|
|
281
|
+
|
|
282
|
+
if (shellpath.empty() || !path_util::file_exists(shellpath)) {
|
|
283
|
+
std::string why;
|
|
284
|
+
why += "File not found: ";
|
|
285
|
+
why += path_util::wstring_to_string(shellpath);
|
|
286
|
+
throw Napi::Error::New(env, why);
|
|
287
|
+
}
|
|
288
|
+
|
|
289
|
+
HANDLE hIn, hOut;
|
|
290
|
+
HPCON hpc;
|
|
291
|
+
HRESULT hr = CreateNamedPipesAndPseudoConsole(info, {cols, rows}, inheritCursor ? 1/*PSEUDOCONSOLE_INHERIT_CURSOR*/ : 0, &hIn, &hOut, &hpc, inName, outName, pipeName, useConptyDll);
|
|
292
|
+
|
|
293
|
+
// Restore default handling of ctrl+c
|
|
294
|
+
SetConsoleCtrlHandler(NULL, FALSE);
|
|
295
|
+
|
|
296
|
+
// Set return values
|
|
297
|
+
marshal = Napi::Object::New(env);
|
|
298
|
+
|
|
299
|
+
if (SUCCEEDED(hr)) {
|
|
300
|
+
// We were able to instantiate a conpty
|
|
301
|
+
const int ptyId = InterlockedIncrement(&ptyCounter);
|
|
302
|
+
marshal.Set("pty", Napi::Number::New(env, ptyId));
|
|
303
|
+
ptyHandles.emplace_back(
|
|
304
|
+
std::make_unique<pty_baton>(ptyId, hIn, hOut, hpc));
|
|
305
|
+
} else {
|
|
306
|
+
throw Napi::Error::New(env, "Cannot launch conpty");
|
|
307
|
+
}
|
|
308
|
+
|
|
309
|
+
std::string inNameStr = path_util::wstring_to_string(inName);
|
|
310
|
+
if (inNameStr.empty()) {
|
|
311
|
+
throw Napi::Error::New(env, "Failed to initialize conpty conin");
|
|
312
|
+
}
|
|
313
|
+
std::string outNameStr = path_util::wstring_to_string(outName);
|
|
314
|
+
if (outNameStr.empty()) {
|
|
315
|
+
throw Napi::Error::New(env, "Failed to initialize conpty conout");
|
|
316
|
+
}
|
|
317
|
+
|
|
318
|
+
marshal.Set("fd", Napi::Number::New(env, -1));
|
|
319
|
+
marshal.Set("conin", Napi::String::New(env, inNameStr));
|
|
320
|
+
marshal.Set("conout", Napi::String::New(env, outNameStr));
|
|
321
|
+
return marshal;
|
|
322
|
+
}
|
|
323
|
+
|
|
324
|
+
static Napi::Value PtyConnect(const Napi::CallbackInfo& info) {
|
|
325
|
+
Napi::Env env(info.Env());
|
|
326
|
+
Napi::HandleScope scope(env);
|
|
327
|
+
|
|
328
|
+
// If we're working with conpty's we need to call ConnectNamedPipe here AFTER
|
|
329
|
+
// the Socket has attempted to connect to the other end, then actually
|
|
330
|
+
// spawn the process here.
|
|
331
|
+
|
|
332
|
+
std::stringstream errorText;
|
|
333
|
+
BOOL fSuccess = FALSE;
|
|
334
|
+
|
|
335
|
+
if (info.Length() != 6 ||
|
|
336
|
+
!info[0].IsNumber() ||
|
|
337
|
+
!info[1].IsString() ||
|
|
338
|
+
!info[2].IsString() ||
|
|
339
|
+
!info[3].IsArray() ||
|
|
340
|
+
!info[4].IsBoolean() ||
|
|
341
|
+
!info[5].IsFunction()) {
|
|
342
|
+
throw Napi::Error::New(env, "Usage: pty.connect(id, cmdline, cwd, env, useConptyDll, exitCallback)");
|
|
343
|
+
}
|
|
344
|
+
|
|
345
|
+
const int id = info[0].As<Napi::Number>().Int32Value();
|
|
346
|
+
const std::wstring cmdline(path_util::to_wstring(info[1].As<Napi::String>()));
|
|
347
|
+
const std::wstring cwd(path_util::to_wstring(info[2].As<Napi::String>()));
|
|
348
|
+
const Napi::Array envValues = info[3].As<Napi::Array>();
|
|
349
|
+
const bool useConptyDll = info[4].As<Napi::Boolean>().Value();
|
|
350
|
+
Napi::Function exitCallback = info[5].As<Napi::Function>();
|
|
351
|
+
|
|
352
|
+
// Fetch pty handle from ID and start process
|
|
353
|
+
pty_baton* handle = get_pty_baton(id);
|
|
354
|
+
if (!handle) {
|
|
355
|
+
throw Napi::Error::New(env, "Invalid pty handle");
|
|
356
|
+
}
|
|
357
|
+
|
|
358
|
+
// Prepare command line
|
|
359
|
+
std::unique_ptr<wchar_t[]> mutableCommandline = std::make_unique<wchar_t[]>(cmdline.length() + 1);
|
|
360
|
+
HRESULT hr = StringCchCopyW(mutableCommandline.get(), cmdline.length() + 1, cmdline.c_str());
|
|
361
|
+
|
|
362
|
+
// Prepare cwd
|
|
363
|
+
std::unique_ptr<wchar_t[]> mutableCwd = std::make_unique<wchar_t[]>(cwd.length() + 1);
|
|
364
|
+
hr = StringCchCopyW(mutableCwd.get(), cwd.length() + 1, cwd.c_str());
|
|
365
|
+
|
|
366
|
+
// Prepare environment
|
|
367
|
+
std::wstring envStr;
|
|
368
|
+
if (!envValues.IsEmpty()) {
|
|
369
|
+
std::wstring envBlock;
|
|
370
|
+
for(uint32_t i = 0; i < envValues.Length(); i++) {
|
|
371
|
+
envBlock += path_util::to_wstring(envValues.Get(i).As<Napi::String>());
|
|
372
|
+
envBlock += L'\0';
|
|
373
|
+
}
|
|
374
|
+
envBlock += L'\0';
|
|
375
|
+
envStr = std::move(envBlock);
|
|
376
|
+
}
|
|
377
|
+
std::vector<wchar_t> envV(envStr.cbegin(), envStr.cend());
|
|
378
|
+
LPWSTR envArg = envV.empty() ? nullptr : envV.data();
|
|
379
|
+
|
|
380
|
+
ConnectNamedPipe(handle->hIn, nullptr);
|
|
381
|
+
ConnectNamedPipe(handle->hOut, nullptr);
|
|
382
|
+
|
|
383
|
+
// Attach the pseudoconsole to the client application we're creating
|
|
384
|
+
STARTUPINFOEXW siEx{0};
|
|
385
|
+
siEx.StartupInfo.cb = sizeof(STARTUPINFOEXW);
|
|
386
|
+
siEx.StartupInfo.dwFlags |= STARTF_USESTDHANDLES;
|
|
387
|
+
siEx.StartupInfo.hStdError = nullptr;
|
|
388
|
+
siEx.StartupInfo.hStdInput = nullptr;
|
|
389
|
+
siEx.StartupInfo.hStdOutput = nullptr;
|
|
390
|
+
|
|
391
|
+
SIZE_T size = 0;
|
|
392
|
+
InitializeProcThreadAttributeList(NULL, 1, 0, &size);
|
|
393
|
+
BYTE *attrList = new BYTE[size];
|
|
394
|
+
siEx.lpAttributeList = reinterpret_cast<PPROC_THREAD_ATTRIBUTE_LIST>(attrList);
|
|
395
|
+
|
|
396
|
+
fSuccess = InitializeProcThreadAttributeList(siEx.lpAttributeList, 1, 0, &size);
|
|
397
|
+
if (!fSuccess) {
|
|
398
|
+
throw errorWithCode(info, "InitializeProcThreadAttributeList failed");
|
|
399
|
+
}
|
|
400
|
+
fSuccess = UpdateProcThreadAttribute(siEx.lpAttributeList,
|
|
401
|
+
0,
|
|
402
|
+
PROC_THREAD_ATTRIBUTE_PSEUDOCONSOLE,
|
|
403
|
+
handle->hpc,
|
|
404
|
+
sizeof(HPCON),
|
|
405
|
+
NULL,
|
|
406
|
+
NULL);
|
|
407
|
+
if (!fSuccess) {
|
|
408
|
+
throw errorWithCode(info, "UpdateProcThreadAttribute failed");
|
|
409
|
+
}
|
|
410
|
+
|
|
411
|
+
PROCESS_INFORMATION piClient{};
|
|
412
|
+
fSuccess = !!CreateProcessW(
|
|
413
|
+
nullptr,
|
|
414
|
+
mutableCommandline.get(),
|
|
415
|
+
nullptr, // lpProcessAttributes
|
|
416
|
+
nullptr, // lpThreadAttributes
|
|
417
|
+
false, // bInheritHandles VERY IMPORTANT that this is false
|
|
418
|
+
EXTENDED_STARTUPINFO_PRESENT | CREATE_UNICODE_ENVIRONMENT, // dwCreationFlags
|
|
419
|
+
envArg, // lpEnvironment
|
|
420
|
+
mutableCwd.get(), // lpCurrentDirectory
|
|
421
|
+
&siEx.StartupInfo, // lpStartupInfo
|
|
422
|
+
&piClient // lpProcessInformation
|
|
423
|
+
);
|
|
424
|
+
if (!fSuccess) {
|
|
425
|
+
throw errorWithCode(info, "Cannot create process");
|
|
426
|
+
}
|
|
427
|
+
|
|
428
|
+
HANDLE hLibrary = LoadConptyDll(info, useConptyDll);
|
|
429
|
+
bool fLoadedDll = hLibrary != nullptr;
|
|
430
|
+
if (useConptyDll && fLoadedDll)
|
|
431
|
+
{
|
|
432
|
+
PFNRELEASEPSEUDOCONSOLE const pfnReleasePseudoConsole = (PFNRELEASEPSEUDOCONSOLE)GetProcAddress(
|
|
433
|
+
(HMODULE)hLibrary, "ConptyReleasePseudoConsole");
|
|
434
|
+
if (pfnReleasePseudoConsole)
|
|
435
|
+
{
|
|
436
|
+
pfnReleasePseudoConsole(handle->hpc);
|
|
437
|
+
}
|
|
438
|
+
}
|
|
439
|
+
|
|
440
|
+
// Update handle
|
|
441
|
+
handle->hShell = piClient.hProcess;
|
|
442
|
+
|
|
443
|
+
// Close the thread handle to avoid resource leak
|
|
444
|
+
CloseHandle(piClient.hThread);
|
|
445
|
+
// Close the input read and output write handle of the pseudoconsole
|
|
446
|
+
CloseHandle(handle->hIn);
|
|
447
|
+
CloseHandle(handle->hOut);
|
|
448
|
+
|
|
449
|
+
SetupExitCallback(env, exitCallback, handle);
|
|
450
|
+
|
|
451
|
+
// Return
|
|
452
|
+
auto marshal = Napi::Object::New(env);
|
|
453
|
+
marshal.Set("pid", Napi::Number::New(env, piClient.dwProcessId));
|
|
454
|
+
return marshal;
|
|
455
|
+
}
|
|
456
|
+
|
|
457
|
+
static Napi::Value PtyResize(const Napi::CallbackInfo& info) {
|
|
458
|
+
Napi::Env env(info.Env());
|
|
459
|
+
Napi::HandleScope scope(env);
|
|
460
|
+
|
|
461
|
+
if (info.Length() != 4 ||
|
|
462
|
+
!info[0].IsNumber() ||
|
|
463
|
+
!info[1].IsNumber() ||
|
|
464
|
+
!info[2].IsNumber() ||
|
|
465
|
+
!info[3].IsBoolean()) {
|
|
466
|
+
throw Napi::Error::New(env, "Usage: pty.resize(id, cols, rows, useConptyDll)");
|
|
467
|
+
}
|
|
468
|
+
|
|
469
|
+
int id = info[0].As<Napi::Number>().Int32Value();
|
|
470
|
+
SHORT cols = static_cast<SHORT>(info[1].As<Napi::Number>().Uint32Value());
|
|
471
|
+
SHORT rows = static_cast<SHORT>(info[2].As<Napi::Number>().Uint32Value());
|
|
472
|
+
const bool useConptyDll = info[3].As<Napi::Boolean>().Value();
|
|
473
|
+
|
|
474
|
+
const pty_baton* handle = get_pty_baton(id);
|
|
475
|
+
|
|
476
|
+
if (handle != nullptr) {
|
|
477
|
+
HANDLE hLibrary = LoadConptyDll(info, useConptyDll);
|
|
478
|
+
bool fLoadedDll = hLibrary != nullptr;
|
|
479
|
+
if (fLoadedDll)
|
|
480
|
+
{
|
|
481
|
+
PFNRESIZEPSEUDOCONSOLE const pfnResizePseudoConsole = (PFNRESIZEPSEUDOCONSOLE)GetProcAddress(
|
|
482
|
+
(HMODULE)hLibrary,
|
|
483
|
+
useConptyDll ? "ConptyResizePseudoConsole" : "ResizePseudoConsole");
|
|
484
|
+
if (pfnResizePseudoConsole)
|
|
485
|
+
{
|
|
486
|
+
COORD size = {cols, rows};
|
|
487
|
+
pfnResizePseudoConsole(handle->hpc, size);
|
|
488
|
+
}
|
|
489
|
+
}
|
|
490
|
+
}
|
|
491
|
+
|
|
492
|
+
return env.Undefined();
|
|
493
|
+
}
|
|
494
|
+
|
|
495
|
+
static Napi::Value PtyClear(const Napi::CallbackInfo& info) {
|
|
496
|
+
Napi::Env env(info.Env());
|
|
497
|
+
Napi::HandleScope scope(env);
|
|
498
|
+
|
|
499
|
+
if (info.Length() != 2 ||
|
|
500
|
+
!info[0].IsNumber() ||
|
|
501
|
+
!info[1].IsBoolean()) {
|
|
502
|
+
throw Napi::Error::New(env, "Usage: pty.clear(id, useConptyDll)");
|
|
503
|
+
}
|
|
504
|
+
|
|
505
|
+
int id = info[0].As<Napi::Number>().Int32Value();
|
|
506
|
+
const bool useConptyDll = info[1].As<Napi::Boolean>().Value();
|
|
507
|
+
|
|
508
|
+
// This API is only supported for conpty.dll as it was introduced in a later version of Windows.
|
|
509
|
+
// We could hook it up to point at >= a version of Windows only, but the future is conpty.dll
|
|
510
|
+
// anyway.
|
|
511
|
+
if (!useConptyDll) {
|
|
512
|
+
return env.Undefined();
|
|
513
|
+
}
|
|
514
|
+
|
|
515
|
+
const pty_baton* handle = get_pty_baton(id);
|
|
516
|
+
|
|
517
|
+
if (handle != nullptr) {
|
|
518
|
+
HANDLE hLibrary = LoadConptyDll(info, useConptyDll);
|
|
519
|
+
bool fLoadedDll = hLibrary != nullptr;
|
|
520
|
+
if (fLoadedDll)
|
|
521
|
+
{
|
|
522
|
+
PFNCLEARPSEUDOCONSOLE const pfnClearPseudoConsole = (PFNCLEARPSEUDOCONSOLE)GetProcAddress((HMODULE)hLibrary, "ConptyClearPseudoConsole");
|
|
523
|
+
if (pfnClearPseudoConsole)
|
|
524
|
+
{
|
|
525
|
+
pfnClearPseudoConsole(handle->hpc);
|
|
526
|
+
}
|
|
527
|
+
}
|
|
528
|
+
}
|
|
529
|
+
|
|
530
|
+
return env.Undefined();
|
|
531
|
+
}
|
|
532
|
+
|
|
533
|
+
static Napi::Value PtyKill(const Napi::CallbackInfo& info) {
|
|
534
|
+
Napi::Env env(info.Env());
|
|
535
|
+
Napi::HandleScope scope(env);
|
|
536
|
+
|
|
537
|
+
if (info.Length() != 2 ||
|
|
538
|
+
!info[0].IsNumber() ||
|
|
539
|
+
!info[1].IsBoolean()) {
|
|
540
|
+
throw Napi::Error::New(env, "Usage: pty.kill(id, useConptyDll)");
|
|
541
|
+
}
|
|
542
|
+
|
|
543
|
+
int id = info[0].As<Napi::Number>().Int32Value();
|
|
544
|
+
const bool useConptyDll = info[1].As<Napi::Boolean>().Value();
|
|
545
|
+
|
|
546
|
+
const pty_baton* handle = get_pty_baton(id);
|
|
547
|
+
|
|
548
|
+
if (handle != nullptr) {
|
|
549
|
+
HANDLE hLibrary = LoadConptyDll(info, useConptyDll);
|
|
550
|
+
bool fLoadedDll = hLibrary != nullptr;
|
|
551
|
+
if (fLoadedDll)
|
|
552
|
+
{
|
|
553
|
+
PFNCLOSEPSEUDOCONSOLE const pfnClosePseudoConsole = (PFNCLOSEPSEUDOCONSOLE)GetProcAddress(
|
|
554
|
+
(HMODULE)hLibrary,
|
|
555
|
+
useConptyDll ? "ConptyClosePseudoConsole" : "ClosePseudoConsole");
|
|
556
|
+
if (pfnClosePseudoConsole)
|
|
557
|
+
{
|
|
558
|
+
pfnClosePseudoConsole(handle->hpc);
|
|
559
|
+
}
|
|
560
|
+
}
|
|
561
|
+
if (useConptyDll) {
|
|
562
|
+
TerminateProcess(handle->hShell, 1);
|
|
563
|
+
}
|
|
564
|
+
}
|
|
565
|
+
|
|
566
|
+
return env.Undefined();
|
|
567
|
+
}
|
|
568
|
+
|
|
569
|
+
/**
|
|
570
|
+
* Init
|
|
571
|
+
*/
|
|
572
|
+
|
|
573
|
+
Napi::Object init(Napi::Env env, Napi::Object exports) {
|
|
574
|
+
exports.Set("startProcess", Napi::Function::New(env, PtyStartProcess));
|
|
575
|
+
exports.Set("connect", Napi::Function::New(env, PtyConnect));
|
|
576
|
+
exports.Set("resize", Napi::Function::New(env, PtyResize));
|
|
577
|
+
exports.Set("clear", Napi::Function::New(env, PtyClear));
|
|
578
|
+
exports.Set("kill", Napi::Function::New(env, PtyKill));
|
|
579
|
+
return exports;
|
|
580
|
+
};
|
|
581
|
+
|
|
582
|
+
NODE_API_MODULE(NODE_GYP_MODULE_NAME, init);
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
// Copyright (c) Microsoft Corporation.
|
|
2
|
+
// Licensed under the MIT license.
|
|
3
|
+
|
|
4
|
+
// This header prototypes the Pseudoconsole symbols from conpty.lib with their original names.
|
|
5
|
+
// This is required because we cannot import __imp_CreatePseudoConsole from a static library
|
|
6
|
+
// as it doesn't produce an import lib.
|
|
7
|
+
// We can't use an /ALTERNATENAME trick because it seems that that name is only resolved when the
|
|
8
|
+
// linker cannot otherwise find the symbol.
|
|
9
|
+
|
|
10
|
+
#pragma once
|
|
11
|
+
|
|
12
|
+
#include <consoleapi.h>
|
|
13
|
+
|
|
14
|
+
#ifndef CONPTY_IMPEXP
|
|
15
|
+
#define CONPTY_IMPEXP __declspec(dllimport)
|
|
16
|
+
#endif
|
|
17
|
+
|
|
18
|
+
#ifndef CONPTY_EXPORT
|
|
19
|
+
#ifdef __cplusplus
|
|
20
|
+
#define CONPTY_EXPORT extern "C" CONPTY_IMPEXP
|
|
21
|
+
#else
|
|
22
|
+
#define CONPTY_EXPORT extern CONPTY_IMPEXP
|
|
23
|
+
#endif
|
|
24
|
+
#endif
|
|
25
|
+
|
|
26
|
+
#define PSEUDOCONSOLE_RESIZE_QUIRK (2u)
|
|
27
|
+
#define PSEUDOCONSOLE_PASSTHROUGH_MODE (8u)
|
|
28
|
+
|
|
29
|
+
CONPTY_EXPORT HRESULT WINAPI ConptyCreatePseudoConsole(COORD size, HANDLE hInput, HANDLE hOutput, DWORD dwFlags, HPCON* phPC);
|
|
30
|
+
CONPTY_EXPORT HRESULT WINAPI ConptyCreatePseudoConsoleAsUser(HANDLE hToken, COORD size, HANDLE hInput, HANDLE hOutput, DWORD dwFlags, HPCON* phPC);
|
|
31
|
+
|
|
32
|
+
CONPTY_EXPORT HRESULT WINAPI ConptyResizePseudoConsole(HPCON hPC, COORD size);
|
|
33
|
+
CONPTY_EXPORT HRESULT WINAPI ConptyClearPseudoConsole(HPCON hPC);
|
|
34
|
+
CONPTY_EXPORT HRESULT WINAPI ConptyShowHidePseudoConsole(HPCON hPC, bool show);
|
|
35
|
+
CONPTY_EXPORT HRESULT WINAPI ConptyReparentPseudoConsole(HPCON hPC, HWND newParent);
|
|
36
|
+
CONPTY_EXPORT HRESULT WINAPI ConptyReleasePseudoConsole(HPCON hPC);
|
|
37
|
+
|
|
38
|
+
CONPTY_EXPORT VOID WINAPI ConptyClosePseudoConsole(HPCON hPC);
|
|
39
|
+
CONPTY_EXPORT VOID WINAPI ConptyClosePseudoConsoleTimeout(HPCON hPC, DWORD dwMilliseconds);
|
|
40
|
+
|
|
41
|
+
CONPTY_EXPORT HRESULT WINAPI ConptyPackPseudoConsole(HANDLE hServerProcess, HANDLE hRef, HANDLE hSignal, HPCON* phPC);
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Copyright (c) 2019, Microsoft Corporation (MIT License).
|
|
3
|
+
*/
|
|
4
|
+
|
|
5
|
+
#define NODE_ADDON_API_DISABLE_DEPRECATED
|
|
6
|
+
#include <napi.h>
|
|
7
|
+
#include <windows.h>
|
|
8
|
+
|
|
9
|
+
static Napi::Value ApiConsoleProcessList(const Napi::CallbackInfo& info) {
|
|
10
|
+
Napi::Env env(info.Env());
|
|
11
|
+
if (info.Length() != 1 ||
|
|
12
|
+
!info[0].IsNumber()) {
|
|
13
|
+
throw Napi::Error::New(env, "Usage: getConsoleProcessList(shellPid)");
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
const DWORD pid = info[0].As<Napi::Number>().Uint32Value();
|
|
17
|
+
|
|
18
|
+
if (!FreeConsole()) {
|
|
19
|
+
throw Napi::Error::New(env, "FreeConsole failed");
|
|
20
|
+
}
|
|
21
|
+
if (!AttachConsole(pid)) {
|
|
22
|
+
throw Napi::Error::New(env, "AttachConsole failed");
|
|
23
|
+
}
|
|
24
|
+
auto processList = std::vector<DWORD>(64);
|
|
25
|
+
auto processCount = GetConsoleProcessList(&processList[0], static_cast<DWORD>(processList.size()));
|
|
26
|
+
if (processList.size() < processCount) {
|
|
27
|
+
processList.resize(processCount);
|
|
28
|
+
processCount = GetConsoleProcessList(&processList[0], static_cast<DWORD>(processList.size()));
|
|
29
|
+
}
|
|
30
|
+
FreeConsole();
|
|
31
|
+
|
|
32
|
+
Napi::Array result = Napi::Array::New(env);
|
|
33
|
+
for (DWORD i = 0; i < processCount; i++) {
|
|
34
|
+
result.Set(i, Napi::Number::New(env, processList[i]));
|
|
35
|
+
}
|
|
36
|
+
return result;
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
Napi::Object init(Napi::Env env, Napi::Object exports) {
|
|
40
|
+
exports.Set("getConsoleProcessList", Napi::Function::New(env, ApiConsoleProcessList));
|
|
41
|
+
return exports;
|
|
42
|
+
};
|
|
43
|
+
|
|
44
|
+
NODE_API_MODULE(NODE_GYP_MODULE_NAME, init);
|