@ainetwork/adk 0.3.2 → 0.3.4

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 (382) hide show
  1. package/README.md +62 -29
  2. package/dist/cjs/{chunk-RCOESZIX.cjs → chunk-3COIZ4H5.cjs} +5 -5
  3. package/dist/cjs/chunk-3COIZ4H5.cjs.map +1 -0
  4. package/dist/cjs/chunk-4VIZ52C2.cjs +37 -0
  5. package/dist/cjs/chunk-4VIZ52C2.cjs.map +1 -0
  6. package/dist/cjs/{chunk-X46GJS7X.cjs → chunk-4ZTPNV3C.cjs} +4 -4
  7. package/dist/cjs/chunk-4ZTPNV3C.cjs.map +1 -0
  8. package/dist/cjs/{chunk-A2I7D6JW.cjs → chunk-6HUEBFXL.cjs} +1 -1
  9. package/dist/cjs/{chunk-A2I7D6JW.cjs.map → chunk-6HUEBFXL.cjs.map} +1 -1
  10. package/dist/cjs/{chunk-EA3YMPST.cjs → chunk-6JO4LWIY.cjs} +7 -14
  11. package/dist/cjs/chunk-6JO4LWIY.cjs.map +1 -0
  12. package/dist/cjs/{chunk-NEWJ7PXH.cjs → chunk-7E3A6PCO.cjs} +9 -8
  13. package/dist/cjs/chunk-7E3A6PCO.cjs.map +1 -0
  14. package/dist/cjs/chunk-7XYVRO76.cjs +68 -0
  15. package/dist/cjs/chunk-7XYVRO76.cjs.map +1 -0
  16. package/dist/cjs/chunk-AQGJBXBU.cjs +8 -0
  17. package/dist/cjs/chunk-AQGJBXBU.cjs.map +1 -0
  18. package/dist/cjs/chunk-CHREGFB3.cjs +38 -0
  19. package/dist/cjs/chunk-CHREGFB3.cjs.map +1 -0
  20. package/dist/cjs/chunk-CKZDAQBG.cjs +17 -0
  21. package/dist/cjs/chunk-CKZDAQBG.cjs.map +1 -0
  22. package/dist/cjs/chunk-EQWAVDJY.cjs +47 -0
  23. package/dist/cjs/chunk-EQWAVDJY.cjs.map +1 -0
  24. package/dist/cjs/{chunk-5FZ7QLJD.cjs → chunk-EUNCRF3F.cjs} +4 -4
  25. package/dist/cjs/chunk-EUNCRF3F.cjs.map +1 -0
  26. package/dist/cjs/chunk-FLPLVYXQ.cjs +45 -0
  27. package/dist/cjs/chunk-FLPLVYXQ.cjs.map +1 -0
  28. package/dist/cjs/chunk-GA6NTHXB.cjs +17 -0
  29. package/dist/cjs/chunk-GA6NTHXB.cjs.map +1 -0
  30. package/dist/cjs/{chunk-NNYPZA6W.cjs → chunk-HDF5WQFQ.cjs} +31 -26
  31. package/dist/cjs/chunk-HDF5WQFQ.cjs.map +1 -0
  32. package/dist/cjs/{chunk-YCTPMLZO.cjs → chunk-HVNTK4O7.cjs} +12 -8
  33. package/dist/cjs/chunk-HVNTK4O7.cjs.map +1 -0
  34. package/dist/cjs/chunk-I72VEOEC.cjs +62 -0
  35. package/dist/cjs/chunk-I72VEOEC.cjs.map +1 -0
  36. package/dist/cjs/{chunk-OZPPTVUA.cjs → chunk-IP6P2TQM.cjs} +121 -37
  37. package/dist/cjs/chunk-IP6P2TQM.cjs.map +1 -0
  38. package/dist/cjs/chunk-JQIAM5N4.cjs +18 -0
  39. package/dist/cjs/chunk-JQIAM5N4.cjs.map +1 -0
  40. package/dist/cjs/chunk-LTBTLUJD.cjs +74 -0
  41. package/dist/cjs/chunk-LTBTLUJD.cjs.map +1 -0
  42. package/dist/cjs/chunk-MSPDYSCC.cjs +21 -0
  43. package/dist/cjs/chunk-MSPDYSCC.cjs.map +1 -0
  44. package/dist/cjs/chunk-NFEFQTIX.cjs +104 -0
  45. package/dist/cjs/chunk-NFEFQTIX.cjs.map +1 -0
  46. package/dist/cjs/{chunk-QCYLIOXZ.cjs → chunk-NLONGI2K.cjs} +7 -4
  47. package/dist/cjs/chunk-NLONGI2K.cjs.map +1 -0
  48. package/dist/cjs/chunk-NNVC34HX.cjs +95 -0
  49. package/dist/cjs/chunk-NNVC34HX.cjs.map +1 -0
  50. package/dist/cjs/{chunk-Z6TQ7TFO.cjs → chunk-OERUQFT7.cjs} +1 -1
  51. package/dist/cjs/chunk-OERUQFT7.cjs.map +1 -0
  52. package/dist/cjs/{chunk-TZ6JOGWV.cjs → chunk-PH5CFKLN.cjs} +4 -1
  53. package/dist/cjs/chunk-PH5CFKLN.cjs.map +1 -0
  54. package/dist/cjs/{chunk-FJ2JWXSL.cjs → chunk-QHDIM62U.cjs} +12 -8
  55. package/dist/cjs/chunk-QHDIM62U.cjs.map +1 -0
  56. package/dist/cjs/{chunk-5QSLQX4H.cjs → chunk-TDHM5TWT.cjs} +24 -34
  57. package/dist/cjs/chunk-TDHM5TWT.cjs.map +1 -0
  58. package/dist/cjs/{chunk-W224GBH7.cjs → chunk-UNRN7WF6.cjs} +1 -1
  59. package/dist/cjs/{chunk-W224GBH7.cjs.map → chunk-UNRN7WF6.cjs.map} +1 -1
  60. package/dist/cjs/chunk-VM74R2KP.cjs +170 -0
  61. package/dist/cjs/chunk-VM74R2KP.cjs.map +1 -0
  62. package/dist/cjs/chunk-WQIUHNUX.cjs +45 -0
  63. package/dist/cjs/chunk-WQIUHNUX.cjs.map +1 -0
  64. package/dist/cjs/chunk-ZWJ6IAP2.cjs +89 -0
  65. package/dist/cjs/chunk-ZWJ6IAP2.cjs.map +1 -0
  66. package/dist/cjs/{chunk-4Z4HSVCQ.cjs → chunk-ZZP6LQ5R.cjs} +4 -5
  67. package/dist/cjs/chunk-ZZP6LQ5R.cjs.map +1 -0
  68. package/dist/cjs/config/agent.cjs +9 -0
  69. package/dist/cjs/config/agent.cjs.map +1 -0
  70. package/dist/cjs/config/modules.cjs +19 -0
  71. package/dist/cjs/config/modules.cjs.map +1 -0
  72. package/dist/cjs/config/options.cjs +11 -0
  73. package/dist/cjs/config/options.cjs.map +1 -0
  74. package/dist/cjs/container/controllers.cjs +16 -0
  75. package/dist/cjs/container/controllers.cjs.map +1 -0
  76. package/dist/cjs/container/index.cjs +40 -0
  77. package/dist/cjs/container/index.cjs.map +1 -0
  78. package/dist/cjs/container/services.cjs +25 -0
  79. package/dist/cjs/container/services.cjs.map +1 -0
  80. package/dist/cjs/controllers/api/agent.api.controller.cjs +2 -2
  81. package/dist/cjs/controllers/api/threads.api.controller.cjs +2 -2
  82. package/dist/cjs/controllers/api/workflow.api.controller.cjs +7 -0
  83. package/dist/cjs/controllers/api/workflow.api.controller.cjs.map +1 -0
  84. package/dist/cjs/controllers/index.cjs +7 -8
  85. package/dist/cjs/controllers/index.cjs.map +1 -1
  86. package/dist/cjs/controllers/query.controller.cjs +3 -4
  87. package/dist/cjs/controllers/query.controller.cjs.map +1 -1
  88. package/dist/cjs/index.cjs +74 -50
  89. package/dist/cjs/index.cjs.map +1 -1
  90. package/dist/cjs/middlewares/auth.middleware.cjs +3 -3
  91. package/dist/cjs/modules/a2a/a2a.module.cjs +1 -1
  92. package/dist/cjs/modules/auth/auth.module.cjs +7 -0
  93. package/dist/cjs/modules/auth/auth.module.cjs.map +1 -0
  94. package/dist/cjs/modules/index.cjs +9 -9
  95. package/dist/cjs/modules/index.cjs.map +1 -1
  96. package/dist/cjs/modules/memory/memory.module.cjs +2 -2
  97. package/dist/cjs/routes/a2a.routes.cjs +29 -11
  98. package/dist/cjs/routes/a2a.routes.cjs.map +1 -1
  99. package/dist/cjs/routes/api/agent.routes.cjs +30 -3
  100. package/dist/cjs/routes/api/agent.routes.cjs.map +1 -1
  101. package/dist/cjs/routes/api/intent.routes.cjs +29 -3
  102. package/dist/cjs/routes/api/intent.routes.cjs.map +1 -1
  103. package/dist/cjs/routes/api/model.routes.cjs +29 -2
  104. package/dist/cjs/routes/api/model.routes.cjs.map +1 -1
  105. package/dist/cjs/routes/api/threads.routes.cjs +30 -4
  106. package/dist/cjs/routes/api/threads.routes.cjs.map +1 -1
  107. package/dist/cjs/routes/api/workflow.routes.cjs +35 -0
  108. package/dist/cjs/routes/api/workflow.routes.cjs.map +1 -0
  109. package/dist/cjs/routes/api.routes.cjs +33 -9
  110. package/dist/cjs/routes/api.routes.cjs.map +1 -1
  111. package/dist/cjs/routes/index.cjs +36 -24
  112. package/dist/cjs/routes/index.cjs.map +1 -1
  113. package/dist/cjs/routes/intent.routes.cjs +27 -15
  114. package/dist/cjs/routes/intent.routes.cjs.map +1 -1
  115. package/dist/cjs/routes/query.routes.cjs +27 -12
  116. package/dist/cjs/routes/query.routes.cjs.map +1 -1
  117. package/dist/cjs/services/a2a.service.cjs +2 -2
  118. package/dist/cjs/services/index.cjs +14 -19
  119. package/dist/cjs/services/index.cjs.map +1 -1
  120. package/dist/cjs/services/intents/aggregate.service.cjs +10 -0
  121. package/dist/cjs/services/intents/aggregate.service.cjs.map +1 -0
  122. package/dist/cjs/services/intents/fulfill.service.cjs +6 -3
  123. package/dist/cjs/services/intents/fulfill.service.cjs.map +1 -1
  124. package/dist/cjs/services/intents/multi-trigger.service.cjs +8 -0
  125. package/dist/cjs/services/intents/multi-trigger.service.cjs.map +1 -0
  126. package/dist/cjs/services/intents/single-trigger.service.cjs +8 -0
  127. package/dist/cjs/services/intents/single-trigger.service.cjs.map +1 -0
  128. package/dist/cjs/services/intents/trigger.service.cjs +4 -2
  129. package/dist/cjs/services/intents/trigger.service.cjs.map +1 -1
  130. package/dist/cjs/services/query.service.cjs +4 -8
  131. package/dist/cjs/services/query.service.cjs.map +1 -1
  132. package/dist/cjs/services/thread.service.cjs +2 -2
  133. package/dist/cjs/services/utils/aggregate.common.cjs +9 -0
  134. package/dist/cjs/services/utils/aggregate.common.cjs.map +1 -0
  135. package/dist/cjs/types/agent.cjs +2 -2
  136. package/dist/cjs/types/memory.cjs +2 -2
  137. package/dist/esm/{chunk-275JHD5P.js → chunk-2VGXYWJD.js} +5 -5
  138. package/dist/esm/chunk-2VGXYWJD.js.map +1 -0
  139. package/dist/esm/{chunk-A5PRJ33H.js → chunk-44CTGJX4.js} +116 -32
  140. package/dist/esm/chunk-44CTGJX4.js.map +1 -0
  141. package/dist/esm/{chunk-GRN6CHNO.js → chunk-4BHU7SPZ.js} +1 -1
  142. package/dist/esm/{chunk-GRN6CHNO.js.map → chunk-4BHU7SPZ.js.map} +1 -1
  143. package/dist/esm/{chunk-SPRW6KUR.js → chunk-6YBQCUNB.js} +12 -8
  144. package/dist/esm/chunk-6YBQCUNB.js.map +1 -0
  145. package/dist/esm/chunk-7DH4SI44.js +89 -0
  146. package/dist/esm/chunk-7DH4SI44.js.map +1 -0
  147. package/dist/esm/{chunk-OUIXXZFI.js → chunk-7GV6DSPE.js} +4 -1
  148. package/dist/esm/chunk-7GV6DSPE.js.map +1 -0
  149. package/dist/esm/chunk-7XQPJVYO.js +62 -0
  150. package/dist/esm/chunk-7XQPJVYO.js.map +1 -0
  151. package/dist/esm/{chunk-6AN7Z5OC.js → chunk-AEBBZSQ4.js} +10 -17
  152. package/dist/esm/chunk-AEBBZSQ4.js.map +1 -0
  153. package/dist/esm/chunk-BS52JTBH.js +8 -0
  154. package/dist/esm/chunk-BS52JTBH.js.map +1 -0
  155. package/dist/esm/chunk-BZUWX7HX.js +68 -0
  156. package/dist/esm/chunk-BZUWX7HX.js.map +1 -0
  157. package/dist/esm/{chunk-WUNZG3WP.js → chunk-C5JXXLCW.js} +1 -1
  158. package/dist/esm/chunk-C5JXXLCW.js.map +1 -0
  159. package/dist/esm/chunk-CC6DWPHZ.js +95 -0
  160. package/dist/esm/chunk-CC6DWPHZ.js.map +1 -0
  161. package/dist/esm/chunk-CG35V3ZH.js +21 -0
  162. package/dist/esm/chunk-CG35V3ZH.js.map +1 -0
  163. package/dist/esm/{chunk-JHKBIDPX.js → chunk-D6STNZ2L.js} +30 -25
  164. package/dist/esm/chunk-D6STNZ2L.js.map +1 -0
  165. package/dist/esm/chunk-FCH7BUK4.js +17 -0
  166. package/dist/esm/chunk-FCH7BUK4.js.map +1 -0
  167. package/dist/esm/chunk-I4P7JMJC.js +104 -0
  168. package/dist/esm/chunk-I4P7JMJC.js.map +1 -0
  169. package/dist/esm/chunk-IG3B5AXN.js +74 -0
  170. package/dist/esm/chunk-IG3B5AXN.js.map +1 -0
  171. package/dist/esm/{chunk-JCXAHLRN.js → chunk-JXGQVFCO.js} +20 -30
  172. package/dist/esm/chunk-JXGQVFCO.js.map +1 -0
  173. package/dist/esm/chunk-LMOWEXWF.js +38 -0
  174. package/dist/esm/chunk-LMOWEXWF.js.map +1 -0
  175. package/dist/esm/chunk-O3MPFL5J.js +47 -0
  176. package/dist/esm/chunk-O3MPFL5J.js.map +1 -0
  177. package/dist/esm/chunk-PZQRSWST.js +18 -0
  178. package/dist/esm/chunk-PZQRSWST.js.map +1 -0
  179. package/dist/esm/{chunk-KOCOM7IC.js → chunk-QQZ5ANSD.js} +8 -7
  180. package/dist/esm/chunk-QQZ5ANSD.js.map +1 -0
  181. package/dist/esm/chunk-TQJCYP7X.js +170 -0
  182. package/dist/esm/chunk-TQJCYP7X.js.map +1 -0
  183. package/dist/esm/{chunk-WZQVH4XY.js → chunk-V23GKNNJ.js} +7 -7
  184. package/dist/esm/chunk-V23GKNNJ.js.map +1 -0
  185. package/dist/esm/chunk-VBK4WM2M.js +17 -0
  186. package/dist/esm/chunk-VBK4WM2M.js.map +1 -0
  187. package/dist/esm/{chunk-F3SGL62A.js → chunk-VP5Q63JU.js} +12 -8
  188. package/dist/esm/chunk-VP5Q63JU.js.map +1 -0
  189. package/dist/esm/chunk-VSQVYW2H.js +37 -0
  190. package/dist/esm/chunk-VSQVYW2H.js.map +1 -0
  191. package/dist/esm/{chunk-TUEEIIR3.js → chunk-WKFSYGMH.js} +5 -6
  192. package/dist/esm/chunk-WKFSYGMH.js.map +1 -0
  193. package/dist/esm/{chunk-OTBWAUJF.js → chunk-YDER5JOU.js} +5 -2
  194. package/dist/esm/chunk-YDER5JOU.js.map +1 -0
  195. package/dist/esm/{chunk-4LBR3TIJ.js → chunk-ZJVWC666.js} +6 -6
  196. package/dist/esm/chunk-ZJVWC666.js.map +1 -0
  197. package/dist/esm/{chunk-AMRKK46V.js → chunk-ZK3HZBER.js} +5 -5
  198. package/dist/esm/chunk-ZK3HZBER.js.map +1 -0
  199. package/dist/esm/chunk-ZNZZZ4NN.js +45 -0
  200. package/dist/esm/chunk-ZNZZZ4NN.js.map +1 -0
  201. package/dist/esm/{chunk-RL6SRSSK.js → chunk-ZVYC5Y6Z.js} +1 -1
  202. package/dist/esm/chunk-ZVYC5Y6Z.js.map +1 -0
  203. package/dist/esm/config/agent.d.ts +25 -0
  204. package/dist/esm/config/agent.js +9 -0
  205. package/dist/esm/config/manifest.d.ts +3 -0
  206. package/dist/esm/config/modules.d.ts +34 -0
  207. package/dist/esm/config/modules.js +19 -0
  208. package/dist/esm/config/options.d.ts +14 -0
  209. package/dist/esm/config/options.js +11 -0
  210. package/dist/esm/container/controllers.d.ts +57 -0
  211. package/dist/esm/container/controllers.js +16 -0
  212. package/dist/esm/container/index.d.ts +68 -0
  213. package/dist/esm/container/index.js +40 -0
  214. package/dist/esm/container/index.js.map +1 -0
  215. package/dist/esm/container/services.d.ts +42 -0
  216. package/dist/esm/container/services.js +25 -0
  217. package/dist/esm/container/services.js.map +1 -0
  218. package/dist/esm/controllers/a2a.controller.d.ts +11 -7
  219. package/dist/esm/controllers/api/agent.api.controller.d.ts +3 -17
  220. package/dist/esm/controllers/api/agent.api.controller.js +1 -1
  221. package/dist/esm/controllers/api/threads.api.controller.js +1 -1
  222. package/dist/esm/controllers/api/workflow.api.controller.d.ts +16 -0
  223. package/dist/esm/controllers/api/workflow.api.controller.js +7 -0
  224. package/dist/esm/controllers/api/workflow.api.controller.js.map +1 -0
  225. package/dist/esm/controllers/index.d.ts +9 -11
  226. package/dist/esm/controllers/index.js +7 -8
  227. package/dist/esm/controllers/query.controller.d.ts +13 -11
  228. package/dist/esm/controllers/query.controller.js +2 -3
  229. package/dist/esm/index.d.ts +16 -10
  230. package/dist/esm/index.js +77 -53
  231. package/dist/esm/index.js.map +1 -1
  232. package/dist/esm/middlewares/auth.middleware.d.ts +2 -2
  233. package/dist/esm/middlewares/auth.middleware.js +2 -2
  234. package/dist/esm/middlewares/error.middleware.d.ts +3 -0
  235. package/dist/esm/modules/a2a/a2a.module.js +1 -1
  236. package/dist/esm/modules/auth/{base.auth.d.ts → auth.module.d.ts} +2 -2
  237. package/dist/esm/modules/auth/auth.module.js +7 -0
  238. package/dist/esm/modules/auth/auth.module.js.map +1 -0
  239. package/dist/esm/modules/index.d.ts +2 -2
  240. package/dist/esm/modules/index.js +9 -9
  241. package/dist/esm/modules/memory/base.memory.d.ts +13 -2
  242. package/dist/esm/modules/memory/memory.module.d.ts +2 -1
  243. package/dist/esm/modules/memory/memory.module.js +1 -1
  244. package/dist/esm/routes/a2a.routes.d.ts +1 -22
  245. package/dist/esm/routes/a2a.routes.js +28 -10
  246. package/dist/esm/routes/api/agent.routes.d.ts +1 -20
  247. package/dist/esm/routes/api/agent.routes.js +29 -2
  248. package/dist/esm/routes/api/intent.routes.d.ts +1 -4
  249. package/dist/esm/routes/api/intent.routes.js +28 -2
  250. package/dist/esm/routes/api/model.routes.d.ts +1 -6
  251. package/dist/esm/routes/api/model.routes.js +28 -1
  252. package/dist/esm/routes/api/threads.routes.d.ts +1 -4
  253. package/dist/esm/routes/api/threads.routes.js +29 -3
  254. package/dist/esm/routes/api/workflow.routes.d.ts +5 -0
  255. package/dist/esm/routes/api/workflow.routes.js +35 -0
  256. package/dist/esm/routes/api/workflow.routes.js.map +1 -0
  257. package/dist/esm/routes/api.routes.d.ts +1 -20
  258. package/dist/esm/routes/api.routes.js +32 -8
  259. package/dist/esm/routes/index.d.ts +0 -19
  260. package/dist/esm/routes/index.js +39 -27
  261. package/dist/esm/routes/intent.routes.d.ts +1 -20
  262. package/dist/esm/routes/intent.routes.js +26 -14
  263. package/dist/esm/routes/query.routes.d.ts +1 -20
  264. package/dist/esm/routes/query.routes.js +26 -11
  265. package/dist/esm/services/a2a.service.d.ts +14 -10
  266. package/dist/esm/services/a2a.service.js +1 -1
  267. package/dist/esm/services/index.d.ts +9 -9
  268. package/dist/esm/services/index.js +16 -21
  269. package/dist/esm/services/intents/aggregate.service.d.ts +41 -0
  270. package/dist/esm/services/intents/aggregate.service.js +10 -0
  271. package/dist/esm/services/intents/aggregate.service.js.map +1 -0
  272. package/dist/esm/services/intents/fulfill.service.d.ts +23 -7
  273. package/dist/esm/services/intents/fulfill.service.js +5 -2
  274. package/dist/esm/services/intents/multi-trigger.service.d.ts +27 -0
  275. package/dist/esm/services/intents/multi-trigger.service.js +8 -0
  276. package/dist/esm/services/intents/multi-trigger.service.js.map +1 -0
  277. package/dist/esm/services/intents/single-trigger.service.d.ts +28 -0
  278. package/dist/esm/services/intents/single-trigger.service.js +8 -0
  279. package/dist/esm/services/intents/single-trigger.service.js.map +1 -0
  280. package/dist/esm/services/intents/trigger.service.d.ts +9 -4
  281. package/dist/esm/services/intents/trigger.service.js +3 -1
  282. package/dist/esm/services/query.service.d.ts +21 -15
  283. package/dist/esm/services/query.service.js +3 -7
  284. package/dist/esm/services/thread.service.d.ts +2 -2
  285. package/dist/esm/services/thread.service.js +1 -1
  286. package/dist/esm/services/utils/aggregate.common.d.ts +10 -0
  287. package/dist/esm/services/utils/aggregate.common.js +9 -0
  288. package/dist/esm/services/utils/aggregate.common.js.map +1 -0
  289. package/dist/esm/types/agent.d.ts +9 -1
  290. package/dist/esm/types/agent.js +1 -1
  291. package/dist/esm/types/memory.d.ts +23 -1
  292. package/dist/esm/types/memory.js +1 -1
  293. package/dist/esm/types/stream.d.ts +11 -0
  294. package/package.json +1 -1
  295. package/dist/cjs/chunk-2P3ZBNVN.cjs +0 -45
  296. package/dist/cjs/chunk-2P3ZBNVN.cjs.map +0 -1
  297. package/dist/cjs/chunk-3RS6NVSN.cjs +0 -41
  298. package/dist/cjs/chunk-3RS6NVSN.cjs.map +0 -1
  299. package/dist/cjs/chunk-4Z4HSVCQ.cjs.map +0 -1
  300. package/dist/cjs/chunk-5FZ7QLJD.cjs.map +0 -1
  301. package/dist/cjs/chunk-5QSLQX4H.cjs.map +0 -1
  302. package/dist/cjs/chunk-6T2YGFSD.cjs +0 -28
  303. package/dist/cjs/chunk-6T2YGFSD.cjs.map +0 -1
  304. package/dist/cjs/chunk-7KXB6FOT.cjs +0 -112
  305. package/dist/cjs/chunk-7KXB6FOT.cjs.map +0 -1
  306. package/dist/cjs/chunk-AHNKY3JY.cjs +0 -30
  307. package/dist/cjs/chunk-AHNKY3JY.cjs.map +0 -1
  308. package/dist/cjs/chunk-DGXLVGIM.cjs +0 -36
  309. package/dist/cjs/chunk-DGXLVGIM.cjs.map +0 -1
  310. package/dist/cjs/chunk-E3PD4Q76.cjs +0 -41
  311. package/dist/cjs/chunk-E3PD4Q76.cjs.map +0 -1
  312. package/dist/cjs/chunk-EA3YMPST.cjs.map +0 -1
  313. package/dist/cjs/chunk-FJ2JWXSL.cjs.map +0 -1
  314. package/dist/cjs/chunk-HF2QUMQV.cjs +0 -30
  315. package/dist/cjs/chunk-HF2QUMQV.cjs.map +0 -1
  316. package/dist/cjs/chunk-HF7GKQ6Y.cjs +0 -105
  317. package/dist/cjs/chunk-HF7GKQ6Y.cjs.map +0 -1
  318. package/dist/cjs/chunk-MT722JJC.cjs +0 -1
  319. package/dist/cjs/chunk-MT722JJC.cjs.map +0 -1
  320. package/dist/cjs/chunk-NEWJ7PXH.cjs.map +0 -1
  321. package/dist/cjs/chunk-NNYPZA6W.cjs.map +0 -1
  322. package/dist/cjs/chunk-OZPPTVUA.cjs.map +0 -1
  323. package/dist/cjs/chunk-QCYLIOXZ.cjs.map +0 -1
  324. package/dist/cjs/chunk-RCOESZIX.cjs.map +0 -1
  325. package/dist/cjs/chunk-RVT67VJL.cjs +0 -105
  326. package/dist/cjs/chunk-RVT67VJL.cjs.map +0 -1
  327. package/dist/cjs/chunk-TZ6JOGWV.cjs.map +0 -1
  328. package/dist/cjs/chunk-U47SG7XG.cjs +0 -168
  329. package/dist/cjs/chunk-U47SG7XG.cjs.map +0 -1
  330. package/dist/cjs/chunk-X46GJS7X.cjs.map +0 -1
  331. package/dist/cjs/chunk-XEAJBA3S.cjs +0 -30
  332. package/dist/cjs/chunk-XEAJBA3S.cjs.map +0 -1
  333. package/dist/cjs/chunk-XQTVE64W.cjs +0 -8
  334. package/dist/cjs/chunk-XQTVE64W.cjs.map +0 -1
  335. package/dist/cjs/chunk-YCTPMLZO.cjs.map +0 -1
  336. package/dist/cjs/chunk-YY7HSXBP.cjs +0 -36
  337. package/dist/cjs/chunk-YY7HSXBP.cjs.map +0 -1
  338. package/dist/cjs/chunk-Z6TQ7TFO.cjs.map +0 -1
  339. package/dist/cjs/modules/auth/base.auth.cjs +0 -7
  340. package/dist/cjs/modules/auth/base.auth.cjs.map +0 -1
  341. package/dist/cjs/services/intents/fulfill-stream.service.cjs +0 -12
  342. package/dist/cjs/services/intents/fulfill-stream.service.cjs.map +0 -1
  343. package/dist/cjs/services/query-stream.service.cjs +0 -16
  344. package/dist/cjs/services/query-stream.service.cjs.map +0 -1
  345. package/dist/esm/chunk-275JHD5P.js.map +0 -1
  346. package/dist/esm/chunk-4LBR3TIJ.js.map +0 -1
  347. package/dist/esm/chunk-6AN7Z5OC.js.map +0 -1
  348. package/dist/esm/chunk-A5PRJ33H.js.map +0 -1
  349. package/dist/esm/chunk-AMRKK46V.js.map +0 -1
  350. package/dist/esm/chunk-F3SGL62A.js.map +0 -1
  351. package/dist/esm/chunk-FF5RJ4L2.js +0 -8
  352. package/dist/esm/chunk-FF5RJ4L2.js.map +0 -1
  353. package/dist/esm/chunk-JCXAHLRN.js.map +0 -1
  354. package/dist/esm/chunk-JHKBIDPX.js.map +0 -1
  355. package/dist/esm/chunk-KOCOM7IC.js.map +0 -1
  356. package/dist/esm/chunk-OTBWAUJF.js.map +0 -1
  357. package/dist/esm/chunk-OUIXXZFI.js.map +0 -1
  358. package/dist/esm/chunk-Q7NLA5X4.js +0 -30
  359. package/dist/esm/chunk-Q7NLA5X4.js.map +0 -1
  360. package/dist/esm/chunk-RL6SRSSK.js.map +0 -1
  361. package/dist/esm/chunk-SPRW6KUR.js.map +0 -1
  362. package/dist/esm/chunk-TUEEIIR3.js.map +0 -1
  363. package/dist/esm/chunk-U7REZSMO.js +0 -1
  364. package/dist/esm/chunk-UEUZ7G5P.js +0 -168
  365. package/dist/esm/chunk-UEUZ7G5P.js.map +0 -1
  366. package/dist/esm/chunk-WO2QJ6UM.js +0 -28
  367. package/dist/esm/chunk-WO2QJ6UM.js.map +0 -1
  368. package/dist/esm/chunk-WUNZG3WP.js.map +0 -1
  369. package/dist/esm/chunk-WZQVH4XY.js.map +0 -1
  370. package/dist/esm/chunk-Y7BKUWRJ.js +0 -105
  371. package/dist/esm/chunk-Y7BKUWRJ.js.map +0 -1
  372. package/dist/esm/chunk-YJTWW6QK.js +0 -41
  373. package/dist/esm/chunk-YJTWW6QK.js.map +0 -1
  374. package/dist/esm/modules/auth/base.auth.js +0 -7
  375. package/dist/esm/services/intents/fulfill-stream.service.d.ts +0 -50
  376. package/dist/esm/services/intents/fulfill-stream.service.js +0 -12
  377. package/dist/esm/services/query-stream.service.d.ts +0 -54
  378. package/dist/esm/services/query-stream.service.js +0 -16
  379. /package/dist/esm/{chunk-U7REZSMO.js.map → config/agent.js.map} +0 -0
  380. /package/dist/esm/{modules/auth/base.auth.js.map → config/modules.js.map} +0 -0
  381. /package/dist/esm/{services/intents/fulfill-stream.service.js.map → config/options.js.map} +0 -0
  382. /package/dist/esm/{services/query-stream.service.js.map → container/controllers.js.map} +0 -0
