@ainetwork/adk 0.3.0 → 0.3.2

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 (367) hide show
  1. package/dist/cjs/{chunk-ZFSXQFEK.cjs → chunk-25FZXCHU.cjs} +51 -16
  2. package/dist/cjs/chunk-25FZXCHU.cjs.map +1 -0
  3. package/dist/cjs/{chunk-7QIF3FVV.cjs → chunk-3RS6NVSN.cjs} +7 -7
  4. package/dist/cjs/{chunk-7QIF3FVV.cjs.map → chunk-3RS6NVSN.cjs.map} +1 -1
  5. package/dist/cjs/{chunk-6WAVK3BS.cjs → chunk-4IBKK5HW.cjs} +27 -9
  6. package/dist/cjs/chunk-4IBKK5HW.cjs.map +1 -0
  7. package/dist/cjs/{chunk-QSBUV5WJ.cjs → chunk-5QSLQX4H.cjs} +20 -16
  8. package/dist/cjs/chunk-5QSLQX4H.cjs.map +1 -0
  9. package/dist/cjs/{chunk-OVTUSYSU.cjs → chunk-5WWZOWMA.cjs} +1 -1
  10. package/dist/cjs/chunk-5WWZOWMA.cjs.map +1 -0
  11. package/dist/cjs/{chunk-AWHKDGXN.cjs → chunk-6T2YGFSD.cjs} +3 -3
  12. package/dist/cjs/{chunk-AWHKDGXN.cjs.map → chunk-6T2YGFSD.cjs.map} +1 -1
  13. package/dist/cjs/{chunk-4TO7EZ5J.cjs → chunk-7KXB6FOT.cjs} +22 -43
  14. package/dist/cjs/chunk-7KXB6FOT.cjs.map +1 -0
  15. package/dist/cjs/chunk-B3U3LJ7J.cjs +17 -0
  16. package/dist/cjs/chunk-B3U3LJ7J.cjs.map +1 -0
  17. package/dist/cjs/{chunk-ICFTUZP5.cjs → chunk-C5JALNJT.cjs} +4 -4
  18. package/dist/cjs/{chunk-ICFTUZP5.cjs.map → chunk-C5JALNJT.cjs.map} +1 -1
  19. package/dist/cjs/chunk-CLJ3DWTA.cjs +62 -0
  20. package/dist/cjs/chunk-CLJ3DWTA.cjs.map +1 -0
  21. package/dist/cjs/{chunk-I4ET55WI.cjs → chunk-DGXLVGIM.cjs} +7 -7
  22. package/dist/cjs/{chunk-I4ET55WI.cjs.map → chunk-DGXLVGIM.cjs.map} +1 -1
  23. package/dist/cjs/{chunk-PSHQ4OBL.cjs → chunk-E3PD4Q76.cjs} +7 -7
  24. package/dist/cjs/{chunk-PSHQ4OBL.cjs.map → chunk-E3PD4Q76.cjs.map} +1 -1
  25. package/dist/cjs/{chunk-ASEYNIPL.cjs → chunk-EA3YMPST.cjs} +7 -7
  26. package/dist/cjs/{chunk-OFUS74ON.cjs.map → chunk-EA3YMPST.cjs.map} +1 -1
  27. package/dist/cjs/{chunk-K5LS7KNV.cjs → chunk-HF7GKQ6Y.cjs} +10 -10
  28. package/dist/cjs/{chunk-K5LS7KNV.cjs.map → chunk-HF7GKQ6Y.cjs.map} +1 -1
  29. package/dist/cjs/{chunk-NYYEZ4ER.cjs → chunk-M5TQFW2Y.cjs} +3 -3
  30. package/dist/cjs/{chunk-NYYEZ4ER.cjs.map → chunk-M5TQFW2Y.cjs.map} +1 -1
  31. package/dist/cjs/{chunk-TF7S7SPO.cjs → chunk-NEWJ7PXH.cjs} +4 -4
  32. package/dist/cjs/{chunk-TF7S7SPO.cjs.map → chunk-NEWJ7PXH.cjs.map} +1 -1
  33. package/dist/cjs/{chunk-AQXHOGJD.cjs → chunk-NNYPZA6W.cjs} +19 -1
  34. package/dist/cjs/chunk-NNYPZA6W.cjs.map +1 -0
  35. package/dist/cjs/chunk-O5X5QT63.cjs +19 -0
  36. package/dist/cjs/chunk-O5X5QT63.cjs.map +1 -0
  37. package/dist/cjs/{chunk-2TOW46DI.cjs → chunk-OZPPTVUA.cjs} +46 -57
  38. package/dist/cjs/chunk-OZPPTVUA.cjs.map +1 -0
  39. package/dist/cjs/{chunk-BDQDZXZI.cjs → chunk-RCOESZIX.cjs} +9 -23
  40. package/dist/cjs/chunk-RCOESZIX.cjs.map +1 -0
  41. package/dist/cjs/{chunk-L7QJRM2U.cjs → chunk-RVT67VJL.cjs} +13 -39
  42. package/dist/cjs/chunk-RVT67VJL.cjs.map +1 -0
  43. package/dist/cjs/{chunk-X5INT5HE.cjs → chunk-U47SG7XG.cjs} +16 -11
  44. package/dist/cjs/chunk-U47SG7XG.cjs.map +1 -0
  45. package/dist/cjs/{chunk-MO3H4KHE.cjs → chunk-XHTEJE4E.cjs} +3 -3
  46. package/dist/cjs/{chunk-MO3H4KHE.cjs.map → chunk-XHTEJE4E.cjs.map} +1 -1
  47. package/dist/cjs/{chunk-OFUS74ON.cjs → chunk-YY7HSXBP.cjs} +7 -7
  48. package/dist/cjs/{chunk-YGK2LYEU.cjs.map → chunk-YY7HSXBP.cjs.map} +1 -1
  49. package/dist/cjs/config/manifest.cjs +9 -0
  50. package/dist/cjs/config/manifest.cjs.map +1 -0
  51. package/dist/cjs/controllers/a2a.controller.cjs +3 -3
  52. package/dist/cjs/controllers/index.cjs +5 -4
  53. package/dist/cjs/controllers/index.cjs.map +1 -1
  54. package/dist/cjs/controllers/query.controller.cjs +3 -2
  55. package/dist/cjs/controllers/query.controller.cjs.map +1 -1
  56. package/dist/cjs/index.cjs +38 -50
  57. package/dist/cjs/index.cjs.map +1 -1
  58. package/dist/cjs/middlewares/error.middleware.cjs +3 -3
  59. package/dist/cjs/modules/a2a/a2a.connector.cjs +2 -2
  60. package/dist/cjs/modules/a2a/a2a.module.cjs +5 -5
  61. package/dist/cjs/modules/index.cjs +9 -9
  62. package/dist/cjs/modules/index.cjs.map +1 -1
  63. package/dist/cjs/modules/mcp/mcp.module.cjs +3 -3
  64. package/dist/cjs/routes/a2a.routes.cjs +12 -11
  65. package/dist/cjs/routes/a2a.routes.cjs.map +1 -1
  66. package/dist/cjs/routes/index.cjs +16 -15
  67. package/dist/cjs/routes/index.cjs.map +1 -1
  68. package/dist/cjs/routes/intent.routes.cjs +13 -12
  69. package/dist/cjs/routes/intent.routes.cjs.map +1 -1
  70. package/dist/cjs/routes/query.routes.cjs +13 -12
  71. package/dist/cjs/routes/query.routes.cjs.map +1 -1
  72. package/dist/cjs/services/a2a.service.cjs +3 -3
  73. package/dist/cjs/services/index.cjs +13 -12
  74. package/dist/cjs/services/index.cjs.map +1 -1
  75. package/dist/cjs/services/intents/fulfill-stream.service.cjs +5 -4
  76. package/dist/cjs/services/intents/fulfill-stream.service.cjs.map +1 -1
  77. package/dist/cjs/services/intents/fulfill.service.cjs +4 -4
  78. package/dist/cjs/services/intents/trigger.service.cjs +3 -3
  79. package/dist/cjs/services/query-stream.service.cjs +9 -8
  80. package/dist/cjs/services/query-stream.service.cjs.map +1 -1
  81. package/dist/cjs/services/query.service.cjs +8 -8
  82. package/dist/cjs/services/utils/query.common.cjs +3 -3
  83. package/dist/cjs/utils/isValidUrl.cjs +7 -0
  84. package/dist/cjs/utils/isValidUrl.cjs.map +1 -0
  85. package/dist/cjs/utils/logger.cjs +2 -2
  86. package/dist/esm/chunk-2J2TQRP4.js +19 -0
  87. package/dist/esm/chunk-2J2TQRP4.js.map +1 -0
  88. package/dist/esm/{chunk-DM6UZSRU.js → chunk-4LBR3TIJ.js} +5 -19
  89. package/dist/esm/chunk-4LBR3TIJ.js.map +1 -0
  90. package/dist/esm/{chunk-J2UFYVKK.js → chunk-5IIF5O4A.js} +2 -2
  91. package/dist/esm/{chunk-YVN6VFRT.js → chunk-6AN7Z5OC.js} +6 -6
  92. package/dist/esm/{chunk-4NESTSZ3.js → chunk-A5PRJ33H.js} +34 -45
  93. package/dist/esm/chunk-A5PRJ33H.js.map +1 -0
  94. package/dist/esm/{chunk-WMZ6PYTE.js → chunk-BZZDVW26.js} +1 -1
  95. package/dist/esm/chunk-BZZDVW26.js.map +1 -0
  96. package/dist/esm/{chunk-NWL3BMUH.js → chunk-FRQSMPPK.js} +49 -14
  97. package/dist/esm/chunk-FRQSMPPK.js.map +1 -0
  98. package/dist/esm/chunk-I5DLV2CU.js +17 -0
  99. package/dist/esm/chunk-I5DLV2CU.js.map +1 -0
  100. package/dist/esm/{chunk-3QCXIHM7.js → chunk-JCXAHLRN.js} +12 -8
  101. package/dist/esm/chunk-JCXAHLRN.js.map +1 -0
  102. package/dist/esm/{chunk-OW7PCDK5.js → chunk-JHKBIDPX.js} +19 -1
  103. package/dist/esm/chunk-JHKBIDPX.js.map +1 -0
  104. package/dist/esm/{chunk-DIW5VDAQ.js → chunk-KOCOM7IC.js} +2 -2
  105. package/dist/esm/{chunk-YDMTU6UH.js → chunk-PVWOU6LA.js} +21 -3
  106. package/dist/esm/chunk-PVWOU6LA.js.map +1 -0
  107. package/dist/esm/{chunk-MCMWSGRJ.js → chunk-Q7NLA5X4.js} +7 -7
  108. package/dist/esm/{chunk-MAU2MAK2.js → chunk-RAHOYMKY.js} +2 -2
  109. package/dist/esm/{chunk-WL7H2QX4.js → chunk-UEUZ7G5P.js} +8 -3
  110. package/dist/esm/chunk-UEUZ7G5P.js.map +1 -0
  111. package/dist/esm/chunk-VUMI4XOY.js +62 -0
  112. package/dist/esm/chunk-VUMI4XOY.js.map +1 -0
  113. package/dist/esm/{chunk-THBAYYPZ.js → chunk-WO2QJ6UM.js} +2 -2
  114. package/dist/esm/{chunk-7XCSPITE.js → chunk-Y7BKUWRJ.js} +7 -7
  115. package/dist/esm/{chunk-ZK2KSFGQ.js → chunk-YJTWW6QK.js} +4 -4
  116. package/dist/esm/{chunk-HAE333YO.js → chunk-YMSNW2SU.js} +2 -2
  117. package/dist/esm/config/manifest.d.ts +7 -0
  118. package/dist/esm/config/manifest.js +9 -0
  119. package/dist/esm/config/manifest.js.map +1 -0
  120. package/dist/esm/controllers/a2a.controller.d.ts +2 -2
  121. package/dist/esm/controllers/a2a.controller.js +2 -2
  122. package/dist/esm/controllers/api/agent.api.controller.d.ts +2 -2
  123. package/dist/esm/controllers/index.d.ts +2 -2
  124. package/dist/esm/controllers/index.js +4 -3
  125. package/dist/esm/controllers/query.controller.d.ts +2 -2
  126. package/dist/esm/controllers/query.controller.js +2 -1
  127. package/dist/esm/index.d.ts +2 -9
  128. package/dist/esm/index.js +36 -48
  129. package/dist/esm/index.js.map +1 -1
  130. package/dist/esm/middlewares/error.middleware.js +2 -2
  131. package/dist/esm/modules/a2a/a2a.connector.d.ts +2 -2
  132. package/dist/esm/modules/a2a/a2a.connector.js +1 -1
  133. package/dist/esm/modules/a2a/a2a.module.d.ts +5 -2
  134. package/dist/esm/modules/a2a/a2a.module.js +4 -4
  135. package/dist/esm/modules/index.d.ts +2 -2
  136. package/dist/esm/modules/index.js +10 -10
  137. package/dist/esm/modules/mcp/mcp.module.js +2 -2
  138. package/dist/esm/routes/a2a.routes.d.ts +2 -2
  139. package/dist/esm/routes/a2a.routes.js +11 -10
  140. package/dist/esm/routes/api/agent.routes.d.ts +2 -2
  141. package/dist/esm/routes/api.routes.d.ts +2 -2
  142. package/dist/esm/routes/api.routes.js +3 -3
  143. package/dist/esm/routes/index.d.ts +2 -2
  144. package/dist/esm/routes/index.js +20 -19
  145. package/dist/esm/routes/intent.routes.d.ts +2 -2
  146. package/dist/esm/routes/intent.routes.js +13 -12
  147. package/dist/esm/routes/query.routes.d.ts +2 -2
  148. package/dist/esm/routes/query.routes.js +12 -11
  149. package/dist/esm/services/a2a.service.d.ts +2 -2
  150. package/dist/esm/services/a2a.service.js +2 -2
  151. package/dist/esm/services/index.d.ts +2 -2
  152. package/dist/esm/services/index.js +13 -12
  153. package/dist/esm/services/intents/fulfill-stream.service.js +4 -3
  154. package/dist/esm/services/intents/fulfill.service.d.ts +1 -1
  155. package/dist/esm/services/intents/fulfill.service.js +3 -3
  156. package/dist/esm/services/intents/trigger.service.js +2 -2
  157. package/dist/esm/services/query-stream.service.d.ts +2 -1
  158. package/dist/esm/services/query-stream.service.js +8 -7
  159. package/dist/esm/services/query.service.d.ts +1 -1
  160. package/dist/esm/services/query.service.js +7 -7
  161. package/dist/esm/services/utils/fulfill.common.d.ts +1 -1
  162. package/dist/esm/services/utils/query.common.js +2 -2
  163. package/dist/esm/types/stream.d.ts +3 -3
  164. package/dist/esm/utils/isValidUrl.d.ts +9 -0
  165. package/dist/esm/utils/isValidUrl.js +7 -0
  166. package/dist/esm/utils/isValidUrl.js.map +1 -0
  167. package/dist/esm/utils/logger.js +1 -1
  168. package/package.json +5 -4
  169. package/dist/cjs/chunk-2OXSV2VU.cjs +0 -134
  170. package/dist/cjs/chunk-2OXSV2VU.cjs.map +0 -1
  171. package/dist/cjs/chunk-2TNBBXQ3.cjs +0 -129
  172. package/dist/cjs/chunk-2TNBBXQ3.cjs.map +0 -1
  173. package/dist/cjs/chunk-2TOW46DI.cjs.map +0 -1
  174. package/dist/cjs/chunk-35MIRD7Z.cjs +0 -134
  175. package/dist/cjs/chunk-35MIRD7Z.cjs.map +0 -1
  176. package/dist/cjs/chunk-37J4FFJ3.cjs +0 -133
  177. package/dist/cjs/chunk-37J4FFJ3.cjs.map +0 -1
  178. package/dist/cjs/chunk-3BPHCG6M.cjs +0 -30
  179. package/dist/cjs/chunk-3BPHCG6M.cjs.map +0 -1
  180. package/dist/cjs/chunk-3XJS5S3O.cjs +0 -191
  181. package/dist/cjs/chunk-3XJS5S3O.cjs.map +0 -1
  182. package/dist/cjs/chunk-43XI3NHI.cjs +0 -43
  183. package/dist/cjs/chunk-43XI3NHI.cjs.map +0 -1
  184. package/dist/cjs/chunk-466ED5WN.cjs +0 -41
  185. package/dist/cjs/chunk-466ED5WN.cjs.map +0 -1
  186. package/dist/cjs/chunk-4KL2BCDZ.cjs +0 -43
  187. package/dist/cjs/chunk-4KL2BCDZ.cjs.map +0 -1
  188. package/dist/cjs/chunk-4RPP5UAH.cjs +0 -202
  189. package/dist/cjs/chunk-4RPP5UAH.cjs.map +0 -1
  190. package/dist/cjs/chunk-4TO7EZ5J.cjs.map +0 -1
  191. package/dist/cjs/chunk-5IEVTAT2.cjs +0 -37
  192. package/dist/cjs/chunk-5IEVTAT2.cjs.map +0 -1
  193. package/dist/cjs/chunk-67CP7NP7.cjs +0 -132
  194. package/dist/cjs/chunk-67CP7NP7.cjs.map +0 -1
  195. package/dist/cjs/chunk-6WAVK3BS.cjs.map +0 -1
  196. package/dist/cjs/chunk-7CCDDRLV.cjs +0 -28
  197. package/dist/cjs/chunk-7CCDDRLV.cjs.map +0 -1
  198. package/dist/cjs/chunk-7ELF6ICG.cjs +0 -129
  199. package/dist/cjs/chunk-7ELF6ICG.cjs.map +0 -1
  200. package/dist/cjs/chunk-7IORLKS7.cjs +0 -28
  201. package/dist/cjs/chunk-7IORLKS7.cjs.map +0 -1
  202. package/dist/cjs/chunk-7P4O537H.cjs +0 -132
  203. package/dist/cjs/chunk-7P4O537H.cjs.map +0 -1
  204. package/dist/cjs/chunk-AIUJ6CZR.cjs +0 -37
  205. package/dist/cjs/chunk-AIUJ6CZR.cjs.map +0 -1
  206. package/dist/cjs/chunk-AQXHOGJD.cjs.map +0 -1
  207. package/dist/cjs/chunk-ASEYNIPL.cjs.map +0 -1
  208. package/dist/cjs/chunk-BDQDZXZI.cjs.map +0 -1
  209. package/dist/cjs/chunk-BXBFJKZC.cjs +0 -114
  210. package/dist/cjs/chunk-BXBFJKZC.cjs.map +0 -1
  211. package/dist/cjs/chunk-BYTLWEXM.cjs +0 -43
  212. package/dist/cjs/chunk-BYTLWEXM.cjs.map +0 -1
  213. package/dist/cjs/chunk-C35ER63S.cjs +0 -134
  214. package/dist/cjs/chunk-C35ER63S.cjs.map +0 -1
  215. package/dist/cjs/chunk-CGD7CECK.cjs +0 -129
  216. package/dist/cjs/chunk-CGD7CECK.cjs.map +0 -1
  217. package/dist/cjs/chunk-CKIA6H2D.cjs +0 -30
  218. package/dist/cjs/chunk-CKIA6H2D.cjs.map +0 -1
  219. package/dist/cjs/chunk-CPZBDQ5D.cjs +0 -28
  220. package/dist/cjs/chunk-CPZBDQ5D.cjs.map +0 -1
  221. package/dist/cjs/chunk-DEWNBL5H.cjs +0 -37
  222. package/dist/cjs/chunk-DEWNBL5H.cjs.map +0 -1
  223. package/dist/cjs/chunk-DK57ZF33.cjs +0 -28
  224. package/dist/cjs/chunk-DK57ZF33.cjs.map +0 -1
  225. package/dist/cjs/chunk-DQIGZKKW.cjs +0 -37
  226. package/dist/cjs/chunk-DQIGZKKW.cjs.map +0 -1
  227. package/dist/cjs/chunk-DT2RCV6G.cjs +0 -40
  228. package/dist/cjs/chunk-DT2RCV6G.cjs.map +0 -1
  229. package/dist/cjs/chunk-E35E4LQY.cjs +0 -43
  230. package/dist/cjs/chunk-E35E4LQY.cjs.map +0 -1
  231. package/dist/cjs/chunk-EETXLYKA.cjs +0 -28
  232. package/dist/cjs/chunk-EETXLYKA.cjs.map +0 -1
  233. package/dist/cjs/chunk-F3A5E26D.cjs +0 -115
  234. package/dist/cjs/chunk-F3A5E26D.cjs.map +0 -1
  235. package/dist/cjs/chunk-FH44ANEI.cjs +0 -134
  236. package/dist/cjs/chunk-FH44ANEI.cjs.map +0 -1
  237. package/dist/cjs/chunk-FTRCEUDB.cjs +0 -40
  238. package/dist/cjs/chunk-FTRCEUDB.cjs.map +0 -1
  239. package/dist/cjs/chunk-G3BK3F7V.cjs +0 -129
  240. package/dist/cjs/chunk-G3BK3F7V.cjs.map +0 -1
  241. package/dist/cjs/chunk-GKXXTC6C.cjs +0 -191
  242. package/dist/cjs/chunk-GKXXTC6C.cjs.map +0 -1
  243. package/dist/cjs/chunk-GM3S5465.cjs +0 -28
  244. package/dist/cjs/chunk-GM3S5465.cjs.map +0 -1
  245. package/dist/cjs/chunk-GMCHHP5Z.cjs +0 -37
  246. package/dist/cjs/chunk-GMCHHP5Z.cjs.map +0 -1
  247. package/dist/cjs/chunk-GP3SSTAQ.cjs +0 -8
  248. package/dist/cjs/chunk-GP3SSTAQ.cjs.map +0 -1
  249. package/dist/cjs/chunk-HDZ5POWB.cjs +0 -134
  250. package/dist/cjs/chunk-HDZ5POWB.cjs.map +0 -1
  251. package/dist/cjs/chunk-HIL5SDJR.cjs +0 -43
  252. package/dist/cjs/chunk-HIL5SDJR.cjs.map +0 -1
  253. package/dist/cjs/chunk-HNKMBS3C.cjs +0 -43
  254. package/dist/cjs/chunk-HNKMBS3C.cjs.map +0 -1
  255. package/dist/cjs/chunk-ICNXY2NK.cjs +0 -132
  256. package/dist/cjs/chunk-ICNXY2NK.cjs.map +0 -1
  257. package/dist/cjs/chunk-ISQSPK4F.cjs +0 -134
  258. package/dist/cjs/chunk-ISQSPK4F.cjs.map +0 -1
  259. package/dist/cjs/chunk-J2FGGTF5.cjs +0 -37
  260. package/dist/cjs/chunk-J2FGGTF5.cjs.map +0 -1
  261. package/dist/cjs/chunk-J5GBTBSY.cjs +0 -134
  262. package/dist/cjs/chunk-J5GBTBSY.cjs.map +0 -1
  263. package/dist/cjs/chunk-JU5AB7AB.cjs +0 -37
  264. package/dist/cjs/chunk-JU5AB7AB.cjs.map +0 -1
  265. package/dist/cjs/chunk-K2W5TTBJ.cjs +0 -28
  266. package/dist/cjs/chunk-K2W5TTBJ.cjs.map +0 -1
  267. package/dist/cjs/chunk-KLSZEQ7H.cjs +0 -281
  268. package/dist/cjs/chunk-KLSZEQ7H.cjs.map +0 -1
  269. package/dist/cjs/chunk-L3PZU7OF.cjs +0 -285
  270. package/dist/cjs/chunk-L3PZU7OF.cjs.map +0 -1
  271. package/dist/cjs/chunk-L7QJRM2U.cjs.map +0 -1
  272. package/dist/cjs/chunk-LKVNLT2M.cjs +0 -132
  273. package/dist/cjs/chunk-LKVNLT2M.cjs.map +0 -1
  274. package/dist/cjs/chunk-M7K34W2H.cjs +0 -134
  275. package/dist/cjs/chunk-M7K34W2H.cjs.map +0 -1
  276. package/dist/cjs/chunk-MJAKDII2.cjs +0 -78
  277. package/dist/cjs/chunk-MJAKDII2.cjs.map +0 -1
  278. package/dist/cjs/chunk-MN47LTUO.cjs +0 -37
  279. package/dist/cjs/chunk-MN47LTUO.cjs.map +0 -1
  280. package/dist/cjs/chunk-NB6OID2Z.cjs +0 -285
  281. package/dist/cjs/chunk-NB6OID2Z.cjs.map +0 -1
  282. package/dist/cjs/chunk-NCYNT6TA.cjs +0 -129
  283. package/dist/cjs/chunk-NCYNT6TA.cjs.map +0 -1
  284. package/dist/cjs/chunk-NQUYHJ3J.cjs +0 -115
  285. package/dist/cjs/chunk-NQUYHJ3J.cjs.map +0 -1
  286. package/dist/cjs/chunk-OU5UB2HF.cjs +0 -113
  287. package/dist/cjs/chunk-OU5UB2HF.cjs.map +0 -1
  288. package/dist/cjs/chunk-OVTUSYSU.cjs.map +0 -1
  289. package/dist/cjs/chunk-PACFW2PR.cjs +0 -37
  290. package/dist/cjs/chunk-PACFW2PR.cjs.map +0 -1
  291. package/dist/cjs/chunk-QDX7LVBM.cjs +0 -284
  292. package/dist/cjs/chunk-QDX7LVBM.cjs.map +0 -1
  293. package/dist/cjs/chunk-QE7UAZY6.cjs +0 -37
  294. package/dist/cjs/chunk-QE7UAZY6.cjs.map +0 -1
  295. package/dist/cjs/chunk-QHQLU7BI.cjs +0 -13
  296. package/dist/cjs/chunk-QHQLU7BI.cjs.map +0 -1
  297. package/dist/cjs/chunk-QSBUV5WJ.cjs.map +0 -1
  298. package/dist/cjs/chunk-QZHI7LLI.cjs +0 -156
  299. package/dist/cjs/chunk-QZHI7LLI.cjs.map +0 -1
  300. package/dist/cjs/chunk-R42QDO6G.cjs +0 -28
  301. package/dist/cjs/chunk-R42QDO6G.cjs.map +0 -1
  302. package/dist/cjs/chunk-RIJV7J5Z.cjs +0 -52
  303. package/dist/cjs/chunk-RIJV7J5Z.cjs.map +0 -1
  304. package/dist/cjs/chunk-S2NO7QKM.cjs +0 -132
  305. package/dist/cjs/chunk-S2NO7QKM.cjs.map +0 -1
  306. package/dist/cjs/chunk-SCOMNXDA.cjs +0 -51
  307. package/dist/cjs/chunk-SCOMNXDA.cjs.map +0 -1
  308. package/dist/cjs/chunk-SSOKZ4O2.cjs +0 -41
  309. package/dist/cjs/chunk-SSOKZ4O2.cjs.map +0 -1
  310. package/dist/cjs/chunk-T3N54JRA.cjs +0 -41
  311. package/dist/cjs/chunk-T3N54JRA.cjs.map +0 -1
  312. package/dist/cjs/chunk-TJAP46DQ.cjs +0 -43
  313. package/dist/cjs/chunk-TJAP46DQ.cjs.map +0 -1
  314. package/dist/cjs/chunk-TOVCM7I7.cjs +0 -281
  315. package/dist/cjs/chunk-TOVCM7I7.cjs.map +0 -1
  316. package/dist/cjs/chunk-TUAC64ZF.cjs +0 -41
  317. package/dist/cjs/chunk-TUAC64ZF.cjs.map +0 -1
  318. package/dist/cjs/chunk-UEOOHJIR.cjs +0 -43
  319. package/dist/cjs/chunk-UEOOHJIR.cjs.map +0 -1
  320. package/dist/cjs/chunk-UGDFRSMS.cjs +0 -200
  321. package/dist/cjs/chunk-UGDFRSMS.cjs.map +0 -1
  322. package/dist/cjs/chunk-VNAH5COA.cjs +0 -202
  323. package/dist/cjs/chunk-VNAH5COA.cjs.map +0 -1
  324. package/dist/cjs/chunk-W4IBNFLJ.cjs +0 -43
  325. package/dist/cjs/chunk-W4IBNFLJ.cjs.map +0 -1
  326. package/dist/cjs/chunk-W5NZWOXV.cjs +0 -283
  327. package/dist/cjs/chunk-W5NZWOXV.cjs.map +0 -1
  328. package/dist/cjs/chunk-WGAEW3R3.cjs +0 -134
  329. package/dist/cjs/chunk-WGAEW3R3.cjs.map +0 -1
  330. package/dist/cjs/chunk-WKGN6P3D.cjs +0 -131
  331. package/dist/cjs/chunk-WKGN6P3D.cjs.map +0 -1
  332. package/dist/cjs/chunk-X5INT5HE.cjs.map +0 -1
  333. package/dist/cjs/chunk-X6R53KCL.cjs +0 -134
  334. package/dist/cjs/chunk-X6R53KCL.cjs.map +0 -1
  335. package/dist/cjs/chunk-YCD3FBPB.cjs +0 -41
  336. package/dist/cjs/chunk-YCD3FBPB.cjs.map +0 -1
  337. package/dist/cjs/chunk-YE6INMSS.cjs +0 -41
  338. package/dist/cjs/chunk-YE6INMSS.cjs.map +0 -1
  339. package/dist/cjs/chunk-YGK2LYEU.cjs +0 -36
  340. package/dist/cjs/chunk-YIRGAWMS.cjs +0 -30
  341. package/dist/cjs/chunk-YIRGAWMS.cjs.map +0 -1
  342. package/dist/cjs/chunk-YJSEM4WE.cjs +0 -116
  343. package/dist/cjs/chunk-YJSEM4WE.cjs.map +0 -1
  344. package/dist/cjs/chunk-YMNLHFLD.cjs +0 -251
  345. package/dist/cjs/chunk-YMNLHFLD.cjs.map +0 -1
  346. package/dist/cjs/chunk-ZFSXQFEK.cjs.map +0 -1
  347. package/dist/cjs/chunk-ZP35BH7F.cjs +0 -43
  348. package/dist/cjs/chunk-ZP35BH7F.cjs.map +0 -1
  349. package/dist/esm/chunk-3QCXIHM7.js.map +0 -1
  350. package/dist/esm/chunk-4NESTSZ3.js.map +0 -1
  351. package/dist/esm/chunk-DM6UZSRU.js.map +0 -1
  352. package/dist/esm/chunk-N7VYM2R5.js +0 -41
  353. package/dist/esm/chunk-N7VYM2R5.js.map +0 -1
  354. package/dist/esm/chunk-NWL3BMUH.js.map +0 -1
  355. package/dist/esm/chunk-OW7PCDK5.js.map +0 -1
  356. package/dist/esm/chunk-WL7H2QX4.js.map +0 -1
  357. package/dist/esm/chunk-WMZ6PYTE.js.map +0 -1
  358. package/dist/esm/chunk-YDMTU6UH.js.map +0 -1
  359. /package/dist/esm/{chunk-J2UFYVKK.js.map → chunk-5IIF5O4A.js.map} +0 -0
  360. /package/dist/esm/{chunk-YVN6VFRT.js.map → chunk-6AN7Z5OC.js.map} +0 -0
  361. /package/dist/esm/{chunk-DIW5VDAQ.js.map → chunk-KOCOM7IC.js.map} +0 -0
  362. /package/dist/esm/{chunk-MCMWSGRJ.js.map → chunk-Q7NLA5X4.js.map} +0 -0
  363. /package/dist/esm/{chunk-MAU2MAK2.js.map → chunk-RAHOYMKY.js.map} +0 -0
  364. /package/dist/esm/{chunk-THBAYYPZ.js.map → chunk-WO2QJ6UM.js.map} +0 -0
  365. /package/dist/esm/{chunk-7XCSPITE.js.map → chunk-Y7BKUWRJ.js.map} +0 -0
  366. /package/dist/esm/{chunk-ZK2KSFGQ.js.map → chunk-YJTWW6QK.js.map} +0 -0
  367. /package/dist/esm/{chunk-HAE333YO.js.map → chunk-YMSNW2SU.js.map} +0 -0
