@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,246 @@
1
+ import { ChannelType, Client, GatewayIntentBits, Partials } from "discord.js";
2
+ import { createLogger } from "../../logger.js";
3
+ import { GatewayRpcClient } from "../rpcClient.js";
4
+ import { parseStreamChunk } from "../../cli/core/streamParser.js";
5
+ function _define_property(obj, key, value) {
6
+ if (key in obj) Object.defineProperty(obj, key, {
7
+ value: value,
8
+ enumerable: true,
9
+ configurable: true,
10
+ writable: true
11
+ });
12
+ else obj[key] = value;
13
+ return obj;
14
+ }
15
+ const DEFAULT_DISCORD_RESPONSE_CHUNK = 1900;
16
+ function splitDiscordMessage(text, maxLength = DEFAULT_DISCORD_RESPONSE_CHUNK) {
17
+ const normalized = text.trim();
18
+ if (!normalized) return [];
19
+ const chunks = [];
20
+ let current = "";
21
+ for (const char of normalized){
22
+ if (current.length + 1 > maxLength) {
23
+ chunks.push(current);
24
+ current = "";
25
+ }
26
+ current += char;
27
+ }
28
+ if (current) chunks.push(current);
29
+ return chunks;
30
+ }
31
+ function stripDiscordBotMention(content, botId) {
32
+ if (!content) return content;
33
+ const mention = new RegExp(`<@!?${botId}>`, "g");
34
+ return content.replace(mention, "").trim();
35
+ }
36
+ function extractSessionOverride(content, command) {
37
+ const trimmed = content.trim();
38
+ if (!command || !trimmed.toLowerCase().startsWith(command.toLowerCase())) return {
39
+ content,
40
+ matched: false
41
+ };
42
+ const withoutCommand = trimmed.slice(command.length).trim();
43
+ if (!withoutCommand) return {
44
+ content: "",
45
+ matched: true
46
+ };
47
+ const [sessionKey, ...rest] = withoutCommand.split(/\s+/);
48
+ return {
49
+ sessionKey,
50
+ content: rest.join(" "),
51
+ matched: true
52
+ };
53
+ }
54
+ function resolveDiscordChannelSessionKey(channelId, channelSessions, parentChannelId) {
55
+ if (!channelSessions) return;
56
+ const direct = channelSessions[channelId];
57
+ if (direct) return direct;
58
+ if (parentChannelId) return channelSessions[parentChannelId];
59
+ }
60
+ function parseAgentIdFromSessionKey(sessionKey) {
61
+ if (!sessionKey) return;
62
+ const match = sessionKey.match(/^agent:([^:]+):/);
63
+ return match?.[1];
64
+ }
65
+ function buildRoutingInfo(message, botUserId) {
66
+ const routing = {
67
+ channel: "discord",
68
+ accountId: botUserId
69
+ };
70
+ if (message.guildId) routing.guildId = message.guildId;
71
+ const channel = message.channel;
72
+ if (channel.isDMBased()) {
73
+ if (channel.type === ChannelType.DM) routing.peer = {
74
+ kind: "dm",
75
+ id: message.author.id
76
+ };
77
+ else routing.peer = {
78
+ kind: "group",
79
+ id: channel.id
80
+ };
81
+ return routing;
82
+ }
83
+ if (channel.isThread()) {
84
+ routing.threadId = channel.id;
85
+ routing.peer = {
86
+ kind: "channel",
87
+ id: channel.parentId || channel.id
88
+ };
89
+ return routing;
90
+ }
91
+ routing.peer = {
92
+ kind: "channel",
93
+ id: channel.id
94
+ };
95
+ return routing;
96
+ }
97
+ class DiscordGatewayAdapter {
98
+ async start() {
99
+ if (this.started) return;
100
+ if (!this.config.enabled) return;
101
+ if (!this.config.token) return void this.logger.warn("Discord adapter enabled but no token configured.");
102
+ this.gatewayClient = new GatewayRpcClient(this.gateway.url, {
103
+ token: this.gateway.token,
104
+ password: this.gateway.password,
105
+ clientType: "discord"
106
+ });
107
+ await this.gatewayClient.connect();
108
+ this.client = new Client({
109
+ intents: [
110
+ GatewayIntentBits.Guilds,
111
+ GatewayIntentBits.GuildMessages,
112
+ GatewayIntentBits.DirectMessages,
113
+ GatewayIntentBits.MessageContent
114
+ ],
115
+ partials: [
116
+ Partials.Channel
117
+ ]
118
+ });
119
+ this.client.on("clientReady", ()=>{
120
+ this.logger.info("Discord adapter connected.");
121
+ });
122
+ this.client.on("error", (error)=>{
123
+ this.logger.error("Discord adapter error", error);
124
+ });
125
+ this.client.on("messageCreate", (message)=>{
126
+ this.handleMessage(message);
127
+ });
128
+ await this.client.login(this.config.token);
129
+ this.started = true;
130
+ }
131
+ async stop() {
132
+ if (!this.started) return;
133
+ this.started = false;
134
+ if (this.client) {
135
+ await this.client.destroy();
136
+ this.client = null;
137
+ }
138
+ if (this.gatewayClient) {
139
+ this.gatewayClient.disconnect();
140
+ this.gatewayClient = null;
141
+ }
142
+ }
143
+ async handleMessage(message) {
144
+ if (!this.client || !this.gatewayClient) return;
145
+ if (!message.content && 0 === message.attachments.size) return;
146
+ if (message.author.bot) {
147
+ if (!this.config.allowBots) return;
148
+ if (message.author.id === this.client.user?.id) return;
149
+ }
150
+ const botUserId = this.client.user?.id;
151
+ if (!botUserId) return;
152
+ if (!message.channel.isTextBased()) return;
153
+ const channel = message.channel;
154
+ if (!("send" in channel)) return;
155
+ const sendChannel = channel;
156
+ if (this.config.allowedGuilds.length > 0 && message.guildId) {
157
+ if (!this.config.allowedGuilds.includes(message.guildId)) return;
158
+ }
159
+ if (this.config.allowedChannels.length > 0) {
160
+ if (!this.config.allowedChannels.includes(message.channelId)) return;
161
+ }
162
+ const isDm = message.channel.isDMBased();
163
+ const mentioned = message.mentions.has(botUserId);
164
+ if (this.config.mentionOnly && !isDm && !mentioned) return;
165
+ const cleaned = stripDiscordBotMention(message.content || "", botUserId);
166
+ const attachments = Array.from(message.attachments.values()).map((attachment)=>attachment.url);
167
+ const attachmentText = attachments.length > 0 ? `\n\nAttachments:\n${attachments.map((url)=>`- ${url}`).join("\n")}` : "";
168
+ let content = `${cleaned}${attachmentText}`.trim();
169
+ const { sessionKey, content: nextContent, matched } = extractSessionOverride(content, this.config.sessionCommand);
170
+ let resolvedSessionKey = sessionKey;
171
+ let usedChannelMapping = false;
172
+ if (matched) {
173
+ content = nextContent.trim();
174
+ if (!sessionKey) return void await sendChannel.send(`Provide a session key after \`${this.config.sessionCommand}\`.`);
175
+ }
176
+ if (!matched) {
177
+ const parentChannelId = message.channel.isThread() ? message.channel.parentId ?? void 0 : void 0;
178
+ resolvedSessionKey = resolveDiscordChannelSessionKey(message.channelId, this.config.channelSessions, parentChannelId);
179
+ usedChannelMapping = Boolean(resolvedSessionKey);
180
+ }
181
+ const inferredAgentId = parseAgentIdFromSessionKey(resolvedSessionKey);
182
+ if (usedChannelMapping && !inferredAgentId) this.logger.warn(`Discord channel session mapping for channel ${message.channelId} does not include an agent prefix. Use "agent:<id>:..." to auto-select an agent.`, {
183
+ sessionKey: resolvedSessionKey
184
+ });
185
+ if (!content) return;
186
+ const payload = {
187
+ agentId: inferredAgentId,
188
+ content,
189
+ routing: buildRoutingInfo(message, botUserId),
190
+ sessionKey: resolvedSessionKey
191
+ };
192
+ try {
193
+ if (sendChannel.sendTyping) await sendChannel.sendTyping();
194
+ let fallbackText = "";
195
+ const textByMessageId = new Map();
196
+ const messageOrder = [];
197
+ await this.gatewayClient.requestAgent(payload, (event)=>{
198
+ if (!event || "object" != typeof event) return;
199
+ if ("agent-error" === event.type) {
200
+ fallbackText += `\n${event.error || "Agent error"}`;
201
+ return;
202
+ }
203
+ if ("agent-stream" !== event.type) return;
204
+ const parsedChunks = parseStreamChunk(event.chunk);
205
+ for (const chunk of parsedChunks)if ("text" === chunk.type && chunk.text) {
206
+ if (chunk.messageId) {
207
+ if (!textByMessageId.has(chunk.messageId)) {
208
+ messageOrder.push(chunk.messageId);
209
+ textByMessageId.set(chunk.messageId, chunk.text);
210
+ continue;
211
+ }
212
+ const current = textByMessageId.get(chunk.messageId) || "";
213
+ textByMessageId.set(chunk.messageId, chunk.isDelta ? current + chunk.text : chunk.text);
214
+ continue;
215
+ }
216
+ fallbackText += chunk.text;
217
+ }
218
+ });
219
+ const orderedText = messageOrder.map((id)=>textByMessageId.get(id)).filter((value)=>Boolean(value)).join("\n\n");
220
+ const responseText = `${fallbackText}${fallbackText && orderedText ? "\n\n" : ""}${orderedText}`.trim();
221
+ if (!responseText) return;
222
+ const chunks = splitDiscordMessage(responseText, this.config.responseChunkSize);
223
+ for (const chunk of chunks)await sendChannel.send(chunk);
224
+ } catch (error) {
225
+ this.logger.error("Discord adapter failed to handle message", error);
226
+ try {
227
+ await sendChannel.send("Sorry, I hit an error running that request.");
228
+ } catch {}
229
+ }
230
+ }
231
+ constructor(config, gateway, logger){
232
+ _define_property(this, "config", void 0);
233
+ _define_property(this, "gateway", void 0);
234
+ _define_property(this, "client", void 0);
235
+ _define_property(this, "gatewayClient", void 0);
236
+ _define_property(this, "logger", void 0);
237
+ _define_property(this, "started", void 0);
238
+ this.config = config;
239
+ this.gateway = gateway;
240
+ this.client = null;
241
+ this.gatewayClient = null;
242
+ this.started = false;
243
+ this.logger = logger || createLogger();
244
+ }
245
+ }
246
+ export { DEFAULT_DISCORD_RESPONSE_CHUNK, DiscordGatewayAdapter, extractSessionOverride, parseAgentIdFromSessionKey, resolveDiscordChannelSessionKey, splitDiscordMessage, stripDiscordBotMention };
@@ -0,0 +1,94 @@
1
+ "use strict";
2
+ var __webpack_require__ = {};
3
+ (()=>{
4
+ __webpack_require__.d = (exports1, definition)=>{
5
+ for(var key in definition)if (__webpack_require__.o(definition, key) && !__webpack_require__.o(exports1, key)) Object.defineProperty(exports1, key, {
6
+ enumerable: true,
7
+ get: definition[key]
8
+ });
9
+ };
10
+ })();
11
+ (()=>{
12
+ __webpack_require__.o = (obj, prop)=>Object.prototype.hasOwnProperty.call(obj, prop);
13
+ })();
14
+ (()=>{
15
+ __webpack_require__.r = (exports1)=>{
16
+ if ("u" > typeof Symbol && Symbol.toStringTag) Object.defineProperty(exports1, Symbol.toStringTag, {
17
+ value: 'Module'
18
+ });
19
+ Object.defineProperty(exports1, '__esModule', {
20
+ value: true
21
+ });
22
+ };
23
+ })();
24
+ var __webpack_exports__ = {};
25
+ __webpack_require__.r(__webpack_exports__);
26
+ __webpack_require__.d(__webpack_exports__, {
27
+ GatewayAuth: ()=>GatewayAuth
28
+ });
29
+ const external_crypto_namespaceObject = require("crypto");
30
+ function _define_property(obj, key, value) {
31
+ if (key in obj) Object.defineProperty(obj, key, {
32
+ value: value,
33
+ enumerable: true,
34
+ configurable: true,
35
+ writable: true
36
+ });
37
+ else obj[key] = value;
38
+ return obj;
39
+ }
40
+ class GatewayAuth {
41
+ generateToken() {
42
+ const token = (0, external_crypto_namespaceObject.randomBytes)(32).toString("hex");
43
+ this.tokens.add(token);
44
+ return token;
45
+ }
46
+ validate(auth, tailscaleUser) {
47
+ if ("none" === this.mode) return true;
48
+ if (this.allowTailscale && tailscaleUser) return true;
49
+ if ("token" === this.mode) {
50
+ if (!auth?.token) return false;
51
+ return this.tokens.has(auth.token);
52
+ }
53
+ if ("password" === this.mode) {
54
+ if (!auth?.password || !this.password) return false;
55
+ return auth.password === this.password;
56
+ }
57
+ return false;
58
+ }
59
+ addToken(token) {
60
+ this.tokens.add(token);
61
+ }
62
+ revokeToken(token) {
63
+ return this.tokens.delete(token);
64
+ }
65
+ getTokens() {
66
+ return Array.from(this.tokens);
67
+ }
68
+ isAuthRequired() {
69
+ return "none" !== this.mode;
70
+ }
71
+ setAuthRequired(required) {
72
+ this.mode = required ? "token" : "none";
73
+ }
74
+ constructor(config = {
75
+ mode: "none"
76
+ }, initialTokens = []){
77
+ _define_property(this, "tokens", void 0);
78
+ _define_property(this, "mode", void 0);
79
+ _define_property(this, "password", void 0);
80
+ _define_property(this, "allowTailscale", void 0);
81
+ this.mode = config.mode;
82
+ this.password = config.password;
83
+ this.allowTailscale = config.allowTailscale ?? false;
84
+ this.tokens = new Set(initialTokens);
85
+ if (config.token) this.tokens.add(config.token);
86
+ }
87
+ }
88
+ exports.GatewayAuth = __webpack_exports__.GatewayAuth;
89
+ for(var __rspack_i in __webpack_exports__)if (-1 === [
90
+ "GatewayAuth"
91
+ ].indexOf(__rspack_i)) exports[__rspack_i] = __webpack_exports__[__rspack_i];
92
+ Object.defineProperty(exports, '__esModule', {
93
+ value: true
94
+ });
@@ -0,0 +1,36 @@
1
+ import type { GatewayAuthConfig, GatewayAuthPayload } from "./types.js";
2
+ /**
3
+ * Simple token-based authentication for the gateway
4
+ */
5
+ export declare class GatewayAuth {
6
+ private tokens;
7
+ private mode;
8
+ private password?;
9
+ private allowTailscale;
10
+ constructor(config?: GatewayAuthConfig, initialTokens?: string[]);
11
+ /**
12
+ * Generate a new authentication token
13
+ */
14
+ generateToken(): string;
15
+ /**
16
+ * Validate an authentication token
17
+ */
18
+ validate(auth?: GatewayAuthPayload, tailscaleUser?: string): boolean;
19
+ /**
20
+ * Add a token to the valid tokens set
21
+ */
22
+ addToken(token: string): void;
23
+ /**
24
+ * Remove a token from the valid tokens set
25
+ */
26
+ revokeToken(token: string): boolean;
27
+ /**
28
+ * Get all valid tokens
29
+ */
30
+ getTokens(): string[];
31
+ /**
32
+ * Check if authentication is required
33
+ */
34
+ isAuthRequired(): boolean;
35
+ setAuthRequired(required: boolean): void;
36
+ }
@@ -0,0 +1,60 @@
1
+ import { randomBytes } from "crypto";
2
+ function _define_property(obj, key, value) {
3
+ if (key in obj) Object.defineProperty(obj, key, {
4
+ value: value,
5
+ enumerable: true,
6
+ configurable: true,
7
+ writable: true
8
+ });
9
+ else obj[key] = value;
10
+ return obj;
11
+ }
12
+ class GatewayAuth {
13
+ generateToken() {
14
+ const token = randomBytes(32).toString("hex");
15
+ this.tokens.add(token);
16
+ return token;
17
+ }
18
+ validate(auth, tailscaleUser) {
19
+ if ("none" === this.mode) return true;
20
+ if (this.allowTailscale && tailscaleUser) return true;
21
+ if ("token" === this.mode) {
22
+ if (!auth?.token) return false;
23
+ return this.tokens.has(auth.token);
24
+ }
25
+ if ("password" === this.mode) {
26
+ if (!auth?.password || !this.password) return false;
27
+ return auth.password === this.password;
28
+ }
29
+ return false;
30
+ }
31
+ addToken(token) {
32
+ this.tokens.add(token);
33
+ }
34
+ revokeToken(token) {
35
+ return this.tokens.delete(token);
36
+ }
37
+ getTokens() {
38
+ return Array.from(this.tokens);
39
+ }
40
+ isAuthRequired() {
41
+ return "none" !== this.mode;
42
+ }
43
+ setAuthRequired(required) {
44
+ this.mode = required ? "token" : "none";
45
+ }
46
+ constructor(config = {
47
+ mode: "none"
48
+ }, initialTokens = []){
49
+ _define_property(this, "tokens", void 0);
50
+ _define_property(this, "mode", void 0);
51
+ _define_property(this, "password", void 0);
52
+ _define_property(this, "allowTailscale", void 0);
53
+ this.mode = config.mode;
54
+ this.password = config.password;
55
+ this.allowTailscale = config.allowTailscale ?? false;
56
+ this.tokens = new Set(initialTokens);
57
+ if (config.token) this.tokens.add(config.token);
58
+ }
59
+ }
60
+ export { GatewayAuth };
@@ -0,0 +1,131 @@
1
+ "use strict";
2
+ var __webpack_require__ = {};
3
+ (()=>{
4
+ __webpack_require__.d = (exports1, definition)=>{
5
+ for(var key in definition)if (__webpack_require__.o(definition, key) && !__webpack_require__.o(exports1, key)) Object.defineProperty(exports1, key, {
6
+ enumerable: true,
7
+ get: definition[key]
8
+ });
9
+ };
10
+ })();
11
+ (()=>{
12
+ __webpack_require__.o = (obj, prop)=>Object.prototype.hasOwnProperty.call(obj, prop);
13
+ })();
14
+ (()=>{
15
+ __webpack_require__.r = (exports1)=>{
16
+ if ("u" > typeof Symbol && Symbol.toStringTag) Object.defineProperty(exports1, Symbol.toStringTag, {
17
+ value: 'Module'
18
+ });
19
+ Object.defineProperty(exports1, '__esModule', {
20
+ value: true
21
+ });
22
+ };
23
+ })();
24
+ var __webpack_exports__ = {};
25
+ __webpack_require__.r(__webpack_exports__);
26
+ __webpack_require__.d(__webpack_exports__, {
27
+ BroadcastGroupManager: ()=>BroadcastGroupManager
28
+ });
29
+ const external_crypto_namespaceObject = require("crypto");
30
+ function _define_property(obj, key, value) {
31
+ if (key in obj) Object.defineProperty(obj, key, {
32
+ value: value,
33
+ enumerable: true,
34
+ configurable: true,
35
+ writable: true
36
+ });
37
+ else obj[key] = value;
38
+ return obj;
39
+ }
40
+ class BroadcastGroupManager {
41
+ createGroup(name, createdBy, description, strategy = "parallel") {
42
+ const id = this.generateGroupId();
43
+ const group = {
44
+ id,
45
+ name,
46
+ description,
47
+ createdAt: Date.now(),
48
+ createdBy,
49
+ members: new Set(),
50
+ strategy
51
+ };
52
+ this.groups.set(id, group);
53
+ return group;
54
+ }
55
+ getGroup(groupId) {
56
+ return this.groups.get(groupId);
57
+ }
58
+ getGroupByName(name) {
59
+ for (const group of this.groups.values())if (group.name === name) return group;
60
+ }
61
+ getOrCreateGroup(name, createdBy, description, strategy = "parallel") {
62
+ const existing = this.getGroupByName(name);
63
+ if (existing) return existing;
64
+ return this.createGroup(name, createdBy, description, strategy);
65
+ }
66
+ setGroupStrategy(groupId, strategy) {
67
+ const group = this.groups.get(groupId);
68
+ if (!group) return false;
69
+ group.strategy = strategy;
70
+ return true;
71
+ }
72
+ getGroupStrategy(groupId) {
73
+ const group = this.groups.get(groupId);
74
+ return group?.strategy;
75
+ }
76
+ deleteGroup(groupId) {
77
+ return this.groups.delete(groupId);
78
+ }
79
+ addNodeToGroup(groupId, nodeId) {
80
+ const group = this.groups.get(groupId);
81
+ if (!group) return false;
82
+ group.members.add(nodeId);
83
+ return true;
84
+ }
85
+ removeNodeFromGroup(groupId, nodeId) {
86
+ const group = this.groups.get(groupId);
87
+ if (!group) return false;
88
+ return group.members.delete(nodeId);
89
+ }
90
+ removeNodeFromAllGroups(nodeId) {
91
+ for (const group of this.groups.values())group.members.delete(nodeId);
92
+ }
93
+ getNodeGroups(nodeId) {
94
+ const nodeGroups = [];
95
+ for (const group of this.groups.values())if (group.members.has(nodeId)) nodeGroups.push(group);
96
+ return nodeGroups;
97
+ }
98
+ getAllGroups() {
99
+ return Array.from(this.groups.values());
100
+ }
101
+ getGroupMembers(groupId) {
102
+ const group = this.groups.get(groupId);
103
+ if (!group) return [];
104
+ return Array.from(group.members);
105
+ }
106
+ generateGroupId() {
107
+ return (0, external_crypto_namespaceObject.randomBytes)(16).toString("hex");
108
+ }
109
+ getStats() {
110
+ return {
111
+ totalGroups: this.groups.size,
112
+ groups: Array.from(this.groups.values()).map((g)=>({
113
+ id: g.id,
114
+ name: g.name,
115
+ memberCount: g.members.size,
116
+ createdAt: g.createdAt
117
+ }))
118
+ };
119
+ }
120
+ constructor(){
121
+ _define_property(this, "groups", void 0);
122
+ this.groups = new Map();
123
+ }
124
+ }
125
+ exports.BroadcastGroupManager = __webpack_exports__.BroadcastGroupManager;
126
+ for(var __rspack_i in __webpack_exports__)if (-1 === [
127
+ "BroadcastGroupManager"
128
+ ].indexOf(__rspack_i)) exports[__rspack_i] = __webpack_exports__[__rspack_i];
129
+ Object.defineProperty(exports, '__esModule', {
130
+ value: true
131
+ });
@@ -0,0 +1,76 @@
1
+ import type { BroadcastGroup, BroadcastStrategy } from "./types.js";
2
+ /**
3
+ * Manages broadcast groups for the gateway
4
+ */
5
+ export declare class BroadcastGroupManager {
6
+ private groups;
7
+ constructor();
8
+ /**
9
+ * Create a new broadcast group
10
+ */
11
+ createGroup(name: string, createdBy: string, description?: string, strategy?: BroadcastStrategy): BroadcastGroup;
12
+ /**
13
+ * Get a group by ID
14
+ */
15
+ getGroup(groupId: string): BroadcastGroup | undefined;
16
+ /**
17
+ * Get a group by name
18
+ */
19
+ getGroupByName(name: string): BroadcastGroup | undefined;
20
+ /**
21
+ * Get or create a group by name
22
+ */
23
+ getOrCreateGroup(name: string, createdBy: string, description?: string, strategy?: BroadcastStrategy): BroadcastGroup;
24
+ /**
25
+ * Update group strategy
26
+ */
27
+ setGroupStrategy(groupId: string, strategy: BroadcastStrategy): boolean;
28
+ /**
29
+ * Get group strategy
30
+ */
31
+ getGroupStrategy(groupId: string): BroadcastStrategy | undefined;
32
+ /**
33
+ * Delete a group
34
+ */
35
+ deleteGroup(groupId: string): boolean;
36
+ /**
37
+ * Add a node to a group
38
+ */
39
+ addNodeToGroup(groupId: string, nodeId: string): boolean;
40
+ /**
41
+ * Remove a node from a group
42
+ */
43
+ removeNodeFromGroup(groupId: string, nodeId: string): boolean;
44
+ /**
45
+ * Remove a node from all groups
46
+ */
47
+ removeNodeFromAllGroups(nodeId: string): void;
48
+ /**
49
+ * Get all groups a node is a member of
50
+ */
51
+ getNodeGroups(nodeId: string): BroadcastGroup[];
52
+ /**
53
+ * Get all groups
54
+ */
55
+ getAllGroups(): BroadcastGroup[];
56
+ /**
57
+ * Get group member IDs
58
+ */
59
+ getGroupMembers(groupId: string): string[];
60
+ /**
61
+ * Generate a unique group ID
62
+ */
63
+ private generateGroupId;
64
+ /**
65
+ * Get statistics
66
+ */
67
+ getStats(): {
68
+ totalGroups: number;
69
+ groups: {
70
+ id: string;
71
+ name: string;
72
+ memberCount: number;
73
+ createdAt: number;
74
+ }[];
75
+ };
76
+ }