@wingman-ai/gateway 0.5.2 → 0.5.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/agent/config/agentConfig.cjs +4 -0
- package/dist/agent/config/agentConfig.d.ts +12 -0
- package/dist/agent/config/agentConfig.js +4 -0
- package/dist/agent/config/toolRegistry.cjs +75 -1
- package/dist/agent/config/toolRegistry.d.ts +3 -0
- package/dist/agent/config/toolRegistry.js +75 -1
- package/dist/agent/middleware/large-tool-results.cjs +207 -0
- package/dist/agent/middleware/large-tool-results.d.ts +16 -0
- package/dist/agent/middleware/large-tool-results.js +173 -0
- package/dist/agent/tools/browser_control.cjs +9 -1231
- package/dist/agent/tools/browser_control.d.ts +126 -234
- package/dist/agent/tools/browser_control.js +7 -1226
- package/dist/agent/tools/browser_runtime.cjs +1189 -0
- package/dist/agent/tools/browser_runtime.d.ts +560 -0
- package/dist/agent/tools/browser_runtime.js +1122 -0
- package/dist/agent/tools/browser_session.cjs +153 -0
- package/dist/agent/tools/browser_session.d.ts +741 -0
- package/dist/agent/tools/browser_session.js +110 -0
- package/dist/agent/tools/browser_session_manager.cjs +202 -0
- package/dist/agent/tools/browser_session_manager.d.ts +64 -0
- package/dist/agent/tools/browser_session_manager.js +165 -0
- package/dist/cli/commands/init.cjs +5 -1
- package/dist/cli/commands/init.js +5 -1
- package/dist/cli/config/loader.cjs +0 -5
- package/dist/cli/config/loader.js +0 -5
- package/dist/cli/config/schema.cjs +3 -7
- package/dist/cli/config/schema.d.ts +6 -6
- package/dist/cli/config/schema.js +3 -7
- package/dist/cli/core/agentInvoker.cjs +86 -22
- package/dist/cli/core/agentInvoker.d.ts +10 -3
- package/dist/cli/core/agentInvoker.js +86 -25
- package/dist/cli/core/outputManager.cjs +7 -2
- package/dist/cli/core/outputManager.d.ts +2 -2
- package/dist/cli/core/outputManager.js +7 -2
- package/dist/cli/types.d.ts +2 -1
- package/dist/webui/assets/index-XrEnkZiq.css +11 -0
- package/dist/webui/assets/index-mDs6HbKM.js +215 -0
- package/dist/webui/index.html +2 -2
- package/package.json +10 -10
- package/templates/agents/README.md +2 -1
- package/templates/agents/coding/agent.md +6 -13
- package/templates/agents/coding-v2/agent.md +6 -1
- package/templates/agents/game-dev/agent.md +8 -2
- package/templates/agents/game-dev/game-designer.md +4 -0
- package/templates/agents/game-dev/scene-engineer.md +4 -0
- package/templates/agents/main/agent.md +5 -0
- package/templates/agents/researcher/agent.md +11 -0
- package/templates/agents/stock-trader/agent.md +4 -0
- package/dist/agent/tests/agentConfig.test.cjs +0 -224
- package/dist/agent/tests/agentConfig.test.d.ts +0 -1
- package/dist/agent/tests/agentConfig.test.js +0 -218
- package/dist/agent/tests/agentLoader.test.cjs +0 -335
- package/dist/agent/tests/agentLoader.test.d.ts +0 -1
- package/dist/agent/tests/agentLoader.test.js +0 -329
- package/dist/agent/tests/backgroundTerminal.test.cjs +0 -70
- package/dist/agent/tests/backgroundTerminal.test.d.ts +0 -1
- package/dist/agent/tests/backgroundTerminal.test.js +0 -64
- package/dist/agent/tests/browserControlHelpers.test.cjs +0 -35
- package/dist/agent/tests/browserControlHelpers.test.d.ts +0 -1
- package/dist/agent/tests/browserControlHelpers.test.js +0 -29
- package/dist/agent/tests/browserControlTool.test.cjs +0 -2117
- package/dist/agent/tests/browserControlTool.test.d.ts +0 -1
- package/dist/agent/tests/browserControlTool.test.js +0 -2111
- package/dist/agent/tests/commandExecuteTool.test.cjs +0 -29
- package/dist/agent/tests/commandExecuteTool.test.d.ts +0 -1
- package/dist/agent/tests/commandExecuteTool.test.js +0 -23
- package/dist/agent/tests/internet_search.test.cjs +0 -107
- package/dist/agent/tests/internet_search.test.d.ts +0 -1
- package/dist/agent/tests/internet_search.test.js +0 -101
- package/dist/agent/tests/mcpClientManager.test.cjs +0 -290
- package/dist/agent/tests/mcpClientManager.test.d.ts +0 -1
- package/dist/agent/tests/mcpClientManager.test.js +0 -284
- package/dist/agent/tests/mcpResourceTools.test.cjs +0 -101
- package/dist/agent/tests/mcpResourceTools.test.d.ts +0 -1
- package/dist/agent/tests/mcpResourceTools.test.js +0 -95
- package/dist/agent/tests/modelFactory.test.cjs +0 -190
- package/dist/agent/tests/modelFactory.test.d.ts +0 -1
- package/dist/agent/tests/modelFactory.test.js +0 -184
- package/dist/agent/tests/terminalSessionManager.test.cjs +0 -121
- package/dist/agent/tests/terminalSessionManager.test.d.ts +0 -1
- package/dist/agent/tests/terminalSessionManager.test.js +0 -115
- package/dist/agent/tests/test-agent-loader.cjs +0 -33
- package/dist/agent/tests/test-agent-loader.d.ts +0 -1
- package/dist/agent/tests/test-agent-loader.js +0 -27
- package/dist/agent/tests/test-subagent-loading.cjs +0 -99
- package/dist/agent/tests/test-subagent-loading.d.ts +0 -1
- package/dist/agent/tests/test-subagent-loading.js +0 -93
- package/dist/agent/tests/toolRegistry.test.cjs +0 -147
- package/dist/agent/tests/toolRegistry.test.d.ts +0 -1
- package/dist/agent/tests/toolRegistry.test.js +0 -141
- package/dist/agent/tests/uiRegistryTools.test.cjs +0 -114
- package/dist/agent/tests/uiRegistryTools.test.d.ts +0 -1
- package/dist/agent/tests/uiRegistryTools.test.js +0 -105
- package/dist/agent/tests/xaiImageModel.test.cjs +0 -194
- package/dist/agent/tests/xaiImageModel.test.d.ts +0 -1
- package/dist/agent/tests/xaiImageModel.test.js +0 -188
- package/dist/tests/additionalMessageMiddleware.test.cjs +0 -216
- package/dist/tests/additionalMessageMiddleware.test.d.ts +0 -1
- package/dist/tests/additionalMessageMiddleware.test.js +0 -188
- package/dist/tests/agent-config-voice.test.cjs +0 -25
- package/dist/tests/agent-config-voice.test.d.ts +0 -1
- package/dist/tests/agent-config-voice.test.js +0 -19
- package/dist/tests/agentInvokerAttachments.test.cjs +0 -190
- package/dist/tests/agentInvokerAttachments.test.d.ts +0 -1
- package/dist/tests/agentInvokerAttachments.test.js +0 -184
- package/dist/tests/agentInvokerSummarization.test.cjs +0 -613
- package/dist/tests/agentInvokerSummarization.test.d.ts +0 -1
- package/dist/tests/agentInvokerSummarization.test.js +0 -607
- package/dist/tests/agentInvokerTokenUsage.test.cjs +0 -124
- package/dist/tests/agentInvokerTokenUsage.test.d.ts +0 -1
- package/dist/tests/agentInvokerTokenUsage.test.js +0 -118
- package/dist/tests/agentInvokerWorkdir.test.cjs +0 -150
- package/dist/tests/agentInvokerWorkdir.test.d.ts +0 -1
- package/dist/tests/agentInvokerWorkdir.test.js +0 -122
- package/dist/tests/agents-api.test.cjs +0 -324
- package/dist/tests/agents-api.test.d.ts +0 -1
- package/dist/tests/agents-api.test.js +0 -318
- package/dist/tests/attachments-utils.test.cjs +0 -46
- package/dist/tests/attachments-utils.test.d.ts +0 -1
- package/dist/tests/attachments-utils.test.js +0 -40
- package/dist/tests/browser-command.test.cjs +0 -264
- package/dist/tests/browser-command.test.d.ts +0 -1
- package/dist/tests/browser-command.test.js +0 -258
- package/dist/tests/browser-relay-server.test.cjs +0 -20
- package/dist/tests/browser-relay-server.test.d.ts +0 -1
- package/dist/tests/browser-relay-server.test.js +0 -14
- package/dist/tests/bunSqliteAdapter.test.cjs +0 -265
- package/dist/tests/bunSqliteAdapter.test.d.ts +0 -1
- package/dist/tests/bunSqliteAdapter.test.js +0 -259
- package/dist/tests/candleRange.test.cjs +0 -48
- package/dist/tests/candleRange.test.d.ts +0 -1
- package/dist/tests/candleRange.test.js +0 -42
- package/dist/tests/cli-config-loader.test.cjs +0 -532
- package/dist/tests/cli-config-loader.test.d.ts +0 -1
- package/dist/tests/cli-config-loader.test.js +0 -526
- package/dist/tests/cli-config-warnings.test.cjs +0 -94
- package/dist/tests/cli-config-warnings.test.d.ts +0 -1
- package/dist/tests/cli-config-warnings.test.js +0 -88
- package/dist/tests/cli-init.test.cjs +0 -225
- package/dist/tests/cli-init.test.d.ts +0 -1
- package/dist/tests/cli-init.test.js +0 -219
- package/dist/tests/cli-workspace-root.test.cjs +0 -114
- package/dist/tests/cli-workspace-root.test.d.ts +0 -1
- package/dist/tests/cli-workspace-root.test.js +0 -108
- package/dist/tests/codex-credentials-precedence.test.cjs +0 -94
- package/dist/tests/codex-credentials-precedence.test.d.ts +0 -1
- package/dist/tests/codex-credentials-precedence.test.js +0 -88
- package/dist/tests/codex-provider.test.cjs +0 -383
- package/dist/tests/codex-provider.test.d.ts +0 -1
- package/dist/tests/codex-provider.test.js +0 -377
- package/dist/tests/config-json-schema.test.cjs +0 -37
- package/dist/tests/config-json-schema.test.d.ts +0 -1
- package/dist/tests/config-json-schema.test.js +0 -31
- package/dist/tests/discord-adapter.test.cjs +0 -89
- package/dist/tests/discord-adapter.test.d.ts +0 -1
- package/dist/tests/discord-adapter.test.js +0 -83
- package/dist/tests/falRuntime.test.cjs +0 -78
- package/dist/tests/falRuntime.test.d.ts +0 -1
- package/dist/tests/falRuntime.test.js +0 -72
- package/dist/tests/falSummary.test.cjs +0 -51
- package/dist/tests/falSummary.test.d.ts +0 -1
- package/dist/tests/falSummary.test.js +0 -45
- package/dist/tests/fs-api.test.cjs +0 -138
- package/dist/tests/fs-api.test.d.ts +0 -1
- package/dist/tests/fs-api.test.js +0 -132
- package/dist/tests/gateway-command-workspace.test.cjs +0 -150
- package/dist/tests/gateway-command-workspace.test.d.ts +0 -1
- package/dist/tests/gateway-command-workspace.test.js +0 -144
- package/dist/tests/gateway-http-security.test.cjs +0 -318
- package/dist/tests/gateway-http-security.test.d.ts +0 -1
- package/dist/tests/gateway-http-security.test.js +0 -312
- package/dist/tests/gateway-node-mode.test.cjs +0 -174
- package/dist/tests/gateway-node-mode.test.d.ts +0 -1
- package/dist/tests/gateway-node-mode.test.js +0 -168
- package/dist/tests/gateway-origin-policy.test.cjs +0 -82
- package/dist/tests/gateway-origin-policy.test.d.ts +0 -1
- package/dist/tests/gateway-origin-policy.test.js +0 -76
- package/dist/tests/gateway-request-execution-overrides.test.cjs +0 -42
- package/dist/tests/gateway-request-execution-overrides.test.d.ts +0 -1
- package/dist/tests/gateway-request-execution-overrides.test.js +0 -36
- package/dist/tests/gateway.test.cjs +0 -700
- package/dist/tests/gateway.test.d.ts +0 -1
- package/dist/tests/gateway.test.js +0 -694
- package/dist/tests/hooks-matcher.test.cjs +0 -309
- package/dist/tests/hooks-matcher.test.d.ts +0 -1
- package/dist/tests/hooks-matcher.test.js +0 -303
- package/dist/tests/hooks-merger.test.cjs +0 -528
- package/dist/tests/hooks-merger.test.d.ts +0 -1
- package/dist/tests/hooks-merger.test.js +0 -522
- package/dist/tests/imagePersistence.test.cjs +0 -169
- package/dist/tests/imagePersistence.test.d.ts +0 -1
- package/dist/tests/imagePersistence.test.js +0 -163
- package/dist/tests/integration/agent-invocation.integration.test.cjs +0 -264
- package/dist/tests/integration/agent-invocation.integration.test.d.ts +0 -1
- package/dist/tests/integration/agent-invocation.integration.test.js +0 -258
- package/dist/tests/integration/finnhub-candles.integration.test.cjs +0 -98
- package/dist/tests/integration/finnhub-candles.integration.test.d.ts +0 -1
- package/dist/tests/integration/finnhub-candles.integration.test.js +0 -92
- package/dist/tests/integration/summarization-e2e.integration.test.cjs +0 -127
- package/dist/tests/integration/summarization-e2e.integration.test.d.ts +0 -1
- package/dist/tests/integration/summarization-e2e.integration.test.js +0 -121
- package/dist/tests/logger.test.cjs +0 -353
- package/dist/tests/logger.test.d.ts +0 -1
- package/dist/tests/logger.test.js +0 -347
- package/dist/tests/mediaCompatibilityMiddleware.test.cjs +0 -106
- package/dist/tests/mediaCompatibilityMiddleware.test.d.ts +0 -1
- package/dist/tests/mediaCompatibilityMiddleware.test.js +0 -100
- package/dist/tests/node-tools.test.cjs +0 -77
- package/dist/tests/node-tools.test.d.ts +0 -1
- package/dist/tests/node-tools.test.js +0 -71
- package/dist/tests/nodes-api.test.cjs +0 -86
- package/dist/tests/nodes-api.test.d.ts +0 -1
- package/dist/tests/nodes-api.test.js +0 -80
- package/dist/tests/outputManagerContextSummarized.test.cjs +0 -43
- package/dist/tests/outputManagerContextSummarized.test.d.ts +0 -1
- package/dist/tests/outputManagerContextSummarized.test.js +0 -37
- package/dist/tests/provider-command-codex.test.cjs +0 -57
- package/dist/tests/provider-command-codex.test.d.ts +0 -1
- package/dist/tests/provider-command-codex.test.js +0 -51
- package/dist/tests/routines-api.test.cjs +0 -107
- package/dist/tests/routines-api.test.d.ts +0 -1
- package/dist/tests/routines-api.test.js +0 -101
- package/dist/tests/run-terminal-bench-official-script.test.cjs +0 -61
- package/dist/tests/run-terminal-bench-official-script.test.d.ts +0 -1
- package/dist/tests/run-terminal-bench-official-script.test.js +0 -55
- package/dist/tests/sessionManager-uionly.test.cjs +0 -50
- package/dist/tests/sessionManager-uionly.test.d.ts +0 -1
- package/dist/tests/sessionManager-uionly.test.js +0 -44
- package/dist/tests/sessionMessageAttachments.test.cjs +0 -197
- package/dist/tests/sessionMessageAttachments.test.d.ts +0 -1
- package/dist/tests/sessionMessageAttachments.test.js +0 -191
- package/dist/tests/sessionMessageRole.test.cjs +0 -44
- package/dist/tests/sessionMessageRole.test.d.ts +0 -1
- package/dist/tests/sessionMessageRole.test.js +0 -38
- package/dist/tests/sessionStateMessages.test.cjs +0 -236
- package/dist/tests/sessionStateMessages.test.d.ts +0 -1
- package/dist/tests/sessionStateMessages.test.js +0 -230
- package/dist/tests/sessions-api.test.cjs +0 -250
- package/dist/tests/sessions-api.test.d.ts +0 -1
- package/dist/tests/sessions-api.test.js +0 -244
- package/dist/tests/skill-activation.test.cjs +0 -86
- package/dist/tests/skill-activation.test.d.ts +0 -1
- package/dist/tests/skill-activation.test.js +0 -80
- package/dist/tests/skill-metadata.test.cjs +0 -119
- package/dist/tests/skill-metadata.test.d.ts +0 -1
- package/dist/tests/skill-metadata.test.js +0 -113
- package/dist/tests/skill-repository.test.cjs +0 -469
- package/dist/tests/skill-repository.test.d.ts +0 -1
- package/dist/tests/skill-repository.test.js +0 -463
- package/dist/tests/skill-security-scanner.test.cjs +0 -126
- package/dist/tests/skill-security-scanner.test.d.ts +0 -1
- package/dist/tests/skill-security-scanner.test.js +0 -120
- package/dist/tests/sms-api.test.cjs +0 -183
- package/dist/tests/sms-api.test.d.ts +0 -1
- package/dist/tests/sms-api.test.js +0 -177
- package/dist/tests/sms-commands.test.cjs +0 -90
- package/dist/tests/sms-commands.test.d.ts +0 -1
- package/dist/tests/sms-commands.test.js +0 -84
- package/dist/tests/sms-policy-store.test.cjs +0 -69
- package/dist/tests/sms-policy-store.test.d.ts +0 -1
- package/dist/tests/sms-policy-store.test.js +0 -63
- package/dist/tests/teams-adapter.test.cjs +0 -58
- package/dist/tests/teams-adapter.test.d.ts +0 -1
- package/dist/tests/teams-adapter.test.js +0 -52
- package/dist/tests/technicalIndicators.test.cjs +0 -82
- package/dist/tests/technicalIndicators.test.d.ts +0 -1
- package/dist/tests/technicalIndicators.test.js +0 -76
- package/dist/tests/terminal-bench-adapters-helpers.test.cjs +0 -64
- package/dist/tests/terminal-bench-adapters-helpers.test.d.ts +0 -1
- package/dist/tests/terminal-bench-adapters-helpers.test.js +0 -58
- package/dist/tests/terminal-bench-cleanup.test.cjs +0 -93
- package/dist/tests/terminal-bench-cleanup.test.d.ts +0 -1
- package/dist/tests/terminal-bench-cleanup.test.js +0 -87
- package/dist/tests/terminal-bench-config.test.cjs +0 -62
- package/dist/tests/terminal-bench-config.test.d.ts +0 -1
- package/dist/tests/terminal-bench-config.test.js +0 -56
- package/dist/tests/terminal-bench-official.test.cjs +0 -194
- package/dist/tests/terminal-bench-official.test.d.ts +0 -1
- package/dist/tests/terminal-bench-official.test.js +0 -188
- package/dist/tests/terminal-bench-runner.test.cjs +0 -82
- package/dist/tests/terminal-bench-runner.test.d.ts +0 -1
- package/dist/tests/terminal-bench-runner.test.js +0 -76
- package/dist/tests/terminal-bench-scoring.test.cjs +0 -128
- package/dist/tests/terminal-bench-scoring.test.d.ts +0 -1
- package/dist/tests/terminal-bench-scoring.test.js +0 -122
- package/dist/tests/terminalProbe.test.cjs +0 -45
- package/dist/tests/terminalProbe.test.d.ts +0 -1
- package/dist/tests/terminalProbe.test.js +0 -39
- package/dist/tests/terminalProbeAuth.test.cjs +0 -85
- package/dist/tests/terminalProbeAuth.test.d.ts +0 -1
- package/dist/tests/terminalProbeAuth.test.js +0 -79
- package/dist/tests/toolDisplayHelpers.test.cjs +0 -46
- package/dist/tests/toolDisplayHelpers.test.d.ts +0 -1
- package/dist/tests/toolDisplayHelpers.test.js +0 -40
- package/dist/tests/uv.test.cjs +0 -47
- package/dist/tests/uv.test.d.ts +0 -1
- package/dist/tests/uv.test.js +0 -41
- package/dist/tests/voice-config.test.cjs +0 -35
- package/dist/tests/voice-config.test.d.ts +0 -1
- package/dist/tests/voice-config.test.js +0 -29
- package/dist/tests/websocket-transport.test.cjs +0 -31
- package/dist/tests/websocket-transport.test.d.ts +0 -1
- package/dist/tests/websocket-transport.test.js +0 -25
- package/dist/tests/yahooCandles.test.cjs +0 -111
- package/dist/tests/yahooCandles.test.d.ts +0 -1
- package/dist/tests/yahooCandles.test.js +0 -105
- package/dist/tools/finance/optionsAnalytics.test.cjs +0 -128
- package/dist/tools/finance/optionsAnalytics.test.d.ts +0 -1
- package/dist/tools/finance/optionsAnalytics.test.js +0 -122
- package/dist/webui/assets/index-D07GBGp0.js +0 -215
- package/dist/webui/assets/index-DV8IYeOw.css +0 -11
|
@@ -0,0 +1,110 @@
|
|
|
1
|
+
import { tool } from "langchain";
|
|
2
|
+
import { object, string } from "zod";
|
|
3
|
+
import { BrowserControlInputSchema, BrowserSessionActionInputSchema } from "./browser_runtime.js";
|
|
4
|
+
const CloseBrowserSessionInputSchema = object({
|
|
5
|
+
session_id: string().min(1).describe("Existing browser session id to close")
|
|
6
|
+
});
|
|
7
|
+
const BrowserSessionListInputSchema = object({});
|
|
8
|
+
const buildResponse = (payload)=>payload;
|
|
9
|
+
const summarizeResult = (snapshot, summary)=>({
|
|
10
|
+
session_id: snapshot.sessionId,
|
|
11
|
+
status: snapshot.status,
|
|
12
|
+
transport_requested: snapshot.transportRequested,
|
|
13
|
+
transport_used: snapshot.transportUsed,
|
|
14
|
+
mode: snapshot.mode,
|
|
15
|
+
persistent_profile: snapshot.persistentProfile,
|
|
16
|
+
profile_id: snapshot.profileId || null,
|
|
17
|
+
profile_path: snapshot.profilePath || null,
|
|
18
|
+
reused_existing_session: snapshot.reusedExistingSession,
|
|
19
|
+
started_at: snapshot.startedAt,
|
|
20
|
+
updated_at: snapshot.updatedAt,
|
|
21
|
+
workspace: snapshot.workspace,
|
|
22
|
+
config_workspace: snapshot.configWorkspace,
|
|
23
|
+
final_url: summary?.finalUrl || snapshot.finalUrl || null,
|
|
24
|
+
title: summary?.title || snapshot.title || null,
|
|
25
|
+
fallback_reason: summary?.fallbackReason || null,
|
|
26
|
+
extensions: summary?.extensions || [],
|
|
27
|
+
action_results: summary?.actionResults || [],
|
|
28
|
+
browser: summary?.browser || null,
|
|
29
|
+
transport: summary?.transport || snapshot.transportUsed
|
|
30
|
+
});
|
|
31
|
+
const createBrowserSessionStartTool = (options, dependencies = {})=>tool(async (input)=>{
|
|
32
|
+
try {
|
|
33
|
+
const { snapshot, summary } = await options.sessionManager.startSession({
|
|
34
|
+
ownerId: options.ownerId,
|
|
35
|
+
options,
|
|
36
|
+
dependencies,
|
|
37
|
+
input
|
|
38
|
+
});
|
|
39
|
+
return buildResponse({
|
|
40
|
+
ok: true,
|
|
41
|
+
...summarizeResult(snapshot, summary)
|
|
42
|
+
});
|
|
43
|
+
} catch (error) {
|
|
44
|
+
return buildResponse({
|
|
45
|
+
ok: false,
|
|
46
|
+
error: error instanceof Error ? error.message : String(error)
|
|
47
|
+
});
|
|
48
|
+
}
|
|
49
|
+
}, {
|
|
50
|
+
name: "browser_session_start",
|
|
51
|
+
description: 'Start a managed browser session that persists across multiple tool calls. Use this for iterative QA/debugging where the same browser state should survive across turns. Transport can be selected per session with "auto", "playwright", or "relay".',
|
|
52
|
+
schema: BrowserControlInputSchema
|
|
53
|
+
});
|
|
54
|
+
const createBrowserSessionActionTool = (options)=>tool(async (input)=>{
|
|
55
|
+
try {
|
|
56
|
+
const { session_id, ...actionInput } = input;
|
|
57
|
+
const { snapshot, summary } = await options.sessionManager.runSession({
|
|
58
|
+
ownerId: options.ownerId,
|
|
59
|
+
sessionId: session_id,
|
|
60
|
+
input: actionInput
|
|
61
|
+
});
|
|
62
|
+
return buildResponse({
|
|
63
|
+
ok: true,
|
|
64
|
+
...summarizeResult(snapshot, summary)
|
|
65
|
+
});
|
|
66
|
+
} catch (error) {
|
|
67
|
+
return buildResponse({
|
|
68
|
+
ok: false,
|
|
69
|
+
error: error instanceof Error ? error.message : String(error)
|
|
70
|
+
});
|
|
71
|
+
}
|
|
72
|
+
}, {
|
|
73
|
+
name: "browser_session_action",
|
|
74
|
+
description: "Run browser actions inside an existing managed browser session. Use the session_id returned by browser_session_start to continue the same tab/profile state across multiple calls.",
|
|
75
|
+
schema: BrowserSessionActionInputSchema
|
|
76
|
+
});
|
|
77
|
+
const createBrowserSessionCloseTool = (options)=>tool(async ({ session_id })=>{
|
|
78
|
+
try {
|
|
79
|
+
const snapshot = await options.sessionManager.closeSession({
|
|
80
|
+
ownerId: options.ownerId,
|
|
81
|
+
sessionId: session_id
|
|
82
|
+
});
|
|
83
|
+
return buildResponse({
|
|
84
|
+
ok: true,
|
|
85
|
+
closed: true,
|
|
86
|
+
...summarizeResult(snapshot, null)
|
|
87
|
+
});
|
|
88
|
+
} catch (error) {
|
|
89
|
+
return buildResponse({
|
|
90
|
+
ok: false,
|
|
91
|
+
error: error instanceof Error ? error.message : String(error)
|
|
92
|
+
});
|
|
93
|
+
}
|
|
94
|
+
}, {
|
|
95
|
+
name: "browser_session_close",
|
|
96
|
+
description: "Close a managed browser session and release any temporary browser resources or profile locks owned by that session.",
|
|
97
|
+
schema: CloseBrowserSessionInputSchema
|
|
98
|
+
});
|
|
99
|
+
const createBrowserSessionListTool = (options)=>tool(async ()=>{
|
|
100
|
+
const sessions = options.sessionManager.listSessions(options.ownerId);
|
|
101
|
+
return buildResponse({
|
|
102
|
+
ok: true,
|
|
103
|
+
sessions: sessions.map((snapshot)=>summarizeResult(snapshot, null))
|
|
104
|
+
});
|
|
105
|
+
}, {
|
|
106
|
+
name: "browser_session_list",
|
|
107
|
+
description: "List the managed browser sessions currently owned by this agent run. Use this to recover a session_id before continuing or closing a session.",
|
|
108
|
+
schema: BrowserSessionListInputSchema
|
|
109
|
+
});
|
|
110
|
+
export { createBrowserSessionActionTool, createBrowserSessionCloseTool, createBrowserSessionListTool, createBrowserSessionStartTool };
|
|
@@ -0,0 +1,202 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __webpack_require__ = {};
|
|
3
|
+
(()=>{
|
|
4
|
+
__webpack_require__.d = (exports1, definition)=>{
|
|
5
|
+
for(var key in definition)if (__webpack_require__.o(definition, key) && !__webpack_require__.o(exports1, key)) Object.defineProperty(exports1, key, {
|
|
6
|
+
enumerable: true,
|
|
7
|
+
get: definition[key]
|
|
8
|
+
});
|
|
9
|
+
};
|
|
10
|
+
})();
|
|
11
|
+
(()=>{
|
|
12
|
+
__webpack_require__.o = (obj, prop)=>Object.prototype.hasOwnProperty.call(obj, prop);
|
|
13
|
+
})();
|
|
14
|
+
(()=>{
|
|
15
|
+
__webpack_require__.r = (exports1)=>{
|
|
16
|
+
if ("u" > typeof Symbol && Symbol.toStringTag) Object.defineProperty(exports1, Symbol.toStringTag, {
|
|
17
|
+
value: 'Module'
|
|
18
|
+
});
|
|
19
|
+
Object.defineProperty(exports1, '__esModule', {
|
|
20
|
+
value: true
|
|
21
|
+
});
|
|
22
|
+
};
|
|
23
|
+
})();
|
|
24
|
+
var __webpack_exports__ = {};
|
|
25
|
+
__webpack_require__.r(__webpack_exports__);
|
|
26
|
+
__webpack_require__.d(__webpack_exports__, {
|
|
27
|
+
getSharedBrowserSessionManager: ()=>getSharedBrowserSessionManager,
|
|
28
|
+
BrowserSessionManager: ()=>BrowserSessionManager
|
|
29
|
+
});
|
|
30
|
+
const external_node_crypto_namespaceObject = require("node:crypto");
|
|
31
|
+
const external_browser_runtime_cjs_namespaceObject = require("./browser_runtime.cjs");
|
|
32
|
+
function _define_property(obj, key, value) {
|
|
33
|
+
if (key in obj) Object.defineProperty(obj, key, {
|
|
34
|
+
value: value,
|
|
35
|
+
enumerable: true,
|
|
36
|
+
configurable: true,
|
|
37
|
+
writable: true
|
|
38
|
+
});
|
|
39
|
+
else obj[key] = value;
|
|
40
|
+
return obj;
|
|
41
|
+
}
|
|
42
|
+
const DEFAULT_MAX_SESSIONS_PER_OWNER = 3;
|
|
43
|
+
const DEFAULT_IDLE_TIMEOUT_MS = 900000;
|
|
44
|
+
class BrowserSessionManager {
|
|
45
|
+
async dispose() {
|
|
46
|
+
clearInterval(this.cleanupTimer);
|
|
47
|
+
const sessions = [
|
|
48
|
+
...this.sessions.values()
|
|
49
|
+
];
|
|
50
|
+
this.sessions.clear();
|
|
51
|
+
this.ownerIndex.clear();
|
|
52
|
+
await Promise.allSettled(sessions.map((record)=>(0, external_browser_runtime_cjs_namespaceObject.closeBrowserSessionRuntime)(record.runtime, record.dependencies)));
|
|
53
|
+
}
|
|
54
|
+
async startSession(input) {
|
|
55
|
+
const ownerId = this.normalizeOwnerId(input.ownerId);
|
|
56
|
+
const existing = this.ownerIndex.get(ownerId);
|
|
57
|
+
if ((existing?.size || 0) >= this.maxSessionsPerOwner) throw new Error(`Owner "${ownerId}" reached browser session limit (${this.maxSessionsPerOwner})`);
|
|
58
|
+
const runtime = await (0, external_browser_runtime_cjs_namespaceObject.openBrowserSessionRuntime)(input.options, input.dependencies, input.input);
|
|
59
|
+
const now = Date.now();
|
|
60
|
+
const sessionId = (0, external_node_crypto_namespaceObject.randomUUID)();
|
|
61
|
+
const record = {
|
|
62
|
+
sessionId,
|
|
63
|
+
ownerId,
|
|
64
|
+
runtime,
|
|
65
|
+
dependencies: input.dependencies || {},
|
|
66
|
+
startedAt: now,
|
|
67
|
+
updatedAt: now,
|
|
68
|
+
lastSummary: null,
|
|
69
|
+
closing: false
|
|
70
|
+
};
|
|
71
|
+
this.sessions.set(sessionId, record);
|
|
72
|
+
if (existing) existing.add(sessionId);
|
|
73
|
+
else this.ownerIndex.set(ownerId, new Set([
|
|
74
|
+
sessionId
|
|
75
|
+
]));
|
|
76
|
+
try {
|
|
77
|
+
const summary = await (0, external_browser_runtime_cjs_namespaceObject.executeBrowserSessionRuntime)(runtime, input.input);
|
|
78
|
+
record.lastSummary = summary;
|
|
79
|
+
record.updatedAt = Date.now();
|
|
80
|
+
return {
|
|
81
|
+
snapshot: this.toSnapshot(record),
|
|
82
|
+
summary
|
|
83
|
+
};
|
|
84
|
+
} catch (error) {
|
|
85
|
+
await this.closeAndDelete(record);
|
|
86
|
+
throw error;
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
async runSession(input) {
|
|
90
|
+
const record = this.getOwnedRecord(input.ownerId, input.sessionId);
|
|
91
|
+
const summary = await (0, external_browser_runtime_cjs_namespaceObject.executeBrowserSessionRuntime)(record.runtime, input.input);
|
|
92
|
+
record.lastSummary = summary;
|
|
93
|
+
record.updatedAt = Date.now();
|
|
94
|
+
return {
|
|
95
|
+
snapshot: this.toSnapshot(record),
|
|
96
|
+
summary
|
|
97
|
+
};
|
|
98
|
+
}
|
|
99
|
+
async closeSession(input) {
|
|
100
|
+
const record = this.getOwnedRecord(input.ownerId, input.sessionId);
|
|
101
|
+
const snapshot = this.toSnapshot(record);
|
|
102
|
+
await this.closeAndDelete(record);
|
|
103
|
+
return snapshot;
|
|
104
|
+
}
|
|
105
|
+
listSessions(ownerId) {
|
|
106
|
+
const normalizedOwnerId = this.normalizeOwnerId(ownerId);
|
|
107
|
+
const sessionIds = this.ownerIndex.get(normalizedOwnerId);
|
|
108
|
+
if (!sessionIds || 0 === sessionIds.size) return [];
|
|
109
|
+
return [
|
|
110
|
+
...sessionIds
|
|
111
|
+
].map((sessionId)=>this.sessions.get(sessionId)).filter((record)=>Boolean(record)).sort((a, b)=>b.updatedAt - a.updatedAt).map((record)=>this.toSnapshot(record));
|
|
112
|
+
}
|
|
113
|
+
async cleanupExpiredSessions() {
|
|
114
|
+
const now = Date.now();
|
|
115
|
+
const expired = [
|
|
116
|
+
...this.sessions.values()
|
|
117
|
+
].filter((record)=>!record.closing && now - record.updatedAt > this.idleTimeoutMs);
|
|
118
|
+
await Promise.allSettled(expired.map((record)=>this.closeAndDelete(record)));
|
|
119
|
+
}
|
|
120
|
+
async closeAndDelete(record) {
|
|
121
|
+
if (record.closing) return;
|
|
122
|
+
record.closing = true;
|
|
123
|
+
try {
|
|
124
|
+
await (0, external_browser_runtime_cjs_namespaceObject.closeBrowserSessionRuntime)(record.runtime, record.dependencies);
|
|
125
|
+
} finally{
|
|
126
|
+
this.sessions.delete(record.sessionId);
|
|
127
|
+
const ownerSessions = this.ownerIndex.get(record.ownerId);
|
|
128
|
+
if (ownerSessions) {
|
|
129
|
+
ownerSessions.delete(record.sessionId);
|
|
130
|
+
if (0 === ownerSessions.size) this.ownerIndex.delete(record.ownerId);
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
getOwnedRecord(ownerId, sessionId) {
|
|
135
|
+
const normalizedOwnerId = this.normalizeOwnerId(ownerId);
|
|
136
|
+
const record = this.sessions.get(sessionId);
|
|
137
|
+
if (!record) throw new Error(`Browser session ${sessionId} was not found`);
|
|
138
|
+
if (record.ownerId !== normalizedOwnerId) throw new Error(`Browser session ${sessionId} is not accessible`);
|
|
139
|
+
if (record.closing) throw new Error(`Browser session ${sessionId} is closing`);
|
|
140
|
+
return record;
|
|
141
|
+
}
|
|
142
|
+
toSnapshot(record) {
|
|
143
|
+
return {
|
|
144
|
+
sessionId: record.sessionId,
|
|
145
|
+
ownerId: record.ownerId,
|
|
146
|
+
workspace: record.runtime.workspace,
|
|
147
|
+
configWorkspace: record.runtime.configWorkspace,
|
|
148
|
+
status: "running",
|
|
149
|
+
startedAt: record.startedAt,
|
|
150
|
+
updatedAt: record.updatedAt,
|
|
151
|
+
transportRequested: record.runtime.transportRequested,
|
|
152
|
+
transportUsed: record.runtime.browserTransport,
|
|
153
|
+
mode: record.runtime.headless ? "headless" : "headed",
|
|
154
|
+
persistentProfile: record.runtime.userDataDirSelection.persistentProfile,
|
|
155
|
+
...record.runtime.userDataDirSelection.profileId ? {
|
|
156
|
+
profileId: record.runtime.userDataDirSelection.profileId
|
|
157
|
+
} : {},
|
|
158
|
+
...record.runtime.userDataDirSelection.persistentProfile ? {
|
|
159
|
+
profilePath: record.runtime.userDataDirSelection.userDataDir
|
|
160
|
+
} : {},
|
|
161
|
+
reusedExistingSession: record.runtime.reusedExistingCdpSession,
|
|
162
|
+
...record.lastSummary?.finalUrl ? {
|
|
163
|
+
finalUrl: record.lastSummary.finalUrl
|
|
164
|
+
} : {},
|
|
165
|
+
...record.lastSummary?.title ? {
|
|
166
|
+
title: record.lastSummary.title
|
|
167
|
+
} : {}
|
|
168
|
+
};
|
|
169
|
+
}
|
|
170
|
+
normalizeOwnerId(ownerId) {
|
|
171
|
+
const trimmed = ownerId.trim();
|
|
172
|
+
if (!trimmed) throw new Error("Browser ownerId is required");
|
|
173
|
+
return trimmed;
|
|
174
|
+
}
|
|
175
|
+
constructor(options = {}){
|
|
176
|
+
_define_property(this, "sessions", new Map());
|
|
177
|
+
_define_property(this, "ownerIndex", new Map());
|
|
178
|
+
_define_property(this, "cleanupTimer", void 0);
|
|
179
|
+
_define_property(this, "maxSessionsPerOwner", void 0);
|
|
180
|
+
_define_property(this, "idleTimeoutMs", void 0);
|
|
181
|
+
this.maxSessionsPerOwner = options.maxSessionsPerOwner ?? DEFAULT_MAX_SESSIONS_PER_OWNER;
|
|
182
|
+
this.idleTimeoutMs = options.idleTimeoutMs ?? DEFAULT_IDLE_TIMEOUT_MS;
|
|
183
|
+
this.cleanupTimer = setInterval(()=>{
|
|
184
|
+
this.cleanupExpiredSessions();
|
|
185
|
+
}, 60000);
|
|
186
|
+
this.cleanupTimer.unref?.();
|
|
187
|
+
}
|
|
188
|
+
}
|
|
189
|
+
let sharedBrowserSessionManager = null;
|
|
190
|
+
const getSharedBrowserSessionManager = ()=>{
|
|
191
|
+
if (!sharedBrowserSessionManager) sharedBrowserSessionManager = new BrowserSessionManager();
|
|
192
|
+
return sharedBrowserSessionManager;
|
|
193
|
+
};
|
|
194
|
+
exports.BrowserSessionManager = __webpack_exports__.BrowserSessionManager;
|
|
195
|
+
exports.getSharedBrowserSessionManager = __webpack_exports__.getSharedBrowserSessionManager;
|
|
196
|
+
for(var __rspack_i in __webpack_exports__)if (-1 === [
|
|
197
|
+
"BrowserSessionManager",
|
|
198
|
+
"getSharedBrowserSessionManager"
|
|
199
|
+
].indexOf(__rspack_i)) exports[__rspack_i] = __webpack_exports__[__rspack_i];
|
|
200
|
+
Object.defineProperty(exports, '__esModule', {
|
|
201
|
+
value: true
|
|
202
|
+
});
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
import { type BrowserControlDependencies, type BrowserControlInput, type BrowserControlToolOptions, type BrowserExecutionSummary, type BrowserRuntimeTransport, type BrowserTransportPreference } from "./browser_runtime.js";
|
|
2
|
+
export interface BrowserSessionSnapshot {
|
|
3
|
+
sessionId: string;
|
|
4
|
+
ownerId: string;
|
|
5
|
+
workspace: string;
|
|
6
|
+
configWorkspace: string;
|
|
7
|
+
status: "running";
|
|
8
|
+
startedAt: number;
|
|
9
|
+
updatedAt: number;
|
|
10
|
+
transportRequested: BrowserTransportPreference;
|
|
11
|
+
transportUsed: BrowserRuntimeTransport;
|
|
12
|
+
mode: "headless" | "headed";
|
|
13
|
+
persistentProfile: boolean;
|
|
14
|
+
profileId?: string;
|
|
15
|
+
profilePath?: string;
|
|
16
|
+
reusedExistingSession: boolean;
|
|
17
|
+
finalUrl?: string;
|
|
18
|
+
title?: string;
|
|
19
|
+
}
|
|
20
|
+
export interface BrowserSessionManagerOptions {
|
|
21
|
+
maxSessionsPerOwner?: number;
|
|
22
|
+
idleTimeoutMs?: number;
|
|
23
|
+
}
|
|
24
|
+
interface StartBrowserSessionInput {
|
|
25
|
+
ownerId: string;
|
|
26
|
+
options: BrowserControlToolOptions;
|
|
27
|
+
dependencies?: Partial<BrowserControlDependencies>;
|
|
28
|
+
input: BrowserControlInput;
|
|
29
|
+
}
|
|
30
|
+
interface RunBrowserSessionInput {
|
|
31
|
+
ownerId: string;
|
|
32
|
+
sessionId: string;
|
|
33
|
+
input: Pick<BrowserControlInput, "url" | "actions" | "timeoutMs">;
|
|
34
|
+
}
|
|
35
|
+
interface CloseBrowserSessionInput {
|
|
36
|
+
ownerId: string;
|
|
37
|
+
sessionId: string;
|
|
38
|
+
}
|
|
39
|
+
export declare class BrowserSessionManager {
|
|
40
|
+
private readonly sessions;
|
|
41
|
+
private readonly ownerIndex;
|
|
42
|
+
private readonly cleanupTimer;
|
|
43
|
+
private readonly maxSessionsPerOwner;
|
|
44
|
+
private readonly idleTimeoutMs;
|
|
45
|
+
constructor(options?: BrowserSessionManagerOptions);
|
|
46
|
+
dispose(): Promise<void>;
|
|
47
|
+
startSession(input: StartBrowserSessionInput): Promise<{
|
|
48
|
+
snapshot: BrowserSessionSnapshot;
|
|
49
|
+
summary: BrowserExecutionSummary;
|
|
50
|
+
}>;
|
|
51
|
+
runSession(input: RunBrowserSessionInput): Promise<{
|
|
52
|
+
snapshot: BrowserSessionSnapshot;
|
|
53
|
+
summary: BrowserExecutionSummary;
|
|
54
|
+
}>;
|
|
55
|
+
closeSession(input: CloseBrowserSessionInput): Promise<BrowserSessionSnapshot>;
|
|
56
|
+
listSessions(ownerId: string): BrowserSessionSnapshot[];
|
|
57
|
+
private cleanupExpiredSessions;
|
|
58
|
+
private closeAndDelete;
|
|
59
|
+
private getOwnedRecord;
|
|
60
|
+
private toSnapshot;
|
|
61
|
+
private normalizeOwnerId;
|
|
62
|
+
}
|
|
63
|
+
export declare const getSharedBrowserSessionManager: () => BrowserSessionManager;
|
|
64
|
+
export {};
|
|
@@ -0,0 +1,165 @@
|
|
|
1
|
+
import { randomUUID } from "node:crypto";
|
|
2
|
+
import { closeBrowserSessionRuntime, executeBrowserSessionRuntime, openBrowserSessionRuntime } from "./browser_runtime.js";
|
|
3
|
+
function _define_property(obj, key, value) {
|
|
4
|
+
if (key in obj) Object.defineProperty(obj, key, {
|
|
5
|
+
value: value,
|
|
6
|
+
enumerable: true,
|
|
7
|
+
configurable: true,
|
|
8
|
+
writable: true
|
|
9
|
+
});
|
|
10
|
+
else obj[key] = value;
|
|
11
|
+
return obj;
|
|
12
|
+
}
|
|
13
|
+
const DEFAULT_MAX_SESSIONS_PER_OWNER = 3;
|
|
14
|
+
const DEFAULT_IDLE_TIMEOUT_MS = 900000;
|
|
15
|
+
class BrowserSessionManager {
|
|
16
|
+
async dispose() {
|
|
17
|
+
clearInterval(this.cleanupTimer);
|
|
18
|
+
const sessions = [
|
|
19
|
+
...this.sessions.values()
|
|
20
|
+
];
|
|
21
|
+
this.sessions.clear();
|
|
22
|
+
this.ownerIndex.clear();
|
|
23
|
+
await Promise.allSettled(sessions.map((record)=>closeBrowserSessionRuntime(record.runtime, record.dependencies)));
|
|
24
|
+
}
|
|
25
|
+
async startSession(input) {
|
|
26
|
+
const ownerId = this.normalizeOwnerId(input.ownerId);
|
|
27
|
+
const existing = this.ownerIndex.get(ownerId);
|
|
28
|
+
if ((existing?.size || 0) >= this.maxSessionsPerOwner) throw new Error(`Owner "${ownerId}" reached browser session limit (${this.maxSessionsPerOwner})`);
|
|
29
|
+
const runtime = await openBrowserSessionRuntime(input.options, input.dependencies, input.input);
|
|
30
|
+
const now = Date.now();
|
|
31
|
+
const sessionId = randomUUID();
|
|
32
|
+
const record = {
|
|
33
|
+
sessionId,
|
|
34
|
+
ownerId,
|
|
35
|
+
runtime,
|
|
36
|
+
dependencies: input.dependencies || {},
|
|
37
|
+
startedAt: now,
|
|
38
|
+
updatedAt: now,
|
|
39
|
+
lastSummary: null,
|
|
40
|
+
closing: false
|
|
41
|
+
};
|
|
42
|
+
this.sessions.set(sessionId, record);
|
|
43
|
+
if (existing) existing.add(sessionId);
|
|
44
|
+
else this.ownerIndex.set(ownerId, new Set([
|
|
45
|
+
sessionId
|
|
46
|
+
]));
|
|
47
|
+
try {
|
|
48
|
+
const summary = await executeBrowserSessionRuntime(runtime, input.input);
|
|
49
|
+
record.lastSummary = summary;
|
|
50
|
+
record.updatedAt = Date.now();
|
|
51
|
+
return {
|
|
52
|
+
snapshot: this.toSnapshot(record),
|
|
53
|
+
summary
|
|
54
|
+
};
|
|
55
|
+
} catch (error) {
|
|
56
|
+
await this.closeAndDelete(record);
|
|
57
|
+
throw error;
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
async runSession(input) {
|
|
61
|
+
const record = this.getOwnedRecord(input.ownerId, input.sessionId);
|
|
62
|
+
const summary = await executeBrowserSessionRuntime(record.runtime, input.input);
|
|
63
|
+
record.lastSummary = summary;
|
|
64
|
+
record.updatedAt = Date.now();
|
|
65
|
+
return {
|
|
66
|
+
snapshot: this.toSnapshot(record),
|
|
67
|
+
summary
|
|
68
|
+
};
|
|
69
|
+
}
|
|
70
|
+
async closeSession(input) {
|
|
71
|
+
const record = this.getOwnedRecord(input.ownerId, input.sessionId);
|
|
72
|
+
const snapshot = this.toSnapshot(record);
|
|
73
|
+
await this.closeAndDelete(record);
|
|
74
|
+
return snapshot;
|
|
75
|
+
}
|
|
76
|
+
listSessions(ownerId) {
|
|
77
|
+
const normalizedOwnerId = this.normalizeOwnerId(ownerId);
|
|
78
|
+
const sessionIds = this.ownerIndex.get(normalizedOwnerId);
|
|
79
|
+
if (!sessionIds || 0 === sessionIds.size) return [];
|
|
80
|
+
return [
|
|
81
|
+
...sessionIds
|
|
82
|
+
].map((sessionId)=>this.sessions.get(sessionId)).filter((record)=>Boolean(record)).sort((a, b)=>b.updatedAt - a.updatedAt).map((record)=>this.toSnapshot(record));
|
|
83
|
+
}
|
|
84
|
+
async cleanupExpiredSessions() {
|
|
85
|
+
const now = Date.now();
|
|
86
|
+
const expired = [
|
|
87
|
+
...this.sessions.values()
|
|
88
|
+
].filter((record)=>!record.closing && now - record.updatedAt > this.idleTimeoutMs);
|
|
89
|
+
await Promise.allSettled(expired.map((record)=>this.closeAndDelete(record)));
|
|
90
|
+
}
|
|
91
|
+
async closeAndDelete(record) {
|
|
92
|
+
if (record.closing) return;
|
|
93
|
+
record.closing = true;
|
|
94
|
+
try {
|
|
95
|
+
await closeBrowserSessionRuntime(record.runtime, record.dependencies);
|
|
96
|
+
} finally{
|
|
97
|
+
this.sessions.delete(record.sessionId);
|
|
98
|
+
const ownerSessions = this.ownerIndex.get(record.ownerId);
|
|
99
|
+
if (ownerSessions) {
|
|
100
|
+
ownerSessions.delete(record.sessionId);
|
|
101
|
+
if (0 === ownerSessions.size) this.ownerIndex.delete(record.ownerId);
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
getOwnedRecord(ownerId, sessionId) {
|
|
106
|
+
const normalizedOwnerId = this.normalizeOwnerId(ownerId);
|
|
107
|
+
const record = this.sessions.get(sessionId);
|
|
108
|
+
if (!record) throw new Error(`Browser session ${sessionId} was not found`);
|
|
109
|
+
if (record.ownerId !== normalizedOwnerId) throw new Error(`Browser session ${sessionId} is not accessible`);
|
|
110
|
+
if (record.closing) throw new Error(`Browser session ${sessionId} is closing`);
|
|
111
|
+
return record;
|
|
112
|
+
}
|
|
113
|
+
toSnapshot(record) {
|
|
114
|
+
return {
|
|
115
|
+
sessionId: record.sessionId,
|
|
116
|
+
ownerId: record.ownerId,
|
|
117
|
+
workspace: record.runtime.workspace,
|
|
118
|
+
configWorkspace: record.runtime.configWorkspace,
|
|
119
|
+
status: "running",
|
|
120
|
+
startedAt: record.startedAt,
|
|
121
|
+
updatedAt: record.updatedAt,
|
|
122
|
+
transportRequested: record.runtime.transportRequested,
|
|
123
|
+
transportUsed: record.runtime.browserTransport,
|
|
124
|
+
mode: record.runtime.headless ? "headless" : "headed",
|
|
125
|
+
persistentProfile: record.runtime.userDataDirSelection.persistentProfile,
|
|
126
|
+
...record.runtime.userDataDirSelection.profileId ? {
|
|
127
|
+
profileId: record.runtime.userDataDirSelection.profileId
|
|
128
|
+
} : {},
|
|
129
|
+
...record.runtime.userDataDirSelection.persistentProfile ? {
|
|
130
|
+
profilePath: record.runtime.userDataDirSelection.userDataDir
|
|
131
|
+
} : {},
|
|
132
|
+
reusedExistingSession: record.runtime.reusedExistingCdpSession,
|
|
133
|
+
...record.lastSummary?.finalUrl ? {
|
|
134
|
+
finalUrl: record.lastSummary.finalUrl
|
|
135
|
+
} : {},
|
|
136
|
+
...record.lastSummary?.title ? {
|
|
137
|
+
title: record.lastSummary.title
|
|
138
|
+
} : {}
|
|
139
|
+
};
|
|
140
|
+
}
|
|
141
|
+
normalizeOwnerId(ownerId) {
|
|
142
|
+
const trimmed = ownerId.trim();
|
|
143
|
+
if (!trimmed) throw new Error("Browser ownerId is required");
|
|
144
|
+
return trimmed;
|
|
145
|
+
}
|
|
146
|
+
constructor(options = {}){
|
|
147
|
+
_define_property(this, "sessions", new Map());
|
|
148
|
+
_define_property(this, "ownerIndex", new Map());
|
|
149
|
+
_define_property(this, "cleanupTimer", void 0);
|
|
150
|
+
_define_property(this, "maxSessionsPerOwner", void 0);
|
|
151
|
+
_define_property(this, "idleTimeoutMs", void 0);
|
|
152
|
+
this.maxSessionsPerOwner = options.maxSessionsPerOwner ?? DEFAULT_MAX_SESSIONS_PER_OWNER;
|
|
153
|
+
this.idleTimeoutMs = options.idleTimeoutMs ?? DEFAULT_IDLE_TIMEOUT_MS;
|
|
154
|
+
this.cleanupTimer = setInterval(()=>{
|
|
155
|
+
this.cleanupExpiredSessions();
|
|
156
|
+
}, 60000);
|
|
157
|
+
this.cleanupTimer.unref?.();
|
|
158
|
+
}
|
|
159
|
+
}
|
|
160
|
+
let sharedBrowserSessionManager = null;
|
|
161
|
+
const getSharedBrowserSessionManager = ()=>{
|
|
162
|
+
if (!sharedBrowserSessionManager) sharedBrowserSessionManager = new BrowserSessionManager();
|
|
163
|
+
return sharedBrowserSessionManager;
|
|
164
|
+
};
|
|
165
|
+
export { BrowserSessionManager, getSharedBrowserSessionManager };
|
|
@@ -52,12 +52,16 @@ const schema_cjs_namespaceObject = require("../config/schema.cjs");
|
|
|
52
52
|
const outputManager_cjs_namespaceObject = require("../core/outputManager.cjs");
|
|
53
53
|
const DEFAULT_AGENT_ID = "wingman";
|
|
54
54
|
const DEFAULT_AGENT_DESCRIPTION = "General-purpose coding assistant for this workspace.";
|
|
55
|
-
const DEFAULT_AGENT_PROMPT = "You are Wingman, a coding assistant for this repository.\nBe direct and concise. Ask clarifying questions when requirements are unclear.\nPrefer minimal diffs and safe changes. Avoid destructive actions unless asked.\nUse tools to inspect the codebase before editing.";
|
|
55
|
+
const DEFAULT_AGENT_PROMPT = "You are Wingman, a coding assistant for this repository.\nBe direct and concise. Ask clarifying questions when requirements are unclear.\nPrefer minimal diffs and safe changes. Avoid destructive actions unless asked.\nUse tools to inspect the codebase before editing.\nUse browser_session_start/browser_session_action/browser_session_close for iterative browser debugging across turns, and browser_control for one-shot browser tasks.";
|
|
56
56
|
const DEFAULT_TOOLS = [
|
|
57
57
|
"code_search",
|
|
58
58
|
"git_status",
|
|
59
59
|
"command_execute",
|
|
60
60
|
"browser_control",
|
|
61
|
+
"browser_session_start",
|
|
62
|
+
"browser_session_action",
|
|
63
|
+
"browser_session_close",
|
|
64
|
+
"browser_session_list",
|
|
61
65
|
"internet_search",
|
|
62
66
|
"think"
|
|
63
67
|
];
|
|
@@ -11,12 +11,16 @@ import { WingmanConfigSchema } from "../config/schema.js";
|
|
|
11
11
|
import { OutputManager } from "../core/outputManager.js";
|
|
12
12
|
const DEFAULT_AGENT_ID = "wingman";
|
|
13
13
|
const DEFAULT_AGENT_DESCRIPTION = "General-purpose coding assistant for this workspace.";
|
|
14
|
-
const DEFAULT_AGENT_PROMPT = "You are Wingman, a coding assistant for this repository.\nBe direct and concise. Ask clarifying questions when requirements are unclear.\nPrefer minimal diffs and safe changes. Avoid destructive actions unless asked.\nUse tools to inspect the codebase before editing.";
|
|
14
|
+
const DEFAULT_AGENT_PROMPT = "You are Wingman, a coding assistant for this repository.\nBe direct and concise. Ask clarifying questions when requirements are unclear.\nPrefer minimal diffs and safe changes. Avoid destructive actions unless asked.\nUse tools to inspect the codebase before editing.\nUse browser_session_start/browser_session_action/browser_session_close for iterative browser debugging across turns, and browser_control for one-shot browser tasks.";
|
|
15
15
|
const DEFAULT_TOOLS = [
|
|
16
16
|
"code_search",
|
|
17
17
|
"git_status",
|
|
18
18
|
"command_execute",
|
|
19
19
|
"browser_control",
|
|
20
|
+
"browser_session_start",
|
|
21
|
+
"browser_session_action",
|
|
22
|
+
"browser_session_close",
|
|
23
|
+
"browser_session_list",
|
|
20
24
|
"internet_search",
|
|
21
25
|
"think"
|
|
22
26
|
];
|
|
@@ -141,8 +141,8 @@ const BrowserConfigSchema = external_zod_namespaceObject.object({
|
|
|
141
141
|
});
|
|
142
142
|
const SummarizationConfigSchema = external_zod_namespaceObject.object({
|
|
143
143
|
enabled: external_zod_namespaceObject.boolean().optional().default(true).describe("Enable conversation history summarization"),
|
|
144
|
-
maxTokensBeforeSummary: external_zod_namespaceObject.number().min(1000).max(1000000).optional().
|
|
145
|
-
messagesToKeep: external_zod_namespaceObject.number().min(2).max(100).optional().
|
|
144
|
+
maxTokensBeforeSummary: external_zod_namespaceObject.number().min(1000).max(1000000).optional().describe("Token threshold before summarizing conversation history"),
|
|
145
|
+
messagesToKeep: external_zod_namespaceObject.number().min(2).max(100).optional().describe("How many most recent messages to keep after summarization")
|
|
146
146
|
});
|
|
147
147
|
const RetryOnFailureSchema = external_zod_namespaceObject["enum"]([
|
|
148
148
|
"continue",
|
|
@@ -382,11 +382,7 @@ const WingmanConfigSchema = external_zod_namespaceObject.object({
|
|
|
382
382
|
]).optional().default("info"),
|
|
383
383
|
defaultAgent: external_zod_namespaceObject.string().optional(),
|
|
384
384
|
recursionLimit: external_zod_namespaceObject.number().min(1).max(1000000).optional().default(5000),
|
|
385
|
-
summarization: SummarizationConfigSchema.optional()
|
|
386
|
-
enabled: true,
|
|
387
|
-
maxTokensBeforeSummary: 12000,
|
|
388
|
-
messagesToKeep: 8
|
|
389
|
-
}),
|
|
385
|
+
summarization: SummarizationConfigSchema.optional(),
|
|
390
386
|
modelRetry: ModelRetryConfigSchema.optional().default({
|
|
391
387
|
enabled: true,
|
|
392
388
|
maxRetries: 2,
|
|
@@ -64,8 +64,8 @@ export declare const BrowserConfigSchema: z.ZodObject<{
|
|
|
64
64
|
export type BrowserConfig = z.infer<typeof BrowserConfigSchema>;
|
|
65
65
|
export declare const SummarizationConfigSchema: z.ZodObject<{
|
|
66
66
|
enabled: z.ZodDefault<z.ZodOptional<z.ZodBoolean>>;
|
|
67
|
-
maxTokensBeforeSummary: z.
|
|
68
|
-
messagesToKeep: z.
|
|
67
|
+
maxTokensBeforeSummary: z.ZodOptional<z.ZodNumber>;
|
|
68
|
+
messagesToKeep: z.ZodOptional<z.ZodNumber>;
|
|
69
69
|
}, z.core.$strip>;
|
|
70
70
|
export type SummarizationConfig = z.infer<typeof SummarizationConfigSchema>;
|
|
71
71
|
export declare const ModelRetryConfigSchema: z.ZodObject<{
|
|
@@ -218,11 +218,11 @@ export declare const WingmanConfigSchema: z.ZodObject<{
|
|
|
218
218
|
}>>>;
|
|
219
219
|
defaultAgent: z.ZodOptional<z.ZodString>;
|
|
220
220
|
recursionLimit: z.ZodDefault<z.ZodOptional<z.ZodNumber>>;
|
|
221
|
-
summarization: z.
|
|
221
|
+
summarization: z.ZodOptional<z.ZodObject<{
|
|
222
222
|
enabled: z.ZodDefault<z.ZodOptional<z.ZodBoolean>>;
|
|
223
|
-
maxTokensBeforeSummary: z.
|
|
224
|
-
messagesToKeep: z.
|
|
225
|
-
}, z.core.$strip
|
|
223
|
+
maxTokensBeforeSummary: z.ZodOptional<z.ZodNumber>;
|
|
224
|
+
messagesToKeep: z.ZodOptional<z.ZodNumber>;
|
|
225
|
+
}, z.core.$strip>>;
|
|
226
226
|
modelRetry: z.ZodDefault<z.ZodOptional<z.ZodObject<{
|
|
227
227
|
enabled: z.ZodDefault<z.ZodOptional<z.ZodBoolean>>;
|
|
228
228
|
maxRetries: z.ZodDefault<z.ZodOptional<z.ZodNumber>>;
|