@wingman-ai/gateway 0.5.3 → 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-BMf95nv5.js +0 -215
  311. package/dist/webui/assets/index-DhJQ8Mbn.css +0 -11
@@ -1,150 +0,0 @@
1
- "use strict";
2
- var __webpack_exports__ = {};
3
- const external_node_fs_namespaceObject = require("node:fs");
4
- const external_node_os_namespaceObject = require("node:os");
5
- const external_node_path_namespaceObject = require("node:path");
6
- const external_vitest_namespaceObject = require("vitest");
7
- const gateway_cjs_namespaceObject = require("../cli/commands/gateway.cjs");
8
- function _define_property(obj, key, value) {
9
- if (key in obj) Object.defineProperty(obj, key, {
10
- value: value,
11
- enumerable: true,
12
- configurable: true,
13
- writable: true
14
- });
15
- else obj[key] = value;
16
- return obj;
17
- }
18
- const daemonStartMock = external_vitest_namespaceObject.vi.fn(async (_config)=>{});
19
- const daemonStopMock = external_vitest_namespaceObject.vi.fn(async ()=>{});
20
- const daemonRestartMock = external_vitest_namespaceObject.vi.fn(async ()=>{});
21
- const daemonGetStatusMock = external_vitest_namespaceObject.vi.fn(()=>({
22
- running: false
23
- }));
24
- const daemonGetLogFileMock = external_vitest_namespaceObject.vi.fn(()=>"/tmp/wingman-gateway.log");
25
- const daemonGetPidFileMock = external_vitest_namespaceObject.vi.fn(()=>"/tmp/wingman-gateway.pid");
26
- const daemonGetConfigFileMock = external_vitest_namespaceObject.vi.fn(()=>"/tmp/wingman-gateway.json");
27
- let serverStartShouldReject = false;
28
- const createdServerConfigs = [];
29
- const serverStartMock = external_vitest_namespaceObject.vi.fn(async ()=>{
30
- if (serverStartShouldReject) throw new Error("synthetic gateway run stop");
31
- });
32
- const serverStopMock = external_vitest_namespaceObject.vi.fn(async ()=>{});
33
- const loadConfigMock = external_vitest_namespaceObject.vi.fn(()=>({
34
- gateway: {
35
- host: "127.0.0.1",
36
- port: 18789,
37
- auth: {
38
- mode: "none"
39
- }
40
- }
41
- }));
42
- external_vitest_namespaceObject.vi.mock("../gateway/index.js", ()=>({
43
- GatewayDaemon: class {
44
- constructor(){
45
- _define_property(this, "start", daemonStartMock);
46
- _define_property(this, "stop", daemonStopMock);
47
- _define_property(this, "restart", daemonRestartMock);
48
- _define_property(this, "getStatus", daemonGetStatusMock);
49
- _define_property(this, "getLogFile", daemonGetLogFileMock);
50
- _define_property(this, "getPidFile", daemonGetPidFileMock);
51
- _define_property(this, "getConfigFile", daemonGetConfigFileMock);
52
- }
53
- },
54
- GatewayServer: class {
55
- constructor(config){
56
- _define_property(this, "start", serverStartMock);
57
- _define_property(this, "stop", serverStopMock);
58
- createdServerConfigs.push(config);
59
- }
60
- },
61
- GatewayClient: class {
62
- }
63
- }));
64
- external_vitest_namespaceObject.vi.mock("../cli/config/loader.js", ()=>({
65
- WingmanConfigLoader: class {
66
- constructor(){
67
- _define_property(this, "loadConfig", loadConfigMock);
68
- }
69
- }
70
- }));
71
- (0, external_vitest_namespaceObject.describe)("gateway command workspace handling", ()=>{
72
- let tempRoot;
73
- let consoleLogSpy;
74
- let consoleErrorSpy;
75
- let processExitSpy;
76
- const originalGatewayConfigEnv = process.env.WINGMAN_GATEWAY_CONFIG;
77
- (0, external_vitest_namespaceObject.beforeEach)(()=>{
78
- tempRoot = (0, external_node_fs_namespaceObject.mkdtempSync)((0, external_node_path_namespaceObject.join)((0, external_node_os_namespaceObject.tmpdir)(), "wingman-gateway-command-"));
79
- serverStartShouldReject = false;
80
- createdServerConfigs.length = 0;
81
- daemonStartMock.mockClear();
82
- serverStartMock.mockClear();
83
- loadConfigMock.mockClear();
84
- consoleLogSpy = external_vitest_namespaceObject.vi.spyOn(console, "log").mockImplementation(()=>{});
85
- consoleErrorSpy = external_vitest_namespaceObject.vi.spyOn(console, "error").mockImplementation(()=>{});
86
- processExitSpy = external_vitest_namespaceObject.vi.spyOn(process, "exit").mockImplementation((code)=>{
87
- throw new Error(`process.exit(${code ?? "undefined"})`);
88
- });
89
- delete process.env.WINGMAN_GATEWAY_CONFIG;
90
- });
91
- (0, external_vitest_namespaceObject.afterEach)(()=>{
92
- consoleLogSpy.mockRestore();
93
- consoleErrorSpy.mockRestore();
94
- processExitSpy.mockRestore();
95
- if (originalGatewayConfigEnv) process.env.WINGMAN_GATEWAY_CONFIG = originalGatewayConfigEnv;
96
- else delete process.env.WINGMAN_GATEWAY_CONFIG;
97
- if ((0, external_node_fs_namespaceObject.existsSync)(tempRoot)) (0, external_node_fs_namespaceObject.rmSync)(tempRoot, {
98
- recursive: true,
99
- force: true
100
- });
101
- });
102
- (0, external_vitest_namespaceObject.it)("passes workspace/configDir into daemon config on gateway start", async ()=>{
103
- const workspace = (0, external_node_path_namespaceObject.join)(tempRoot, "workspace");
104
- const configDir = ".wingman-dev";
105
- await (0, gateway_cjs_namespaceObject.executeGatewayCommand)({
106
- subcommand: "start",
107
- args: [],
108
- options: {}
109
- }, {
110
- workspace,
111
- configDir
112
- });
113
- (0, external_vitest_namespaceObject.expect)(daemonStartMock).toHaveBeenCalledTimes(1);
114
- (0, external_vitest_namespaceObject.expect)(daemonStartMock).toHaveBeenCalledWith(external_vitest_namespaceObject.expect.objectContaining({
115
- workspace,
116
- configDir
117
- }));
118
- });
119
- (0, external_vitest_namespaceObject.it)("fills missing workspace/configDir when running from daemon config", async ()=>{
120
- const workspace = (0, external_node_path_namespaceObject.join)(tempRoot, "workspace");
121
- const configDir = ".wingman-dev";
122
- const daemonConfigPath = (0, external_node_path_namespaceObject.join)(tempRoot, "gateway-daemon.json");
123
- (0, external_node_fs_namespaceObject.writeFileSync)(daemonConfigPath, JSON.stringify({
124
- host: "127.0.0.1",
125
- port: 18789,
126
- auth: {
127
- mode: "none"
128
- }
129
- }));
130
- process.env.WINGMAN_GATEWAY_CONFIG = daemonConfigPath;
131
- serverStartShouldReject = true;
132
- await (0, external_vitest_namespaceObject.expect)((0, gateway_cjs_namespaceObject.executeGatewayCommand)({
133
- subcommand: "run",
134
- args: [],
135
- options: {
136
- daemon: true
137
- }
138
- }, {
139
- workspace,
140
- configDir
141
- })).rejects.toThrow("process.exit(1)");
142
- (0, external_vitest_namespaceObject.expect)(createdServerConfigs).toHaveLength(1);
143
- (0, external_vitest_namespaceObject.expect)(createdServerConfigs[0]?.workspace).toBe(workspace);
144
- (0, external_vitest_namespaceObject.expect)(createdServerConfigs[0]?.configDir).toBe(configDir);
145
- });
146
- });
147
- for(var __rspack_i in __webpack_exports__)exports[__rspack_i] = __webpack_exports__[__rspack_i];
148
- Object.defineProperty(exports, '__esModule', {
149
- value: true
150
- });
@@ -1 +0,0 @@
1
- export {};
@@ -1,144 +0,0 @@
1
- import { existsSync, mkdtempSync, rmSync, writeFileSync } from "node:fs";
2
- import { tmpdir } from "node:os";
3
- import { join } from "node:path";
4
- import { afterEach, beforeEach, describe, expect, it, vi } from "vitest";
5
- import { executeGatewayCommand } from "../cli/commands/gateway.js";
6
- function _define_property(obj, key, value) {
7
- if (key in obj) Object.defineProperty(obj, key, {
8
- value: value,
9
- enumerable: true,
10
- configurable: true,
11
- writable: true
12
- });
13
- else obj[key] = value;
14
- return obj;
15
- }
16
- const daemonStartMock = vi.fn(async (_config)=>{});
17
- const daemonStopMock = vi.fn(async ()=>{});
18
- const daemonRestartMock = vi.fn(async ()=>{});
19
- const daemonGetStatusMock = vi.fn(()=>({
20
- running: false
21
- }));
22
- const daemonGetLogFileMock = vi.fn(()=>"/tmp/wingman-gateway.log");
23
- const daemonGetPidFileMock = vi.fn(()=>"/tmp/wingman-gateway.pid");
24
- const daemonGetConfigFileMock = vi.fn(()=>"/tmp/wingman-gateway.json");
25
- let serverStartShouldReject = false;
26
- const createdServerConfigs = [];
27
- const serverStartMock = vi.fn(async ()=>{
28
- if (serverStartShouldReject) throw new Error("synthetic gateway run stop");
29
- });
30
- const serverStopMock = vi.fn(async ()=>{});
31
- const loadConfigMock = vi.fn(()=>({
32
- gateway: {
33
- host: "127.0.0.1",
34
- port: 18789,
35
- auth: {
36
- mode: "none"
37
- }
38
- }
39
- }));
40
- vi.mock("../gateway/index.js", ()=>({
41
- GatewayDaemon: class {
42
- constructor(){
43
- _define_property(this, "start", daemonStartMock);
44
- _define_property(this, "stop", daemonStopMock);
45
- _define_property(this, "restart", daemonRestartMock);
46
- _define_property(this, "getStatus", daemonGetStatusMock);
47
- _define_property(this, "getLogFile", daemonGetLogFileMock);
48
- _define_property(this, "getPidFile", daemonGetPidFileMock);
49
- _define_property(this, "getConfigFile", daemonGetConfigFileMock);
50
- }
51
- },
52
- GatewayServer: class {
53
- constructor(config){
54
- _define_property(this, "start", serverStartMock);
55
- _define_property(this, "stop", serverStopMock);
56
- createdServerConfigs.push(config);
57
- }
58
- },
59
- GatewayClient: class {
60
- }
61
- }));
62
- vi.mock("../cli/config/loader.js", ()=>({
63
- WingmanConfigLoader: class {
64
- constructor(){
65
- _define_property(this, "loadConfig", loadConfigMock);
66
- }
67
- }
68
- }));
69
- describe("gateway command workspace handling", ()=>{
70
- let tempRoot;
71
- let consoleLogSpy;
72
- let consoleErrorSpy;
73
- let processExitSpy;
74
- const originalGatewayConfigEnv = process.env.WINGMAN_GATEWAY_CONFIG;
75
- beforeEach(()=>{
76
- tempRoot = mkdtempSync(join(tmpdir(), "wingman-gateway-command-"));
77
- serverStartShouldReject = false;
78
- createdServerConfigs.length = 0;
79
- daemonStartMock.mockClear();
80
- serverStartMock.mockClear();
81
- loadConfigMock.mockClear();
82
- consoleLogSpy = vi.spyOn(console, "log").mockImplementation(()=>{});
83
- consoleErrorSpy = vi.spyOn(console, "error").mockImplementation(()=>{});
84
- processExitSpy = vi.spyOn(process, "exit").mockImplementation((code)=>{
85
- throw new Error(`process.exit(${code ?? "undefined"})`);
86
- });
87
- delete process.env.WINGMAN_GATEWAY_CONFIG;
88
- });
89
- afterEach(()=>{
90
- consoleLogSpy.mockRestore();
91
- consoleErrorSpy.mockRestore();
92
- processExitSpy.mockRestore();
93
- if (originalGatewayConfigEnv) process.env.WINGMAN_GATEWAY_CONFIG = originalGatewayConfigEnv;
94
- else delete process.env.WINGMAN_GATEWAY_CONFIG;
95
- if (existsSync(tempRoot)) rmSync(tempRoot, {
96
- recursive: true,
97
- force: true
98
- });
99
- });
100
- it("passes workspace/configDir into daemon config on gateway start", async ()=>{
101
- const workspace = join(tempRoot, "workspace");
102
- const configDir = ".wingman-dev";
103
- await executeGatewayCommand({
104
- subcommand: "start",
105
- args: [],
106
- options: {}
107
- }, {
108
- workspace,
109
- configDir
110
- });
111
- expect(daemonStartMock).toHaveBeenCalledTimes(1);
112
- expect(daemonStartMock).toHaveBeenCalledWith(expect.objectContaining({
113
- workspace,
114
- configDir
115
- }));
116
- });
117
- it("fills missing workspace/configDir when running from daemon config", async ()=>{
118
- const workspace = join(tempRoot, "workspace");
119
- const configDir = ".wingman-dev";
120
- const daemonConfigPath = join(tempRoot, "gateway-daemon.json");
121
- writeFileSync(daemonConfigPath, JSON.stringify({
122
- host: "127.0.0.1",
123
- port: 18789,
124
- auth: {
125
- mode: "none"
126
- }
127
- }));
128
- process.env.WINGMAN_GATEWAY_CONFIG = daemonConfigPath;
129
- serverStartShouldReject = true;
130
- await expect(executeGatewayCommand({
131
- subcommand: "run",
132
- args: [],
133
- options: {
134
- daemon: true
135
- }
136
- }, {
137
- workspace,
138
- configDir
139
- })).rejects.toThrow("process.exit(1)");
140
- expect(createdServerConfigs).toHaveLength(1);
141
- expect(createdServerConfigs[0]?.workspace).toBe(workspace);
142
- expect(createdServerConfigs[0]?.configDir).toBe(configDir);
143
- });
144
- });
@@ -1,318 +0,0 @@
1
- "use strict";
2
- var __webpack_exports__ = {};
3
- const external_node_fs_namespaceObject = require("node:fs");
4
- const external_node_os_namespaceObject = require("node:os");
5
- const external_node_path_namespaceObject = require("node:path");
6
- const external_vitest_namespaceObject = require("vitest");
7
- const server_cjs_namespaceObject = require("../gateway/server.cjs");
8
- const tempWorkspaces = [];
9
- function createGateway(config) {
10
- const workspace = (0, external_node_fs_namespaceObject.mkdtempSync)((0, external_node_path_namespaceObject.join)((0, external_node_os_namespaceObject.tmpdir)(), "wingman-gateway-http-security-"));
11
- tempWorkspaces.push(workspace);
12
- return new server_cjs_namespaceObject.GatewayServer({
13
- logLevel: "silent",
14
- workspace,
15
- configDir: ".wingman-http-security-config",
16
- stateDir: ".wingman-http-security-state",
17
- ...config
18
- });
19
- }
20
- function getGatewayInternals(server) {
21
- return server;
22
- }
23
- function createTestSocket(initialData) {
24
- const messages = [];
25
- const ws = {
26
- data: {
27
- ...initialData || {}
28
- },
29
- send: (serialized)=>{
30
- messages.push(JSON.parse(serialized));
31
- return 1;
32
- },
33
- close: ()=>{}
34
- };
35
- return {
36
- ws,
37
- messages
38
- };
39
- }
40
- (0, external_vitest_namespaceObject.afterAll)(()=>{
41
- for (const workspace of tempWorkspaces)(0, external_node_fs_namespaceObject.rmSync)(workspace, {
42
- recursive: true,
43
- force: true
44
- });
45
- });
46
- (0, external_vitest_namespaceObject.describe)("gateway HTTP security", ()=>{
47
- (0, external_vitest_namespaceObject.it)("requires auth for /api routes when token auth is enabled", async ()=>{
48
- const server = createGateway({
49
- host: "127.0.0.1",
50
- port: 18789,
51
- auth: {
52
- mode: "token",
53
- token: "test-token"
54
- },
55
- requireAuth: true
56
- });
57
- const internals = getGatewayInternals(server);
58
- const unauthenticated = await internals.handleUiRequest(new Request("http://127.0.0.1:18789/api/providers"));
59
- (0, external_vitest_namespaceObject.expect)(unauthenticated.status).toBe(401);
60
- const authenticated = await internals.handleUiRequest(new Request("http://127.0.0.1:18789/api/providers", {
61
- headers: {
62
- Authorization: "Bearer test-token"
63
- }
64
- }));
65
- (0, external_vitest_namespaceObject.expect)(authenticated.status).toBe(200);
66
- });
67
- (0, external_vitest_namespaceObject.it)("returns summarization settings from /api/config without auth", async ()=>{
68
- const server = createGateway({
69
- host: "127.0.0.1",
70
- port: 18789,
71
- auth: {
72
- mode: "token",
73
- token: "test-token"
74
- },
75
- requireAuth: true
76
- });
77
- const internals = getGatewayInternals(server);
78
- const response = await internals.handleUiRequest(new Request("http://127.0.0.1:18789/api/config"));
79
- (0, external_vitest_namespaceObject.expect)(response.status).toBe(200);
80
- const payload = await response.json();
81
- (0, external_vitest_namespaceObject.expect)(payload.summarization).toMatchObject({
82
- enabled: true,
83
- maxTokensBeforeSummary: 12000,
84
- messagesToKeep: 8
85
- });
86
- });
87
- (0, external_vitest_namespaceObject.it)("rejects disallowed origins and allows loopback development preflight", async ()=>{
88
- const server = createGateway({
89
- host: "127.0.0.1",
90
- port: 18789,
91
- auth: {
92
- mode: "token",
93
- token: "test-token"
94
- },
95
- requireAuth: true
96
- });
97
- const internals = getGatewayInternals(server);
98
- const denied = await internals.handleUiRequest(new Request("http://127.0.0.1:18789/api/providers", {
99
- method: "OPTIONS",
100
- headers: {
101
- Origin: "https://evil.example",
102
- "Access-Control-Request-Method": "GET"
103
- }
104
- }));
105
- (0, external_vitest_namespaceObject.expect)(denied.status).toBe(403);
106
- const allowed = await internals.handleUiRequest(new Request("http://127.0.0.1:18789/api/providers", {
107
- method: "OPTIONS",
108
- headers: {
109
- Origin: "http://localhost:5173",
110
- "Access-Control-Request-Method": "GET"
111
- }
112
- }));
113
- (0, external_vitest_namespaceObject.expect)(allowed.status).toBe(204);
114
- (0, external_vitest_namespaceObject.expect)(allowed.headers.get("access-control-allow-origin")).toBe("http://localhost:5173");
115
- });
116
- (0, external_vitest_namespaceObject.it)("allows tauri loopback origin preflight for desktop clients", async ()=>{
117
- const server = createGateway({
118
- host: "127.0.0.1",
119
- port: 18789,
120
- auth: {
121
- mode: "token",
122
- token: "test-token"
123
- },
124
- requireAuth: true
125
- });
126
- const internals = getGatewayInternals(server);
127
- const allowed = await internals.handleUiRequest(new Request("http://127.0.0.1:18789/api/providers", {
128
- method: "OPTIONS",
129
- headers: {
130
- Origin: "tauri://localhost",
131
- "Access-Control-Request-Method": "GET"
132
- }
133
- }));
134
- (0, external_vitest_namespaceObject.expect)(allowed.status).toBe(204);
135
- (0, external_vitest_namespaceObject.expect)(allowed.headers.get("access-control-allow-origin")).toBe("tauri://localhost");
136
- });
137
- (0, external_vitest_namespaceObject.it)("does not trust tailscale identity headers on non-loopback hosts", ()=>{
138
- const server = createGateway({
139
- host: "0.0.0.0",
140
- port: 18789,
141
- auth: {
142
- mode: "token",
143
- token: "tailscale-token",
144
- allowTailscale: true
145
- },
146
- requireAuth: true
147
- });
148
- const internals = getGatewayInternals(server);
149
- const bypassAttempt = internals.requireHttpAuth(new Request("http://127.0.0.1:18789/api/providers", {
150
- headers: {
151
- "tailscale-user-login": "attacker@example.com"
152
- }
153
- }));
154
- (0, external_vitest_namespaceObject.expect)(bypassAttempt?.status).toBe(401);
155
- const authenticated = internals.requireHttpAuth(new Request("http://127.0.0.1:18789/api/providers", {
156
- headers: {
157
- Authorization: "Bearer tailscale-token",
158
- "tailscale-user-login": "attacker@example.com"
159
- }
160
- }));
161
- (0, external_vitest_namespaceObject.expect)(authenticated).toBeNull();
162
- });
163
- (0, external_vitest_namespaceObject.it)("enforces bridge node capacity limits", async ()=>{
164
- const server = createGateway({
165
- host: "127.0.0.1",
166
- port: 18789,
167
- auth: {
168
- mode: "none"
169
- },
170
- requireAuth: false,
171
- maxNodes: 1
172
- });
173
- const internals = getGatewayInternals(server);
174
- const registerBody = JSON.stringify({
175
- type: "register",
176
- payload: {
177
- name: "bridge-node"
178
- },
179
- timestamp: Date.now()
180
- });
181
- const first = await internals.handleBridgeSend(new Request("http://127.0.0.1:18789/bridge/send", {
182
- method: "POST",
183
- headers: {
184
- "Content-Type": "application/json"
185
- },
186
- body: registerBody
187
- }));
188
- (0, external_vitest_namespaceObject.expect)(first.status).toBe(200);
189
- const second = await internals.handleBridgeSend(new Request("http://127.0.0.1:18789/bridge/send", {
190
- method: "POST",
191
- headers: {
192
- "Content-Type": "application/json"
193
- },
194
- body: registerBody
195
- }));
196
- (0, external_vitest_namespaceObject.expect)(second.status).toBe(429);
197
- });
198
- (0, external_vitest_namespaceObject.it)("rejects malformed /api/nodes client IDs with 400", async ()=>{
199
- const server = createGateway({
200
- host: "127.0.0.1",
201
- port: 18789,
202
- auth: {
203
- mode: "none"
204
- },
205
- requireAuth: false
206
- });
207
- const internals = getGatewayInternals(server);
208
- const res = await internals.handleUiRequest(new Request("http://127.0.0.1:18789/api/nodes/%E0%A4%A", {
209
- method: "PUT",
210
- headers: {
211
- "Content-Type": "application/json"
212
- },
213
- body: JSON.stringify({
214
- enabled: true
215
- })
216
- }));
217
- (0, external_vitest_namespaceObject.expect)(res.status).toBe(400);
218
- });
219
- (0, external_vitest_namespaceObject.it)("requires approved client identity for node execution capabilities", ()=>{
220
- const server = createGateway({
221
- host: "127.0.0.1",
222
- port: 18789,
223
- auth: {
224
- mode: "none"
225
- },
226
- requireAuth: false
227
- });
228
- const internals = getGatewayInternals(server);
229
- const blocked = createTestSocket({
230
- authenticated: true
231
- });
232
- internals.handleRegister(blocked.ws, {
233
- type: "register",
234
- payload: {
235
- name: "unpaired-node",
236
- capabilities: [
237
- "system.run"
238
- ]
239
- },
240
- timestamp: Date.now()
241
- });
242
- (0, external_vitest_namespaceObject.expect)(blocked.messages.some((message)=>"error" === message.type && message.payload?.code === "NODE_NOT_ENABLED")).toBe(true);
243
- });
244
- (0, external_vitest_namespaceObject.it)("rejects duplicate pending node request IDs", async ()=>{
245
- const server = createGateway({
246
- host: "127.0.0.1",
247
- port: 18789,
248
- auth: {
249
- mode: "none"
250
- },
251
- requireAuth: false
252
- });
253
- const internals = getGatewayInternals(server);
254
- const enableTarget = await internals.handleUiRequest(new Request("http://127.0.0.1:18789/api/nodes/desktop-target", {
255
- method: "PUT",
256
- headers: {
257
- "Content-Type": "application/json"
258
- },
259
- body: JSON.stringify({
260
- enabled: true,
261
- name: "Desktop Target"
262
- })
263
- }));
264
- (0, external_vitest_namespaceObject.expect)(enableTarget.status).toBe(200);
265
- const target = createTestSocket({
266
- authenticated: true,
267
- clientId: "desktop-target",
268
- clientType: "desktop"
269
- });
270
- internals.handleRegister(target.ws, {
271
- type: "register",
272
- payload: {
273
- name: "target-node",
274
- capabilities: [
275
- "system.notify"
276
- ]
277
- },
278
- timestamp: Date.now()
279
- });
280
- const nodeId = target.messages.find((message)=>"ack" === message.type && "string" == typeof message.payload?.nodeId)?.payload?.nodeId;
281
- (0, external_vitest_namespaceObject.expect)(nodeId).toBeTruthy();
282
- const requester = createTestSocket({
283
- authenticated: true,
284
- clientId: "desktop-requester",
285
- clientType: "desktop"
286
- });
287
- const duplicateRequestId = "dup-node-request-id";
288
- internals.handleNodeRequest(requester.ws, {
289
- type: "req:node",
290
- id: duplicateRequestId,
291
- targetNodeId: nodeId,
292
- payload: {
293
- tool: "system.notify",
294
- args: {
295
- title: "test"
296
- }
297
- },
298
- timestamp: Date.now()
299
- });
300
- internals.handleNodeRequest(requester.ws, {
301
- type: "req:node",
302
- id: duplicateRequestId,
303
- targetNodeId: nodeId,
304
- payload: {
305
- tool: "system.notify",
306
- args: {
307
- title: "test"
308
- }
309
- },
310
- timestamp: Date.now()
311
- });
312
- (0, external_vitest_namespaceObject.expect)(requester.messages.some((message)=>"error" === message.type && message.payload?.code === "DUPLICATE_REQUEST_ID")).toBe(true);
313
- });
314
- });
315
- for(var __rspack_i in __webpack_exports__)exports[__rspack_i] = __webpack_exports__[__rspack_i];
316
- Object.defineProperty(exports, '__esModule', {
317
- value: true
318
- });
@@ -1 +0,0 @@
1
- export {};