@ainetwork/adk 0.2.8 → 0.2.10

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 (373) hide show
  1. package/dist/cjs/{chunk-2GJKQSDQ.cjs → chunk-2EPZZPWG.cjs} +3 -3
  2. package/dist/cjs/{chunk-3SYBDGMH.cjs.map → chunk-2EPZZPWG.cjs.map} +1 -1
  3. package/dist/cjs/chunk-2P3ZBNVN.cjs +45 -0
  4. package/dist/cjs/chunk-2P3ZBNVN.cjs.map +1 -0
  5. package/dist/cjs/{chunk-OAPMGKE2.cjs → chunk-33ZJ74NB.cjs} +15 -9
  6. package/dist/cjs/chunk-33ZJ74NB.cjs.map +1 -0
  7. package/dist/cjs/{chunk-MXDXXOXE.cjs → chunk-3X2EKOWC.cjs} +15 -7
  8. package/dist/cjs/chunk-3X2EKOWC.cjs.map +1 -0
  9. package/dist/cjs/chunk-BQ6BY5HN.cjs +28 -0
  10. package/dist/cjs/chunk-BQ6BY5HN.cjs.map +1 -0
  11. package/dist/cjs/{chunk-WGFYVOP5.cjs → chunk-CKIA6H2D.cjs} +5 -5
  12. package/dist/cjs/{chunk-WGFYVOP5.cjs.map → chunk-CKIA6H2D.cjs.map} +1 -1
  13. package/dist/cjs/{chunk-W4PRBE6H.cjs → chunk-G3KWCMMQ.cjs} +32 -10
  14. package/dist/cjs/chunk-G3KWCMMQ.cjs.map +1 -0
  15. package/dist/cjs/chunk-IJBFU7GX.cjs +28 -0
  16. package/dist/cjs/chunk-IJBFU7GX.cjs.map +1 -0
  17. package/dist/cjs/{chunk-AY3PG2UZ.cjs → chunk-JRFTCDMQ.cjs} +15 -9
  18. package/dist/cjs/chunk-JRFTCDMQ.cjs.map +1 -0
  19. package/dist/cjs/{chunk-4PFJ7PDN.cjs → chunk-LNLZLOW2.cjs} +6 -6
  20. package/dist/cjs/{chunk-3GPSKXKA.cjs.map → chunk-LNLZLOW2.cjs.map} +1 -1
  21. package/dist/cjs/{chunk-KAF2EDPZ.cjs → chunk-M6YACFW4.cjs} +13 -7
  22. package/dist/cjs/chunk-M6YACFW4.cjs.map +1 -0
  23. package/dist/cjs/chunk-MT722JJC.cjs +1 -0
  24. package/dist/cjs/chunk-MT722JJC.cjs.map +1 -0
  25. package/dist/cjs/chunk-NWIZHGCS.cjs +28 -0
  26. package/dist/cjs/chunk-NWIZHGCS.cjs.map +1 -0
  27. package/dist/cjs/chunk-QIHLINHW.cjs +106 -0
  28. package/dist/cjs/chunk-QIHLINHW.cjs.map +1 -0
  29. package/dist/cjs/{chunk-3GPSKXKA.cjs → chunk-QXLAC5OS.cjs} +6 -6
  30. package/dist/cjs/{chunk-4PFJ7PDN.cjs.map → chunk-QXLAC5OS.cjs.map} +1 -1
  31. package/dist/cjs/{chunk-IKPQ52KY.cjs → chunk-QZHI7LLI.cjs} +1 -1
  32. package/dist/cjs/chunk-QZHI7LLI.cjs.map +1 -0
  33. package/dist/cjs/chunk-R3K7LK6W.cjs +134 -0
  34. package/dist/cjs/chunk-R3K7LK6W.cjs.map +1 -0
  35. package/dist/cjs/chunk-S454SFT6.cjs +129 -0
  36. package/dist/cjs/chunk-S454SFT6.cjs.map +1 -0
  37. package/dist/cjs/chunk-S6BHSEXF.cjs +26 -0
  38. package/dist/cjs/chunk-S6BHSEXF.cjs.map +1 -0
  39. package/dist/cjs/{chunk-2NKMH5DO.cjs → chunk-SB5GVESM.cjs} +6 -6
  40. package/dist/cjs/{chunk-5ARBSKWU.cjs.map → chunk-SB5GVESM.cjs.map} +1 -1
  41. package/dist/cjs/chunk-SC6WN4ED.cjs +28 -0
  42. package/dist/cjs/chunk-SC6WN4ED.cjs.map +1 -0
  43. package/dist/cjs/{chunk-3SYBDGMH.cjs → chunk-SH6JCUEJ.cjs} +3 -3
  44. package/dist/cjs/{chunk-2GJKQSDQ.cjs.map → chunk-SH6JCUEJ.cjs.map} +1 -1
  45. package/dist/cjs/chunk-T7444BWH.cjs +134 -0
  46. package/dist/cjs/chunk-T7444BWH.cjs.map +1 -0
  47. package/dist/cjs/chunk-TILUFTIG.cjs +111 -0
  48. package/dist/cjs/chunk-TILUFTIG.cjs.map +1 -0
  49. package/dist/cjs/{chunk-45H4WOKN.cjs → chunk-VRCXZ4LV.cjs} +3 -3
  50. package/dist/cjs/{chunk-3IB2WAKN.cjs.map → chunk-VRCXZ4LV.cjs.map} +1 -1
  51. package/dist/cjs/{chunk-MADCWTBO.cjs → chunk-W224GBH7.cjs} +1 -1
  52. package/dist/cjs/{chunk-CD3RWOCR.cjs.map → chunk-W224GBH7.cjs.map} +1 -1
  53. package/dist/cjs/{chunk-3IB2WAKN.cjs → chunk-WGSFHDDZ.cjs} +3 -3
  54. package/dist/cjs/{chunk-45H4WOKN.cjs.map → chunk-WGSFHDDZ.cjs.map} +1 -1
  55. package/dist/cjs/chunk-X7FADTCP.cjs +110 -0
  56. package/dist/cjs/chunk-X7FADTCP.cjs.map +1 -0
  57. package/dist/cjs/chunk-Y337ZZKZ.cjs +129 -0
  58. package/dist/cjs/chunk-Y337ZZKZ.cjs.map +1 -0
  59. package/dist/cjs/{chunk-5ARBSKWU.cjs → chunk-YU3TYLMR.cjs} +5 -5
  60. package/dist/cjs/{chunk-2NKMH5DO.cjs.map → chunk-YU3TYLMR.cjs.map} +1 -1
  61. package/dist/cjs/{chunk-TYLHXACM.cjs → chunk-ZVPJLZIQ.cjs} +6 -2
  62. package/dist/cjs/chunk-ZVPJLZIQ.cjs.map +1 -0
  63. package/dist/cjs/controllers/index.cjs +4 -4
  64. package/dist/cjs/controllers/intent.controller.cjs +7 -0
  65. package/dist/cjs/controllers/intent.controller.cjs.map +1 -0
  66. package/dist/cjs/index.cjs +28 -21
  67. package/dist/cjs/index.cjs.map +1 -1
  68. package/dist/cjs/modules/a2a/a2a.module.cjs +3 -3
  69. package/dist/cjs/modules/index.cjs +7 -7
  70. package/dist/cjs/modules/index.cjs.map +1 -1
  71. package/dist/cjs/routes/a2a.routes.cjs +6 -6
  72. package/dist/cjs/routes/api.routes.cjs +5 -5
  73. package/dist/cjs/routes/index.cjs +17 -17
  74. package/dist/cjs/routes/index.cjs.map +1 -1
  75. package/dist/cjs/routes/intent.routes.cjs +20 -0
  76. package/dist/cjs/routes/intent.routes.cjs.map +1 -0
  77. package/dist/cjs/routes/query.routes.cjs +8 -8
  78. package/dist/cjs/services/index.cjs +19 -9
  79. package/dist/cjs/services/index.cjs.map +1 -1
  80. package/dist/cjs/services/intents/fulfill-stream.service.cjs +3 -3
  81. package/dist/cjs/services/intents/fulfill.service.cjs +3 -3
  82. package/dist/cjs/services/intents/trigger.service.cjs +2 -2
  83. package/dist/cjs/services/query-stream.service.cjs +5 -5
  84. package/dist/cjs/services/query.service.cjs +5 -5
  85. package/dist/cjs/services/thread.service.cjs +7 -0
  86. package/dist/cjs/services/thread.service.cjs.map +1 -0
  87. package/dist/cjs/types/memory.cjs +2 -2
  88. package/dist/esm/{chunk-XTPDMHUI.js → chunk-5YU3CTYW.js} +11 -5
  89. package/dist/esm/{chunk-XTPDMHUI.js.map → chunk-5YU3CTYW.js.map} +1 -1
  90. package/dist/esm/{chunk-6OHUQ6DV.js → chunk-6PT5BUHR.js} +5 -5
  91. package/dist/esm/{chunk-IRGR2OHS.js → chunk-7276G7GV.js} +11 -5
  92. package/dist/esm/{chunk-IRGR2OHS.js.map → chunk-7276G7GV.js.map} +1 -1
  93. package/dist/esm/{chunk-5T7E533R.js → chunk-A3UQKLUC.js} +2 -2
  94. package/dist/esm/{chunk-X6JNM3XR.js → chunk-GRN6CHNO.js} +1 -1
  95. package/dist/esm/{chunk-X6JNM3XR.js.map → chunk-GRN6CHNO.js.map} +1 -1
  96. package/dist/esm/{chunk-OCONOO5Z.js → chunk-JNZCPCEC.js} +14 -7
  97. package/dist/esm/chunk-JNZCPCEC.js.map +1 -0
  98. package/dist/esm/{chunk-EYZ5Z7FG.js → chunk-LOFJBMHT.js} +1 -1
  99. package/dist/esm/chunk-LOFJBMHT.js.map +1 -0
  100. package/dist/esm/{chunk-SHQWRBWS.js → chunk-NWL3BMUH.js} +3 -7
  101. package/dist/esm/chunk-NWL3BMUH.js.map +1 -0
  102. package/dist/esm/chunk-PBGBCH2S.js +28 -0
  103. package/dist/esm/chunk-PBGBCH2S.js.map +1 -0
  104. package/dist/esm/{chunk-E2RV322Z.js → chunk-QCK645XC.js} +24 -2
  105. package/dist/esm/chunk-QCK645XC.js.map +1 -0
  106. package/dist/esm/chunk-U7REZSMO.js +1 -0
  107. package/dist/esm/chunk-U7REZSMO.js.map +1 -0
  108. package/dist/esm/chunk-WZQVH4XY.js +45 -0
  109. package/dist/esm/chunk-WZQVH4XY.js.map +1 -0
  110. package/dist/esm/chunk-YUKPKFX5.js +26 -0
  111. package/dist/esm/chunk-YUKPKFX5.js.map +1 -0
  112. package/dist/esm/controllers/index.js +5 -5
  113. package/dist/esm/controllers/intent.controller.d.ts +19 -0
  114. package/dist/esm/controllers/intent.controller.js +7 -0
  115. package/dist/esm/controllers/intent.controller.js.map +1 -0
  116. package/dist/esm/index.js +24 -17
  117. package/dist/esm/index.js.map +1 -1
  118. package/dist/esm/modules/a2a/a2a.module.js +2 -2
  119. package/dist/esm/modules/index.d.ts +1 -1
  120. package/dist/esm/modules/index.js +6 -6
  121. package/dist/esm/routes/a2a.routes.js +5 -5
  122. package/dist/esm/routes/api.routes.js +1 -1
  123. package/dist/esm/routes/index.js +15 -15
  124. package/dist/esm/routes/intent.routes.d.ts +24 -0
  125. package/dist/esm/routes/intent.routes.js +20 -0
  126. package/dist/esm/routes/intent.routes.js.map +1 -0
  127. package/dist/esm/routes/query.routes.js +7 -7
  128. package/dist/esm/services/index.d.ts +3 -0
  129. package/dist/esm/services/index.js +16 -6
  130. package/dist/esm/services/intents/fulfill-stream.service.d.ts +2 -2
  131. package/dist/esm/services/intents/fulfill-stream.service.js +2 -2
  132. package/dist/esm/services/intents/fulfill.service.d.ts +2 -2
  133. package/dist/esm/services/intents/fulfill.service.js +2 -2
  134. package/dist/esm/services/intents/trigger.service.js +1 -1
  135. package/dist/esm/services/query-stream.service.js +4 -4
  136. package/dist/esm/services/query.service.js +4 -4
  137. package/dist/esm/services/thread.service.d.ts +13 -0
  138. package/dist/esm/services/thread.service.js +7 -0
  139. package/dist/esm/services/thread.service.js.map +1 -0
  140. package/dist/esm/types/memory.d.ts +1 -0
  141. package/dist/esm/types/memory.js +1 -1
  142. package/package.json +1 -1
  143. package/dist/cjs/chunk-2UK6RDHB.cjs +0 -337
  144. package/dist/cjs/chunk-2UK6RDHB.cjs.map +0 -1
  145. package/dist/cjs/chunk-4TK4MTAR.cjs +0 -17
  146. package/dist/cjs/chunk-4TK4MTAR.cjs.map +0 -1
  147. package/dist/cjs/chunk-5WNANWIO.cjs +0 -43
  148. package/dist/cjs/chunk-5WNANWIO.cjs.map +0 -1
  149. package/dist/cjs/chunk-67EDI57F.cjs +0 -37
  150. package/dist/cjs/chunk-67EDI57F.cjs.map +0 -1
  151. package/dist/cjs/chunk-6S376RMW.cjs +0 -338
  152. package/dist/cjs/chunk-6S376RMW.cjs.map +0 -1
  153. package/dist/cjs/chunk-6UHPYXKS.cjs +0 -381
  154. package/dist/cjs/chunk-6UHPYXKS.cjs.map +0 -1
  155. package/dist/cjs/chunk-7HH3N36Q.cjs +0 -43
  156. package/dist/cjs/chunk-7HH3N36Q.cjs.map +0 -1
  157. package/dist/cjs/chunk-7J5DYKDJ.cjs +0 -376
  158. package/dist/cjs/chunk-7J5DYKDJ.cjs.map +0 -1
  159. package/dist/cjs/chunk-7Y3W3SIL.cjs +0 -37
  160. package/dist/cjs/chunk-7Y3W3SIL.cjs.map +0 -1
  161. package/dist/cjs/chunk-AEYHJEGM.cjs +0 -26
  162. package/dist/cjs/chunk-AEYHJEGM.cjs.map +0 -1
  163. package/dist/cjs/chunk-AIAIY7IU.cjs +0 -43
  164. package/dist/cjs/chunk-AIAIY7IU.cjs.map +0 -1
  165. package/dist/cjs/chunk-APGW3LWW.cjs +0 -43
  166. package/dist/cjs/chunk-APGW3LWW.cjs.map +0 -1
  167. package/dist/cjs/chunk-AWLDQTED.cjs +0 -257
  168. package/dist/cjs/chunk-AWLDQTED.cjs.map +0 -1
  169. package/dist/cjs/chunk-AXLG6NY4.cjs +0 -337
  170. package/dist/cjs/chunk-AXLG6NY4.cjs.map +0 -1
  171. package/dist/cjs/chunk-AY3PG2UZ.cjs.map +0 -1
  172. package/dist/cjs/chunk-B2XCYG4C.cjs +0 -43
  173. package/dist/cjs/chunk-B2XCYG4C.cjs.map +0 -1
  174. package/dist/cjs/chunk-BAPJ7AYM.cjs +0 -43
  175. package/dist/cjs/chunk-BAPJ7AYM.cjs.map +0 -1
  176. package/dist/cjs/chunk-BFWJLMUR.cjs +0 -43
  177. package/dist/cjs/chunk-BFWJLMUR.cjs.map +0 -1
  178. package/dist/cjs/chunk-BGEBE36B.cjs +0 -43
  179. package/dist/cjs/chunk-BGEBE36B.cjs.map +0 -1
  180. package/dist/cjs/chunk-BIDIP5MX.cjs +0 -37
  181. package/dist/cjs/chunk-BIDIP5MX.cjs.map +0 -1
  182. package/dist/cjs/chunk-BKU7EWEM.cjs +0 -37
  183. package/dist/cjs/chunk-BKU7EWEM.cjs.map +0 -1
  184. package/dist/cjs/chunk-C5V4X3ZH.cjs +0 -364
  185. package/dist/cjs/chunk-C5V4X3ZH.cjs.map +0 -1
  186. package/dist/cjs/chunk-C77OTZYZ.cjs +0 -43
  187. package/dist/cjs/chunk-C77OTZYZ.cjs.map +0 -1
  188. package/dist/cjs/chunk-C7SJ2X3X.cjs +0 -43
  189. package/dist/cjs/chunk-C7SJ2X3X.cjs.map +0 -1
  190. package/dist/cjs/chunk-CD3RWOCR.cjs +0 -18
  191. package/dist/cjs/chunk-CEUCTNAJ.cjs +0 -43
  192. package/dist/cjs/chunk-CEUCTNAJ.cjs.map +0 -1
  193. package/dist/cjs/chunk-CIV2QV4C.cjs +0 -43
  194. package/dist/cjs/chunk-CIV2QV4C.cjs.map +0 -1
  195. package/dist/cjs/chunk-CKE4RRTI.cjs +0 -378
  196. package/dist/cjs/chunk-CKE4RRTI.cjs.map +0 -1
  197. package/dist/cjs/chunk-EEND2E3Y.cjs +0 -37
  198. package/dist/cjs/chunk-EEND2E3Y.cjs.map +0 -1
  199. package/dist/cjs/chunk-ET7NGSCR.cjs +0 -382
  200. package/dist/cjs/chunk-ET7NGSCR.cjs.map +0 -1
  201. package/dist/cjs/chunk-EXKLB7FF.cjs +0 -18
  202. package/dist/cjs/chunk-EXKLB7FF.cjs.map +0 -1
  203. package/dist/cjs/chunk-F6LFBKIF.cjs +0 -43
  204. package/dist/cjs/chunk-F6LFBKIF.cjs.map +0 -1
  205. package/dist/cjs/chunk-FCIBDAL5.cjs +0 -364
  206. package/dist/cjs/chunk-FCIBDAL5.cjs.map +0 -1
  207. package/dist/cjs/chunk-FGBHPONX.cjs +0 -43
  208. package/dist/cjs/chunk-FGBHPONX.cjs.map +0 -1
  209. package/dist/cjs/chunk-FJ2S5TGS.cjs +0 -37
  210. package/dist/cjs/chunk-FJ2S5TGS.cjs.map +0 -1
  211. package/dist/cjs/chunk-FZEACIU2.cjs +0 -37
  212. package/dist/cjs/chunk-FZEACIU2.cjs.map +0 -1
  213. package/dist/cjs/chunk-GAXPKI2P.cjs +0 -364
  214. package/dist/cjs/chunk-GAXPKI2P.cjs.map +0 -1
  215. package/dist/cjs/chunk-GBQXIGWQ.cjs +0 -37
  216. package/dist/cjs/chunk-GBQXIGWQ.cjs.map +0 -1
  217. package/dist/cjs/chunk-GGP6URMG.cjs +0 -43
  218. package/dist/cjs/chunk-GGP6URMG.cjs.map +0 -1
  219. package/dist/cjs/chunk-GO2OLIWF.cjs +0 -359
  220. package/dist/cjs/chunk-GO2OLIWF.cjs.map +0 -1
  221. package/dist/cjs/chunk-GYIACLMZ.cjs +0 -376
  222. package/dist/cjs/chunk-GYIACLMZ.cjs.map +0 -1
  223. package/dist/cjs/chunk-GZE5BVB2.cjs +0 -361
  224. package/dist/cjs/chunk-GZE5BVB2.cjs.map +0 -1
  225. package/dist/cjs/chunk-HPCNM6XP.cjs +0 -25
  226. package/dist/cjs/chunk-HPCNM6XP.cjs.map +0 -1
  227. package/dist/cjs/chunk-HXRGFZL7.cjs +0 -360
  228. package/dist/cjs/chunk-HXRGFZL7.cjs.map +0 -1
  229. package/dist/cjs/chunk-IC5TWI4A.cjs +0 -37
  230. package/dist/cjs/chunk-IC5TWI4A.cjs.map +0 -1
  231. package/dist/cjs/chunk-ICTSMRXC.cjs +0 -360
  232. package/dist/cjs/chunk-ICTSMRXC.cjs.map +0 -1
  233. package/dist/cjs/chunk-IH4I2JTE.cjs +0 -348
  234. package/dist/cjs/chunk-IH4I2JTE.cjs.map +0 -1
  235. package/dist/cjs/chunk-IKPQ52KY.cjs.map +0 -1
  236. package/dist/cjs/chunk-J5WX6GPC.cjs +0 -43
  237. package/dist/cjs/chunk-J5WX6GPC.cjs.map +0 -1
  238. package/dist/cjs/chunk-J7GCQY3S.cjs +0 -18
  239. package/dist/cjs/chunk-J7GCQY3S.cjs.map +0 -1
  240. package/dist/cjs/chunk-JFLQREPM.cjs +0 -37
  241. package/dist/cjs/chunk-JFLQREPM.cjs.map +0 -1
  242. package/dist/cjs/chunk-JO6AZASU.cjs +0 -37
  243. package/dist/cjs/chunk-JO6AZASU.cjs.map +0 -1
  244. package/dist/cjs/chunk-JUPAGIP4.cjs +0 -43
  245. package/dist/cjs/chunk-JUPAGIP4.cjs.map +0 -1
  246. package/dist/cjs/chunk-JWIVQT6C.cjs +0 -37
  247. package/dist/cjs/chunk-JWIVQT6C.cjs.map +0 -1
  248. package/dist/cjs/chunk-JYHYAQQ2.cjs +0 -43
  249. package/dist/cjs/chunk-JYHYAQQ2.cjs.map +0 -1
  250. package/dist/cjs/chunk-K6HWDDNX.cjs +0 -367
  251. package/dist/cjs/chunk-K6HWDDNX.cjs.map +0 -1
  252. package/dist/cjs/chunk-K6J5XJRM.cjs +0 -382
  253. package/dist/cjs/chunk-K6J5XJRM.cjs.map +0 -1
  254. package/dist/cjs/chunk-KAF2EDPZ.cjs.map +0 -1
  255. package/dist/cjs/chunk-KBWHLMA4.cjs +0 -26
  256. package/dist/cjs/chunk-KBWHLMA4.cjs.map +0 -1
  257. package/dist/cjs/chunk-KH25JPQS.cjs +0 -256
  258. package/dist/cjs/chunk-KH25JPQS.cjs.map +0 -1
  259. package/dist/cjs/chunk-KHAIZONV.cjs +0 -43
  260. package/dist/cjs/chunk-KHAIZONV.cjs.map +0 -1
  261. package/dist/cjs/chunk-KQ4MBNUW.cjs +0 -43
  262. package/dist/cjs/chunk-KQ4MBNUW.cjs.map +0 -1
  263. package/dist/cjs/chunk-L5ZICBT4.cjs +0 -37
  264. package/dist/cjs/chunk-L5ZICBT4.cjs.map +0 -1
  265. package/dist/cjs/chunk-MADCWTBO.cjs.map +0 -1
  266. package/dist/cjs/chunk-MV6L3NPY.cjs +0 -164
  267. package/dist/cjs/chunk-MV6L3NPY.cjs.map +0 -1
  268. package/dist/cjs/chunk-MXDXXOXE.cjs.map +0 -1
  269. package/dist/cjs/chunk-N6VAOFEP.cjs +0 -37
  270. package/dist/cjs/chunk-N6VAOFEP.cjs.map +0 -1
  271. package/dist/cjs/chunk-NWMGBXPZ.cjs +0 -37
  272. package/dist/cjs/chunk-NWMGBXPZ.cjs.map +0 -1
  273. package/dist/cjs/chunk-OAPMGKE2.cjs.map +0 -1
  274. package/dist/cjs/chunk-OCGEXAVI.cjs +0 -373
  275. package/dist/cjs/chunk-OCGEXAVI.cjs.map +0 -1
  276. package/dist/cjs/chunk-OOSRLRNL.cjs +0 -37
  277. package/dist/cjs/chunk-OOSRLRNL.cjs.map +0 -1
  278. package/dist/cjs/chunk-ORLXR6OZ.cjs +0 -257
  279. package/dist/cjs/chunk-ORLXR6OZ.cjs.map +0 -1
  280. package/dist/cjs/chunk-OZKAPLCE.cjs +0 -43
  281. package/dist/cjs/chunk-OZKAPLCE.cjs.map +0 -1
  282. package/dist/cjs/chunk-P42QPS2N.cjs +0 -43
  283. package/dist/cjs/chunk-P42QPS2N.cjs.map +0 -1
  284. package/dist/cjs/chunk-PHTT7NVZ.cjs +0 -37
  285. package/dist/cjs/chunk-PHTT7NVZ.cjs.map +0 -1
  286. package/dist/cjs/chunk-PNN5WGWA.cjs +0 -43
  287. package/dist/cjs/chunk-PNN5WGWA.cjs.map +0 -1
  288. package/dist/cjs/chunk-Q673YXOW.cjs +0 -37
  289. package/dist/cjs/chunk-Q673YXOW.cjs.map +0 -1
  290. package/dist/cjs/chunk-QCEMS4A3.cjs +0 -168
  291. package/dist/cjs/chunk-QCEMS4A3.cjs.map +0 -1
  292. package/dist/cjs/chunk-QV2CSL6T.cjs +0 -352
  293. package/dist/cjs/chunk-QV2CSL6T.cjs.map +0 -1
  294. package/dist/cjs/chunk-QW4T5RFB.cjs +0 -374
  295. package/dist/cjs/chunk-QW4T5RFB.cjs.map +0 -1
  296. package/dist/cjs/chunk-RA62RT7K.cjs +0 -43
  297. package/dist/cjs/chunk-RA62RT7K.cjs.map +0 -1
  298. package/dist/cjs/chunk-RXMGXWLH.cjs +0 -352
  299. package/dist/cjs/chunk-RXMGXWLH.cjs.map +0 -1
  300. package/dist/cjs/chunk-SEJO6F5X.cjs +0 -43
  301. package/dist/cjs/chunk-SEJO6F5X.cjs.map +0 -1
  302. package/dist/cjs/chunk-SMKJY53T.cjs +0 -367
  303. package/dist/cjs/chunk-SMKJY53T.cjs.map +0 -1
  304. package/dist/cjs/chunk-SUWC3YAJ.cjs +0 -359
  305. package/dist/cjs/chunk-SUWC3YAJ.cjs.map +0 -1
  306. package/dist/cjs/chunk-SZU5VCQL.cjs +0 -256
  307. package/dist/cjs/chunk-SZU5VCQL.cjs.map +0 -1
  308. package/dist/cjs/chunk-T2CE7W67.cjs +0 -43
  309. package/dist/cjs/chunk-T2CE7W67.cjs.map +0 -1
  310. package/dist/cjs/chunk-TBQF2VIX.cjs +0 -43
  311. package/dist/cjs/chunk-TBQF2VIX.cjs.map +0 -1
  312. package/dist/cjs/chunk-TK2MNTOI.cjs +0 -43
  313. package/dist/cjs/chunk-TK2MNTOI.cjs.map +0 -1
  314. package/dist/cjs/chunk-TOVEWQW2.cjs +0 -43
  315. package/dist/cjs/chunk-TOVEWQW2.cjs.map +0 -1
  316. package/dist/cjs/chunk-TS46OIE7.cjs +0 -252
  317. package/dist/cjs/chunk-TS46OIE7.cjs.map +0 -1
  318. package/dist/cjs/chunk-TYLHXACM.cjs.map +0 -1
  319. package/dist/cjs/chunk-UDLSTQ4I.cjs +0 -21
  320. package/dist/cjs/chunk-UDLSTQ4I.cjs.map +0 -1
  321. package/dist/cjs/chunk-UFVWBUJM.cjs +0 -365
  322. package/dist/cjs/chunk-UFVWBUJM.cjs.map +0 -1
  323. package/dist/cjs/chunk-USDDAUYF.cjs +0 -364
  324. package/dist/cjs/chunk-USDDAUYF.cjs.map +0 -1
  325. package/dist/cjs/chunk-UUWWBHFR.cjs +0 -37
  326. package/dist/cjs/chunk-UUWWBHFR.cjs.map +0 -1
  327. package/dist/cjs/chunk-UVN2DE6N.cjs +0 -368
  328. package/dist/cjs/chunk-UVN2DE6N.cjs.map +0 -1
  329. package/dist/cjs/chunk-VVLC6T66.cjs +0 -37
  330. package/dist/cjs/chunk-VVLC6T66.cjs.map +0 -1
  331. package/dist/cjs/chunk-VZS6VPLE.cjs +0 -26
  332. package/dist/cjs/chunk-VZS6VPLE.cjs.map +0 -1
  333. package/dist/cjs/chunk-W4PRBE6H.cjs.map +0 -1
  334. package/dist/cjs/chunk-WDPCMSZM.cjs +0 -37
  335. package/dist/cjs/chunk-WDPCMSZM.cjs.map +0 -1
  336. package/dist/cjs/chunk-X276C2SQ.cjs +0 -37
  337. package/dist/cjs/chunk-X276C2SQ.cjs.map +0 -1
  338. package/dist/cjs/chunk-X3XEJQRF.cjs +0 -37
  339. package/dist/cjs/chunk-X3XEJQRF.cjs.map +0 -1
  340. package/dist/cjs/chunk-X5ARZJ77.cjs +0 -353
  341. package/dist/cjs/chunk-X5ARZJ77.cjs.map +0 -1
  342. package/dist/cjs/chunk-XIR7UR77.cjs +0 -37
  343. package/dist/cjs/chunk-XIR7UR77.cjs.map +0 -1
  344. package/dist/cjs/chunk-XIXM5VST.cjs +0 -37
  345. package/dist/cjs/chunk-XIXM5VST.cjs.map +0 -1
  346. package/dist/cjs/chunk-XIYB6QQC.cjs +0 -37
  347. package/dist/cjs/chunk-XIYB6QQC.cjs.map +0 -1
  348. package/dist/cjs/chunk-XM22DX5O.cjs +0 -43
  349. package/dist/cjs/chunk-XM22DX5O.cjs.map +0 -1
  350. package/dist/cjs/chunk-XVYFBQRE.cjs +0 -37
  351. package/dist/cjs/chunk-XVYFBQRE.cjs.map +0 -1
  352. package/dist/cjs/chunk-YORAOGFM.cjs +0 -37
  353. package/dist/cjs/chunk-YORAOGFM.cjs.map +0 -1
  354. package/dist/cjs/chunk-YUCTXIN5.cjs +0 -37
  355. package/dist/cjs/chunk-YUCTXIN5.cjs.map +0 -1
  356. package/dist/cjs/chunk-YUEKJCO7.cjs +0 -18
  357. package/dist/cjs/chunk-YUEKJCO7.cjs.map +0 -1
  358. package/dist/cjs/chunk-YVE4DLAT.cjs +0 -43
  359. package/dist/cjs/chunk-YVE4DLAT.cjs.map +0 -1
  360. package/dist/cjs/chunk-ZBD7JCDL.cjs +0 -381
  361. package/dist/cjs/chunk-ZBD7JCDL.cjs.map +0 -1
  362. package/dist/cjs/chunk-ZNMRAQT2.cjs +0 -164
  363. package/dist/cjs/chunk-ZNMRAQT2.cjs.map +0 -1
  364. package/dist/cjs/chunk-ZS3QMRHK.cjs +0 -165
  365. package/dist/cjs/chunk-ZS3QMRHK.cjs.map +0 -1
  366. package/dist/cjs/chunk-ZZ3SXOOC.cjs +0 -37
  367. package/dist/cjs/chunk-ZZ3SXOOC.cjs.map +0 -1
  368. package/dist/esm/chunk-E2RV322Z.js.map +0 -1
  369. package/dist/esm/chunk-EYZ5Z7FG.js.map +0 -1
  370. package/dist/esm/chunk-OCONOO5Z.js.map +0 -1
  371. package/dist/esm/chunk-SHQWRBWS.js.map +0 -1
  372. /package/dist/esm/{chunk-6OHUQ6DV.js.map → chunk-6PT5BUHR.js.map} +0 -0
  373. /package/dist/esm/{chunk-5T7E533R.js.map → chunk-A3UQKLUC.js.map} +0 -0