@@ -1 +0,0 @@
1
- {"version":3,"sources":["/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-HF7GKQ6Y.cjs","../../src/services/query.service.ts"],"names":[],"mappings":"AAAA;AACE;AACF,wDAA6B;AAC7B;AACE;AACF,wDAA6B;AAC7B;AACE;AACF,wDAA6B;AAC7B;AACE;AACF,wDAA6B;AAC7B;AACE;AACF,wDAA6B;AAC7B;AACA;AChBA,gCAA2B;AAC3B,oDAA4B;AA4BrB,IAAM,aAAA,EAAN,MAAmB;AAAA,EACjB;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EAER,WAAA,CACC,WAAA,EACA,SAAA,EACA,SAAA,EACA,YAAA,EACC;AACD,IAAA,IAAA,CAAK,YAAA,EAAc,WAAA;AACnB,IAAA,IAAA,CAAK,aAAA,EAAe,YAAA;AACpB,IAAA,IAAA,CAAK,qBAAA,EAAuB,IAAI,2CAAA;AAAA,MAC/B,WAAA;AAAA,MACA;AAAA,IACD,CAAA;AACA,IAAA,IAAA,CAAK,qBAAA,EAAuB,IAAI,2CAAA;AAAA,MAC/B,WAAA;AAAA,MACA,SAAA;AAAA,MACA,SAAA;AAAA,MACA;AAAA,IACD,CAAA;AAAA,EACD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAkBA,MAAa,WAAA,CACZ,cAAA,EAMA,KAAA,EACA,KAAA,EACC;AACD,IAAA,MAAM,EAAE,IAAA,EAAM,MAAA,EAAQ,QAAQ,EAAA,EAAI,cAAA;AAClC,IAAA,MAAM,aAAA,kBAAe,IAAA,mBAAK,YAAA,6BAAc,eAAA,mBAAgB,GAAA;AAGxD,IAAA,IAAI,SAAA,EAAW,cAAA,CAAe,QAAA;AAC9B,IAAA,IAAI,MAAA;AACJ,IAAA,GAAA,CAAI,QAAA,EAAU;AACb,MAAA,OAAA,EAAS,sBAAM,YAAA,6BAAc,SAAA,mBAAU,MAAA,EAAQ,QAAQ,GAAA;AACvD,MAAA,GAAA,CAAI,CAAC,OAAA,GAAU,CAAC,KAAA,EAAO;AACtB,QAAA,MAAM,IAAI,mCAAA,CAAa,4BAAA,CAAY,SAAA,EAAW,kBAAkB,CAAA;AAAA,MACjE;AAAA,IACD;AAEA,IAAA,SAAA,IAAa,gCAAA,CAAW;AACxB,IAAA,GAAA,CAAI,CAAC,MAAA,EAAQ;AACZ,MAAA,MAAM,MAAA,EAAQ,MAAM,6CAAA,IAAc,CAAK,WAAA,EAAa,KAAA,EAAO,OAAO,CAAA;AAClE,MAAA,MAAM,SAAA,EAA4B,sBAAM,YAAA,6BAAc,YAAA;AAAA,QACrD,IAAA;AAAA,QACA,MAAA;AAAA,QACA,QAAA;AAAA,QACA;AAAA,MACD,IAAA,GAAM,EAAE,IAAA,EAAM,MAAA,EAAQ,QAAA,EAAU,MAAM,CAAA;AACtC,MAAA,OAAA,EAAS,EAAE,GAAG,QAAA,EAAU,QAAA,EAAU,CAAC,EAAE,CAAA;AACrC,MAAA,yBAAA,CAAQ,MAAA,CAAO,IAAA,CAAK,CAAA,mBAAA,EAAsB,QAAQ,CAAA,CAAA;AACnD,IAAA;AAIY,IAAA;AACgC,IAAA;AAGI,IAAA;AAC/C,MAAA;AACuB,QAAA;AACtB,QAAA;AACoB,QAAA;AACoB,QAAA;AAC9B,QAAA;AAEc,UAAA;AAEF,YAAA;AACF,YAAA;AAChB,UAAA;AACJ,QAAA;AACD,MAAA;AACA,IAAA;AAG8C,IAAA;AAC9C,MAAA;AACA,MAAA;AACD,IAAA;AAEyB,IAAA;AAC1B,EAAA;AACD;ADtCyD;AACA;AACA;AACA","file":"/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-HF7GKQ6Y.cjs","sourcesContent":[null,"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\tMessageRole,\n\ttype ThreadMetadata,\n\ttype ThreadObject,\n\ttype ThreadType,\n\ttype TriggeredIntent,\n} from \"@/types/memory.js\";\nimport { loggers } from \"@/utils/logger.js\";\nimport { IntentFulfillService } from \"./intents/fulfill.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 QueryService {\n\tprivate modelModule: ModelModule;\n\tprivate memoryModule?: MemoryModule;\n\tprivate intentTriggerService: IntentTriggerService;\n\tprivate intentFulfillService: IntentFulfillService;\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.intentFulfillService = new IntentFulfillService(\n\t\t\tmodelModule,\n\t\t\ta2aModule,\n\t\t\tmcpModule,\n\t\t\tmemoryModule,\n\t\t);\n\t}\n\n\t/**\n\t * Main entry point for processing 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 AI response\n\t * 4. Updates conversation history\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 Promise resolving to object with content property containing the response\n\t */\n\tpublic async handleQuery(\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) {\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}\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 threadMemory?.addMessagesToThread(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 result = await this.intentFulfillService.intentFulfill(\n\t\t\ttriggeredIntent,\n\t\t\tthread,\n\t\t);\n\n\t\treturn { content: result };\n\t}\n}\n"]}
@@ -1 +0,0 @@
1
- "use strict";//# sourceMappingURL=chunk-MT722JJC.cjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-MT722JJC.cjs"],"names":[],"mappings":"AAAA","file":"/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-MT722JJC.cjs"}
@@ -1 +0,0 @@
1
- {"version":3,"sources":["/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-NEWJ7PXH.cjs","../../src/services/intents/trigger.service.ts"],"names":[],"mappings":"AAAA;AACE;AACF,wDAA6B;AAC7B;AACA;ACIO,IAAM,qBAAA,EAAN,MAA2B;AAAA,EACzB;AAAA,EACA;AAAA,EAER,WAAA,CAAY,WAAA,EAA0B,YAAA,EAA6B;AAClE,IAAA,IAAA,CAAK,YAAA,EAAc,WAAA;AACnB,IAAA,IAAA,CAAK,aAAA,EAAe,YAAA;AAAA,EACrB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASA,MAAa,gBAAA,CACZ,KAAA,EACA,MAAA,EACkC;AAClC,IAAA,MAAM,cAAA,EAAgB,IAAA,CAAK,WAAA,CAAY,QAAA,CAAS,CAAA;AAChD,IAAA,MAAM,aAAA,EAAe,IAAA,CAAK,WAAA,CAAY,eAAA,CAAgB,CAAA;AACtD,IAAA,MAAM,aAAA,kBAAe,IAAA,mBAAK,YAAA,6BAAc,eAAA,mBAAgB,GAAA;AACxD,IAAA,GAAA,CAAI,CAAC,YAAA,EAAc;AAClB,MAAA,OAAO,CAAC,EAAE,QAAA,EAAU,MAAM,CAAC,CAAA;AAAA,IAC5B;AAGA,IAAA,MAAM,QAAA,EAAU,MAAM,YAAA,CAAa,WAAA,CAAY,CAAA;AAE/C,IAAA,GAAA,CAAI,OAAA,CAAQ,OAAA,IAAW,CAAA,EAAG;AACzB,MAAA,yBAAA,CAAQ,YAAA,CAAa,IAAA,CAAK,iBAAiB,CAAA;AAC3C,MAAA,OAAO,CAAC,EAAE,QAAA,EAAU,MAAM,CAAC,CAAA;AAAA,IAC5B;AAEA,IAAA,MAAM,WAAA,EAAa,OAAA,CACjB,GAAA,CAAI,CAAC,MAAA,EAAA,GAAW,CAAA,EAAA,EAAK,MAAA,CAAO,IAAI,CAAA,EAAA,EAAK,MAAA,CAAO,WAAW,CAAA,CAAA;AAOxB,IAAA;AAMxB,MAAA;AAGoB,MAAA;AAEI,MAAA;AAEpB,IAAA;AAEQ,IAAA;AACmB,SAAA;AAAA;AAAA;AAAA;AAI9B;AAAA;AAAA,yDAAA;AAIU,IAAA;AAG0C;AAAc;AAI9E,CAAA;AAC4B,qBAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,oHAAA;AAmCsB,IAAA;AACxC,MAAA;AACP,MAAA;AACA,IAAA;AAEgE,IAAA;AAC1C,IAAA;AACgC,MAAA;AAC3B,MAAA;AAC5B,IAAA;AAEI,IAAA;AACA,IAAA;AACqC,MAAA;AAChB,IAAA;AACG,MAAA;AAC5B,IAAA;AAEiD,IAAA;AACc,IAAA;AAC1B,MAAA;AACpB,MAAA;AAC4C,QAAA;AAC5D,MAAA;AACyB,MAAA;AAC1B,IAAA;AAEO,IAAA;AACR,EAAA;AACD;ADtCuF;AACA;AACA;AACA","file":"/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-NEWJ7PXH.cjs","sourcesContent":[null,"import type { MemoryModule, ModelModule } from \"@/modules\";\nimport type {\n\tMessageObject,\n\tThreadObject,\n\tTriggeredIntent,\n} from \"@/types/memory\";\nimport { loggers } from \"@/utils/logger\";\n\nexport class IntentTriggerService {\n\tprivate modelModule: ModelModule;\n\tprivate memoryModule?: MemoryModule;\n\n\tconstructor(modelModule: ModelModule, memoryModule?: MemoryModule) {\n\t\tthis.modelModule = modelModule;\n\t\tthis.memoryModule = memoryModule;\n\t}\n\n\t/**\n\t * Detects the intent from context.\n\t *\n\t * @param query - The user's input query\n\t * @param thread - The thread history\n\t * @returns The detected intent\n\t */\n\tpublic async intentTriggering(\n\t\tquery: string,\n\t\tthread: ThreadObject | undefined,\n\t): Promise<Array<TriggeredIntent>> {\n\t\tconst modelInstance = this.modelModule.getModel();\n\t\tconst modelOptions = this.modelModule.getModelOptions();\n\t\tconst intentMemory = this.memoryModule?.getIntentMemory();\n\t\tif (!intentMemory) {\n\t\t\treturn [{ subquery: query }];\n\t\t}\n\n\t\t// 인텐트 목록 가져오기\n\t\tconst intents = await intentMemory.listIntents();\n\n\t\tif (intents.length === 0) {\n\t\t\tloggers.intentStream.warn(\"No intent found\");\n\t\t\treturn [{ subquery: query }];\n\t\t}\n\n\t\tconst intentList = intents\n\t\t\t.map((intent) => `- ${intent.name}: ${intent.description}`)\n\t\t\t.join(\"\\n\");\n\n\t\t// Convert thread messages to a string\n\t\tconst threadMessages = !thread\n\t\t\t? \"\"\n\t\t\t: thread.messages\n\t\t\t\t\t.sort((a, b) => a.timestamp - b.timestamp)\n\t\t\t\t\t.map((message: MessageObject) => {\n\t\t\t\t\t\tconst role =\n\t\t\t\t\t\t\tmessage.role === \"USER\"\n\t\t\t\t\t\t\t\t? \"User\"\n\t\t\t\t\t\t\t\t: message.role === \"MODEL\"\n\t\t\t\t\t\t\t\t\t? \"Assistant\"\n\t\t\t\t\t\t\t\t\t: \"System\";\n\t\t\t\t\t\tconst content = Array.isArray(message.content.parts)\n\t\t\t\t\t\t\t? message.content.parts.join(\" \")\n\t\t\t\t\t\t\t: String(message.content.parts);\n\t\t\t\t\t\treturn `${role}: \"\"\"${content}\"\"\"`;\n\t\t\t\t\t})\n\t\t\t\t\t.join(\"\\n\");\n\n\t\tconst systemPrompt = `\nToday is ${new Date().toLocaleDateString()}.\nYou are an expert in accurately identifying user intentions.\n\nAvailable intent list:\n${intentList}\n\nPlease select and answer only from the above intent list.`;\n\n\t\tconst userMessage = `\n${\n\tthreadMessages !== \"\"\n\t\t? `The following is the conversation history with the user: ${threadMessages}\n\n\t`\n\t\t: \"\"\n}\nLast user question: \"${query}\"\n\nBased on the above conversation history, analyze the last user question and identify all relevant intents.\n\nInstructions:\n1. First, decompose the last user question into action-based subqueries (each representing a distinct action or task)\n2. Then, map each subquery to its corresponding intent from the available intent list\n3. For each subquery, provide a 2-3 sentence summary of what actions will be performed\n4. Multiple intents can be identified if the question covers various topics or actions\n5. Maintain the logical sequence of the original question when splitting into subqueries\n6. **Important**: If the query cannot be split into multiple subqueries (i.e., it represents a single action or request), treat the entire query as one subquery and still follow the output format\n\nOutput Format:\nYou MUST return the output in the following JSON format. Do not include any other text before or after the JSON:\n[\n {\n \"subquery\": \"<subquery_1>\",\n \"intentName\": \"<intent_name_1>\",\n\t\t\"actionPlan\": \"<2-3 sentence description of what will be done for this subquery>\"\n\t},\n {\n \"subquery\": \"<subquery_2>\",\n \"intentName\": \"<intent_name_2>\",\n\t\t\"actionPlan\": \"<2-3 sentence description of what will be done for this subquery>\"\n },\n ...\n]\n\nRequirements:\n- Each subquery should represent a single, actionable task or request\n- Preserve the original meaning and context when splitting queries\n- Select only from the provided intent list\n- DO NOT set intentName for any subquery that doesn't match available intents.\n- Even if the query is simple and cannot be decomposed, return it as a single-element array with one subquery object`;\n\n\t\tconst messages = modelInstance.generateMessages({\n\t\t\tquery: userMessage,\n\t\t\tsystemPrompt,\n\t\t});\n\n\t\tconst response = await modelInstance.fetch(messages, modelOptions);\n\t\tif (!response.content) {\n\t\t\tloggers.intent.warn(\"Cannot extract intent from query\");\n\t\t\treturn [{ subquery: query }];\n\t\t}\n\n\t\tlet subqueries: any;\n\t\ttry {\n\t\t\tsubqueries = JSON.parse(response.content);\n\t\t} catch (error: unknown) {\n\t\t\treturn [{ subquery: query }];\n\t\t}\n\n\t\tconst triggeredIntent: Array<TriggeredIntent> = [];\n\t\tfor (const { subquery, intentName, actionPlan } of subqueries) {\n\t\t\tconst item = { subquery, actionPlan } as TriggeredIntent;\n\t\t\tif (intentName) {\n\t\t\t\titem.intent = await intentMemory.getIntentByName(intentName);\n\t\t\t}\n\t\t\ttriggeredIntent.push(item);\n\t\t}\n\n\t\treturn triggeredIntent;\n\t}\n}\n"]}
@@ -1 +0,0 @@
1
- {"version":3,"sources":["/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-NNYPZA6W.cjs","../../src/controllers/query.controller.ts"],"names":[],"mappings":"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","file":"/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-NNYPZA6W.cjs","sourcesContent":[null,"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"]}
@@ -1 +0,0 @@
1
- {"version":3,"sources":["/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-OZPPTVUA.cjs","../../src/services/intents/fulfill-stream.service.ts"],"names":[],"mappings":"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","file":"/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-OZPPTVUA.cjs","sourcesContent":[null,"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"]}
@@ -1 +0,0 @@
1
- {"version":3,"sources":["/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-QCYLIOXZ.cjs","../../src/middlewares/auth.middleware.ts"],"names":[],"mappings":"AAAA;AACE;AACF,wDAA6B;AAC7B;AACA;ACHA,oDAA4B;AAKrB,IAAM,eAAA,EAAN,MAAqB;AAAA,EACnB;AAAA,EACR,WAAA,CAAY,IAAA,EAAgB;AAC3B,IAAA,IAAA,CAAK,KAAA,EAAO,IAAA;AAAA,EACb;AAAA,EAEO,UAAA,CAAA,EAA6B;AACnC,IAAA,OAAO,MAAA,CAAO,GAAA,EAAc,GAAA,EAAe,IAAA,EAAA,GAAuB;AACjE,MAAA,IAAI;AACH,QAAA,MAAM,QAAA,EAAwB,MAAM,IAAA,CAAK,IAAA,CAAK,YAAA,CAAa,GAAA,EAAK,GAAG,CAAA;AACnE,QAAA,GAAA,CAAI,OAAA,CAAQ,eAAA,EAAiB;AAC5B,UAAA,GAAA,CAAI,MAAA,CAAO,OAAA,EAAS,OAAA,CAAQ,MAAA;AAC5B,UAAA,IAAA,CAAK,CAAA;AAAA,QACN,EAAA,KAAO;AACN,UAAA,MAAM,MAAA,EAAsB,IAAI,mCAAA;AAAA,YAC/B,4BAAA,CAAY,YAAA;AAAA,YACZ;AAAA,UACD,CAAA;AACA,UAAA,MAAM,KAAA;AAAA,QACP;AAAA,MACD,EAAA,MAAA,CAAS,CAAA,EAAQ;AAChB,QAAA,GAAA,CAAI,CAAC,CAAA,CAAE,MAAA,EAAQ;AACd,UAAA,MAAM,MAAA,EAAsB,IAAI,mCAAA;AAAA,YAC/B,4BAAA,CAAY,qBAAA;AAAA,YACZ,CAAA,sBAAA,EAAyB,IAAA,CAAK,SAAA,CAAU,CAAC,CAAC,CAAA;AAAA,UAAA;AAE3C,UAAA;AAAM,QAAA;AAEP,QAAA;AAAM,MAAA;AACP,IAAA;AACD,EAAA;AAEF;ADAA;AACA;AACA;AACA","file":"/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-QCYLIOXZ.cjs","sourcesContent":[null,"import type { NextFunction, Request, RequestHandler, Response } from \"express\";\nimport { StatusCodes } from \"http-status-codes\";\nimport type { BaseAuth } from \"@/modules/auth/base.auth\";\nimport { AinHttpError } from \"@/types/agent\";\nimport type { AuthResponse } from \"@/types/auth\";\n\nexport class AuthMiddleware {\n\tprivate auth: BaseAuth;\n\tconstructor(auth: BaseAuth) {\n\t\tthis.auth = auth;\n\t}\n\n\tpublic middleware(): RequestHandler {\n\t\treturn async (req: Request, res: Response, next: NextFunction) => {\n\t\t\ttry {\n\t\t\t\tconst authRes: AuthResponse = await this.auth.authenticate(req, res);\n\t\t\t\tif (authRes.isAuthenticated) {\n\t\t\t\t\tres.locals.userId = authRes.userId;\n\t\t\t\t\tnext();\n\t\t\t\t} else {\n\t\t\t\t\tconst error: AinHttpError = new AinHttpError(\n\t\t\t\t\t\tStatusCodes.UNAUTHORIZED,\n\t\t\t\t\t\t\"Unauthorized\",\n\t\t\t\t\t);\n\t\t\t\t\tthrow error;\n\t\t\t\t}\n\t\t\t} catch (e: any) {\n\t\t\t\tif (!e.status) {\n\t\t\t\t\tconst error: AinHttpError = new AinHttpError(\n\t\t\t\t\t\tStatusCodes.INTERNAL_SERVER_ERROR,\n\t\t\t\t\t\t`Authentication error: ${JSON.stringify(e)}`,\n\t\t\t\t\t);\n\t\t\t\t\tthrow error;\n\t\t\t\t}\n\t\t\t\tthrow e;\n\t\t\t}\n\t\t};\n\t}\n}\n"]}
@@ -1 +0,0 @@
1
- {"version":3,"sources":["/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-RCOESZIX.cjs","../../src/services/a2a.service.ts"],"names":[],"mappings":"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","file":"/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-RCOESZIX.cjs","sourcesContent":[null,"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"]}
@@ -1,105 +0,0 @@
1
- "use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _optionalChain(ops) { let lastAccessLHS = undefined; let value = ops[0]; let i = 1; while (i < ops.length) { const op = ops[i]; const fn = ops[i + 1]; i += 2; if ((op === 'optionalAccess' || op === 'optionalCall') && value == null) { return undefined; } if (op === 'access' || op === 'optionalAccess') { lastAccessLHS = value; value = fn(value); } else if (op === 'call' || op === 'optionalCall') { value = fn((...args) => value.call(lastAccessLHS, ...args)); lastAccessLHS = undefined; } } return value; }
2
-
3
- var _chunkU47SG7XGcjs = require('./chunk-U47SG7XG.cjs');
4
-
5
-
6
- var _chunkXHTEJE4Ecjs = require('./chunk-XHTEJE4E.cjs');
7
-
8
-
9
- var _chunkNEWJ7PXHcjs = require('./chunk-NEWJ7PXH.cjs');
10
-
11
-
12
- var _chunkZ6TQ7TFOcjs = require('./chunk-Z6TQ7TFO.cjs');
13
-
14
-
15
- var _chunkCLJ3DWTAcjs = require('./chunk-CLJ3DWTA.cjs');
16
-
17
- // src/services/query.service.ts
18
- var _crypto = require('crypto');
19
- var _httpstatuscodes = require('http-status-codes');
20
- var QueryService = class {
21
-
22
-
23
-
24
-
25
- constructor(modelModule, a2aModule, mcpModule, memoryModule) {
26
- this.modelModule = modelModule;
27
- this.memoryModule = memoryModule;
28
- this.intentTriggerService = new (0, _chunkNEWJ7PXHcjs.IntentTriggerService)(
29
- modelModule,
30
- memoryModule
31
- );
32
- this.intentFulfillService = new (0, _chunkU47SG7XGcjs.IntentFulfillService)(
33
- modelModule,
34
- a2aModule,
35
- mcpModule,
36
- memoryModule
37
- );
38
- }
39
- /**
40
- * Main entry point for processing user queries.
41
- *
42
- * Handles the complete query lifecycle:
43
- * 1. Loads or creates thread from memory
44
- * 2. Detects intent from the query
45
- * 3. Fulfills the intent with AI response
46
- * 4. Updates conversation history
47
- *
48
- * @param threadMetadata - Metadata containing type, userId, and optional threadId
49
- * @param threadMetadata.type - The type of thread (e.g., chat, workflow)
50
- * @param threadMetadata.userId - The user's unique identifier
51
- * @param threadMetadata.threadId - Optional thread identifier
52
- * @param query - The user's input query
53
- * @returns Promise resolving to object with content property containing the response
54
- */
55
- async handleQuery(threadMetadata, query, isA2A) {
56
- const { type, userId, options } = threadMetadata;
57
- const threadMemory = _optionalChain([this, 'access', _ => _.memoryModule, 'optionalAccess', _2 => _2.getThreadMemory, 'call', _3 => _3()]);
58
- let threadId = threadMetadata.threadId;
59
- let thread;
60
- if (threadId) {
61
- thread = await _optionalChain([threadMemory, 'optionalAccess', _4 => _4.getThread, 'call', _5 => _5(userId, threadId)]);
62
- if (!thread && !isA2A) {
63
- throw new (0, _chunkZ6TQ7TFOcjs.AinHttpError)(_httpstatuscodes.StatusCodes.NOT_FOUND, "Thread not found");
64
- }
65
- }
66
- threadId ??= _crypto.randomUUID.call(void 0, );
67
- if (!thread) {
68
- const title = await _chunkXHTEJE4Ecjs.generateTitle.call(void 0, this.modelModule, query, options);
69
- const metadata = await _optionalChain([threadMemory, 'optionalAccess', _6 => _6.createThread, 'call', _7 => _7(
70
- type,
71
- userId,
72
- threadId,
73
- title
74
- )]) || { type, userId, threadId, title };
75
- thread = { ...metadata, messages: [] };
76
- _chunkCLJ3DWTAcjs.loggers.intent.info(`Create new thread: ${threadId}`);
77
- }
78
- const triggeredIntent = await this.intentTriggerService.intentTriggering(query, thread);
79
- _chunkCLJ3DWTAcjs.loggers.intent.debug("Triggered intents", { triggeredIntent });
80
- await _optionalChain([threadMemory, 'optionalAccess', _8 => _8.addMessagesToThread, 'call', _9 => _9(userId, threadId, [
81
- {
82
- messageId: _crypto.randomUUID.call(void 0, ),
83
- role: "USER" /* USER */,
84
- timestamp: Date.now(),
85
- content: { type: "text", parts: [query] },
86
- metadata: {
87
- intents: triggeredIntent.filter((intent) => !!intent.intent).map((intent) => ({
88
- id: _optionalChain([intent, 'access', _10 => _10.intent, 'optionalAccess', _11 => _11.id]),
89
- subquery: intent.subquery
90
- }))
91
- }
92
- }
93
- ])]);
94
- const result = await this.intentFulfillService.intentFulfill(
95
- triggeredIntent,
96
- thread
97
- );
98
- return { content: result };
99
- }
100
- };
101
-
102
-
103
-
104
- exports.QueryService = QueryService;
105
- //# sourceMappingURL=chunk-RVT67VJL.cjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-RVT67VJL.cjs","../../src/services/query.service.ts"],"names":[],"mappings":"AAAA;AACE;AACF,wDAA6B;AAC7B;AACE;AACF,wDAA6B;AAC7B;AACE;AACF,wDAA6B;AAC7B;AACE;AACF,wDAA6B;AAC7B;AACE;AACF,wDAA6B;AAC7B;AACA;AChBA,gCAA2B;AAC3B,oDAA4B;AA4BrB,IAAM,aAAA,EAAN,MAAmB;AAAA,EACjB;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EAER,WAAA,CACC,WAAA,EACA,SAAA,EACA,SAAA,EACA,YAAA,EACC;AACD,IAAA,IAAA,CAAK,YAAA,EAAc,WAAA;AACnB,IAAA,IAAA,CAAK,aAAA,EAAe,YAAA;AACpB,IAAA,IAAA,CAAK,qBAAA,EAAuB,IAAI,2CAAA;AAAA,MAC/B,WAAA;AAAA,MACA;AAAA,IACD,CAAA;AACA,IAAA,IAAA,CAAK,qBAAA,EAAuB,IAAI,2CAAA;AAAA,MAC/B,WAAA;AAAA,MACA,SAAA;AAAA,MACA,SAAA;AAAA,MACA;AAAA,IACD,CAAA;AAAA,EACD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAkBA,MAAa,WAAA,CACZ,cAAA,EAMA,KAAA,EACA,KAAA,EACC;AACD,IAAA,MAAM,EAAE,IAAA,EAAM,MAAA,EAAQ,QAAQ,EAAA,EAAI,cAAA;AAClC,IAAA,MAAM,aAAA,kBAAe,IAAA,mBAAK,YAAA,6BAAc,eAAA,mBAAgB,GAAA;AAGxD,IAAA,IAAI,SAAA,EAAW,cAAA,CAAe,QAAA;AAC9B,IAAA,IAAI,MAAA;AACJ,IAAA,GAAA,CAAI,QAAA,EAAU;AACb,MAAA,OAAA,EAAS,sBAAM,YAAA,6BAAc,SAAA,mBAAU,MAAA,EAAQ,QAAQ,GAAA;AACvD,MAAA,GAAA,CAAI,CAAC,OAAA,GAAU,CAAC,KAAA,EAAO;AACtB,QAAA,MAAM,IAAI,mCAAA,CAAa,4BAAA,CAAY,SAAA,EAAW,kBAAkB,CAAA;AAAA,MACjE;AAAA,IACD;AAEA,IAAA,SAAA,IAAa,gCAAA,CAAW;AACxB,IAAA,GAAA,CAAI,CAAC,MAAA,EAAQ;AACZ,MAAA,MAAM,MAAA,EAAQ,MAAM,6CAAA,IAAc,CAAK,WAAA,EAAa,KAAA,EAAO,OAAO,CAAA;AAClE,MAAA,MAAM,SAAA,EAA4B,sBAAM,YAAA,6BAAc,YAAA;AAAA,QACrD,IAAA;AAAA,QACA,MAAA;AAAA,QACA,QAAA;AAAA,QACA;AAAA,MACD,IAAA,GAAM,EAAE,IAAA,EAAM,MAAA,EAAQ,QAAA,EAAU,MAAM,CAAA;AACtC,MAAA,OAAA,EAAS,EAAE,GAAG,QAAA,EAAU,QAAA,EAAU,CAAC,EAAE,CAAA;AACrC,MAAA,yBAAA,CAAQ,MAAA,CAAO,IAAA,CAAK,CAAA,mBAAA,EAAsB,QAAQ,CAAA,CAAA;AACnD,IAAA;AAIY,IAAA;AACgC,IAAA;AAGI,IAAA;AAC/C,MAAA;AACuB,QAAA;AACtB,QAAA;AACoB,QAAA;AACoB,QAAA;AAC9B,QAAA;AAEc,UAAA;AAEF,YAAA;AACF,YAAA;AAChB,UAAA;AACJ,QAAA;AACD,MAAA;AACA,IAAA;AAG8C,IAAA;AAC9C,MAAA;AACA,MAAA;AACD,IAAA;AAEyB,IAAA;AAC1B,EAAA;AACD;ADtCyD;AACA;AACA;AACA","file":"/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-RVT67VJL.cjs","sourcesContent":[null,"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\tMessageRole,\n\ttype ThreadMetadata,\n\ttype ThreadObject,\n\ttype ThreadType,\n\ttype TriggeredIntent,\n} from \"@/types/memory.js\";\nimport { loggers } from \"@/utils/logger.js\";\nimport { IntentFulfillService } from \"./intents/fulfill.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 QueryService {\n\tprivate modelModule: ModelModule;\n\tprivate memoryModule?: MemoryModule;\n\tprivate intentTriggerService: IntentTriggerService;\n\tprivate intentFulfillService: IntentFulfillService;\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.intentFulfillService = new IntentFulfillService(\n\t\t\tmodelModule,\n\t\t\ta2aModule,\n\t\t\tmcpModule,\n\t\t\tmemoryModule,\n\t\t);\n\t}\n\n\t/**\n\t * Main entry point for processing 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 AI response\n\t * 4. Updates conversation history\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 Promise resolving to object with content property containing the response\n\t */\n\tpublic async handleQuery(\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) {\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}\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 threadMemory?.addMessagesToThread(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 result = await this.intentFulfillService.intentFulfill(\n\t\t\ttriggeredIntent,\n\t\t\tthread,\n\t\t);\n\n\t\treturn { content: result };\n\t}\n}\n"]}
@@ -1 +0,0 @@
1
- {"version":3,"sources":["/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-TZ6JOGWV.cjs","../../src/modules/memory/memory.module.ts"],"names":[],"mappings":"AAAA;ACOO,IAAM,aAAA,EAAN,MAAmB;AAAA,EACjB;AAAA,EAER,WAAA,CAAY,MAAA,EAAiB;AAC5B,IAAA,IAAA,CAAK,OAAA,EAAS,MAAA;AAAA,EACf;AAAA,EAEA,MAAM,UAAA,CAAA,EAA4B;AACjC,IAAA,MAAM,IAAA,CAAK,MAAA,CAAO,OAAA,CAAQ,CAAA;AAAA,EAC3B;AAAA,EAEA,MAAM,QAAA,CAAA,EAA0B;AAC/B,IAAA,GAAA,CAAI,IAAA,CAAK,MAAA,CAAO,WAAA,CAAY,CAAA,EAAG;AAC9B,MAAA,MAAM,IAAA,CAAK,MAAA,CAAO,UAAA,CAAW,CAAA;AAAA,IAC9B;AAAA,EACD;AAAA,EAEO,cAAA,CAAA,EAA+B;AACrC,IAAA,OAAO,IAAA,CAAK,MAAA,CAAO,cAAA,CAAe,CAAA;AAAA,EACnC;AAAA,EAEO,eAAA,CAAA,EAAiC;AACvC,IAAA,OAAO,IAAA,CAAK,MAAA,CAAO,eAAA,CAAgB,CAAA;AAAA,EACpC;AAAA,EAEO,eAAA,CAAA,EAAiC;AACvC,IAAA,OAAO,IAAA,CAAK,MAAA,CAAO,eAAA,CAAgB,CAAA;AAAA,EACpC;AACD,CAAA;ADXA;AACA;AACE;AACF,oCAAC","file":"/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-TZ6JOGWV.cjs","sourcesContent":[null,"import type {\n\tIAgentMemory,\n\tIIntentMemory,\n\tIMemory,\n\tIThreadMemory,\n} from \"./base.memory.js\";\n\nexport class MemoryModule {\n\tprivate memory: IMemory;\n\n\tconstructor(memory: IMemory) {\n\t\tthis.memory = memory;\n\t}\n\n\tasync initialize(): Promise<void> {\n\t\tawait this.memory.connect();\n\t}\n\n\tasync shutdown(): Promise<void> {\n\t\tif (this.memory.isConnected()) {\n\t\t\tawait this.memory.disconnect();\n\t\t}\n\t}\n\n\tpublic getAgentMemory(): IAgentMemory {\n\t\treturn this.memory.getAgentMemory();\n\t}\n\n\tpublic getThreadMemory(): IThreadMemory {\n\t\treturn this.memory.getThreadMemory();\n\t}\n\n\tpublic getIntentMemory(): IIntentMemory {\n\t\treturn this.memory.getIntentMemory();\n\t}\n}\n"]}
@@ -1,168 +0,0 @@
1
- "use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _optionalChain(ops) { let lastAccessLHS = undefined; let value = ops[0]; let i = 1; while (i < ops.length) { const op = ops[i]; const fn = ops[i + 1]; i += 2; if ((op === 'optionalAccess' || op === 'optionalCall') && value == null) { return undefined; } if (op === 'access' || op === 'optionalAccess') { lastAccessLHS = value; value = fn(value); } else if (op === 'call' || op === 'optionalCall') { value = fn((...args) => value.call(lastAccessLHS, ...args)); lastAccessLHS = undefined; } } return value; }
2
-
3
- var _chunk7HBOMBZGcjs = require('./chunk-7HBOMBZG.cjs');
4
-
5
-
6
- var _chunkCLJ3DWTAcjs = require('./chunk-CLJ3DWTA.cjs');
7
-
8
- // src/services/intents/fulfill.service.ts
9
- var _crypto = require('crypto');
10
- var IntentFulfillService = class {
11
-
12
-
13
-
14
-
15
- constructor(modelModule, a2aModule, mcpModule, memoryModule) {
16
- this.modelModule = modelModule;
17
- this.a2aModule = a2aModule;
18
- this.mcpModule = mcpModule;
19
- this.memoryModule = memoryModule;
20
- }
21
- async addToThreadMessages(thread, params) {
22
- try {
23
- const threadMemory = _optionalChain([this, 'access', _ => _.memoryModule, 'optionalAccess', _2 => _2.getThreadMemory, 'call', _3 => _3()]);
24
- const { userId, threadId } = thread;
25
- const newMessage = {
26
- messageId: _crypto.randomUUID.call(void 0, ),
27
- role: params.role,
28
- timestamp: Date.now(),
29
- content: { type: "text", parts: [params.content] },
30
- metadata: params.metadata
31
- };
32
- thread.messages.push(newMessage);
33
- await _optionalChain([threadMemory, 'optionalAccess', _4 => _4.addMessagesToThread, 'call', _5 => _5(userId, threadId, [newMessage])]);
34
- } catch (error) {
35
- _chunkCLJ3DWTAcjs.loggers.intentStream.error("Error adding message to thread", error);
36
- }
37
- }
38
- /**
39
- * Fulfills the detected intent by generating a streaming response.
40
- *
41
- * Manages the complete inference loop including:
42
- * - Loading prompts and conversation history
43
- * - Collecting available tools from modules
44
- * - Executing model inference with tool support
45
- * - Processing tool calls iteratively until completion
46
- * - Streaming results as Server-Sent Events
47
- *
48
- * @param query - The user's input query
49
- * @param threadId - Thread identifier for context
50
- * @param thread - Previous conversation history
51
- * @param intent - Optional detected intent with custom prompt
52
- * @returns AsyncGenerator yielding StreamEvent objects
53
- */
54
- async intentFulfilling(query, thread, intent) {
55
- const agentMemory = _optionalChain([this, 'access', _6 => _6.memoryModule, 'optionalAccess', _7 => _7.getAgentMemory, 'call', _8 => _8()]);
56
- const fulfillPrompt = await _chunk7HBOMBZGcjs.createFulfillPrompt.call(void 0, agentMemory, intent);
57
- const modelInstance = this.modelModule.getModel();
58
- const modelOptions = this.modelModule.getModelOptions();
59
- const messages = modelInstance.generateMessages({
60
- query,
61
- thread,
62
- systemPrompt: fulfillPrompt.trim()
63
- });
64
- _chunkCLJ3DWTAcjs.loggers.intent.debug("Intent fulfillment start", {
65
- threadId: thread.threadId,
66
- messages
67
- });
68
- const tools = [];
69
- this.mcpModule && tools.push(...this.mcpModule.getTools());
70
- this.a2aModule && tools.push(...await this.a2aModule.getTools());
71
- const functions = modelInstance.convertToolsToFunctions(tools);
72
- let finalMessage = "";
73
- while (true) {
74
- const response = await modelInstance.fetchWithContextMessage(
75
- messages,
76
- functions,
77
- modelOptions
78
- );
79
- const { content, toolCalls } = response;
80
- _chunkCLJ3DWTAcjs.loggers.intent.debug("Tool calls", {
81
- threadId: thread.threadId,
82
- content,
83
- toolCalls
84
- });
85
- if (toolCalls) {
86
- for (const toolCall of toolCalls) {
87
- const toolName = toolCall.name;
88
- const selectedTool = tools.filter(
89
- (tool) => tool.toolName === toolName
90
- )[0];
91
- let toolResult = "";
92
- if (this.mcpModule && selectedTool.protocol === "MCP" /* MCP */) {
93
- const toolArgs = toolCall.arguments;
94
- _chunkCLJ3DWTAcjs.loggers.intent.debug("MCP tool call", { toolName, toolArgs });
95
- toolResult = await this.mcpModule.useTool(selectedTool, toolArgs);
96
- } else if (this.a2aModule && selectedTool.protocol === "A2A" /* A2A */) {
97
- const a2aGenerator = this.a2aModule.useTool(
98
- selectedTool,
99
- query,
100
- thread.threadId
101
- );
102
- let result = await a2aGenerator.next();
103
- while (!result.done) {
104
- result = await a2aGenerator.next();
105
- }
106
- toolResult = result.value;
107
- } else {
108
- _chunkCLJ3DWTAcjs.loggers.intent.warn(
109
- `Unrecognized tool type: ${selectedTool.protocol}`
110
- );
111
- continue;
112
- }
113
- _chunkCLJ3DWTAcjs.loggers.intent.debug("Tool Result", {
114
- threadId: thread.threadId,
115
- toolResult
116
- });
117
- modelInstance.appendMessages(messages, toolResult);
118
- }
119
- } else if (content) {
120
- finalMessage = content;
121
- break;
122
- }
123
- }
124
- return finalMessage;
125
- }
126
- /**
127
- * Detects the intent from context.
128
- *
129
- * @param intents - The user's input query
130
- * @param thread - The thread history
131
- * @returns The detected intent
132
- */
133
- async intentFulfill(intents, thread) {
134
- let finalResponseText = "";
135
- for (let i = 0; i < intents.length; i++) {
136
- const { subquery, intent, actionPlan } = intents[i];
137
- _chunkCLJ3DWTAcjs.loggers.intent.info(`Process query: ${subquery}, ${_optionalChain([intent, 'optionalAccess', _9 => _9.name])}`);
138
- _chunkCLJ3DWTAcjs.loggers.intent.info(`Action plan: ${actionPlan}`);
139
- finalResponseText !== "" && thread.messages.push({
140
- messageId: _crypto.randomUUID.call(void 0, ),
141
- role: "MODEL" /* MODEL */,
142
- timestamp: Date.now(),
143
- content: { type: "text", parts: [finalResponseText] },
144
- metadata: { isThinking: true }
145
- });
146
- await this.addToThreadMessages(thread, {
147
- role: "MODEL" /* MODEL */,
148
- content: subquery,
149
- metadata: {
150
- subquery,
151
- isThinking: true,
152
- actionPlan
153
- }
154
- });
155
- finalResponseText = await this.intentFulfilling(subquery, thread, intent);
156
- }
157
- await this.addToThreadMessages(thread, {
158
- role: "MODEL" /* MODEL */,
159
- content: finalResponseText
160
- });
161
- return finalResponseText;
162
- }
163
- };
164
-
165
-
166
-
167
- exports.IntentFulfillService = IntentFulfillService;
168
- //# sourceMappingURL=chunk-U47SG7XG.cjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-U47SG7XG.cjs","../../src/services/intents/fulfill.service.ts"],"names":[],"mappings":"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","file":"/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-U47SG7XG.cjs","sourcesContent":[null,"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"]}
@@ -1 +0,0 @@
1
- {"version":3,"sources":["/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-X46GJS7X.cjs","../../src/routes/api/model.routes.ts"],"names":[],"mappings":"AAAA;AACE;AACF,wDAA6B;AAC7B;AACA;ACJA,kCAAuB;AAIhB,IAAM,qBAAA,EAAuB,CAAC,WAAA,EAAA,GAAqC;AACzE,EAAA,MAAM,OAAA,EAAS,6BAAA,CAAO;AACtB,EAAA,MAAM,mBAAA,EAAqB,IAAI,yCAAA,CAAmB,WAAW,CAAA;AAG7D,EAAA,MAAA,CAAO,GAAA,CAAI,GAAA,EAAK,kBAAA,CAAmB,eAAe,CAAA;AAElD,EAAA,OAAO,MAAA;AACR,CAAA;ADAA;AACA;AACE;AACF,oDAAC","file":"/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-X46GJS7X.cjs","sourcesContent":[null,"import { Router } from \"express\";\nimport { ModelApiController } from \"@/controllers/api/model.api.controller.js\";\nimport type { ModelModule } from \"@/modules/index.js\";\n\nexport const createModelApiRouter = (modelModule: ModelModule): Router => {\n\tconst router = Router();\n\tconst modelApiController = new ModelApiController(modelModule);\n\n\t// APIs (prefix: /api/model)\n\trouter.get(\"/\", modelApiController.handleModelList);\n\n\treturn router;\n};\n"]}
@@ -1,30 +0,0 @@
1
- "use strict";Object.defineProperty(exports, "__esModule", {value: true});
2
-
3
- var _chunkX46GJS7Xcjs = require('./chunk-X46GJS7X.cjs');
4
-
5
-
6
- var _chunkFJ2JWXSLcjs = require('./chunk-FJ2JWXSL.cjs');
7
-
8
-
9
- var _chunk5FZ7QLJDcjs = require('./chunk-5FZ7QLJD.cjs');
10
-
11
-
12
- var _chunkYCTPMLZOcjs = require('./chunk-YCTPMLZO.cjs');
13
-
14
- // src/routes/api.routes.ts
15
- var _express = require('express');
16
- var createApiRouter = (agent) => {
17
- const router = _express.Router.call(void 0, );
18
- router.use("/model", _chunkX46GJS7Xcjs.createModelApiRouter.call(void 0, agent.modelModule));
19
- router.use("/agent", _chunk5FZ7QLJDcjs.createAgentApiRouter.call(void 0, agent));
20
- if (agent.memoryModule) {
21
- router.use("/threads", _chunkFJ2JWXSLcjs.createThreadApiRouter.call(void 0, agent.memoryModule));
22
- router.use("/intent", _chunkYCTPMLZOcjs.createIntentApiRouter.call(void 0, agent.memoryModule));
23
- }
24
- return router;
25
- };
26
-
27
-
28
-
29
- exports.createApiRouter = createApiRouter;
30
- //# sourceMappingURL=chunk-XEAJBA3S.cjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-XEAJBA3S.cjs","../../src/routes/api.routes.ts"],"names":[],"mappings":"AAAA;AACE;AACF,wDAA6B;AAC7B;AACE;AACF,wDAA6B;AAC7B;AACE;AACF,wDAA6B;AAC7B;AACE;AACF,wDAA6B;AAC7B;AACA;ACbA,kCAAuB;AAOhB,IAAM,gBAAA,EAAkB,CAAC,KAAA,EAAA,GAA4B;AAC3D,EAAA,MAAM,OAAA,EAAS,6BAAA,CAAO;AAEtB,EAAA,MAAA,CAAO,GAAA,CAAI,QAAA,EAAU,oDAAA,KAAqB,CAAM,WAAW,CAAC,CAAA;AAC5D,EAAA,MAAA,CAAO,GAAA,CAAI,QAAA,EAAU,oDAAA,KAA0B,CAAC,CAAA;AAChD,EAAA,GAAA,CAAI,KAAA,CAAM,YAAA,EAAc;AACvB,IAAA,MAAA,CAAO,GAAA,CAAI,UAAA,EAAY,qDAAA,KAAsB,CAAM,YAAY,CAAC,CAAA;AAChE,IAAA,MAAA,CAAO,GAAA,CAAI,SAAA,EAAW,qDAAA,KAAsB,CAAM,YAAY,CAAC,CAAA;AAAA,EAChE;AAEA,EAAA,OAAO,MAAA;AACR,CAAA;ADOA;AACA;AACE;AACF,0CAAC","file":"/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-XEAJBA3S.cjs","sourcesContent":[null,"import { Router } from \"express\";\nimport type { AINAgent } from \"@/index.js\";\nimport { createAgentApiRouter } from \"./api/agent.routes.js\";\nimport { createIntentApiRouter } from \"./api/intent.routes.js\";\nimport { createModelApiRouter } from \"./api/model.routes.js\";\nimport { createThreadApiRouter } from \"./api/threads.routes.js\";\n\nexport const createApiRouter = (agent: AINAgent): Router => {\n\tconst router = Router();\n\n\trouter.use(\"/model\", createModelApiRouter(agent.modelModule));\n\trouter.use(\"/agent\", createAgentApiRouter(agent));\n\tif (agent.memoryModule) {\n\t\trouter.use(\"/threads\", createThreadApiRouter(agent.memoryModule));\n\t\trouter.use(\"/intent\", createIntentApiRouter(agent.memoryModule));\n\t}\n\n\treturn router;\n};\n"]}
@@ -1,8 +0,0 @@
1
- "use strict";Object.defineProperty(exports, "__esModule", {value: true});// src/modules/auth/base.auth.ts
2
- var BaseAuth = class {
3
- };
4
-
5
-
6
-
7
- exports.BaseAuth = BaseAuth;
8
- //# sourceMappingURL=chunk-XQTVE64W.cjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-XQTVE64W.cjs","../../src/modules/auth/base.auth.ts"],"names":[],"mappings":"AAAA;ACGO,IAAe,SAAA,EAAf,MAAwB;AAE/B,CAAA;ADFA;AACA;AACE;AACF,4BAAC","file":"/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-XQTVE64W.cjs","sourcesContent":[null,"import type { Request, Response } from \"express\";\nimport type { AuthResponse } from \"@/types/auth\";\n\nexport abstract class BaseAuth {\n\tabstract authenticate(req: Request, res: Response): Promise<AuthResponse>;\n}\n"]}
@@ -1 +0,0 @@
1
- {"version":3,"sources":["/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-YCTPMLZO.cjs","../../src/routes/api/intent.routes.ts"],"names":[],"mappings":"AAAA;AACE;AACF,wDAA6B;AAC7B;AACE;AACF,wDAA6B;AAC7B;AACA;ACPA;AAIC;AAAA,kCACM;AACP,oDAA4B;AAKrB,IAAM,sBAAA,EAAwB,CAAC,YAAA,EAAA,GAAuC;AAC5E,EAAA,MAAM,OAAA,EAAS,6BAAA,CAAO;AACtB,EAAA,MAAM,oBAAA,EAAsB,IAAI,0CAAA,CAAoB,YAAY,CAAA;AAEhE,EAAA,MAAM,kBAAA,EAAoB,CACzB,IAAA,EACA,IAAA,EACA,IAAA,EAAA,GACI;AACJ,IAAA,MAAM,aAAA,EAAe,YAAA,CAAa,eAAA,CAAgB,CAAA;AAClD,IAAA,GAAA,CAAI,CAAC,YAAA,EAAc;AAClB,MAAA,MAAM,MAAA,EAAQ,IAAI,mCAAA;AAAA,QACjB,4BAAA,CAAY,mBAAA;AAAA,QACZ;AAAA,MACD,CAAA;AACA,MAAA,MAAM,KAAA;AAAA,IACP;AACA,IAAA,IAAA,CAAK,CAAA;AAAA,EACN,CAAA;AAGA,EAAA,MAAA,CAAO,GAAA,CAAI,GAAA,EAAK,iBAAA,EAAmB,mBAAA,CAAoB,mBAAmB,CAAA;AAC1E,EAAA,MAAA,CAAO,IAAA,CAAK,OAAA,EAAS,iBAAA,EAAmB,mBAAA,CAAoB,gBAAgB,CAAA;AAC5E,EAAA,MAAA,CAAO,MAAA;AAAA,IACN,MAAA;AAAA,IACA,iBAAA;AAAA,IACA,mBAAA,CAAoB;AAAA,EACrB,CAAA;AAEA,EAAA,OAAO,MAAA;AACR,CAAA;ADNA;AACA;AACE;AACF,sDAAC","file":"/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-YCTPMLZO.cjs","sourcesContent":[null,"import {\n\ttype NextFunction,\n\ttype Request,\n\ttype Response,\n\tRouter,\n} from \"express\";\nimport { StatusCodes } from \"http-status-codes\";\nimport { IntentApiController } from \"@/controllers/api/intent.api.controller\";\nimport type { MemoryModule } from \"@/modules/index.js\";\nimport { AinHttpError } from \"@/types/agent\";\n\nexport const createIntentApiRouter = (memoryModule: MemoryModule): Router => {\n\tconst router = Router();\n\tconst intentApiController = new IntentApiController(memoryModule);\n\n\tconst checkThreadMemory = (\n\t\t_req: Request,\n\t\t_res: Response,\n\t\tnext: NextFunction,\n\t) => {\n\t\tconst threadMemory = memoryModule.getThreadMemory();\n\t\tif (!threadMemory) {\n\t\t\tconst error = new AinHttpError(\n\t\t\t\tStatusCodes.SERVICE_UNAVAILABLE,\n\t\t\t\t\"Memory module is not initialized\",\n\t\t\t);\n\t\t\tthrow error;\n\t\t}\n\t\tnext();\n\t};\n\n\t// APIs (prefix: /api/intent)\n\trouter.get(\"/\", checkThreadMemory, intentApiController.handleGetAllIntents);\n\trouter.post(\"/save\", checkThreadMemory, intentApiController.handleSaveIntent);\n\trouter.delete(\n\t\t\"/:id\",\n\t\tcheckThreadMemory,\n\t\tintentApiController.handleDeleteIntent,\n\t);\n\n\treturn router;\n};\n"]}
@@ -1,36 +0,0 @@
1
- "use strict";Object.defineProperty(exports, "__esModule", {value: true});
2
-
3
- var _chunk5QSLQX4Hcjs = require('./chunk-5QSLQX4H.cjs');
4
-
5
-
6
- var _chunkC5JALNJTcjs = require('./chunk-C5JALNJT.cjs');
7
-
8
-
9
- var _chunkRCOESZIXcjs = require('./chunk-RCOESZIX.cjs');
10
-
11
- // src/routes/a2a.routes.ts
12
- var _server = require('@a2a-js/sdk/server');
13
- var _express = require('express');
14
- var createA2ARouter = (agent) => {
15
- const router = _express.Router.call(void 0, );
16
- const taskStore = new (0, _server.InMemoryTaskStore)();
17
- const queryStreamService = new (0, _chunk5QSLQX4Hcjs.QueryStreamService)(
18
- agent.modelModule,
19
- agent.a2aModule,
20
- agent.mcpModule,
21
- agent.memoryModule
22
- );
23
- const a2aService = new (0, _chunkRCOESZIXcjs.A2AService)(queryStreamService);
24
- const a2aController = new (0, _chunkC5JALNJTcjs.A2AController)(
25
- a2aService,
26
- taskStore,
27
- agent.generateAgentCard
28
- );
29
- router.post("/", a2aController.handleA2ARequest);
30
- return router;
31
- };
32
-
33
-
34
-
35
- exports.createA2ARouter = createA2ARouter;
36
- //# sourceMappingURL=chunk-YY7HSXBP.cjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-YY7HSXBP.cjs","../../src/routes/a2a.routes.ts"],"names":[],"mappings":"AAAA;AACE;AACF,wDAA6B;AAC7B;AACE;AACF,wDAA6B;AAC7B;AACE;AACF,wDAA6B;AAC7B;AACA;ACVA,4CAAkC;AAClC,kCAAuB;AAchB,IAAM,gBAAA,EAAkB,CAAC,KAAA,EAAA,GAA4B;AAC3D,EAAA,MAAM,OAAA,EAAS,6BAAA,CAAO;AAGtB,EAAA,MAAM,UAAA,EAAY,IAAI,8BAAA,CAAkB,CAAA;AACxC,EAAA,MAAM,mBAAA,EAAqB,IAAI,yCAAA;AAAA,IAC9B,KAAA,CAAM,WAAA;AAAA,IACN,KAAA,CAAM,SAAA;AAAA,IACN,KAAA,CAAM,SAAA;AAAA,IACN,KAAA,CAAM;AAAA,EACP,CAAA;AACA,EAAA,MAAM,WAAA,EAAa,IAAI,iCAAA,CAAW,kBAAkB,CAAA;AACpD,EAAA,MAAM,cAAA,EAAgB,IAAI,oCAAA;AAAA,IACzB,UAAA;AAAA,IACA,SAAA;AAAA,IACA,KAAA,CAAM;AAAA,EACP,CAAA;AAGA,EAAA,MAAA,CAAO,IAAA,CAAK,GAAA,EAAK,aAAA,CAAc,gBAAgB,CAAA;AAE/C,EAAA,OAAO,MAAA;AACR,CAAA;ADNA;AACA;AACE;AACF,0CAAC","file":"/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-YY7HSXBP.cjs","sourcesContent":[null,"import { InMemoryTaskStore } from \"@a2a-js/sdk/server\";\nimport { Router } from \"express\";\nimport type { AINAgent } from \"@/index.js\";\nimport { QueryStreamService } from \"@/services/query-stream.service.js\";\nimport { A2AController } from \"../controllers/a2a.controller.js\";\nimport { A2AService } from \"../services/a2a.service.js\";\n\n/**\n * Creates and configures the A2A router.\n * This function is a \"composition root\" for the A2A feature,\n * creating and injecting all necessary dependencies.\n * @param intentAnalyzer The core intent analyzer.\n * @param agentCard The agent's card.\n * @returns An Express Router instance.\n */\nexport const createA2ARouter = (agent: AINAgent): Router => {\n\tconst router = Router();\n\n\t// 1. Create dependencies for the A2A feature\n\tconst taskStore = new InMemoryTaskStore();\n\tconst queryStreamService = new QueryStreamService(\n\t\tagent.modelModule,\n\t\tagent.a2aModule,\n\t\tagent.mcpModule,\n\t\tagent.memoryModule,\n\t);\n\tconst a2aService = new A2AService(queryStreamService);\n\tconst a2aController = new A2AController(\n\t\ta2aService,\n\t\ttaskStore,\n\t\tagent.generateAgentCard,\n\t);\n\n\t// 2. Define the route\n\trouter.post(\"/\", a2aController.handleA2ARequest);\n\n\treturn router;\n};\n"]}
@@ -1 +0,0 @@
1
- {"version":3,"sources":["/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-Z6TQ7TFO.cjs","../../src/types/agent.ts"],"names":[],"mappings":"AAAA;AC+BO,IAAM,aAAA,EAAN,MAAA,QAA2B,MAAM;AAAA,EAChC;AAAA,EAEP,WAAA,CAAY,MAAA,EAAqB,OAAA,EAAiB;AACjD,IAAA,KAAA,CAAM,OAAO,CAAA;AACb,IAAA,IAAA,CAAK,OAAA,EAAS,MAAA;AAAA,EACf;AACD,CAAA;AD9BA;AACA;AACE;AACF,oCAAC","file":"/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-Z6TQ7TFO.cjs","sourcesContent":[null,"import type { StatusCodes } from \"http-status-codes\";\n\n/**\n * Agent manifest containing essential metadata and configuration.\n *\n * The manifest defines the agent's identity, version, and optional configuration\n * such as the public URL for A2A protocol support and custom prompts.\n *\n * @example\n * ```typescript\n * const manifest: AinAgentManifest = {\n * name: \"CustomerSupportAgent\",\n * description: \"AI agent for handling customer support queries\",\n * version: \"1.0.0\",\n * url: \"https://api.example.com/agent\",\n * prompts: {\n * system: \"You are a helpful customer support assistant.\",\n * agent: \"Always be polite and provide detailed solutions.\"\n * }\n * };\n * ```\n */\nexport type AinAgentManifest = {\n\t/** Unique name identifier for the agent */\n\tname: string;\n\t/** Human-readable description of the agent's purpose and capabilities */\n\tdescription: string;\n\t/** Optional public URL for A2A protocol discovery and communication */\n\turl?: string;\n};\n\nexport class AinHttpError extends Error {\n\tpublic status?: StatusCodes;\n\n\tconstructor(status: StatusCodes, message: string) {\n\t\tsuper(message);\n\t\tthis.status = status;\n\t}\n}\n"]}
@@ -1,7 +0,0 @@
1
- "use strict";Object.defineProperty(exports, "__esModule", {value: true});
2
-
3
- var _chunkXQTVE64Wcjs = require('../../chunk-XQTVE64W.cjs');
4
-
5
-
6
- exports.BaseAuth = _chunkXQTVE64Wcjs.BaseAuth;
7
- //# sourceMappingURL=base.auth.cjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/modules/auth/base.auth.cjs"],"names":[],"mappings":"AAAA;AACE;AACF,4DAAiC;AACjC;AACE;AACF,8CAAC","file":"/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/modules/auth/base.auth.cjs"}
@@ -1,12 +0,0 @@
1
- "use strict";Object.defineProperty(exports, "__esModule", {value: true});
2
-
3
- var _chunkOZPPTVUAcjs = require('../../chunk-OZPPTVUA.cjs');
4
- require('../../chunk-7HBOMBZG.cjs');
5
- require('../../chunk-L6RI7RO4.cjs');
6
- require('../../chunk-O5X5QT63.cjs');
7
- require('../../chunk-W224GBH7.cjs');
8
- require('../../chunk-CLJ3DWTA.cjs');
9
-
10
-
11
- exports.IntentFulfillStreamService = _chunkOZPPTVUAcjs.IntentFulfillStreamService;
12
- //# sourceMappingURL=fulfill-stream.service.cjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/services/intents/fulfill-stream.service.cjs"],"names":[],"mappings":"AAAA;AACE;AACF,4DAAiC;AACjC,oCAAiC;AACjC,oCAAiC;AACjC,oCAAiC;AACjC,oCAAiC;AACjC,oCAAiC;AACjC;AACE;AACF,kFAAC","file":"/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/services/intents/fulfill-stream.service.cjs"}
@@ -1,16 +0,0 @@
1
- "use strict";Object.defineProperty(exports, "__esModule", {value: true});
2
-
3
- var _chunk7KXB6FOTcjs = require('../chunk-7KXB6FOT.cjs');
4
- require('../chunk-OZPPTVUA.cjs');
5
- require('../chunk-XHTEJE4E.cjs');
6
- require('../chunk-NEWJ7PXH.cjs');
7
- require('../chunk-7HBOMBZG.cjs');
8
- require('../chunk-L6RI7RO4.cjs');
9
- require('../chunk-O5X5QT63.cjs');
10
- require('../chunk-W224GBH7.cjs');
11
- require('../chunk-Z6TQ7TFO.cjs');
12
- require('../chunk-CLJ3DWTA.cjs');
13
-
14
-
15
- exports.QueryStreamService = _chunk7KXB6FOTcjs.QueryStreamService;
16
- //# sourceMappingURL=query-stream.service.cjs.map