@wingman-ai/gateway 0.5.3 → 0.6.0

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 (327) hide show
  1. package/dist/agent/backend/filtered-backend.cjs +130 -0
  2. package/dist/agent/backend/filtered-backend.d.ts +10 -0
  3. package/dist/agent/backend/filtered-backend.js +87 -0
  4. package/dist/agent/config/agentConfig.cjs +4 -0
  5. package/dist/agent/config/agentConfig.d.ts +12 -0
  6. package/dist/agent/config/agentConfig.js +4 -0
  7. package/dist/agent/config/toolRegistry.cjs +75 -1
  8. package/dist/agent/config/toolRegistry.d.ts +3 -0
  9. package/dist/agent/config/toolRegistry.js +75 -1
  10. package/dist/agent/middleware/additional-messages.cjs +4 -1
  11. package/dist/agent/middleware/additional-messages.js +4 -1
  12. package/dist/agent/middleware/large-tool-results.cjs +207 -0
  13. package/dist/agent/middleware/large-tool-results.d.ts +16 -0
  14. package/dist/agent/middleware/large-tool-results.js +173 -0
  15. package/dist/agent/tools/browser_control.cjs +9 -1231
  16. package/dist/agent/tools/browser_control.d.ts +126 -234
  17. package/dist/agent/tools/browser_control.js +7 -1226
  18. package/dist/agent/tools/browser_runtime.cjs +1358 -0
  19. package/dist/agent/tools/browser_runtime.d.ts +617 -0
  20. package/dist/agent/tools/browser_runtime.js +1288 -0
  21. package/dist/agent/tools/browser_session.cjs +189 -0
  22. package/dist/agent/tools/browser_session.d.ts +686 -0
  23. package/dist/agent/tools/browser_session.js +146 -0
  24. package/dist/agent/tools/browser_session_manager.cjs +213 -0
  25. package/dist/agent/tools/browser_session_manager.d.ts +70 -0
  26. package/dist/agent/tools/browser_session_manager.js +176 -0
  27. package/dist/cli/commands/init.cjs +80 -98
  28. package/dist/cli/commands/init.js +80 -98
  29. package/dist/cli/config/loader.cjs +0 -5
  30. package/dist/cli/config/loader.js +0 -5
  31. package/dist/cli/config/schema.cjs +3 -7
  32. package/dist/cli/config/schema.d.ts +6 -6
  33. package/dist/cli/config/schema.js +3 -7
  34. package/dist/cli/core/agentInvoker.cjs +88 -22
  35. package/dist/cli/core/agentInvoker.d.ts +10 -3
  36. package/dist/cli/core/agentInvoker.js +88 -25
  37. package/dist/cli/core/outputManager.cjs +7 -2
  38. package/dist/cli/core/outputManager.d.ts +2 -2
  39. package/dist/cli/core/outputManager.js +7 -2
  40. package/dist/cli/core/sessionManager.cjs +208 -41
  41. package/dist/cli/core/sessionManager.d.ts +20 -0
  42. package/dist/cli/core/sessionManager.js +208 -41
  43. package/dist/cli/index.cjs +16 -1
  44. package/dist/cli/index.js +16 -1
  45. package/dist/cli/services/updateCheck.cjs +212 -0
  46. package/dist/cli/services/updateCheck.d.ts +26 -0
  47. package/dist/cli/services/updateCheck.js +166 -0
  48. package/dist/cli/types.d.ts +2 -1
  49. package/dist/gateway/server.cjs +7 -0
  50. package/dist/gateway/server.js +7 -0
  51. package/dist/webui/assets/index-D3x3G75t.css +11 -0
  52. package/dist/webui/assets/index-UpMmcU1f.js +215 -0
  53. package/dist/webui/index.html +2 -2
  54. package/package.json +12 -12
  55. package/templates/agents/README.md +3 -1
  56. package/templates/agents/coding/agent.md +6 -13
  57. package/templates/agents/coding-v2/agent.md +6 -1
  58. package/templates/agents/game-dev/agent.md +9 -2
  59. package/templates/agents/game-dev/game-designer.md +4 -0
  60. package/templates/agents/game-dev/scene-engineer.md +4 -0
  61. package/templates/agents/main/agent.md +7 -2
  62. package/templates/agents/researcher/agent.md +14 -3
  63. package/templates/agents/stock-trader/agent.md +4 -0
  64. package/dist/agent/tests/agentConfig.test.cjs +0 -224
  65. package/dist/agent/tests/agentConfig.test.d.ts +0 -1
  66. package/dist/agent/tests/agentConfig.test.js +0 -218
  67. package/dist/agent/tests/agentLoader.test.cjs +0 -335
  68. package/dist/agent/tests/agentLoader.test.d.ts +0 -1
  69. package/dist/agent/tests/agentLoader.test.js +0 -329
  70. package/dist/agent/tests/backgroundTerminal.test.cjs +0 -70
  71. package/dist/agent/tests/backgroundTerminal.test.d.ts +0 -1
  72. package/dist/agent/tests/backgroundTerminal.test.js +0 -64
  73. package/dist/agent/tests/browserControlHelpers.test.cjs +0 -35
  74. package/dist/agent/tests/browserControlHelpers.test.d.ts +0 -1
  75. package/dist/agent/tests/browserControlHelpers.test.js +0 -29
  76. package/dist/agent/tests/browserControlTool.test.cjs +0 -2117
  77. package/dist/agent/tests/browserControlTool.test.d.ts +0 -1
  78. package/dist/agent/tests/browserControlTool.test.js +0 -2111
  79. package/dist/agent/tests/commandExecuteTool.test.cjs +0 -29
  80. package/dist/agent/tests/commandExecuteTool.test.d.ts +0 -1
  81. package/dist/agent/tests/commandExecuteTool.test.js +0 -23
  82. package/dist/agent/tests/internet_search.test.cjs +0 -107
  83. package/dist/agent/tests/internet_search.test.d.ts +0 -1
  84. package/dist/agent/tests/internet_search.test.js +0 -101
  85. package/dist/agent/tests/mcpClientManager.test.cjs +0 -290
  86. package/dist/agent/tests/mcpClientManager.test.d.ts +0 -1
  87. package/dist/agent/tests/mcpClientManager.test.js +0 -284
  88. package/dist/agent/tests/mcpResourceTools.test.cjs +0 -101
  89. package/dist/agent/tests/mcpResourceTools.test.d.ts +0 -1
  90. package/dist/agent/tests/mcpResourceTools.test.js +0 -95
  91. package/dist/agent/tests/modelFactory.test.cjs +0 -190
  92. package/dist/agent/tests/modelFactory.test.d.ts +0 -1
  93. package/dist/agent/tests/modelFactory.test.js +0 -184
  94. package/dist/agent/tests/terminalSessionManager.test.cjs +0 -121
  95. package/dist/agent/tests/terminalSessionManager.test.d.ts +0 -1
  96. package/dist/agent/tests/terminalSessionManager.test.js +0 -115
  97. package/dist/agent/tests/test-agent-loader.cjs +0 -33
  98. package/dist/agent/tests/test-agent-loader.d.ts +0 -1
  99. package/dist/agent/tests/test-agent-loader.js +0 -27
  100. package/dist/agent/tests/test-subagent-loading.cjs +0 -99
  101. package/dist/agent/tests/test-subagent-loading.d.ts +0 -1
  102. package/dist/agent/tests/test-subagent-loading.js +0 -93
  103. package/dist/agent/tests/toolRegistry.test.cjs +0 -147
  104. package/dist/agent/tests/toolRegistry.test.d.ts +0 -1
  105. package/dist/agent/tests/toolRegistry.test.js +0 -141
  106. package/dist/agent/tests/uiRegistryTools.test.cjs +0 -114
  107. package/dist/agent/tests/uiRegistryTools.test.d.ts +0 -1
  108. package/dist/agent/tests/uiRegistryTools.test.js +0 -105
  109. package/dist/agent/tests/xaiImageModel.test.cjs +0 -194
  110. package/dist/agent/tests/xaiImageModel.test.d.ts +0 -1
  111. package/dist/agent/tests/xaiImageModel.test.js +0 -188
  112. package/dist/tests/additionalMessageMiddleware.test.cjs +0 -216
  113. package/dist/tests/additionalMessageMiddleware.test.d.ts +0 -1
  114. package/dist/tests/additionalMessageMiddleware.test.js +0 -188
  115. package/dist/tests/agent-config-voice.test.cjs +0 -25
  116. package/dist/tests/agent-config-voice.test.d.ts +0 -1
  117. package/dist/tests/agent-config-voice.test.js +0 -19
  118. package/dist/tests/agentInvokerAttachments.test.cjs +0 -190
  119. package/dist/tests/agentInvokerAttachments.test.d.ts +0 -1
  120. package/dist/tests/agentInvokerAttachments.test.js +0 -184
  121. package/dist/tests/agentInvokerSummarization.test.cjs +0 -613
  122. package/dist/tests/agentInvokerSummarization.test.d.ts +0 -1
  123. package/dist/tests/agentInvokerSummarization.test.js +0 -607
  124. package/dist/tests/agentInvokerTokenUsage.test.cjs +0 -124
  125. package/dist/tests/agentInvokerTokenUsage.test.d.ts +0 -1
  126. package/dist/tests/agentInvokerTokenUsage.test.js +0 -118
  127. package/dist/tests/agentInvokerWorkdir.test.cjs +0 -150
  128. package/dist/tests/agentInvokerWorkdir.test.d.ts +0 -1
  129. package/dist/tests/agentInvokerWorkdir.test.js +0 -122
  130. package/dist/tests/agents-api.test.cjs +0 -324
  131. package/dist/tests/agents-api.test.d.ts +0 -1
  132. package/dist/tests/agents-api.test.js +0 -318
  133. package/dist/tests/attachments-utils.test.cjs +0 -46
  134. package/dist/tests/attachments-utils.test.d.ts +0 -1
  135. package/dist/tests/attachments-utils.test.js +0 -40
  136. package/dist/tests/browser-command.test.cjs +0 -264
  137. package/dist/tests/browser-command.test.d.ts +0 -1
  138. package/dist/tests/browser-command.test.js +0 -258
  139. package/dist/tests/browser-relay-server.test.cjs +0 -20
  140. package/dist/tests/browser-relay-server.test.d.ts +0 -1
  141. package/dist/tests/browser-relay-server.test.js +0 -14
  142. package/dist/tests/bunSqliteAdapter.test.cjs +0 -265
  143. package/dist/tests/bunSqliteAdapter.test.d.ts +0 -1
  144. package/dist/tests/bunSqliteAdapter.test.js +0 -259
  145. package/dist/tests/candleRange.test.cjs +0 -48
  146. package/dist/tests/candleRange.test.d.ts +0 -1
  147. package/dist/tests/candleRange.test.js +0 -42
  148. package/dist/tests/cli-config-loader.test.cjs +0 -532
  149. package/dist/tests/cli-config-loader.test.d.ts +0 -1
  150. package/dist/tests/cli-config-loader.test.js +0 -526
  151. package/dist/tests/cli-config-warnings.test.cjs +0 -94
  152. package/dist/tests/cli-config-warnings.test.d.ts +0 -1
  153. package/dist/tests/cli-config-warnings.test.js +0 -88
  154. package/dist/tests/cli-init.test.cjs +0 -225
  155. package/dist/tests/cli-init.test.d.ts +0 -1
  156. package/dist/tests/cli-init.test.js +0 -219
  157. package/dist/tests/cli-workspace-root.test.cjs +0 -114
  158. package/dist/tests/cli-workspace-root.test.d.ts +0 -1
  159. package/dist/tests/cli-workspace-root.test.js +0 -108
  160. package/dist/tests/codex-credentials-precedence.test.cjs +0 -94
  161. package/dist/tests/codex-credentials-precedence.test.d.ts +0 -1
  162. package/dist/tests/codex-credentials-precedence.test.js +0 -88
  163. package/dist/tests/codex-provider.test.cjs +0 -383
  164. package/dist/tests/codex-provider.test.d.ts +0 -1
  165. package/dist/tests/codex-provider.test.js +0 -377
  166. package/dist/tests/config-json-schema.test.cjs +0 -37
  167. package/dist/tests/config-json-schema.test.d.ts +0 -1
  168. package/dist/tests/config-json-schema.test.js +0 -31
  169. package/dist/tests/discord-adapter.test.cjs +0 -89
  170. package/dist/tests/discord-adapter.test.d.ts +0 -1
  171. package/dist/tests/discord-adapter.test.js +0 -83
  172. package/dist/tests/falRuntime.test.cjs +0 -78
  173. package/dist/tests/falRuntime.test.d.ts +0 -1
  174. package/dist/tests/falRuntime.test.js +0 -72
  175. package/dist/tests/falSummary.test.cjs +0 -51
  176. package/dist/tests/falSummary.test.d.ts +0 -1
  177. package/dist/tests/falSummary.test.js +0 -45
  178. package/dist/tests/fs-api.test.cjs +0 -138
  179. package/dist/tests/fs-api.test.d.ts +0 -1
  180. package/dist/tests/fs-api.test.js +0 -132
  181. package/dist/tests/gateway-command-workspace.test.cjs +0 -150
  182. package/dist/tests/gateway-command-workspace.test.d.ts +0 -1
  183. package/dist/tests/gateway-command-workspace.test.js +0 -144
  184. package/dist/tests/gateway-http-security.test.cjs +0 -318
  185. package/dist/tests/gateway-http-security.test.d.ts +0 -1
  186. package/dist/tests/gateway-http-security.test.js +0 -312
  187. package/dist/tests/gateway-node-mode.test.cjs +0 -174
  188. package/dist/tests/gateway-node-mode.test.d.ts +0 -1
  189. package/dist/tests/gateway-node-mode.test.js +0 -168
  190. package/dist/tests/gateway-origin-policy.test.cjs +0 -82
  191. package/dist/tests/gateway-origin-policy.test.d.ts +0 -1
  192. package/dist/tests/gateway-origin-policy.test.js +0 -76
  193. package/dist/tests/gateway-request-execution-overrides.test.cjs +0 -42
  194. package/dist/tests/gateway-request-execution-overrides.test.d.ts +0 -1
  195. package/dist/tests/gateway-request-execution-overrides.test.js +0 -36
  196. package/dist/tests/gateway.test.cjs +0 -700
  197. package/dist/tests/gateway.test.d.ts +0 -1
  198. package/dist/tests/gateway.test.js +0 -694
  199. package/dist/tests/hooks-matcher.test.cjs +0 -309
  200. package/dist/tests/hooks-matcher.test.d.ts +0 -1
  201. package/dist/tests/hooks-matcher.test.js +0 -303
  202. package/dist/tests/hooks-merger.test.cjs +0 -528
  203. package/dist/tests/hooks-merger.test.d.ts +0 -1
  204. package/dist/tests/hooks-merger.test.js +0 -522
  205. package/dist/tests/imagePersistence.test.cjs +0 -169
  206. package/dist/tests/imagePersistence.test.d.ts +0 -1
  207. package/dist/tests/imagePersistence.test.js +0 -163
  208. package/dist/tests/integration/agent-invocation.integration.test.cjs +0 -264
  209. package/dist/tests/integration/agent-invocation.integration.test.d.ts +0 -1
  210. package/dist/tests/integration/agent-invocation.integration.test.js +0 -258
  211. package/dist/tests/integration/finnhub-candles.integration.test.cjs +0 -98
  212. package/dist/tests/integration/finnhub-candles.integration.test.d.ts +0 -1
  213. package/dist/tests/integration/finnhub-candles.integration.test.js +0 -92
  214. package/dist/tests/integration/summarization-e2e.integration.test.cjs +0 -127
  215. package/dist/tests/integration/summarization-e2e.integration.test.d.ts +0 -1
  216. package/dist/tests/integration/summarization-e2e.integration.test.js +0 -121
  217. package/dist/tests/logger.test.cjs +0 -353
  218. package/dist/tests/logger.test.d.ts +0 -1
  219. package/dist/tests/logger.test.js +0 -347
  220. package/dist/tests/mediaCompatibilityMiddleware.test.cjs +0 -106
  221. package/dist/tests/mediaCompatibilityMiddleware.test.d.ts +0 -1
  222. package/dist/tests/mediaCompatibilityMiddleware.test.js +0 -100
  223. package/dist/tests/node-tools.test.cjs +0 -77
  224. package/dist/tests/node-tools.test.d.ts +0 -1
  225. package/dist/tests/node-tools.test.js +0 -71
  226. package/dist/tests/nodes-api.test.cjs +0 -86
  227. package/dist/tests/nodes-api.test.d.ts +0 -1
  228. package/dist/tests/nodes-api.test.js +0 -80
  229. package/dist/tests/outputManagerContextSummarized.test.cjs +0 -43
  230. package/dist/tests/outputManagerContextSummarized.test.d.ts +0 -1
  231. package/dist/tests/outputManagerContextSummarized.test.js +0 -37
  232. package/dist/tests/provider-command-codex.test.cjs +0 -57
  233. package/dist/tests/provider-command-codex.test.d.ts +0 -1
  234. package/dist/tests/provider-command-codex.test.js +0 -51
  235. package/dist/tests/routines-api.test.cjs +0 -107
  236. package/dist/tests/routines-api.test.d.ts +0 -1
  237. package/dist/tests/routines-api.test.js +0 -101
  238. package/dist/tests/run-terminal-bench-official-script.test.cjs +0 -61
  239. package/dist/tests/run-terminal-bench-official-script.test.d.ts +0 -1
  240. package/dist/tests/run-terminal-bench-official-script.test.js +0 -55
  241. package/dist/tests/sessionManager-uionly.test.cjs +0 -50
  242. package/dist/tests/sessionManager-uionly.test.d.ts +0 -1
  243. package/dist/tests/sessionManager-uionly.test.js +0 -44
  244. package/dist/tests/sessionMessageAttachments.test.cjs +0 -197
  245. package/dist/tests/sessionMessageAttachments.test.d.ts +0 -1
  246. package/dist/tests/sessionMessageAttachments.test.js +0 -191
  247. package/dist/tests/sessionMessageRole.test.cjs +0 -44
  248. package/dist/tests/sessionMessageRole.test.d.ts +0 -1
  249. package/dist/tests/sessionMessageRole.test.js +0 -38
  250. package/dist/tests/sessionStateMessages.test.cjs +0 -236
  251. package/dist/tests/sessionStateMessages.test.d.ts +0 -1
  252. package/dist/tests/sessionStateMessages.test.js +0 -230
  253. package/dist/tests/sessions-api.test.cjs +0 -250
  254. package/dist/tests/sessions-api.test.d.ts +0 -1
  255. package/dist/tests/sessions-api.test.js +0 -244
  256. package/dist/tests/skill-activation.test.cjs +0 -86
  257. package/dist/tests/skill-activation.test.d.ts +0 -1
  258. package/dist/tests/skill-activation.test.js +0 -80
  259. package/dist/tests/skill-metadata.test.cjs +0 -119
  260. package/dist/tests/skill-metadata.test.d.ts +0 -1
  261. package/dist/tests/skill-metadata.test.js +0 -113
  262. package/dist/tests/skill-repository.test.cjs +0 -469
  263. package/dist/tests/skill-repository.test.d.ts +0 -1
  264. package/dist/tests/skill-repository.test.js +0 -463
  265. package/dist/tests/skill-security-scanner.test.cjs +0 -126
  266. package/dist/tests/skill-security-scanner.test.d.ts +0 -1
  267. package/dist/tests/skill-security-scanner.test.js +0 -120
  268. package/dist/tests/sms-api.test.cjs +0 -183
  269. package/dist/tests/sms-api.test.d.ts +0 -1
  270. package/dist/tests/sms-api.test.js +0 -177
  271. package/dist/tests/sms-commands.test.cjs +0 -90
  272. package/dist/tests/sms-commands.test.d.ts +0 -1
  273. package/dist/tests/sms-commands.test.js +0 -84
  274. package/dist/tests/sms-policy-store.test.cjs +0 -69
  275. package/dist/tests/sms-policy-store.test.d.ts +0 -1
  276. package/dist/tests/sms-policy-store.test.js +0 -63
  277. package/dist/tests/teams-adapter.test.cjs +0 -58
  278. package/dist/tests/teams-adapter.test.d.ts +0 -1
  279. package/dist/tests/teams-adapter.test.js +0 -52
  280. package/dist/tests/technicalIndicators.test.cjs +0 -82
  281. package/dist/tests/technicalIndicators.test.d.ts +0 -1
  282. package/dist/tests/technicalIndicators.test.js +0 -76
  283. package/dist/tests/terminal-bench-adapters-helpers.test.cjs +0 -64
  284. package/dist/tests/terminal-bench-adapters-helpers.test.d.ts +0 -1
  285. package/dist/tests/terminal-bench-adapters-helpers.test.js +0 -58
  286. package/dist/tests/terminal-bench-cleanup.test.cjs +0 -93
  287. package/dist/tests/terminal-bench-cleanup.test.d.ts +0 -1
  288. package/dist/tests/terminal-bench-cleanup.test.js +0 -87
  289. package/dist/tests/terminal-bench-config.test.cjs +0 -62
  290. package/dist/tests/terminal-bench-config.test.d.ts +0 -1
  291. package/dist/tests/terminal-bench-config.test.js +0 -56
  292. package/dist/tests/terminal-bench-official.test.cjs +0 -194
  293. package/dist/tests/terminal-bench-official.test.d.ts +0 -1
  294. package/dist/tests/terminal-bench-official.test.js +0 -188
  295. package/dist/tests/terminal-bench-runner.test.cjs +0 -82
  296. package/dist/tests/terminal-bench-runner.test.d.ts +0 -1
  297. package/dist/tests/terminal-bench-runner.test.js +0 -76
  298. package/dist/tests/terminal-bench-scoring.test.cjs +0 -128
  299. package/dist/tests/terminal-bench-scoring.test.d.ts +0 -1
  300. package/dist/tests/terminal-bench-scoring.test.js +0 -122
  301. package/dist/tests/terminalProbe.test.cjs +0 -45
  302. package/dist/tests/terminalProbe.test.d.ts +0 -1
  303. package/dist/tests/terminalProbe.test.js +0 -39
  304. package/dist/tests/terminalProbeAuth.test.cjs +0 -85
  305. package/dist/tests/terminalProbeAuth.test.d.ts +0 -1
  306. package/dist/tests/terminalProbeAuth.test.js +0 -79
  307. package/dist/tests/toolDisplayHelpers.test.cjs +0 -46
  308. package/dist/tests/toolDisplayHelpers.test.d.ts +0 -1
  309. package/dist/tests/toolDisplayHelpers.test.js +0 -40
  310. package/dist/tests/uv.test.cjs +0 -47
  311. package/dist/tests/uv.test.d.ts +0 -1
  312. package/dist/tests/uv.test.js +0 -41
  313. package/dist/tests/voice-config.test.cjs +0 -35
  314. package/dist/tests/voice-config.test.d.ts +0 -1
  315. package/dist/tests/voice-config.test.js +0 -29
  316. package/dist/tests/websocket-transport.test.cjs +0 -31
  317. package/dist/tests/websocket-transport.test.d.ts +0 -1
  318. package/dist/tests/websocket-transport.test.js +0 -25
  319. package/dist/tests/yahooCandles.test.cjs +0 -111
  320. package/dist/tests/yahooCandles.test.d.ts +0 -1
  321. package/dist/tests/yahooCandles.test.js +0 -105
  322. package/dist/tools/finance/optionsAnalytics.test.cjs +0 -128
  323. package/dist/tools/finance/optionsAnalytics.test.d.ts +0 -1
  324. package/dist/tools/finance/optionsAnalytics.test.js +0 -122
  325. package/dist/webui/assets/index-BMf95nv5.js +0 -215
  326. package/dist/webui/assets/index-DhJQ8Mbn.css +0 -11
  327. package/dist/webui/assets/wingman_logo-Cogyt3qm.webp +0 -0
