wispy-ai 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 (471) hide show
  1. package/.env.example +20 -0
  2. package/LICENSE +21 -0
  3. package/README.md +232 -0
  4. package/bin/wispy.js +3 -0
  5. package/dist/a2a/delegation.d.ts +19 -0
  6. package/dist/a2a/delegation.d.ts.map +1 -0
  7. package/dist/a2a/delegation.js +156 -0
  8. package/dist/a2a/delegation.js.map +1 -0
  9. package/dist/a2a/peer.d.ts +19 -0
  10. package/dist/a2a/peer.d.ts.map +1 -0
  11. package/dist/a2a/peer.js +27 -0
  12. package/dist/a2a/peer.js.map +1 -0
  13. package/dist/a2a/protocol.d.ts +36 -0
  14. package/dist/a2a/protocol.d.ts.map +1 -0
  15. package/dist/a2a/protocol.js +23 -0
  16. package/dist/a2a/protocol.js.map +1 -0
  17. package/dist/agents/collaboration.d.ts +59 -0
  18. package/dist/agents/collaboration.d.ts.map +1 -0
  19. package/dist/agents/collaboration.js +110 -0
  20. package/dist/agents/collaboration.js.map +1 -0
  21. package/dist/agents/orchestrator.d.ts +59 -0
  22. package/dist/agents/orchestrator.d.ts.map +1 -0
  23. package/dist/agents/orchestrator.js +171 -0
  24. package/dist/agents/orchestrator.js.map +1 -0
  25. package/dist/agents/tool-executor.d.ts +36 -0
  26. package/dist/agents/tool-executor.d.ts.map +1 -0
  27. package/dist/agents/tool-executor.js +363 -0
  28. package/dist/agents/tool-executor.js.map +1 -0
  29. package/dist/agents/types/coder.d.ts +10 -0
  30. package/dist/agents/types/coder.d.ts.map +1 -0
  31. package/dist/agents/types/coder.js +43 -0
  32. package/dist/agents/types/coder.js.map +1 -0
  33. package/dist/agents/types/data.d.ts +7 -0
  34. package/dist/agents/types/data.d.ts.map +1 -0
  35. package/dist/agents/types/data.js +30 -0
  36. package/dist/agents/types/data.js.map +1 -0
  37. package/dist/agents/types/designer.d.ts +7 -0
  38. package/dist/agents/types/designer.d.ts.map +1 -0
  39. package/dist/agents/types/designer.js +30 -0
  40. package/dist/agents/types/designer.js.map +1 -0
  41. package/dist/agents/types/devops.d.ts +7 -0
  42. package/dist/agents/types/devops.d.ts.map +1 -0
  43. package/dist/agents/types/devops.js +30 -0
  44. package/dist/agents/types/devops.js.map +1 -0
  45. package/dist/agents/types/planner.d.ts +7 -0
  46. package/dist/agents/types/planner.d.ts.map +1 -0
  47. package/dist/agents/types/planner.js +35 -0
  48. package/dist/agents/types/planner.js.map +1 -0
  49. package/dist/agents/types/researcher.d.ts +10 -0
  50. package/dist/agents/types/researcher.d.ts.map +1 -0
  51. package/dist/agents/types/researcher.js +33 -0
  52. package/dist/agents/types/researcher.js.map +1 -0
  53. package/dist/agents/types/security.d.ts +7 -0
  54. package/dist/agents/types/security.d.ts.map +1 -0
  55. package/dist/agents/types/security.js +30 -0
  56. package/dist/agents/types/security.js.map +1 -0
  57. package/dist/agents/types/writer.d.ts +7 -0
  58. package/dist/agents/types/writer.d.ts.map +1 -0
  59. package/dist/agents/types/writer.js +30 -0
  60. package/dist/agents/types/writer.js.map +1 -0
  61. package/dist/agents/workspace.d.ts +61 -0
  62. package/dist/agents/workspace.d.ts.map +1 -0
  63. package/dist/agents/workspace.js +115 -0
  64. package/dist/agents/workspace.js.map +1 -0
  65. package/dist/ai/embeddings.d.ts +4 -0
  66. package/dist/ai/embeddings.d.ts.map +1 -0
  67. package/dist/ai/embeddings.js +20 -0
  68. package/dist/ai/embeddings.js.map +1 -0
  69. package/dist/ai/gemini.d.ts +31 -0
  70. package/dist/ai/gemini.d.ts.map +1 -0
  71. package/dist/ai/gemini.js +121 -0
  72. package/dist/ai/gemini.js.map +1 -0
  73. package/dist/ai/model-registry.d.ts +73 -0
  74. package/dist/ai/model-registry.d.ts.map +1 -0
  75. package/dist/ai/model-registry.js +86 -0
  76. package/dist/ai/model-registry.js.map +1 -0
  77. package/dist/ai/prompts.d.ts +3 -0
  78. package/dist/ai/prompts.d.ts.map +1 -0
  79. package/dist/ai/prompts.js +42 -0
  80. package/dist/ai/prompts.js.map +1 -0
  81. package/dist/ai/providers/ollama.d.ts +22 -0
  82. package/dist/ai/providers/ollama.d.ts.map +1 -0
  83. package/dist/ai/providers/ollama.js +144 -0
  84. package/dist/ai/providers/ollama.js.map +1 -0
  85. package/dist/ai/providers/openai-compat.d.ts +25 -0
  86. package/dist/ai/providers/openai-compat.d.ts.map +1 -0
  87. package/dist/ai/providers/openai-compat.js +141 -0
  88. package/dist/ai/providers/openai-compat.js.map +1 -0
  89. package/dist/ai/router.d.ts +10 -0
  90. package/dist/ai/router.d.ts.map +1 -0
  91. package/dist/ai/router.js +23 -0
  92. package/dist/ai/router.js.map +1 -0
  93. package/dist/ai/tools.d.ts +15 -0
  94. package/dist/ai/tools.d.ts.map +1 -0
  95. package/dist/ai/tools.js +134 -0
  96. package/dist/ai/tools.js.map +1 -0
  97. package/dist/autostart/service.d.ts +24 -0
  98. package/dist/autostart/service.d.ts.map +1 -0
  99. package/dist/autostart/service.js +202 -0
  100. package/dist/autostart/service.js.map +1 -0
  101. package/dist/channels/dock.d.ts +22 -0
  102. package/dist/channels/dock.d.ts.map +1 -0
  103. package/dist/channels/dock.js +21 -0
  104. package/dist/channels/dock.js.map +1 -0
  105. package/dist/channels/rest/adapter.d.ts +4 -0
  106. package/dist/channels/rest/adapter.d.ts.map +1 -0
  107. package/dist/channels/rest/adapter.js +86 -0
  108. package/dist/channels/rest/adapter.js.map +1 -0
  109. package/dist/channels/telegram/adapter.d.ts +3 -0
  110. package/dist/channels/telegram/adapter.d.ts.map +1 -0
  111. package/dist/channels/telegram/adapter.js +56 -0
  112. package/dist/channels/telegram/adapter.js.map +1 -0
  113. package/dist/cli/commands.d.ts +17 -0
  114. package/dist/cli/commands.d.ts.map +1 -0
  115. package/dist/cli/commands.js +258 -0
  116. package/dist/cli/commands.js.map +1 -0
  117. package/dist/cli/doctor.d.ts +8 -0
  118. package/dist/cli/doctor.d.ts.map +1 -0
  119. package/dist/cli/doctor.js +34 -0
  120. package/dist/cli/doctor.js.map +1 -0
  121. package/dist/cli/history.d.ts +9 -0
  122. package/dist/cli/history.d.ts.map +1 -0
  123. package/dist/cli/history.js +32 -0
  124. package/dist/cli/history.js.map +1 -0
  125. package/dist/cli/postinstall.d.ts +5 -0
  126. package/dist/cli/postinstall.d.ts.map +1 -0
  127. package/dist/cli/postinstall.js +20 -0
  128. package/dist/cli/postinstall.js.map +1 -0
  129. package/dist/cli/program.d.ts +3 -0
  130. package/dist/cli/program.d.ts.map +1 -0
  131. package/dist/cli/program.js +537 -0
  132. package/dist/cli/program.js.map +1 -0
  133. package/dist/cli/repl.d.ts +7 -0
  134. package/dist/cli/repl.d.ts.map +1 -0
  135. package/dist/cli/repl.js +132 -0
  136. package/dist/cli/repl.js.map +1 -0
  137. package/dist/cli/setup/wizard.d.ts +17 -0
  138. package/dist/cli/setup/wizard.d.ts.map +1 -0
  139. package/dist/cli/setup/wizard.js +157 -0
  140. package/dist/cli/setup/wizard.js.map +1 -0
  141. package/dist/cli/ui/banner.d.ts +2 -0
  142. package/dist/cli/ui/banner.d.ts.map +1 -0
  143. package/dist/cli/ui/banner.js +9 -0
  144. package/dist/cli/ui/banner.js.map +1 -0
  145. package/dist/cli/ui/renderer.d.ts +6 -0
  146. package/dist/cli/ui/renderer.d.ts.map +1 -0
  147. package/dist/cli/ui/renderer.js +55 -0
  148. package/dist/cli/ui/renderer.js.map +1 -0
  149. package/dist/cli/ui/spinner.d.ts +7 -0
  150. package/dist/cli/ui/spinner.d.ts.map +1 -0
  151. package/dist/cli/ui/spinner.js +31 -0
  152. package/dist/cli/ui/spinner.js.map +1 -0
  153. package/dist/cli/ui/theme.d.ts +21 -0
  154. package/dist/cli/ui/theme.d.ts.map +1 -0
  155. package/dist/cli/ui/theme.js +28 -0
  156. package/dist/cli/ui/theme.js.map +1 -0
  157. package/dist/cli/ui/tool-display.d.ts +9 -0
  158. package/dist/cli/ui/tool-display.d.ts.map +1 -0
  159. package/dist/cli/ui/tool-display.js +19 -0
  160. package/dist/cli/ui/tool-display.js.map +1 -0
  161. package/dist/cli/voice/stt.d.ts +37 -0
  162. package/dist/cli/voice/stt.d.ts.map +1 -0
  163. package/dist/cli/voice/stt.js +115 -0
  164. package/dist/cli/voice/stt.js.map +1 -0
  165. package/dist/cli/voice/tts.d.ts +35 -0
  166. package/dist/cli/voice/tts.d.ts.map +1 -0
  167. package/dist/cli/voice/tts.js +142 -0
  168. package/dist/cli/voice/tts.js.map +1 -0
  169. package/dist/cli/voice/voice-mode.d.ts +35 -0
  170. package/dist/cli/voice/voice-mode.d.ts.map +1 -0
  171. package/dist/cli/voice/voice-mode.js +89 -0
  172. package/dist/cli/voice/voice-mode.js.map +1 -0
  173. package/dist/config/config.d.ts +5 -0
  174. package/dist/config/config.d.ts.map +1 -0
  175. package/dist/config/config.js +68 -0
  176. package/dist/config/config.js.map +1 -0
  177. package/dist/config/hot-reload.d.ts +3 -0
  178. package/dist/config/hot-reload.d.ts.map +1 -0
  179. package/dist/config/hot-reload.js +21 -0
  180. package/dist/config/hot-reload.js.map +1 -0
  181. package/dist/config/schema.d.ts +48 -0
  182. package/dist/config/schema.d.ts.map +1 -0
  183. package/dist/config/schema.js +105 -0
  184. package/dist/config/schema.js.map +1 -0
  185. package/dist/content/pipeline.d.ts +12 -0
  186. package/dist/content/pipeline.d.ts.map +1 -0
  187. package/dist/content/pipeline.js +55 -0
  188. package/dist/content/pipeline.js.map +1 -0
  189. package/dist/content/publisher.d.ts +26 -0
  190. package/dist/content/publisher.d.ts.map +1 -0
  191. package/dist/content/publisher.js +101 -0
  192. package/dist/content/publisher.js.map +1 -0
  193. package/dist/core/agent.d.ts +37 -0
  194. package/dist/core/agent.d.ts.map +1 -0
  195. package/dist/core/agent.js +170 -0
  196. package/dist/core/agent.js.map +1 -0
  197. package/dist/core/heartbeat.d.ts +15 -0
  198. package/dist/core/heartbeat.d.ts.map +1 -0
  199. package/dist/core/heartbeat.js +70 -0
  200. package/dist/core/heartbeat.js.map +1 -0
  201. package/dist/core/identity.d.ts +13 -0
  202. package/dist/core/identity.d.ts.map +1 -0
  203. package/dist/core/identity.js +16 -0
  204. package/dist/core/identity.js.map +1 -0
  205. package/dist/core/memory.d.ts +11 -0
  206. package/dist/core/memory.d.ts.map +1 -0
  207. package/dist/core/memory.js +58 -0
  208. package/dist/core/memory.js.map +1 -0
  209. package/dist/core/session.d.ts +29 -0
  210. package/dist/core/session.d.ts.map +1 -0
  211. package/dist/core/session.js +59 -0
  212. package/dist/core/session.js.map +1 -0
  213. package/dist/core/thinking.d.ts +3 -0
  214. package/dist/core/thinking.d.ts.map +1 -0
  215. package/dist/core/thinking.js +27 -0
  216. package/dist/core/thinking.js.map +1 -0
  217. package/dist/cron/service.d.ts +24 -0
  218. package/dist/cron/service.d.ts.map +1 -0
  219. package/dist/cron/service.js +74 -0
  220. package/dist/cron/service.js.map +1 -0
  221. package/dist/entry.d.ts +2 -0
  222. package/dist/entry.d.ts.map +1 -0
  223. package/dist/entry.js +26 -0
  224. package/dist/entry.js.map +1 -0
  225. package/dist/gateway/boot.d.ts +9 -0
  226. package/dist/gateway/boot.d.ts.map +1 -0
  227. package/dist/gateway/boot.js +64 -0
  228. package/dist/gateway/boot.js.map +1 -0
  229. package/dist/gateway/client.d.ts +19 -0
  230. package/dist/gateway/client.d.ts.map +1 -0
  231. package/dist/gateway/client.js +64 -0
  232. package/dist/gateway/client.js.map +1 -0
  233. package/dist/gateway/protocol/index.d.ts +41 -0
  234. package/dist/gateway/protocol/index.d.ts.map +1 -0
  235. package/dist/gateway/protocol/index.js +30 -0
  236. package/dist/gateway/protocol/index.js.map +1 -0
  237. package/dist/gateway/server.d.ts +9 -0
  238. package/dist/gateway/server.d.ts.map +1 -0
  239. package/dist/gateway/server.js +147 -0
  240. package/dist/gateway/server.js.map +1 -0
  241. package/dist/index.d.ts +10 -0
  242. package/dist/index.d.ts.map +1 -0
  243. package/dist/index.js +10 -0
  244. package/dist/index.js.map +1 -0
  245. package/dist/infra/dotenv.d.ts +2 -0
  246. package/dist/infra/dotenv.d.ts.map +1 -0
  247. package/dist/infra/dotenv.js +7 -0
  248. package/dist/infra/dotenv.js.map +1 -0
  249. package/dist/infra/logger.d.ts +4 -0
  250. package/dist/infra/logger.d.ts.map +1 -0
  251. package/dist/infra/logger.js +12 -0
  252. package/dist/infra/logger.js.map +1 -0
  253. package/dist/infra/ports.d.ts +2 -0
  254. package/dist/infra/ports.d.ts.map +1 -0
  255. package/dist/infra/ports.js +12 -0
  256. package/dist/infra/ports.js.map +1 -0
  257. package/dist/integrations/ai-models/anthropic.d.ts +15 -0
  258. package/dist/integrations/ai-models/anthropic.d.ts.map +1 -0
  259. package/dist/integrations/ai-models/anthropic.js +91 -0
  260. package/dist/integrations/ai-models/anthropic.js.map +1 -0
  261. package/dist/integrations/ai-models/ollama.d.ts +17 -0
  262. package/dist/integrations/ai-models/ollama.d.ts.map +1 -0
  263. package/dist/integrations/ai-models/ollama.js +113 -0
  264. package/dist/integrations/ai-models/ollama.js.map +1 -0
  265. package/dist/integrations/ai-models/openai.d.ts +19 -0
  266. package/dist/integrations/ai-models/openai.d.ts.map +1 -0
  267. package/dist/integrations/ai-models/openai.js +136 -0
  268. package/dist/integrations/ai-models/openai.js.map +1 -0
  269. package/dist/integrations/base.d.ts +102 -0
  270. package/dist/integrations/base.d.ts.map +1 -0
  271. package/dist/integrations/base.js +44 -0
  272. package/dist/integrations/base.js.map +1 -0
  273. package/dist/integrations/categories.d.ts +13 -0
  274. package/dist/integrations/categories.d.ts.map +1 -0
  275. package/dist/integrations/categories.js +69 -0
  276. package/dist/integrations/categories.js.map +1 -0
  277. package/dist/integrations/chat/discord.d.ts +19 -0
  278. package/dist/integrations/chat/discord.d.ts.map +1 -0
  279. package/dist/integrations/chat/discord.js +122 -0
  280. package/dist/integrations/chat/discord.js.map +1 -0
  281. package/dist/integrations/chat/slack.d.ts +19 -0
  282. package/dist/integrations/chat/slack.d.ts.map +1 -0
  283. package/dist/integrations/chat/slack.js +113 -0
  284. package/dist/integrations/chat/slack.js.map +1 -0
  285. package/dist/integrations/chat/whatsapp.d.ts +18 -0
  286. package/dist/integrations/chat/whatsapp.d.ts.map +1 -0
  287. package/dist/integrations/chat/whatsapp.js +115 -0
  288. package/dist/integrations/chat/whatsapp.js.map +1 -0
  289. package/dist/integrations/credential-manager.d.ts +68 -0
  290. package/dist/integrations/credential-manager.d.ts.map +1 -0
  291. package/dist/integrations/credential-manager.js +156 -0
  292. package/dist/integrations/credential-manager.js.map +1 -0
  293. package/dist/integrations/google/calendar.d.ts +17 -0
  294. package/dist/integrations/google/calendar.d.ts.map +1 -0
  295. package/dist/integrations/google/calendar.js +126 -0
  296. package/dist/integrations/google/calendar.js.map +1 -0
  297. package/dist/integrations/google/docs.d.ts +19 -0
  298. package/dist/integrations/google/docs.d.ts.map +1 -0
  299. package/dist/integrations/google/docs.js +153 -0
  300. package/dist/integrations/google/docs.js.map +1 -0
  301. package/dist/integrations/google/drive.d.ts +17 -0
  302. package/dist/integrations/google/drive.d.ts.map +1 -0
  303. package/dist/integrations/google/drive.js +130 -0
  304. package/dist/integrations/google/drive.js.map +1 -0
  305. package/dist/integrations/google/gmail.d.ts +19 -0
  306. package/dist/integrations/google/gmail.d.ts.map +1 -0
  307. package/dist/integrations/google/gmail.js +124 -0
  308. package/dist/integrations/google/gmail.js.map +1 -0
  309. package/dist/integrations/google/maps.d.ts +20 -0
  310. package/dist/integrations/google/maps.d.ts.map +1 -0
  311. package/dist/integrations/google/maps.js +115 -0
  312. package/dist/integrations/google/maps.js.map +1 -0
  313. package/dist/integrations/google/meet.d.ts +16 -0
  314. package/dist/integrations/google/meet.d.ts.map +1 -0
  315. package/dist/integrations/google/meet.js +104 -0
  316. package/dist/integrations/google/meet.js.map +1 -0
  317. package/dist/integrations/google/oauth.d.ts +39 -0
  318. package/dist/integrations/google/oauth.d.ts.map +1 -0
  319. package/dist/integrations/google/oauth.js +134 -0
  320. package/dist/integrations/google/oauth.js.map +1 -0
  321. package/dist/integrations/google/search.d.ts +15 -0
  322. package/dist/integrations/google/search.d.ts.map +1 -0
  323. package/dist/integrations/google/search.js +66 -0
  324. package/dist/integrations/google/search.js.map +1 -0
  325. package/dist/integrations/google/sheets.d.ts +17 -0
  326. package/dist/integrations/google/sheets.d.ts.map +1 -0
  327. package/dist/integrations/google/sheets.js +118 -0
  328. package/dist/integrations/google/sheets.js.map +1 -0
  329. package/dist/integrations/google/youtube.d.ts +19 -0
  330. package/dist/integrations/google/youtube.d.ts.map +1 -0
  331. package/dist/integrations/google/youtube.js +128 -0
  332. package/dist/integrations/google/youtube.js.map +1 -0
  333. package/dist/integrations/loader.d.ts +15 -0
  334. package/dist/integrations/loader.d.ts.map +1 -0
  335. package/dist/integrations/loader.js +97 -0
  336. package/dist/integrations/loader.js.map +1 -0
  337. package/dist/integrations/music/spotify.d.ts +21 -0
  338. package/dist/integrations/music/spotify.d.ts.map +1 -0
  339. package/dist/integrations/music/spotify.js +161 -0
  340. package/dist/integrations/music/spotify.js.map +1 -0
  341. package/dist/integrations/productivity/github.d.ts +20 -0
  342. package/dist/integrations/productivity/github.d.ts.map +1 -0
  343. package/dist/integrations/productivity/github.js +146 -0
  344. package/dist/integrations/productivity/github.js.map +1 -0
  345. package/dist/integrations/productivity/linear.d.ts +19 -0
  346. package/dist/integrations/productivity/linear.d.ts.map +1 -0
  347. package/dist/integrations/productivity/linear.js +152 -0
  348. package/dist/integrations/productivity/linear.js.map +1 -0
  349. package/dist/integrations/productivity/notion.d.ts +20 -0
  350. package/dist/integrations/productivity/notion.d.ts.map +1 -0
  351. package/dist/integrations/productivity/notion.js +186 -0
  352. package/dist/integrations/productivity/notion.js.map +1 -0
  353. package/dist/integrations/productivity/obsidian.d.ts +21 -0
  354. package/dist/integrations/productivity/obsidian.d.ts.map +1 -0
  355. package/dist/integrations/productivity/obsidian.js +141 -0
  356. package/dist/integrations/productivity/obsidian.js.map +1 -0
  357. package/dist/integrations/registry.d.ts +78 -0
  358. package/dist/integrations/registry.d.ts.map +1 -0
  359. package/dist/integrations/registry.js +193 -0
  360. package/dist/integrations/registry.js.map +1 -0
  361. package/dist/integrations/smart-home/homeassistant.d.ts +21 -0
  362. package/dist/integrations/smart-home/homeassistant.d.ts.map +1 -0
  363. package/dist/integrations/smart-home/homeassistant.js +129 -0
  364. package/dist/integrations/smart-home/homeassistant.js.map +1 -0
  365. package/dist/integrations/smart-home/hue.d.ts +23 -0
  366. package/dist/integrations/smart-home/hue.d.ts.map +1 -0
  367. package/dist/integrations/smart-home/hue.js +144 -0
  368. package/dist/integrations/smart-home/hue.js.map +1 -0
  369. package/dist/integrations/social/email-smtp.d.ts +23 -0
  370. package/dist/integrations/social/email-smtp.d.ts.map +1 -0
  371. package/dist/integrations/social/email-smtp.js +168 -0
  372. package/dist/integrations/social/email-smtp.js.map +1 -0
  373. package/dist/integrations/social/twitter.d.ts +28 -0
  374. package/dist/integrations/social/twitter.d.ts.map +1 -0
  375. package/dist/integrations/social/twitter.js +168 -0
  376. package/dist/integrations/social/twitter.js.map +1 -0
  377. package/dist/integrations/tools/browser.d.ts +18 -0
  378. package/dist/integrations/tools/browser.d.ts.map +1 -0
  379. package/dist/integrations/tools/browser.js +131 -0
  380. package/dist/integrations/tools/browser.js.map +1 -0
  381. package/dist/integrations/tools/weather.d.ts +17 -0
  382. package/dist/integrations/tools/weather.d.ts.map +1 -0
  383. package/dist/integrations/tools/weather.js +113 -0
  384. package/dist/integrations/tools/weather.js.map +1 -0
  385. package/dist/integrations/tools/webhooks.d.ts +15 -0
  386. package/dist/integrations/tools/webhooks.d.ts.map +1 -0
  387. package/dist/integrations/tools/webhooks.js +89 -0
  388. package/dist/integrations/tools/webhooks.js.map +1 -0
  389. package/dist/mcp/client.d.ts +42 -0
  390. package/dist/mcp/client.d.ts.map +1 -0
  391. package/dist/mcp/client.js +164 -0
  392. package/dist/mcp/client.js.map +1 -0
  393. package/dist/mcp/server.d.ts +2 -0
  394. package/dist/mcp/server.d.ts.map +1 -0
  395. package/dist/mcp/server.js +114 -0
  396. package/dist/mcp/server.js.map +1 -0
  397. package/dist/mcp/tools-adapter.d.ts +14 -0
  398. package/dist/mcp/tools-adapter.d.ts.map +1 -0
  399. package/dist/mcp/tools-adapter.js +133 -0
  400. package/dist/mcp/tools-adapter.js.map +1 -0
  401. package/dist/memory/manager.d.ts +14 -0
  402. package/dist/memory/manager.d.ts.map +1 -0
  403. package/dist/memory/manager.js +49 -0
  404. package/dist/memory/manager.js.map +1 -0
  405. package/dist/memory/vector-store.d.ts +17 -0
  406. package/dist/memory/vector-store.d.ts.map +1 -0
  407. package/dist/memory/vector-store.js +65 -0
  408. package/dist/memory/vector-store.js.map +1 -0
  409. package/dist/security/action-guard.d.ts +12 -0
  410. package/dist/security/action-guard.d.ts.map +1 -0
  411. package/dist/security/action-guard.js +37 -0
  412. package/dist/security/action-guard.js.map +1 -0
  413. package/dist/security/api-key-guard.d.ts +3 -0
  414. package/dist/security/api-key-guard.d.ts.map +1 -0
  415. package/dist/security/api-key-guard.js +36 -0
  416. package/dist/security/api-key-guard.js.map +1 -0
  417. package/dist/security/auth.d.ts +17 -0
  418. package/dist/security/auth.d.ts.map +1 -0
  419. package/dist/security/auth.js +31 -0
  420. package/dist/security/auth.js.map +1 -0
  421. package/dist/security/device-identity.d.ts +11 -0
  422. package/dist/security/device-identity.d.ts.map +1 -0
  423. package/dist/security/device-identity.js +64 -0
  424. package/dist/security/device-identity.js.map +1 -0
  425. package/dist/security/encryption.d.ts +5 -0
  426. package/dist/security/encryption.d.ts.map +1 -0
  427. package/dist/security/encryption.js +13 -0
  428. package/dist/security/encryption.js.map +1 -0
  429. package/dist/security/isolation.d.ts +11 -0
  430. package/dist/security/isolation.d.ts.map +1 -0
  431. package/dist/security/isolation.js +37 -0
  432. package/dist/security/isolation.js.map +1 -0
  433. package/dist/skills/loader.d.ts +17 -0
  434. package/dist/skills/loader.d.ts.map +1 -0
  435. package/dist/skills/loader.js +68 -0
  436. package/dist/skills/loader.js.map +1 -0
  437. package/dist/token/estimator.d.ts +72 -0
  438. package/dist/token/estimator.d.ts.map +1 -0
  439. package/dist/token/estimator.js +165 -0
  440. package/dist/token/estimator.js.map +1 -0
  441. package/dist/utils/crypto.d.ts +4 -0
  442. package/dist/utils/crypto.d.ts.map +1 -0
  443. package/dist/utils/crypto.js +28 -0
  444. package/dist/utils/crypto.js.map +1 -0
  445. package/dist/utils/file.d.ts +14 -0
  446. package/dist/utils/file.d.ts.map +1 -0
  447. package/dist/utils/file.js +54 -0
  448. package/dist/utils/file.js.map +1 -0
  449. package/dist/utils/media.d.ts +6 -0
  450. package/dist/utils/media.d.ts.map +1 -0
  451. package/dist/utils/media.js +65 -0
  452. package/dist/utils/media.js.map +1 -0
  453. package/dist/wallet/x402.d.ts +22 -0
  454. package/dist/wallet/x402.d.ts.map +1 -0
  455. package/dist/wallet/x402.js +63 -0
  456. package/dist/wallet/x402.js.map +1 -0
  457. package/package.json +79 -0
  458. package/wispy/AGENTS.md +46 -0
  459. package/wispy/BOOT.md +28 -0
  460. package/wispy/CONTEXT.md +13 -0
  461. package/wispy/HEARTBEAT.md +17 -0
  462. package/wispy/IDENTITY.md +26 -0
  463. package/wispy/MEMORY.md +16 -0
  464. package/wispy/SOUL.md +35 -0
  465. package/wispy/TOOLS.md +45 -0
  466. package/wispy/USER.md +16 -0
  467. package/wispy/skills/a2a-delegate/SKILL.md +14 -0
  468. package/wispy/skills/content-creator/SKILL.md +14 -0
  469. package/wispy/skills/image-gen/SKILL.md +14 -0
  470. package/wispy/skills/wallet-ops/SKILL.md +14 -0
  471. package/wispy/skills/x-poster/SKILL.md +11 -0
