@wingman-ai/gateway 0.1.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 (418) hide show
  1. package/.wingman/agents/README.md +161 -0
  2. package/.wingman/agents/coding/agent.md +147 -0
  3. package/.wingman/agents/coding/implementor.md +56 -0
  4. package/.wingman/agents/main/agent.md +19 -0
  5. package/.wingman/agents/researcher/agent.md +62 -0
  6. package/.wingman/agents/stock-trader/agent.md +223 -0
  7. package/.wingman/agents/stock-trader/chain-curator.md +24 -0
  8. package/.wingman/agents/stock-trader/goal-translator.md +42 -0
  9. package/.wingman/agents/stock-trader/guardrails-veto.md +11 -0
  10. package/.wingman/agents/stock-trader/path-planner.md +23 -0
  11. package/.wingman/agents/stock-trader/regime-analyst.md +15 -0
  12. package/.wingman/agents/stock-trader/risk.md +20 -0
  13. package/.wingman/agents/stock-trader/selection.md +22 -0
  14. package/.wingman/agents/stock-trader/strategy-composer.md +38 -0
  15. package/.wingman/agents/wingman/agent.json +12 -0
  16. package/bin/wingman +7 -0
  17. package/dist/agent/config/agentConfig.cjs +95 -0
  18. package/dist/agent/config/agentConfig.d.ts +187 -0
  19. package/dist/agent/config/agentConfig.js +52 -0
  20. package/dist/agent/config/agentLoader.cjs +242 -0
  21. package/dist/agent/config/agentLoader.d.ts +42 -0
  22. package/dist/agent/config/agentLoader.js +208 -0
  23. package/dist/agent/config/mcpClientManager.cjs +168 -0
  24. package/dist/agent/config/mcpClientManager.d.ts +41 -0
  25. package/dist/agent/config/mcpClientManager.js +134 -0
  26. package/dist/agent/config/modelFactory.cjs +175 -0
  27. package/dist/agent/config/modelFactory.d.ts +33 -0
  28. package/dist/agent/config/modelFactory.js +141 -0
  29. package/dist/agent/config/toolRegistry.cjs +111 -0
  30. package/dist/agent/config/toolRegistry.d.ts +25 -0
  31. package/dist/agent/config/toolRegistry.js +71 -0
  32. package/dist/agent/middleware/additional-messages.cjs +60 -0
  33. package/dist/agent/middleware/additional-messages.d.ts +7 -0
  34. package/dist/agent/middleware/additional-messages.js +26 -0
  35. package/dist/agent/middleware/hooks/executor.cjs +137 -0
  36. package/dist/agent/middleware/hooks/executor.d.ts +52 -0
  37. package/dist/agent/middleware/hooks/executor.js +103 -0
  38. package/dist/agent/middleware/hooks/input-builder.cjs +55 -0
  39. package/dist/agent/middleware/hooks/input-builder.d.ts +15 -0
  40. package/dist/agent/middleware/hooks/input-builder.js +21 -0
  41. package/dist/agent/middleware/hooks/matcher.cjs +59 -0
  42. package/dist/agent/middleware/hooks/matcher.d.ts +27 -0
  43. package/dist/agent/middleware/hooks/matcher.js +22 -0
  44. package/dist/agent/middleware/hooks/merger.cjs +54 -0
  45. package/dist/agent/middleware/hooks/merger.d.ts +18 -0
  46. package/dist/agent/middleware/hooks/merger.js +20 -0
  47. package/dist/agent/middleware/hooks/types.cjs +62 -0
  48. package/dist/agent/middleware/hooks/types.d.ts +82 -0
  49. package/dist/agent/middleware/hooks/types.js +19 -0
  50. package/dist/agent/middleware/hooks.cjs +79 -0
  51. package/dist/agent/middleware/hooks.d.ts +19 -0
  52. package/dist/agent/middleware/hooks.js +45 -0
  53. package/dist/agent/middleware/media-compat.cjs +80 -0
  54. package/dist/agent/middleware/media-compat.d.ts +7 -0
  55. package/dist/agent/middleware/media-compat.js +46 -0
  56. package/dist/agent/tests/agentConfig.test.cjs +132 -0
  57. package/dist/agent/tests/agentConfig.test.d.ts +1 -0
  58. package/dist/agent/tests/agentConfig.test.js +126 -0
  59. package/dist/agent/tests/agentLoader.test.cjs +235 -0
  60. package/dist/agent/tests/agentLoader.test.d.ts +1 -0
  61. package/dist/agent/tests/agentLoader.test.js +229 -0
  62. package/dist/agent/tests/modelFactory.test.cjs +114 -0
  63. package/dist/agent/tests/modelFactory.test.d.ts +1 -0
  64. package/dist/agent/tests/modelFactory.test.js +108 -0
  65. package/dist/agent/tests/test-agent-loader.cjs +33 -0
  66. package/dist/agent/tests/test-agent-loader.d.ts +1 -0
  67. package/dist/agent/tests/test-agent-loader.js +27 -0
  68. package/dist/agent/tests/test-subagent-loading.cjs +99 -0
  69. package/dist/agent/tests/test-subagent-loading.d.ts +1 -0
  70. package/dist/agent/tests/test-subagent-loading.js +93 -0
  71. package/dist/agent/tests/toolRegistry.test.cjs +109 -0
  72. package/dist/agent/tests/toolRegistry.test.d.ts +1 -0
  73. package/dist/agent/tests/toolRegistry.test.js +103 -0
  74. package/dist/agent/tools/code_search.cjs +108 -0
  75. package/dist/agent/tools/code_search.d.ts +24 -0
  76. package/dist/agent/tools/code_search.js +74 -0
  77. package/dist/agent/tools/command_execute.cjs +136 -0
  78. package/dist/agent/tools/command_execute.d.ts +12 -0
  79. package/dist/agent/tools/command_execute.js +99 -0
  80. package/dist/agent/tools/git_status.cjs +126 -0
  81. package/dist/agent/tools/git_status.d.ts +15 -0
  82. package/dist/agent/tools/git_status.js +92 -0
  83. package/dist/agent/tools/internet_search.cjs +93 -0
  84. package/dist/agent/tools/internet_search.d.ts +25 -0
  85. package/dist/agent/tools/internet_search.js +56 -0
  86. package/dist/agent/tools/think.cjs +53 -0
  87. package/dist/agent/tools/think.d.ts +26 -0
  88. package/dist/agent/tools/think.js +16 -0
  89. package/dist/agent/tools/web_crawler.cjs +180 -0
  90. package/dist/agent/tools/web_crawler.d.ts +31 -0
  91. package/dist/agent/tools/web_crawler.js +143 -0
  92. package/dist/agent/utils.cjs +54 -0
  93. package/dist/agent/utils.d.ts +1 -0
  94. package/dist/agent/utils.js +10 -0
  95. package/dist/cli/commands/agent.cjs +169 -0
  96. package/dist/cli/commands/agent.d.ts +15 -0
  97. package/dist/cli/commands/agent.js +125 -0
  98. package/dist/cli/commands/gateway.cjs +601 -0
  99. package/dist/cli/commands/gateway.d.ts +12 -0
  100. package/dist/cli/commands/gateway.js +567 -0
  101. package/dist/cli/commands/init.cjs +681 -0
  102. package/dist/cli/commands/init.d.ts +10 -0
  103. package/dist/cli/commands/init.js +634 -0
  104. package/dist/cli/commands/provider.cjs +208 -0
  105. package/dist/cli/commands/provider.d.ts +5 -0
  106. package/dist/cli/commands/provider.js +174 -0
  107. package/dist/cli/commands/skill.cjs +145 -0
  108. package/dist/cli/commands/skill.d.ts +10 -0
  109. package/dist/cli/commands/skill.js +111 -0
  110. package/dist/cli/config/loader.cjs +143 -0
  111. package/dist/cli/config/loader.d.ts +14 -0
  112. package/dist/cli/config/loader.js +109 -0
  113. package/dist/cli/config/schema.cjs +262 -0
  114. package/dist/cli/config/schema.d.ts +268 -0
  115. package/dist/cli/config/schema.js +213 -0
  116. package/dist/cli/core/agentInvoker.cjs +284 -0
  117. package/dist/cli/core/agentInvoker.d.ts +77 -0
  118. package/dist/cli/core/agentInvoker.js +247 -0
  119. package/dist/cli/core/commandHandler.cjs +257 -0
  120. package/dist/cli/core/commandHandler.d.ts +62 -0
  121. package/dist/cli/core/commandHandler.js +223 -0
  122. package/dist/cli/core/database/bunSqliteAdapter.cjs +87 -0
  123. package/dist/cli/core/database/bunSqliteAdapter.d.ts +34 -0
  124. package/dist/cli/core/database/bunSqliteAdapter.js +53 -0
  125. package/dist/cli/core/loggerBridge.cjs +42 -0
  126. package/dist/cli/core/loggerBridge.d.ts +8 -0
  127. package/dist/cli/core/loggerBridge.js +8 -0
  128. package/dist/cli/core/outputManager.cjs +106 -0
  129. package/dist/cli/core/outputManager.d.ts +43 -0
  130. package/dist/cli/core/outputManager.js +72 -0
  131. package/dist/cli/core/sessionManager.cjs +535 -0
  132. package/dist/cli/core/sessionManager.d.ts +111 -0
  133. package/dist/cli/core/sessionManager.js +486 -0
  134. package/dist/cli/core/streamParser.cjs +328 -0
  135. package/dist/cli/core/streamParser.d.ts +42 -0
  136. package/dist/cli/core/streamParser.js +288 -0
  137. package/dist/cli/index.cjs +211 -0
  138. package/dist/cli/index.d.ts +2 -0
  139. package/dist/cli/index.js +205 -0
  140. package/dist/cli/services/skillRepository.cjs +178 -0
  141. package/dist/cli/services/skillRepository.d.ts +35 -0
  142. package/dist/cli/services/skillRepository.js +144 -0
  143. package/dist/cli/services/skillService.cjs +336 -0
  144. package/dist/cli/services/skillService.d.ts +48 -0
  145. package/dist/cli/services/skillService.js +302 -0
  146. package/dist/cli/types/gateway.cjs +18 -0
  147. package/dist/cli/types/gateway.d.ts +18 -0
  148. package/dist/cli/types/gateway.js +0 -0
  149. package/dist/cli/types/init.cjs +18 -0
  150. package/dist/cli/types/init.d.ts +13 -0
  151. package/dist/cli/types/init.js +0 -0
  152. package/dist/cli/types/provider.cjs +18 -0
  153. package/dist/cli/types/provider.d.ts +9 -0
  154. package/dist/cli/types/provider.js +0 -0
  155. package/dist/cli/types/skill.cjs +18 -0
  156. package/dist/cli/types/skill.d.ts +71 -0
  157. package/dist/cli/types/skill.js +0 -0
  158. package/dist/cli/types.cjs +18 -0
  159. package/dist/cli/types.d.ts +175 -0
  160. package/dist/cli/types.js +0 -0
  161. package/dist/cli/ui/AgentOutput.cjs +82 -0
  162. package/dist/cli/ui/AgentOutput.d.ts +8 -0
  163. package/dist/cli/ui/AgentOutput.js +38 -0
  164. package/dist/cli/ui/App.cjs +285 -0
  165. package/dist/cli/ui/App.d.ts +6 -0
  166. package/dist/cli/ui/App.js +241 -0
  167. package/dist/cli/ui/ErrorDisplay.cjs +65 -0
  168. package/dist/cli/ui/ErrorDisplay.d.ts +8 -0
  169. package/dist/cli/ui/ErrorDisplay.js +21 -0
  170. package/dist/cli/ui/LogDisplay.cjs +74 -0
  171. package/dist/cli/ui/LogDisplay.d.ts +13 -0
  172. package/dist/cli/ui/LogDisplay.js +30 -0
  173. package/dist/cli/ui/SessionListDisplay.cjs +135 -0
  174. package/dist/cli/ui/SessionListDisplay.d.ts +9 -0
  175. package/dist/cli/ui/SessionListDisplay.js +91 -0
  176. package/dist/cli/ui/blockHelpers.cjs +80 -0
  177. package/dist/cli/ui/blockHelpers.d.ts +21 -0
  178. package/dist/cli/ui/blockHelpers.js +40 -0
  179. package/dist/cli/ui/components/ToolCallDisplay.cjs +207 -0
  180. package/dist/cli/ui/components/ToolCallDisplay.d.ts +7 -0
  181. package/dist/cli/ui/components/ToolCallDisplay.js +162 -0
  182. package/dist/cli/ui/components/ToolResultDisplay.cjs +86 -0
  183. package/dist/cli/ui/components/ToolResultDisplay.d.ts +8 -0
  184. package/dist/cli/ui/components/ToolResultDisplay.js +42 -0
  185. package/dist/cli/ui/toolDisplayHelpers.cjs +112 -0
  186. package/dist/cli/ui/toolDisplayHelpers.d.ts +3 -0
  187. package/dist/cli/ui/toolDisplayHelpers.js +72 -0
  188. package/dist/gateway/adapters/discord.cjs +298 -0
  189. package/dist/gateway/adapters/discord.d.ts +42 -0
  190. package/dist/gateway/adapters/discord.js +246 -0
  191. package/dist/gateway/auth.cjs +94 -0
  192. package/dist/gateway/auth.d.ts +36 -0
  193. package/dist/gateway/auth.js +60 -0
  194. package/dist/gateway/broadcast.cjs +131 -0
  195. package/dist/gateway/broadcast.d.ts +76 -0
  196. package/dist/gateway/broadcast.js +97 -0
  197. package/dist/gateway/client.cjs +282 -0
  198. package/dist/gateway/client.d.ts +141 -0
  199. package/dist/gateway/client.js +248 -0
  200. package/dist/gateway/daemon.cjs +195 -0
  201. package/dist/gateway/daemon.d.ts +67 -0
  202. package/dist/gateway/daemon.js +161 -0
  203. package/dist/gateway/discovery/index.cjs +72 -0
  204. package/dist/gateway/discovery/index.d.ts +3 -0
  205. package/dist/gateway/discovery/index.js +3 -0
  206. package/dist/gateway/discovery/mdns.cjs +221 -0
  207. package/dist/gateway/discovery/mdns.d.ts +37 -0
  208. package/dist/gateway/discovery/mdns.js +177 -0
  209. package/dist/gateway/discovery/tailscale.cjs +140 -0
  210. package/dist/gateway/discovery/tailscale.d.ts +31 -0
  211. package/dist/gateway/discovery/tailscale.js +106 -0
  212. package/dist/gateway/discovery/types.cjs +18 -0
  213. package/dist/gateway/discovery/types.d.ts +41 -0
  214. package/dist/gateway/discovery/types.js +0 -0
  215. package/dist/gateway/env.cjs +45 -0
  216. package/dist/gateway/env.d.ts +2 -0
  217. package/dist/gateway/env.js +8 -0
  218. package/dist/gateway/hooks/loader.cjs +137 -0
  219. package/dist/gateway/hooks/loader.d.ts +10 -0
  220. package/dist/gateway/hooks/loader.js +103 -0
  221. package/dist/gateway/hooks/registry.cjs +128 -0
  222. package/dist/gateway/hooks/registry.d.ts +13 -0
  223. package/dist/gateway/hooks/registry.js +94 -0
  224. package/dist/gateway/hooks/types.cjs +58 -0
  225. package/dist/gateway/hooks/types.d.ts +50 -0
  226. package/dist/gateway/hooks/types.js +18 -0
  227. package/dist/gateway/http/agents.cjs +280 -0
  228. package/dist/gateway/http/agents.d.ts +2 -0
  229. package/dist/gateway/http/agents.js +246 -0
  230. package/dist/gateway/http/fs.cjs +81 -0
  231. package/dist/gateway/http/fs.d.ts +2 -0
  232. package/dist/gateway/http/fs.js +47 -0
  233. package/dist/gateway/http/providers.cjs +120 -0
  234. package/dist/gateway/http/providers.d.ts +2 -0
  235. package/dist/gateway/http/providers.js +86 -0
  236. package/dist/gateway/http/routines.cjs +196 -0
  237. package/dist/gateway/http/routines.d.ts +20 -0
  238. package/dist/gateway/http/routines.js +159 -0
  239. package/dist/gateway/http/sessions.cjs +241 -0
  240. package/dist/gateway/http/sessions.d.ts +2 -0
  241. package/dist/gateway/http/sessions.js +207 -0
  242. package/dist/gateway/http/types.cjs +18 -0
  243. package/dist/gateway/http/types.d.ts +25 -0
  244. package/dist/gateway/http/types.js +0 -0
  245. package/dist/gateway/http/voice.cjs +167 -0
  246. package/dist/gateway/http/voice.d.ts +2 -0
  247. package/dist/gateway/http/voice.js +133 -0
  248. package/dist/gateway/http/webhooks.cjs +353 -0
  249. package/dist/gateway/http/webhooks.d.ts +22 -0
  250. package/dist/gateway/http/webhooks.js +313 -0
  251. package/dist/gateway/index.cjs +119 -0
  252. package/dist/gateway/index.d.ts +8 -0
  253. package/dist/gateway/index.js +9 -0
  254. package/dist/gateway/node.cjs +218 -0
  255. package/dist/gateway/node.d.ts +112 -0
  256. package/dist/gateway/node.js +184 -0
  257. package/dist/gateway/router.cjs +85 -0
  258. package/dist/gateway/router.d.ts +9 -0
  259. package/dist/gateway/router.js +51 -0
  260. package/dist/gateway/rpcClient.cjs +152 -0
  261. package/dist/gateway/rpcClient.d.ts +24 -0
  262. package/dist/gateway/rpcClient.js +118 -0
  263. package/dist/gateway/server.cjs +1175 -0
  264. package/dist/gateway/server.d.ts +185 -0
  265. package/dist/gateway/server.js +1138 -0
  266. package/dist/gateway/transport/http.cjs +153 -0
  267. package/dist/gateway/transport/http.d.ts +25 -0
  268. package/dist/gateway/transport/http.js +119 -0
  269. package/dist/gateway/transport/index.cjs +40 -0
  270. package/dist/gateway/transport/index.d.ts +3 -0
  271. package/dist/gateway/transport/index.js +3 -0
  272. package/dist/gateway/transport/types.cjs +18 -0
  273. package/dist/gateway/transport/types.d.ts +59 -0
  274. package/dist/gateway/transport/types.js +0 -0
  275. package/dist/gateway/transport/websocket.cjs +132 -0
  276. package/dist/gateway/transport/websocket.d.ts +21 -0
  277. package/dist/gateway/transport/websocket.js +98 -0
  278. package/dist/gateway/types.cjs +18 -0
  279. package/dist/gateway/types.d.ts +215 -0
  280. package/dist/gateway/types.js +0 -0
  281. package/dist/gateway/validation.cjs +225 -0
  282. package/dist/gateway/validation.d.ts +157 -0
  283. package/dist/gateway/validation.js +158 -0
  284. package/dist/index.cjs +95 -0
  285. package/dist/index.d.ts +6 -0
  286. package/dist/index.js +6 -0
  287. package/dist/logger.cjs +270 -0
  288. package/dist/logger.d.ts +54 -0
  289. package/dist/logger.js +215 -0
  290. package/dist/providers/copilot.cjs +148 -0
  291. package/dist/providers/copilot.d.ts +3 -0
  292. package/dist/providers/copilot.js +114 -0
  293. package/dist/providers/credentials.cjs +154 -0
  294. package/dist/providers/credentials.d.ts +26 -0
  295. package/dist/providers/credentials.js +99 -0
  296. package/dist/providers/oauth.cjs +279 -0
  297. package/dist/providers/oauth.d.ts +13 -0
  298. package/dist/providers/oauth.js +245 -0
  299. package/dist/providers/registry.cjs +138 -0
  300. package/dist/providers/registry.d.ts +32 -0
  301. package/dist/providers/registry.js +98 -0
  302. package/dist/tests/additionalMessageMiddleware.test.cjs +45 -0
  303. package/dist/tests/additionalMessageMiddleware.test.d.ts +1 -0
  304. package/dist/tests/additionalMessageMiddleware.test.js +39 -0
  305. package/dist/tests/agent-config-voice.test.cjs +25 -0
  306. package/dist/tests/agent-config-voice.test.d.ts +1 -0
  307. package/dist/tests/agent-config-voice.test.js +19 -0
  308. package/dist/tests/agentInvokerAttachments.test.cjs +67 -0
  309. package/dist/tests/agentInvokerAttachments.test.d.ts +1 -0
  310. package/dist/tests/agentInvokerAttachments.test.js +61 -0
  311. package/dist/tests/attachments-utils.test.cjs +46 -0
  312. package/dist/tests/attachments-utils.test.d.ts +1 -0
  313. package/dist/tests/attachments-utils.test.js +40 -0
  314. package/dist/tests/bunSqliteAdapter.test.cjs +265 -0
  315. package/dist/tests/bunSqliteAdapter.test.d.ts +1 -0
  316. package/dist/tests/bunSqliteAdapter.test.js +259 -0
  317. package/dist/tests/candleRange.test.cjs +48 -0
  318. package/dist/tests/candleRange.test.d.ts +1 -0
  319. package/dist/tests/candleRange.test.js +42 -0
  320. package/dist/tests/cli-config-loader.test.cjs +364 -0
  321. package/dist/tests/cli-config-loader.test.d.ts +1 -0
  322. package/dist/tests/cli-config-loader.test.js +358 -0
  323. package/dist/tests/cli-init.test.cjs +82 -0
  324. package/dist/tests/cli-init.test.d.ts +1 -0
  325. package/dist/tests/cli-init.test.js +76 -0
  326. package/dist/tests/discord-adapter.test.cjs +55 -0
  327. package/dist/tests/discord-adapter.test.d.ts +1 -0
  328. package/dist/tests/discord-adapter.test.js +49 -0
  329. package/dist/tests/gateway.test.cjs +319 -0
  330. package/dist/tests/gateway.test.d.ts +1 -0
  331. package/dist/tests/gateway.test.js +313 -0
  332. package/dist/tests/hooks-matcher.test.cjs +309 -0
  333. package/dist/tests/hooks-matcher.test.d.ts +1 -0
  334. package/dist/tests/hooks-matcher.test.js +303 -0
  335. package/dist/tests/hooks-merger.test.cjs +528 -0
  336. package/dist/tests/hooks-merger.test.d.ts +1 -0
  337. package/dist/tests/hooks-merger.test.js +522 -0
  338. package/dist/tests/integration/agent-invocation.integration.test.cjs +264 -0
  339. package/dist/tests/integration/agent-invocation.integration.test.d.ts +1 -0
  340. package/dist/tests/integration/agent-invocation.integration.test.js +258 -0
  341. package/dist/tests/integration/finnhub-candles.integration.test.cjs +98 -0
  342. package/dist/tests/integration/finnhub-candles.integration.test.d.ts +1 -0
  343. package/dist/tests/integration/finnhub-candles.integration.test.js +92 -0
  344. package/dist/tests/logger.test.cjs +353 -0
  345. package/dist/tests/logger.test.d.ts +1 -0
  346. package/dist/tests/logger.test.js +347 -0
  347. package/dist/tests/mediaCompatibilityMiddleware.test.cjs +106 -0
  348. package/dist/tests/mediaCompatibilityMiddleware.test.d.ts +1 -0
  349. package/dist/tests/mediaCompatibilityMiddleware.test.js +100 -0
  350. package/dist/tests/routines-api.test.cjs +107 -0
  351. package/dist/tests/routines-api.test.d.ts +1 -0
  352. package/dist/tests/routines-api.test.js +101 -0
  353. package/dist/tests/sessionMessageAttachments.test.cjs +108 -0
  354. package/dist/tests/sessionMessageAttachments.test.d.ts +1 -0
  355. package/dist/tests/sessionMessageAttachments.test.js +102 -0
  356. package/dist/tests/sessionMessageRole.test.cjs +44 -0
  357. package/dist/tests/sessionMessageRole.test.d.ts +1 -0
  358. package/dist/tests/sessionMessageRole.test.js +38 -0
  359. package/dist/tests/sessionStateMessages.test.cjs +72 -0
  360. package/dist/tests/sessionStateMessages.test.d.ts +1 -0
  361. package/dist/tests/sessionStateMessages.test.js +66 -0
  362. package/dist/tests/sessions-api.test.cjs +68 -0
  363. package/dist/tests/sessions-api.test.d.ts +1 -0
  364. package/dist/tests/sessions-api.test.js +62 -0
  365. package/dist/tests/technicalIndicators.test.cjs +82 -0
  366. package/dist/tests/technicalIndicators.test.d.ts +1 -0
  367. package/dist/tests/technicalIndicators.test.js +76 -0
  368. package/dist/tests/toolDisplayHelpers.test.cjs +43 -0
  369. package/dist/tests/toolDisplayHelpers.test.d.ts +1 -0
  370. package/dist/tests/toolDisplayHelpers.test.js +37 -0
  371. package/dist/tests/voice-config.test.cjs +35 -0
  372. package/dist/tests/voice-config.test.d.ts +1 -0
  373. package/dist/tests/voice-config.test.js +29 -0
  374. package/dist/tests/yahooCandles.test.cjs +111 -0
  375. package/dist/tests/yahooCandles.test.d.ts +1 -0
  376. package/dist/tests/yahooCandles.test.js +105 -0
  377. package/dist/tools/finance/candleRange.cjs +71 -0
  378. package/dist/tools/finance/candleRange.d.ts +21 -0
  379. package/dist/tools/finance/candleRange.js +28 -0
  380. package/dist/tools/finance/optionsAnalytics.cjs +222 -0
  381. package/dist/tools/finance/optionsAnalytics.d.ts +44 -0
  382. package/dist/tools/finance/optionsAnalytics.js +188 -0
  383. package/dist/tools/finance/optionsAnalytics.test.cjs +128 -0
  384. package/dist/tools/finance/optionsAnalytics.test.d.ts +1 -0
  385. package/dist/tools/finance/optionsAnalytics.test.js +122 -0
  386. package/dist/tools/finance/technicalIndicators.cjs +111 -0
  387. package/dist/tools/finance/technicalIndicators.d.ts +15 -0
  388. package/dist/tools/finance/technicalIndicators.js +68 -0
  389. package/dist/tools/finance/yahooCandles.cjs +125 -0
  390. package/dist/tools/finance/yahooCandles.d.ts +41 -0
  391. package/dist/tools/finance/yahooCandles.js +85 -0
  392. package/dist/tools/mcp-finance.cjs +649 -0
  393. package/dist/tools/mcp-finance.d.ts +1 -0
  394. package/dist/tools/mcp-finance.js +631 -0
  395. package/dist/types/agents.cjs +18 -0
  396. package/dist/types/agents.d.ts +11 -0
  397. package/dist/types/agents.js +0 -0
  398. package/dist/types/hooks.cjs +18 -0
  399. package/dist/types/hooks.d.ts +82 -0
  400. package/dist/types/hooks.js +0 -0
  401. package/dist/types/mcp.cjs +86 -0
  402. package/dist/types/mcp.d.ts +107 -0
  403. package/dist/types/mcp.js +40 -0
  404. package/dist/types/voice.cjs +103 -0
  405. package/dist/types/voice.d.ts +117 -0
  406. package/dist/types/voice.js +51 -0
  407. package/dist/utils/attachments.cjs +46 -0
  408. package/dist/utils/attachments.d.ts +7 -0
  409. package/dist/utils/attachments.js +12 -0
  410. package/dist/voice/config.cjs +52 -0
  411. package/dist/voice/config.d.ts +8 -0
  412. package/dist/voice/config.js +18 -0
  413. package/dist/webui/assets/index-BA0HaStz.css +1 -0
  414. package/dist/webui/assets/index-NHgTZsWN.js +112 -0
  415. package/dist/webui/assets/wingman_icon-DOy91UEF.webp +0 -0
  416. package/dist/webui/assets/wingman_logo-Cogyt3qm.webp +0 -0
  417. package/dist/webui/index.html +19 -0
  418. package/package.json +130 -0