@@ -1,312 +0,0 @@
1
- import { mkdtempSync, rmSync } from "node:fs";
2
- import { tmpdir } from "node:os";
3
- import { join } from "node:path";
4
- import { afterAll, describe, expect, it } from "vitest";
5
- import { GatewayServer } from "../gateway/server.js";
6
- const tempWorkspaces = [];
7
- function createGateway(config) {
8
- const workspace = mkdtempSync(join(tmpdir(), "wingman-gateway-http-security-"));
9
- tempWorkspaces.push(workspace);
10
- return new GatewayServer({
11
- logLevel: "silent",
12
- workspace,
13
- configDir: ".wingman-http-security-config",
14
- stateDir: ".wingman-http-security-state",
15
- ...config
16
- });
17
- }
18
- function getGatewayInternals(server) {
19
- return server;
20
- }
21
- function createTestSocket(initialData) {
22
- const messages = [];
23
- const ws = {
24
- data: {
25
- ...initialData || {}
26
- },
27
- send: (serialized)=>{
28
- messages.push(JSON.parse(serialized));
29
- return 1;
30
- },
31
- close: ()=>{}
32
- };
33
- return {
34
- ws,
35
- messages
36
- };
37
- }
38
- afterAll(()=>{
39
- for (const workspace of tempWorkspaces)rmSync(workspace, {
40
- recursive: true,
41
- force: true
42
- });
43
- });
44
- describe("gateway HTTP security", ()=>{
45
- it("requires auth for /api routes when token auth is enabled", async ()=>{
46
- const server = createGateway({
47
- host: "127.0.0.1",
48
- port: 18789,
49
- auth: {
50
- mode: "token",
51
- token: "test-token"
52
- },
53
- requireAuth: true
54
- });
55
- const internals = getGatewayInternals(server);
56
- const unauthenticated = await internals.handleUiRequest(new Request("http://127.0.0.1:18789/api/providers"));
57
- expect(unauthenticated.status).toBe(401);
58
- const authenticated = await internals.handleUiRequest(new Request("http://127.0.0.1:18789/api/providers", {
59
- headers: {
60
- Authorization: "Bearer test-token"
61
- }
62
- }));
63
- expect(authenticated.status).toBe(200);
64
- });
65
- it("returns summarization settings from /api/config without auth", async ()=>{
66
- const server = createGateway({
67
- host: "127.0.0.1",
68
- port: 18789,
69
- auth: {
70
- mode: "token",
71
- token: "test-token"
72
- },
73
- requireAuth: true
74
- });
75
- const internals = getGatewayInternals(server);
76
- const response = await internals.handleUiRequest(new Request("http://127.0.0.1:18789/api/config"));
77
- expect(response.status).toBe(200);
78
- const payload = await response.json();
79
- expect(payload.summarization).toMatchObject({
80
- enabled: true,
81
- maxTokensBeforeSummary: 12000,
82
- messagesToKeep: 8
83
- });
84
- });
85
- it("rejects disallowed origins and allows loopback development preflight", async ()=>{
86
- const server = createGateway({
87
- host: "127.0.0.1",
88
- port: 18789,
89
- auth: {
90
- mode: "token",
91
- token: "test-token"
92
- },
93
- requireAuth: true
94
- });
95
- const internals = getGatewayInternals(server);
96
- const denied = await internals.handleUiRequest(new Request("http://127.0.0.1:18789/api/providers", {
97
- method: "OPTIONS",
98
- headers: {
99
- Origin: "https://evil.example",
100
- "Access-Control-Request-Method": "GET"
101
- }
102
- }));
103
- expect(denied.status).toBe(403);
104
- const allowed = await internals.handleUiRequest(new Request("http://127.0.0.1:18789/api/providers", {
105
- method: "OPTIONS",
106
- headers: {
107
- Origin: "http://localhost:5173",
108
- "Access-Control-Request-Method": "GET"
109
- }
110
- }));
111
- expect(allowed.status).toBe(204);
112
- expect(allowed.headers.get("access-control-allow-origin")).toBe("http://localhost:5173");
113
- });
114
- it("allows tauri loopback origin preflight for desktop clients", async ()=>{
115
- const server = createGateway({
116
- host: "127.0.0.1",
117
- port: 18789,
118
- auth: {
119
- mode: "token",
120
- token: "test-token"
121
- },
122
- requireAuth: true
123
- });
124
- const internals = getGatewayInternals(server);
125
- const allowed = await internals.handleUiRequest(new Request("http://127.0.0.1:18789/api/providers", {
126
- method: "OPTIONS",
127
- headers: {
128
- Origin: "tauri://localhost",
129
- "Access-Control-Request-Method": "GET"
130
- }
131
- }));
132
- expect(allowed.status).toBe(204);
133
- expect(allowed.headers.get("access-control-allow-origin")).toBe("tauri://localhost");
134
- });
135
- it("does not trust tailscale identity headers on non-loopback hosts", ()=>{
136
- const server = createGateway({
137
- host: "0.0.0.0",
138
- port: 18789,
139
- auth: {
140
- mode: "token",
141
- token: "tailscale-token",
142
- allowTailscale: true
143
- },
144
- requireAuth: true
145
- });
146
- const internals = getGatewayInternals(server);
147
- const bypassAttempt = internals.requireHttpAuth(new Request("http://127.0.0.1:18789/api/providers", {
148
- headers: {
149
- "tailscale-user-login": "attacker@example.com"
150
- }
151
- }));
152
- expect(bypassAttempt?.status).toBe(401);
153
- const authenticated = internals.requireHttpAuth(new Request("http://127.0.0.1:18789/api/providers", {
154
- headers: {
155
- Authorization: "Bearer tailscale-token",
156
- "tailscale-user-login": "attacker@example.com"
157
- }
158
- }));
159
- expect(authenticated).toBeNull();
160
- });
161
- it("enforces bridge node capacity limits", async ()=>{
162
- const server = createGateway({
163
- host: "127.0.0.1",
164
- port: 18789,
165
- auth: {
166
- mode: "none"
167
- },
168
- requireAuth: false,
169
- maxNodes: 1
170
- });
171
- const internals = getGatewayInternals(server);
172
- const registerBody = JSON.stringify({
173
- type: "register",
174
- payload: {
175
- name: "bridge-node"
176
- },
177
- timestamp: Date.now()
178
- });
179
- const first = await internals.handleBridgeSend(new Request("http://127.0.0.1:18789/bridge/send", {
180
- method: "POST",
181
- headers: {
182
- "Content-Type": "application/json"
183
- },
184
- body: registerBody
185
- }));
186
- expect(first.status).toBe(200);
187
- const second = await internals.handleBridgeSend(new Request("http://127.0.0.1:18789/bridge/send", {
188
- method: "POST",
189
- headers: {
190
- "Content-Type": "application/json"
191
- },
192
- body: registerBody
193
- }));
194
- expect(second.status).toBe(429);
195
- });
196
- it("rejects malformed /api/nodes client IDs with 400", async ()=>{
197
- const server = createGateway({
198
- host: "127.0.0.1",
199
- port: 18789,
200
- auth: {
201
- mode: "none"
202
- },
203
- requireAuth: false
204
- });
205
- const internals = getGatewayInternals(server);
206
- const res = await internals.handleUiRequest(new Request("http://127.0.0.1:18789/api/nodes/%E0%A4%A", {
207
- method: "PUT",
208
- headers: {
209
- "Content-Type": "application/json"
210
- },
211
- body: JSON.stringify({
212
- enabled: true
213
- })
214
- }));
215
- expect(res.status).toBe(400);
216
- });
217
- it("requires approved client identity for node execution capabilities", ()=>{
218
- const server = createGateway({
219
- host: "127.0.0.1",
220
- port: 18789,
221
- auth: {
222
- mode: "none"
223
- },
224
- requireAuth: false
225
- });
226
- const internals = getGatewayInternals(server);
227
- const blocked = createTestSocket({
228
- authenticated: true
229
- });
230
- internals.handleRegister(blocked.ws, {
231
- type: "register",
232
- payload: {
233
- name: "unpaired-node",
234
- capabilities: [
235
- "system.run"
236
- ]
237
- },
238
- timestamp: Date.now()
239
- });
240
- expect(blocked.messages.some((message)=>"error" === message.type && message.payload?.code === "NODE_NOT_ENABLED")).toBe(true);
241
- });
242
- it("rejects duplicate pending node request IDs", async ()=>{
243
- const server = createGateway({
244
- host: "127.0.0.1",
245
- port: 18789,
246
- auth: {
247
- mode: "none"
248
- },
249
- requireAuth: false
250
- });
251
- const internals = getGatewayInternals(server);
252
- const enableTarget = await internals.handleUiRequest(new Request("http://127.0.0.1:18789/api/nodes/desktop-target", {
253
- method: "PUT",
254
- headers: {
255
- "Content-Type": "application/json"
256
- },
257
- body: JSON.stringify({
258
- enabled: true,
259
- name: "Desktop Target"
260
- })
261
- }));
262
- expect(enableTarget.status).toBe(200);
263
- const target = createTestSocket({
264
- authenticated: true,
265
- clientId: "desktop-target",
266
- clientType: "desktop"
267
- });
268
- internals.handleRegister(target.ws, {
269
- type: "register",
270
- payload: {
271
- name: "target-node",
272
- capabilities: [
273
- "system.notify"
274
- ]
275
- },
276
- timestamp: Date.now()
277
- });
278
- const nodeId = target.messages.find((message)=>"ack" === message.type && "string" == typeof message.payload?.nodeId)?.payload?.nodeId;
279
- expect(nodeId).toBeTruthy();
280
- const requester = createTestSocket({
281
- authenticated: true,
282
- clientId: "desktop-requester",
283
- clientType: "desktop"
284
- });
285
- const duplicateRequestId = "dup-node-request-id";
286
- internals.handleNodeRequest(requester.ws, {
287
- type: "req:node",
288
- id: duplicateRequestId,
289
- targetNodeId: nodeId,
290
- payload: {
291
- tool: "system.notify",
292
- args: {
293
- title: "test"
294
- }
295
- },
296
- timestamp: Date.now()
297
- });
298
- internals.handleNodeRequest(requester.ws, {
299
- type: "req:node",
300
- id: duplicateRequestId,
301
- targetNodeId: nodeId,
302
- payload: {
303
- tool: "system.notify",
304
- args: {
305
- title: "test"
306
- }
307
- },
308
- timestamp: Date.now()
309
- });
310
- expect(requester.messages.some((message)=>"error" === message.type && message.payload?.code === "DUPLICATE_REQUEST_ID")).toBe(true);
311
- });
312
- });
@@ -1,174 +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 isBun = void 0 !== globalThis.Bun;
9
- const describeIfBun = isBun ? external_vitest_namespaceObject.describe : external_vitest_namespaceObject.describe.skip;
10
- describeIfBun("Gateway node enablement", ()=>{
11
- let server;
12
- let port = 0;
13
- let workspace;
14
- (0, external_vitest_namespaceObject.beforeAll)(async ()=>{
15
- workspace = (0, external_node_fs_namespaceObject.mkdtempSync)((0, external_node_path_namespaceObject.join)((0, external_node_os_namespaceObject.tmpdir)(), "wingman-gateway-node-mode-"));
16
- server = new server_cjs_namespaceObject.GatewayServer({
17
- port: 0,
18
- host: "localhost",
19
- requireAuth: false,
20
- auth: {
21
- mode: "none"
22
- },
23
- logLevel: "silent",
24
- workspace,
25
- configDir: ".wingman-node-test-config",
26
- stateDir: ".wingman-node-test-state"
27
- });
28
- await server.start();
29
- port = server.getPort();
30
- if (!port) throw new Error("Unable to determine gateway port");
31
- });
32
- (0, external_vitest_namespaceObject.afterAll)(async ()=>{
33
- await server.stop();
34
- (0, external_node_fs_namespaceObject.rmSync)(workspace, {
35
- recursive: true,
36
- force: true
37
- });
38
- });
39
- const connectClient = (instanceId, clientType = "desktop")=>new Promise((resolve, reject)=>{
40
- const ws = new WebSocket(`ws://localhost:${port}/ws`);
41
- const connectId = `connect-${instanceId}-${Date.now()}`;
42
- const timeout = setTimeout(()=>reject(new Error("Connect timeout")), 5000);
43
- ws.addEventListener("open", ()=>{
44
- ws.send(JSON.stringify({
45
- type: "connect",
46
- id: connectId,
47
- client: {
48
- instanceId,
49
- clientType,
50
- version: "test"
51
- },
52
- timestamp: Date.now()
53
- }));
54
- });
55
- ws.addEventListener("message", (event)=>{
56
- const msg = JSON.parse(event.data);
57
- if ("res" === msg.type && msg.id === connectId && msg.ok) {
58
- clearTimeout(timeout);
59
- resolve(ws);
60
- }
61
- });
62
- ws.addEventListener("error", ()=>{
63
- clearTimeout(timeout);
64
- reject(new Error("WebSocket error"));
65
- });
66
- });
67
- const waitForMessage = (ws, predicate, timeoutMs = 5000)=>new Promise((resolve, reject)=>{
68
- const timeout = setTimeout(()=>reject(new Error("Message timeout")), timeoutMs);
69
- const handler = (event)=>{
70
- const data = event.data;
71
- if ("string" != typeof data) return;
72
- let msg;
73
- try {
74
- msg = JSON.parse(data);
75
- } catch {
76
- return;
77
- }
78
- if (!predicate(msg)) return;
79
- clearTimeout(timeout);
80
- ws.removeEventListener("message", handler);
81
- resolve(msg);
82
- };
83
- ws.addEventListener("message", handler);
84
- });
85
- (0, external_vitest_namespaceObject.it)("blocks node registration before device enablement", async ()=>{
86
- const ws = await connectClient("desktop-node-blocked");
87
- ws.send(JSON.stringify({
88
- type: "register",
89
- payload: {
90
- name: "Blocked Node",
91
- capabilities: [
92
- "system.notify"
93
- ]
94
- },
95
- timestamp: Date.now()
96
- }));
97
- const errorMessage = await waitForMessage(ws, (msg)=>"error" === msg.type && msg.payload?.code === "NODE_NOT_ENABLED");
98
- (0, external_vitest_namespaceObject.expect)(errorMessage.payload?.message).toContain("not approved");
99
- ws.close();
100
- });
101
- (0, external_vitest_namespaceObject.it)("allows enabled devices to register, execute, and revoke", async ()=>{
102
- const enableResponse = await fetch(`http://localhost:${port}/api/nodes/${encodeURIComponent("desktop-node-enabled")}`, {
103
- method: "PUT",
104
- headers: {
105
- "Content-Type": "application/json"
106
- },
107
- body: JSON.stringify({
108
- enabled: true,
109
- name: "Enabled Desktop"
110
- })
111
- });
112
- (0, external_vitest_namespaceObject.expect)(enableResponse.ok).toBe(true);
113
- const nodeWs = await connectClient("desktop-node-enabled");
114
- nodeWs.send(JSON.stringify({
115
- type: "register",
116
- payload: {
117
- name: "Enabled Desktop",
118
- capabilities: [
119
- "system.notify"
120
- ]
121
- },
122
- timestamp: Date.now()
123
- }));
124
- const registrationAck = await waitForMessage(nodeWs, (msg)=>"ack" === msg.type && "string" == typeof msg.payload?.nodeId);
125
- const nodeId = registrationAck.payload.nodeId;
126
- (0, external_vitest_namespaceObject.expect)(nodeId).toBeTruthy();
127
- const requesterWs = await connectClient("desktop-requester");
128
- requesterWs.send(JSON.stringify({
129
- type: "req:node",
130
- id: "node-req-1",
131
- targetNodeId: nodeId,
132
- payload: {
133
- tool: "system.notify",
134
- args: {
135
- title: "Hello",
136
- body: "Node test"
137
- }
138
- },
139
- timestamp: Date.now()
140
- }));
141
- const forwardedToNode = await waitForMessage(nodeWs, (msg)=>"req:node" === msg.type && "node-req-1" === msg.id);
142
- (0, external_vitest_namespaceObject.expect)(forwardedToNode.targetNodeId).toBe(nodeId);
143
- nodeWs.send(JSON.stringify({
144
- type: "res",
145
- id: "node-req-1",
146
- ok: true,
147
- payload: {
148
- delivered: true
149
- },
150
- timestamp: Date.now()
151
- }));
152
- const returnedToRequester = await waitForMessage(requesterWs, (msg)=>"res" === msg.type && "node-req-1" === msg.id);
153
- (0, external_vitest_namespaceObject.expect)(returnedToRequester.ok).toBe(true);
154
- (0, external_vitest_namespaceObject.expect)(returnedToRequester.nodeId).toBe(nodeId);
155
- const closePromise = new Promise((resolve)=>{
156
- nodeWs.addEventListener("close", ()=>{
157
- resolve();
158
- }, {
159
- once: true
160
- });
161
- });
162
- const revokeResponse = await fetch(`http://localhost:${port}/api/nodes/${encodeURIComponent("desktop-node-enabled")}`, {
163
- method: "DELETE"
164
- });
165
- (0, external_vitest_namespaceObject.expect)(revokeResponse.ok).toBe(true);
166
- await closePromise;
167
- requesterWs.close();
168
- nodeWs.close();
169
- });
170
- });
171
- for(var __rspack_i in __webpack_exports__)exports[__rspack_i] = __webpack_exports__[__rspack_i];
172
- Object.defineProperty(exports, '__esModule', {
173
- value: true
174
- });
@@ -1 +0,0 @@
1
- export {};
@@ -1,168 +0,0 @@
1
- import { mkdtempSync, rmSync } from "node:fs";
2
- import { tmpdir } from "node:os";
3
- import { join } from "node:path";
4
- import { afterAll, beforeAll, describe, expect, it } from "vitest";
5
- import { GatewayServer } from "../gateway/server.js";
6
- const isBun = void 0 !== globalThis.Bun;
7
- const describeIfBun = isBun ? describe : describe.skip;
8
- describeIfBun("Gateway node enablement", ()=>{
9
- let server;
10
- let port = 0;
11
- let workspace;
12
- beforeAll(async ()=>{
13
- workspace = mkdtempSync(join(tmpdir(), "wingman-gateway-node-mode-"));
14
- server = new GatewayServer({
15
- port: 0,
16
- host: "localhost",
17
- requireAuth: false,
18
- auth: {
19
- mode: "none"
20
- },
21
- logLevel: "silent",
22
- workspace,
23
- configDir: ".wingman-node-test-config",
24
- stateDir: ".wingman-node-test-state"
25
- });
26
- await server.start();
27
- port = server.getPort();
28
- if (!port) throw new Error("Unable to determine gateway port");
29
- });
30
- afterAll(async ()=>{
31
- await server.stop();
32
- rmSync(workspace, {
33
- recursive: true,
34
- force: true
35
- });
36
- });
37
- const connectClient = (instanceId, clientType = "desktop")=>new Promise((resolve, reject)=>{
38
- const ws = new WebSocket(`ws://localhost:${port}/ws`);
39
- const connectId = `connect-${instanceId}-${Date.now()}`;
40
- const timeout = setTimeout(()=>reject(new Error("Connect timeout")), 5000);
41
- ws.addEventListener("open", ()=>{
42
- ws.send(JSON.stringify({
43
- type: "connect",
44
- id: connectId,
45
- client: {
46
- instanceId,
47
- clientType,
48
- version: "test"
49
- },
50
- timestamp: Date.now()
51
- }));
52
- });
53
- ws.addEventListener("message", (event)=>{
54
- const msg = JSON.parse(event.data);
55
- if ("res" === msg.type && msg.id === connectId && msg.ok) {
56
- clearTimeout(timeout);
57
- resolve(ws);
58
- }
59
- });
60
- ws.addEventListener("error", ()=>{
61
- clearTimeout(timeout);
62
- reject(new Error("WebSocket error"));
63
- });
64
- });
65
- const waitForMessage = (ws, predicate, timeoutMs = 5000)=>new Promise((resolve, reject)=>{
66
- const timeout = setTimeout(()=>reject(new Error("Message timeout")), timeoutMs);
67
- const handler = (event)=>{
68
- const data = event.data;
69
- if ("string" != typeof data) return;
70
- let msg;
71
- try {
72
- msg = JSON.parse(data);
73
- } catch {
74
- return;
75
- }
76
- if (!predicate(msg)) return;
77
- clearTimeout(timeout);
78
- ws.removeEventListener("message", handler);
79
- resolve(msg);
80
- };
81
- ws.addEventListener("message", handler);
82
- });
83
- it("blocks node registration before device enablement", async ()=>{
84
- const ws = await connectClient("desktop-node-blocked");
85
- ws.send(JSON.stringify({
86
- type: "register",
87
- payload: {
88
- name: "Blocked Node",
89
- capabilities: [
90
- "system.notify"
91
- ]
92
- },
93
- timestamp: Date.now()
94
- }));
95
- const errorMessage = await waitForMessage(ws, (msg)=>"error" === msg.type && msg.payload?.code === "NODE_NOT_ENABLED");
96
- expect(errorMessage.payload?.message).toContain("not approved");
97
- ws.close();
98
- });
99
- it("allows enabled devices to register, execute, and revoke", async ()=>{
100
- const enableResponse = await fetch(`http://localhost:${port}/api/nodes/${encodeURIComponent("desktop-node-enabled")}`, {
101
- method: "PUT",
102
- headers: {
103
- "Content-Type": "application/json"
104
- },
105
- body: JSON.stringify({
106
- enabled: true,
107
- name: "Enabled Desktop"
108
- })
109
- });
110
- expect(enableResponse.ok).toBe(true);
111
- const nodeWs = await connectClient("desktop-node-enabled");
112
- nodeWs.send(JSON.stringify({
113
- type: "register",
114
- payload: {
115
- name: "Enabled Desktop",
116
- capabilities: [
117
- "system.notify"
118
- ]
119
- },
120
- timestamp: Date.now()
121
- }));
122
- const registrationAck = await waitForMessage(nodeWs, (msg)=>"ack" === msg.type && "string" == typeof msg.payload?.nodeId);
123
- const nodeId = registrationAck.payload.nodeId;
124
- expect(nodeId).toBeTruthy();
125
- const requesterWs = await connectClient("desktop-requester");
126
- requesterWs.send(JSON.stringify({
127
- type: "req:node",
128
- id: "node-req-1",
129
- targetNodeId: nodeId,
130
- payload: {
131
- tool: "system.notify",
132
- args: {
133
- title: "Hello",
134
- body: "Node test"
135
- }
136
- },
137
- timestamp: Date.now()
138
- }));
139
- const forwardedToNode = await waitForMessage(nodeWs, (msg)=>"req:node" === msg.type && "node-req-1" === msg.id);
140
- expect(forwardedToNode.targetNodeId).toBe(nodeId);
141
- nodeWs.send(JSON.stringify({
142
- type: "res",
143
- id: "node-req-1",
144
- ok: true,
145
- payload: {
146
- delivered: true
147
- },
148
- timestamp: Date.now()
149
- }));
150
- const returnedToRequester = await waitForMessage(requesterWs, (msg)=>"res" === msg.type && "node-req-1" === msg.id);
151
- expect(returnedToRequester.ok).toBe(true);
152
- expect(returnedToRequester.nodeId).toBe(nodeId);
153
- const closePromise = new Promise((resolve)=>{
154
- nodeWs.addEventListener("close", ()=>{
155
- resolve();
156
- }, {
157
- once: true
158
- });
159
- });
160
- const revokeResponse = await fetch(`http://localhost:${port}/api/nodes/${encodeURIComponent("desktop-node-enabled")}`, {
161
- method: "DELETE"
162
- });
163
- expect(revokeResponse.ok).toBe(true);
164
- await closePromise;
165
- requesterWs.close();
166
- nodeWs.close();
167
- });
168
- });