@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.
Files changed (311) hide show
  1. package/dist/agent/config/agentConfig.cjs +4 -0
  2. package/dist/agent/config/agentConfig.d.ts +12 -0
  3. package/dist/agent/config/agentConfig.js +4 -0
  4. package/dist/agent/config/toolRegistry.cjs +75 -1
  5. package/dist/agent/config/toolRegistry.d.ts +3 -0
  6. package/dist/agent/config/toolRegistry.js +75 -1
  7. package/dist/agent/middleware/large-tool-results.cjs +207 -0
  8. package/dist/agent/middleware/large-tool-results.d.ts +16 -0
  9. package/dist/agent/middleware/large-tool-results.js +173 -0
  10. package/dist/agent/tools/browser_control.cjs +9 -1231
  11. package/dist/agent/tools/browser_control.d.ts +126 -234
  12. package/dist/agent/tools/browser_control.js +7 -1226
  13. package/dist/agent/tools/browser_runtime.cjs +1189 -0
  14. package/dist/agent/tools/browser_runtime.d.ts +560 -0
  15. package/dist/agent/tools/browser_runtime.js +1122 -0
  16. package/dist/agent/tools/browser_session.cjs +153 -0
  17. package/dist/agent/tools/browser_session.d.ts +741 -0
  18. package/dist/agent/tools/browser_session.js +110 -0
  19. package/dist/agent/tools/browser_session_manager.cjs +202 -0
  20. package/dist/agent/tools/browser_session_manager.d.ts +64 -0
  21. package/dist/agent/tools/browser_session_manager.js +165 -0
  22. package/dist/cli/commands/init.cjs +5 -1
  23. package/dist/cli/commands/init.js +5 -1
  24. package/dist/cli/config/loader.cjs +0 -5
  25. package/dist/cli/config/loader.js +0 -5
  26. package/dist/cli/config/schema.cjs +3 -7
  27. package/dist/cli/config/schema.d.ts +6 -6
  28. package/dist/cli/config/schema.js +3 -7
  29. package/dist/cli/core/agentInvoker.cjs +86 -22
  30. package/dist/cli/core/agentInvoker.d.ts +10 -3
  31. package/dist/cli/core/agentInvoker.js +86 -25
  32. package/dist/cli/core/outputManager.cjs +7 -2
  33. package/dist/cli/core/outputManager.d.ts +2 -2
  34. package/dist/cli/core/outputManager.js +7 -2
  35. package/dist/cli/types.d.ts +2 -1
  36. package/dist/webui/assets/index-XrEnkZiq.css +11 -0
  37. package/dist/webui/assets/index-mDs6HbKM.js +215 -0
  38. package/dist/webui/index.html +2 -2
  39. package/package.json +10 -10
  40. package/templates/agents/README.md +2 -1
  41. package/templates/agents/coding/agent.md +6 -13
  42. package/templates/agents/coding-v2/agent.md +6 -1
  43. package/templates/agents/game-dev/agent.md +8 -2
  44. package/templates/agents/game-dev/game-designer.md +4 -0
  45. package/templates/agents/game-dev/scene-engineer.md +4 -0
  46. package/templates/agents/main/agent.md +5 -0
  47. package/templates/agents/researcher/agent.md +11 -0
  48. package/templates/agents/stock-trader/agent.md +4 -0
  49. package/dist/agent/tests/agentConfig.test.cjs +0 -224
  50. package/dist/agent/tests/agentConfig.test.d.ts +0 -1
  51. package/dist/agent/tests/agentConfig.test.js +0 -218
  52. package/dist/agent/tests/agentLoader.test.cjs +0 -335
  53. package/dist/agent/tests/agentLoader.test.d.ts +0 -1
  54. package/dist/agent/tests/agentLoader.test.js +0 -329
  55. package/dist/agent/tests/backgroundTerminal.test.cjs +0 -70
  56. package/dist/agent/tests/backgroundTerminal.test.d.ts +0 -1
  57. package/dist/agent/tests/backgroundTerminal.test.js +0 -64
  58. package/dist/agent/tests/browserControlHelpers.test.cjs +0 -35
  59. package/dist/agent/tests/browserControlHelpers.test.d.ts +0 -1
  60. package/dist/agent/tests/browserControlHelpers.test.js +0 -29
  61. package/dist/agent/tests/browserControlTool.test.cjs +0 -2117
  62. package/dist/agent/tests/browserControlTool.test.d.ts +0 -1
  63. package/dist/agent/tests/browserControlTool.test.js +0 -2111
  64. package/dist/agent/tests/commandExecuteTool.test.cjs +0 -29
  65. package/dist/agent/tests/commandExecuteTool.test.d.ts +0 -1
  66. package/dist/agent/tests/commandExecuteTool.test.js +0 -23
  67. package/dist/agent/tests/internet_search.test.cjs +0 -107
  68. package/dist/agent/tests/internet_search.test.d.ts +0 -1
  69. package/dist/agent/tests/internet_search.test.js +0 -101
  70. package/dist/agent/tests/mcpClientManager.test.cjs +0 -290
  71. package/dist/agent/tests/mcpClientManager.test.d.ts +0 -1
  72. package/dist/agent/tests/mcpClientManager.test.js +0 -284
  73. package/dist/agent/tests/mcpResourceTools.test.cjs +0 -101
  74. package/dist/agent/tests/mcpResourceTools.test.d.ts +0 -1
  75. package/dist/agent/tests/mcpResourceTools.test.js +0 -95
  76. package/dist/agent/tests/modelFactory.test.cjs +0 -190
  77. package/dist/agent/tests/modelFactory.test.d.ts +0 -1
  78. package/dist/agent/tests/modelFactory.test.js +0 -184
  79. package/dist/agent/tests/terminalSessionManager.test.cjs +0 -121
  80. package/dist/agent/tests/terminalSessionManager.test.d.ts +0 -1
  81. package/dist/agent/tests/terminalSessionManager.test.js +0 -115
  82. package/dist/agent/tests/test-agent-loader.cjs +0 -33
  83. package/dist/agent/tests/test-agent-loader.d.ts +0 -1
  84. package/dist/agent/tests/test-agent-loader.js +0 -27
  85. package/dist/agent/tests/test-subagent-loading.cjs +0 -99
  86. package/dist/agent/tests/test-subagent-loading.d.ts +0 -1
  87. package/dist/agent/tests/test-subagent-loading.js +0 -93
  88. package/dist/agent/tests/toolRegistry.test.cjs +0 -147
  89. package/dist/agent/tests/toolRegistry.test.d.ts +0 -1
  90. package/dist/agent/tests/toolRegistry.test.js +0 -141
  91. package/dist/agent/tests/uiRegistryTools.test.cjs +0 -114
  92. package/dist/agent/tests/uiRegistryTools.test.d.ts +0 -1
  93. package/dist/agent/tests/uiRegistryTools.test.js +0 -105
  94. package/dist/agent/tests/xaiImageModel.test.cjs +0 -194
  95. package/dist/agent/tests/xaiImageModel.test.d.ts +0 -1
  96. package/dist/agent/tests/xaiImageModel.test.js +0 -188
  97. package/dist/tests/additionalMessageMiddleware.test.cjs +0 -216
  98. package/dist/tests/additionalMessageMiddleware.test.d.ts +0 -1
  99. package/dist/tests/additionalMessageMiddleware.test.js +0 -188
  100. package/dist/tests/agent-config-voice.test.cjs +0 -25
  101. package/dist/tests/agent-config-voice.test.d.ts +0 -1
  102. package/dist/tests/agent-config-voice.test.js +0 -19
  103. package/dist/tests/agentInvokerAttachments.test.cjs +0 -190
  104. package/dist/tests/agentInvokerAttachments.test.d.ts +0 -1
  105. package/dist/tests/agentInvokerAttachments.test.js +0 -184
  106. package/dist/tests/agentInvokerSummarization.test.cjs +0 -613
  107. package/dist/tests/agentInvokerSummarization.test.d.ts +0 -1
  108. package/dist/tests/agentInvokerSummarization.test.js +0 -607
  109. package/dist/tests/agentInvokerTokenUsage.test.cjs +0 -124
  110. package/dist/tests/agentInvokerTokenUsage.test.d.ts +0 -1
  111. package/dist/tests/agentInvokerTokenUsage.test.js +0 -118
  112. package/dist/tests/agentInvokerWorkdir.test.cjs +0 -150
  113. package/dist/tests/agentInvokerWorkdir.test.d.ts +0 -1
  114. package/dist/tests/agentInvokerWorkdir.test.js +0 -122
  115. package/dist/tests/agents-api.test.cjs +0 -324
  116. package/dist/tests/agents-api.test.d.ts +0 -1
  117. package/dist/tests/agents-api.test.js +0 -318
  118. package/dist/tests/attachments-utils.test.cjs +0 -46
  119. package/dist/tests/attachments-utils.test.d.ts +0 -1
  120. package/dist/tests/attachments-utils.test.js +0 -40
  121. package/dist/tests/browser-command.test.cjs +0 -264
  122. package/dist/tests/browser-command.test.d.ts +0 -1
  123. package/dist/tests/browser-command.test.js +0 -258
  124. package/dist/tests/browser-relay-server.test.cjs +0 -20
  125. package/dist/tests/browser-relay-server.test.d.ts +0 -1
  126. package/dist/tests/browser-relay-server.test.js +0 -14
  127. package/dist/tests/bunSqliteAdapter.test.cjs +0 -265
  128. package/dist/tests/bunSqliteAdapter.test.d.ts +0 -1
  129. package/dist/tests/bunSqliteAdapter.test.js +0 -259
  130. package/dist/tests/candleRange.test.cjs +0 -48
  131. package/dist/tests/candleRange.test.d.ts +0 -1
  132. package/dist/tests/candleRange.test.js +0 -42
  133. package/dist/tests/cli-config-loader.test.cjs +0 -532
  134. package/dist/tests/cli-config-loader.test.d.ts +0 -1
  135. package/dist/tests/cli-config-loader.test.js +0 -526
  136. package/dist/tests/cli-config-warnings.test.cjs +0 -94
  137. package/dist/tests/cli-config-warnings.test.d.ts +0 -1
  138. package/dist/tests/cli-config-warnings.test.js +0 -88
  139. package/dist/tests/cli-init.test.cjs +0 -225
  140. package/dist/tests/cli-init.test.d.ts +0 -1
  141. package/dist/tests/cli-init.test.js +0 -219
  142. package/dist/tests/cli-workspace-root.test.cjs +0 -114
  143. package/dist/tests/cli-workspace-root.test.d.ts +0 -1
  144. package/dist/tests/cli-workspace-root.test.js +0 -108
  145. package/dist/tests/codex-credentials-precedence.test.cjs +0 -94
  146. package/dist/tests/codex-credentials-precedence.test.d.ts +0 -1
  147. package/dist/tests/codex-credentials-precedence.test.js +0 -88
  148. package/dist/tests/codex-provider.test.cjs +0 -383
  149. package/dist/tests/codex-provider.test.d.ts +0 -1
  150. package/dist/tests/codex-provider.test.js +0 -377
  151. package/dist/tests/config-json-schema.test.cjs +0 -37
  152. package/dist/tests/config-json-schema.test.d.ts +0 -1
  153. package/dist/tests/config-json-schema.test.js +0 -31
  154. package/dist/tests/discord-adapter.test.cjs +0 -89
  155. package/dist/tests/discord-adapter.test.d.ts +0 -1
  156. package/dist/tests/discord-adapter.test.js +0 -83
  157. package/dist/tests/falRuntime.test.cjs +0 -78
  158. package/dist/tests/falRuntime.test.d.ts +0 -1
  159. package/dist/tests/falRuntime.test.js +0 -72
  160. package/dist/tests/falSummary.test.cjs +0 -51
  161. package/dist/tests/falSummary.test.d.ts +0 -1
  162. package/dist/tests/falSummary.test.js +0 -45
  163. package/dist/tests/fs-api.test.cjs +0 -138
  164. package/dist/tests/fs-api.test.d.ts +0 -1
  165. package/dist/tests/fs-api.test.js +0 -132
  166. package/dist/tests/gateway-command-workspace.test.cjs +0 -150
  167. package/dist/tests/gateway-command-workspace.test.d.ts +0 -1
  168. package/dist/tests/gateway-command-workspace.test.js +0 -144
  169. package/dist/tests/gateway-http-security.test.cjs +0 -318
  170. package/dist/tests/gateway-http-security.test.d.ts +0 -1
  171. package/dist/tests/gateway-http-security.test.js +0 -312
  172. package/dist/tests/gateway-node-mode.test.cjs +0 -174
  173. package/dist/tests/gateway-node-mode.test.d.ts +0 -1
  174. package/dist/tests/gateway-node-mode.test.js +0 -168
  175. package/dist/tests/gateway-origin-policy.test.cjs +0 -82
  176. package/dist/tests/gateway-origin-policy.test.d.ts +0 -1
  177. package/dist/tests/gateway-origin-policy.test.js +0 -76
  178. package/dist/tests/gateway-request-execution-overrides.test.cjs +0 -42
  179. package/dist/tests/gateway-request-execution-overrides.test.d.ts +0 -1
  180. package/dist/tests/gateway-request-execution-overrides.test.js +0 -36
  181. package/dist/tests/gateway.test.cjs +0 -700
  182. package/dist/tests/gateway.test.d.ts +0 -1
  183. package/dist/tests/gateway.test.js +0 -694
  184. package/dist/tests/hooks-matcher.test.cjs +0 -309
  185. package/dist/tests/hooks-matcher.test.d.ts +0 -1
  186. package/dist/tests/hooks-matcher.test.js +0 -303
  187. package/dist/tests/hooks-merger.test.cjs +0 -528
  188. package/dist/tests/hooks-merger.test.d.ts +0 -1
  189. package/dist/tests/hooks-merger.test.js +0 -522
  190. package/dist/tests/imagePersistence.test.cjs +0 -169
  191. package/dist/tests/imagePersistence.test.d.ts +0 -1
  192. package/dist/tests/imagePersistence.test.js +0 -163
  193. package/dist/tests/integration/agent-invocation.integration.test.cjs +0 -264
  194. package/dist/tests/integration/agent-invocation.integration.test.d.ts +0 -1
  195. package/dist/tests/integration/agent-invocation.integration.test.js +0 -258
  196. package/dist/tests/integration/finnhub-candles.integration.test.cjs +0 -98
  197. package/dist/tests/integration/finnhub-candles.integration.test.d.ts +0 -1
  198. package/dist/tests/integration/finnhub-candles.integration.test.js +0 -92
  199. package/dist/tests/integration/summarization-e2e.integration.test.cjs +0 -127
  200. package/dist/tests/integration/summarization-e2e.integration.test.d.ts +0 -1
  201. package/dist/tests/integration/summarization-e2e.integration.test.js +0 -121
  202. package/dist/tests/logger.test.cjs +0 -353
  203. package/dist/tests/logger.test.d.ts +0 -1
  204. package/dist/tests/logger.test.js +0 -347
  205. package/dist/tests/mediaCompatibilityMiddleware.test.cjs +0 -106
  206. package/dist/tests/mediaCompatibilityMiddleware.test.d.ts +0 -1
  207. package/dist/tests/mediaCompatibilityMiddleware.test.js +0 -100
  208. package/dist/tests/node-tools.test.cjs +0 -77
  209. package/dist/tests/node-tools.test.d.ts +0 -1
  210. package/dist/tests/node-tools.test.js +0 -71
  211. package/dist/tests/nodes-api.test.cjs +0 -86
  212. package/dist/tests/nodes-api.test.d.ts +0 -1
  213. package/dist/tests/nodes-api.test.js +0 -80
  214. package/dist/tests/outputManagerContextSummarized.test.cjs +0 -43
  215. package/dist/tests/outputManagerContextSummarized.test.d.ts +0 -1
  216. package/dist/tests/outputManagerContextSummarized.test.js +0 -37
  217. package/dist/tests/provider-command-codex.test.cjs +0 -57
  218. package/dist/tests/provider-command-codex.test.d.ts +0 -1
  219. package/dist/tests/provider-command-codex.test.js +0 -51
  220. package/dist/tests/routines-api.test.cjs +0 -107
  221. package/dist/tests/routines-api.test.d.ts +0 -1
  222. package/dist/tests/routines-api.test.js +0 -101
  223. package/dist/tests/run-terminal-bench-official-script.test.cjs +0 -61
  224. package/dist/tests/run-terminal-bench-official-script.test.d.ts +0 -1
  225. package/dist/tests/run-terminal-bench-official-script.test.js +0 -55
  226. package/dist/tests/sessionManager-uionly.test.cjs +0 -50
  227. package/dist/tests/sessionManager-uionly.test.d.ts +0 -1
  228. package/dist/tests/sessionManager-uionly.test.js +0 -44
  229. package/dist/tests/sessionMessageAttachments.test.cjs +0 -197
  230. package/dist/tests/sessionMessageAttachments.test.d.ts +0 -1
  231. package/dist/tests/sessionMessageAttachments.test.js +0 -191
  232. package/dist/tests/sessionMessageRole.test.cjs +0 -44
  233. package/dist/tests/sessionMessageRole.test.d.ts +0 -1
  234. package/dist/tests/sessionMessageRole.test.js +0 -38
  235. package/dist/tests/sessionStateMessages.test.cjs +0 -236
  236. package/dist/tests/sessionStateMessages.test.d.ts +0 -1
  237. package/dist/tests/sessionStateMessages.test.js +0 -230
  238. package/dist/tests/sessions-api.test.cjs +0 -250
  239. package/dist/tests/sessions-api.test.d.ts +0 -1
  240. package/dist/tests/sessions-api.test.js +0 -244
  241. package/dist/tests/skill-activation.test.cjs +0 -86
  242. package/dist/tests/skill-activation.test.d.ts +0 -1
  243. package/dist/tests/skill-activation.test.js +0 -80
  244. package/dist/tests/skill-metadata.test.cjs +0 -119
  245. package/dist/tests/skill-metadata.test.d.ts +0 -1
  246. package/dist/tests/skill-metadata.test.js +0 -113
  247. package/dist/tests/skill-repository.test.cjs +0 -469
  248. package/dist/tests/skill-repository.test.d.ts +0 -1
  249. package/dist/tests/skill-repository.test.js +0 -463
  250. package/dist/tests/skill-security-scanner.test.cjs +0 -126
  251. package/dist/tests/skill-security-scanner.test.d.ts +0 -1
  252. package/dist/tests/skill-security-scanner.test.js +0 -120
  253. package/dist/tests/sms-api.test.cjs +0 -183
  254. package/dist/tests/sms-api.test.d.ts +0 -1
  255. package/dist/tests/sms-api.test.js +0 -177
  256. package/dist/tests/sms-commands.test.cjs +0 -90
  257. package/dist/tests/sms-commands.test.d.ts +0 -1
  258. package/dist/tests/sms-commands.test.js +0 -84
  259. package/dist/tests/sms-policy-store.test.cjs +0 -69
  260. package/dist/tests/sms-policy-store.test.d.ts +0 -1
  261. package/dist/tests/sms-policy-store.test.js +0 -63
  262. package/dist/tests/teams-adapter.test.cjs +0 -58
  263. package/dist/tests/teams-adapter.test.d.ts +0 -1
  264. package/dist/tests/teams-adapter.test.js +0 -52
  265. package/dist/tests/technicalIndicators.test.cjs +0 -82
  266. package/dist/tests/technicalIndicators.test.d.ts +0 -1
  267. package/dist/tests/technicalIndicators.test.js +0 -76
  268. package/dist/tests/terminal-bench-adapters-helpers.test.cjs +0 -64
  269. package/dist/tests/terminal-bench-adapters-helpers.test.d.ts +0 -1
  270. package/dist/tests/terminal-bench-adapters-helpers.test.js +0 -58
  271. package/dist/tests/terminal-bench-cleanup.test.cjs +0 -93
  272. package/dist/tests/terminal-bench-cleanup.test.d.ts +0 -1
  273. package/dist/tests/terminal-bench-cleanup.test.js +0 -87
  274. package/dist/tests/terminal-bench-config.test.cjs +0 -62
  275. package/dist/tests/terminal-bench-config.test.d.ts +0 -1
  276. package/dist/tests/terminal-bench-config.test.js +0 -56
  277. package/dist/tests/terminal-bench-official.test.cjs +0 -194
  278. package/dist/tests/terminal-bench-official.test.d.ts +0 -1
  279. package/dist/tests/terminal-bench-official.test.js +0 -188
  280. package/dist/tests/terminal-bench-runner.test.cjs +0 -82
  281. package/dist/tests/terminal-bench-runner.test.d.ts +0 -1
  282. package/dist/tests/terminal-bench-runner.test.js +0 -76
  283. package/dist/tests/terminal-bench-scoring.test.cjs +0 -128
  284. package/dist/tests/terminal-bench-scoring.test.d.ts +0 -1
  285. package/dist/tests/terminal-bench-scoring.test.js +0 -122
  286. package/dist/tests/terminalProbe.test.cjs +0 -45
  287. package/dist/tests/terminalProbe.test.d.ts +0 -1
  288. package/dist/tests/terminalProbe.test.js +0 -39
  289. package/dist/tests/terminalProbeAuth.test.cjs +0 -85
  290. package/dist/tests/terminalProbeAuth.test.d.ts +0 -1
  291. package/dist/tests/terminalProbeAuth.test.js +0 -79
  292. package/dist/tests/toolDisplayHelpers.test.cjs +0 -46
  293. package/dist/tests/toolDisplayHelpers.test.d.ts +0 -1
  294. package/dist/tests/toolDisplayHelpers.test.js +0 -40
  295. package/dist/tests/uv.test.cjs +0 -47
  296. package/dist/tests/uv.test.d.ts +0 -1
  297. package/dist/tests/uv.test.js +0 -41
  298. package/dist/tests/voice-config.test.cjs +0 -35
  299. package/dist/tests/voice-config.test.d.ts +0 -1
  300. package/dist/tests/voice-config.test.js +0 -29
  301. package/dist/tests/websocket-transport.test.cjs +0 -31
  302. package/dist/tests/websocket-transport.test.d.ts +0 -1
  303. package/dist/tests/websocket-transport.test.js +0 -25
  304. package/dist/tests/yahooCandles.test.cjs +0 -111
  305. package/dist/tests/yahooCandles.test.d.ts +0 -1
  306. package/dist/tests/yahooCandles.test.js +0 -105
  307. package/dist/tools/finance/optionsAnalytics.test.cjs +0 -128
  308. package/dist/tools/finance/optionsAnalytics.test.d.ts +0 -1
  309. package/dist/tools/finance/optionsAnalytics.test.js +0 -122
  310. package/dist/webui/assets/index-D07GBGp0.js +0 -215
  311. 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
  ];
