@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,11 +1,11 @@
1
1
  "use strict";Object.defineProperty(exports, "__esModule", {value: true});
2
2
 
3
- var _chunkX5INT5HEcjs = require('../../chunk-X5INT5HE.cjs');
3
+ var _chunkU47SG7XGcjs = require('../../chunk-U47SG7XG.cjs');
4
4
  require('../../chunk-7HBOMBZG.cjs');
5
- require('../../chunk-W224GBH7.cjs');
6
5
  require('../../chunk-L6RI7RO4.cjs');
7
- require('../../chunk-466ED5WN.cjs');
6
+ require('../../chunk-W224GBH7.cjs');
7
+ require('../../chunk-CLJ3DWTA.cjs');
8
8
 
9
9
 
10
- exports.IntentFulfillService = _chunkX5INT5HEcjs.IntentFulfillService;
10
+ exports.IntentFulfillService = _chunkU47SG7XGcjs.IntentFulfillService;
11
11
  //# sourceMappingURL=fulfill.service.cjs.map
@@ -1,8 +1,8 @@
1
1
  "use strict";Object.defineProperty(exports, "__esModule", {value: true});
2
2
 
3
- var _chunkTF7S7SPOcjs = require('../../chunk-TF7S7SPO.cjs');
4
- require('../../chunk-466ED5WN.cjs');
3
+ var _chunkNEWJ7PXHcjs = require('../../chunk-NEWJ7PXH.cjs');
4
+ require('../../chunk-CLJ3DWTA.cjs');
5
5
 
6
6
 
7
- exports.IntentTriggerService = _chunkTF7S7SPOcjs.IntentTriggerService;
7
+ exports.IntentTriggerService = _chunkNEWJ7PXHcjs.IntentTriggerService;
8
8
  //# sourceMappingURL=trigger.service.cjs.map
@@ -1,15 +1,16 @@
1
1
  "use strict";Object.defineProperty(exports, "__esModule", {value: true});
2
2
 
3
- var _chunkQSBUV5WJcjs = require('../chunk-QSBUV5WJ.cjs');
4
- require('../chunk-2TOW46DI.cjs');
5
- require('../chunk-TF7S7SPO.cjs');
3
+ var _chunk7KXB6FOTcjs = require('../chunk-7KXB6FOT.cjs');
4
+ require('../chunk-OZPPTVUA.cjs');
5
+ require('../chunk-XHTEJE4E.cjs');
6
+ require('../chunk-NEWJ7PXH.cjs');
6
7
  require('../chunk-7HBOMBZG.cjs');
7
- require('../chunk-MO3H4KHE.cjs');
8
- require('../chunk-Z6TQ7TFO.cjs');
9
- require('../chunk-W224GBH7.cjs');
10
8
  require('../chunk-L6RI7RO4.cjs');
11
- require('../chunk-466ED5WN.cjs');
9
+ require('../chunk-O5X5QT63.cjs');
10
+ require('../chunk-W224GBH7.cjs');
11
+ require('../chunk-Z6TQ7TFO.cjs');
12
+ require('../chunk-CLJ3DWTA.cjs');
12
13
 
13
14
 
14
- exports.QueryStreamService = _chunkQSBUV5WJcjs.QueryStreamService;
15
+ exports.QueryStreamService = _chunk7KXB6FOTcjs.QueryStreamService;
15
16
  //# sourceMappingURL=query-stream.service.cjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/services/query-stream.service.cjs"],"names":[],"mappings":"AAAA;AACE;AACF,yDAA8B;AAC9B,iCAA8B;AAC9B,iCAA8B;AAC9B,iCAA8B;AAC9B,iCAA8B;AAC9B,iCAA8B;AAC9B,iCAA8B;AAC9B,iCAA8B;AAC9B,iCAA8B;AAC9B;AACE;AACF,kEAAC","file":"/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/services/query-stream.service.cjs"}
1
+ {"version":3,"sources":["/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/services/query-stream.service.cjs"],"names":[],"mappings":"AAAA;AACE;AACF,yDAA8B;AAC9B,iCAA8B;AAC9B,iCAA8B;AAC9B,iCAA8B;AAC9B,iCAA8B;AAC9B,iCAA8B;AAC9B,iCAA8B;AAC9B,iCAA8B;AAC9B,iCAA8B;AAC9B,iCAA8B;AAC9B;AACE;AACF,kEAAC","file":"/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/services/query-stream.service.cjs"}
@@ -1,15 +1,15 @@
1
1
  "use strict";Object.defineProperty(exports, "__esModule", {value: true});
2
2
 
3
- var _chunkK5LS7KNVcjs = require('../chunk-K5LS7KNV.cjs');
4
- require('../chunk-X5INT5HE.cjs');
5
- require('../chunk-TF7S7SPO.cjs');
3
+ var _chunkRVT67VJLcjs = require('../chunk-RVT67VJL.cjs');
4
+ require('../chunk-U47SG7XG.cjs');
5
+ require('../chunk-XHTEJE4E.cjs');
6
+ require('../chunk-NEWJ7PXH.cjs');
6
7
  require('../chunk-7HBOMBZG.cjs');
7
- require('../chunk-MO3H4KHE.cjs');
8
- require('../chunk-Z6TQ7TFO.cjs');
9
- require('../chunk-W224GBH7.cjs');
10
8
  require('../chunk-L6RI7RO4.cjs');
11
- require('../chunk-466ED5WN.cjs');
9
+ require('../chunk-W224GBH7.cjs');
10
+ require('../chunk-Z6TQ7TFO.cjs');
11
+ require('../chunk-CLJ3DWTA.cjs');
12
12
 
13
13
 
14
- exports.QueryService = _chunkK5LS7KNVcjs.QueryService;
14
+ exports.QueryService = _chunkRVT67VJLcjs.QueryService;
15
15
  //# sourceMappingURL=query.service.cjs.map
@@ -1,8 +1,8 @@
1
1
  "use strict";Object.defineProperty(exports, "__esModule", {value: true});
2
2
 
3
- var _chunkMO3H4KHEcjs = require('../../chunk-MO3H4KHE.cjs');
4
- require('../../chunk-466ED5WN.cjs');
3
+ var _chunkXHTEJE4Ecjs = require('../../chunk-XHTEJE4E.cjs');
4
+ require('../../chunk-CLJ3DWTA.cjs');
5
5
 