@@ -0,0 +1,37 @@
1
+ const PERMISSIONS = {
2
+ main: {
3
+ canAccessMemory: true,
4
+ canAccessMainHistory: true,
5
+ canUseWallet: true,
6
+ canSendExternal: true,
7
+ canAccessPersonalInfo: true,
8
+ },
9
+ cron: {
10
+ canAccessMemory: false,
11
+ canAccessMainHistory: false,
12
+ canUseWallet: false,
13
+ canSendExternal: true,
14
+ canAccessPersonalInfo: false,
15
+ },
16
+ group: {
17
+ canAccessMemory: false,
18
+ canAccessMainHistory: false,
19
+ canUseWallet: false,
20
+ canSendExternal: true,
21
+ canAccessPersonalInfo: false,
22
+ },
23
+ sub: {
24
+ canAccessMemory: false,
25
+ canAccessMainHistory: false,
26
+ canUseWallet: false,
27
+ canSendExternal: false,
28
+ canAccessPersonalInfo: false,
29
+ },
30
+ };
31
+ export function getPermissions(sessionType) {
32
+ return PERMISSIONS[sessionType];
33
+ }
34
+ export function buildSessionKey(agentId, sessionType, peerId) {
35
+ return `agent:${agentId}:${sessionType}:${peerId}`;
36
+ }
37
+ //# sourceMappingURL=isolation.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"isolation.js","sourceRoot":"","sources":["../../src/security/isolation.ts"],"names":[],"mappings":"AAUA,MAAM,WAAW,GAA4C;IAC3D,IAAI,EAAE;QACJ,eAAe,EAAE,IAAI;QACrB,oBAAoB,EAAE,IAAI;QAC1B,YAAY,EAAE,IAAI;QAClB,eAAe,EAAE,IAAI;QACrB,qBAAqB,EAAE,IAAI;KAC5B;IACD,IAAI,EAAE;QACJ,eAAe,EAAE,KAAK;QACtB,oBAAoB,EAAE,KAAK;QAC3B,YAAY,EAAE,KAAK;QACnB,eAAe,EAAE,IAAI;QACrB,qBAAqB,EAAE,KAAK;KAC7B;IACD,KAAK,EAAE;QACL,eAAe,EAAE,KAAK;QACtB,oBAAoB,EAAE,KAAK;QAC3B,YAAY,EAAE,KAAK;QACnB,eAAe,EAAE,IAAI;QACrB,qBAAqB,EAAE,KAAK;KAC7B;IACD,GAAG,EAAE;QACH,eAAe,EAAE,KAAK;QACtB,oBAAoB,EAAE,KAAK;QAC3B,YAAY,EAAE,KAAK;QACnB,eAAe,EAAE,KAAK;QACtB,qBAAqB,EAAE,KAAK;KAC7B;CACF,CAAC;AAEF,MAAM,UAAU,cAAc,CAAC,WAAwB;IACrD,OAAO,WAAW,CAAC,WAAW,CAAC,CAAC;AAClC,CAAC;AAED,MAAM,UAAU,eAAe,CAC7B,OAAe,EACf,WAAwB,EACxB,MAAc;IAEd,OAAO,SAAS,OAAO,IAAI,WAAW,IAAI,MAAM,EAAE,CAAC;AACrD,CAAC"}
@@ -0,0 +1,17 @@
1
+ export interface SkillManifest {
2
+ name: string;
3
+ description: string;
4
+ version: string;
5
+ author?: string;
6
+ tools: Array<{
7
+ name: string;
8
+ description: string;
9
+ parameters: Record<string, unknown>;
10
+ }>;
11
+ requires?: {
12
+ env?: string[];
13
+ bins?: string[];
14
+ };
15
+ }
16
+ export declare function loadSkills(soulDir: string): SkillManifest[];
17
+ //# sourceMappingURL=loader.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"loader.d.ts","sourceRoot":"","sources":["../../src/skills/loader.ts"],"names":[],"mappings":"AAOA,MAAM,WAAW,aAAa;IAC5B,IAAI,EAAE,MAAM,CAAC;IACb,WAAW,EAAE,MAAM,CAAC;IACpB,OAAO,EAAE,MAAM,CAAC;IAChB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,KAAK,EAAE,KAAK,CAAC;QACX,IAAI,EAAE,MAAM,CAAC;QACb,WAAW,EAAE,MAAM,CAAC;QACpB,UAAU,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;KACrC,CAAC,CAAC;IACH,QAAQ,CAAC,EAAE;QACT,GAAG,CAAC,EAAE,MAAM,EAAE,CAAC;QACf,IAAI,CAAC,EAAE,MAAM,EAAE,CAAC;KACjB,CAAC;CACH;AAED,wBAAgB,UAAU,CAAC,OAAO,EAAE,MAAM,GAAG,aAAa,EAAE,CAuB3D"}
@@ -0,0 +1,68 @@
1
+ import { readdirSync, existsSync } from "fs";
2
+ import { resolve } from "path";
3
+ import { readMD } from "../utils/file.js";
4
+ import { createLogger } from "../infra/logger.js";
5
+ const log = createLogger("skill-loader");
6
+ export function loadSkills(soulDir) {
7
+ const skillsDir = resolve(soulDir, "skills");
8
+ if (!existsSync(skillsDir))
9
+ return [];
10
+ const skills = [];
11
+ const dirs = readdirSync(skillsDir, { withFileTypes: true })
12
+ .filter((d) => d.isDirectory());
13
+ for (const dir of dirs) {
14
+ const skillPath = resolve(skillsDir, dir.name, "SKILL.md");
15
+ const content = readMD(skillPath);
16
+ if (!content)
17
+ continue;
18
+ try {
19
+ const manifest = parseSkillMd(content, dir.name);
20
+ skills.push(manifest);
21
+ log.info("Loaded skill: %s", manifest.name);
22
+ }
23
+ catch (err) {
24
+ log.warn("Failed to parse skill %s: %s", dir.name, err);
25
+ }
26
+ }
27
+ return skills;
28
+ }
29
+ function parseSkillMd(content, dirName) {
30
+ // Parse frontmatter-style SKILL.md
31
+ const lines = content.split("\n");
32
+ const manifest = {
33
+ name: dirName,
34
+ description: "",
35
+ version: "0.1.0",
36
+ tools: [],
37
+ };
38
+ let inTools = false;
39
+ let currentTool = null;
40
+ for (const line of lines) {
41
+ if (line.startsWith("# ")) {
42
+ manifest.name = line.slice(2).trim();
43
+ }
44
+ else if (line.startsWith("## Description")) {
45
+ // Next non-empty line is description
46
+ }
47
+ else if (line.startsWith("## Tools")) {
48
+ inTools = true;
49
+ }
50
+ else if (inTools && line.startsWith("### ")) {
51
+ if (currentTool)
52
+ manifest.tools.push(currentTool);
53
+ currentTool = { name: line.slice(4).trim(), description: "", parameters: {} };
54
+ }
55
+ else if (currentTool && line.trim() && !line.startsWith("#")) {
56
+ if (!currentTool.description) {
57
+ currentTool.description = line.trim();
58
+ }
59
+ }
60
+ else if (!line.startsWith("#") && line.trim() && !inTools && !manifest.description) {
61
+ manifest.description = line.trim();
62
+ }
63
+ }
64
+ if (currentTool)
65
+ manifest.tools.push(currentTool);
66
+ return manifest;
67
+ }
68
+ //# sourceMappingURL=loader.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"loader.js","sourceRoot":"","sources":["../../src/skills/loader.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,72 @@
1
+ /**
2
+ * Token estimation and budget management.
3
+ *
4
+ * Solves the #1 complaint with agent platforms: excessive token usage.
5
+ * Estimates tokens before sending, enforces budgets, and optimizes context.
6
+ */
7
+ interface TokenEstimate {
8
+ inputTokens: number;
9
+ estimatedOutputTokens: number;
10
+ totalTokens: number;
11
+ estimatedCostUsd: number;
12
+ withinBudget: boolean;
13
+ model: string;
14
+ }
15
+ export interface TokenBudget {
16
+ maxTokensPerRequest: number;
17
+ maxTokensPerSession: number;
18
+ maxTokensPerDay: number;
19
+ warnAtPercentage: number;
20
+ }
21
+ export declare class TokenManager {
22
+ private budget;
23
+ private sessionUsage;
24
+ private dailyUsage;
25
+ constructor(budget?: Partial<TokenBudget>);
26
+ /**
27
+ * Estimate token count for a string using character-based approximation.
28
+ * More accurate than most heuristics for English/code mixed content.
29
+ */
30
+ estimateTokens(text: string): number;
31
+ /**
32
+ * Estimate tokens for a full request (system prompt + messages + tools).
33
+ */
34
+ estimateRequest(model: string, systemPrompt: string, messages: Array<{
35
+ role: string;
36
+ content: string;
37
+ }>, toolDeclarations?: unknown[]): TokenEstimate;
38
+ /**
39
+ * Record actual token usage after a request completes.
40
+ */
41
+ recordUsage(model: string, inputTokens: number, outputTokens: number): void;
42
+ /**
43
+ * Apply context windowing: trim message history to fit within token budget.
44
+ * Keeps system prompt + most recent messages that fit.
45
+ */
46
+ windowMessages(messages: Array<{
47
+ role: string;
48
+ content: string;
49
+ }>, maxTokens: number, systemPromptTokens: number): Array<{
50
+ role: string;
51
+ content: string;
52
+ }>;
53
+ /**
54
+ * Recommend the cheapest model that can handle the task.
55
+ */
56
+ recommendModel(inputTokens: number, requiresTools: boolean, requiresThinking: boolean): string;
57
+ getSessionTotal(): number;
58
+ getDailyTotal(): number;
59
+ getSessionCost(): number;
60
+ getDailyCost(): number;
61
+ getStats(): {
62
+ sessionTokens: number;
63
+ sessionCost: number;
64
+ dailyTokens: number;
65
+ dailyCost: number;
66
+ requestCount: number;
67
+ budget: TokenBudget;
68
+ };
69
+ resetSession(): void;
70
+ }
71
+ export {};
72
+ //# sourceMappingURL=estimator.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"estimator.d.ts","sourceRoot":"","sources":["../../src/token/estimator.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AA2BH,UAAU,aAAa;IACrB,WAAW,EAAE,MAAM,CAAC;IACpB,qBAAqB,EAAE,MAAM,CAAC;IAC9B,WAAW,EAAE,MAAM,CAAC;IACpB,gBAAgB,EAAE,MAAM,CAAC;IACzB,YAAY,EAAE,OAAO,CAAC;IACtB,KAAK,EAAE,MAAM,CAAC;CACf;AAUD,MAAM,WAAW,WAAW;IAC1B,mBAAmB,EAAE,MAAM,CAAC;IAC5B,mBAAmB,EAAE,MAAM,CAAC;IAC5B,eAAe,EAAE,MAAM,CAAC;IACxB,gBAAgB,EAAE,MAAM,CAAC;CAC1B;AASD,qBAAa,YAAY;IACvB,OAAO,CAAC,MAAM,CAAc;IAC5B,OAAO,CAAC,YAAY,CAAoB;IACxC,OAAO,CAAC,UAAU,CAAoB;gBAE1B,MAAM,CAAC,EAAE,OAAO,CAAC,WAAW,CAAC;IAIzC;;;OAGG;IACH,cAAc,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM;IAKpC;;OAEG;IACH,eAAe,CACb,KAAK,EAAE,MAAM,EACb,YAAY,EAAE,MAAM,EACpB,QAAQ,EAAE,KAAK,CAAC;QAAE,IAAI,EAAE,MAAM,CAAC;QAAC,OAAO,EAAE,MAAM,CAAA;KAAE,CAAC,EAClD,gBAAgB,CAAC,EAAE,OAAO,EAAE,GAC3B,aAAa;IA+DhB;;OAEG;IACH,WAAW,CAAC,KAAK,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,GAAG,IAAI;IA0B3E;;;OAGG;IACH,cAAc,CACZ,QAAQ,EAAE,KAAK,CAAC;QAAE,IAAI,EAAE,MAAM,CAAC;QAAC,OAAO,EAAE,MAAM,CAAA;KAAE,CAAC,EAClD,SAAS,EAAE,MAAM,EACjB,kBAAkB,EAAE,MAAM,GACzB,KAAK,CAAC;QAAE,IAAI,EAAE,MAAM,CAAC;QAAC,OAAO,EAAE,MAAM,CAAA;KAAE,CAAC;IAyB3C;;OAEG;IACH,cAAc,CACZ,WAAW,EAAE,MAAM,EACnB,aAAa,EAAE,OAAO,EACtB,gBAAgB,EAAE,OAAO,GACxB,MAAM;IAUT,eAAe,IAAI,MAAM;IAIzB,aAAa,IAAI,MAAM;IAOvB,cAAc,IAAI,MAAM;IAIxB,YAAY,IAAI,MAAM;IAOtB,QAAQ,IAAI;QACV,aAAa,EAAE,MAAM,CAAC;QACtB,WAAW,EAAE,MAAM,CAAC;QACpB,WAAW,EAAE,MAAM,CAAC;QACpB,SAAS,EAAE,MAAM,CAAC;QAClB,YAAY,EAAE,MAAM,CAAC;QACrB,MAAM,EAAE,WAAW,CAAC;KACrB;IAWD,YAAY,IAAI,IAAI;CAGrB"}
@@ -0,0 +1,165 @@
1
+ /**
2
+ * Token estimation and budget management.
3
+ *
4
+ * Solves the #1 complaint with agent platforms: excessive token usage.
5
+ * Estimates tokens before sending, enforces budgets, and optimizes context.
6
+ */
7
+ import { createLogger } from "../infra/logger.js";
8
+ const log = createLogger("token");
9
+ /** Approximate tokens per character ratio for English text. */
10
+ const CHARS_PER_TOKEN = 4;
11
+ /** Model context limits and pricing (per 1M tokens). */
12
+ const MODEL_SPECS = {
13
+ "gemini-2.5-pro": { contextWindow: 1_000_000, inputCostPer1M: 1.25, outputCostPer1M: 10.0 },
14
+ "gemini-2.5-flash": { contextWindow: 1_000_000, inputCostPer1M: 0.15, outputCostPer1M: 0.60 },
15
+ "gemini-2.0-flash": { contextWindow: 1_000_000, inputCostPer1M: 0.10, outputCostPer1M: 0.40 },
16
+ "gemma-3-27b": { contextWindow: 128_000, inputCostPer1M: 0, outputCostPer1M: 0 },
17
+ "gemma-3-12b": { contextWindow: 128_000, inputCostPer1M: 0, outputCostPer1M: 0 },
18
+ "gpt-4o": { contextWindow: 128_000, inputCostPer1M: 2.50, outputCostPer1M: 10.0 },
19
+ "claude-opus-4": { contextWindow: 200_000, inputCostPer1M: 15.0, outputCostPer1M: 75.0 },
20
+ "claude-sonnet-4": { contextWindow: 200_000, inputCostPer1M: 3.0, outputCostPer1M: 15.0 },
21
+ };
22
+ const DEFAULT_BUDGET = {
23
+ maxTokensPerRequest: 100_000,
24
+ maxTokensPerSession: 500_000,
25
+ maxTokensPerDay: 2_000_000,
26
+ warnAtPercentage: 80,
27
+ };
28
+ export class TokenManager {
29
+ budget;
30
+ sessionUsage = [];
31
+ dailyUsage = [];
32
+ constructor(budget) {
33
+ this.budget = { ...DEFAULT_BUDGET, ...budget };
34
+ }
35
+ /**
36
+ * Estimate token count for a string using character-based approximation.
37
+ * More accurate than most heuristics for English/code mixed content.
38
+ */
39
+ estimateTokens(text) {
40
+ if (!text)
41
+ return 0;
42
+ return Math.ceil(text.length / CHARS_PER_TOKEN);
43
+ }
44
+ /**
45
+ * Estimate tokens for a full request (system prompt + messages + tools).
46
+ */
47
+ estimateRequest(model, systemPrompt, messages, toolDeclarations) {
48
+ const spec = MODEL_SPECS[model] || MODEL_SPECS["gemini-2.5-pro"];
49
+ let inputTokens = this.estimateTokens(systemPrompt);
50
+ for (const msg of messages) {
51
+ inputTokens += this.estimateTokens(msg.content) + 4; // role overhead
52
+ }
53
+ if (toolDeclarations) {
54
+ inputTokens += this.estimateTokens(JSON.stringify(toolDeclarations));
55
+ }
56
+ // Estimate output as 25% of input (typical for conversational AI)
57
+ const estimatedOutputTokens = Math.min(Math.ceil(inputTokens * 0.25), 8192);
58
+ const totalTokens = inputTokens + estimatedOutputTokens;
59
+ const estimatedCostUsd = (inputTokens / 1_000_000) * spec.inputCostPer1M +
60
+ (estimatedOutputTokens / 1_000_000) * spec.outputCostPer1M;
61
+ const sessionTotal = this.getSessionTotal() + totalTokens;
62
+ const dailyTotal = this.getDailyTotal() + totalTokens;
63
+ const withinBudget = totalTokens <= this.budget.maxTokensPerRequest &&
64
+ sessionTotal <= this.budget.maxTokensPerSession &&
65
+ dailyTotal <= this.budget.maxTokensPerDay;
66
+ if (!withinBudget) {
67
+ log.warn("Token budget exceeded: request=%d, session=%d/%d, daily=%d/%d", totalTokens, sessionTotal, this.budget.maxTokensPerSession, dailyTotal, this.budget.maxTokensPerDay);
68
+ }
69
+ const warnThreshold = this.budget.maxTokensPerDay * (this.budget.warnAtPercentage / 100);
70
+ if (dailyTotal > warnThreshold) {
71
+ log.warn("Token usage at %d%% of daily budget (%d/%d)", Math.round((dailyTotal / this.budget.maxTokensPerDay) * 100), dailyTotal, this.budget.maxTokensPerDay);
72
+ }
73
+ return {
74
+ inputTokens,
75
+ estimatedOutputTokens,
76
+ totalTokens,
77
+ estimatedCostUsd,
78
+ withinBudget,
79
+ model,
80
+ };
81
+ }
82
+ /**
83
+ * Record actual token usage after a request completes.
84
+ */
85
+ recordUsage(model, inputTokens, outputTokens) {
86
+ const spec = MODEL_SPECS[model] || MODEL_SPECS["gemini-2.5-pro"];
87
+ const costUsd = (inputTokens / 1_000_000) * spec.inputCostPer1M +
88
+ (outputTokens / 1_000_000) * spec.outputCostPer1M;
89
+ const usage = {
90
+ inputTokens,
91
+ outputTokens,
92
+ totalTokens: inputTokens + outputTokens,
93
+ costUsd,
94
+ timestamp: new Date().toISOString(),
95
+ };
96
+ this.sessionUsage.push(usage);
97
+ this.dailyUsage.push(usage);
98
+ log.debug("Token usage: in=%d out=%d total=%d cost=$%s", inputTokens, outputTokens, usage.totalTokens, costUsd.toFixed(4));
99
+ }
100
+ /**
101
+ * Apply context windowing: trim message history to fit within token budget.
102
+ * Keeps system prompt + most recent messages that fit.
103
+ */
104
+ windowMessages(messages, maxTokens, systemPromptTokens) {
105
+ const available = maxTokens - systemPromptTokens - 2000; // reserve for output
106
+ let used = 0;
107
+ const windowed = [];
108
+ // Always include the most recent message
109
+ for (let i = messages.length - 1; i >= 0; i--) {
110
+ const tokens = this.estimateTokens(messages[i].content) + 4;
111
+ if (used + tokens > available && windowed.length > 0)
112
+ break;
113
+ used += tokens;
114
+ windowed.unshift(messages[i]);
115
+ }
116
+ if (windowed.length < messages.length) {
117
+ log.debug("Context windowed: %d → %d messages (%d tokens)", messages.length, windowed.length, used);
118
+ }
119
+ return windowed;
120
+ }
121
+ /**
122
+ * Recommend the cheapest model that can handle the task.
123
+ */
124
+ recommendModel(inputTokens, requiresTools, requiresThinking) {
125
+ if (requiresThinking || inputTokens > 50_000) {
126
+ return "gemini-2.5-pro";
127
+ }
128
+ if (!requiresTools && inputTokens < 5_000) {
129
+ return "gemini-2.5-flash";
130
+ }
131
+ return "gemini-2.5-flash";
132
+ }
133
+ getSessionTotal() {
134
+ return this.sessionUsage.reduce((sum, u) => sum + u.totalTokens, 0);
135
+ }
136
+ getDailyTotal() {
137
+ const today = new Date().toISOString().slice(0, 10);
138
+ return this.dailyUsage
139
+ .filter((u) => u.timestamp.startsWith(today))
140
+ .reduce((sum, u) => sum + u.totalTokens, 0);
141
+ }
142
+ getSessionCost() {
143
+ return this.sessionUsage.reduce((sum, u) => sum + u.costUsd, 0);
144
+ }
145
+ getDailyCost() {
146
+ const today = new Date().toISOString().slice(0, 10);
147
+ return this.dailyUsage
148
+ .filter((u) => u.timestamp.startsWith(today))
149
+ .reduce((sum, u) => sum + u.costUsd, 0);
150
+ }
151
+ getStats() {
152
+ return {
153
+ sessionTokens: this.getSessionTotal(),
154
+ sessionCost: this.getSessionCost(),
155
+ dailyTokens: this.getDailyTotal(),
156
+ dailyCost: this.getDailyCost(),
157
+ requestCount: this.sessionUsage.length,
158
+ budget: this.budget,
159
+ };
160
+ }
161
+ resetSession() {
162
+ this.sessionUsage = [];
163
+ }
164
+ }
165
+ //# sourceMappingURL=estimator.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"estimator.js","sourceRoot":"","sources":["../../src/token/estimator.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,4 @@
1
+ export declare function encrypt(plaintext: string, key: Buffer): string;
2
+ export declare function decrypt(encoded: string, key: Buffer): string;
3
+ export declare function deriveKey(secret: Buffer): Buffer;
4
+ //# sourceMappingURL=crypto.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"crypto.d.ts","sourceRoot":"","sources":["../../src/utils/crypto.ts"],"names":[],"mappings":"AAIA,wBAAgB,OAAO,CAAC,SAAS,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,GAAG,MAAM,CAS9D;AAED,wBAAgB,OAAO,CAAC,OAAO,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,GAAG,MAAM,CAW5D;AAED,wBAAgB,SAAS,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,CAEhD"}
@@ -0,0 +1,28 @@
1
+ import { randomBytes, createCipheriv, createDecipheriv, createHash } from "crypto";
2
+ const ALGO = "aes-256-gcm";
3
+ export function encrypt(plaintext, key) {
4
+ const iv = randomBytes(12);
5
+ const cipher = createCipheriv(ALGO, key, iv);
6
+ const encrypted = Buffer.concat([
7
+ cipher.update(plaintext, "utf8"),
8
+ cipher.final(),
9
+ ]);
10
+ const tag = cipher.getAuthTag();
11
+ return Buffer.concat([iv, tag, encrypted]).toString("base64");
12
+ }
13
+ export function decrypt(encoded, key) {
14
+ const buf = Buffer.from(encoded, "base64");
15
+ const iv = buf.subarray(0, 12);
16
+ const tag = buf.subarray(12, 28);
17
+ const encrypted = buf.subarray(28);
18
+ const decipher = createDecipheriv(ALGO, key, iv);
19
+ decipher.setAuthTag(tag);
20
+ return Buffer.concat([
21
+ decipher.update(encrypted),
22
+ decipher.final(),
23
+ ]).toString("utf8");
24
+ }
25
+ export function deriveKey(secret) {
26
+ return createHash("sha256").update(secret).digest();
27
+ }
28
+ //# sourceMappingURL=crypto.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"crypto.js","sourceRoot":"","sources":["../../src/utils/crypto.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,cAAc,EAAE,gBAAgB,EAAE,UAAU,EAAE,MAAM,QAAQ,CAAC;AAEnF,MAAM,IAAI,GAAG,aAAa,CAAC;AAE3B,MAAM,UAAU,OAAO,CAAC,SAAiB,EAAE,GAAW;IACpD,MAAM,EAAE,GAAG,WAAW,CAAC,EAAE,CAAC,CAAC;IAC3B,MAAM,MAAM,GAAG,cAAc,CAAC,IAAI,EAAE,GAAG,EAAE,EAAE,CAAC,CAAC;IAC7C,MAAM,SAAS,GAAG,MAAM,CAAC,MAAM,CAAC;QAC9B,MAAM,CAAC,MAAM,CAAC,SAAS,EAAE,MAAM,CAAC;QAChC,MAAM,CAAC,KAAK,EAAE;KACf,CAAC,CAAC;IACH,MAAM,GAAG,GAAG,MAAM,CAAC,UAAU,EAAE,CAAC;IAChC,OAAO,MAAM,CAAC,MAAM,CAAC,CAAC,EAAE,EAAE,GAAG,EAAE,SAAS,CAAC,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;AAChE,CAAC;AAED,MAAM,UAAU,OAAO,CAAC,OAAe,EAAE,GAAW;IAClD,MAAM,GAAG,GAAG,MAAM,CAAC,IAAI,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAC;IAC3C,MAAM,EAAE,GAAG,GAAG,CAAC,QAAQ,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;IAC/B,MAAM,GAAG,GAAG,GAAG,CAAC,QAAQ,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC;IACjC,MAAM,SAAS,GAAG,GAAG,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;IACnC,MAAM,QAAQ,GAAG,gBAAgB,CAAC,IAAI,EAAE,GAAG,EAAE,EAAE,CAAC,CAAC;IACjD,QAAQ,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC;IACzB,OAAO,MAAM,CAAC,MAAM,CAAC;QACnB,QAAQ,CAAC,MAAM,CAAC,SAAS,CAAC;QAC1B,QAAQ,CAAC,KAAK,EAAE;KACjB,CAAC,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;AACtB,CAAC;AAED,MAAM,UAAU,SAAS,CAAC,MAAc;IACtC,OAAO,UAAU,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,MAAM,EAAE,CAAC;AACtD,CAAC"}
@@ -0,0 +1,14 @@
1
+ export declare function ensureDir(dir: string): void;
2
+ export declare function readJSON<T = unknown>(path: string): T | null;
3
+ export declare function writeJSON(path: string, data: unknown): void;
4
+ export declare function readJSON5<T = unknown>(path: string): T | null;
5
+ /** Alias for workspace.ts compatibility */
6
+ export declare const readYaml: typeof readYAML;
7
+ /** Alias for workspace.ts compatibility */
8
+ export declare const writeYaml: typeof writeYAML;
9
+ export declare function readYAML<T = unknown>(path: string): T | null;
10
+ export declare function writeYAML(path: string, data: unknown): void;
11
+ export declare function readMD(path: string): string | null;
12
+ export declare function appendJSONL(path: string, entry: unknown): void;
13
+ export declare function readJSONL<T = unknown>(path: string): T[];
14
+ //# sourceMappingURL=file.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"file.d.ts","sourceRoot":"","sources":["../../src/utils/file.ts"],"names":[],"mappings":"AAKA,wBAAgB,SAAS,CAAC,GAAG,EAAE,MAAM,QAEpC;AAED,wBAAgB,QAAQ,CAAC,CAAC,GAAG,OAAO,EAAE,IAAI,EAAE,MAAM,GAAG,CAAC,GAAG,IAAI,CAG5D;AAED,wBAAgB,SAAS,CAAC,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,OAAO,QAGpD;AAED,wBAAgB,SAAS,CAAC,CAAC,GAAG,OAAO,EAAE,IAAI,EAAE,MAAM,GAAG,CAAC,GAAG,IAAI,CAG7D;AAED,2CAA2C;AAC3C,eAAO,MAAM,QAAQ,iBAAW,CAAC;AACjC,2CAA2C;AAC3C,eAAO,MAAM,SAAS,kBAAY,CAAC;AAEnC,wBAAgB,QAAQ,CAAC,CAAC,GAAG,OAAO,EAAE,IAAI,EAAE,MAAM,GAAG,CAAC,GAAG,IAAI,CAG5D;AAED,wBAAgB,SAAS,CAAC,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,OAAO,QAGpD;AAED,wBAAgB,MAAM,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI,CAGlD;AAED,wBAAgB,WAAW,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,OAAO,QAIvD;AAED,wBAAgB,SAAS,CAAC,CAAC,GAAG,OAAO,EAAE,IAAI,EAAE,MAAM,GAAG,CAAC,EAAE,CAMxD"}
@@ -0,0 +1,54 @@
1
+ import { readFileSync, writeFileSync, existsSync, mkdirSync } from "fs";
2
+ import { dirname } from "path";
3
+ import YAML from "yaml";
4
+ import JSON5 from "json5";
5
+ export function ensureDir(dir) {
6
+ if (!existsSync(dir))
7
+ mkdirSync(dir, { recursive: true });
8
+ }
9
+ export function readJSON(path) {
10
+ if (!existsSync(path))
11
+ return null;
12
+ return JSON.parse(readFileSync(path, "utf-8"));
13
+ }
14
+ export function writeJSON(path, data) {
15
+ ensureDir(dirname(path));
16
+ writeFileSync(path, JSON.stringify(data, null, 2), "utf-8");
17
+ }
18
+ export function readJSON5(path) {
19
+ if (!existsSync(path))
20
+ return null;
21
+ return JSON5.parse(readFileSync(path, "utf-8"));
22
+ }
23
+ /** Alias for workspace.ts compatibility */
24
+ export const readYaml = readYAML;
25
+ /** Alias for workspace.ts compatibility */
26
+ export const writeYaml = writeYAML;
27
+ export function readYAML(path) {
28
+ if (!existsSync(path))
29
+ return null;
30
+ return YAML.parse(readFileSync(path, "utf-8"));
31
+ }
32
+ export function writeYAML(path, data) {
33
+ ensureDir(dirname(path));
34
+ writeFileSync(path, YAML.stringify(data), "utf-8");
35
+ }
36
+ export function readMD(path) {
37
+ if (!existsSync(path))
38
+ return null;
39
+ return readFileSync(path, "utf-8");
40
+ }
41
+ export function appendJSONL(path, entry) {
42
+ ensureDir(dirname(path));
43
+ const line = JSON.stringify(entry) + "\n";
44
+ writeFileSync(path, line, { flag: "a", encoding: "utf-8" });
45
+ }
46
+ export function readJSONL(path) {
47
+ if (!existsSync(path))
48
+ return [];
49
+ return readFileSync(path, "utf-8")
50
+ .split("\n")
51
+ .filter(Boolean)
52
+ .map((l) => JSON.parse(l));
53
+ }
54
+ //# sourceMappingURL=file.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"file.js","sourceRoot":"","sources":["../../src/utils/file.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,aAAa,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,IAAI,CAAC;AACxE,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAC/B,OAAO,IAAI,MAAM,MAAM,CAAC;AACxB,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,MAAM,UAAU,SAAS,CAAC,GAAW;IACnC,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC;QAAE,SAAS,CAAC,GAAG,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;AAC5D,CAAC;AAED,MAAM,UAAU,QAAQ,CAAc,IAAY;IAChD,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC;QAAE,OAAO,IAAI,CAAC;IACnC,OAAO,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC,CAAC;AACjD,CAAC;AAED,MAAM,UAAU,SAAS,CAAC,IAAY,EAAE,IAAa;IACnD,SAAS,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC;IACzB,aAAa,CAAC,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC,EAAE,OAAO,CAAC,CAAC;AAC9D,CAAC;AAED,MAAM,UAAU,SAAS,CAAc,IAAY;IACjD,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC;QAAE,OAAO,IAAI,CAAC;IACnC,OAAO,KAAK,CAAC,KAAK,CAAC,YAAY,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC,CAAC;AAClD,CAAC;AAED,2CAA2C;AAC3C,MAAM,CAAC,MAAM,QAAQ,GAAG,QAAQ,CAAC;AACjC,2CAA2C;AAC3C,MAAM,CAAC,MAAM,SAAS,GAAG,SAAS,CAAC;AAEnC,MAAM,UAAU,QAAQ,CAAc,IAAY;IAChD,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC;QAAE,OAAO,IAAI,CAAC;IACnC,OAAO,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC,CAAC;AACjD,CAAC;AAED,MAAM,UAAU,SAAS,CAAC,IAAY,EAAE,IAAa;IACnD,SAAS,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC;IACzB,aAAa,CAAC,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,OAAO,CAAC,CAAC;AACrD,CAAC;AAED,MAAM,UAAU,MAAM,CAAC,IAAY;IACjC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC;QAAE,OAAO,IAAI,CAAC;IACnC,OAAO,YAAY,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;AACrC,CAAC;AAED,MAAM,UAAU,WAAW,CAAC,IAAY,EAAE,KAAc;IACtD,SAAS,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC;IACzB,MAAM,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC;IAC1C,aAAa,CAAC,IAAI,EAAE,IAAI,EAAE,EAAE,IAAI,EAAE,GAAG,EAAE,QAAQ,EAAE,OAAO,EAAE,CAAC,CAAC;AAC9D,CAAC;AAED,MAAM,UAAU,SAAS,CAAc,IAAY;IACjD,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC;QAAE,OAAO,EAAE,CAAC;IACjC,OAAO,YAAY,CAAC,IAAI,EAAE,OAAO,CAAC;SAC/B,KAAK,CAAC,IAAI,CAAC;SACX,MAAM,CAAC,OAAO,CAAC;SACf,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;AAC/B,CAAC"}
@@ -0,0 +1,6 @@
1
+ export type MediaType = "image" | "video" | "audio" | "document" | "unknown";
2
+ export declare function detectMediaType(filename: string, mime?: string): MediaType;
3
+ export declare function saveMedia(runtimeDir: string, direction: "incoming" | "outgoing", filename: string, data: Buffer): string;
4
+ export declare function loadMedia(path: string): Buffer | null;
5
+ export declare function downloadMedia(url: string, runtimeDir: string): Promise<string | null>;
6
+ //# sourceMappingURL=media.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"media.d.ts","sourceRoot":"","sources":["../../src/utils/media.ts"],"names":[],"mappings":"AAQA,MAAM,MAAM,SAAS,GAAG,OAAO,GAAG,OAAO,GAAG,OAAO,GAAG,UAAU,GAAG,SAAS,CAAC;AA0B7E,wBAAgB,eAAe,CAAC,QAAQ,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,MAAM,GAAG,SAAS,CAI1E;AAED,wBAAgB,SAAS,CACvB,UAAU,EAAE,MAAM,EAClB,SAAS,EAAE,UAAU,GAAG,UAAU,EAClC,QAAQ,EAAE,MAAM,EAChB,IAAI,EAAE,MAAM,GACX,MAAM,CASR;AAED,wBAAgB,SAAS,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI,CAGrD;AAED,wBAAsB,aAAa,CAAC,GAAG,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC,CAY3F"}
@@ -0,0 +1,65 @@
1
+ import { resolve } from "path";
2
+ import { writeFileSync, readFileSync, existsSync } from "fs";
3
+ import { ensureDir } from "./file.js";
4
+ import { createLogger } from "../infra/logger.js";
5
+ import { randomBytes } from "crypto";
6
+ const log = createLogger("media");
7
+ const MIME_MAP = {
8
+ "image/png": "image",
9
+ "image/jpeg": "image",
10
+ "image/gif": "image",
11
+ "image/webp": "image",
12
+ "image/heic": "image",
13
+ "image/svg+xml": "image",
14
+ "video/mp4": "video",
15
+ "video/webm": "video",
16
+ "audio/mpeg": "audio",
17
+ "audio/ogg": "audio",
18
+ "audio/wav": "audio",
19
+ "audio/mp4": "audio",
20
+ "application/pdf": "document",
21
+ };
22
+ const EXT_MAP = {
23
+ ".png": "image", ".jpg": "image", ".jpeg": "image", ".gif": "image",
24
+ ".webp": "image", ".heic": "image", ".svg": "image",
25
+ ".mp4": "video", ".webm": "video", ".mov": "video",
26
+ ".mp3": "audio", ".ogg": "audio", ".wav": "audio", ".m4a": "audio", ".opus": "audio",
27
+ ".pdf": "document", ".docx": "document",
28
+ };
29
+ export function detectMediaType(filename, mime) {
30
+ if (mime && MIME_MAP[mime])
31
+ return MIME_MAP[mime];
32
+ const ext = filename.toLowerCase().match(/\.[a-z0-9]+$/)?.[0] || "";
33
+ return EXT_MAP[ext] || "unknown";
34
+ }
35
+ export function saveMedia(runtimeDir, direction, filename, data) {
36
+ const dir = resolve(runtimeDir, "media", direction);
37
+ ensureDir(dir);
38
+ const id = randomBytes(8).toString("hex");
39
+ const safeName = `${id}-${filename.replace(/[^a-zA-Z0-9._-]/g, "_")}`;
40
+ const path = resolve(dir, safeName);
41
+ writeFileSync(path, data);
42
+ log.debug("Saved %s media: %s", direction, safeName);
43
+ return path;
44
+ }
45
+ export function loadMedia(path) {
46
+ if (!existsSync(path))
47
+ return null;
48
+ return readFileSync(path);
49
+ }
50
+ export async function downloadMedia(url, runtimeDir) {
51
+ try {
52
+ const res = await fetch(url);
53
+ if (!res.ok)
54
+ return null;
55
+ const buf = Buffer.from(await res.arrayBuffer());
56
+ const urlParts = new URL(url);
57
+ const filename = urlParts.pathname.split("/").pop() || "download";
58
+ return saveMedia(runtimeDir, "incoming", filename, buf);
59
+ }
60
+ catch (err) {
61
+ log.error({ err }, "Failed to download media from %s", url);
62
+ return null;
63
+ }
64
+ }
65
+ //# sourceMappingURL=media.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"media.js","sourceRoot":"","sources":["../../src/utils/media.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,22 @@
1
+ import type { DeviceIdentity } from "../security/device-identity.js";
2
+ export interface WalletInfo {
3
+ address: string;
4
+ chain: string;
5
+ createdAt: string;
6
+ }
7
+ export interface WalletState {
8
+ info: WalletInfo;
9
+ encryptedKey: string;
10
+ }
11
+ export declare function getWalletPath(runtimeDir: string): string;
12
+ export declare function initWallet(runtimeDir: string, identity: DeviceIdentity, chain?: string): WalletInfo;
13
+ export declare function getWalletAddress(runtimeDir: string): string | null;
14
+ export declare function getBalance(runtimeDir: string, rpcUrl?: string): Promise<string>;
15
+ export declare function logTransaction(runtimeDir: string, tx: {
16
+ type: string;
17
+ to: string;
18
+ amount: string;
19
+ hash?: string;
20
+ status: string;
21
+ }): void;
22
+ //# sourceMappingURL=x402.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"x402.d.ts","sourceRoot":"","sources":["../../src/wallet/x402.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,gCAAgC,CAAC;AAKrE,MAAM,WAAW,UAAU;IACzB,OAAO,EAAE,MAAM,CAAC;IAChB,KAAK,EAAE,MAAM,CAAC;IACd,SAAS,EAAE,MAAM,CAAC;CACnB;AAED,MAAM,WAAW,WAAW;IAC1B,IAAI,EAAE,UAAU,CAAC;IACjB,YAAY,EAAE,MAAM,CAAC;CACtB;AAID,wBAAgB,aAAa,CAAC,UAAU,EAAE,MAAM,GAAG,MAAM,CAExD;AAED,wBAAgB,UAAU,CACxB,UAAU,EAAE,MAAM,EAClB,QAAQ,EAAE,cAAc,EACxB,KAAK,GAAE,MAAe,GACrB,UAAU,CA2BZ;AAED,wBAAgB,gBAAgB,CAAC,UAAU,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI,CAGlE;AAED,wBAAsB,UAAU,CAC9B,UAAU,EAAE,MAAM,EAClB,MAAM,GAAE,MAAmC,GAC1C,OAAO,CAAC,MAAM,CAAC,CAmBjB;AAED,wBAAgB,cAAc,CAC5B,UAAU,EAAE,MAAM,EAClB,EAAE,EAAE;IAAE,IAAI,EAAE,MAAM,CAAC;IAAC,EAAE,EAAE,MAAM,CAAC;IAAC,MAAM,EAAE,MAAM,CAAC;IAAC,IAAI,CAAC,EAAE,MAAM,CAAC;IAAC,MAAM,EAAE,MAAM,CAAA;CAAE,QAMhF"}