@@ -91,11 +91,6 @@ class WingmanConfigLoader {
91
91
  return {
92
92
  logLevel: "info",
93
93
  recursionLimit: 5000,
94
- summarization: {
95
- enabled: true,
96
- maxTokensBeforeSummary: 12000,
97
- messagesToKeep: 8
98
- },
99
94
  modelRetry: {
100
95
  enabled: true,
101
96
  maxRetries: 2,
@@ -63,11 +63,6 @@ class WingmanConfigLoader {
63
63
  return {
64
64
  logLevel: "info",
65
65
  recursionLimit: 5000,
66
- summarization: {
67
- enabled: true,
68
- maxTokensBeforeSummary: 12000,
69
- messagesToKeep: 8
70
- },
71
66
  modelRetry: {
72
67
  enabled: true,
73
68
  maxRetries: 2,
@@ -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().default(12000).describe("Token threshold before summarizing conversation history"),
145
- messagesToKeep: external_zod_namespaceObject.number().min(2).max(100).optional().default(8).describe("How many most recent messages to keep after summarization")
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().default({
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.ZodDefault<z.ZodOptional<z.ZodNumber>>;
68
- messagesToKeep: z.ZodDefault<z.ZodOptional<z.ZodNumber>>;
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.ZodDefault<z.ZodOptional<z.ZodObject<{
221
+ summarization: z.ZodOptional<z.ZodObject<{
222
222
  enabled: z.ZodDefault<z.ZodOptional<z.ZodBoolean>>;
223
- maxTokensBeforeSummary: z.ZodDefault<z.ZodOptional<z.ZodNumber>>;
224
- messagesToKeep: z.ZodDefault<z.ZodOptional<z.ZodNumber>>;
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>>;