@ainetwork/adk 0.3.1 → 0.3.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/{chunk-ZFSXQFEK.cjs → chunk-25FZXCHU.cjs} +51 -16
- package/dist/cjs/chunk-25FZXCHU.cjs.map +1 -0
- package/dist/cjs/{chunk-7QIF3FVV.cjs → chunk-3RS6NVSN.cjs} +7 -7
- package/dist/cjs/{chunk-7QIF3FVV.cjs.map → chunk-3RS6NVSN.cjs.map} +1 -1
- package/dist/cjs/{chunk-6WAVK3BS.cjs → chunk-4IBKK5HW.cjs} +27 -9
- package/dist/cjs/chunk-4IBKK5HW.cjs.map +1 -0
- package/dist/cjs/{chunk-QSBUV5WJ.cjs → chunk-5QSLQX4H.cjs} +20 -16
- package/dist/cjs/chunk-5QSLQX4H.cjs.map +1 -0
- package/dist/cjs/{chunk-OVTUSYSU.cjs → chunk-5WWZOWMA.cjs} +1 -1
- package/dist/cjs/chunk-5WWZOWMA.cjs.map +1 -0
- package/dist/cjs/{chunk-AWHKDGXN.cjs → chunk-6T2YGFSD.cjs} +3 -3
- package/dist/cjs/{chunk-AWHKDGXN.cjs.map → chunk-6T2YGFSD.cjs.map} +1 -1
- package/dist/cjs/{chunk-NYDNXGKB.cjs → chunk-7KXB6FOT.cjs} +20 -16
- package/dist/cjs/chunk-7KXB6FOT.cjs.map +1 -0
- package/dist/cjs/chunk-B3U3LJ7J.cjs +17 -0
- package/dist/cjs/chunk-B3U3LJ7J.cjs.map +1 -0
- package/dist/cjs/{chunk-ICFTUZP5.cjs → chunk-C5JALNJT.cjs} +4 -4
- package/dist/cjs/{chunk-ICFTUZP5.cjs.map → chunk-C5JALNJT.cjs.map} +1 -1
- package/dist/cjs/chunk-CLJ3DWTA.cjs +62 -0
- package/dist/cjs/chunk-CLJ3DWTA.cjs.map +1 -0
- package/dist/cjs/{chunk-I4ET55WI.cjs → chunk-DGXLVGIM.cjs} +7 -7
- package/dist/cjs/{chunk-I4ET55WI.cjs.map → chunk-DGXLVGIM.cjs.map} +1 -1
- package/dist/cjs/{chunk-G42JXC76.cjs → chunk-E3PD4Q76.cjs} +7 -7
- package/dist/cjs/{chunk-G42JXC76.cjs.map → chunk-E3PD4Q76.cjs.map} +1 -1
- package/dist/cjs/{chunk-ASEYNIPL.cjs → chunk-EA3YMPST.cjs} +7 -7
- package/dist/cjs/{chunk-OFUS74ON.cjs.map → chunk-EA3YMPST.cjs.map} +1 -1
- package/dist/cjs/{chunk-K5LS7KNV.cjs → chunk-HF7GKQ6Y.cjs} +10 -10
- package/dist/cjs/{chunk-K63YCRBA.cjs.map → chunk-HF7GKQ6Y.cjs.map} +1 -1
- package/dist/cjs/{chunk-NYYEZ4ER.cjs → chunk-M5TQFW2Y.cjs} +3 -3
- package/dist/cjs/{chunk-NYYEZ4ER.cjs.map → chunk-M5TQFW2Y.cjs.map} +1 -1
- package/dist/cjs/{chunk-TF7S7SPO.cjs → chunk-NEWJ7PXH.cjs} +4 -4
- package/dist/cjs/{chunk-TF7S7SPO.cjs.map → chunk-NEWJ7PXH.cjs.map} +1 -1
- package/dist/cjs/{chunk-AQXHOGJD.cjs → chunk-NNYPZA6W.cjs} +19 -1
- package/dist/cjs/chunk-NNYPZA6W.cjs.map +1 -0
- package/dist/cjs/chunk-O5X5QT63.cjs +19 -0
- package/dist/cjs/chunk-O5X5QT63.cjs.map +1 -0
- package/dist/cjs/{chunk-7QXQYCZP.cjs → chunk-OZPPTVUA.cjs} +41 -55
- package/dist/cjs/chunk-OZPPTVUA.cjs.map +1 -0
- package/dist/cjs/{chunk-BDQDZXZI.cjs → chunk-RCOESZIX.cjs} +9 -23
- package/dist/cjs/chunk-RCOESZIX.cjs.map +1 -0
- package/dist/cjs/{chunk-K63YCRBA.cjs → chunk-RVT67VJL.cjs} +10 -10
- package/dist/cjs/{chunk-K5LS7KNV.cjs.map → chunk-RVT67VJL.cjs.map} +1 -1
- package/dist/cjs/{chunk-X5INT5HE.cjs → chunk-U47SG7XG.cjs} +16 -11
- package/dist/cjs/chunk-U47SG7XG.cjs.map +1 -0
- package/dist/cjs/{chunk-MO3H4KHE.cjs → chunk-XHTEJE4E.cjs} +3 -3
- package/dist/cjs/{chunk-MO3H4KHE.cjs.map → chunk-XHTEJE4E.cjs.map} +1 -1
- package/dist/cjs/{chunk-OFUS74ON.cjs → chunk-YY7HSXBP.cjs} +7 -7
- package/dist/cjs/{chunk-TF2SCL3K.cjs.map → chunk-YY7HSXBP.cjs.map} +1 -1
- package/dist/cjs/config/manifest.cjs +9 -0
- package/dist/cjs/config/manifest.cjs.map +1 -0
- package/dist/cjs/controllers/a2a.controller.cjs +3 -3
- package/dist/cjs/controllers/index.cjs +5 -4
- package/dist/cjs/controllers/index.cjs.map +1 -1
- package/dist/cjs/controllers/query.controller.cjs +3 -2
- package/dist/cjs/controllers/query.controller.cjs.map +1 -1
- package/dist/cjs/index.cjs +42 -54
- package/dist/cjs/index.cjs.map +1 -1
- package/dist/cjs/middlewares/error.middleware.cjs +3 -3
- package/dist/cjs/modules/a2a/a2a.connector.cjs +2 -2
- package/dist/cjs/modules/a2a/a2a.module.cjs +4 -4
- package/dist/cjs/modules/index.cjs +10 -10
- package/dist/cjs/modules/index.cjs.map +1 -1
- package/dist/cjs/modules/mcp/mcp.module.cjs +3 -3
- package/dist/cjs/routes/a2a.routes.cjs +11 -10
- package/dist/cjs/routes/a2a.routes.cjs.map +1 -1
- package/dist/cjs/routes/api.routes.cjs +4 -4
- package/dist/cjs/routes/index.cjs +21 -20
- package/dist/cjs/routes/index.cjs.map +1 -1
- package/dist/cjs/routes/intent.routes.cjs +13 -12
- package/dist/cjs/routes/intent.routes.cjs.map +1 -1
- package/dist/cjs/routes/query.routes.cjs +12 -11
- package/dist/cjs/routes/query.routes.cjs.map +1 -1
- package/dist/cjs/services/a2a.service.cjs +3 -3
- package/dist/cjs/services/index.cjs +12 -11
- package/dist/cjs/services/index.cjs.map +1 -1
- package/dist/cjs/services/intents/fulfill-stream.service.cjs +4 -3
- package/dist/cjs/services/intents/fulfill-stream.service.cjs.map +1 -1
- package/dist/cjs/services/intents/fulfill.service.cjs +3 -3
- package/dist/cjs/services/intents/trigger.service.cjs +3 -3
- package/dist/cjs/services/query-stream.service.cjs +8 -7
- package/dist/cjs/services/query-stream.service.cjs.map +1 -1
- package/dist/cjs/services/query.service.cjs +7 -7
- package/dist/cjs/services/utils/query.common.cjs +3 -3
- package/dist/cjs/utils/isValidUrl.cjs +7 -0
- package/dist/cjs/utils/isValidUrl.cjs.map +1 -0
- package/dist/cjs/utils/logger.cjs +2 -2
- package/dist/esm/chunk-2J2TQRP4.js +19 -0
- package/dist/esm/chunk-2J2TQRP4.js.map +1 -0
- package/dist/esm/{chunk-DM6UZSRU.js → chunk-4LBR3TIJ.js} +5 -19
- package/dist/esm/chunk-4LBR3TIJ.js.map +1 -0
- package/dist/esm/{chunk-J2UFYVKK.js → chunk-5IIF5O4A.js} +2 -2
- package/dist/esm/{chunk-WRKUZMNO.js → chunk-6AN7Z5OC.js} +6 -6
- package/dist/esm/{chunk-V24ATQLM.js → chunk-A5PRJ33H.js} +29 -43
- package/dist/esm/chunk-A5PRJ33H.js.map +1 -0
- package/dist/esm/{chunk-WMZ6PYTE.js → chunk-BZZDVW26.js} +1 -1
- package/dist/esm/chunk-BZZDVW26.js.map +1 -0
- package/dist/esm/{chunk-NWL3BMUH.js → chunk-FRQSMPPK.js} +49 -14
- package/dist/esm/chunk-FRQSMPPK.js.map +1 -0
- package/dist/esm/chunk-I5DLV2CU.js +17 -0
- package/dist/esm/chunk-I5DLV2CU.js.map +1 -0
- package/dist/esm/{chunk-RJZ4QSDX.js → chunk-JCXAHLRN.js} +12 -8
- package/dist/esm/chunk-JCXAHLRN.js.map +1 -0
- package/dist/esm/{chunk-OW7PCDK5.js → chunk-JHKBIDPX.js} +19 -1
- package/dist/esm/chunk-JHKBIDPX.js.map +1 -0
- package/dist/esm/{chunk-DIW5VDAQ.js → chunk-KOCOM7IC.js} +2 -2
- package/dist/esm/{chunk-YDMTU6UH.js → chunk-PVWOU6LA.js} +21 -3
- package/dist/esm/chunk-PVWOU6LA.js.map +1 -0
- package/dist/esm/{chunk-MCMWSGRJ.js → chunk-Q7NLA5X4.js} +7 -7
- package/dist/esm/{chunk-MAU2MAK2.js → chunk-RAHOYMKY.js} +2 -2
- package/dist/esm/{chunk-WL7H2QX4.js → chunk-UEUZ7G5P.js} +8 -3
- package/dist/esm/chunk-UEUZ7G5P.js.map +1 -0
- package/dist/esm/chunk-VUMI4XOY.js +62 -0
- package/dist/esm/chunk-VUMI4XOY.js.map +1 -0
- package/dist/esm/{chunk-THBAYYPZ.js → chunk-WO2QJ6UM.js} +2 -2
- package/dist/esm/{chunk-7XCSPITE.js → chunk-Y7BKUWRJ.js} +7 -7
- package/dist/esm/{chunk-3FE3GPF2.js → chunk-YJTWW6QK.js} +4 -4
- package/dist/esm/{chunk-HAE333YO.js → chunk-YMSNW2SU.js} +2 -2
- package/dist/esm/config/manifest.d.ts +7 -0
- package/dist/esm/config/manifest.js +9 -0
- package/dist/esm/config/manifest.js.map +1 -0
- package/dist/esm/controllers/a2a.controller.d.ts +2 -2
- package/dist/esm/controllers/a2a.controller.js +2 -2
- package/dist/esm/controllers/api/agent.api.controller.d.ts +2 -2
- package/dist/esm/controllers/index.d.ts +2 -2
- package/dist/esm/controllers/index.js +4 -3
- package/dist/esm/controllers/query.controller.d.ts +2 -2
- package/dist/esm/controllers/query.controller.js +2 -1
- package/dist/esm/index.d.ts +2 -9
- package/dist/esm/index.js +35 -47
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/middlewares/error.middleware.js +2 -2
- package/dist/esm/modules/a2a/a2a.connector.d.ts +2 -2
- package/dist/esm/modules/a2a/a2a.connector.js +1 -1
- package/dist/esm/modules/a2a/a2a.module.d.ts +5 -2
- package/dist/esm/modules/a2a/a2a.module.js +3 -3
- package/dist/esm/modules/index.d.ts +2 -2
- package/dist/esm/modules/index.js +9 -9
- package/dist/esm/modules/mcp/mcp.module.js +2 -2
- package/dist/esm/routes/a2a.routes.d.ts +2 -2
- package/dist/esm/routes/a2a.routes.js +10 -9
- package/dist/esm/routes/api/agent.routes.d.ts +2 -2
- package/dist/esm/routes/api.routes.d.ts +2 -2
- package/dist/esm/routes/api.routes.js +3 -3
- package/dist/esm/routes/index.d.ts +2 -2
- package/dist/esm/routes/index.js +20 -19
- package/dist/esm/routes/intent.routes.d.ts +2 -2
- package/dist/esm/routes/intent.routes.js +12 -11
- package/dist/esm/routes/query.routes.d.ts +2 -2
- package/dist/esm/routes/query.routes.js +11 -10
- package/dist/esm/services/a2a.service.d.ts +2 -2
- package/dist/esm/services/a2a.service.js +2 -2
- package/dist/esm/services/index.d.ts +2 -2
- package/dist/esm/services/index.js +12 -11
- package/dist/esm/services/intents/fulfill-stream.service.js +3 -2
- package/dist/esm/services/intents/fulfill.service.d.ts +1 -1
- package/dist/esm/services/intents/fulfill.service.js +2 -2
- package/dist/esm/services/intents/trigger.service.js +2 -2
- package/dist/esm/services/query-stream.service.d.ts +2 -1
- package/dist/esm/services/query-stream.service.js +7 -6
- package/dist/esm/services/query.service.d.ts +1 -1
- package/dist/esm/services/query.service.js +6 -6
- package/dist/esm/services/utils/fulfill.common.d.ts +1 -1
- package/dist/esm/services/utils/query.common.js +2 -2
- package/dist/esm/types/stream.d.ts +3 -3
- package/dist/esm/utils/isValidUrl.d.ts +9 -0
- package/dist/esm/utils/isValidUrl.js +7 -0
- package/dist/esm/utils/isValidUrl.js.map +1 -0
- package/dist/esm/utils/logger.js +1 -1
- package/package.json +5 -4
- package/dist/cjs/chunk-2OXSV2VU.cjs +0 -134
- package/dist/cjs/chunk-2OXSV2VU.cjs.map +0 -1
- package/dist/cjs/chunk-2TNBBXQ3.cjs +0 -129
- package/dist/cjs/chunk-2TNBBXQ3.cjs.map +0 -1
- package/dist/cjs/chunk-2TOW46DI.cjs +0 -246
- package/dist/cjs/chunk-2TOW46DI.cjs.map +0 -1
- package/dist/cjs/chunk-35MIRD7Z.cjs +0 -134
- package/dist/cjs/chunk-35MIRD7Z.cjs.map +0 -1
- package/dist/cjs/chunk-37J4FFJ3.cjs +0 -133
- package/dist/cjs/chunk-37J4FFJ3.cjs.map +0 -1
- package/dist/cjs/chunk-3BPHCG6M.cjs +0 -30
- package/dist/cjs/chunk-3BPHCG6M.cjs.map +0 -1
- package/dist/cjs/chunk-3XJS5S3O.cjs +0 -191
- package/dist/cjs/chunk-3XJS5S3O.cjs.map +0 -1
- package/dist/cjs/chunk-43XI3NHI.cjs +0 -43
- package/dist/cjs/chunk-43XI3NHI.cjs.map +0 -1
- package/dist/cjs/chunk-466ED5WN.cjs +0 -41
- package/dist/cjs/chunk-466ED5WN.cjs.map +0 -1
- package/dist/cjs/chunk-4KL2BCDZ.cjs +0 -43
- package/dist/cjs/chunk-4KL2BCDZ.cjs.map +0 -1
- package/dist/cjs/chunk-4RPP5UAH.cjs +0 -202
- package/dist/cjs/chunk-4RPP5UAH.cjs.map +0 -1
- package/dist/cjs/chunk-4TO7EZ5J.cjs +0 -133
- package/dist/cjs/chunk-4TO7EZ5J.cjs.map +0 -1
- package/dist/cjs/chunk-5IEVTAT2.cjs +0 -37
- package/dist/cjs/chunk-5IEVTAT2.cjs.map +0 -1
- package/dist/cjs/chunk-67CP7NP7.cjs +0 -132
- package/dist/cjs/chunk-67CP7NP7.cjs.map +0 -1
- package/dist/cjs/chunk-6WAVK3BS.cjs.map +0 -1
- package/dist/cjs/chunk-7CCDDRLV.cjs +0 -28
- package/dist/cjs/chunk-7CCDDRLV.cjs.map +0 -1
- package/dist/cjs/chunk-7ELF6ICG.cjs +0 -129
- package/dist/cjs/chunk-7ELF6ICG.cjs.map +0 -1
- package/dist/cjs/chunk-7IORLKS7.cjs +0 -28
- package/dist/cjs/chunk-7IORLKS7.cjs.map +0 -1
- package/dist/cjs/chunk-7P4O537H.cjs +0 -132
- package/dist/cjs/chunk-7P4O537H.cjs.map +0 -1
- package/dist/cjs/chunk-7QXQYCZP.cjs.map +0 -1
- package/dist/cjs/chunk-AIUJ6CZR.cjs +0 -37
- package/dist/cjs/chunk-AIUJ6CZR.cjs.map +0 -1
- package/dist/cjs/chunk-AQXHOGJD.cjs.map +0 -1
- package/dist/cjs/chunk-ASEYNIPL.cjs.map +0 -1
- package/dist/cjs/chunk-BDQDZXZI.cjs.map +0 -1
- package/dist/cjs/chunk-BXBFJKZC.cjs +0 -114
- package/dist/cjs/chunk-BXBFJKZC.cjs.map +0 -1
- package/dist/cjs/chunk-BYTLWEXM.cjs +0 -43
- package/dist/cjs/chunk-BYTLWEXM.cjs.map +0 -1
- package/dist/cjs/chunk-C35ER63S.cjs +0 -134
- package/dist/cjs/chunk-C35ER63S.cjs.map +0 -1
- package/dist/cjs/chunk-CGD7CECK.cjs +0 -129
- package/dist/cjs/chunk-CGD7CECK.cjs.map +0 -1
- package/dist/cjs/chunk-CKIA6H2D.cjs +0 -30
- package/dist/cjs/chunk-CKIA6H2D.cjs.map +0 -1
- package/dist/cjs/chunk-CPZBDQ5D.cjs +0 -28
- package/dist/cjs/chunk-CPZBDQ5D.cjs.map +0 -1
- package/dist/cjs/chunk-DEWNBL5H.cjs +0 -37
- package/dist/cjs/chunk-DEWNBL5H.cjs.map +0 -1
- package/dist/cjs/chunk-DK57ZF33.cjs +0 -28
- package/dist/cjs/chunk-DK57ZF33.cjs.map +0 -1
- package/dist/cjs/chunk-DQIGZKKW.cjs +0 -37
- package/dist/cjs/chunk-DQIGZKKW.cjs.map +0 -1
- package/dist/cjs/chunk-DT2RCV6G.cjs +0 -40
- package/dist/cjs/chunk-DT2RCV6G.cjs.map +0 -1
- package/dist/cjs/chunk-E35E4LQY.cjs +0 -43
- package/dist/cjs/chunk-E35E4LQY.cjs.map +0 -1
- package/dist/cjs/chunk-EETXLYKA.cjs +0 -28
- package/dist/cjs/chunk-EETXLYKA.cjs.map +0 -1
- package/dist/cjs/chunk-F3A5E26D.cjs +0 -115
- package/dist/cjs/chunk-F3A5E26D.cjs.map +0 -1
- package/dist/cjs/chunk-FH44ANEI.cjs +0 -134
- package/dist/cjs/chunk-FH44ANEI.cjs.map +0 -1
- package/dist/cjs/chunk-FTRCEUDB.cjs +0 -40
- package/dist/cjs/chunk-FTRCEUDB.cjs.map +0 -1
- package/dist/cjs/chunk-G3BK3F7V.cjs +0 -129
- package/dist/cjs/chunk-G3BK3F7V.cjs.map +0 -1
- package/dist/cjs/chunk-GKXXTC6C.cjs +0 -191
- package/dist/cjs/chunk-GKXXTC6C.cjs.map +0 -1
- package/dist/cjs/chunk-GM3S5465.cjs +0 -28
- package/dist/cjs/chunk-GM3S5465.cjs.map +0 -1
- package/dist/cjs/chunk-GMCHHP5Z.cjs +0 -37
- package/dist/cjs/chunk-GMCHHP5Z.cjs.map +0 -1
- package/dist/cjs/chunk-GP3SSTAQ.cjs +0 -8
- package/dist/cjs/chunk-GP3SSTAQ.cjs.map +0 -1
- package/dist/cjs/chunk-HDZ5POWB.cjs +0 -134
- package/dist/cjs/chunk-HDZ5POWB.cjs.map +0 -1
- package/dist/cjs/chunk-HIL5SDJR.cjs +0 -43
- package/dist/cjs/chunk-HIL5SDJR.cjs.map +0 -1
- package/dist/cjs/chunk-HNKMBS3C.cjs +0 -43
- package/dist/cjs/chunk-HNKMBS3C.cjs.map +0 -1
- package/dist/cjs/chunk-ICNXY2NK.cjs +0 -132
- package/dist/cjs/chunk-ICNXY2NK.cjs.map +0 -1
- package/dist/cjs/chunk-ISQSPK4F.cjs +0 -134
- package/dist/cjs/chunk-ISQSPK4F.cjs.map +0 -1
- package/dist/cjs/chunk-J2FGGTF5.cjs +0 -37
- package/dist/cjs/chunk-J2FGGTF5.cjs.map +0 -1
- package/dist/cjs/chunk-J5GBTBSY.cjs +0 -134
- package/dist/cjs/chunk-J5GBTBSY.cjs.map +0 -1
- package/dist/cjs/chunk-JU5AB7AB.cjs +0 -37
- package/dist/cjs/chunk-JU5AB7AB.cjs.map +0 -1
- package/dist/cjs/chunk-K2W5TTBJ.cjs +0 -28
- package/dist/cjs/chunk-K2W5TTBJ.cjs.map +0 -1
- package/dist/cjs/chunk-KLSZEQ7H.cjs +0 -281
- package/dist/cjs/chunk-KLSZEQ7H.cjs.map +0 -1
- package/dist/cjs/chunk-L3PZU7OF.cjs +0 -285
- package/dist/cjs/chunk-L3PZU7OF.cjs.map +0 -1
- package/dist/cjs/chunk-L7QJRM2U.cjs +0 -131
- package/dist/cjs/chunk-L7QJRM2U.cjs.map +0 -1
- package/dist/cjs/chunk-LKVNLT2M.cjs +0 -132
- package/dist/cjs/chunk-LKVNLT2M.cjs.map +0 -1
- package/dist/cjs/chunk-M7K34W2H.cjs +0 -134
- package/dist/cjs/chunk-M7K34W2H.cjs.map +0 -1
- package/dist/cjs/chunk-MJAKDII2.cjs +0 -78
- package/dist/cjs/chunk-MJAKDII2.cjs.map +0 -1
- package/dist/cjs/chunk-MN47LTUO.cjs +0 -37
- package/dist/cjs/chunk-MN47LTUO.cjs.map +0 -1
- package/dist/cjs/chunk-NB6OID2Z.cjs +0 -285
- package/dist/cjs/chunk-NB6OID2Z.cjs.map +0 -1
- package/dist/cjs/chunk-NCYNT6TA.cjs +0 -129
- package/dist/cjs/chunk-NCYNT6TA.cjs.map +0 -1
- package/dist/cjs/chunk-NQUYHJ3J.cjs +0 -115
- package/dist/cjs/chunk-NQUYHJ3J.cjs.map +0 -1
- package/dist/cjs/chunk-NYDNXGKB.cjs.map +0 -1
- package/dist/cjs/chunk-OU5UB2HF.cjs +0 -113
- package/dist/cjs/chunk-OU5UB2HF.cjs.map +0 -1
- package/dist/cjs/chunk-OVTUSYSU.cjs.map +0 -1
- package/dist/cjs/chunk-PACFW2PR.cjs +0 -37
- package/dist/cjs/chunk-PACFW2PR.cjs.map +0 -1
- package/dist/cjs/chunk-PSHQ4OBL.cjs +0 -41
- package/dist/cjs/chunk-PSHQ4OBL.cjs.map +0 -1
- package/dist/cjs/chunk-QDX7LVBM.cjs +0 -284
- package/dist/cjs/chunk-QDX7LVBM.cjs.map +0 -1
- package/dist/cjs/chunk-QE7UAZY6.cjs +0 -37
- package/dist/cjs/chunk-QE7UAZY6.cjs.map +0 -1
- package/dist/cjs/chunk-QHQLU7BI.cjs +0 -13
- package/dist/cjs/chunk-QHQLU7BI.cjs.map +0 -1
- package/dist/cjs/chunk-QSBUV5WJ.cjs.map +0 -1
- package/dist/cjs/chunk-QZHI7LLI.cjs +0 -156
- package/dist/cjs/chunk-QZHI7LLI.cjs.map +0 -1
- package/dist/cjs/chunk-R42QDO6G.cjs +0 -28
- package/dist/cjs/chunk-R42QDO6G.cjs.map +0 -1
- package/dist/cjs/chunk-RIJV7J5Z.cjs +0 -52
- package/dist/cjs/chunk-RIJV7J5Z.cjs.map +0 -1
- package/dist/cjs/chunk-S2NO7QKM.cjs +0 -132
- package/dist/cjs/chunk-S2NO7QKM.cjs.map +0 -1
- package/dist/cjs/chunk-SCOMNXDA.cjs +0 -51
- package/dist/cjs/chunk-SCOMNXDA.cjs.map +0 -1
- package/dist/cjs/chunk-SSOKZ4O2.cjs +0 -41
- package/dist/cjs/chunk-SSOKZ4O2.cjs.map +0 -1
- package/dist/cjs/chunk-T3N54JRA.cjs +0 -41
- package/dist/cjs/chunk-T3N54JRA.cjs.map +0 -1
- package/dist/cjs/chunk-TF2SCL3K.cjs +0 -36
- package/dist/cjs/chunk-TJAP46DQ.cjs +0 -43
- package/dist/cjs/chunk-TJAP46DQ.cjs.map +0 -1
- package/dist/cjs/chunk-TOVCM7I7.cjs +0 -281
- package/dist/cjs/chunk-TOVCM7I7.cjs.map +0 -1
- package/dist/cjs/chunk-TUAC64ZF.cjs +0 -41
- package/dist/cjs/chunk-TUAC64ZF.cjs.map +0 -1
- package/dist/cjs/chunk-UEOOHJIR.cjs +0 -43
- package/dist/cjs/chunk-UEOOHJIR.cjs.map +0 -1
- package/dist/cjs/chunk-UGDFRSMS.cjs +0 -200
- package/dist/cjs/chunk-UGDFRSMS.cjs.map +0 -1
- package/dist/cjs/chunk-VNAH5COA.cjs +0 -202
- package/dist/cjs/chunk-VNAH5COA.cjs.map +0 -1
- package/dist/cjs/chunk-W4IBNFLJ.cjs +0 -43
- package/dist/cjs/chunk-W4IBNFLJ.cjs.map +0 -1
- package/dist/cjs/chunk-W5NZWOXV.cjs +0 -283
- package/dist/cjs/chunk-W5NZWOXV.cjs.map +0 -1
- package/dist/cjs/chunk-WGAEW3R3.cjs +0 -134
- package/dist/cjs/chunk-WGAEW3R3.cjs.map +0 -1
- package/dist/cjs/chunk-WKGN6P3D.cjs +0 -131
- package/dist/cjs/chunk-WKGN6P3D.cjs.map +0 -1
- package/dist/cjs/chunk-X5INT5HE.cjs.map +0 -1
- package/dist/cjs/chunk-X6R53KCL.cjs +0 -134
- package/dist/cjs/chunk-X6R53KCL.cjs.map +0 -1
- package/dist/cjs/chunk-YCD3FBPB.cjs +0 -41
- package/dist/cjs/chunk-YCD3FBPB.cjs.map +0 -1
- package/dist/cjs/chunk-YE6INMSS.cjs +0 -41
- package/dist/cjs/chunk-YE6INMSS.cjs.map +0 -1
- package/dist/cjs/chunk-YGK2LYEU.cjs +0 -36
- package/dist/cjs/chunk-YGK2LYEU.cjs.map +0 -1
- package/dist/cjs/chunk-YIRGAWMS.cjs +0 -30
- package/dist/cjs/chunk-YIRGAWMS.cjs.map +0 -1
- package/dist/cjs/chunk-YJSEM4WE.cjs +0 -116
- package/dist/cjs/chunk-YJSEM4WE.cjs.map +0 -1
- package/dist/cjs/chunk-YMNLHFLD.cjs +0 -251
- package/dist/cjs/chunk-YMNLHFLD.cjs.map +0 -1
- package/dist/cjs/chunk-ZFSXQFEK.cjs.map +0 -1
- package/dist/cjs/chunk-ZP35BH7F.cjs +0 -43
- package/dist/cjs/chunk-ZP35BH7F.cjs.map +0 -1
- package/dist/esm/chunk-DM6UZSRU.js.map +0 -1
- package/dist/esm/chunk-N7VYM2R5.js +0 -41
- package/dist/esm/chunk-N7VYM2R5.js.map +0 -1
- package/dist/esm/chunk-NWL3BMUH.js.map +0 -1
- package/dist/esm/chunk-OW7PCDK5.js.map +0 -1
- package/dist/esm/chunk-RJZ4QSDX.js.map +0 -1
- package/dist/esm/chunk-V24ATQLM.js.map +0 -1
- package/dist/esm/chunk-WL7H2QX4.js.map +0 -1
- package/dist/esm/chunk-WMZ6PYTE.js.map +0 -1
- package/dist/esm/chunk-YDMTU6UH.js.map +0 -1
- /package/dist/esm/{chunk-J2UFYVKK.js.map → chunk-5IIF5O4A.js.map} +0 -0
- /package/dist/esm/{chunk-WRKUZMNO.js.map → chunk-6AN7Z5OC.js.map} +0 -0
- /package/dist/esm/{chunk-DIW5VDAQ.js.map → chunk-KOCOM7IC.js.map} +0 -0
- /package/dist/esm/{chunk-MCMWSGRJ.js.map → chunk-Q7NLA5X4.js.map} +0 -0
- /package/dist/esm/{chunk-MAU2MAK2.js.map → chunk-RAHOYMKY.js.map} +0 -0
- /package/dist/esm/{chunk-THBAYYPZ.js.map → chunk-WO2QJ6UM.js.map} +0 -0
- /package/dist/esm/{chunk-7XCSPITE.js.map → chunk-Y7BKUWRJ.js.map} +0 -0
- /package/dist/esm/{chunk-3FE3GPF2.js.map → chunk-YJTWW6QK.js.map} +0 -0
- /package/dist/esm/{chunk-HAE333YO.js.map → chunk-YMSNW2SU.js.map} +0 -0
|
@@ -0,0 +1 @@
|
|
|
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"]}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports, "__esModule", {value: true});// src/config/manifest.ts
|
|
2
|
+
var _manifest = null;
|
|
3
|
+
function setManifest(manifest) {
|
|
4
|
+
_manifest = manifest;
|
|
5
|
+
}
|
|
6
|
+
function getManifest() {
|
|
7
|
+
if (!_manifest) {
|
|
8
|
+
throw new Error(
|
|
9
|
+
"Manifest not initialized. AINAgent must be created first."
|
|
10
|
+
);
|
|
11
|
+
}
|
|
12
|
+
return _manifest;
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
|
|
16
|
+
|
|
17
|
+
|
|
18
|
+
exports.setManifest = setManifest; exports.getManifest = getManifest;
|
|
19
|
+
//# sourceMappingURL=chunk-O5X5QT63.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-O5X5QT63.cjs","../../src/config/manifest.ts"],"names":[],"mappings":"AAAA;ACEA,IAAI,UAAA,EAAqC,IAAA;AAElC,SAAS,WAAA,CAAY,QAAA,EAAkC;AAC7D,EAAA,UAAA,EAAY,QAAA;AACb;AAEO,SAAS,WAAA,CAAA,EAAgC;AAC/C,EAAA,GAAA,CAAI,CAAC,SAAA,EAAW;AACf,IAAA,MAAM,IAAI,KAAA;AAAA,MACT;AAAA,IACD,CAAA;AAAA,EACD;AACA,EAAA,OAAO,SAAA;AACR;ADFA;AACA;AACE;AACA;AACF,qEAAC","file":"/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-O5X5QT63.cjs","sourcesContent":[null,"import type { AinAgentManifest } from \"@/types/agent\";\n\nlet _manifest: AinAgentManifest | null = null;\n\nexport function setManifest(manifest: AinAgentManifest): void {\n\t_manifest = manifest;\n}\n\nexport function getManifest(): AinAgentManifest {\n\tif (!_manifest) {\n\t\tthrow new Error(\n\t\t\t\"Manifest not initialized. AINAgent must be created first.\",\n\t\t);\n\t}\n\treturn _manifest;\n}\n"]}
|
|
@@ -3,7 +3,10 @@
|
|
|
3
3
|
var _chunk7HBOMBZGcjs = require('./chunk-7HBOMBZG.cjs');
|
|
4
4
|
|
|
5
5
|
|
|
6
|
-
var
|
|
6
|
+
var _chunkO5X5QT63cjs = require('./chunk-O5X5QT63.cjs');
|
|
7
|
+
|
|
8
|
+
|
|
9
|
+
var _chunkCLJ3DWTAcjs = require('./chunk-CLJ3DWTA.cjs');
|
|
7
10
|
|
|
8
11
|
// src/services/intents/fulfill-stream.service.ts
|
|
9
12
|
var _crypto = require('crypto');
|
|
@@ -32,7 +35,7 @@ var IntentFulfillStreamService = class {
|
|
|
32
35
|
thread.messages.push(newMessage);
|
|
33
36
|
await _optionalChain([threadMemory, 'optionalAccess', _4 => _4.addMessagesToThread, 'call', _5 => _5(userId, threadId, [newMessage])]);
|
|
34
37
|
} catch (error) {
|
|
35
|
-
|
|
38
|
+
_chunkCLJ3DWTAcjs.loggers.intentStream.error("Error adding message to thread", error);
|
|
36
39
|
}
|
|
37
40
|
}
|
|
38
41
|
/**
|
|
@@ -61,7 +64,7 @@ var IntentFulfillStreamService = class {
|
|
|
61
64
|
thread,
|
|
62
65
|
systemPrompt: fulfillPrompt.trim()
|
|
63
66
|
});
|
|
64
|
-
|
|
67
|
+
_chunkCLJ3DWTAcjs.loggers.intent.debug("Intent fulfillment start", {
|
|
65
68
|
threadId: thread.threadId,
|
|
66
69
|
messages
|
|
67
70
|
});
|
|
@@ -98,13 +101,12 @@ var IntentFulfillStreamService = class {
|
|
|
98
101
|
};
|
|
99
102
|
}
|
|
100
103
|
}
|
|
101
|
-
|
|
104
|
+
_chunkCLJ3DWTAcjs.loggers.intentStream.debug("assembledToolCalls", {
|
|
102
105
|
threadId: thread.threadId,
|
|
103
106
|
assembledToolCalls
|
|
104
107
|
});
|
|
105
108
|
if (assembledToolCalls.length > 0) {
|
|
106
109
|
for (const toolCall of assembledToolCalls) {
|
|
107
|
-
const toolCallId = _crypto.randomUUID.call(void 0, );
|
|
108
110
|
const toolName = toolCall.function.name;
|
|
109
111
|
let selectedTool;
|
|
110
112
|
for (const [index, toolTmp] of tools.entries()) {
|
|
@@ -119,52 +121,41 @@ var IntentFulfillStreamService = class {
|
|
|
119
121
|
if (!selectedTool) {
|
|
120
122
|
continue;
|
|
121
123
|
}
|
|
124
|
+
const toolArgs = JSON.parse(toolCall.function.arguments);
|
|
125
|
+
const thinkData = {
|
|
126
|
+
title: `[${_chunkO5X5QT63cjs.getManifest.call(void 0, ).name}] ${selectedTool.protocol} \uC2E4\uD589: ${toolName}`,
|
|
127
|
+
description: `${toolArgs.thinking_text || ""}`
|
|
128
|
+
};
|
|
129
|
+
yield {
|
|
130
|
+
event: "thinking_process",
|
|
131
|
+
data: thinkData
|
|
132
|
+
};
|
|
122
133
|
let toolResult = "";
|
|
123
134
|
if (this.mcpModule && selectedTool.protocol === "MCP" /* MCP */) {
|
|
124
|
-
|
|
125
|
-
yield {
|
|
126
|
-
event: "tool_start",
|
|
127
|
-
data: {
|
|
128
|
-
toolCallId,
|
|
129
|
-
protocol: "MCP" /* MCP */,
|
|
130
|
-
toolName,
|
|
131
|
-
toolArgs
|
|
132
|
-
}
|
|
133
|
-
};
|
|
134
|
-
_chunk466ED5WNcjs.loggers.intent.info("MCP tool call", { toolName, toolArgs });
|
|
135
|
+
_chunkCLJ3DWTAcjs.loggers.intent.info("MCP tool call", { toolName, toolArgs });
|
|
135
136
|
toolResult = await this.mcpModule.useTool(selectedTool, toolArgs);
|
|
136
137
|
} else if (this.a2aModule && selectedTool.protocol === "A2A" /* A2A */) {
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
data: {
|
|
140
|
-
toolCallId,
|
|
141
|
-
protocol: "A2A" /* A2A */,
|
|
142
|
-
toolName,
|
|
143
|
-
toolArgs: null
|
|
144
|
-
}
|
|
145
|
-
};
|
|
146
|
-
_chunk466ED5WNcjs.loggers.intent.info("A2A tool call", { toolName });
|
|
147
|
-
toolResult = await this.a2aModule.useTool(
|
|
138
|
+
_chunkCLJ3DWTAcjs.loggers.intent.info("A2A tool call", { toolName });
|
|
139
|
+
const a2aStream = this.a2aModule.useTool(
|
|
148
140
|
selectedTool,
|
|
149
141
|
query,
|
|
150
142
|
thread.threadId
|
|
151
143
|
);
|
|
144
|
+
let result = await a2aStream.next();
|
|
145
|
+
while (!result.done) {
|
|
146
|
+
if (result.value.event === "thinking_process") {
|
|
147
|
+
yield result.value;
|
|
148
|
+
}
|
|
149
|
+
result = await a2aStream.next();
|
|
150
|
+
}
|
|
151
|
+
toolResult = result.value;
|
|
152
152
|
} else {
|
|
153
|
-
|
|
153
|
+
_chunkCLJ3DWTAcjs.loggers.intent.warn(
|
|
154
154
|
`Unrecognized tool type: ${selectedTool.protocol}`
|
|
155
155
|
);
|
|
156
156
|
continue;
|
|
157
157
|
}
|
|
158
|
-
|
|
159
|
-
event: "tool_output",
|
|
160
|
-
data: {
|
|
161
|
-
toolCallId,
|
|
162
|
-
protocol: selectedTool.protocol,
|
|
163
|
-
toolName,
|
|
164
|
-
result: toolResult
|
|
165
|
-
}
|
|
166
|
-
};
|
|
167
|
-
_chunk466ED5WNcjs.loggers.intent.debug("Tool Result", { toolResult });
|
|
158
|
+
_chunkCLJ3DWTAcjs.loggers.intent.debug("Tool Result", { toolResult });
|
|
168
159
|
processList.push(toolResult);
|
|
169
160
|
modelInstance.appendMessages(messages, toolResult);
|
|
170
161
|
}
|
|
@@ -172,7 +163,7 @@ var IntentFulfillStreamService = class {
|
|
|
172
163
|
break;
|
|
173
164
|
}
|
|
174
165
|
}
|
|
175
|
-
|
|
166
|
+
_chunkCLJ3DWTAcjs.loggers.intent.debug("Intent fulfillment completed", {
|
|
176
167
|
threadId: thread.threadId,
|
|
177
168
|
toolCallsExecuted: processList.length,
|
|
178
169
|
intentName: _optionalChain([intent, 'optionalAccess', _14 => _14.name])
|
|
@@ -187,7 +178,7 @@ var IntentFulfillStreamService = class {
|
|
|
187
178
|
*/
|
|
188
179
|
async *intentFulfillStream(intents, thread) {
|
|
189
180
|
const streamStartTime = Date.now();
|
|
190
|
-
|
|
181
|
+
_chunkCLJ3DWTAcjs.loggers.intentStream.info("Stream session started", {
|
|
191
182
|
threadId: thread.threadId,
|
|
192
183
|
intentCount: intents.length,
|
|
193
184
|
startTime: new Date(streamStartTime).toISOString()
|
|
@@ -195,8 +186,8 @@ var IntentFulfillStreamService = class {
|
|
|
195
186
|
let finalResponseText = "";
|
|
196
187
|
for (let i = 0; i < intents.length; i++) {
|
|
197
188
|
const { subquery, intent, actionPlan } = intents[i];
|
|
198
|
-
|
|
199
|
-
|
|
189
|
+
_chunkCLJ3DWTAcjs.loggers.intent.info(`Process query: ${subquery}, ${_optionalChain([intent, 'optionalAccess', _15 => _15.name])}`);
|
|
190
|
+
_chunkCLJ3DWTAcjs.loggers.intent.info(`Action plan: ${actionPlan}`);
|
|
200
191
|
finalResponseText !== "" && thread.messages.push({
|
|
201
192
|
messageId: _crypto.randomUUID.call(void 0, ),
|
|
202
193
|
role: "MODEL" /* MODEL */,
|
|
@@ -204,18 +195,13 @@ var IntentFulfillStreamService = class {
|
|
|
204
195
|
content: { type: "text", parts: [finalResponseText] },
|
|
205
196
|
metadata: { isThinking: true }
|
|
206
197
|
});
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
subquery,
|
|
212
|
-
isThinking: true,
|
|
213
|
-
actionPlan
|
|
214
|
-
}
|
|
215
|
-
});
|
|
198
|
+
const thinkData = {
|
|
199
|
+
title: `[${_chunkO5X5QT63cjs.getManifest.call(void 0, ).name}] ${subquery}`,
|
|
200
|
+
description: actionPlan || ""
|
|
201
|
+
};
|
|
216
202
|
yield {
|
|
217
|
-
event: "
|
|
218
|
-
data:
|
|
203
|
+
event: "thinking_process",
|
|
204
|
+
data: thinkData
|
|
219
205
|
};
|
|
220
206
|
const stream = this.intentFulfilling(subquery, thread, intent);
|
|
221
207
|
finalResponseText = "";
|
|
@@ -235,7 +221,7 @@ var IntentFulfillStreamService = class {
|
|
|
235
221
|
});
|
|
236
222
|
const streamEndTime = Date.now();
|
|
237
223
|
const streamDuration = streamEndTime - streamStartTime;
|
|
238
|
-
|
|
224
|
+
_chunkCLJ3DWTAcjs.loggers.intentStream.info("Stream session completed", {
|
|
239
225
|
threadId: thread.threadId,
|
|
240
226
|
duration: `${streamDuration}ms`,
|
|
241
227
|
endTime: new Date(streamEndTime).toISOString()
|
|
@@ -246,4 +232,4 @@ var IntentFulfillStreamService = class {
|
|
|
246
232
|
|
|
247
233
|
|
|
248
234
|
exports.IntentFulfillStreamService = IntentFulfillStreamService;
|
|
249
|
-
//# sourceMappingURL=chunk-
|
|
235
|
+
//# sourceMappingURL=chunk-OZPPTVUA.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
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,6 +1,6 @@
|
|
|
1
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; } var _class;
|
|
2
2
|
|
|
3
|
-
var
|
|
3
|
+
var _chunkCLJ3DWTAcjs = require('./chunk-CLJ3DWTA.cjs');
|
|
4
4
|
|
|
5
5
|
// src/services/a2a.service.ts
|
|
6
6
|
var _crypto = require('crypto');
|
|
@@ -54,15 +54,9 @@ var A2AService = (_class = class {
|
|
|
54
54
|
};
|
|
55
55
|
eventBus.publish(initialTask);
|
|
56
56
|
}
|
|
57
|
-
const workingStatusUpdate = this.createTaskStatusUpdateEvent(
|
|
58
|
-
taskId,
|
|
59
|
-
threadId,
|
|
60
|
-
"working"
|
|
61
|
-
);
|
|
62
|
-
eventBus.publish(workingStatusUpdate);
|
|
63
57
|
const message = userMessage.parts.filter((part) => part.kind === "text").map((part) => part.text).join("\n");
|
|
64
58
|
if (message.length === 0) {
|
|
65
|
-
|
|
59
|
+
_chunkCLJ3DWTAcjs.loggers.server.warn(`Empty message received for task ${taskId}.`);
|
|
66
60
|
const failureUpdate = this.createTaskStatusUpdateEvent(
|
|
67
61
|
taskId,
|
|
68
62
|
threadId,
|
|
@@ -81,7 +75,7 @@ var A2AService = (_class = class {
|
|
|
81
75
|
let finalResponseText = "";
|
|
82
76
|
for await (const event of stream) {
|
|
83
77
|
if (this.canceledTasks.has(taskId)) {
|
|
84
|
-
|
|
78
|
+
_chunkCLJ3DWTAcjs.loggers.server.info(`Task ${taskId} was canceled.`);
|
|
85
79
|
const canceledUpdate = this.createTaskStatusUpdateEvent(
|
|
86
80
|
taskId,
|
|
87
81
|
threadId,
|
|
@@ -92,22 +86,14 @@ var A2AService = (_class = class {
|
|
|
92
86
|
}
|
|
93
87
|
if (event.event === "text_chunk") {
|
|
94
88
|
finalResponseText += event.data.delta;
|
|
95
|
-
} else if (event.event === "
|
|
96
|
-
const
|
|
97
|
-
taskId,
|
|
98
|
-
threadId,
|
|
99
|
-
"working",
|
|
100
|
-
JSON.stringify(event.data)
|
|
101
|
-
);
|
|
102
|
-
eventBus.publish(toolStartUpdate);
|
|
103
|
-
} else if (event.event === "tool_output") {
|
|
104
|
-
const toolOutputUpdate = this.createTaskStatusUpdateEvent(
|
|
89
|
+
} else if (event.event === "thinking_process") {
|
|
90
|
+
const thinkingProcessUpdate = this.createTaskStatusUpdateEvent(
|
|
105
91
|
taskId,
|
|
106
92
|
threadId,
|
|
107
93
|
"working",
|
|
108
94
|
JSON.stringify(event.data)
|
|
109
95
|
);
|
|
110
|
-
eventBus.publish(
|
|
96
|
+
eventBus.publish(thinkingProcessUpdate);
|
|
111
97
|
}
|
|
112
98
|
}
|
|
113
99
|
const finalUpdate = this.createTaskStatusUpdateEvent(
|
|
@@ -117,9 +103,9 @@ var A2AService = (_class = class {
|
|
|
117
103
|
finalResponseText
|
|
118
104
|
);
|
|
119
105
|
eventBus.publish(finalUpdate);
|
|
120
|
-
|
|
106
|
+
_chunkCLJ3DWTAcjs.loggers.server.info(`Task ${taskId} completed successfully.`);
|
|
121
107
|
} catch (error) {
|
|
122
|
-
|
|
108
|
+
_chunkCLJ3DWTAcjs.loggers.server.error(`Error processing task ${taskId}:`, error);
|
|
123
109
|
const errorUpdate = this.createTaskStatusUpdateEvent(
|
|
124
110
|
taskId,
|
|
125
111
|
threadId,
|
|
@@ -134,4 +120,4 @@ var A2AService = (_class = class {
|
|
|
134
120
|
|
|
135
121
|
|
|
136
122
|
exports.A2AService = A2AService;
|
|
137
|
-
//# sourceMappingURL=chunk-
|
|
123
|
+
//# sourceMappingURL=chunk-RCOESZIX.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
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,18 +1,18 @@
|
|
|
1
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
2
|
|
|
3
|
-
var
|
|
3
|
+
var _chunkU47SG7XGcjs = require('./chunk-U47SG7XG.cjs');
|
|
4
4
|
|
|
5
5
|
|
|
6
|
-
var
|
|
6
|
+
var _chunkXHTEJE4Ecjs = require('./chunk-XHTEJE4E.cjs');
|
|
7
7
|
|
|
8
8
|
|
|
9
|
-
var
|
|
9
|
+
var _chunkNEWJ7PXHcjs = require('./chunk-NEWJ7PXH.cjs');
|
|
10
10
|
|
|
11
11
|
|
|
12
12
|
var _chunkZ6TQ7TFOcjs = require('./chunk-Z6TQ7TFO.cjs');
|
|
13
13
|
|
|
14
14
|
|
|
15
|
-
var
|
|
15
|
+
var _chunkCLJ3DWTAcjs = require('./chunk-CLJ3DWTA.cjs');
|
|
16
16
|
|
|
17
17
|
// src/services/query.service.ts
|
|
18
18
|
var _crypto = require('crypto');
|
|
@@ -25,11 +25,11 @@ var QueryService = class {
|
|
|
25
25
|
constructor(modelModule, a2aModule, mcpModule, memoryModule) {
|
|
26
26
|
this.modelModule = modelModule;
|
|
27
27
|
this.memoryModule = memoryModule;
|
|
28
|
-
this.intentTriggerService = new (0,
|
|
28
|
+
this.intentTriggerService = new (0, _chunkNEWJ7PXHcjs.IntentTriggerService)(
|
|
29
29
|
modelModule,
|
|
30
30
|
memoryModule
|
|
31
31
|
);
|
|
32
|
-
this.intentFulfillService = new (0,
|
|
32
|
+
this.intentFulfillService = new (0, _chunkU47SG7XGcjs.IntentFulfillService)(
|
|
33
33
|
modelModule,
|
|
34
34
|
a2aModule,
|
|
35
35
|
mcpModule,
|
|
@@ -65,7 +65,7 @@ var QueryService = class {
|
|
|
65
65
|
}
|
|
66
66
|
threadId ??= _crypto.randomUUID.call(void 0, );
|
|
67
67
|
if (!thread) {
|
|
68
|
-
const title = await
|
|
68
|
+
const title = await _chunkXHTEJE4Ecjs.generateTitle.call(void 0, this.modelModule, query, options);
|
|
69
69
|
const metadata = await _optionalChain([threadMemory, 'optionalAccess', _6 => _6.createThread, 'call', _7 => _7(
|
|
70
70
|
type,
|
|
71
71
|
userId,
|
|
@@ -73,10 +73,10 @@ var QueryService = class {
|
|
|
73
73
|
title
|
|
74
74
|
)]) || { type, userId, threadId, title };
|
|
75
75
|
thread = { ...metadata, messages: [] };
|
|
76
|
-
|
|
76
|
+
_chunkCLJ3DWTAcjs.loggers.intent.info(`Create new thread: ${threadId}`);
|
|
77
77
|
}
|
|
78
78
|
const triggeredIntent = await this.intentTriggerService.intentTriggering(query, thread);
|
|
79
|
-
|
|
79
|
+
_chunkCLJ3DWTAcjs.loggers.intent.debug("Triggered intents", { triggeredIntent });
|
|
80
80
|
await _optionalChain([threadMemory, 'optionalAccess', _8 => _8.addMessagesToThread, 'call', _9 => _9(userId, threadId, [
|
|
81
81
|
{
|
|
82
82
|
messageId: _crypto.randomUUID.call(void 0, ),
|
|
@@ -102,4 +102,4 @@ var QueryService = class {
|
|
|
102
102
|
|
|
103
103
|
|
|
104
104
|
exports.QueryService = QueryService;
|
|
105
|
-
//# sourceMappingURL=chunk-
|
|
105
|
+
//# sourceMappingURL=chunk-RVT67VJL.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-
|
|
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"]}
|
|
@@ -3,7 +3,7 @@
|
|
|
3
3
|
var _chunk7HBOMBZGcjs = require('./chunk-7HBOMBZG.cjs');
|
|
4
4
|
|
|
5
5
|
|
|
6
|
-
var
|
|
6
|
+
var _chunkCLJ3DWTAcjs = require('./chunk-CLJ3DWTA.cjs');
|
|
7
7
|
|
|
8
8
|
// src/services/intents/fulfill.service.ts
|
|
9
9
|
var _crypto = require('crypto');
|
|
@@ -32,7 +32,7 @@ var IntentFulfillService = class {
|
|
|
32
32
|
thread.messages.push(newMessage);
|
|
33
33
|
await _optionalChain([threadMemory, 'optionalAccess', _4 => _4.addMessagesToThread, 'call', _5 => _5(userId, threadId, [newMessage])]);
|
|
34
34
|
} catch (error) {
|
|
35
|
-
|
|
35
|
+
_chunkCLJ3DWTAcjs.loggers.intentStream.error("Error adding message to thread", error);
|
|
36
36
|
}
|
|
37
37
|
}
|
|
38
38
|
/**
|
|
@@ -61,7 +61,7 @@ var IntentFulfillService = class {
|
|
|
61
61
|
thread,
|
|
62
62
|
systemPrompt: fulfillPrompt.trim()
|
|
63
63
|
});
|
|
64
|
-
|
|
64
|
+
_chunkCLJ3DWTAcjs.loggers.intent.debug("Intent fulfillment start", {
|
|
65
65
|
threadId: thread.threadId,
|
|
66
66
|
messages
|
|
67
67
|
});
|
|
@@ -77,7 +77,7 @@ var IntentFulfillService = class {
|
|
|
77
77
|
modelOptions
|
|
78
78
|
);
|
|
79
79
|
const { content, toolCalls } = response;
|
|
80
|
-
|
|
80
|
+
_chunkCLJ3DWTAcjs.loggers.intent.debug("Tool calls", {
|
|
81
81
|
threadId: thread.threadId,
|
|
82
82
|
content,
|
|
83
83
|
toolCalls
|
|
@@ -91,21 +91,26 @@ var IntentFulfillService = class {
|
|
|
91
91
|
let toolResult = "";
|
|
92
92
|
if (this.mcpModule && selectedTool.protocol === "MCP" /* MCP */) {
|
|
93
93
|
const toolArgs = toolCall.arguments;
|
|
94
|
-
|
|
94
|
+
_chunkCLJ3DWTAcjs.loggers.intent.debug("MCP tool call", { toolName, toolArgs });
|
|
95
95
|
toolResult = await this.mcpModule.useTool(selectedTool, toolArgs);
|
|
96
96
|
} else if (this.a2aModule && selectedTool.protocol === "A2A" /* A2A */) {
|
|
97
|
-
|
|
97
|
+
const a2aGenerator = this.a2aModule.useTool(
|
|
98
98
|
selectedTool,
|
|
99
99
|
query,
|
|
100
100
|
thread.threadId
|
|
101
101
|
);
|
|
102
|
+
let result = await a2aGenerator.next();
|
|
103
|
+
while (!result.done) {
|
|
104
|
+
result = await a2aGenerator.next();
|
|
105
|
+
}
|
|
106
|
+
toolResult = result.value;
|
|
102
107
|
} else {
|
|
103
|
-
|
|
108
|
+
_chunkCLJ3DWTAcjs.loggers.intent.warn(
|
|
104
109
|
`Unrecognized tool type: ${selectedTool.protocol}`
|
|
105
110
|
);
|
|
106
111
|
continue;
|
|
107
112
|
}
|
|
108
|
-
|
|
113
|
+
_chunkCLJ3DWTAcjs.loggers.intent.debug("Tool Result", {
|
|
109
114
|
threadId: thread.threadId,
|
|
110
115
|
toolResult
|
|
111
116
|
});
|
|
@@ -129,8 +134,8 @@ var IntentFulfillService = class {
|
|
|
129
134
|
let finalResponseText = "";
|
|
130
135
|
for (let i = 0; i < intents.length; i++) {
|
|
131
136
|
const { subquery, intent, actionPlan } = intents[i];
|
|
132
|
-
|
|
133
|
-
|
|
137
|
+
_chunkCLJ3DWTAcjs.loggers.intent.info(`Process query: ${subquery}, ${_optionalChain([intent, 'optionalAccess', _9 => _9.name])}`);
|
|
138
|
+
_chunkCLJ3DWTAcjs.loggers.intent.info(`Action plan: ${actionPlan}`);
|
|
134
139
|
finalResponseText !== "" && thread.messages.push({
|
|
135
140
|
messageId: _crypto.randomUUID.call(void 0, ),
|
|
136
141
|
role: "MODEL" /* MODEL */,
|
|
@@ -160,4 +165,4 @@ var IntentFulfillService = class {
|
|
|
160
165
|
|
|
161
166
|
|
|
162
167
|
exports.IntentFulfillService = IntentFulfillService;
|
|
163
|
-
//# sourceMappingURL=chunk-
|
|
168
|
+
//# sourceMappingURL=chunk-U47SG7XG.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
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,6 +1,6 @@
|
|
|
1
1
|
"use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _nullishCoalesce(lhs, rhsFn) { if (lhs != null) { return lhs; } else { return rhsFn(); } }
|
|
2
2
|
|
|
3
|
-
var
|
|
3
|
+
var _chunkCLJ3DWTAcjs = require('./chunk-CLJ3DWTA.cjs');
|
|
4
4
|
|
|
5
5
|
// src/services/utils/query.common.ts
|
|
6
6
|
async function generateTitle(modelModule, query, options) {
|
|
@@ -24,7 +24,7 @@ Always respond in the same language as the user's input.`
|
|
|
24
24
|
);
|
|
25
25
|
return response.content || DEFAULT_TITLE;
|
|
26
26
|
} catch (error) {
|
|
27
|
-
|
|
27
|
+
_chunkCLJ3DWTAcjs.loggers.intent.error("Error generating title", {
|
|
28
28
|
error,
|
|
29
29
|
query
|
|
30
30
|
});
|
|
@@ -35,4 +35,4 @@ Always respond in the same language as the user's input.`
|
|
|
35
35
|
|
|
36
36
|
|
|
37
37
|
exports.generateTitle = generateTitle;
|
|
38
|
-
//# sourceMappingURL=chunk-
|
|
38
|
+
//# sourceMappingURL=chunk-XHTEJE4E.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-
|
|
1
|
+
{"version":3,"sources":["/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-XHTEJE4E.cjs","../../src/services/utils/query.common.ts"],"names":[],"mappings":"AAAA;AACE;AACF,wDAA6B;AAC7B;AACA;ACDA,MAAA,SAAsB,aAAA,CACrB,WAAA,EACA,KAAA,EACA,OAAA,EACkB;AAClB,EAAA,MAAM,cAAA,EAAgB,UAAA;AACtB,EAAA,IAAI;AACH,IAAA,MAAM,cAAA,EAAgB,WAAA,CAAY,QAAA,CAAS,CAAA;AAC3C,IAAA,MAAM,aAAA,EAAe,WAAA,CAAY,eAAA,CAAgB,CAAA;AACjD,IAAA,MAAM,SAAA,EAAW,aAAA,CAAc,gBAAA,CAAiB;AAAA,MAC/C,KAAA;AAAA,MACA,YAAA,EAAc,CAAA;AAAA,SAAA,EAAA,iBACN,IAAI,IAAA,CAAK,CAAA,CAAA,CAAE,kBAAA,CAAmB,CAAC,CAAA;AAAA;AAAA;AAAA;AAAA;AAAA,wDAAA;AAAA,IAMxC,CAAC,CAAA;AACD,IAAA,MAAM,SAAA,EAAW,MAAM,aAAA,CAAc,KAAA;AAAA,MACpC,QAAA;AAAA,uBACA,OAAA,UAAW;AAAA,IACZ,CAAA;AACA,IAAA,OAAO,QAAA,CAAS,QAAA,GAAW,aAAA;AAAA,EAC5B,EAAA,MAAA,CAAS,KAAA,EAAO;AACf,IAAA,yBAAA,CAAQ,MAAA,CAAO,KAAA,CAAM,wBAAA,EAA0B;AAAA,MAC9C,KAAA;AAAA,MACA;AAAA,IACD,CAAC,CAAA;AACD,IAAA,OAAO,aAAA;AAAA,EACR;AACD;ADDA;AACA;AACE;AACF,sCAAC","file":"/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-XHTEJE4E.cjs","sourcesContent":[null,"import type { ModelFetchOptions, ModelModule } from \"@/modules\";\nimport { loggers } from \"@/utils/logger.js\";\n\nexport async function generateTitle(\n\tmodelModule: ModelModule,\n\tquery: string,\n\toptions?: ModelFetchOptions,\n): Promise<string> {\n\tconst DEFAULT_TITLE = \"New Chat\";\n\ttry {\n\t\tconst modelInstance = modelModule.getModel();\n\t\tconst modelOptions = modelModule.getModelOptions();\n\t\tconst messages = modelInstance.generateMessages({\n\t\t\tquery,\n\t\t\tsystemPrompt: `\nToday is ${new Date().toLocaleDateString()}.\nYou are a helpful assistant that generates titles for conversations.\nPlease analyze the user's query and create a concise title that accurately reflects the conversation's core topic.\nThe title must be no more than 5 words long.\nRespond with only the title. Do not include any punctuation or extra explanations.\nAlways respond in the same language as the user's input.`,\n\t\t});\n\t\tconst response = await modelInstance.fetch(\n\t\t\tmessages,\n\t\t\toptions ?? modelOptions,\n\t\t);\n\t\treturn response.content || DEFAULT_TITLE;\n\t} catch (error) {\n\t\tloggers.intent.error(\"Error generating title\", {\n\t\t\terror,\n\t\t\tquery,\n\t\t});\n\t\treturn DEFAULT_TITLE;\n\t}\n}\n"]}
|