@@ -0,0 +1,101 @@
1
+ import { afterEach, beforeEach, describe, expect, it } from "vitest";
2
+ import { createRoutineStore, handleRoutinesApi } from "../gateway/http/routines.js";
3
+ import { mkdirSync, mkdtempSync, rmSync, writeFileSync } from "node:fs";
4
+ import { tmpdir } from "node:os";
5
+ import { join } from "node:path";
6
+ const isBunRuntime = void 0 !== globalThis.Bun;
7
+ const describeIfBun = isBunRuntime ? describe : describe.skip;
8
+ describeIfBun("routines API", ()=>{
9
+ let tempDir;
10
+ beforeEach(()=>{
11
+ tempDir = mkdtempSync(join(tmpdir(), "wingman-routines-"));
12
+ const agentDir = join(tempDir, "agents", "main");
13
+ mkdirSync(agentDir, {
14
+ recursive: true
15
+ });
16
+ writeFileSync(join(agentDir, "agent.json"), JSON.stringify({
17
+ name: "main",
18
+ description: "Main agent",
19
+ systemPrompt: "You are the main agent"
20
+ }, null, 2));
21
+ });
22
+ afterEach(()=>{
23
+ rmSync(tempDir, {
24
+ recursive: true,
25
+ force: true
26
+ });
27
+ });
28
+ it("creates, lists, and deletes routines", async ()=>{
29
+ const ctx = {
30
+ configDir: tempDir,
31
+ workspace: tempDir,
32
+ getWingmanConfig: ()=>({}),
33
+ getSessionManager: async ()=>{
34
+ throw new Error("SessionManager not used in this test");
35
+ }
36
+ };
37
+ const store = createRoutineStore(()=>tempDir);
38
+ const createReq = new Request("http://localhost/api/routines", {
39
+ method: "POST",
40
+ headers: {
41
+ "Content-Type": "application/json"
42
+ },
43
+ body: JSON.stringify({
44
+ name: "Daily Check-in",
45
+ agentId: "main",
46
+ cron: "0 9 * * *",
47
+ prompt: "Summarize today's tasks.",
48
+ enabled: true
49
+ })
50
+ });
51
+ const createRes = await handleRoutinesApi(ctx, store, createReq, new URL(createReq.url));
52
+ expect(createRes).not.toBeNull();
53
+ expect(createRes?.ok).toBe(true);
54
+ const created = await createRes.json();
55
+ expect(created.id).toMatch(/^routine-/);
56
+ const listReq = new Request("http://localhost/api/routines", {
57
+ method: "GET"
58
+ });
59
+ const listRes = await handleRoutinesApi(ctx, store, listReq, new URL(listReq.url));
60
+ expect(listRes).not.toBeNull();
61
+ const list = await listRes.json();
62
+ expect(list).toHaveLength(1);
63
+ expect(list[0].id).toBe(created.id);
64
+ const deleteReq = new Request(`http://localhost/api/routines/${encodeURIComponent(created.id)}`, {
65
+ method: "DELETE"
66
+ });
67
+ const deleteRes = await handleRoutinesApi(ctx, store, deleteReq, new URL(deleteReq.url));
68
+ expect(deleteRes).not.toBeNull();
69
+ expect(deleteRes?.ok).toBe(true);
70
+ const listResAfter = await handleRoutinesApi(ctx, store, listReq, new URL(listReq.url));
71
+ const listAfter = await listResAfter.json();
72
+ expect(listAfter).toHaveLength(0);
73
+ });
74
+ it("rejects invalid cron expressions", async ()=>{
75
+ const ctx = {
76
+ configDir: tempDir,
77
+ workspace: tempDir,
78
+ getWingmanConfig: ()=>({}),
79
+ getSessionManager: async ()=>{
80
+ throw new Error("SessionManager not used in this test");
81
+ }
82
+ };
83
+ const store = createRoutineStore(()=>tempDir);
84
+ const createReq = new Request("http://localhost/api/routines", {
85
+ method: "POST",
86
+ headers: {
87
+ "Content-Type": "application/json"
88
+ },
89
+ body: JSON.stringify({
90
+ name: "Invalid Cron",
91
+ agentId: "main",
92
+ cron: "bad cron",
93
+ prompt: "Hello",
94
+ enabled: true
95
+ })
96
+ });
97
+ const createRes = await handleRoutinesApi(ctx, store, createReq, new URL(createReq.url));
98
+ expect(createRes).not.toBeNull();
99
+ expect(createRes?.status).toBe(400);
100
+ });
101
+ });
@@ -0,0 +1,108 @@
1
+ "use strict";
2
+ var __webpack_exports__ = {};
3
+ const external_vitest_namespaceObject = require("vitest");
4
+ const sessionManager_cjs_namespaceObject = require("../cli/core/sessionManager.cjs");
5
+ (0, external_vitest_namespaceObject.describe)("extractImageAttachments", ()=>{
6
+ (0, external_vitest_namespaceObject.it)("extracts image_url blocks", ()=>{
7
+ const blocks = [
8
+ {
9
+ type: "image_url",
10
+ image_url: {
11
+ url: "data:image/png;base64,abc"
12
+ }
13
+ }
14
+ ];
15
+ (0, external_vitest_namespaceObject.expect)((0, sessionManager_cjs_namespaceObject.extractImageAttachments)(blocks)).toEqual([
16
+ {
17
+ kind: "image",
18
+ dataUrl: "data:image/png;base64,abc"
19
+ }
20
+ ]);
21
+ });
22
+ (0, external_vitest_namespaceObject.it)("extracts input_image blocks", ()=>{
23
+ const blocks = [
24
+ {
25
+ type: "input_image",
26
+ image_url: "data:image/jpeg;base64,xyz"
27
+ }
28
+ ];
29
+ (0, external_vitest_namespaceObject.expect)((0, sessionManager_cjs_namespaceObject.extractImageAttachments)(blocks)).toEqual([
30
+ {
31
+ kind: "image",
32
+ dataUrl: "data:image/jpeg;base64,xyz"
33
+ }
34
+ ]);
35
+ });
36
+ (0, external_vitest_namespaceObject.it)("extracts base64 image blocks", ()=>{
37
+ const blocks = [
38
+ {
39
+ type: "image",
40
+ source: {
41
+ media_type: "image/png",
42
+ data: "zzz"
43
+ }
44
+ }
45
+ ];
46
+ (0, external_vitest_namespaceObject.expect)((0, sessionManager_cjs_namespaceObject.extractImageAttachments)(blocks)).toEqual([
47
+ {
48
+ kind: "image",
49
+ dataUrl: "data:image/png;base64,zzz"
50
+ }
51
+ ]);
52
+ });
53
+ });
54
+ (0, external_vitest_namespaceObject.describe)("extractAttachments", ()=>{
55
+ (0, external_vitest_namespaceObject.it)("extracts input_audio blocks", ()=>{
56
+ const blocks = [
57
+ {
58
+ type: "input_audio",
59
+ input_audio: {
60
+ data: "abc",
61
+ format: "wav"
62
+ }
63
+ }
64
+ ];
65
+ (0, external_vitest_namespaceObject.expect)((0, sessionManager_cjs_namespaceObject.extractAttachments)(blocks)).toEqual([
66
+ {
67
+ kind: "audio",
68
+ dataUrl: "data:audio/wav;base64,abc"
69
+ }
70
+ ]);
71
+ });
72
+ (0, external_vitest_namespaceObject.it)("extracts audio_url blocks", ()=>{
73
+ const blocks = [
74
+ {
75
+ type: "audio_url",
76
+ audio_url: {
77
+ url: "https://cdn.example/audio.mp3"
78
+ }
79
+ }
80
+ ];
81
+ (0, external_vitest_namespaceObject.expect)((0, sessionManager_cjs_namespaceObject.extractAttachments)(blocks)).toEqual([
82
+ {
83
+ kind: "audio",
84
+ dataUrl: "https://cdn.example/audio.mp3"
85
+ }
86
+ ]);
87
+ });
88
+ (0, external_vitest_namespaceObject.it)("extracts base64 audio blocks", ()=>{
89
+ const blocks = [
90
+ {
91
+ type: "audio",
92
+ source_type: "base64",
93
+ data: "abc",
94
+ mime_type: "audio/wav"
95
+ }
96
+ ];
97
+ (0, external_vitest_namespaceObject.expect)((0, sessionManager_cjs_namespaceObject.extractAttachments)(blocks)).toEqual([
98
+ {
99
+ kind: "audio",
100
+ dataUrl: "data:audio/wav;base64,abc"
101
+ }
102
+ ]);
103
+ });
104
+ });
105
+ for(var __rspack_i in __webpack_exports__)exports[__rspack_i] = __webpack_exports__[__rspack_i];
106
+ Object.defineProperty(exports, '__esModule', {
107
+ value: true
108
+ });
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,102 @@
1
+ import { describe, expect, it } from "vitest";
2
+ import { extractAttachments, extractImageAttachments } from "../cli/core/sessionManager.js";
3
+ describe("extractImageAttachments", ()=>{
4
+ it("extracts image_url blocks", ()=>{
5
+ const blocks = [
6
+ {
7
+ type: "image_url",
8
+ image_url: {
9
+ url: "data:image/png;base64,abc"
10
+ }
11
+ }
12
+ ];
13
+ expect(extractImageAttachments(blocks)).toEqual([
14
+ {
15
+ kind: "image",
16
+ dataUrl: "data:image/png;base64,abc"
17
+ }
18
+ ]);
19
+ });
20
+ it("extracts input_image blocks", ()=>{
21
+ const blocks = [
22
+ {
23
+ type: "input_image",
24
+ image_url: "data:image/jpeg;base64,xyz"
25
+ }
26
+ ];
27
+ expect(extractImageAttachments(blocks)).toEqual([
28
+ {
29
+ kind: "image",
30
+ dataUrl: "data:image/jpeg;base64,xyz"
31
+ }
32
+ ]);
33
+ });
34
+ it("extracts base64 image blocks", ()=>{
35
+ const blocks = [
36
+ {
37
+ type: "image",
38
+ source: {
39
+ media_type: "image/png",
40
+ data: "zzz"
41
+ }
42
+ }
43
+ ];
44
+ expect(extractImageAttachments(blocks)).toEqual([
45
+ {
46
+ kind: "image",
47
+ dataUrl: "data:image/png;base64,zzz"
48
+ }
49
+ ]);
50
+ });
51
+ });
52
+ describe("extractAttachments", ()=>{
53
+ it("extracts input_audio blocks", ()=>{
54
+ const blocks = [
55
+ {
56
+ type: "input_audio",
57
+ input_audio: {
58
+ data: "abc",
59
+ format: "wav"
60
+ }
61
+ }
62
+ ];
63
+ expect(extractAttachments(blocks)).toEqual([
64
+ {
65
+ kind: "audio",
66
+ dataUrl: "data:audio/wav;base64,abc"
67
+ }
68
+ ]);
69
+ });
70
+ it("extracts audio_url blocks", ()=>{
71
+ const blocks = [
72
+ {
73
+ type: "audio_url",
74
+ audio_url: {
75
+ url: "https://cdn.example/audio.mp3"
76
+ }
77
+ }
78
+ ];
79
+ expect(extractAttachments(blocks)).toEqual([
80
+ {
81
+ kind: "audio",
82
+ dataUrl: "https://cdn.example/audio.mp3"
83
+ }
84
+ ]);
85
+ });
86
+ it("extracts base64 audio blocks", ()=>{
87
+ const blocks = [
88
+ {
89
+ type: "audio",
90
+ source_type: "base64",
91
+ data: "abc",
92
+ mime_type: "audio/wav"
93
+ }
94
+ ];
95
+ expect(extractAttachments(blocks)).toEqual([
96
+ {
97
+ kind: "audio",
98
+ dataUrl: "data:audio/wav;base64,abc"
99
+ }
100
+ ]);
101
+ });
102
+ });
@@ -0,0 +1,44 @@
1
+ "use strict";
2
+ var __webpack_exports__ = {};
3
+ const external_vitest_namespaceObject = require("vitest");
4
+ const sessionManager_cjs_namespaceObject = require("../cli/core/sessionManager.cjs");
5
+ (0, external_vitest_namespaceObject.describe)("resolveMessageRole", ()=>{
6
+ (0, external_vitest_namespaceObject.it)("resolves role from langchain id arrays", ()=>{
7
+ const human = {
8
+ type: "constructor",
9
+ id: [
10
+ "langchain_core",
11
+ "messages",
12
+ "HumanMessage"
13
+ ],
14
+ kwargs: {
15
+ content: "hi"
16
+ }
17
+ };
18
+ const ai = {
19
+ type: "constructor",
20
+ id: [
21
+ "langchain_core",
22
+ "messages",
23
+ "AIMessageChunk"
24
+ ],
25
+ kwargs: {
26
+ content: "hello"
27
+ }
28
+ };
29
+ (0, external_vitest_namespaceObject.expect)((0, sessionManager_cjs_namespaceObject.resolveMessageRole)(human)).toBe("user");
30
+ (0, external_vitest_namespaceObject.expect)((0, sessionManager_cjs_namespaceObject.resolveMessageRole)(ai)).toBe("assistant");
31
+ });
32
+ (0, external_vitest_namespaceObject.it)("resolves role from explicit types", ()=>{
33
+ (0, external_vitest_namespaceObject.expect)((0, sessionManager_cjs_namespaceObject.resolveMessageRole)({
34
+ type: "human"
35
+ })).toBe("user");
36
+ (0, external_vitest_namespaceObject.expect)((0, sessionManager_cjs_namespaceObject.resolveMessageRole)({
37
+ type: "ai"
38
+ })).toBe("assistant");
39
+ });
40
+ });
41
+ for(var __rspack_i in __webpack_exports__)exports[__rspack_i] = __webpack_exports__[__rspack_i];
42
+ Object.defineProperty(exports, '__esModule', {
43
+ value: true
44
+ });
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,38 @@
1
+ import { describe, expect, it } from "vitest";
2
+ import { resolveMessageRole } from "../cli/core/sessionManager.js";
3
+ describe("resolveMessageRole", ()=>{
4
+ it("resolves role from langchain id arrays", ()=>{
5
+ const human = {
6
+ type: "constructor",
7
+ id: [
8
+ "langchain_core",
9
+ "messages",
10
+ "HumanMessage"
11
+ ],
12
+ kwargs: {
13
+ content: "hi"
14
+ }
15
+ };
16
+ const ai = {
17
+ type: "constructor",
18
+ id: [
19
+ "langchain_core",
20
+ "messages",
21
+ "AIMessageChunk"
22
+ ],
23
+ kwargs: {
24
+ content: "hello"
25
+ }
26
+ };
27
+ expect(resolveMessageRole(human)).toBe("user");
28
+ expect(resolveMessageRole(ai)).toBe("assistant");
29
+ });
30
+ it("resolves role from explicit types", ()=>{
31
+ expect(resolveMessageRole({
32
+ type: "human"
33
+ })).toBe("user");
34
+ expect(resolveMessageRole({
35
+ type: "ai"
36
+ })).toBe("assistant");
37
+ });
38
+ });
@@ -0,0 +1,72 @@
1
+ "use strict";
2
+ var __webpack_exports__ = {};
3
+ const external_vitest_namespaceObject = require("vitest");
4
+ const sessionManager_cjs_namespaceObject = require("../cli/core/sessionManager.cjs");
5
+ (0, external_vitest_namespaceObject.describe)("extractMessagesFromState", ()=>{
6
+ (0, external_vitest_namespaceObject.it)("maps state messages using createdAt", ()=>{
7
+ const state = {
8
+ createdAt: "2025-01-01T00:00:00.000Z",
9
+ values: {
10
+ messages: [
11
+ {
12
+ role: "user",
13
+ content: "hi"
14
+ },
15
+ {
16
+ role: "assistant",
17
+ content: "hello"
18
+ }
19
+ ]
20
+ }
21
+ };
22
+ const result = (0, sessionManager_cjs_namespaceObject.extractMessagesFromState)(state);
23
+ (0, external_vitest_namespaceObject.expect)(result).not.toBeNull();
24
+ (0, external_vitest_namespaceObject.expect)(result).toHaveLength(2);
25
+ (0, external_vitest_namespaceObject.expect)(result?.[0]).toMatchObject({
26
+ role: "user",
27
+ content: "hi"
28
+ });
29
+ (0, external_vitest_namespaceObject.expect)(result?.[1]).toMatchObject({
30
+ role: "assistant",
31
+ content: "hello"
32
+ });
33
+ const baseTime = new Date("2025-01-01T00:00:00.000Z").getTime();
34
+ (0, external_vitest_namespaceObject.expect)(result?.[0]?.createdAt).toBe(baseTime);
35
+ (0, external_vitest_namespaceObject.expect)(result?.[1]?.createdAt).toBe(baseTime + 1);
36
+ });
37
+ (0, external_vitest_namespaceObject.it)("filters non-user messages and ui_hidden entries", ()=>{
38
+ const state = {
39
+ createdAt: 1000,
40
+ values: {
41
+ messages: [
42
+ {
43
+ role: "tool",
44
+ content: "skip"
45
+ },
46
+ {
47
+ role: "assistant",
48
+ content: "",
49
+ additional_kwargs: {
50
+ ui_hidden: true
51
+ }
52
+ },
53
+ {
54
+ role: "assistant",
55
+ content: "keep"
56
+ }
57
+ ]
58
+ }
59
+ };
60
+ const result = (0, sessionManager_cjs_namespaceObject.extractMessagesFromState)(state);
61
+ (0, external_vitest_namespaceObject.expect)(result).not.toBeNull();
62
+ (0, external_vitest_namespaceObject.expect)(result).toHaveLength(1);
63
+ (0, external_vitest_namespaceObject.expect)(result?.[0]).toMatchObject({
64
+ role: "assistant",
65
+ content: "keep"
66
+ });
67
+ });
68
+ });
69
+ for(var __rspack_i in __webpack_exports__)exports[__rspack_i] = __webpack_exports__[__rspack_i];
70
+ Object.defineProperty(exports, '__esModule', {
71
+ value: true
72
+ });
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,66 @@
1
+ import { describe, expect, it } from "vitest";
2
+ import { extractMessagesFromState } from "../cli/core/sessionManager.js";
3
+ describe("extractMessagesFromState", ()=>{
4
+ it("maps state messages using createdAt", ()=>{
5
+ const state = {
6
+ createdAt: "2025-01-01T00:00:00.000Z",
7
+ values: {
8
+ messages: [
9
+ {
10
+ role: "user",
11
+ content: "hi"
12
+ },
13
+ {
14
+ role: "assistant",
15
+ content: "hello"
16
+ }
17
+ ]
18
+ }
19
+ };
20
+ const result = extractMessagesFromState(state);
21
+ expect(result).not.toBeNull();
22
+ expect(result).toHaveLength(2);
23
+ expect(result?.[0]).toMatchObject({
24
+ role: "user",
25
+ content: "hi"
26
+ });
27
+ expect(result?.[1]).toMatchObject({
28
+ role: "assistant",
29
+ content: "hello"
30
+ });
31
+ const baseTime = new Date("2025-01-01T00:00:00.000Z").getTime();
32
+ expect(result?.[0]?.createdAt).toBe(baseTime);
33
+ expect(result?.[1]?.createdAt).toBe(baseTime + 1);
34
+ });
35
+ it("filters non-user messages and ui_hidden entries", ()=>{
36
+ const state = {
37
+ createdAt: 1000,
38
+ values: {
39
+ messages: [
40
+ {
41
+ role: "tool",
42
+ content: "skip"
43
+ },
44
+ {
45
+ role: "assistant",
46
+ content: "",
47
+ additional_kwargs: {
48
+ ui_hidden: true
49
+ }
50
+ },
51
+ {
52
+ role: "assistant",
53
+ content: "keep"
54
+ }
55
+ ]
56
+ }
57
+ };
58
+ const result = extractMessagesFromState(state);
59
+ expect(result).not.toBeNull();
60
+ expect(result).toHaveLength(1);
61
+ expect(result?.[0]).toMatchObject({
62
+ role: "assistant",
63
+ content: "keep"
64
+ });
65
+ });
66
+ });
@@ -0,0 +1,68 @@
1
+ "use strict";
2
+ var __webpack_exports__ = {};
3
+ const external_vitest_namespaceObject = require("vitest");
4
+ const sessions_cjs_namespaceObject = require("../gateway/http/sessions.cjs");
5
+ const sessionManager_cjs_namespaceObject = require("../cli/core/sessionManager.cjs");
6
+ const external_node_fs_namespaceObject = require("node:fs");
7
+ const external_node_os_namespaceObject = require("node:os");
8
+ const external_node_path_namespaceObject = require("node:path");
9
+ const isBunRuntime = void 0 !== globalThis.Bun;
10
+ const describeIfBun = isBunRuntime ? external_vitest_namespaceObject.describe : external_vitest_namespaceObject.describe.skip;
11
+ describeIfBun("sessions API", ()=>{
12
+ let manager;
13
+ let tempDir;
14
+ (0, external_vitest_namespaceObject.beforeEach)(async ()=>{
15
+ tempDir = (0, external_node_fs_namespaceObject.mkdtempSync)((0, external_node_path_namespaceObject.join)((0, external_node_os_namespaceObject.tmpdir)(), "wingman-sessions-"));
16
+ const dbPath = (0, external_node_path_namespaceObject.join)(tempDir, "sessions.db");
17
+ manager = new sessionManager_cjs_namespaceObject.SessionManager(dbPath);
18
+ await manager.initialize();
19
+ });
20
+ (0, external_vitest_namespaceObject.afterEach)(()=>{
21
+ manager.close();
22
+ (0, external_node_fs_namespaceObject.rmSync)(tempDir, {
23
+ recursive: true,
24
+ force: true
25
+ });
26
+ });
27
+ (0, external_vitest_namespaceObject.it)("clears persisted session messages", async ()=>{
28
+ const ctx = {
29
+ getSessionManager: async ()=>manager,
30
+ router: {
31
+ selectAgent: (agentId)=>agentId || "main"
32
+ }
33
+ };
34
+ const createReq = new Request("http://localhost/api/sessions", {
35
+ method: "POST",
36
+ headers: {
37
+ "Content-Type": "application/json"
38
+ },
39
+ body: JSON.stringify({
40
+ agentId: "main",
41
+ name: "Clear Test"
42
+ })
43
+ });
44
+ const createRes = await (0, sessions_cjs_namespaceObject.handleSessionsApi)(ctx, createReq, new URL(createReq.url));
45
+ (0, external_vitest_namespaceObject.expect)(createRes).not.toBeNull();
46
+ (0, external_vitest_namespaceObject.expect)(createRes?.ok).toBe(true);
47
+ const created = await createRes.json();
48
+ manager.updateSession(created.id, {
49
+ messageCount: 2,
50
+ lastMessagePreview: "Hello"
51
+ });
52
+ const deleteReq = new Request(`http://localhost/api/sessions/${encodeURIComponent(created.id)}/messages?agentId=main`, {
53
+ method: "DELETE"
54
+ });
55
+ const deleteRes = await (0, sessions_cjs_namespaceObject.handleSessionsApi)(ctx, deleteReq, new URL(deleteReq.url));
56
+ (0, external_vitest_namespaceObject.expect)(deleteRes).not.toBeNull();
57
+ (0, external_vitest_namespaceObject.expect)(deleteRes?.ok).toBe(true);
58
+ const payload = await deleteRes.json();
59
+ (0, external_vitest_namespaceObject.expect)(payload.messageCount).toBe(0);
60
+ const updated = manager.getSession(created.id);
61
+ (0, external_vitest_namespaceObject.expect)(updated?.messageCount).toBe(0);
62
+ (0, external_vitest_namespaceObject.expect)(updated?.lastMessagePreview).toBeNull();
63
+ });
64
+ });
65
+ for(var __rspack_i in __webpack_exports__)exports[__rspack_i] = __webpack_exports__[__rspack_i];
66
+ Object.defineProperty(exports, '__esModule', {
67
+ value: true
68
+ });
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,62 @@
1
+ import { afterEach, beforeEach, describe, expect, it } from "vitest";
2
+ import { handleSessionsApi } from "../gateway/http/sessions.js";
3
+ import { SessionManager } from "../cli/core/sessionManager.js";
4
+ import { mkdtempSync, rmSync } from "node:fs";
5
+ import { tmpdir } from "node:os";
6
+ import { join } from "node:path";
7
+ const isBunRuntime = void 0 !== globalThis.Bun;
8
+ const describeIfBun = isBunRuntime ? describe : describe.skip;
9
+ describeIfBun("sessions API", ()=>{
10
+ let manager;
11
+ let tempDir;
12
+ beforeEach(async ()=>{
13
+ tempDir = mkdtempSync(join(tmpdir(), "wingman-sessions-"));
14
+ const dbPath = join(tempDir, "sessions.db");
15
+ manager = new SessionManager(dbPath);
16
+ await manager.initialize();
17
+ });
18
+ afterEach(()=>{
19
+ manager.close();
20
+ rmSync(tempDir, {
21
+ recursive: true,
22
+ force: true
23
+ });
24
+ });
25
+ it("clears persisted session messages", async ()=>{
26
+ const ctx = {
27
+ getSessionManager: async ()=>manager,
28
+ router: {
29
+ selectAgent: (agentId)=>agentId || "main"
30
+ }
31
+ };
32
+ const createReq = new Request("http://localhost/api/sessions", {
33
+ method: "POST",
34
+ headers: {
35
+ "Content-Type": "application/json"
36
+ },
37
+ body: JSON.stringify({
38
+ agentId: "main",
39
+ name: "Clear Test"
40
+ })
41
+ });
42
+ const createRes = await handleSessionsApi(ctx, createReq, new URL(createReq.url));
43
+ expect(createRes).not.toBeNull();
44
+ expect(createRes?.ok).toBe(true);
45
+ const created = await createRes.json();
46
+ manager.updateSession(created.id, {
47
+ messageCount: 2,
48
+ lastMessagePreview: "Hello"
49
+ });
50
+ const deleteReq = new Request(`http://localhost/api/sessions/${encodeURIComponent(created.id)}/messages?agentId=main`, {
51
+ method: "DELETE"
52
+ });
53
+ const deleteRes = await handleSessionsApi(ctx, deleteReq, new URL(deleteReq.url));
54
+ expect(deleteRes).not.toBeNull();
55
+ expect(deleteRes?.ok).toBe(true);
56
+ const payload = await deleteRes.json();
57
+ expect(payload.messageCount).toBe(0);
58
+ const updated = manager.getSession(created.id);
59
+ expect(updated?.messageCount).toBe(0);
60
+ expect(updated?.lastMessagePreview).toBeNull();
61
+ });
62
+ });