@@ -1,18 +1,18 @@
1
1
  import {
2
2
  IntentFulfillStreamService
3
- } from "./chunk-4NESTSZ3.js";
4
- import {
5
- IntentTriggerService
6
- } from "./chunk-DIW5VDAQ.js";
3
+ } from "./chunk-A5PRJ33H.js";
7
4
  import {
8
5
  generateTitle
9
- } from "./chunk-J2UFYVKK.js";
6
+ } from "./chunk-5IIF5O4A.js";
7
+ import {
8
+ IntentTriggerService
9
+ } from "./chunk-KOCOM7IC.js";
10
10
  import {
11
11
  AinHttpError
12
12
  } from "./chunk-WUNZG3WP.js";
13
13
  import {
14
14
  loggers
15
- } from "./chunk-N7VYM2R5.js";
15
+ } from "./chunk-VUMI4XOY.js";
16
16
 
17
17
  // src/services/query-stream.service.ts
18
18
  import { randomUUID } from "crypto";
@@ -36,6 +36,10 @@ var QueryStreamService = class {
36
36
  memoryModule
37
37
  );
38
38
  }
39
+ async addToThreadMessages(userId, threadId, messages) {
40
+ const threadMemory = this.memoryModule?.getThreadMemory();
41
+ await threadMemory?.addMessagesToThread(userId, threadId, messages);
42
+ }
39
43
  /**
40
44
  * Main entry point for processing streaming user queries.
41
45
  *
@@ -78,7 +82,7 @@ var QueryStreamService = class {
78
82
  }
79
83
  const triggeredIntent = await this.intentTriggerService.intentTriggering(query, thread);
80
84
  loggers.intent.debug("Triggered intents", { triggeredIntent });
81
- await threadMemory?.addMessagesToThread(userId, threadId, [
85
+ await this.addToThreadMessages(userId, threadId, [
82
86
  {
83
87
  messageId: randomUUID(),
84
88
  role: "USER" /* USER */,