6
6
 
7
- exports.generateTitle = _chunkMO3H4KHEcjs.generateTitle;
7
+ exports.generateTitle = _chunkXHTEJE4Ecjs.generateTitle;
8
8
  //# sourceMappingURL=query.common.cjs.map
@@ -0,0 +1,7 @@
1
+ "use strict";Object.defineProperty(exports, "__esModule", {value: true});
2
+
3
+ var _chunkB3U3LJ7Jcjs = require('../chunk-B3U3LJ7J.cjs');
4
+
5
+
6
+ exports.default = _chunkB3U3LJ7Jcjs.isValidUrl;
7
+ //# sourceMappingURL=isValidUrl.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/utils/isValidUrl.cjs"],"names":[],"mappings":"AAAA;AACE;AACF,yDAA8B;AAC9B;AACE;AACF,+CAAC","file":"/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/utils/isValidUrl.cjs"}
@@ -2,10 +2,10 @@
2
2
 
3
3
 
4
4
 
5
- var _chunk466ED5WNcjs = require('../chunk-466ED5WN.cjs');
5
+ var _chunkCLJ3DWTAcjs = require('../chunk-CLJ3DWTA.cjs');
6
6
 
7
7
 
8
8
 
9
9
 
10
- exports.getLogger = _chunk466ED5WNcjs.getLogger; exports.logger = _chunk466ED5WNcjs.logger; exports.loggers = _chunk466ED5WNcjs.loggers;
10
+ exports.getLogger = _chunkCLJ3DWTAcjs.getLogger; exports.logger = _chunkCLJ3DWTAcjs.logger; exports.loggers = _chunkCLJ3DWTAcjs.loggers;
11
11
  //# sourceMappingURL=logger.cjs.map
@@ -0,0 +1,19 @@
1
+ // src/config/manifest.ts
2
+ var _manifest = null;
3
+ function setManifest(manifest) {
4
+ _manifest = manifest;
5
+ }
6
+ function getManifest() {
7
+ if (!_manifest) {
8
+ throw new Error(
9
+ "Manifest not initialized. AINAgent must be created first."
10
+ );
11
+ }
12
+ return _manifest;
13
+ }
14
+
15
+ export {
16
+ setManifest,
17
+ getManifest
18
+ };
19
+ //# sourceMappingURL=chunk-2J2TQRP4.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/config/manifest.ts"],"sourcesContent":["import type { AinAgentManifest } from \"@/types/agent\";\n\nlet _manifest: AinAgentManifest | null = null;\n\nexport function setManifest(manifest: AinAgentManifest): void {\n\t_manifest = manifest;\n}\n\nexport function getManifest(): AinAgentManifest {\n\tif (!_manifest) {\n\t\tthrow new Error(\n\t\t\t\"Manifest not initialized. AINAgent must be created first.\",\n\t\t);\n\t}\n\treturn _manifest;\n}\n"],"mappings":";AAEA,IAAI,YAAqC;AAElC,SAAS,YAAY,UAAkC;AAC7D,cAAY;AACb;AAEO,SAAS,cAAgC;AAC/C,MAAI,CAAC,WAAW;AACf,UAAM,IAAI;AAAA,MACT;AAAA,IACD;AAAA,EACD;AACA,SAAO;AACR;","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/a2a.service.ts
6
6
  import { randomUUID } from "crypto";
@@ -54,12 +54,6 @@ var A2AService = class {
54
54
  };
55
55
  eventBus.publish(initialTask);
56
56
  }
57
- const workingStatusUpdate = this.createTaskStatusUpdateEvent(
58
- taskId,
59
- threadId,
60
- "working"
61
- );
62
- eventBus.publish(workingStatusUpdate);
63
57
  const message = userMessage.parts.filter((part) => part.kind === "text").map((part) => part.text).join("\n");
