@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 +0,0 @@
1
- export {};
@@ -1,108 +0,0 @@
1
- import { existsSync, mkdirSync, rmSync, writeFileSync } from "node:fs";
2
- import { tmpdir } from "node:os";
3
- import { join, resolve } from "node:path";
4
- import { afterEach, beforeEach, describe, expect, it } from "vitest";
5
- import { resolveWorkspaceRoot } from "../cli/core/workspace.js";
6
- describe("resolveWorkspaceRoot", ()=>{
7
- let sandbox;
8
- beforeEach(()=>{
9
- sandbox = join(tmpdir(), `wingman-workspace-${Date.now()}-${Math.random()}`);
10
- mkdirSync(sandbox, {
11
- recursive: true
12
- });
13
- });
14
- afterEach(()=>{
15
- if (existsSync(sandbox)) rmSync(sandbox, {
16
- recursive: true,
17
- force: true
18
- });
19
- });
20
- it("uses explicit workspace override when provided", ()=>{
21
- const startDir = join(sandbox, "repo", "apps", "wingman");
22
- mkdirSync(startDir, {
23
- recursive: true
24
- });
25
- const resolved = resolveWorkspaceRoot(startDir, "../..");
26
- expect(resolved).toBe(resolve(startDir, "../.."));
27
- });
28
- it("finds nearest ancestor with .wingman/wingman.config.json", ()=>{
29
- const workspaceRoot = join(sandbox, "repo");
30
- const nestedDir = join(workspaceRoot, "apps", "wingman", "src");
31
- mkdirSync(join(workspaceRoot, ".wingman"), {
32
- recursive: true
33
- });
34
- mkdirSync(nestedDir, {
35
- recursive: true
36
- });
37
- writeFileSync(join(workspaceRoot, ".wingman", "wingman.config.json"), JSON.stringify({
38
- logLevel: "info"
39
- }));
40
- const resolved = resolveWorkspaceRoot(nestedDir);
41
- expect(resolved).toBe(workspaceRoot);
42
- });
43
- it("finds nearest ancestor with .wingman/agents marker", ()=>{
44
- const workspaceRoot = join(sandbox, "repo");
45
- const nestedDir = join(workspaceRoot, "packages", "cli");
46
- mkdirSync(join(workspaceRoot, ".wingman", "agents"), {
47
- recursive: true
48
- });
49
- mkdirSync(nestedDir, {
50
- recursive: true
51
- });
52
- const resolved = resolveWorkspaceRoot(nestedDir);
53
- expect(resolved).toBe(workspaceRoot);
54
- });
55
- it("does not search above git root when workspace markers are missing", ()=>{
56
- const parentRoot = join(sandbox, "parent");
57
- const gitRoot = join(parentRoot, "repo");
58
- const nestedDir = join(gitRoot, "apps", "wingman");
59
- mkdirSync(join(parentRoot, ".wingman"), {
60
- recursive: true
61
- });
62
- mkdirSync(join(gitRoot, ".git"), {
63
- recursive: true
64
- });
65
- mkdirSync(nestedDir, {
66
- recursive: true
67
- });
68
- writeFileSync(join(parentRoot, ".wingman", "wingman.config.json"), JSON.stringify({
69
- logLevel: "info"
70
- }));
71
- const resolved = resolveWorkspaceRoot(nestedDir);
72
- expect(resolved).toBe(nestedDir);
73
- });
74
- it("falls back to nested apps/wingman workspace from repo root", ()=>{
75
- const repoRoot = join(sandbox, "repo");
76
- const nestedWorkspace = join(repoRoot, "apps", "wingman");
77
- mkdirSync(join(repoRoot, ".git"), {
78
- recursive: true
79
- });
80
- mkdirSync(join(nestedWorkspace, ".wingman"), {
81
- recursive: true
82
- });
83
- writeFileSync(join(nestedWorkspace, ".wingman", "wingman.config.json"), JSON.stringify({
84
- logLevel: "info"
85
- }));
86
- const resolved = resolveWorkspaceRoot(repoRoot);
87
- expect(resolved).toBe(nestedWorkspace);
88
- });
89
- it("falls back to nested apps/wingman workspace from sibling app directory", ()=>{
90
- const repoRoot = join(sandbox, "repo");
91
- const startDir = join(repoRoot, "apps", "docs-website");
92
- const nestedWorkspace = join(repoRoot, "apps", "wingman");
93
- mkdirSync(join(repoRoot, ".git"), {
94
- recursive: true
95
- });
96
- mkdirSync(startDir, {
97
- recursive: true
98
- });
99
- mkdirSync(join(nestedWorkspace, ".wingman"), {
100
- recursive: true
101
- });
102
- writeFileSync(join(nestedWorkspace, ".wingman", "wingman.config.json"), JSON.stringify({
103
- logLevel: "info"
104
- }));
105
- const resolved = resolveWorkspaceRoot(startDir);
106
- expect(resolved).toBe(nestedWorkspace);
107
- });
108
- });
@@ -1,94 +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
- (0, external_vitest_namespaceObject.describe)("codex credential precedence", ()=>{
8
- let homeDir;
9
- let codexHome;
10
- const originalHome = process.env.HOME;
11
- const originalCodexHome = process.env.CODEX_HOME;
12
- const originalCodexAccessToken = process.env.CODEX_ACCESS_TOKEN;
13
- const originalChatGptAccessToken = process.env.CHATGPT_ACCESS_TOKEN;
14
- (0, external_vitest_namespaceObject.beforeEach)(()=>{
15
- homeDir = (0, external_node_fs_namespaceObject.mkdtempSync)((0, external_node_path_namespaceObject.join)((0, external_node_os_namespaceObject.tmpdir)(), "wingman-home-"));
16
- codexHome = (0, external_node_fs_namespaceObject.mkdtempSync)((0, external_node_path_namespaceObject.join)((0, external_node_os_namespaceObject.tmpdir)(), "wingman-codex-home-"));
17
- process.env.HOME = homeDir;
18
- process.env.CODEX_HOME = codexHome;
19
- delete process.env.CODEX_ACCESS_TOKEN;
20
- delete process.env.CHATGPT_ACCESS_TOKEN;
21
- });
22
- (0, external_vitest_namespaceObject.afterEach)(()=>{
23
- if (void 0 === originalHome) delete process.env.HOME;
24
- else process.env.HOME = originalHome;
25
- if (void 0 === originalCodexHome) delete process.env.CODEX_HOME;
26
- else process.env.CODEX_HOME = originalCodexHome;
27
- if (void 0 === originalCodexAccessToken) delete process.env.CODEX_ACCESS_TOKEN;
28
- else process.env.CODEX_ACCESS_TOKEN = originalCodexAccessToken;
29
- if (void 0 === originalChatGptAccessToken) delete process.env.CHATGPT_ACCESS_TOKEN;
30
- else process.env.CHATGPT_ACCESS_TOKEN = originalChatGptAccessToken;
31
- if ((0, external_node_fs_namespaceObject.existsSync)(homeDir)) (0, external_node_fs_namespaceObject.rmSync)(homeDir, {
32
- recursive: true,
33
- force: true
34
- });
35
- if ((0, external_node_fs_namespaceObject.existsSync)(codexHome)) (0, external_node_fs_namespaceObject.rmSync)(codexHome, {
36
- recursive: true,
37
- force: true
38
- });
39
- });
40
- (0, external_vitest_namespaceObject.it)("prefers Codex auth file over stored Wingman credentials for codex", async ()=>{
41
- external_vitest_namespaceObject.vi.resetModules();
42
- const credentials = await import("../providers/credentials.cjs");
43
- const codex = await import("../providers/codex.cjs");
44
- const credsPath = credentials.getCredentialsPath();
45
- (0, external_node_fs_namespaceObject.mkdirSync)((0, external_node_path_namespaceObject.dirname)(credsPath), {
46
- recursive: true
47
- });
48
- (0, external_node_fs_namespaceObject.writeFileSync)(credsPath, JSON.stringify({
49
- version: 1,
50
- updatedAt: new Date().toISOString(),
51
- providers: {
52
- codex: {
53
- apiKey: "stale-wingman-token"
54
- }
55
- }
56
- }, null, 2));
57
- const authPath = codex.getCodexAuthPath();
58
- (0, external_node_fs_namespaceObject.mkdirSync)((0, external_node_path_namespaceObject.dirname)(authPath), {
59
- recursive: true
60
- });
61
- (0, external_node_fs_namespaceObject.writeFileSync)(authPath, JSON.stringify({
62
- tokens: {
63
- access_token: "codex-file-token",
64
- account_id: "acct_123"
65
- }
66
- }, null, 2));
67
- const resolved = credentials.resolveProviderToken("codex");
68
- (0, external_vitest_namespaceObject.expect)(resolved.token).toBe("codex-file-token");
69
- (0, external_vitest_namespaceObject.expect)(resolved.source).toBe("credentials");
70
- });
71
- (0, external_vitest_namespaceObject.it)("still prefers env vars over Codex auth file", async ()=>{
72
- process.env.CODEX_ACCESS_TOKEN = "env-token";
73
- external_vitest_namespaceObject.vi.resetModules();
74
- const credentials = await import("../providers/credentials.cjs");
75
- const codex = await import("../providers/codex.cjs");
76
- const authPath = codex.getCodexAuthPath();
77
- (0, external_node_fs_namespaceObject.mkdirSync)((0, external_node_path_namespaceObject.dirname)(authPath), {
78
- recursive: true
79
- });
80
- (0, external_node_fs_namespaceObject.writeFileSync)(authPath, JSON.stringify({
81
- tokens: {
82
- access_token: "codex-file-token"
83
- }
84
- }, null, 2));
85
- const resolved = credentials.resolveProviderToken("codex");
86
- (0, external_vitest_namespaceObject.expect)(resolved.token).toBe("env-token");
87
- (0, external_vitest_namespaceObject.expect)(resolved.source).toBe("env");
88
- (0, external_vitest_namespaceObject.expect)((0, external_node_fs_namespaceObject.readFileSync)(authPath, "utf-8")).toContain("codex-file-token");
89
- });
90
- });
91
- for(var __rspack_i in __webpack_exports__)exports[__rspack_i] = __webpack_exports__[__rspack_i];
92
- Object.defineProperty(exports, '__esModule', {
93
- value: true
94
- });
@@ -1 +0,0 @@
1
- export {};
@@ -1,88 +0,0 @@
1
- import { existsSync, mkdirSync, mkdtempSync, readFileSync, rmSync, writeFileSync } from "node:fs";
2
- import { tmpdir } from "node:os";
3
- import { dirname, join } from "node:path";
4
- import { afterEach, beforeEach, describe, expect, it, vi } from "vitest";
5
- describe("codex credential precedence", ()=>{
6
- let homeDir;
7
- let codexHome;
8
- const originalHome = process.env.HOME;
9
- const originalCodexHome = process.env.CODEX_HOME;
10
- const originalCodexAccessToken = process.env.CODEX_ACCESS_TOKEN;
11
- const originalChatGptAccessToken = process.env.CHATGPT_ACCESS_TOKEN;
12
- beforeEach(()=>{
13
- homeDir = mkdtempSync(join(tmpdir(), "wingman-home-"));
14
- codexHome = mkdtempSync(join(tmpdir(), "wingman-codex-home-"));
15
- process.env.HOME = homeDir;
16
- process.env.CODEX_HOME = codexHome;
17
- delete process.env.CODEX_ACCESS_TOKEN;
18
- delete process.env.CHATGPT_ACCESS_TOKEN;
19
- });
20
- afterEach(()=>{
21
- if (void 0 === originalHome) delete process.env.HOME;
22
- else process.env.HOME = originalHome;
23
- if (void 0 === originalCodexHome) delete process.env.CODEX_HOME;
24
- else process.env.CODEX_HOME = originalCodexHome;
25
- if (void 0 === originalCodexAccessToken) delete process.env.CODEX_ACCESS_TOKEN;
26
- else process.env.CODEX_ACCESS_TOKEN = originalCodexAccessToken;
27
- if (void 0 === originalChatGptAccessToken) delete process.env.CHATGPT_ACCESS_TOKEN;
28
- else process.env.CHATGPT_ACCESS_TOKEN = originalChatGptAccessToken;
29
- if (existsSync(homeDir)) rmSync(homeDir, {
30
- recursive: true,
31
- force: true
32
- });
33
- if (existsSync(codexHome)) rmSync(codexHome, {
34
- recursive: true,
35
- force: true
36
- });
37
- });
38
- it("prefers Codex auth file over stored Wingman credentials for codex", async ()=>{
39
- vi.resetModules();
40
- const credentials = await import("../providers/credentials.js");
41
- const codex = await import("../providers/codex.js");
42
- const credsPath = credentials.getCredentialsPath();
43
- mkdirSync(dirname(credsPath), {
44
- recursive: true
45
- });
46
- writeFileSync(credsPath, JSON.stringify({
47
- version: 1,
48
- updatedAt: new Date().toISOString(),
49
- providers: {
50
- codex: {
51
- apiKey: "stale-wingman-token"
52
- }
53
- }
54
- }, null, 2));
55
- const authPath = codex.getCodexAuthPath();
56
- mkdirSync(dirname(authPath), {
57
- recursive: true
58
- });
59
- writeFileSync(authPath, JSON.stringify({
60
- tokens: {
61
- access_token: "codex-file-token",
62
- account_id: "acct_123"
63
- }
64
- }, null, 2));
65
- const resolved = credentials.resolveProviderToken("codex");
66
- expect(resolved.token).toBe("codex-file-token");
67
- expect(resolved.source).toBe("credentials");
68
- });
69
- it("still prefers env vars over Codex auth file", async ()=>{
70
- process.env.CODEX_ACCESS_TOKEN = "env-token";
71
- vi.resetModules();
72
- const credentials = await import("../providers/credentials.js");
73
- const codex = await import("../providers/codex.js");
74
- const authPath = codex.getCodexAuthPath();
75
- mkdirSync(dirname(authPath), {
76
- recursive: true
77
- });
78
- writeFileSync(authPath, JSON.stringify({
79
- tokens: {
80
- access_token: "codex-file-token"
81
- }
82
- }, null, 2));
83
- const resolved = credentials.resolveProviderToken("codex");
84
- expect(resolved.token).toBe("env-token");
85
- expect(resolved.source).toBe("env");
86
- expect(readFileSync(authPath, "utf-8")).toContain("codex-file-token");
87
- });
88
- });
@@ -1,383 +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 codex_cjs_namespaceObject = require("../providers/codex.cjs");
8
- (0, external_vitest_namespaceObject.describe)("codex provider", ()=>{
9
- let codexHome;
10
- const originalCodexHome = process.env.CODEX_HOME;
11
- (0, external_vitest_namespaceObject.beforeEach)(()=>{
12
- codexHome = (0, external_node_fs_namespaceObject.mkdtempSync)((0, external_node_path_namespaceObject.join)((0, external_node_os_namespaceObject.tmpdir)(), "wingman-codex-"));
13
- process.env.CODEX_HOME = codexHome;
14
- delete process.env.CODEX_ACCESS_TOKEN;
15
- delete process.env.CHATGPT_ACCESS_TOKEN;
16
- });
17
- (0, external_vitest_namespaceObject.afterEach)(()=>{
18
- if (void 0 === originalCodexHome) delete process.env.CODEX_HOME;
19
- else process.env.CODEX_HOME = originalCodexHome;
20
- if ((0, external_node_fs_namespaceObject.existsSync)(codexHome)) (0, external_node_fs_namespaceObject.rmSync)(codexHome, {
21
- recursive: true,
22
- force: true
23
- });
24
- });
25
- (0, external_vitest_namespaceObject.it)("reads access token and account id from codex auth file", ()=>{
26
- writeCodexAuth({
27
- tokens: {
28
- access_token: "codex-access-token",
29
- account_id: "acct_123"
30
- }
31
- });
32
- const resolved = (0, codex_cjs_namespaceObject.resolveCodexAuthFromFile)();
33
- (0, external_vitest_namespaceObject.expect)(resolved.accessToken).toBe("codex-access-token");
34
- (0, external_vitest_namespaceObject.expect)(resolved.accountId).toBe("acct_123");
35
- (0, external_vitest_namespaceObject.expect)(resolved.authPath).toBe((0, external_node_path_namespaceObject.join)(codexHome, "auth.json"));
36
- });
37
- (0, external_vitest_namespaceObject.it)("applies codex auth headers and forces store=false", async ()=>{
38
- writeCodexAuth({
39
- tokens: {
40
- access_token: "file-token",
41
- account_id: "acct_file"
42
- }
43
- });
44
- const baseFetch = external_vitest_namespaceObject.vi.fn(async (_input, _init)=>new Response("{}", {
45
- status: 200
46
- }));
47
- const codexFetch = (0, codex_cjs_namespaceObject.createCodexFetch)({
48
- baseFetch
49
- });
50
- await codexFetch("https://chatgpt.com/backend-api/codex/responses", {
51
- method: "POST",
52
- headers: {
53
- "x-api-key": "placeholder"
54
- },
55
- body: JSON.stringify({
56
- model: "codex-mini-latest",
57
- input: "hello",
58
- temperature: 1
59
- })
60
- });
61
- (0, external_vitest_namespaceObject.expect)(baseFetch).toHaveBeenCalledTimes(1);
62
- const requestInit = baseFetch.mock.calls[0]?.[1];
63
- (0, external_vitest_namespaceObject.expect)(requestInit).toBeDefined();
64
- const headers = new Headers(requestInit?.headers);
65
- const payload = JSON.parse(String(requestInit?.body));
66
- (0, external_vitest_namespaceObject.expect)(headers.get("authorization")).toBe("Bearer file-token");
67
- (0, external_vitest_namespaceObject.expect)(headers.get("chatgpt-account-id")).toBe("acct_file");
68
- (0, external_vitest_namespaceObject.expect)(headers.get("x-api-key")).toBeNull();
69
- (0, external_vitest_namespaceObject.expect)(payload.store).toBe(false);
70
- (0, external_vitest_namespaceObject.expect)(payload.temperature).toBeUndefined();
71
- (0, external_vitest_namespaceObject.expect)(typeof payload.instructions).toBe("string");
72
- (0, external_vitest_namespaceObject.expect)(payload.instructions.length).toBeGreaterThan(0);
73
- });
74
- (0, external_vitest_namespaceObject.it)("derives instructions from system/developer input when missing", async ()=>{
75
- writeCodexAuth({
76
- tokens: {
77
- access_token: "file-token"
78
- }
79
- });
80
- const baseFetch = external_vitest_namespaceObject.vi.fn(async (_input, _init)=>new Response("{}", {
81
- status: 200
82
- }));
83
- const codexFetch = (0, codex_cjs_namespaceObject.createCodexFetch)({
84
- baseFetch
85
- });
86
- await codexFetch("https://chatgpt.com/backend-api/codex/responses", {
87
- method: "POST",
88
- body: JSON.stringify({
89
- model: "gpt-5.3-codex",
90
- input: [
91
- {
92
- role: "developer",
93
- content: [
94
- {
95
- type: "input_text",
96
- text: "Always run tests first."
97
- }
98
- ]
99
- },
100
- {
101
- role: "user",
102
- content: [
103
- {
104
- type: "input_text",
105
- text: "Fix the bug."
106
- }
107
- ]
108
- }
109
- ]
110
- })
111
- });
112
- const requestInit = baseFetch.mock.calls[0]?.[1];
113
- const payload = JSON.parse(String(requestInit?.body));
114
- (0, external_vitest_namespaceObject.expect)(payload.instructions).toBe("Always run tests first.");
115
- });
116
- (0, external_vitest_namespaceObject.it)("preserves explicit instructions when provided", async ()=>{
117
- writeCodexAuth({
118
- tokens: {
119
- access_token: "file-token"
120
- }
121
- });
122
- const baseFetch = external_vitest_namespaceObject.vi.fn(async (_input, _init)=>new Response("{}", {
123
- status: 200
124
- }));
125
- const codexFetch = (0, codex_cjs_namespaceObject.createCodexFetch)({
126
- baseFetch
127
- });
128
- await codexFetch("https://chatgpt.com/backend-api/codex/responses", {
129
- method: "POST",
130
- body: JSON.stringify({
131
- model: "gpt-5.3-codex",
132
- instructions: "Use concise answers.",
133
- input: "hello"
134
- })
135
- });
136
- const requestInit = baseFetch.mock.calls[0]?.[1];
137
- const payload = JSON.parse(String(requestInit?.body));
138
- (0, external_vitest_namespaceObject.expect)(payload.instructions).toBe("Use concise answers.");
139
- });
140
- (0, external_vitest_namespaceObject.it)("overrides explicit store values to false when provided", async ()=>{
141
- writeCodexAuth({
142
- tokens: {
143
- access_token: "file-token"
144
- }
145
- });
146
- const baseFetch = external_vitest_namespaceObject.vi.fn(async (_input, _init)=>new Response("{}", {
147
- status: 200
148
- }));
149
- const codexFetch = (0, codex_cjs_namespaceObject.createCodexFetch)({
150
- baseFetch
151
- });
152
- await codexFetch("https://chatgpt.com/backend-api/codex/responses", {
153
- method: "POST",
154
- body: JSON.stringify({
155
- model: "gpt-5.3-codex",
156
- store: true,
157
- input: "hello"
158
- })
159
- });
160
- const requestInit = baseFetch.mock.calls[0]?.[1];
161
- const payload = JSON.parse(String(requestInit?.body));
162
- (0, external_vitest_namespaceObject.expect)(payload.store).toBe(false);
163
- });
164
- (0, external_vitest_namespaceObject.it)("refreshes tokens when the codex access token is expiring", async ()=>{
165
- const expiringAccessToken = createJwt({
166
- exp: Math.floor((Date.now() + 30000) / 1000),
167
- client_id: "app_client_123"
168
- });
169
- const refreshedAccessToken = createJwt({
170
- exp: Math.floor((Date.now() + 86400000) / 1000),
171
- client_id: "app_client_123"
172
- });
173
- const staleIdToken = createJwt({
174
- aud: [
175
- "app_client_123"
176
- ],
177
- "https://api.openai.com/auth": {
178
- chatgpt_account_id: "acct_old"
179
- }
180
- });
181
- const refreshedIdToken = createJwt({
182
- aud: [
183
- "app_client_123"
184
- ],
185
- "https://api.openai.com/auth": {
186
- chatgpt_account_id: "acct_refreshed"
187
- }
188
- });
189
- writeCodexAuth({
190
- tokens: {
191
- access_token: expiringAccessToken,
192
- refresh_token: "refresh-old",
193
- id_token: staleIdToken,
194
- account_id: "acct_old"
195
- }
196
- });
197
- const baseFetch = external_vitest_namespaceObject.vi.fn(async (input, init)=>{
198
- const url = "string" == typeof input ? input : input instanceof URL ? input.toString() : input.url;
199
- if ("https://auth.openai.com/oauth/token" === url) {
200
- const params = new URLSearchParams(String(init?.body ?? ""));
201
- (0, external_vitest_namespaceObject.expect)(params.get("grant_type")).toBe("refresh_token");
202
- (0, external_vitest_namespaceObject.expect)(params.get("refresh_token")).toBe("refresh-old");
203
- (0, external_vitest_namespaceObject.expect)(params.get("client_id")).toBe("app_client_123");
204
- return new Response(JSON.stringify({
205
- access_token: refreshedAccessToken,
206
- refresh_token: "refresh-new",
207
- id_token: refreshedIdToken,
208
- token_type: "bearer",
209
- expires_in: 864000
210
- }), {
211
- status: 200,
212
- headers: {
213
- "content-type": "application/json"
214
- }
215
- });
216
- }
217
- (0, external_vitest_namespaceObject.expect)(url).toBe("https://chatgpt.com/backend-api/codex/responses");
218
- const headers = new Headers(init?.headers);
219
- (0, external_vitest_namespaceObject.expect)(headers.get("authorization")).toBe(`Bearer ${refreshedAccessToken}`);
220
- (0, external_vitest_namespaceObject.expect)(headers.get("chatgpt-account-id")).toBe("acct_refreshed");
221
- return new Response("{}", {
222
- status: 200
223
- });
224
- });
225
- const codexFetch = (0, codex_cjs_namespaceObject.createCodexFetch)({
226
- baseFetch
227
- });
228
- await codexFetch("https://chatgpt.com/backend-api/codex/responses", {
229
- method: "POST",
230
- body: JSON.stringify({
231
- model: "codex-mini-latest",
232
- input: "hello"
233
- })
234
- });
235
- (0, external_vitest_namespaceObject.expect)(baseFetch).toHaveBeenCalledTimes(2);
236
- const persisted = JSON.parse((0, external_node_fs_namespaceObject.readFileSync)((0, codex_cjs_namespaceObject.getCodexAuthPath)(), "utf-8"));
237
- (0, external_vitest_namespaceObject.expect)(persisted.tokens?.access_token).toBe(refreshedAccessToken);
238
- (0, external_vitest_namespaceObject.expect)(persisted.tokens?.refresh_token).toBe("refresh-new");
239
- (0, external_vitest_namespaceObject.expect)(persisted.tokens?.id_token).toBe(refreshedIdToken);
240
- (0, external_vitest_namespaceObject.expect)(persisted.tokens?.account_id).toBe("acct_refreshed");
241
- (0, external_vitest_namespaceObject.expect)(typeof persisted.last_refresh).toBe("string");
242
- });
243
- (0, external_vitest_namespaceObject.it)("retries once after auth failure by refreshing codex token", async ()=>{
244
- const initialAccessToken = createJwt({
245
- exp: Math.floor((Date.now() + 86400000) / 1000),
246
- client_id: "app_client_retry"
247
- });
248
- const refreshedAccessToken = createJwt({
249
- exp: Math.floor((Date.now() + 172800000) / 1000),
250
- client_id: "app_client_retry"
251
- });
252
- const idToken = createJwt({
253
- aud: [
254
- "app_client_retry"
255
- ],
256
- "https://api.openai.com/auth": {
257
- chatgpt_account_id: "acct_retry"
258
- }
259
- });
260
- const refreshedIdToken = createJwt({
261
- aud: [
262
- "app_client_retry"
263
- ],
264
- "https://api.openai.com/auth": {
265
- chatgpt_account_id: "acct_retry_new"
266
- }
267
- });
268
- writeCodexAuth({
269
- tokens: {
270
- access_token: initialAccessToken,
271
- refresh_token: "refresh-retry",
272
- id_token: idToken,
273
- account_id: "acct_retry"
274
- }
275
- });
276
- let codexCallCount = 0;
277
- const baseFetch = external_vitest_namespaceObject.vi.fn(async (input, init)=>{
278
- const url = "string" == typeof input ? input : input instanceof URL ? input.toString() : input.url;
279
- if ("https://auth.openai.com/oauth/token" === url) {
280
- const params = new URLSearchParams(String(init?.body ?? ""));
281
- (0, external_vitest_namespaceObject.expect)(params.get("grant_type")).toBe("refresh_token");
282
- (0, external_vitest_namespaceObject.expect)(params.get("refresh_token")).toBe("refresh-retry");
283
- (0, external_vitest_namespaceObject.expect)(params.get("client_id")).toBe("app_client_retry");
284
- return new Response(JSON.stringify({
285
- access_token: refreshedAccessToken,
286
- refresh_token: "refresh-retry-new",
287
- id_token: refreshedIdToken,
288
- token_type: "bearer",
289
- expires_in: 864000
290
- }), {
291
- status: 200,
292
- headers: {
293
- "content-type": "application/json"
294
- }
295
- });
296
- }
297
- codexCallCount += 1;
298
- const headers = new Headers(init?.headers);
299
- if (1 === codexCallCount) {
300
- (0, external_vitest_namespaceObject.expect)(headers.get("authorization")).toBe(`Bearer ${initialAccessToken}`);
301
- return new Response("unauthorized", {
302
- status: 401
303
- });
304
- }
305
- (0, external_vitest_namespaceObject.expect)(codexCallCount).toBe(2);
306
- (0, external_vitest_namespaceObject.expect)(headers.get("authorization")).toBe(`Bearer ${refreshedAccessToken}`);
307
- (0, external_vitest_namespaceObject.expect)(headers.get("chatgpt-account-id")).toBe("acct_retry_new");
308
- return new Response("{}", {
309
- status: 200
310
- });
311
- });
312
- const codexFetch = (0, codex_cjs_namespaceObject.createCodexFetch)({
313
- baseFetch
314
- });
315
- await codexFetch("https://chatgpt.com/backend-api/codex/responses", {
316
- method: "POST",
317
- body: JSON.stringify({
318
- model: "codex-mini-latest",
319
- input: "hello"
320
- })
321
- });
322
- (0, external_vitest_namespaceObject.expect)(codexCallCount).toBe(2);
323
- (0, external_vitest_namespaceObject.expect)(baseFetch).toHaveBeenCalledTimes(3);
324
- const persisted = JSON.parse((0, external_node_fs_namespaceObject.readFileSync)((0, codex_cjs_namespaceObject.getCodexAuthPath)(), "utf-8"));
325
- (0, external_vitest_namespaceObject.expect)(persisted.tokens?.access_token).toBe(refreshedAccessToken);
326
- (0, external_vitest_namespaceObject.expect)(persisted.tokens?.refresh_token).toBe("refresh-retry-new");
327
- (0, external_vitest_namespaceObject.expect)(persisted.tokens?.account_id).toBe("acct_retry_new");
328
- });
329
- (0, external_vitest_namespaceObject.it)("uses fallback token when codex auth file is unavailable", async ()=>{
330
- const baseFetch = external_vitest_namespaceObject.vi.fn(async (_input, _init)=>new Response("{}", {
331
- status: 200
332
- }));
333
- const codexFetch = (0, codex_cjs_namespaceObject.createCodexFetch)({
334
- baseFetch,
335
- fallbackToken: "fallback-token"
336
- });
337
- await codexFetch("https://chatgpt.com/backend-api/codex/responses", {
338
- method: "POST",
339
- body: JSON.stringify({
340
- model: "codex-mini-latest",
341
- input: "hello"
342
- })
343
- });
344
- const requestInit = baseFetch.mock.calls[0]?.[1];
345
- (0, external_vitest_namespaceObject.expect)(requestInit).toBeDefined();
346
- const headers = new Headers(requestInit?.headers);
347
- (0, external_vitest_namespaceObject.expect)(headers.get("authorization")).toBe("Bearer fallback-token");
348
- });
349
- (0, external_vitest_namespaceObject.it)("throws when no codex token is available", async ()=>{
350
- const baseFetch = external_vitest_namespaceObject.vi.fn(async (_input, _init)=>new Response("{}", {
351
- status: 200
352
- }));
353
- const codexFetch = (0, codex_cjs_namespaceObject.createCodexFetch)({
354
- baseFetch
355
- });
356
- await (0, external_vitest_namespaceObject.expect)(codexFetch("https://chatgpt.com/backend-api/codex/responses", {
357
- method: "POST",
358
- body: JSON.stringify({
359
- model: "codex-mini-latest",
360
- input: "hello"
361
- })
362
- })).rejects.toThrow(/Codex credentials missing/);
363
- });
364
- });
365
- function writeCodexAuth(payload) {
366
- const authPath = (0, codex_cjs_namespaceObject.getCodexAuthPath)();
367
- (0, external_node_fs_namespaceObject.mkdirSync)((0, external_node_path_namespaceObject.dirname)(authPath), {
368
- recursive: true
369
- });
370
- (0, external_node_fs_namespaceObject.writeFileSync)(authPath, JSON.stringify(payload, null, 2));
371
- }
372
- function createJwt(payload) {
373
- const header = Buffer.from(JSON.stringify({
374
- alg: "HS256",
375
- typ: "JWT"
376
- })).toString("base64url");
377
- const body = Buffer.from(JSON.stringify(payload)).toString("base64url");
378
- return `${header}.${body}.signature`;
379
- }
380
- for(var __rspack_i in __webpack_exports__)exports[__rspack_i] = __webpack_exports__[__rspack_i];
381
- Object.defineProperty(exports, '__esModule', {
382
- value: true
383
- });