@@ -105,4 +109,4 @@ var QueryStreamService = class {
105
109
  export {
106
110
  QueryStreamService
107
111
  };
108
- //# sourceMappingURL=chunk-3QCXIHM7.js.map
112
+ //# sourceMappingURL=chunk-JCXAHLRN.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/services/query-stream.service.ts"],"sourcesContent":["import { randomUUID } from \"node:crypto\";\nimport { StatusCodes } from \"http-status-codes\";\nimport type {\n\tA2AModule,\n\tMCPModule,\n\tMemoryModule,\n\tModelFetchOptions,\n\tModelModule,\n} from \"@/modules/index.js\";\nimport { AinHttpError } from \"@/types/agent.js\";\nimport {\n\ttype MessageObject,\n\tMessageRole,\n\ttype ThreadMetadata,\n\ttype ThreadObject,\n\ttype ThreadType,\n\ttype TriggeredIntent,\n} from \"@/types/memory.js\";\nimport type { StreamEvent } from \"@/types/stream\";\nimport { loggers } from \"@/utils/logger.js\";\nimport { IntentFulfillStreamService } from \"./intents/fulfill-stream.service\";\nimport { IntentTriggerService } from \"./intents/trigger.service\";\nimport { generateTitle } from \"./utils/query.common\";\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 memoryModule?: MemoryModule;\n\tprivate intentTriggerService: IntentTriggerService;\n\tprivate intentFulfillStreamService: IntentFulfillStreamService;\n\n\tconstructor(\n\t\tmodelModule: ModelModule,\n\t\ta2aModule?: A2AModule,\n\t\tmcpModule?: MCPModule,\n\t\tmemoryModule?: MemoryModule,\n\t) {\n\t\tthis.modelModule = modelModule;\n\t\tthis.memoryModule = memoryModule;\n\t\tthis.intentTriggerService = new IntentTriggerService(\n\t\t\tmodelModule,\n\t\t\tmemoryModule,\n\t\t);\n\t\tthis.intentFulfillStreamService = new IntentFulfillStreamService(\n\t\t\tmodelModule,\n\t\t\ta2aModule,\n\t\t\tmcpModule,\n\t\t\tmemoryModule,\n\t\t);\n\t}\n\n\tpublic async addToThreadMessages(\n\t\tuserId: string,\n\t\tthreadId: string,\n\t\tmessages: Array<MessageObject>,\n\t) {\n\t\tconst threadMemory = this.memoryModule?.getThreadMemory();\n\t\tawait threadMemory?.addMessagesToThread(userId, threadId, messages);\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\toptions?: ModelFetchOptions;\n\t\t},\n\t\tquery: string,\n\t\tisA2A?: boolean,\n\t): AsyncGenerator<StreamEvent> {\n\t\tconst { type, userId, options } = 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 generateTitle(this.modelModule, query, options);\n\t\t\tconst metadata: ThreadMetadata = (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 };\n\t\t\tthread = { ...metadata, messages: [] };\n\t\t\tloggers.intent.info(`Create new thread: ${threadId}`);\n\t\t\tyield { event: \"thread_id\", data: { type, userId, threadId, title } };\n\t\t}\n\n\t\t// 2. intent triggering\n\t\tconst triggeredIntent: Array<TriggeredIntent> =\n\t\t\tawait this.intentTriggerService.intentTriggering(query, thread);\n\t\tloggers.intent.debug(\"Triggered intents\", { triggeredIntent });\n\n\t\t// only add for storage, not for inference\n\t\tawait this.addToThreadMessages(userId, threadId, [\n\t\t\t{\n\t\t\t\tmessageId: randomUUID(),\n\t\t\t\trole: MessageRole.USER,\n\t\t\t\ttimestamp: Date.now(),\n\t\t\t\tcontent: { type: \"text\", parts: [query] },\n\t\t\t\tmetadata: {\n\t\t\t\t\tintents: triggeredIntent\n\t\t\t\t\t\t.filter((intent) => !!intent.intent)\n\t\t\t\t\t\t.map((intent) => ({\n\t\t\t\t\t\t\tid: intent.intent?.id,\n\t\t\t\t\t\t\tsubquery: intent.subquery,\n\t\t\t\t\t\t})),\n\t\t\t\t},\n\t\t\t},\n\t\t]);\n\n\t\t// 3. intent fulfillment\n\t\tconst stream = this.intentFulfillStreamService.intentFulfillStream(\n\t\t\ttriggeredIntent,\n\t\t\tthread,\n\t\t);\n\n\t\tfor await (const event of stream) {\n\t\t\tyield event;\n\t\t}\n\t}\n}\n"],"mappings":";;;;;;;;;;;;;;;;;AAAA,SAAS,kBAAkB;AAC3B,SAAS,mBAAmB;AA8BrB,IAAM,qBAAN,MAAyB;AAAA,EACvB;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EAER,YACC,aACA,WACA,WACA,cACC;AACD,SAAK,cAAc;AACnB,SAAK,eAAe;AACpB,SAAK,uBAAuB,IAAI;AAAA,MAC/B;AAAA,MACA;AAAA,IACD;AACA,SAAK,6BAA6B,IAAI;AAAA,MACrC;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,IACD;AAAA,EACD;AAAA,EAEA,MAAa,oBACZ,QACA,UACA,UACC;AACD,UAAM,eAAe,KAAK,cAAc,gBAAgB;AACxD,UAAM,cAAc,oBAAoB,QAAQ,UAAU,QAAQ;AAAA,EACnE;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAkBA,OAAc,kBACb,gBAMA,OACA,OAC8B;AAC9B,UAAM,EAAE,MAAM,QAAQ,QAAQ,IAAI;AAClC,UAAM,eAAe,KAAK,cAAc,gBAAgB;AAGxD,QAAI,WAAW,eAAe;AAC9B,QAAI;AACJ,QAAI,UAAU;AACb,eAAS,MAAM,cAAc,UAAU,QAAQ,QAAQ;AACvD,UAAI,CAAC,UAAU,CAAC,OAAO;AACtB,cAAM,IAAI,aAAa,YAAY,WAAW,kBAAkB;AAAA,MACjE;AAAA,IACD;AAEA,iBAAa,WAAW;AACxB,QAAI,CAAC,QAAQ;AACZ,YAAM,QAAQ,MAAM,cAAc,KAAK,aAAa,OAAO,OAAO;AAClE,YAAM,WAA4B,MAAM,cAAc;AAAA,QACrD;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,MACD,KAAM,EAAE,MAAM,QAAQ,UAAU,MAAM;AACtC,eAAS,EAAE,GAAG,UAAU,UAAU,CAAC,EAAE;AACrC,cAAQ,OAAO,KAAK,sBAAsB,QAAQ,EAAE;AACpD,YAAM,EAAE,OAAO,aAAa,MAAM,EAAE,MAAM,QAAQ,UAAU,MAAM,EAAE;AAAA,IACrE;AAGA,UAAM,kBACL,MAAM,KAAK,qBAAqB,iBAAiB,OAAO,MAAM;AAC/D,YAAQ,OAAO,MAAM,qBAAqB,EAAE,gBAAgB,CAAC;AAG7D,UAAM,KAAK,oBAAoB,QAAQ,UAAU;AAAA,MAChD;AAAA,QACC,WAAW,WAAW;AAAA,QACtB;AAAA,QACA,WAAW,KAAK,IAAI;AAAA,QACpB,SAAS,EAAE,MAAM,QAAQ,OAAO,CAAC,KAAK,EAAE;AAAA,QACxC,UAAU;AAAA,UACT,SAAS,gBACP,OAAO,CAAC,WAAW,CAAC,CAAC,OAAO,MAAM,EAClC,IAAI,CAAC,YAAY;AAAA,YACjB,IAAI,OAAO,QAAQ;AAAA,YACnB,UAAU,OAAO;AAAA,UAClB,EAAE;AAAA,QACJ;AAAA,MACD;AAAA,IACD,CAAC;AAGD,UAAM,SAAS,KAAK,2BAA2B;AAAA,MAC9C;AAAA,MACA;AAAA,IACD;AAEA,qBAAiB,SAAS,QAAQ;AACjC,YAAM;AAAA,IACP;AAAA,EACD;AACD;","names":[]}
@@ -3,6 +3,7 @@ import {
3
3
  } from "./chunk-WUNZG3WP.js";
4
4
 
5
5
  // src/controllers/query.controller.ts
6
+ import { randomUUID } from "crypto";
6
7
  import { StatusCodes } from "http-status-codes";
7
8
  var QueryController = class {
8
9
  queryService;
@@ -46,12 +47,29 @@ var QueryController = class {
46
47
  const keepaliveInterval = setInterval(() => {
47
48
  res.write(":keepalive\n\n");
48
49
  }, 1e4);
50
+ let currentThreadId = threadId;
49
51
  const stream = this.queryStreamService.handleQueryStream(
50
52
  { type, userId, threadId },
51
53
  message
52
54
  );
53
55
  try {
54
56
  for await (const event of stream) {
57
+ if (event.event === "thread_id") {
58
+ currentThreadId = event.data.threadId;
59
+ } else if (event.event === "thinking_process") {
60
+ this.queryStreamService.addToThreadMessages(userId, currentThreadId, [
61
+ {
62
+ messageId: randomUUID(),
63
+ role: "MODEL" /* MODEL */,
64
+ timestamp: Date.now(),
65
+ content: { type: "text", parts: [event.data.title] },
66
+ metadata: {
67
+ isThinking: true,
68
+ thinkData: event.data
69
+ }
70
+ }
71
+ ]);
72
+ }
55
73
  res.write(
56
74
  `event: ${event.event}
57
75
  data: ${JSON.stringify(event.data)}
@@ -75,4 +93,4 @@ data: ${errMsg}
75
93
  export {
76
94
  QueryController
77
95
  };
78
- //# sourceMappingURL=chunk-OW7PCDK5.js.map
96
+ //# sourceMappingURL=chunk-JHKBIDPX.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/controllers/query.controller.ts"],"sourcesContent":["import { randomUUID } from \"node:crypto\";\nimport type { NextFunction, Request, Response } from \"express\";\nimport { StatusCodes } from \"http-status-codes\";\nimport type { QueryService, QueryStreamService } from \"@/services\";\nimport { AinHttpError } from \"@/types/agent\";\nimport { MessageRole } from \"@/types/memory\";\n\nexport class QueryController {\n\tprivate queryService;\n\tprivate queryStreamService;\n\n\tconstructor(\n\t\tqueryService: QueryService,\n\t\tqueryStreamService?: QueryStreamService,\n\t) {\n\t\tthis.queryService = queryService;\n\t\tthis.queryStreamService = queryStreamService;\n\t}\n\n\tpublic handleQueryRequest = async (\n\t\treq: Request,\n\t\tres: Response,\n\t\tnext: NextFunction,\n\t) => {\n\t\tconst { type, message, threadId } = req.body;\n\t\tconst userId = res.locals.userId;\n\n\t\ttry {\n\t\t\tconst result = await this.queryService.handleQuery(\n\t\t\t\t{ type, userId, threadId },\n\t\t\t\tmessage,\n\t\t\t);\n\n\t\t\tres.status(200).json(result);\n\t\t} catch (error) {\n\t\t\tnext(error);\n\t\t}\n\t};\n\n\tpublic handleQueryStreamRequest = async (\n\t\treq: Request,\n\t\tres: Response,\n\t\tnext: NextFunction,\n\t) => {\n\t\tconst { type, threadId, message } = req.body;\n\t\tconst userId = res.locals.userId;\n\n\t\tif (!this.queryStreamService) {\n\t\t\tconst error = new AinHttpError(\n\t\t\t\tStatusCodes.NOT_IMPLEMENTED,\n\t\t\t\t\"Stream query not supported\",\n\t\t\t);\n\t\t\treturn next(error);\n\t\t}\n\n\t\tres.writeHead(200, {\n\t\t\t\"Content-Type\": \"text/event-stream\",\n\t\t\t\"Cache-Control\": \"no-cache\",\n\t\t\tConnection: \"keep-alive\",\n\t\t\t\"X-Accel-Buffering\": \"no\", // nginx 버퍼링 비활성화\n\t\t});\n\t\tres.flushHeaders();\n\t\tres.write(\":ok\\n\\n\");\n\n\t\tconst keepaliveInterval = setInterval(() => {\n\t\t\tres.write(\":keepalive\\n\\n\");\n\t\t}, 10000); // 10초마다 keepalive 전송\n\n\t\tlet currentThreadId = threadId;\n\t\tconst stream = this.queryStreamService.handleQueryStream(\n\t\t\t{ type, userId, threadId },\n\t\t\tmessage,\n\t\t);\n\n\t\ttry {\n\t\t\tfor await (const event of stream) {\n\t\t\t\tif (event.event === \"thread_id\") {\n\t\t\t\t\tcurrentThreadId = event.data.threadId;\n\t\t\t\t} else if (event.event === \"thinking_process\") {\n\t\t\t\t\t// a2a 호출에 대해서는 데이터베이스에 추가하지 않기 위해 여기서 thread message에 기록\n\t\t\t\t\tthis.queryStreamService.addToThreadMessages(userId, currentThreadId, [\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tmessageId: randomUUID(),\n\t\t\t\t\t\t\trole: MessageRole.MODEL,\n\t\t\t\t\t\t\ttimestamp: Date.now(),\n\t\t\t\t\t\t\tcontent: { type: \"text\", parts: [event.data.title] },\n\t\t\t\t\t\t\tmetadata: {\n\t\t\t\t\t\t\t\tisThinking: true,\n\t\t\t\t\t\t\t\tthinkData: event.data,\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t]);\n\t\t\t\t}\n\n\t\t\t\tres.write(\n\t\t\t\t\t`event: ${event.event}\\ndata: ${JSON.stringify(event.data)}\\n\\n`,\n\t\t\t\t);\n\t\t\t}\n\t\t} catch (error: unknown) {\n\t\t\tconst errMsg =\n\t\t\t\t(error as Error)?.message || \"Failed to handle query stream\";\n\t\t\tres.write(`event: error\\ndata: ${errMsg}\\n\\n`);\n\t\t} finally {\n\t\t\tclearInterval(keepaliveInterval);\n\t\t\tres.end();\n\t\t}\n\t};\n}\n"],"mappings":";;;;;AAAA,SAAS,kBAAkB;AAE3B,SAAS,mBAAmB;AAKrB,IAAM,kBAAN,MAAsB;AAAA,EACpB;AAAA,EACA;AAAA,EAER,YACC,cACA,oBACC;AACD,SAAK,eAAe;AACpB,SAAK,qBAAqB;AAAA,EAC3B;AAAA,EAEO,qBAAqB,OAC3B,KACA,KACA,SACI;AACJ,UAAM,EAAE,MAAM,SAAS,SAAS,IAAI,IAAI;AACxC,UAAM,SAAS,IAAI,OAAO;AAE1B,QAAI;AACH,YAAM,SAAS,MAAM,KAAK,aAAa;AAAA,QACtC,EAAE,MAAM,QAAQ,SAAS;AAAA,QACzB;AAAA,MACD;AAEA,UAAI,OAAO,GAAG,EAAE,KAAK,MAAM;AAAA,IAC5B,SAAS,OAAO;AACf,WAAK,KAAK;AAAA,IACX;AAAA,EACD;AAAA,EAEO,2BAA2B,OACjC,KACA,KACA,SACI;AACJ,UAAM,EAAE,MAAM,UAAU,QAAQ,IAAI,IAAI;AACxC,UAAM,SAAS,IAAI,OAAO;AAE1B,QAAI,CAAC,KAAK,oBAAoB;AAC7B,YAAM,QAAQ,IAAI;AAAA,QACjB,YAAY;AAAA,QACZ;AAAA,MACD;AACA,aAAO,KAAK,KAAK;AAAA,IAClB;AAEA,QAAI,UAAU,KAAK;AAAA,MAClB,gBAAgB;AAAA,MAChB,iBAAiB;AAAA,MACjB,YAAY;AAAA,MACZ,qBAAqB;AAAA;AAAA,IACtB,CAAC;AACD,QAAI,aAAa;AACjB,QAAI,MAAM,SAAS;AAEnB,UAAM,oBAAoB,YAAY,MAAM;AAC3C,UAAI,MAAM,gBAAgB;AAAA,IAC3B,GAAG,GAAK;AAER,QAAI,kBAAkB;AACtB,UAAM,SAAS,KAAK,mBAAmB;AAAA,MACtC,EAAE,MAAM,QAAQ,SAAS;AAAA,MACzB;AAAA,IACD;AAEA,QAAI;AACH,uBAAiB,SAAS,QAAQ;AACjC,YAAI,MAAM,UAAU,aAAa;AAChC,4BAAkB,MAAM,KAAK;AAAA,QAC9B,WAAW,MAAM,UAAU,oBAAoB;AAE9C,eAAK,mBAAmB,oBAAoB,QAAQ,iBAAiB;AAAA,YACpE;AAAA,cACC,WAAW,WAAW;AAAA,cACtB;AAAA,cACA,WAAW,KAAK,IAAI;AAAA,cACpB,SAAS,EAAE,MAAM,QAAQ,OAAO,CAAC,MAAM,KAAK,KAAK,EAAE;AAAA,cACnD,UAAU;AAAA,gBACT,YAAY;AAAA,gBACZ,WAAW,MAAM;AAAA,cAClB;AAAA,YACD;AAAA,UACD,CAAC;AAAA,QACF;AAEA,YAAI;AAAA,UACH,UAAU,MAAM,KAAK;AAAA,QAAW,KAAK,UAAU,MAAM,IAAI,CAAC;AAAA;AAAA;AAAA,QAC3D;AAAA,MACD;AAAA,IACD,SAAS,OAAgB;AACxB,YAAM,SACJ,OAAiB,WAAW;AAC9B,UAAI,MAAM;AAAA,QAAuB,MAAM;AAAA;AAAA,CAAM;AAAA,IAC9C,UAAE;AACD,oBAAc,iBAAiB;AAC/B,UAAI,IAAI;AAAA,IACT;AAAA,EACD;AACD;","names":[]}
@@ -1,6 +1,6 @@
1
1
  import {
2
2
  loggers
3
- } from "./chunk-N7VYM2R5.js";
3
+ } from "./chunk-VUMI4XOY.js";
4
4
 
5
5
  // src/services/intents/trigger.service.ts
6
6
  var IntentTriggerService = class {
@@ -111,4 +111,4 @@ Requirements:
111
111
  export {
112
112
  IntentTriggerService
113
113
  };
114
- //# sourceMappingURL=chunk-DIW5VDAQ.js.map
114
+ //# sourceMappingURL=chunk-KOCOM7IC.js.map
@@ -3,7 +3,7 @@ import {
3
3
  } from "./chunk-IKYOHZYW.js";
4
4
  import {
5
5
  loggers
6
- } from "./chunk-N7VYM2R5.js";
6
+ } from "./chunk-VUMI4XOY.js";
7
7
 
8
8
  // src/modules/mcp/mcp.module.ts
9
9
  import { Client as MCPClient } from "@modelcontextprotocol/sdk/client/index.js";
@@ -89,7 +89,25 @@ var MCPModule = class {
89
89
  getTools() {
90
90
  const allTools = [];
91
91
  for (const conn of this.mcpConnectors.values()) {
92
- allTools.push(...conn.tools);
92
+ for (const tool of conn.tools) {
93
+ const finalInputSchema = {
94
+ type: "object",
95
+ properties: { ...tool.inputSchema?.properties || {} },
96
+ required: [...tool.inputSchema?.required || []]
97
+ };
98
+ finalInputSchema.properties["thinking_text"] = {
99
+ type: "string",
100
+ description: "\uC0AC\uC6A9\uC790\uC758 \uC694\uCCAD\uC744 \uD574\uACB0\uD558\uAE30 \uC704\uD574 \uC774 \uB3C4\uAD6C\uB97C \uC120\uD0DD\uD55C \uAD6C\uCCB4\uC801\uC778 \uC774\uC720\uC640 \uBAA9\uC801 (Why & What). \uD55C\uB450\uC904 \uC815\uB3C4\uC758 \uBD84\uB7C9\uC73C\uB85C \uC785\uB825 \uC5B8\uC5B4\uC640 \uAC19\uC740 \uC5B8\uC5B4\uB85C \uC0DD\uC131\uD55C\uB2E4."
101
+ };
102
+ finalInputSchema.required.push("thinking_text");
103
+ allTools.push({
104
+ toolName: tool.toolName,
105
+ connectorName: tool.connectorName,
106
+ protocol: tool.protocol,
107
+ description: tool.description,
108
+ inputSchema: finalInputSchema
109
+ });
110
+ }
93
111
  }
94
112
  return allTools;
95
113
  }
@@ -139,4 +157,4 @@ ${typeof error === "string" ? error : JSON.stringify(error, null, 2)}`;
139
157
  export {
140
158
  MCPModule
141
159
  };
142
- //# sourceMappingURL=chunk-YDMTU6UH.js.map
160
+ //# sourceMappingURL=chunk-PVWOU6LA.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/modules/mcp/mcp.module.ts"],"sourcesContent":["import { Client as MCPClient } from \"@modelcontextprotocol/sdk/client/index.js\";\nimport { SSEClientTransport } from \"@modelcontextprotocol/sdk/client/sse.js\";\nimport { StdioClientTransport } from \"@modelcontextprotocol/sdk/client/stdio.js\";\nimport { StreamableHTTPClientTransport } from \"@modelcontextprotocol/sdk/client/streamableHttp.js\";\nimport { WebSocketClientTransport } from \"@modelcontextprotocol/sdk/client/websocket.js\";\nimport {\n\tCONNECTOR_PROTOCOL_TYPE,\n\ttype ConnectorTool,\n} from \"@/types/connector.js\";\nimport type { MCPConfig } from \"@/types/mcp.js\";\nimport { loggers } from \"@/utils/logger.js\";\nimport { MCPConnector } from \"./mcp.connector.js\";\n\n/**\n * Module for managing Model Context Protocol (MCP) server connections.\n *\n * This module handles the lifecycle of MCP client connections, discovers\n * available tools from connected servers, and provides an interface for\n * executing those tools. Multiple MCP servers can be connected simultaneously.\n */\nexport class MCPModule {\n\tprivate mcpConnectors: Map<string, MCPConnector> = new Map();\n\n\taddMCPConnector(configs: { [name: string]: MCPConfig }): void {\n\t\tfor (const [name, config] of Object.entries(configs)) {\n\t\t\tconst conn = new MCPConnector(name, config);\n\t\t\tthis.mcpConnectors.set(name, conn);\n\t\t}\n\t}\n\n\tprivate getOrCreateClient(connector: MCPConnector): MCPClient {\n\t\tconnector.client ??= new MCPClient({\n\t\t\tname: connector.name,\n\t\t\tversion: \"1.0.0\",\n\t\t});\n\t\treturn connector.client;\n\t}\n\n\tasync connectToServers(): Promise<void> {\n\t\tfor (const [name, conn] of this.mcpConnectors.entries()) {\n\t\t\ttry {\n\t\t\t\tconst mcpClient = this.getOrCreateClient(conn);\n\t\t\t\tconst config = conn.config;\n\t\t\t\tswitch (config.type) {\n\t\t\t\t\tcase \"stdio\": {\n\t\t\t\t\t\tconst transport = new StdioClientTransport(config.params);\n\t\t\t\t\t\tawait mcpClient.connect(transport);\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t\tcase \"websocket\": {\n\t\t\t\t\t\tconst transport = new WebSocketClientTransport(config.url);\n\t\t\t\t\t\tawait mcpClient.connect(transport);\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t\tcase \"sse\": {\n\t\t\t\t\t\tconst transport = new SSEClientTransport(\n\t\t\t\t\t\t\tconfig.url,\n\t\t\t\t\t\t\tconfig.options,\n\t\t\t\t\t\t);\n\t\t\t\t\t\tawait mcpClient.connect(transport);\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t\tcase \"streamableHttp\": {\n\t\t\t\t\t\tconst transport = new StreamableHTTPClientTransport(\n\t\t\t\t\t\t\tconfig.url,\n\t\t\t\t\t\t\tconfig.options,\n\t\t\t\t\t\t);\n\t\t\t\t\t\tawait mcpClient.connect(transport);\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t\tdefault:\n\t\t\t\t\t\t// This cannot happen.\n\t\t\t\t\t\tloggers.mcp.error(\"Unsupported MCP config type\");\n\t\t\t\t\t\tbreak;\n\t\t\t\t}\n\n\t\t\t\tconst toolList = await mcpClient.listTools();\n\t\t\t\tconn.tools = toolList.tools.map((tool) => {\n\t\t\t\t\treturn {\n\t\t\t\t\t\ttoolName: `${name}-${tool.name}`, // to avoid tool name duplication\n\t\t\t\t\t\tconnectorName: name,\n\t\t\t\t\t\tprotocol: CONNECTOR_PROTOCOL_TYPE.MCP,\n\t\t\t\t\t\tdescription: tool.description,\n\t\t\t\t\t\tinputSchema: tool.inputSchema,\n\t\t\t\t\t};\n\t\t\t\t});\n\t\t\t\tloggers.mcp.info(\"Connected to MCP server with tools:\", {\n\t\t\t\t\ttools: conn.tools.map((tool) => tool.toolName),\n\t\t\t\t});\n\t\t\t} catch (error) {\n\t\t\t\tloggers.mcp.error(`Failed to connect to MCP server ${name}`, { error });\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t * Returns all available tools from connected MCP servers.\n\t *\n\t * @returns Array of MCPTool instances representing available tools\n\t */\n\tgetTools(): Array<ConnectorTool> {\n\t\tconst allTools: Array<ConnectorTool> = [];\n\t\tfor (const conn of this.mcpConnectors.values()) {\n\t\t\tfor (const tool of conn.tools) {\n\t\t\t\t// add thinking_text inputSchema for each tool\n\t\t\t\tconst finalInputSchema: any = {\n\t\t\t\t\ttype: \"object\",\n\t\t\t\t\tproperties: { ...(tool.inputSchema?.properties || {}) },\n\t\t\t\t\trequired: [...(tool.inputSchema?.required || [])],\n\t\t\t\t};\n\n\t\t\t\tfinalInputSchema.properties[\"thinking_text\"] = {\n\t\t\t\t\ttype: \"string\",\n\t\t\t\t\tdescription:\n\t\t\t\t\t\t\"사용자의 요청을 해결하기 위해 이 도구를 선택한 구체적인 이유와 목적 (Why & What). 한두줄 정도의 분량으로 입력 언어와 같은 언어로 생성한다.\",\n\t\t\t\t};\n\t\t\t\tfinalInputSchema.required.push(\"thinking_text\");\n\n\t\t\t\tallTools.push({\n\t\t\t\t\ttoolName: tool.toolName,\n\t\t\t\t\tconnectorName: tool.connectorName,\n\t\t\t\t\tprotocol: tool.protocol,\n\t\t\t\t\tdescription: tool.description,\n\t\t\t\t\tinputSchema: finalInputSchema,\n\t\t\t\t});\n\t\t\t}\n\t\t}\n\t\treturn allTools;\n\t}\n\n\t/**\n\t * Executes a tool on its corresponding MCP server.\n\t *\n\t * @param tool - The MCPTool instance to execute\n\t * @param _args - Arguments to pass to the tool\n\t * @returns Promise resolving to the tool's execution result\n\t * @throws Error if the MCP server for the tool is not found\n\t */\n\tasync useTool(tool: ConnectorTool, _args?: any): Promise<string> {\n\t\tconst { connectorName, toolName } = tool;\n\t\tconst client = this.mcpConnectors.get(connectorName)?.client;\n\n\t\ttry {\n\t\t\tif (!client) {\n\t\t\t\tthrow new Error(`Invalid MCP Tool ${toolName}`);\n\t\t\t}\n\n\t\t\t// `${name}-${tool.name}` => tool.name\n\t\t\tconst mcpToolName = toolName.slice(connectorName.length + 1);\n\t\t\tconst result = await client.callTool({\n\t\t\t\tname: mcpToolName,\n\t\t\t\targuments: _args,\n\t\t\t});\n\t\t\tconst toolResult =\n\t\t\t\t`[Bot Called Tool ${toolName} with args ${JSON.stringify(_args)}]\\n` +\n\t\t\t\tJSON.stringify(result.content, null, 2);\n\t\t\treturn toolResult;\n\t\t} catch (error) {\n\t\t\tloggers.mcp.error(\"Failed to call tool\", { error });\n\t\t\tconst toolResult = `[Bot Called Tool ${toolName} with args ${JSON.stringify(_args)}]\\n${typeof error === \"string\" ? error : JSON.stringify(error, null, 2)}`;\n\t\t\treturn toolResult;\n\t\t}\n\t}\n\n\t/**\n\t * Closes all MCP client connections.\n\t *\n\t * Should be called when shutting down the application to ensure\n\t * all MCP connections are properly closed.\n\t */\n\tasync cleanup() {\n\t\tfor (const conn of this.mcpConnectors.values()) {\n\t\t\tawait conn.client?.close();\n\t\t}\n\t}\n}\n"],"mappings":"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","names":[]}
@@ -1,15 +1,15 @@
1
- import {
2
- createModelApiRouter
3
- } from "./chunk-AMRKK46V.js";
4
- import {
5
- createThreadApiRouter
6
- } from "./chunk-SPRW6KUR.js";
7
1
  import {
8
2
  createAgentApiRouter
9
3
  } from "./chunk-275JHD5P.js";
10
4
  import {
11
5
  createIntentApiRouter
12
6
  } from "./chunk-F3SGL62A.js";
7
+ import {
8
+ createModelApiRouter
9
+ } from "./chunk-AMRKK46V.js";
10
+ import {
11
+ createThreadApiRouter
12
+ } from "./chunk-SPRW6KUR.js";
13
13
 
14
14
  // src/routes/api.routes.ts
15
15
  import { Router } from "express";
@@ -27,4 +27,4 @@ var createApiRouter = (agent) => {
27
27
  export {
28
28
  createApiRouter
29
29
  };
30
- //# sourceMappingURL=chunk-MCMWSGRJ.js.map
30
+ //# sourceMappingURL=chunk-Q7NLA5X4.js.map
@@ -1,6 +1,6 @@
1
1
  import {
2
2
  logger
3
- } from "./chunk-N7VYM2R5.js";
3
+ } from "./chunk-VUMI4XOY.js";
4
4
 
5
5
  // src/middlewares/error.middleware.ts
6
6
  var errorMiddleware = (error, req, res, next) => {
@@ -19,4 +19,4 @@ var errorMiddleware = (error, req, res, next) => {
19
19
  export {
20
20
  errorMiddleware
21
21
  };
22
- //# sourceMappingURL=chunk-MAU2MAK2.js.map
22
+ //# sourceMappingURL=chunk-RAHOYMKY.js.map
@@ -3,7 +3,7 @@ import {
3
3
  } from "./chunk-7BH6AYP7.js";
4
4
  import {
5
5
  loggers
6
- } from "./chunk-N7VYM2R5.js";
6
+ } from "./chunk-VUMI4XOY.js";
7
7
 
8
8
  // src/services/intents/fulfill.service.ts
9
9
  import { randomUUID } from "crypto";
@@ -94,11 +94,16 @@ var IntentFulfillService = class {
94
94
  loggers.intent.debug("MCP tool call", { toolName, toolArgs });
95
95
  toolResult = await this.mcpModule.useTool(selectedTool, toolArgs);
96
96
  } else if (this.a2aModule && selectedTool.protocol === "A2A" /* A2A */) {
97
- toolResult = await this.a2aModule.useTool(
97
+ const a2aGenerator = this.a2aModule.useTool(
98
98
  selectedTool,
99
99
  query,
100
100
  thread.threadId
101
101
  );
102
+ let result = await a2aGenerator.next();
103
+ while (!result.done) {
104
+ result = await a2aGenerator.next();
105
+ }
106
+ toolResult = result.value;
102
107
  } else {
103
108
  loggers.intent.warn(
104
109
  `Unrecognized tool type: ${selectedTool.protocol}`
@@ -160,4 +165,4 @@ var IntentFulfillService = class {
160
165
  export {
161
166
  IntentFulfillService
162
167
  };
163
- //# sourceMappingURL=chunk-WL7H2QX4.js.map
168
+ //# sourceMappingURL=chunk-UEUZ7G5P.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/services/intents/fulfill.service.ts"],"sourcesContent":["import { randomUUID } from \"node:crypto\";\nimport type {\n\tA2AModule,\n\tMCPModule,\n\tMemoryModule,\n\tModelModule,\n} from \"@/modules\";\nimport { CONNECTOR_PROTOCOL_TYPE, type ConnectorTool } from \"@/types/connector\";\nimport {\n\ttype Intent,\n\ttype MessageObject,\n\tMessageRole,\n\ttype ThreadObject,\n\ttype TriggeredIntent,\n} from \"@/types/memory\";\nimport { loggers } from \"@/utils/logger\";\nimport { createFulfillPrompt } from \"../utils/fulfill.common\";\n\nexport class IntentFulfillService {\n\tprivate modelModule: ModelModule;\n\tprivate a2aModule?: A2AModule;\n\tprivate mcpModule?: MCPModule;\n\tprivate memoryModule?: MemoryModule;\n\n\tconstructor(\n\t\tmodelModule: ModelModule,\n\t\ta2aModule?: A2AModule,\n\t\tmcpModule?: MCPModule,\n\t\tmemoryModule?: MemoryModule,\n\t) {\n\t\tthis.modelModule = modelModule;\n\t\tthis.a2aModule = a2aModule;\n\t\tthis.mcpModule = mcpModule;\n\t\tthis.memoryModule = memoryModule;\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;\n\t\t\tconst 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\", error);\n\t\t}\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\tprivate async intentFulfilling(\n\t\tquery: string,\n\t\tthread: ThreadObject,\n\t\tintent?: Intent,\n\t): Promise<string> {\n\t\tconst agentMemory = this.memoryModule?.getAgentMemory();\n\t\tconst fulfillPrompt = await createFulfillPrompt(agentMemory, intent);\n\n\t\tconst modelInstance = this.modelModule.getModel();\n\t\tconst modelOptions = this.modelModule.getModelOptions();\n\t\tconst messages = modelInstance.generateMessages({\n\t\t\tquery,\n\t\t\tthread,\n\t\t\tsystemPrompt: fulfillPrompt.trim(),\n\t\t});\n\n\t\tloggers.intent.debug(\"Intent fulfillment start\", {\n\t\t\tthreadId: thread.threadId,\n\t\t\tmessages,\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\tlet finalMessage = \"\";\n\t\twhile (true) {\n\t\t\tconst response = await modelInstance.fetchWithContextMessage(\n\t\t\t\tmessages,\n\t\t\t\tfunctions,\n\t\t\t\tmodelOptions,\n\t\t\t);\n\n\t\t\tconst { content, toolCalls } = response;\n\t\t\tloggers.intent.debug(\"Tool calls\", {\n\t\t\t\tthreadId: thread.threadId,\n\t\t\t\tcontent,\n\t\t\t\ttoolCalls,\n\t\t\t});\n\n\t\t\tif (toolCalls) {\n\t\t\t\tfor (const toolCall of toolCalls) {\n\t\t\t\t\tconst toolName = toolCall.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 = toolCall.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\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\tconst a2aGenerator = 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\tthread.threadId,\n\t\t\t\t\t\t);\n\t\t\t\t\t\t// consume generator to get final result (ignore intermediate events)\n\t\t\t\t\t\tlet result = await a2aGenerator.next();\n\t\t\t\t\t\twhile (!result.done) {\n\t\t\t\t\t\t\tresult = await a2aGenerator.next();\n\t\t\t\t\t\t}\n\t\t\t\t\t\ttoolResult = result.value;\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\n\t\t\t\t\tloggers.intent.debug(\"Tool Result\", {\n\t\t\t\t\t\tthreadId: thread.threadId,\n\t\t\t\t\t\ttoolResult,\n\t\t\t\t\t});\n\n\t\t\t\t\tmodelInstance.appendMessages(messages, toolResult);\n\t\t\t\t}\n\t\t\t} else if (content) {\n\t\t\t\tfinalMessage = content;\n\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\n\t\treturn finalMessage;\n\t}\n\n\t/**\n\t * Detects the intent from context.\n\t *\n\t * @param intents - The user's input query\n\t * @param thread - The thread history\n\t * @returns The detected intent\n\t */\n\tpublic async intentFulfill(\n\t\tintents: Array<TriggeredIntent>,\n\t\tthread: ThreadObject,\n\t): Promise<string> {\n\t\tlet finalResponseText = \"\";\n\t\tfor (let i = 0; i < intents.length; i++) {\n\t\t\tconst { subquery, intent, actionPlan } = intents[i];\n\t\t\tloggers.intent.info(`Process query: ${subquery}, ${intent?.name}`);\n\t\t\tloggers.intent.info(`Action plan: ${actionPlan}`);\n\n\t\t\t// only use for inference, not stored in memory\n\t\t\tfinalResponseText !== \"\" &&\n\t\t\t\tthread.messages.push({\n\t\t\t\t\tmessageId: randomUUID(),\n\t\t\t\t\trole: MessageRole.MODEL,\n\t\t\t\t\ttimestamp: Date.now(),\n\t\t\t\t\tcontent: { type: \"text\", parts: [finalResponseText] },\n\t\t\t\t\tmetadata: { isThinking: true },\n\t\t\t\t});\n\t\t\tawait this.addToThreadMessages(thread, {\n\t\t\t\trole: MessageRole.MODEL,\n\t\t\t\tcontent: subquery,\n\t\t\t\tmetadata: {\n\t\t\t\t\tsubquery,\n\t\t\t\t\tisThinking: true,\n\t\t\t\t\tactionPlan: actionPlan,\n\t\t\t\t},\n\t\t\t});\n\n\t\t\tfinalResponseText = await this.intentFulfilling(subquery, thread, intent);\n\t\t}\n\n\t\tawait this.addToThreadMessages(thread, {\n\t\t\trole: MessageRole.MODEL,\n\t\t\tcontent: finalResponseText,\n\t\t});\n\n\t\treturn finalResponseText;\n\t}\n}\n"],"mappings":"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","names":[]}
@@ -0,0 +1,62 @@
1
+ // src/utils/logger.ts
2
+ import winston from "winston";
3
+ import DailyRotateFile from "winston-daily-rotate-file";
4
+ var { combine, timestamp, printf, colorize, errors } = winston.format;
5
+ var logFormat = printf(
6
+ ({ level, message, timestamp: timestamp2, service, stack, ...meta }) => {
7
+ const metaStr = Object.keys(meta).length ? ` | ${JSON.stringify(meta)}` : "";
8
+ const errorStack = stack ? `
9
+ ${stack}` : "";
10
+ return `${timestamp2} [${service}] ${level}: ${message}${metaStr}${errorStack}`;
11
+ }
12
+ );
13
+ var createLogger = (service) => {
14
+ const logFilePath = process.env.LOG_FILE_PATH;
15
+ const transports = logFilePath ? [
16
+ new DailyRotateFile({
17
+ filename: logFilePath,
18
+ datePattern: "YYYY-MM-DD",
19
+ maxSize: process.env.LOG_MAX_SIZE || "20m",
20
+ maxFiles: process.env.LOG_MAX_FILES || "14d",
21
+ format: combine(
22
+ errors({ stack: true }),
23
+ timestamp({ format: "YYYY-MM-DD HH:mm:ss" }),
24
+ logFormat
25
+ )
26
+ })
27
+ ] : [
28
+ new winston.transports.Console({
29
+ format: combine(
30
+ errors({ stack: true }),
31
+ colorize(),
32
+ timestamp({ format: "HH:mm:ss" }),
33
+ logFormat
34
+ )
35
+ })
36
+ ];
37
+ const logger2 = winston.createLogger({
38
+ level: (process.env.LOG_LEVEL || "info").toLowerCase(),
39
+ defaultMeta: { service },
40
+ transports
41
+ });
42
+ return logger2;
43
+ };
44
+ var logger = createLogger("ain-adk");
45
+ var getLogger = (service) => createLogger(service);
46
+ var loggers = {
47
+ agent: getLogger("AINAgent"),
48
+ intent: getLogger("Intent"),
49
+ intentStream: getLogger("IntentStream"),
50
+ mcp: getLogger("MCPModule"),
51
+ a2a: getLogger("A2AModule"),
52
+ model: getLogger("Model"),
53
+ server: getLogger("A2AServer"),
54
+ fol: getLogger("FOL")
55
+ };
56
+
57
+ export {
58
+ logger,
59
+ getLogger,
60
+ loggers
61
+ };
62
+ //# sourceMappingURL=chunk-VUMI4XOY.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/utils/logger.ts"],"sourcesContent":["import winston from \"winston\";\nimport DailyRotateFile from \"winston-daily-rotate-file\";\n\nconst { combine, timestamp, printf, colorize, errors } = winston.format;\n\nconst logFormat = printf(\n\t({ level, message, timestamp, service, stack, ...meta }) => {\n\t\tconst metaStr = Object.keys(meta).length\n\t\t\t? ` | ${JSON.stringify(meta)}`\n\t\t\t: \"\";\n\t\tconst errorStack = stack ? `\\n${stack}` : \"\";\n\t\treturn `${timestamp} [${service}] ${level}: ${message}${metaStr}${errorStack}`;\n\t},\n);\n\nconst createLogger = (service: string) => {\n\tconst logFilePath = process.env.LOG_FILE_PATH;\n\n\tconst transports: winston.transport[] = logFilePath\n\t\t? [\n\t\t\t\tnew DailyRotateFile({\n\t\t\t\t\tfilename: logFilePath,\n\t\t\t\t\tdatePattern: \"YYYY-MM-DD\",\n\t\t\t\t\tmaxSize: process.env.LOG_MAX_SIZE || \"20m\",\n\t\t\t\t\tmaxFiles: process.env.LOG_MAX_FILES || \"14d\",\n\t\t\t\t\tformat: combine(\n\t\t\t\t\t\terrors({ stack: true }),\n\t\t\t\t\t\ttimestamp({ format: \"YYYY-MM-DD HH:mm:ss\" }),\n\t\t\t\t\t\tlogFormat,\n\t\t\t\t\t),\n\t\t\t\t}),\n\t\t\t]\n\t\t: [\n\t\t\t\tnew winston.transports.Console({\n\t\t\t\t\tformat: combine(\n\t\t\t\t\t\terrors({ stack: true }),\n\t\t\t\t\t\tcolorize(),\n\t\t\t\t\t\ttimestamp({ format: \"HH:mm:ss\" }),\n\t\t\t\t\t\tlogFormat,\n\t\t\t\t\t),\n\t\t\t\t}),\n\t\t\t];\n\n\tconst logger = winston.createLogger({\n\t\tlevel: (process.env.LOG_LEVEL || \"info\").toLowerCase(),\n\t\tdefaultMeta: { service },\n\t\ttransports,\n\t});\n\n\treturn logger;\n};\n\n// Default logger instance\nexport const logger = createLogger(\"ain-adk\");\n\n// Factory function for creating service-specific loggers\nexport const getLogger = (service: string) => createLogger(service);\n\n// Convenience methods for different components\nexport const loggers = {\n\tagent: getLogger(\"AINAgent\"),\n\tintent: getLogger(\"Intent\"),\n\tintentStream: getLogger(\"IntentStream\"),\n\tmcp: getLogger(\"MCPModule\"),\n\ta2a: getLogger(\"A2AModule\"),\n\tmodel: getLogger(\"Model\"),\n\tserver: getLogger(\"A2AServer\"),\n\tfol: getLogger(\"FOL\"),\n} as const;\n"],"mappings":";AAAA,OAAO,aAAa;AACpB,OAAO,qBAAqB;AAE5B,IAAM,EAAE,SAAS,WAAW,QAAQ,UAAU,OAAO,IAAI,QAAQ;AAEjE,IAAM,YAAY;AAAA,EACjB,CAAC,EAAE,OAAO,SAAS,WAAAA,YAAW,SAAS,OAAO,GAAG,KAAK,MAAM;AAC3D,UAAM,UAAU,OAAO,KAAK,IAAI,EAAE,SAC/B,MAAM,KAAK,UAAU,IAAI,CAAC,KAC1B;AACH,UAAM,aAAa,QAAQ;AAAA,EAAK,KAAK,KAAK;AAC1C,WAAO,GAAGA,UAAS,KAAK,OAAO,KAAK,KAAK,KAAK,OAAO,GAAG,OAAO,GAAG,UAAU;AAAA,EAC7E;AACD;AAEA,IAAM,eAAe,CAAC,YAAoB;AACzC,QAAM,cAAc,QAAQ,IAAI;AAEhC,QAAM,aAAkC,cACrC;AAAA,IACA,IAAI,gBAAgB;AAAA,MACnB,UAAU;AAAA,MACV,aAAa;AAAA,MACb,SAAS,QAAQ,IAAI,gBAAgB;AAAA,MACrC,UAAU,QAAQ,IAAI,iBAAiB;AAAA,MACvC,QAAQ;AAAA,QACP,OAAO,EAAE,OAAO,KAAK,CAAC;AAAA,QACtB,UAAU,EAAE,QAAQ,sBAAsB,CAAC;AAAA,QAC3C;AAAA,MACD;AAAA,IACD,CAAC;AAAA,EACF,IACC;AAAA,IACA,IAAI,QAAQ,WAAW,QAAQ;AAAA,MAC9B,QAAQ;AAAA,QACP,OAAO,EAAE,OAAO,KAAK,CAAC;AAAA,QACtB,SAAS;AAAA,QACT,UAAU,EAAE,QAAQ,WAAW,CAAC;AAAA,QAChC;AAAA,MACD;AAAA,IACD,CAAC;AAAA,EACF;AAEF,QAAMC,UAAS,QAAQ,aAAa;AAAA,IACnC,QAAQ,QAAQ,IAAI,aAAa,QAAQ,YAAY;AAAA,IACrD,aAAa,EAAE,QAAQ;AAAA,IACvB;AAAA,EACD,CAAC;AAED,SAAOA;AACR;AAGO,IAAM,SAAS,aAAa,SAAS;AAGrC,IAAM,YAAY,CAAC,YAAoB,aAAa,OAAO;AAG3D,IAAM,UAAU;AAAA,EACtB,OAAO,UAAU,UAAU;AAAA,EAC3B,QAAQ,UAAU,QAAQ;AAAA,EAC1B,cAAc,UAAU,cAAc;AAAA,EACtC,KAAK,UAAU,WAAW;AAAA,EAC1B,KAAK,UAAU,WAAW;AAAA,EAC1B,OAAO,UAAU,OAAO;AAAA,EACxB,QAAQ,UAAU,WAAW;AAAA,EAC7B,KAAK,UAAU,KAAK;AACrB;","names":["timestamp","logger"]}
@@ -3,7 +3,7 @@ import {
3
3
  } from "./chunk-WZQVH4XY.js";
4
4
  import {
5
5
  IntentTriggerService
6
- } from "./chunk-DIW5VDAQ.js";
6
+ } from "./chunk-KOCOM7IC.js";
7
7
  import {
8
8
  IntentController
9
9
  } from "./chunk-YUKPKFX5.js";
@@ -25,4 +25,4 @@ var createIntentRouter = (agent) => {
25
25
  export {
26
26
  createIntentRouter
27
27
  };
28
- //# sourceMappingURL=chunk-THBAYYPZ.js.map
28
+ //# sourceMappingURL=chunk-WO2QJ6UM.js.map
@@ -1,18 +1,18 @@
1
1
  import {
2
2
  IntentFulfillService
3
- } from "./chunk-WL7H2QX4.js";
4
- import {
5
- IntentTriggerService
6
- } from "./chunk-DIW5VDAQ.js";
3
+ } from "./chunk-UEUZ7G5P.js";
7
4
  import {
8
5
  generateTitle
9
- } from "./chunk-J2UFYVKK.js";
6
+ } from "./chunk-5IIF5O4A.js";
7
+ import {
8
+ IntentTriggerService
9
+ } from "./chunk-KOCOM7IC.js";
10
10
  import {
11
11
  AinHttpError
12
12
  } from "./chunk-WUNZG3WP.js";
13
13
  import {
14
14
  loggers
15
- } from "./chunk-N7VYM2R5.js";
15
+ } from "./chunk-VUMI4XOY.js";
16
16
 
17
17
  // src/services/query.service.ts
18
18
  import { randomUUID } from "crypto";
@@ -102,4 +102,4 @@ var QueryService = class {
102
102
  export {
103
103
  QueryService
104
104
  };
105
- //# sourceMappingURL=chunk-7XCSPITE.js.map
105
+ //# sourceMappingURL=chunk-Y7BKUWRJ.js.map
@@ -1,12 +1,12 @@
1
1
  import {
2
2
  QueryService
3
- } from "./chunk-7XCSPITE.js";
3
+ } from "./chunk-Y7BKUWRJ.js";
4
4
  import {
5
5
  QueryStreamService
6
- } from "./chunk-3QCXIHM7.js";
6
+ } from "./chunk-JCXAHLRN.js";
7
7
  import {
8
8
  QueryController
9
- } from "./chunk-OW7PCDK5.js";
9
+ } from "./chunk-JHKBIDPX.js";
10
10
 
11
11
  // src/routes/query.routes.ts
12
12
  import { Router } from "express";
@@ -38,4 +38,4 @@ var createQueryRouter = (agent, allowStream = false) => {
38
38
  export {
39
39
  createQueryRouter
40
40
  };
41
- //# sourceMappingURL=chunk-ZK2KSFGQ.js.map
41
+ //# sourceMappingURL=chunk-YJTWW6QK.js.map
@@ -1,6 +1,6 @@
1
1
  import {
2
2
  loggers
3
- } from "./chunk-N7VYM2R5.js";
3
+ } from "./chunk-VUMI4XOY.js";
4
4
 
5
5
  // src/controllers/a2a.controller.ts
6
6
  import {
@@ -108,4 +108,4 @@ var A2AController = class {
108
108
  export {
109
109
  A2AController
110
110
  };
111
- //# sourceMappingURL=chunk-HAE333YO.js.map
111
+ //# sourceMappingURL=chunk-YMSNW2SU.js.map
@@ -0,0 +1,7 @@
1
+ import { AinAgentManifest } from '../types/agent.js';
2
+ import 'http-status-codes';
3
+
4
+ declare function setManifest(manifest: AinAgentManifest): void;
5
+ declare function getManifest(): AinAgentManifest;
6
+
7
+ export { getManifest, setManifest };
@@ -0,0 +1,9 @@
1
+ import {
2
+ getManifest,
3
+ setManifest
4
+ } from "../chunk-2J2TQRP4.js";
5
+ export {
6
+ getManifest,
7
+ setManifest
8
+ };
9
+ //# sourceMappingURL=manifest.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
@@ -5,16 +5,16 @@ import { A2AService } from '../services/a2a.service.js';
5
5
  import '../services/query-stream.service.js';
6
6
  import '../modules/a2a/a2a.module.js';
7
7
  import '../types/connector.js';
8
+ import '../types/stream.js';
9
+ import '../types/memory.js';
8
10
  import '../modules/mcp/mcp.module.js';
9
11
  import '../types/mcp.js';
10
12
  import '@modelcontextprotocol/sdk/client/sse.js';
11
13
  import '@modelcontextprotocol/sdk/client/stdio.js';
12
14
  import '@modelcontextprotocol/sdk/client/streamableHttp.js';
13
- import '../types/memory.js';
14
15
  import '../modules/memory/memory.module.js';
15
16
  import '../modules/memory/base.memory.js';
16
17
  import '../modules/models/base.model.js';
17
- import '../types/stream.js';
18
18
  import '../modules/models/model.module.js';
19
19
 
20
20
  declare class A2AController {
@@ -1,7 +1,7 @@
1
1
  import {
2
2
  A2AController
3
- } from "../chunk-HAE333YO.js";
4
- import "../chunk-N7VYM2R5.js";
3
+ } from "../chunk-YMSNW2SU.js";
4
+ import "../chunk-VUMI4XOY.js";
5
5
  export {
6
6
  A2AController
7
7
  };
@@ -3,6 +3,8 @@ import { AINAgent } from '../../index.js';
3
3
  import '@a2a-js/sdk';
4
4
  import '../../modules/a2a/a2a.module.js';
5
5
  import '../../types/connector.js';
6
+ import '../../types/stream.js';
7
+ import '../../types/memory.js';
6
8
  import '../../modules/auth/base.auth.js';
7
9
  import '../../types/auth.js';
8
10
  import '../../modules/mcp/mcp.module.js';
@@ -12,10 +14,8 @@ import '@modelcontextprotocol/sdk/client/stdio.js';
12
14
  import '@modelcontextprotocol/sdk/client/streamableHttp.js';
13
15
  import '../../modules/memory/memory.module.js';
14
16
  import '../../modules/memory/base.memory.js';
15
- import '../../types/memory.js';
16
17
  import '../../modules/models/model.module.js';
17
18
  import '../../modules/models/base.model.js';
18
- import '../../types/stream.js';
19
19
  import '../../types/agent.js';
20
20
  import 'http-status-codes';
21
21
 
@@ -10,16 +10,16 @@ import '../services/a2a.service.js';
10
10
  import '../services/query-stream.service.js';
11
11
  import '../modules/a2a/a2a.module.js';
12
12
  import '../types/connector.js';
13
+ import '../types/stream.js';
14
+ import '../types/memory.js';
13
15
  import '../modules/mcp/mcp.module.js';
14
16
  import '../types/mcp.js';
15
17
  import '@modelcontextprotocol/sdk/client/sse.js';
16
18
  import '@modelcontextprotocol/sdk/client/stdio.js';
17
19
  import '@modelcontextprotocol/sdk/client/streamableHttp.js';
18
- import '../types/memory.js';
19
20
  import '../modules/memory/memory.module.js';
20
21
  import '../modules/memory/base.memory.js';
21
22
  import '../modules/models/base.model.js';
22
- import '../types/stream.js';
23
23
  import '../modules/models/model.module.js';
24
24
  import '../index.js';
25
25
  import '../modules/auth/base.auth.js';
@@ -9,12 +9,13 @@ import {
9
9
  } from "../chunk-RL6SRSSK.js";
10
10
  import {
11
11
  A2AController
12
- } from "../chunk-HAE333YO.js";
12
+ } from "../chunk-YMSNW2SU.js";
13
13
  import {
14
14
  QueryController
15
- } from "../chunk-OW7PCDK5.js";
15
+ } from "../chunk-JHKBIDPX.js";
16
+ import "../chunk-GRN6CHNO.js";
16
17
  import "../chunk-WUNZG3WP.js";
17
- import "../chunk-N7VYM2R5.js";
18
+ import "../chunk-VUMI4XOY.js";
18
19
  export {
19
20
  A2AController,
20
21
  AgentApiController,
@@ -4,16 +4,16 @@ import { QueryService } from '../services/query.service.js';
4
4
  import '../modules/a2a/a2a.module.js';
5
5
  import '@a2a-js/sdk';
6
6
  import '../types/connector.js';
7
+ import '../types/stream.js';
8
+ import '../types/memory.js';
7
9
  import '../modules/mcp/mcp.module.js';
8
10
  import '../types/mcp.js';
9
11
  import '@modelcontextprotocol/sdk/client/sse.js';
10
12
  import '@modelcontextprotocol/sdk/client/stdio.js';
11
13
  import '@modelcontextprotocol/sdk/client/streamableHttp.js';
12
- import '../types/memory.js';
13
14
  import '../modules/memory/memory.module.js';
14
15
  import '../modules/memory/base.memory.js';
15
16
  import '../modules/models/base.model.js';
16
- import '../types/stream.js';
17
17
  import '../modules/models/model.module.js';
18
18
 
19
19
  declare class QueryController {
@@ -1,6 +1,7 @@
1
1
  import {
2
2
  QueryController
3
- } from "../chunk-OW7PCDK5.js";
3
+ } from "../chunk-JHKBIDPX.js";
4
+ import "../chunk-GRN6CHNO.js";
4
5
  import "../chunk-WUNZG3WP.js";
5
6
  export {
6
7
  QueryController
@@ -7,15 +7,15 @@ import { MemoryModule } from './modules/memory/memory.module.js';
7
7
  import { ModelModule } from './modules/models/model.module.js';
8
8
  import { AinAgentManifest } from './types/agent.js';
9
9
  import './types/connector.js';
10
+ import './types/stream.js';
11
+ import './types/memory.js';
10
12
  import './types/auth.js';
11
13
  import './types/mcp.js';
12
14
  import '@modelcontextprotocol/sdk/client/sse.js';
13
15
  import '@modelcontextprotocol/sdk/client/stdio.js';
14
16
  import '@modelcontextprotocol/sdk/client/streamableHttp.js';
15
17
  import './modules/memory/base.memory.js';
16
- import './types/memory.js';
17
18
  import './modules/models/base.model.js';
18
- import './types/stream.js';
19
19
  import 'http-status-codes';
20
20
 
21
21
  /**
@@ -75,13 +75,6 @@ declare class AINAgent {
75
75
  * Also applies authentication middleware if configured.
76
76
  */
77
77
  private initializeMiddlewares;
78
- /**
79
- * Validates if a string is a valid HTTP or HTTPS URL.
80
- *
81
- * @param urlString - The URL string to validate
82
- * @returns true if the URL is valid HTTP/HTTPS, false otherwise
83
- */
84
- private isValidUrl;
85
78
  /**
86
79
  * Generates an A2A protocol agent card for discovery.
87
80
  *