64
58
  if (message.length === 0) {
65
59
  loggers.server.warn(`Empty message received for task ${taskId}.`);
@@ -92,22 +86,14 @@ var A2AService = class {
92
86
  }
93
87
  if (event.event === "text_chunk") {
94
88
  finalResponseText += event.data.delta;
95
- } else if (event.event === "tool_start") {
96
- const toolStartUpdate = this.createTaskStatusUpdateEvent(
97
- taskId,
98
- threadId,
99
- "working",
100
- JSON.stringify(event.data)
101
- );
102
- eventBus.publish(toolStartUpdate);
103
- } else if (event.event === "tool_output") {
104
- const toolOutputUpdate = this.createTaskStatusUpdateEvent(
89
+ } else if (event.event === "thinking_process") {
90
+ const thinkingProcessUpdate = this.createTaskStatusUpdateEvent(
105
91
  taskId,
106
92
  threadId,
107
93
  "working",
108
94
  JSON.stringify(event.data)
109
95
  );
110
- eventBus.publish(toolOutputUpdate);
96
+ eventBus.publish(thinkingProcessUpdate);
111
97
  }
112
98
  }
113
99
  const finalUpdate = this.createTaskStatusUpdateEvent(
@@ -134,4 +120,4 @@ var A2AService = class {
134
120
  export {
135
121
  A2AService
136
122
  };
137
- //# sourceMappingURL=chunk-DM6UZSRU.js.map
123
+ //# sourceMappingURL=chunk-4LBR3TIJ.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/services/a2a.service.ts"],"sourcesContent":["import { randomUUID } from \"node:crypto\";\nimport type { Task, TaskStatusUpdateEvent } from \"@a2a-js/sdk\";\nimport type {\n\tAgentExecutor,\n\tExecutionEventBus,\n\tRequestContext,\n} from \"@a2a-js/sdk/server\";\nimport type { ThreadType } from \"@/types/memory.js\";\nimport { loggers } from \"@/utils/logger.js\";\nimport type { QueryStreamService } from \"./query-stream.service.js\";\n\n/**\n * Implements the AgentExecutor interface from the a2a-js-sdk.\n * This service is responsible for the core business logic of executing an A2A task.\n */\nexport class A2AService implements AgentExecutor {\n\tprivate queryStreamService: QueryStreamService;\n\tprivate canceledTasks: Set<string> = new Set<string>();\n\n\tconstructor(queryStreamService: QueryStreamService) {\n\t\tthis.queryStreamService = queryStreamService;\n\t}\n\n\tpublic cancelTask = async (\n\t\ttaskId: string,\n\t\t_eventBus: ExecutionEventBus,\n\t): Promise<void> => {\n\t\tthis.canceledTasks.add(taskId);\n\t};\n\n\tprivate createTaskStatusUpdateEvent = (\n\t\ttaskId: string,\n\t\tcontextId: string,\n\t\tstate: \"working\" | \"failed\" | \"canceled\" | \"completed\",\n\t\tmessage?: string,\n\t): TaskStatusUpdateEvent => {\n\t\treturn {\n\t\t\tkind: \"status-update\",\n\t\t\ttaskId: taskId,\n\t\t\tcontextId: contextId,\n\t\t\tstatus: {\n\t\t\t\tstate: state,\n\t\t\t\tmessage: message\n\t\t\t\t\t? {\n\t\t\t\t\t\t\tkind: \"message\",\n\t\t\t\t\t\t\trole: \"agent\",\n\t\t\t\t\t\t\tmessageId: randomUUID(),\n\t\t\t\t\t\t\tparts: [{ kind: \"text\", text: message }],\n\t\t\t\t\t\t\ttaskId: taskId,\n\t\t\t\t\t\t\tcontextId: contextId,\n\t\t\t\t\t\t}\n\t\t\t\t\t: undefined,\n\t\t\t\ttimestamp: new Date().toISOString(),\n\t\t\t},\n\t\t\tfinal: state !== \"working\",\n\t\t};\n\t};\n\n\tasync execute(\n\t\trequestContext: RequestContext,\n\t\teventBus: ExecutionEventBus,\n\t): Promise<void> {\n\t\tconst userMessage = requestContext.userMessage;\n\t\t// A2A context ID === AIN ADK thread ID\n\t\tconst threadId = userMessage.contextId!; // TODO: no context id case\n\n\t\tconst { agentId, type } = userMessage.metadata as {\n\t\t\tagentId: string;\n\t\t\ttype: ThreadType;\n\t\t};\n\t\tconst existingTask = requestContext.task;\n\n\t\tconst taskId = existingTask?.id || randomUUID();\n\n\t\tif (!existingTask) {\n\t\t\tconst initialTask: Task = {\n\t\t\t\tkind: \"task\",\n\t\t\t\tid: taskId,\n\t\t\t\tcontextId: threadId,\n\t\t\t\tstatus: {\n\t\t\t\t\tstate: \"submitted\",\n\t\t\t\t\ttimestamp: new Date().toISOString(),\n\t\t\t\t},\n\t\t\t\thistory: [userMessage],\n\t\t\t\tmetadata: userMessage.metadata,\n\t\t\t\tartifacts: [],\n\t\t\t};\n\t\t\teventBus.publish(initialTask);\n\t\t}\n\n\t\tconst message: string = userMessage.parts\n\t\t\t.filter((part) => part.kind === \"text\")\n\t\t\t.map((part) => part.text)\n\t\t\t.join(\"\\n\");\n\t\tif (message.length === 0) {\n\t\t\tloggers.server.warn(`Empty message received for task ${taskId}.`);\n\t\t\tconst failureUpdate = this.createTaskStatusUpdateEvent(\n\t\t\t\ttaskId,\n\t\t\t\tthreadId,\n\t\t\t\t\"failed\",\n\t\t\t\t\"No message found to process.\",\n\t\t\t);\n\t\t\teventBus.publish(failureUpdate);\n\t\t\treturn;\n\t\t}\n\n\t\tconst stream = this.queryStreamService.handleQueryStream(\n\t\t\t{ userId: agentId, type, threadId },\n\t\t\tmessage,\n\t\t\ttrue,\n\t\t);\n\n\t\ttry {\n\t\t\tlet finalResponseText = \"\";\n\t\t\tfor await (const event of stream) {\n\t\t\t\tif (this.canceledTasks.has(taskId)) {\n\t\t\t\t\tloggers.server.info(`Task ${taskId} was canceled.`);\n\t\t\t\t\tconst canceledUpdate = this.createTaskStatusUpdateEvent(\n\t\t\t\t\t\ttaskId,\n\t\t\t\t\t\tthreadId,\n\t\t\t\t\t\t\"canceled\",\n\t\t\t\t\t);\n\t\t\t\t\teventBus.publish(canceledUpdate);\n\t\t\t\t\treturn;\n\t\t\t\t}\n\n\t\t\t\tif (event.event === \"text_chunk\") {\n\t\t\t\t\tfinalResponseText += event.data.delta;\n\t\t\t\t} else if (event.event === \"thinking_process\") {\n\t\t\t\t\tconst thinkingProcessUpdate = this.createTaskStatusUpdateEvent(\n\t\t\t\t\t\ttaskId,\n\t\t\t\t\t\tthreadId,\n\t\t\t\t\t\t\"working\",\n\t\t\t\t\t\tJSON.stringify(event.data),\n\t\t\t\t\t);\n\t\t\t\t\teventBus.publish(thinkingProcessUpdate);\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tconst finalUpdate = this.createTaskStatusUpdateEvent(\n\t\t\t\ttaskId,\n\t\t\t\tthreadId,\n\t\t\t\t\"completed\",\n\t\t\t\tfinalResponseText,\n\t\t\t);\n\t\t\teventBus.publish(finalUpdate);\n\t\t\tloggers.server.info(`Task ${taskId} completed successfully.`);\n\t\t} catch (error: any) {\n\t\t\tloggers.server.error(`Error processing task ${taskId}:`, error);\n\t\t\tconst errorUpdate = this.createTaskStatusUpdateEvent(\n\t\t\t\ttaskId,\n\t\t\t\tthreadId,\n\t\t\t\t\"failed\",\n\t\t\t\t`Agent error: ${error.message}`,\n\t\t\t);\n\t\t\teventBus.publish(errorUpdate);\n\t\t}\n\t}\n}\n"],"mappings":"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","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/utils/query.common.ts
6
6
  async function generateTitle(modelModule, query, options) {
@@ -35,4 +35,4 @@ Always respond in the same language as the user's input.`
35
35
  export {
36
36
  generateTitle
37
37
  };
38
- //# sourceMappingURL=chunk-J2UFYVKK.js.map
38
+ //# sourceMappingURL=chunk-5IIF5O4A.js.map
@@ -1,12 +1,12 @@
1
- import {
2
- A2AService
3
- } from "./chunk-DM6UZSRU.js";
4
1
  import {
5
2
  QueryStreamService
6
- } from "./chunk-3QCXIHM7.js";
3
+ } from "./chunk-JCXAHLRN.js";
4
+ import {
5
+ A2AService
6
+ } from "./chunk-4LBR3TIJ.js";
7
7
  import {
8
8
  A2AController
9
- } from "./chunk-HAE333YO.js";
9
+ } from "./chunk-YMSNW2SU.js";
10
10
 
11
11
  // src/routes/a2a.routes.ts
12
12
  import { InMemoryTaskStore } from "@a2a-js/sdk/server";
@@ -33,4 +33,4 @@ var createA2ARouter = (agent) => {
33
33
  export {
34
34
  createA2ARouter
35
35
  };
36
- //# sourceMappingURL=chunk-YVN6VFRT.js.map
36
+ //# sourceMappingURL=chunk-6AN7Z5OC.js.map
@@ -1,9 +1,12 @@
1
1
  import {
2
2
  createFulfillPrompt
3
3
  } from "./chunk-7BH6AYP7.js";
4
+ import {
5
+ getManifest
6
+ } from "./chunk-2J2TQRP4.js";
4
7
  import {
5
8
  loggers
6
- } from "./chunk-N7VYM2R5.js";
9
+ } from "./chunk-VUMI4XOY.js";
7
10
 
8
11
  // src/services/intents/fulfill-stream.service.ts
9
12
  import { randomUUID } from "crypto";
@@ -104,63 +107,54 @@ var IntentFulfillStreamService = class {
104
107
  });
105
108
  if (assembledToolCalls.length > 0) {
106
109
  for (const toolCall of assembledToolCalls) {
107
- const toolCallId = randomUUID();
108
110
  const toolName = toolCall.function.name;
109
111
  let selectedTool;
110
112
  for (const [index, toolTmp] of tools.entries()) {
111
113
  if (toolTmp.toolName === toolName) {
112
- selectedTool = tools.splice(index, 1)[0];
113
- break;
114
+ if (toolTmp.protocol === "A2A" /* A2A */) {
115
+ selectedTool = tools.splice(index, 1)[0];
116
+ break;
117
+ }
118
+ selectedTool = toolTmp;
114
119
  }
115
120
  }
116
121
  if (!selectedTool) {
117
122
  continue;
118
123
  }
124
+ const toolArgs = JSON.parse(toolCall.function.arguments);
125
+ const thinkData = {
126
+ title: `[${getManifest().name}] ${selectedTool.protocol} \uC2E4\uD589: ${toolName}`,
127
+ description: `${toolArgs.thinking_text || ""}`
128
+ };
129
+ yield {
130
+ event: "thinking_process",
131
+ data: thinkData
132
+ };
119
133
  let toolResult = "";
120
134
  if (this.mcpModule && selectedTool.protocol === "MCP" /* MCP */) {
121
- const toolArgs = JSON.parse(toolCall.function.arguments);
122
- yield {
123
- event: "tool_start",
124
- data: {
125
- toolCallId,
126
- protocol: "MCP" /* MCP */,
127
- toolName,
128
- toolArgs
129
- }
130
- };
131
135
  loggers.intent.info("MCP tool call", { toolName, toolArgs });
132
136
  toolResult = await this.mcpModule.useTool(selectedTool, toolArgs);
133
137
  } else if (this.a2aModule && selectedTool.protocol === "A2A" /* A2A */) {
134
- yield {
135
- event: "tool_start",
136
- data: {
137
- toolCallId,
138
- protocol: "A2A" /* A2A */,
139
- toolName,
140
- toolArgs: null
141
- }
142
- };
143
138
  loggers.intent.info("A2A tool call", { toolName });
144
- toolResult = await this.a2aModule.useTool(
139
+ const a2aStream = this.a2aModule.useTool(
145
140
  selectedTool,
146
141
  query,
147
142
  thread.threadId
148
143
  );
144
+ let result = await a2aStream.next();
145
+ while (!result.done) {
146
+ if (result.value.event === "thinking_process") {
147
+ yield result.value;
148
+ }
149
+ result = await a2aStream.next();
150
+ }
151
+ toolResult = result.value;
149
152
  } else {
150
153
  loggers.intent.warn(
151
154
  `Unrecognized tool type: ${selectedTool.protocol}`
152
155
  );
153
156
  continue;
154
157
  }
155
- yield {
156
- event: "tool_output",
157
- data: {
158
- toolCallId,
159
- protocol: selectedTool.protocol,
160
- toolName,
161
- result: toolResult
162
- }
163
- };
164
158
  loggers.intent.debug("Tool Result", { toolResult });
165
159
  processList.push(toolResult);
166
160
  modelInstance.appendMessages(messages, toolResult);
@@ -201,18 +195,13 @@ var IntentFulfillStreamService = class {
201
195
  content: { type: "text", parts: [finalResponseText] },
202
196
  metadata: { isThinking: true }
203
197
  });
204
- await this.addToThreadMessages(thread, {
205
- role: "MODEL" /* MODEL */,
206
- content: subquery,
207
- metadata: {
208
- subquery,
209
- isThinking: true,
210
- actionPlan
211
- }
212
- });
198
+ const thinkData = {
199
+ title: `[${getManifest().name}] ${subquery}`,
200
+ description: actionPlan || ""
201
+ };
213
202
  yield {
214
- event: "intent_process",
215
- data: { subquery, actionPlan: actionPlan || "" }
203
+ event: "thinking_process",
204
+ data: thinkData
216
205
  };
217
206
  const stream = this.intentFulfilling(subquery, thread, intent);
218
207
  finalResponseText = "";
@@ -243,4 +232,4 @@ var IntentFulfillStreamService = class {
243
232
  export {
244
233
  IntentFulfillStreamService
245
234
  };
246
- //# sourceMappingURL=chunk-4NESTSZ3.js.map
235
+ //# sourceMappingURL=chunk-A5PRJ33H.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/services/intents/fulfill-stream.service.ts"],"sourcesContent":["import { randomUUID } from \"node:crypto\";\nimport { getManifest } from \"@/config/manifest\";\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 type { StreamEvent } from \"@/types/stream\";\nimport { loggers } from \"@/utils/logger\";\nimport { createFulfillPrompt } from \"../utils/fulfill.common\";\n\nexport class IntentFulfillStreamService {\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: {\n\t\t\trole: MessageRole;\n\t\t\tcontent: string;\n\t\t\tmetadata?: Record<string, unknown>;\n\t\t},\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): AsyncGenerator<StreamEvent> {\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 processList: string[] = [];\n\n\t\twhile (true) {\n\t\t\tconst functions = modelInstance.convertToolsToFunctions(tools);\n\t\t\tconst responseStream = await modelInstance.fetchStreamWithContextMessage(\n\t\t\t\tmessages,\n\t\t\t\tfunctions,\n\t\t\t\tmodelOptions,\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\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\tthreadId: thread.threadId,\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 toolName = toolCall.function.name;\n\t\t\t\t\tlet selectedTool: ConnectorTool | undefined;\n\t\t\t\t\tfor (const [index, toolTmp] of tools.entries()) {\n\t\t\t\t\t\tif (toolTmp.toolName === toolName) {\n\t\t\t\t\t\t\tif (toolTmp.protocol === CONNECTOR_PROTOCOL_TYPE.A2A) {\n\t\t\t\t\t\t\t\t// remove used tool to prevent infinite loop\n\t\t\t\t\t\t\t\tselectedTool = tools.splice(index, 1)[0];\n\t\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tselectedTool = toolTmp;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\tif (!selectedTool) {\n\t\t\t\t\t\t// it cannot be happened...\n\t\t\t\t\t\tcontinue;\n\t\t\t\t\t}\n\n\t\t\t\t\tconst toolArgs = JSON.parse(toolCall.function.arguments);\n\t\t\t\t\tconst thinkData = {\n\t\t\t\t\t\ttitle: `[${getManifest().name}] ${selectedTool.protocol} 실행: ${toolName}`,\n\t\t\t\t\t\tdescription: `${toolArgs.thinking_text || \"\"}`,\n\t\t\t\t\t};\n\t\t\t\t\tyield {\n\t\t\t\t\t\tevent: \"thinking_process\",\n\t\t\t\t\t\tdata: thinkData,\n\t\t\t\t\t};\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\tloggers.intent.info(\"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\tloggers.intent.info(\"A2A tool call\", { toolName });\n\t\t\t\t\t\tconst a2aStream = 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// yield intermediate events and get final result\n\t\t\t\t\t\tlet result = await a2aStream.next();\n\t\t\t\t\t\twhile (!result.done) {\n\t\t\t\t\t\t\tif (result.value.event === \"thinking_process\") {\n\t\t\t\t\t\t\t\tyield result.value;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tresult = await a2aStream.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\", { toolResult });\n\n\t\t\t\t\tprocessList.push(toolResult);\n\t\t\t\t\tmodelInstance.appendMessages(messages, toolResult);\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\n\t\tloggers.intent.debug(\"Intent fulfillment completed\", {\n\t\t\tthreadId: thread.threadId,\n\t\t\ttoolCallsExecuted: processList.length,\n\t\t\tintentName: intent?.name,\n\t\t});\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 *intentFulfillStream(\n\t\tintents: Array<TriggeredIntent>,\n\t\tthread: ThreadObject,\n\t): AsyncGenerator<StreamEvent> {\n\t\tconst streamStartTime = Date.now();\n\t\tloggers.intentStream.info(\"Stream session started\", {\n\t\t\tthreadId: thread.threadId,\n\t\t\tintentCount: intents.length,\n\t\t\tstartTime: new Date(streamStartTime).toISOString(),\n\t\t});\n\n\t\tlet finalResponseText = \"\";\n\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\n\t\t\tconst thinkData = {\n\t\t\t\ttitle: `[${getManifest().name}] ${subquery}`,\n\t\t\t\tdescription: actionPlan || \"\",\n\t\t\t};\n\t\t\tyield {\n\t\t\t\tevent: \"thinking_process\",\n\t\t\t\tdata: thinkData,\n\t\t\t};\n\n\t\t\tconst stream = this.intentFulfilling(subquery, thread, intent);\n\n\t\t\tfinalResponseText = \"\";\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\tfinalResponseText += event.data.delta;\n\t\t\t\t}\n\n\t\t\t\tif (event.event === \"text_chunk\" && i !== intents.length - 1) {\n\t\t\t\t\tcontinue; // skip intermediate text_chunk events\n\t\t\t\t}\n\t\t\t\tyield event;\n\t\t\t}\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\tconst streamEndTime = Date.now();\n\t\tconst streamDuration = streamEndTime - streamStartTime;\n\n\t\tloggers.intentStream.info(\"Stream session completed\", {\n\t\t\tthreadId: thread.threadId,\n\t\t\tduration: `${streamDuration}ms`,\n\t\t\tendTime: new Date(streamEndTime).toISOString(),\n\t\t});\n\t}\n}\n"],"mappings":"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","names":[]}
@@ -21,4 +21,4 @@ var A2AConnector = class {
21
21
  export {
22
22
  A2AConnector
23
23
  };
24
- //# sourceMappingURL=chunk-WMZ6PYTE.js.map
24
+ //# sourceMappingURL=chunk-BZZDVW26.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/modules/a2a/a2a.connector.ts"],"sourcesContent":["import type { Client as A2AClient } from \"@a2a-js/sdk/client\";\nimport {\n\tCONNECTOR_PROTOCOL_TYPE,\n\ttype IAgentConnector,\n} from \"@/types/connector.js\";\n\nexport class A2AConnector implements IAgentConnector {\n\tpublic name: string;\n\tpublic protocol: CONNECTOR_PROTOCOL_TYPE = CONNECTOR_PROTOCOL_TYPE.A2A;\n\tpublic enabled: boolean;\n\tpublic url: string;\n\tpublic client: A2AClient | null = null;\n\n\tconstructor(name: string, url: string) {\n\t\tthis.name = name;\n\t\tthis.enabled = true;\n\t\tthis.url = url;\n\t}\n\n\tpublic enable(): void {\n\t\tthis.enabled = true;\n\t}\n\n\tpublic disable(): void {\n\t\tthis.enabled = false;\n\t}\n}\n"],"mappings":";AAMO,IAAM,eAAN,MAA8C;AAAA,EAC7C;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA,SAA2B;AAAA,EAElC,YAAY,MAAc,KAAa;AACtC,SAAK,OAAO;AACZ,SAAK,UAAU;AACf,SAAK,MAAM;AAAA,EACZ;AAAA,EAEO,SAAe;AACrB,SAAK,UAAU;AAAA,EAChB;AAAA,EAEO,UAAgB;AACtB,SAAK,UAAU;AAAA,EAChB;AACD;","names":[]}
@@ -1,13 +1,13 @@
1
1
  import {
2
2
  A2AConnector
3
- } from "./chunk-WMZ6PYTE.js";
3
+ } from "./chunk-BZZDVW26.js";
4
4
  import {
5
5
  loggers
6
- } from "./chunk-N7VYM2R5.js";
6
+ } from "./chunk-VUMI4XOY.js";
7
7
 
8
8
  // src/modules/a2a/a2a.module.ts
9
9
  import { randomUUID } from "crypto";
10
- import { A2AClient } from "@a2a-js/sdk/client";
10
+ import { ClientFactory } from "@a2a-js/sdk/client";
11
11
  var A2AModule = class {
12
12
  /** Map of A2A server URLs to their corresponding tool instances */
13
13
  a2aConnectors = /* @__PURE__ */ new Map();
@@ -33,8 +33,10 @@ var A2AModule = class {
33
33
  }
34
34
  return connectors;
35
35
  }
36
- getOrCreateClient(connector) {
37
- connector.client ??= new A2AClient(connector.url);
36
+ async getOrCreateClient(connector) {
37
+ if (!connector.client) {
38
+ connector.client = await new ClientFactory().createFromUrl(connector.url);
39
+ }
38
40
  return connector.client;
39
41
  }
40
42
  /**
@@ -52,13 +54,24 @@ var A2AModule = class {
52
54
  continue;
53
55
  }
54
56
  try {
55
- const client = this.getOrCreateClient(conn);
57
+ const client = await this.getOrCreateClient(conn);
56
58
  const card = await client.getAgentCard();
57
59
  const tool = {
58
60
  toolName: card.name.replaceAll(" ", "-"),
59
61
  connectorName: name,
60
62
  protocol: "A2A" /* A2A */,
61
- description: card.description
63
+ description: card.description,
64
+ // add thinking_text inputSchema
65
+ inputSchema: {
66
+ type: "object",
67
+ properties: {
68
+ thinking_text: {
69
+ type: "string",
70
+ 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."
71
+ }
72
+ },
73
+ required: ["thinking_text"]
74
+ }
62
75
  };
63
76
  tools.push(tool);
64
77
  } catch (_error) {
@@ -108,17 +121,24 @@ var A2AModule = class {
108
121
  * @param tool - The A2ATool instance to use
109
122
  * @param query - The message to send to the agent
110
123
  * @param threadId - The session identifier for context tracking
111
- * @returns Promise resolving to array of text responses from the agent
124
+ * @yields StreamEvent objects for intermediate events
125
+ * @returns Final text response from the agent
112
126
  */
113
- async useTool(tool, query, threadId) {
127
+ async *useTool(tool, query, threadId) {
114
128
  const finalText = [];
115
129
  const connector = this.a2aConnectors.get(tool.connectorName);
130
+ if (!connector) {
131
+ loggers.a2a.error("Unknown agent:", { tool });
132
+ const toolResult = `[Bot Called A2A Tool ${tool.connectorName}]
133
+ "Unknown agent connector"`;
134
+ return toolResult;
135
+ }
116
136
  const messagePayload = this.getMessagePayload(query, threadId);
117
137
  const params = {
118
138
  message: messagePayload
119
139
  };
120
140
  try {
121
- const client = this.getOrCreateClient(connector);
141
+ const client = await this.getOrCreateClient(connector);
122
142
  const stream = client.sendMessageStream(params);
123
143
  for await (const event of stream) {
124
144
  if (event.kind === "status-update") {
@@ -126,9 +146,24 @@ var A2AModule = class {
126
146
  if (typedEvent.final && typedEvent.status.state !== "input-required") {
127
147
  this.a2aTasks.delete(threadId);
128
148
  }
129
- const texts = typedEvent.status.message?.parts.filter((part) => part.kind === "text").map((part) => part.text).join("\n");
130
- if (texts) {
131
- finalText.push(texts);
149
+ if (typedEvent.status.state === "working") {
150
+ const eventData = JSON.parse(
151
+ (typedEvent.status.message?.parts[0]).text
152
+ );
153
+ yield {
154
+ event: "thinking_process",
155
+ data: eventData
156
+ };
157
+ } else if (typedEvent.status.state === "completed") {
158
+ const texts = typedEvent.status.message?.parts.filter((part) => part.kind === "text").map((part) => part.text).join("\n");
159
+ if (texts) {
160
+ finalText.push(texts);
161
+ yield {
162
+ event: "text_chunk",
163
+ data: { delta: texts }
164
+ };
165
+ }
166
+ } else {
132
167
  }
133
168
  } else if (event.kind === "message") {
134
169
  const msg = event;
@@ -161,4 +196,4 @@ ${finalText.join("\n")}`;
161
196
  export {
162
197
  A2AModule
163
198
  };
164
- //# sourceMappingURL=chunk-NWL3BMUH.js.map
199
+ //# sourceMappingURL=chunk-FRQSMPPK.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/modules/a2a/a2a.module.ts"],"sourcesContent":["import { randomUUID } from \"node:crypto\";\nimport type {\n\tAgentCard,\n\tMessage,\n\tMessageSendParams,\n\tTask,\n\tTaskStatusUpdateEvent,\n\tTextPart,\n} from \"@a2a-js/sdk\";\nimport { type Client as A2AClient, ClientFactory } from \"@a2a-js/sdk/client\";\nimport {\n\tCONNECTOR_PROTOCOL_TYPE,\n\ttype ConnectorTool,\n} from \"@/types/connector.js\";\nimport { ThreadType } from \"@/types/memory.js\";\nimport type { StreamEvent } from \"@/types/stream.js\";\nimport { loggers } from \"@/utils/logger.js\";\nimport { A2AConnector } from \"./a2a.connector.js\";\n\n/**\n * Module for managing Agent-to-Agent (A2A) protocol connections.\n *\n * This module handles connections to other A2A-compatible agents, manages\n * conversation sessions, and provides an interface for inter-agent communication.\n * Supports multi-turn conversations with task and context tracking.\n */\nexport class A2AModule {\n\t/** Map of A2A server URLs to their corresponding tool instances */\n\tprivate a2aConnectors: Map<string, A2AConnector> = new Map();\n\t/** Map of session IDs to their A2A session state */\n\tprivate a2aTasks: Map<string, string> = new Map();\n\tprivate agentId: string = randomUUID(); /* FIXME */\n\n\t/**\n\t * Registers a new A2A peer server URL for connection.\n\t *\n\t * @param conns - Set of name, url pair\n\t */\n\tpublic async addA2AConnector(conns: {\n\t\t[name: string]: string;\n\t}): Promise<void> {\n\t\tfor (const [name, url] of Object.entries(conns)) {\n\t\t\tconst conn = new A2AConnector(name, url);\n\t\t\tthis.a2aConnectors.set(name, conn);\n\t\t}\n\t}\n\n\tpublic getA2AConnectors(): Array<{ name: string; url: string }> {\n\t\tconst connectors: Array<{ name: string; url: string }> = [];\n\t\tfor (const [name, connector] of this.a2aConnectors.entries()) {\n\t\t\tconnectors.push({ name, url: connector.url });\n\t\t}\n\t\treturn connectors;\n\t}\n\n\tprivate async getOrCreateClient(connector: A2AConnector): Promise<A2AClient> {\n\t\tif (!connector.client) {\n\t\t\tconnector.client = await new ClientFactory().createFromUrl(connector.url);\n\t\t}\n\t\treturn connector.client;\n\t}\n\n\t/**\n\t * Retrieves tools from all registered A2A peer servers.\n\t *\n\t * Attempts to connect to each registered server, fetch their agent cards,\n\t * and create tool instances. Disables tools for unreachable servers.\n\t *\n\t * @returns Promise resolving to array of available A2A tools\n\t */\n\tpublic async getTools(): Promise<ConnectorTool[]> {\n\t\tconst tools: ConnectorTool[] = [];\n\t\tfor (const [name, conn] of this.a2aConnectors.entries()) {\n\t\t\tif (!conn.enabled) {\n\t\t\t\tcontinue; // skip disabled agent\n\t\t\t}\n\n\t\t\ttry {\n\t\t\t\tconst client = await this.getOrCreateClient(conn);\n\t\t\t\tconst card: AgentCard = await client.getAgentCard();\n\t\t\t\t/* TODO: add each skill as tool? */\n\t\t\t\tconst tool: ConnectorTool = {\n\t\t\t\t\ttoolName: card.name.replaceAll(\" \", \"-\"),\n\t\t\t\t\tconnectorName: name,\n\t\t\t\t\tprotocol: CONNECTOR_PROTOCOL_TYPE.A2A,\n\t\t\t\t\tdescription: card.description,\n\t\t\t\t\t// add thinking_text inputSchema\n\t\t\t\t\tinputSchema: {\n\t\t\t\t\t\ttype: \"object\",\n\t\t\t\t\t\tproperties: {\n\t\t\t\t\t\t\tthinking_text: {\n\t\t\t\t\t\t\t\ttype: \"string\",\n\t\t\t\t\t\t\t\tdescription:\n\t\t\t\t\t\t\t\t\t\"사용자의 요청을 해결하기 위해 이 도구를 선택한 구체적인 이유와 목적 (Why & What). 한두줄 정도의 분량으로 입력 언어와 같은 언어로 생성한다.\",\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t\trequired: [\"thinking_text\"],\n\t\t\t\t\t},\n\t\t\t\t};\n\n\t\t\t\ttools.push(tool);\n\t\t\t} catch (_error: any) {\n\t\t\t\t// Agent not responded, just skip\n\t\t\t}\n\t\t}\n\t\treturn tools;\n\t}\n\n\t/**\n\t * Constructs a message payload for A2A communication.\n\t *\n\t * Includes session context (task ID and context ID) if available\n\t * for maintaining conversation continuity.\n\t *\n\t * @param query - The message content to send\n\t * @param threadId - The session identifier\n\t * @returns Formatted Message object for A2A protocol\n\t */\n\tpublic getMessagePayload(query: string, threadId: string): Message {\n\t\tconst messagePayload: Message = {\n\t\t\tmessageId: randomUUID(),\n\t\t\tkind: \"message\",\n\t\t\trole: \"user\", // FIXME: it could be 'agent'\n\t\t\tmetadata: {\n\t\t\t\tagentId: this.agentId,\n\t\t\t\ttype: ThreadType.CHAT,\n\t\t\t},\n\t\t\tparts: [\n\t\t\t\t{\n\t\t\t\t\tkind: \"text\",\n\t\t\t\t\ttext: query,\n\t\t\t\t},\n\t\t\t],\n\t\t\tcontextId: threadId,\n\t\t};\n\n\t\tif (this.a2aTasks.has(threadId)) {\n\t\t\tmessagePayload.taskId = this.a2aTasks.get(threadId);\n\t\t}\n\n\t\treturn messagePayload;\n\t}\n\n\t/**\n\t * Executes an A2A tool by sending a message to the remote agent.\n\t *\n\t * Handles streaming responses, maintains session state, and extracts\n\t * text content from various event types in the response stream.\n\t *\n\t * @param tool - The A2ATool instance to use\n\t * @param query - The message to send to the agent\n\t * @param threadId - The session identifier for context tracking\n\t * @yields StreamEvent objects for intermediate events\n\t * @returns Final text response from the agent\n\t */\n\tpublic async *useTool(\n\t\ttool: ConnectorTool,\n\t\tquery: string,\n\t\tthreadId: string,\n\t): AsyncGenerator<StreamEvent, string, unknown> {\n\t\tconst finalText: string[] = [];\n\t\tconst connector = this.a2aConnectors.get(tool.connectorName);\n\t\tif (!connector) {\n\t\t\tloggers.a2a.error(\"Unknown agent:\", { tool });\n\t\t\tconst toolResult = `[Bot Called A2A Tool ${tool.connectorName}]\\n\"Unknown agent connector\"`;\n\t\t\treturn toolResult;\n\t\t}\n\n\t\tconst messagePayload = this.getMessagePayload(query, threadId);\n\t\tconst params: MessageSendParams = {\n\t\t\tmessage: messagePayload,\n\t\t};\n\n\t\ttry {\n\t\t\tconst client = await this.getOrCreateClient(connector);\n\t\t\tconst stream = client.sendMessageStream(params);\n\t\t\tfor await (const event of stream) {\n\t\t\t\tif (event.kind === \"status-update\") {\n\t\t\t\t\tconst typedEvent = event as TaskStatusUpdateEvent;\n\t\t\t\t\tif (\n\t\t\t\t\t\ttypedEvent.final &&\n\t\t\t\t\t\ttypedEvent.status.state !== \"input-required\"\n\t\t\t\t\t) {\n\t\t\t\t\t\tthis.a2aTasks.delete(threadId);\n\t\t\t\t\t}\n\n\t\t\t\t\tif (typedEvent.status.state === \"working\") {\n\t\t\t\t\t\t// thinking process event\n\t\t\t\t\t\tconst eventData = JSON.parse(\n\t\t\t\t\t\t\t(typedEvent.status.message?.parts[0] as TextPart).text,\n\t\t\t\t\t\t);\n\t\t\t\t\t\tyield {\n\t\t\t\t\t\t\tevent: \"thinking_process\",\n\t\t\t\t\t\t\tdata: eventData,\n\t\t\t\t\t\t};\n\t\t\t\t\t} else if (typedEvent.status.state === \"completed\") {\n\t\t\t\t\t\t// TODO: handle 'file', 'data' parts\n\t\t\t\t\t\tconst texts = typedEvent.status.message?.parts\n\t\t\t\t\t\t\t.filter((part) => part.kind === \"text\")\n\t\t\t\t\t\t\t.map((part: TextPart) => part.text)\n\t\t\t\t\t\t\t.join(\"\\n\");\n\t\t\t\t\t\tif (texts) {\n\t\t\t\t\t\t\tfinalText.push(texts);\n\t\t\t\t\t\t\tyield {\n\t\t\t\t\t\t\t\tevent: \"text_chunk\",\n\t\t\t\t\t\t\t\tdata: { delta: texts },\n\t\t\t\t\t\t\t};\n\t\t\t\t\t\t}\n\t\t\t\t\t} else {\n\t\t\t\t\t\t// ignore other status updates\n\t\t\t\t\t}\n\t\t\t\t} else if (event.kind === \"message\") {\n\t\t\t\t\t// FIXME: handling text in 'message'?\n\t\t\t\t\tconst msg = event as Message;\n\t\t\t\t\tconst taskId = this.a2aTasks.get(threadId);\n\t\t\t\t\tif (msg.taskId && msg.taskId !== taskId) {\n\t\t\t\t\t\tthis.a2aTasks.set(threadId, msg.taskId);\n\t\t\t\t\t}\n\t\t\t\t} else if (event.kind === \"task\") {\n\t\t\t\t\t// establishing the Task ID\n\t\t\t\t\tconst task = event as Task;\n\t\t\t\t\tif (task.id !== this.a2aTasks.get(threadId)) {\n\t\t\t\t\t\tthis.a2aTasks.set(threadId, task.id);\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\tloggers.a2a.warn(\"Received unknown event structure from stream:\", {\n\t\t\t\t\t\tevent,\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t}\n\t\t} catch (error) {\n\t\t\tloggers.a2a.error(\"Error communicating with agent:\", { error });\n\t\t\tconst toolResult = `[Bot Called A2A Tool ${tool.toolName}]\\n${typeof error === \"string\" ? error : JSON.stringify(error, null, 2)}`;\n\t\t\treturn toolResult;\n\t\t}\n\n\t\treturn `[Bot Called A2A Tool ${tool.toolName}]\\n${finalText.join(\"\\n\")}`;\n\t}\n}\n"],"mappings":"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","names":[]}
@@ -0,0 +1,17 @@
1
+ // src/utils/isValidUrl.ts
2
+ function isValidUrl(urlString) {
3
+ if (!urlString) {
4
+ return false;
5
+ }
6
+ try {
7
+ const url = new URL(urlString);
8
+ return url.protocol === "http:" || url.protocol === "https:";
9
+ } catch (_error) {
10
+ return false;
11
+ }
12
+ }
13
+
14
+ export {
15
+ isValidUrl
16
+ };
17
+ //# sourceMappingURL=chunk-I5DLV2CU.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/utils/isValidUrl.ts"],"sourcesContent":["/**\n * Validates if a string is a valid HTTP or HTTPS URL.\n *\n * @param urlString - The URL string to validate\n * @returns true if the URL is valid HTTP/HTTPS, false otherwise\n */\nexport default function isValidUrl(urlString: string | undefined): boolean {\n\tif (!urlString) {\n\t\treturn false;\n\t}\n\n\ttry {\n\t\tconst url = new URL(urlString);\n\t\treturn url.protocol === \"http:\" || url.protocol === \"https:\";\n\t} catch (_error) {\n\t\treturn false;\n\t}\n}\n"],"mappings":";AAMe,SAAR,WAA4B,WAAwC;AAC1E,MAAI,CAAC,WAAW;AACf,WAAO;AAAA,EACR;AAEA,MAAI;AACH,UAAM,MAAM,IAAI,IAAI,SAAS;AAC7B,WAAO,IAAI,aAAa,WAAW,IAAI,aAAa;AAAA,EACrD,SAAS,QAAQ;AAChB,WAAO;AAAA,EACR;AACD;","names":[]}