@@ -1,359 +0,0 @@
1
- "use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _optionalChain(ops) { let lastAccessLHS = undefined; let value = ops[0]; let i = 1; while (i < ops.length) { const op = ops[i]; const fn = ops[i + 1]; i += 2; if ((op === 'optionalAccess' || op === 'optionalCall') && value == null) { return undefined; } if (op === 'access' || op === 'optionalAccess') { lastAccessLHS = value; value = fn(value); } else if (op === 'call' || op === 'optionalCall') { value = fn((...args) => value.call(lastAccessLHS, ...args)); lastAccessLHS = undefined; } } return value; }
2
-
3
- var _chunkQHQLU7BIcjs = require('./chunk-QHQLU7BI.cjs');
4
-
5
-
6
- var _chunk466ED5WNcjs = require('./chunk-466ED5WN.cjs');
7
-
8
- // src/services/query-stream.service.ts
9
- var _crypto = require('crypto');
10
- var _httpstatuscodes = require('http-status-codes');
11
- var QueryStreamService = class {
12
-
13
-
14
-
15
-
16
-
17
- constructor(modelModule, a2aModule, mcpModule, memoryModule, prompts) {
18
- this.modelModule = modelModule;
19
- this.a2aModule = a2aModule;
20
- this.mcpModule = mcpModule;
21
- this.memoryModule = memoryModule;
22
- this.prompts = prompts;
23
- }
24
- async addToThreadMessages(thread, params) {
25
- try {
26
- const threadMemory = _optionalChain([this, 'access', _ => _.memoryModule, 'optionalAccess', _2 => _2.getThreadMemory, 'call', _3 => _3()]);
27
- const { userId, threadId } = thread;
28
- const newMessage = {
29
- messageId: _crypto.randomUUID.call(void 0, ),
30
- role: params.role,
31
- timestamp: Date.now(),
32
- content: { type: "text", parts: [params.content] },
33
- metadata: params.metadata
34
- };
35
- thread.messages.push(newMessage);
36
- await _optionalChain([threadMemory, 'optionalAccess', _4 => _4.addMessagesToThread, 'call', _5 => _5(userId, threadId, [newMessage])]);
37
- } catch (error) {
38
- _chunk466ED5WNcjs.loggers.intentStream.error(
39
- "Error adding message to thread",
40
- error
41
- );
42
- }
43
- }
44
- /**
45
- * Detects the intent from context.
46
- *
47
- * @param query - The user's input query
48
- * @param thread - The thread history
49
- * @returns The detected intent
50
- */
51
- async intentTriggering(query, thread) {
52
- const modelInstance = this.modelModule.getModel();
53
- const intentMemory = _optionalChain([this, 'access', _6 => _6.memoryModule, 'optionalAccess', _7 => _7.getIntentMemory, 'call', _8 => _8()]);
54
- if (!intentMemory) {
55
- return [{ subquery: query }];
56
- }
57
- const intents = await intentMemory.listIntents();
58
- if (intents.length === 0) {
59
- _chunk466ED5WNcjs.loggers.intentStream.warn("No intent found");
60
- return [{ subquery: query }];
61
- }
62
- const intentList = intents.map((intent) => `- ${intent.name}: ${intent.description}`).join("\n");
63
- const threadMessages = !thread ? "" : thread.messages.sort((a, b) => a.timestamp - b.timestamp).map((message) => {
64
- const role = message.role === "USER" ? "User" : message.role === "MODEL" ? "Assistant" : "System";
65
- const content = Array.isArray(message.content.parts) ? message.content.parts.join(" ") : String(message.content.parts);
66
- return `${role}: """${content}"""`;
67
- }).join("\n");
68
- const systemPrompt = `You are an expert in accurately identifying user intentions.
69
-
70
- Available intent list:
71
- ${intentList}
72
-
73
- Please select and answer only from the above intent list.
74
- Please return only the exact intent name without any additional explanations or text.`;
75
- const userMessage = `The following is the conversation history with the user:
76
-
77
- ${threadMessages}
78
-
79
- Last user question: "${query}"
80
-
81
- Based on the above conversation history, analyze the last user question and identify all relevant intents.
82
-
83
- Instructions:
84
- 1. First, decompose the last user question into action-based subqueries (each representing a distinct action or task)
85
- 2. Then, map each subquery to its corresponding intent from the available intent list
86
- 3. Multiple intents can be identified if the question covers various topics or actions
87
- 4. Maintain the logical sequence of the original question when splitting into subqueries
88
- 5. If any subquery doesn't match any intent in the available list, map it to "default" intent
89
-
90
- Output Format:
91
- Return the results as a JSON array with the following structure:
92
- [
93
- {
94
- "subquery": "<subquery_1>",
95
- "intentName": "<intent_name_1>"
96
- },
97
- {
98
- "subquery": "<subquery_2>",
99
- "intentName": "<intent_name_2>"
100
- },
101
- ...
102
- ]
103
-
104
- Requirements:
105
- - Each subquery should represent a single, actionable task or request
106
- - Preserve the original meaning and context when splitting queries
107
- - Select only from the provided intent list
108
- - Use "default" as the intent value for any subquery that doesn't match available intents.`;
109
- const messages = modelInstance.generateMessages({
110
- query: userMessage,
111
- systemPrompt
112
- });
113
- const response = await modelInstance.fetch(messages);
114
- if (!response.content) {
115
- _chunk466ED5WNcjs.loggers.intent.debug("Cannot extract intent from query");
116
- return [{ subquery: query }];
117
- }
118
- const subqueries = JSON.parse(response.content);
119
- const triggeredIntent = [];
120
- for (const { subquery, intentName } of subqueries) {
121
- _chunk466ED5WNcjs.loggers.intent.debug(`Intent found: ${subquery}, ${intentName}`);
122
- const intent = await intentMemory.getIntentByName(intentName);
123
- triggeredIntent.push({ subquery, intent });
124
- }
125
- return triggeredIntent;
126
- }
127
- /**
128
- * Fulfills the detected intent by generating a streaming response.
129
- *
130
- * Manages the complete inference loop including:
131
- * - Loading prompts and conversation history
132
- * - Collecting available tools from modules
133
- * - Executing model inference with tool support
134
- * - Processing tool calls iteratively until completion
135
- * - Streaming results as Server-Sent Events
136
- *
137
- * @param query - The user's input query
138
- * @param threadId - Thread identifier for context
139
- * @param thread - Previous conversation history
140
- * @param intent - Optional detected intent with custom prompt
141
- * @returns AsyncGenerator yielding StreamEvent objects
142
- */
143
- async *intentFulfilling(query, threadId, thread, intent) {
144
- const systemPrompt = `
145
- Today is ${(/* @__PURE__ */ new Date()).toLocaleDateString()}.
146
-
147
- ${_optionalChain([this, 'access', _9 => _9.prompts, 'optionalAccess', _10 => _10.agent]) || ""}
148
-
149
- ${_optionalChain([this, 'access', _11 => _11.prompts, 'optionalAccess', _12 => _12.system]) || ""}
150
-
151
- ${_optionalChain([intent, 'optionalAccess', _13 => _13.prompt]) || ""}
152
- `.trim();
153
- const modelInstance = this.modelModule.getModel();
154
- const messages = modelInstance.generateMessages({
155
- query,
156
- thread,
157
- systemPrompt: systemPrompt.trim()
158
- });
159
- const tools = [];
160
- this.mcpModule && tools.push(...this.mcpModule.getTools());
161
- this.a2aModule && tools.push(...await this.a2aModule.getTools());
162
- const functions = modelInstance.convertToolsToFunctions(tools);
163
- const processList = [];
164
- while (true) {
165
- const responseStream = await modelInstance.fetchStreamWithContextMessage(
166
- messages,
167
- functions
168
- );
169
- const assembledToolCalls = [];
170
- _chunk466ED5WNcjs.loggers.intentStream.debug("messages", { messages });
171
- for await (const chunk of responseStream) {
172
- const delta = chunk.delta;
173
- if (_optionalChain([delta, 'optionalAccess', _14 => _14.tool_calls])) {
174
- for (const { index, id, function: func } of delta.tool_calls) {
175
- assembledToolCalls[index] ??= {
176
- id: "",
177
- type: "function",
178
- function: { name: "", arguments: "" }
179
- };
180
- if (id) assembledToolCalls[index].id = id;
181
- if (_optionalChain([func, 'optionalAccess', _15 => _15.name])) assembledToolCalls[index].function.name = func.name;
182
- if (_optionalChain([func, 'optionalAccess', _16 => _16.arguments]))
183
- assembledToolCalls[index].function.arguments += func.arguments;
184
- }
185
- } else if (_optionalChain([chunk, 'access', _17 => _17.delta, 'optionalAccess', _18 => _18.content])) {
186
- yield {
187
- event: "text_chunk",
188
- data: { delta: chunk.delta.content }
189
- };
190
- }
191
- }
192
- _chunk466ED5WNcjs.loggers.intentStream.debug("assembledToolCalls", {
193
- assembledToolCalls
194
- });
195
- if (assembledToolCalls.length > 0) {
196
- for (const toolCall of assembledToolCalls) {
197
- const toolCallId = _crypto.randomUUID.call(void 0, );
198
- const toolName = toolCall.function.name;
199
- const selectedTool = tools.filter(
200
- (tool) => tool.toolName === toolName
201
- )[0];
202
- let toolResult = "";
203
- if (this.mcpModule && selectedTool.protocol === "MCP" /* MCP */) {
204
- const toolArgs = JSON.parse(toolCall.function.arguments);
205
- yield {
206
- event: "tool_start",
207
- data: {
208
- toolCallId,
209
- protocol: "MCP" /* MCP */,
210
- toolName,
211
- toolArgs
212
- }
213
- };
214
- _chunk466ED5WNcjs.loggers.intent.debug("MCP tool call", { toolName, toolArgs });
215
- toolResult = await this.mcpModule.useTool(selectedTool, toolArgs);
216
- } else if (this.a2aModule && selectedTool.protocol === "A2A" /* A2A */) {
217
- yield {
218
- event: "tool_start",
219
- data: {
220
- toolCallId,
221
- protocol: "A2A" /* A2A */,
222
- toolName,
223
- toolArgs: null
224
- }
225
- };
226
- _chunk466ED5WNcjs.loggers.intent.debug("A2A tool call", { toolName });
227
- toolResult = await this.a2aModule.useTool(
228
- selectedTool,
229
- query,
230
- threadId
231
- );
232
- } else {
233
- _chunk466ED5WNcjs.loggers.intent.warn(
234
- `Unrecognized tool type: ${selectedTool.protocol}`
235
- );
236
- continue;
237
- }
238
- yield {
239
- event: "tool_output",
240
- data: {
241
- toolCallId,
242
- protocol: selectedTool.protocol,
243
- toolName,
244
- result: toolResult
245
- }
246
- };
247
- _chunk466ED5WNcjs.loggers.intent.debug("toolResult", { toolResult });
248
- processList.push(toolResult);
249
- modelInstance.appendMessages(messages, toolResult);
250
- await this.addToThreadMessages(thread, {
251
- role: "MODEL" /* MODEL */,
252
- content: toolResult
253
- });
254
- }
255
- } else {
256
- break;
257
- }
258
- }
259
- }
260
- /**
261
- * Generates a title for the conversation based on the query.
262
- *
263
- * @param query - The user's input query
264
- * @returns Promise resolving to a generated title
265
- */
266
- async generateTitle(query) {
267
- const DEFAULT_TITLE = "New Chat";
268
- try {
269
- const modelInstance = this.modelModule.getModel();
270
- const messages = modelInstance.generateMessages({
271
- query,
272
- systemPrompt: `You are a helpful assistant that generates titles for conversations.
273
- Please analyze the user's query and create a concise title that accurately reflects the conversation's core topic.
274
- The title must be no more than 5 words long.
275
- Respond with only the title. Do not include any punctuation or extra explanations.`
276
- });
277
- const response = await modelInstance.fetch(messages);
278
- return response.content || DEFAULT_TITLE;
279
- } catch (error) {
280
- _chunk466ED5WNcjs.loggers.intentStream.error("Error generating title", {
281
- error,
282
- query
283
- });
284
- return DEFAULT_TITLE;
285
- }
286
- }
287
- /**
288
- * Main entry point for processing streaming user queries.
289
- *
290
- * Handles the complete query lifecycle:
291
- * 1. Loads or creates thread from memory
292
- * 2. Detects intent from the query
293
- * 3. Fulfills the intent with streaming AI response
294
- * 4. Updates conversation history in real-time
295
- *
296
- * @param threadMetadata - Metadata containing type, userId, and optional threadId
297
- * @param threadMetadata.type - The type of thread (e.g., chat, workflow)
298
- * @param threadMetadata.userId - The user's unique identifier
299
- * @param threadMetadata.threadId - Optional thread identifier
300
- * @param query - The user's input query
301
- * @returns AsyncGenerator yielding StreamEvent objects for SSE
302
- */
303
- async *handleQueryStream(threadMetadata, query, isA2A) {
304
- const { type, userId } = threadMetadata;
305
- const threadMemory = _optionalChain([this, 'access', _19 => _19.memoryModule, 'optionalAccess', _20 => _20.getThreadMemory, 'call', _21 => _21()]);
306
- let threadId = threadMetadata.threadId;
307
- let thread;
308
- if (threadId) {
309
- thread = await _optionalChain([threadMemory, 'optionalAccess', _22 => _22.getThread, 'call', _23 => _23(userId, threadId)]);
310
- if (!thread && !isA2A) {
311
- throw new (0, _chunkQHQLU7BIcjs.AinHttpError)(_httpstatuscodes.StatusCodes.NOT_FOUND, "Thread not found");
312
- }
313
- }
314
- threadId ??= _crypto.randomUUID.call(void 0, );
315
- if (!thread) {
316
- const title = await this.generateTitle(query);
317
- thread = await _optionalChain([threadMemory, 'optionalAccess', _24 => _24.createThread, 'call', _25 => _25(
318
- type,
319
- userId,
320
- threadId,
321
- title
322
- )]) || { type, userId, threadId, title, messages: [] };
323
- _chunk466ED5WNcjs.loggers.intentStream.info(`Create new thread: ${threadId}`);
324
- yield { event: "thread_id", data: { type, threadId, title } };
325
- }
326
- await this.addToThreadMessages(thread, {
327
- role: "USER" /* USER */,
328
- content: query
329
- });
330
- const triggeredIntent = await this.intentTriggering(
331
- query,
332
- thread
333
- );
334
- for (const { subquery, intent } of triggeredIntent) {
335
- await this.addToThreadMessages(thread, {
336
- role: "MODEL" /* MODEL */,
337
- content: subquery
338
- });
339
- const stream = this.intentFulfilling(subquery, threadId, thread, intent);
340
- let finalResponseText = "";
341
- for await (const event of stream) {
342
- if (event.event === "text_chunk" && event.data.delta) {
343
- _chunk466ED5WNcjs.loggers.intentStream.debug("text_chunk", { event });
344
- finalResponseText += event.data.delta;
345
- }
346
- yield event;
347
- }
348
- await this.addToThreadMessages(thread, {
349
- role: "MODEL" /* MODEL */,
350
- content: finalResponseText
351
- });
352
- }
353
- }
354
- };
355
-
356
-
357
-
358
- exports.QueryStreamService = QueryStreamService;
359
- //# sourceMappingURL=chunk-SUWC3YAJ.cjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-SUWC3YAJ.cjs","../../src/services/query-stream.service.ts"],"names":[],"mappings":"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","file":"/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-SUWC3YAJ.cjs","sourcesContent":[null,"import { randomUUID } from \"node:crypto\";\nimport { StatusCodes } from \"http-status-codes\";\nimport type {\n\tA2AModule,\n\tMCPModule,\n\tMemoryModule,\n\tModelModule,\n} from \"@/modules/index.js\";\nimport { type AinAgentPrompts, AinHttpError } from \"@/types/agent.js\";\nimport {\n\tCONNECTOR_PROTOCOL_TYPE,\n\ttype ConnectorTool,\n} from \"@/types/connector.js\";\nimport {\n\ttype Intent,\n\ttype MessageObject,\n\tMessageRole,\n\ttype ThreadObject,\n\ttype ThreadType,\n} from \"@/types/memory.js\";\nimport type { StreamEvent } from \"@/types/stream\";\nimport { loggers } from \"@/utils/logger.js\";\n\ntype TriggeredIntent = {\n\tsubquery: string;\n\tintent?: Intent;\n};\n\n/**\n * Service for processing user queries through the agent's AI pipeline.\n *\n * Orchestrates the query processing workflow including intent detection,\n * model inference, tool execution, and response generation. Manages\n * conversation context and coordinates between different modules.\n */\nexport class QueryStreamService {\n\tprivate modelModule: ModelModule;\n\tprivate a2aModule?: A2AModule;\n\tprivate mcpModule?: MCPModule;\n\tprivate memoryModule?: MemoryModule;\n\tprivate prompts?: AinAgentPrompts;\n\n\tconstructor(\n\t\tmodelModule: ModelModule,\n\t\ta2aModule?: A2AModule,\n\t\tmcpModule?: MCPModule,\n\t\tmemoryModule?: MemoryModule,\n\t\tprompts?: AinAgentPrompts,\n\t) {\n\t\tthis.modelModule = modelModule;\n\t\tthis.a2aModule = a2aModule;\n\t\tthis.mcpModule = mcpModule;\n\t\tthis.memoryModule = memoryModule;\n\t\tthis.prompts = prompts;\n\t}\n\n\tprivate async addToThreadMessages(\n\t\tthread: ThreadObject,\n\t\tparams: { role: MessageRole; content: string; metadata?: any },\n\t) {\n\t\ttry {\n\t\t\tconst threadMemory = this.memoryModule?.getThreadMemory();\n\t\t\tconst { userId, threadId } = thread; const newMessage: MessageObject = {\n\t\t\t\tmessageId: randomUUID(),\n\t\t\t\trole: params.role,\n\t\t\t\ttimestamp: Date.now(),\n\t\t\t\tcontent: { type: \"text\", parts: [params.content] },\n\t\t\t\tmetadata: params.metadata,\n\t\t\t};\n\t\t\tthread.messages.push(newMessage);\n\t\t\tawait threadMemory?.addMessagesToThread(userId, threadId, [newMessage]);\n\t\t} catch (error) {\n\t\t\tloggers.intentStream.error(\"Error adding message to thread\",\n\t\t\t\terror\n\t\t\t);\n\t\t}\n\t}\n\n\t/**\n\t * Detects the intent from context.\n\t *\n\t * @param query - The user's input query\n\t * @param thread - The thread history\n\t * @returns The detected intent\n\t */\n\tprivate async intentTriggering(\n\t\tquery: string,\n\t\tthread: ThreadObject | undefined,\n\t): Promise<Array<TriggeredIntent>> {\n\t\tconst modelInstance = this.modelModule.getModel();\n\t\tconst intentMemory = this.memoryModule?.getIntentMemory();\n\t\tif (!intentMemory) {\n\t\t\treturn [{ subquery: query }];\n\t\t}\n\n\t\t// 인텐트 목록 가져오기\n\t\tconst intents = await intentMemory.listIntents();\n\n\t\tif (intents.length === 0) {\n\t\t\tloggers.intentStream.warn(\"No intent found\");\n\t\t\treturn [{ subquery: query }];\n\t\t}\n\n\t\tconst intentList = intents\n\t\t\t.map((intent) => `- ${intent.name}: ${intent.description}`)\n\t\t\t.join(\"\\n\");\n\n\t\t// Convert thread messages to a string\n\t\tconst threadMessages = !thread\n\t\t\t? \"\"\n\t\t\t: thread.messages\n\t\t\t\t\t.sort((a, b) => a.timestamp - b.timestamp)\n\t\t\t\t\t.map((message: MessageObject) => {\n\t\t\t\t\t\tconst role =\n\t\t\t\t\t\t\tmessage.role === \"USER\"\n\t\t\t\t\t\t\t\t? \"User\"\n\t\t\t\t\t\t\t\t: message.role === \"MODEL\"\n\t\t\t\t\t\t\t\t\t? \"Assistant\"\n\t\t\t\t\t\t\t\t\t: \"System\";\n\t\t\t\t\t\tconst content = Array.isArray(message.content.parts)\n\t\t\t\t\t\t\t? message.content.parts.join(\" \")\n\t\t\t\t\t\t\t: String(message.content.parts);\n\t\t\t\t\t\treturn `${role}: \"\"\"${content}\"\"\"`;\n\t\t\t\t\t})\n\t\t\t\t\t.join(\"\\n\");\n\n\t\tconst systemPrompt = `You are an expert in accurately identifying user intentions.\n\nAvailable intent list:\n${intentList}\n\nPlease select and answer only from the above intent list. \nPlease return only the exact intent name without any additional explanations or text.`;\n\n\t\tconst userMessage = `The following is the conversation history with the user:\n\n${threadMessages}\n\nLast user question: \"${query}\"\n\nBased on the above conversation history, analyze the last user question and identify all relevant intents.\n\nInstructions:\n1. First, decompose the last user question into action-based subqueries (each representing a distinct action or task)\n2. Then, map each subquery to its corresponding intent from the available intent list\n3. Multiple intents can be identified if the question covers various topics or actions\n4. Maintain the logical sequence of the original question when splitting into subqueries\n5. If any subquery doesn't match any intent in the available list, map it to \"default\" intent\n\nOutput Format:\nReturn the results as a JSON array with the following structure:\n[\n {\n \"subquery\": \"<subquery_1>\",\n \"intentName\": \"<intent_name_1>\"\n },\n {\n \"subquery\": \"<subquery_2>\",\n \"intentName\": \"<intent_name_2>\"\n },\n ...\n]\n\nRequirements:\n- Each subquery should represent a single, actionable task or request\n- Preserve the original meaning and context when splitting queries\n- Select only from the provided intent list\n- Use \"default\" as the intent value for any subquery that doesn't match available intents.`;\n\n\t\tconst messages = modelInstance.generateMessages({\n\t\t\tquery: userMessage,\n\t\t\tsystemPrompt,\n\t\t});\n\n\t\tconst response = await modelInstance.fetch(messages);\n\t\tif (!response.content) {\n\t\t\tloggers.intent.debug(\"Cannot extract intent from query\");\n\t\t\treturn [{ subquery: query }];\n\t\t}\n\n\t\tconst subqueries = JSON.parse(response.content);\n\t\tconst triggeredIntent: Array<TriggeredIntent> = [];\n\t\tfor (const { subquery, intentName } of subqueries) {\n\t\t\tloggers.intent.debug(`Intent found: ${subquery}, ${intentName}`);\n\t\t\tconst intent = await intentMemory.getIntentByName(intentName);\n\t\t\ttriggeredIntent.push({ subquery, intent });\n\t\t}\n\n\t\treturn triggeredIntent;\n\t}\n\n\t/**\n\t * Fulfills the detected intent by generating a streaming response.\n\t *\n\t * Manages the complete inference loop including:\n\t * - Loading prompts and conversation history\n\t * - Collecting available tools from modules\n\t * - Executing model inference with tool support\n\t * - Processing tool calls iteratively until completion\n\t * - Streaming results as Server-Sent Events\n\t *\n\t * @param query - The user's input query\n\t * @param threadId - Thread identifier for context\n\t * @param thread - Previous conversation history\n\t * @param intent - Optional detected intent with custom prompt\n\t * @returns AsyncGenerator yielding StreamEvent objects\n\t */\n\tpublic async *intentFulfilling(\n\t\tquery: string,\n\t\tthreadId: string,\n\t\tthread: ThreadObject,\n\t\tintent?: Intent,\n\t): AsyncGenerator<StreamEvent> {\n\t\tconst systemPrompt = `\nToday is ${new Date().toLocaleDateString()}.\n\n${this.prompts?.agent || \"\"}\n\n${this.prompts?.system || \"\"}\n\n${intent?.prompt || \"\"}\n\t`.trim();\n\n\t\tconst modelInstance = this.modelModule.getModel();\n\t\tconst messages = modelInstance.generateMessages({\n\t\t\tquery,\n\t\t\tthread,\n\t\t\tsystemPrompt: systemPrompt.trim(),\n\t\t});\n\n\t\tconst tools: ConnectorTool[] = [];\n\t\tthis.mcpModule && tools.push(...this.mcpModule.getTools());\n\t\tthis.a2aModule && tools.push(...(await this.a2aModule.getTools()));\n\n\t\tconst functions = modelInstance.convertToolsToFunctions(tools);\n\n\t\tconst processList: string[] = [];\n\n\t\twhile (true) {\n\t\t\tconst responseStream = await modelInstance.fetchStreamWithContextMessage(\n\t\t\t\tmessages,\n\t\t\t\tfunctions,\n\t\t\t);\n\n\t\t\tconst assembledToolCalls: {\n\t\t\t\tid: string;\n\t\t\t\ttype: \"function\";\n\t\t\t\tfunction: { name: string; arguments: string };\n\t\t\t}[] = [];\n\n\t\t\tloggers.intentStream.debug(\"messages\", { messages });\n\n\t\t\tfor await (const chunk of responseStream) {\n\t\t\t\tconst delta = chunk.delta;\n\t\t\t\tif (delta?.tool_calls) {\n\t\t\t\t\tfor (const { index, id, function: func } of delta.tool_calls) {\n\t\t\t\t\t\tassembledToolCalls[index] ??= {\n\t\t\t\t\t\t\tid: \"\",\n\t\t\t\t\t\t\ttype: \"function\",\n\t\t\t\t\t\t\tfunction: { name: \"\", arguments: \"\" },\n\t\t\t\t\t\t};\n\n\t\t\t\t\t\tif (id) assembledToolCalls[index].id = id;\n\t\t\t\t\t\tif (func?.name) assembledToolCalls[index].function.name = func.name;\n\t\t\t\t\t\tif (func?.arguments)\n\t\t\t\t\t\t\tassembledToolCalls[index].function.arguments += func.arguments;\n\t\t\t\t\t}\n\t\t\t\t} else if (chunk.delta?.content) {\n\t\t\t\t\tyield {\n\t\t\t\t\t\tevent: \"text_chunk\",\n\t\t\t\t\t\tdata: { delta: chunk.delta.content },\n\t\t\t\t\t};\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tloggers.intentStream.debug(\"assembledToolCalls\", {\n\t\t\t\tassembledToolCalls,\n\t\t\t});\n\n\t\t\tif (assembledToolCalls.length > 0) {\n\t\t\t\tfor (const toolCall of assembledToolCalls) {\n\t\t\t\t\tconst toolCallId = randomUUID();\n\t\t\t\t\tconst toolName = toolCall.function.name;\n\t\t\t\t\tconst selectedTool = tools.filter(\n\t\t\t\t\t\t(tool) => tool.toolName === toolName,\n\t\t\t\t\t)[0];\n\n\t\t\t\t\tlet toolResult = \"\";\n\t\t\t\t\tif (\n\t\t\t\t\t\tthis.mcpModule &&\n\t\t\t\t\t\tselectedTool.protocol === CONNECTOR_PROTOCOL_TYPE.MCP\n\t\t\t\t\t) {\n\t\t\t\t\t\tconst toolArgs = JSON.parse(toolCall.function.arguments) as\n\t\t\t\t\t\t\t| { [x: string]: unknown }\n\t\t\t\t\t\t\t| undefined;\n\t\t\t\t\t\tyield {\n\t\t\t\t\t\t\tevent: \"tool_start\",\n\t\t\t\t\t\t\tdata: {\n\t\t\t\t\t\t\t\ttoolCallId,\n\t\t\t\t\t\t\t\tprotocol: CONNECTOR_PROTOCOL_TYPE.MCP,\n\t\t\t\t\t\t\t\ttoolName,\n\t\t\t\t\t\t\t\ttoolArgs,\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t};\n\t\t\t\t\t\tloggers.intent.debug(\"MCP tool call\", { toolName, toolArgs });\n\t\t\t\t\t\ttoolResult = await this.mcpModule.useTool(selectedTool, toolArgs);\n\t\t\t\t\t} else if (\n\t\t\t\t\t\tthis.a2aModule &&\n\t\t\t\t\t\tselectedTool.protocol === CONNECTOR_PROTOCOL_TYPE.A2A\n\t\t\t\t\t) {\n\t\t\t\t\t\tyield {\n\t\t\t\t\t\t\tevent: \"tool_start\",\n\t\t\t\t\t\t\tdata: {\n\t\t\t\t\t\t\t\ttoolCallId,\n\t\t\t\t\t\t\t\tprotocol: CONNECTOR_PROTOCOL_TYPE.A2A,\n\t\t\t\t\t\t\t\ttoolName,\n\t\t\t\t\t\t\t\ttoolArgs: null,\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t};\n\t\t\t\t\t\tloggers.intent.debug(\"A2A tool call\", { toolName });\n\t\t\t\t\t\ttoolResult = await this.a2aModule.useTool(\n\t\t\t\t\t\t\tselectedTool,\n\t\t\t\t\t\t\tquery,\n\t\t\t\t\t\t\tthreadId,\n\t\t\t\t\t\t);\n\t\t\t\t\t} else {\n\t\t\t\t\t\t// Unrecognized tool type. It cannot be happened...\n\t\t\t\t\t\tloggers.intent.warn(\n\t\t\t\t\t\t\t`Unrecognized tool type: ${selectedTool.protocol}`,\n\t\t\t\t\t\t);\n\t\t\t\t\t\tcontinue;\n\t\t\t\t\t}\n\t\t\t\t\tyield {\n\t\t\t\t\t\tevent: \"tool_output\",\n\t\t\t\t\t\tdata: {\n\t\t\t\t\t\t\ttoolCallId,\n\t\t\t\t\t\t\tprotocol: selectedTool.protocol,\n\t\t\t\t\t\t\ttoolName,\n\t\t\t\t\t\t\tresult: toolResult,\n\t\t\t\t\t\t},\n\t\t\t\t\t};\n\t\t\t\t\tloggers.intent.debug(\"toolResult\", { toolResult });\n\n\t\t\t\t\tprocessList.push(toolResult);\n\t\t\t\t\tmodelInstance.appendMessages(messages, toolResult);\n\t\t\t\t\tawait this.addToThreadMessages(thread, {\n\t\t\t\t\t\trole: MessageRole.MODEL,\n\t\t\t\t\t\tcontent: toolResult,\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t * Generates a title for the conversation based on the query.\n\t *\n\t * @param query - The user's input query\n\t * @returns Promise resolving to a generated title\n\t */\n\n\tprivate async generateTitle(query: string): Promise<string> {\n\t\tconst DEFAULT_TITLE = \"New Chat\";\n\t\ttry {\n\t\t\tconst modelInstance = this.modelModule.getModel();\n\t\t\tconst messages = modelInstance.generateMessages({\n\t\t\t\tquery,\n\t\t\t\tsystemPrompt: `You are a helpful assistant that generates titles for conversations.\n Please analyze the user's query and create a concise title that accurately reflects the conversation's core topic.\n The title must be no more than 5 words long.\n Respond with only the title. Do not include any punctuation or extra explanations.`,\n\t\t\t});\n\t\t\tconst response = await modelInstance.fetch(messages);\n\t\t\treturn response.content || DEFAULT_TITLE;\n\t\t} catch (error) {\n\t\t\tloggers.intentStream.error(\"Error generating title\", {\n\t\t\t\terror,\n\t\t\t\tquery,\n\t\t\t});\n\t\t\treturn DEFAULT_TITLE;\n\t\t}\n\t}\n\n\t/**\n\t * Main entry point for processing streaming user queries.\n\t *\n\t * Handles the complete query lifecycle:\n\t * 1. Loads or creates thread from memory\n\t * 2. Detects intent from the query\n\t * 3. Fulfills the intent with streaming AI response\n\t * 4. Updates conversation history in real-time\n\t *\n\t * @param threadMetadata - Metadata containing type, userId, and optional threadId\n\t * @param threadMetadata.type - The type of thread (e.g., chat, workflow)\n\t * @param threadMetadata.userId - The user's unique identifier\n\t * @param threadMetadata.threadId - Optional thread identifier\n\t * @param query - The user's input query\n\t * @returns AsyncGenerator yielding StreamEvent objects for SSE\n\t */\n\tpublic async *handleQueryStream(\n\t\tthreadMetadata: {\n\t\t\ttype: ThreadType;\n\t\t\tuserId: string;\n\t\t\tthreadId?: string;\n\t\t},\n\t\tquery: string,\n\t\tisA2A?: boolean,\n\t): AsyncGenerator<StreamEvent> {\n\t\tconst { type, userId } = threadMetadata;\n\t\tconst threadMemory = this.memoryModule?.getThreadMemory();\n\n\t\t// 1. Load or create thread\n\t\tlet threadId = threadMetadata.threadId;\n\t\tlet thread: ThreadObject | undefined;\n\t\tif (threadId) {\n\t\t\tthread = await threadMemory?.getThread(userId, threadId);\n\t\t\tif (!thread && !isA2A) {\n\t\t\t\tthrow new AinHttpError(StatusCodes.NOT_FOUND, \"Thread not found\");\n\t\t\t}\n\t\t}\n\n\t\tthreadId ??= randomUUID();\n\t\tif (!thread) {\n\t\t\tconst title = await this.generateTitle(query);\n\t\t\tthread = (await threadMemory?.createThread(\n\t\t\t\ttype,\n\t\t\t\tuserId,\n\t\t\t\tthreadId,\n\t\t\t\ttitle,\n\t\t\t)) || { type, userId, threadId, title, messages: [] };\n\t\t\tloggers.intentStream.info(`Create new thread: ${threadId}`);\n\t\t\tyield { event: \"thread_id\", data: { type, threadId, title } };\n\t\t}\n\n\t\tawait this.addToThreadMessages(thread, {\n\t\t\trole: MessageRole.USER,\n\t\t\tcontent: query,\n\t\t});\n\n\t\t// 2. intent triggering\n\t\tconst triggeredIntent: Array<TriggeredIntent> = await this.intentTriggering(\n\t\t\tquery,\n\t\t\tthread,\n\t\t);\n\n\t\t// 3. intent fulfillment\n\t\tfor (const { subquery, intent } of triggeredIntent) {\n\t\t\t// add subquery as user message\n\t\t\tawait this.addToThreadMessages(thread, {\n\t\t\t\trole: MessageRole.MODEL,\n\t\t\t\tcontent: subquery,\n\t\t\t});\n\n\t\t\tconst stream = this.intentFulfilling(subquery, threadId, thread, intent);\n\n\t\t\tlet finalResponseText = \"\";\n\t\t\tfor await (const event of stream) {\n\t\t\t\tif (event.event === \"text_chunk\" && event.data.delta) {\n\t\t\t\t\tloggers.intentStream.debug(\"text_chunk\", { event });\n\t\t\t\t\tfinalResponseText += event.data.delta;\n\t\t\t\t}\n\t\t\t\tyield event;\n\t\t\t}\n\n\t\t\t// response for subquery\n\t\t\tawait this.addToThreadMessages(thread, {\n\t\t\t\trole: MessageRole.MODEL,\n\t\t\t\tcontent: finalResponseText,\n\t\t\t});\n\t\t}\n\t}\n}\n"]}
@@ -1,256 +0,0 @@
1
- "use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _optionalChain(ops) { let lastAccessLHS = undefined; let value = ops[0]; let i = 1; while (i < ops.length) { const op = ops[i]; const fn = ops[i + 1]; i += 2; if ((op === 'optionalAccess' || op === 'optionalCall') && value == null) { return undefined; } if (op === 'access' || op === 'optionalAccess') { lastAccessLHS = value; value = fn(value); } else if (op === 'call' || op === 'optionalCall') { value = fn((...args) => value.call(lastAccessLHS, ...args)); lastAccessLHS = undefined; } } return value; }
2
-
3
- var _chunk466ED5WNcjs = require('./chunk-466ED5WN.cjs');
4
-
5
-
6
- var _chunkQHQLU7BIcjs = require('./chunk-QHQLU7BI.cjs');
7
-
8
- // src/services/query.service.ts
9
- var _crypto = require('crypto');
10
- var _httpstatuscodes = require('http-status-codes');
11
- var QueryService = class {
12
-
13
-
14
-
15
-
16
-
17
- constructor(modelModule, a2aModule, mcpModule, memoryModule, prompts) {
18
- this.modelModule = modelModule;
19
- this.a2aModule = a2aModule;
20
- this.mcpModule = mcpModule;
21
- this.memoryModule = memoryModule;
22
- this.prompts = prompts;
23
- }
24
- /**
25
- * Detects the intent from context.
26
- *
27
- * @param query - The user's input query
28
- * @param thread - The thread history
29
- * @returns The detected intent
30
- */
31
- async intentTriggering(query, thread) {
32
- const modelInstance = this.modelModule.getModel();
33
- const intentMemory = _optionalChain([this, 'access', _ => _.memoryModule, 'optionalAccess', _2 => _2.getIntentMemory, 'call', _3 => _3()]);
34
- if (!intentMemory) {
35
- return void 0;
36
- }
37
- const intents = await intentMemory.listIntents();
38
- if (intents.length === 0) {
39
- _chunk466ED5WNcjs.loggers.intent.warn("No intent found");
40
- return void 0;
41
- }
42
- const intentList = intents.map((intent2) => `- ${intent2.name}: ${intent2.description}`).join("\n");
43
- const threadMessages = !thread ? "" : thread.messages.sort((a, b) => a.timestamp - b.timestamp).map((message) => {
44
- const role = message.role === "USER" ? "User" : message.role === "MODEL" ? "Assistant" : "System";
45
- const content = Array.isArray(message.content.parts) ? message.content.parts.join(" ") : String(message.content.parts);
46
- return `${role}: """${content}"""`;
47
- }).join("\n");
48
- const systemPrompt = `You are an expert in accurately identifying user intentions.
49
-
50
- Available intent list:
51
- ${intentList}
52
-
53
- Please select and answer only from the above intent list.
54
- Please return only the exact intent name without any additional explanations or text.`;
55
- const userMessage = `The following is the conversation history with the user:
56
-
57
- ${threadMessages}
58
-
59
- Last user question: "${query}"
60
-
61
- Based on the above conversation history, please determine what the intention of the last user question is.
62
- Please select and answer the most appropriate intent name from the available intent list.`;
63
- const messages = modelInstance.generateMessages({
64
- query: userMessage,
65
- systemPrompt
66
- });
67
- const response = await modelInstance.fetch(messages);
68
- if (!response.content) {
69
- throw new Error("No intent detected");
70
- }
71
- const intentName = response.content.trim();
72
- const intent = await intentMemory.getIntentByName(intentName);
73
- if (!intent) {
74
- throw new Error(`No intent found: ${intentName}`);
75
- }
76
- return intent;
77
- }
78
- /**
79
- * Fulfills the detected intent by generating a response.
80
- *
81
- * Manages the complete inference loop including:
82
- * - Loading prompts and conversation history
83
- * - Collecting available tools from modules
84
- * - Executing model inference with tool support
85
- * - Processing tool calls iteratively until completion
86
- *
87
- * @param query - The user's input query
88
- * @param threadId - Thread identifier for context
89
- * @param thread - Previous conversation history
90
- * @param intent - Optional detected intent with custom prompt
91
- * @returns Object containing process steps and final response
92
- */
93
- async intentFulfilling(query, threadId, thread, intent) {
94
- const systemPrompt = `
95
- Today is ${(/* @__PURE__ */ new Date()).toLocaleDateString()}.
96
-
97
- ${_optionalChain([this, 'access', _4 => _4.prompts, 'optionalAccess', _5 => _5.agent]) || ""}
98
-
99
- ${_optionalChain([this, 'access', _6 => _6.prompts, 'optionalAccess', _7 => _7.system]) || ""}
100
-
101
- ${_optionalChain([intent, 'optionalAccess', _8 => _8.prompt]) || ""}
102
- `;
103
- const modelInstance = this.modelModule.getModel();
104
- const messages = modelInstance.generateMessages({
105
- query,
106
- thread,
107
- systemPrompt: systemPrompt.trim()
108
- });
109
- const tools = [];
110
- if (this.mcpModule) {
111
- tools.push(...this.mcpModule.getTools());
112
- }
113
- if (this.a2aModule) {
114
- tools.push(...await this.a2aModule.getTools());
115
- }
116
- const functions = modelInstance.convertToolsToFunctions(tools);
117
- const processList = [];
118
- let finalMessage = "";
119
- while (true) {
120
- const response = await modelInstance.fetchWithContextMessage(
121
- messages,
122
- functions
123
- );
124
- _chunk466ED5WNcjs.loggers.intent.debug("messages", { messages });
125
- const { content, toolCalls } = response;
126
- _chunk466ED5WNcjs.loggers.intent.debug("content", { content });
127
- _chunk466ED5WNcjs.loggers.intent.debug("tool_calls", { ...toolCalls });
128
- if (toolCalls) {
129
- for (const toolCall of toolCalls) {
130
- const toolName = toolCall.name;
131
- const selectedTool = tools.filter(
132
- (tool) => tool.toolName === toolName
133
- )[0];
134
- let toolResult = "";
135
- if (this.mcpModule && selectedTool.protocol === "MCP" /* MCP */) {
136
- const toolArgs = toolCall.arguments;
137
- _chunk466ED5WNcjs.loggers.intent.debug("MCP tool call", { toolName, toolArgs });
138
- toolResult = await this.mcpModule.useTool(selectedTool, toolArgs);
139
- } else if (this.a2aModule && selectedTool.protocol === "A2A" /* A2A */) {
140
- toolResult = await this.a2aModule.useTool(
141
- selectedTool,
142
- query,
143
- threadId
144
- );
145
- } else {
146
- _chunk466ED5WNcjs.loggers.intent.warn(
147
- `Unrecognized tool type: ${selectedTool.protocol}`
148
- );
149
- continue;
150
- }
151
- _chunk466ED5WNcjs.loggers.intent.debug("toolResult", { toolResult });
152
- processList.push(toolResult);
153
- modelInstance.appendMessages(messages, toolResult);
154
- }
155
- } else if (content) {
156
- processList.push(content);
157
- finalMessage = content;
158
- break;
159
- }
160
- }
161
- const botResponse = {
162
- process: processList.join("\n"),
163
- response: finalMessage
164
- };
165
- return botResponse;
166
- }
167
- /**
168
- * Generates a title for the conversation based on the query.
169
- *
170
- * @param query - The user's input query
171
- * @returns Promise resolving to a generated title
172
- */
173
- async generateTitle(query) {
174
- const DEFAULT_TITLE = "New Chat";
175
- try {
176
- const modelInstance = this.modelModule.getModel();
177
- const messages = modelInstance.generateMessages({
178
- query,
179
- systemPrompt: `You are a helpful assistant that generates titles for conversations.
180
- Please analyze the user's query and create a concise title that accurately reflects the conversation's core topic.
181
- The title must be no more than 5 words long.
182
- Respond with only the title. Do not include any punctuation or extra explanations.`
183
- });
184
- const response = await modelInstance.fetch(messages);
185
- return response.content || DEFAULT_TITLE;
186
- } catch (error) {
187
- _chunk466ED5WNcjs.loggers.intent.error("Error generating title", {
188
- error,
189
- query
190
- });
191
- return DEFAULT_TITLE;
192
- }
193
- }
194
- /**
195
- * Main entry point for processing user queries.
196
- *
197
- * Handles the complete query lifecycle:
198
- * 1. Loads or creates thread from memory
199
- * 2. Detects intent from the query
200
- * 3. Fulfills the intent with AI response
201
- * 4. Updates conversation history
202
- *
203
- * @param threadMetadata - Metadata containing type, userId, and optional threadId
204
- * @param threadMetadata.type - The type of thread (e.g., chat, workflow)
205
- * @param threadMetadata.userId - The user's unique identifier
206
- * @param threadMetadata.threadId - Optional thread identifier
207
- * @param query - The user's input query
208
- * @returns Promise resolving to object with content property containing the response
209
- */
210
- async handleQuery(threadMetadata, query, isA2A) {
211
- const { type, userId } = threadMetadata;
212
- const queryStartAt = Date.now();
213
- const threadMemory = _optionalChain([this, 'access', _9 => _9.memoryModule, 'optionalAccess', _10 => _10.getThreadMemory, 'call', _11 => _11()]);
214
- let threadId = threadMetadata.threadId;
215
- let thread;
216
- if (threadId) {
217
- thread = await _optionalChain([threadMemory, 'optionalAccess', _12 => _12.getThread, 'call', _13 => _13(userId, threadId)]);
218
- if (!thread && !isA2A) {
219
- throw new (0, _chunkQHQLU7BIcjs.AinHttpError)(_httpstatuscodes.StatusCodes.NOT_FOUND, "Thread not found");
220
- }
221
- }
222
- threadId ??= _crypto.randomUUID.call(void 0, );
223
- if (!thread) {
224
- const title = await this.generateTitle(query);
225
- const metadata = await _optionalChain([threadMemory, 'optionalAccess', _14 => _14.createThread, 'call', _15 => _15(type, userId, threadId, title)]) || {
226
- type,
227
- threadId,
228
- title,
229
- updatedAt: Date.now()
230
- };
231
- _chunk466ED5WNcjs.loggers.intent.info("Create new thread", { metadata });
232
- }
233
- const intent = await this.intentTriggering(query, thread);
234
- const result = await this.intentFulfilling(query, threadId, thread, intent);
235
- await _optionalChain([threadMemory, 'optionalAccess', _16 => _16.addMessagesToThread, 'call', _17 => _17(userId, threadId, [
236
- {
237
- messageId: _crypto.randomUUID.call(void 0, ),
238
- role: "USER" /* USER */,
239
- timestamp: queryStartAt,
240
- content: { type: "text", parts: [query] }
241
- },
242
- {
243
- messageId: _crypto.randomUUID.call(void 0, ),
244
- role: "MODEL" /* MODEL */,
245
- timestamp: Date.now(),
246
- content: { type: "text", parts: [result.response] }
247
- }
248
- ])]);
249
- return { content: result.response };
250
- }
251
- };
252
-
253
-
254
-
255
- exports.QueryService = QueryService;
256
- //# sourceMappingURL=chunk-SZU5VCQL.cjs.map