@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
|
@@ -1,9 +1,12 @@
|
|
|
1
1
|
import {
|
|
2
2
|
createFulfillPrompt
|
|
3
3
|
} from "./chunk-7BH6AYP7.js";
|
|
4
|
+
import {
|
|
5
|
+
getManifest
|
|
6
|
+
} from "./chunk-2J2TQRP4.js";
|
|
4
7
|
import {
|
|
5
8
|
loggers
|
|
6
|
-
} from "./chunk-
|
|
9
|
+
} from "./chunk-VUMI4XOY.js";
|
|
7
10
|
|
|
8
11
|
// src/services/intents/fulfill-stream.service.ts
|
|
9
12
|
import { randomUUID } from "crypto";
|
|
@@ -104,7 +107,6 @@ var IntentFulfillStreamService = class {
|
|
|
104
107
|
});
|
|
105
108
|
if (assembledToolCalls.length > 0) {
|
|
106
109
|
for (const toolCall of assembledToolCalls) {
|
|
107
|
-
const toolCallId = randomUUID();
|
|
108
110
|
const toolName = toolCall.function.name;
|
|
109
111
|
let selectedTool;
|
|
110
112
|
for (const [index, toolTmp] of tools.entries()) {
|
|
@@ -119,51 +121,40 @@ 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: `[${getManifest().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
|
-
const toolArgs = JSON.parse(toolCall.function.arguments);
|
|
125
|
-
yield {
|
|
126
|
-
event: "tool_start",
|
|
127
|
-
data: {
|
|
128
|
-
toolCallId,
|
|
129
|
-
protocol: "MCP" /* MCP */,
|
|
130
|
-
toolName,
|
|
131
|
-
toolArgs
|
|
132
|
-
}
|
|
133
|
-
};
|
|
134
135
|
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
|
-
yield {
|
|
138
|
-
event: "tool_start",
|
|
139
|
-
data: {
|
|
140
|
-
toolCallId,
|
|
141
|
-
protocol: "A2A" /* A2A */,
|
|
142
|
-
toolName,
|
|
143
|
-
toolArgs: null
|
|
144
|
-
}
|
|
145
|
-
};
|
|
146
138
|
loggers.intent.info("A2A tool call", { toolName });
|
|
147
|
-
|
|
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
|
loggers.intent.warn(
|
|
154
154
|
`Unrecognized tool type: ${selectedTool.protocol}`
|
|
155
155
|
);
|
|
156
156
|
continue;
|
|
157
157
|
}
|
|
158
|
-
yield {
|
|
159
|
-
event: "tool_output",
|
|
160
|
-
data: {
|
|
161
|
-
toolCallId,
|
|
162
|
-
protocol: selectedTool.protocol,
|
|
163
|
-
toolName,
|
|
164
|
-
result: toolResult
|
|
165
|
-
}
|
|
166
|
-
};
|
|
167
158
|
loggers.intent.debug("Tool Result", { toolResult });
|
|
168
159
|
processList.push(toolResult);
|
|
169
160
|
modelInstance.appendMessages(messages, toolResult);
|
|
@@ -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: `[${getManifest().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 = "";
|
|
@@ -246,4 +232,4 @@ var IntentFulfillStreamService = class {
|
|
|
246
232
|
export {
|
|
247
233
|
IntentFulfillStreamService
|
|
248
234
|
};
|
|
249
|
-
//# sourceMappingURL=chunk-
|
|
235
|
+
//# sourceMappingURL=chunk-A5PRJ33H.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/services/intents/fulfill-stream.service.ts"],"sourcesContent":["import { randomUUID } from \"node:crypto\";\nimport { getManifest } from \"@/config/manifest\";\nimport type {\n\tA2AModule,\n\tMCPModule,\n\tMemoryModule,\n\tModelModule,\n} from \"@/modules\";\nimport { CONNECTOR_PROTOCOL_TYPE, type ConnectorTool } from \"@/types/connector\";\nimport {\n\ttype Intent,\n\ttype MessageObject,\n\tMessageRole,\n\ttype ThreadObject,\n\ttype TriggeredIntent,\n} from \"@/types/memory\";\nimport type { StreamEvent } from \"@/types/stream\";\nimport { loggers } from \"@/utils/logger\";\nimport { createFulfillPrompt } from \"../utils/fulfill.common\";\n\nexport class IntentFulfillStreamService {\n\tprivate modelModule: ModelModule;\n\tprivate a2aModule?: A2AModule;\n\tprivate mcpModule?: MCPModule;\n\tprivate memoryModule?: MemoryModule;\n\n\tconstructor(\n\t\tmodelModule: ModelModule,\n\t\ta2aModule?: A2AModule,\n\t\tmcpModule?: MCPModule,\n\t\tmemoryModule?: MemoryModule,\n\t) {\n\t\tthis.modelModule = modelModule;\n\t\tthis.a2aModule = a2aModule;\n\t\tthis.mcpModule = mcpModule;\n\t\tthis.memoryModule = memoryModule;\n\t}\n\n\tprivate async addToThreadMessages(\n\t\tthread: ThreadObject,\n\t\tparams: {\n\t\t\trole: MessageRole;\n\t\t\tcontent: string;\n\t\t\tmetadata?: Record<string, unknown>;\n\t\t},\n\t) {\n\t\ttry {\n\t\t\tconst threadMemory = this.memoryModule?.getThreadMemory();\n\t\t\tconst { userId, threadId } = thread;\n\t\t\tconst newMessage: MessageObject = {\n\t\t\t\tmessageId: randomUUID(),\n\t\t\t\trole: params.role,\n\t\t\t\ttimestamp: Date.now(),\n\t\t\t\tcontent: { type: \"text\", parts: [params.content] },\n\t\t\t\tmetadata: params.metadata,\n\t\t\t};\n\t\t\tthread.messages.push(newMessage);\n\t\t\tawait threadMemory?.addMessagesToThread(userId, threadId, [newMessage]);\n\t\t} catch (error) {\n\t\t\tloggers.intentStream.error(\"Error adding message to thread\", error);\n\t\t}\n\t}\n\n\t/**\n\t * Fulfills the detected intent by generating a streaming response.\n\t *\n\t * Manages the complete inference loop including:\n\t * - Loading prompts and conversation history\n\t * - Collecting available tools from modules\n\t * - Executing model inference with tool support\n\t * - Processing tool calls iteratively until completion\n\t * - Streaming results as Server-Sent Events\n\t *\n\t * @param query - The user's input query\n\t * @param threadId - Thread identifier for context\n\t * @param thread - Previous conversation history\n\t * @param intent - Optional detected intent with custom prompt\n\t * @returns AsyncGenerator yielding StreamEvent objects\n\t */\n\tprivate async *intentFulfilling(\n\t\tquery: string,\n\t\tthread: ThreadObject,\n\t\tintent?: Intent,\n\t): AsyncGenerator<StreamEvent> {\n\t\tconst agentMemory = this.memoryModule?.getAgentMemory();\n\t\tconst fulfillPrompt = await createFulfillPrompt(agentMemory, intent);\n\n\t\tconst modelInstance = this.modelModule.getModel();\n\t\tconst modelOptions = this.modelModule.getModelOptions();\n\t\tconst messages = modelInstance.generateMessages({\n\t\t\tquery,\n\t\t\tthread,\n\t\t\tsystemPrompt: fulfillPrompt.trim(),\n\t\t});\n\n\t\tloggers.intent.debug(\"Intent fulfillment start\", {\n\t\t\tthreadId: thread.threadId,\n\t\t\tmessages,\n\t\t});\n\n\t\tconst tools: ConnectorTool[] = [];\n\t\tthis.mcpModule && tools.push(...this.mcpModule.getTools());\n\t\tthis.a2aModule && tools.push(...(await this.a2aModule.getTools()));\n\n\t\tconst processList: string[] = [];\n\n\t\twhile (true) {\n\t\t\tconst functions = modelInstance.convertToolsToFunctions(tools);\n\t\t\tconst responseStream = await modelInstance.fetchStreamWithContextMessage(\n\t\t\t\tmessages,\n\t\t\t\tfunctions,\n\t\t\t\tmodelOptions,\n\t\t\t);\n\n\t\t\tconst assembledToolCalls: {\n\t\t\t\tid: string;\n\t\t\t\ttype: \"function\";\n\t\t\t\tfunction: { name: string; arguments: string };\n\t\t\t}[] = [];\n\n\t\t\tfor await (const chunk of responseStream) {\n\t\t\t\tconst delta = chunk.delta;\n\t\t\t\tif (delta?.tool_calls) {\n\t\t\t\t\tfor (const { index, id, function: func } of delta.tool_calls) {\n\t\t\t\t\t\tassembledToolCalls[index] ??= {\n\t\t\t\t\t\t\tid: \"\",\n\t\t\t\t\t\t\ttype: \"function\",\n\t\t\t\t\t\t\tfunction: { name: \"\", arguments: \"\" },\n\t\t\t\t\t\t};\n\n\t\t\t\t\t\tif (id) assembledToolCalls[index].id = id;\n\t\t\t\t\t\tif (func?.name) assembledToolCalls[index].function.name = func.name;\n\t\t\t\t\t\tif (func?.arguments)\n\t\t\t\t\t\t\tassembledToolCalls[index].function.arguments += func.arguments;\n\t\t\t\t\t}\n\t\t\t\t} else if (chunk.delta?.content) {\n\t\t\t\t\tyield {\n\t\t\t\t\t\tevent: \"text_chunk\",\n\t\t\t\t\t\tdata: { delta: chunk.delta.content },\n\t\t\t\t\t};\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tloggers.intentStream.debug(\"assembledToolCalls\", {\n\t\t\t\tthreadId: thread.threadId,\n\t\t\t\tassembledToolCalls,\n\t\t\t});\n\n\t\t\tif (assembledToolCalls.length > 0) {\n\t\t\t\tfor (const toolCall of assembledToolCalls) {\n\t\t\t\t\tconst toolName = toolCall.function.name;\n\t\t\t\t\tlet selectedTool: ConnectorTool | undefined;\n\t\t\t\t\tfor (const [index, toolTmp] of tools.entries()) {\n\t\t\t\t\t\tif (toolTmp.toolName === toolName) {\n\t\t\t\t\t\t\tif (toolTmp.protocol === CONNECTOR_PROTOCOL_TYPE.A2A) {\n\t\t\t\t\t\t\t\t// remove used tool to prevent infinite loop\n\t\t\t\t\t\t\t\tselectedTool = tools.splice(index, 1)[0];\n\t\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tselectedTool = toolTmp;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\n\t\t\t\t\tif (!selectedTool) {\n\t\t\t\t\t\t// it cannot be happened...\n\t\t\t\t\t\tcontinue;\n\t\t\t\t\t}\n\n\t\t\t\t\tconst toolArgs = JSON.parse(toolCall.function.arguments);\n\t\t\t\t\tconst thinkData = {\n\t\t\t\t\t\ttitle: `[${getManifest().name}] ${selectedTool.protocol} 실행: ${toolName}`,\n\t\t\t\t\t\tdescription: `${toolArgs.thinking_text || \"\"}`,\n\t\t\t\t\t};\n\t\t\t\t\tyield {\n\t\t\t\t\t\tevent: \"thinking_process\",\n\t\t\t\t\t\tdata: thinkData,\n\t\t\t\t\t};\n\n\t\t\t\t\tlet toolResult = \"\";\n\t\t\t\t\tif (\n\t\t\t\t\t\tthis.mcpModule &&\n\t\t\t\t\t\tselectedTool.protocol === CONNECTOR_PROTOCOL_TYPE.MCP\n\t\t\t\t\t) {\n\t\t\t\t\t\tloggers.intent.info(\"MCP tool call\", { toolName, toolArgs });\n\t\t\t\t\t\ttoolResult = await this.mcpModule.useTool(selectedTool, toolArgs);\n\t\t\t\t\t} else if (\n\t\t\t\t\t\tthis.a2aModule &&\n\t\t\t\t\t\tselectedTool.protocol === CONNECTOR_PROTOCOL_TYPE.A2A\n\t\t\t\t\t) {\n\t\t\t\t\t\tloggers.intent.info(\"A2A tool call\", { toolName });\n\t\t\t\t\t\tconst a2aStream = this.a2aModule.useTool(\n\t\t\t\t\t\t\tselectedTool,\n\t\t\t\t\t\t\tquery,\n\t\t\t\t\t\t\tthread.threadId,\n\t\t\t\t\t\t);\n\t\t\t\t\t\t// yield intermediate events and get final result\n\t\t\t\t\t\tlet result = await a2aStream.next();\n\t\t\t\t\t\twhile (!result.done) {\n\t\t\t\t\t\t\tif (result.value.event === \"thinking_process\") {\n\t\t\t\t\t\t\t\tyield result.value;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\tresult = await a2aStream.next();\n\t\t\t\t\t\t}\n\t\t\t\t\t\ttoolResult = result.value;\n\t\t\t\t\t} else {\n\t\t\t\t\t\t// Unrecognized tool type. It cannot be happened...\n\t\t\t\t\t\tloggers.intent.warn(\n\t\t\t\t\t\t\t`Unrecognized tool type: ${selectedTool.protocol}`,\n\t\t\t\t\t\t);\n\t\t\t\t\t\tcontinue;\n\t\t\t\t\t}\n\n\t\t\t\t\tloggers.intent.debug(\"Tool Result\", { toolResult });\n\n\t\t\t\t\tprocessList.push(toolResult);\n\t\t\t\t\tmodelInstance.appendMessages(messages, toolResult);\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tbreak;\n\t\t\t}\n\t\t}\n\n\t\tloggers.intent.debug(\"Intent fulfillment completed\", {\n\t\t\tthreadId: thread.threadId,\n\t\t\ttoolCallsExecuted: processList.length,\n\t\t\tintentName: intent?.name,\n\t\t});\n\t}\n\n\t/**\n\t * Detects the intent from context.\n\t *\n\t * @param intents - The user's input query\n\t * @param thread - The thread history\n\t * @returns The detected intent\n\t */\n\tpublic async *intentFulfillStream(\n\t\tintents: Array<TriggeredIntent>,\n\t\tthread: ThreadObject,\n\t): AsyncGenerator<StreamEvent> {\n\t\tconst streamStartTime = Date.now();\n\t\tloggers.intentStream.info(\"Stream session started\", {\n\t\t\tthreadId: thread.threadId,\n\t\t\tintentCount: intents.length,\n\t\t\tstartTime: new Date(streamStartTime).toISOString(),\n\t\t});\n\n\t\tlet finalResponseText = \"\";\n\n\t\tfor (let i = 0; i < intents.length; i++) {\n\t\t\tconst { subquery, intent, actionPlan } = intents[i];\n\t\t\tloggers.intent.info(`Process query: ${subquery}, ${intent?.name}`);\n\t\t\tloggers.intent.info(`Action plan: ${actionPlan}`);\n\n\t\t\t// only use for inference, not stored in memory\n\t\t\tfinalResponseText !== \"\" &&\n\t\t\t\tthread.messages.push({\n\t\t\t\t\tmessageId: randomUUID(),\n\t\t\t\t\trole: MessageRole.MODEL,\n\t\t\t\t\ttimestamp: Date.now(),\n\t\t\t\t\tcontent: { type: \"text\", parts: [finalResponseText] },\n\t\t\t\t\tmetadata: { isThinking: true },\n\t\t\t\t});\n\n\t\t\tconst thinkData = {\n\t\t\t\ttitle: `[${getManifest().name}] ${subquery}`,\n\t\t\t\tdescription: actionPlan || \"\",\n\t\t\t};\n\t\t\tyield {\n\t\t\t\tevent: \"thinking_process\",\n\t\t\t\tdata: thinkData,\n\t\t\t};\n\n\t\t\tconst stream = this.intentFulfilling(subquery, thread, intent);\n\n\t\t\tfinalResponseText = \"\";\n\t\t\tfor await (const event of stream) {\n\t\t\t\tif (event.event === \"text_chunk\" && event.data.delta) {\n\t\t\t\t\tfinalResponseText += event.data.delta;\n\t\t\t\t}\n\n\t\t\t\tif (event.event === \"text_chunk\" && i !== intents.length - 1) {\n\t\t\t\t\tcontinue; // skip intermediate text_chunk events\n\t\t\t\t}\n\t\t\t\tyield event;\n\t\t\t}\n\t\t}\n\n\t\tawait this.addToThreadMessages(thread, {\n\t\t\trole: MessageRole.MODEL,\n\t\t\tcontent: finalResponseText,\n\t\t});\n\n\t\tconst streamEndTime = Date.now();\n\t\tconst streamDuration = streamEndTime - streamStartTime;\n\n\t\tloggers.intentStream.info(\"Stream session completed\", {\n\t\t\tthreadId: thread.threadId,\n\t\t\tduration: `${streamDuration}ms`,\n\t\t\tendTime: new Date(streamEndTime).toISOString(),\n\t\t});\n\t}\n}\n"],"mappings":"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","names":[]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/modules/a2a/a2a.connector.ts"],"sourcesContent":["import type { Client as A2AClient } from \"@a2a-js/sdk/client\";\nimport {\n\tCONNECTOR_PROTOCOL_TYPE,\n\ttype IAgentConnector,\n} from \"@/types/connector.js\";\n\nexport class A2AConnector implements IAgentConnector {\n\tpublic name: string;\n\tpublic protocol: CONNECTOR_PROTOCOL_TYPE = CONNECTOR_PROTOCOL_TYPE.A2A;\n\tpublic enabled: boolean;\n\tpublic url: string;\n\tpublic client: A2AClient | null = null;\n\n\tconstructor(name: string, url: string) {\n\t\tthis.name = name;\n\t\tthis.enabled = true;\n\t\tthis.url = url;\n\t}\n\n\tpublic enable(): void {\n\t\tthis.enabled = true;\n\t}\n\n\tpublic disable(): void {\n\t\tthis.enabled = false;\n\t}\n}\n"],"mappings":";AAMO,IAAM,eAAN,MAA8C;AAAA,EAC7C;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA,SAA2B;AAAA,EAElC,YAAY,MAAc,KAAa;AACtC,SAAK,OAAO;AACZ,SAAK,UAAU;AACf,SAAK,MAAM;AAAA,EACZ;AAAA,EAEO,SAAe;AACrB,SAAK,UAAU;AAAA,EAChB;AAAA,EAEO,UAAgB;AACtB,SAAK,UAAU;AAAA,EAChB;AACD;","names":[]}
|
|
@@ -1,13 +1,13 @@
|
|
|
1
1
|
import {
|
|
2
2
|
A2AConnector
|
|
3
|
-
} from "./chunk-
|
|
3
|
+
} from "./chunk-BZZDVW26.js";
|
|
4
4
|
import {
|
|
5
5
|
loggers
|
|
6
|
-
} from "./chunk-
|
|
6
|
+
} from "./chunk-VUMI4XOY.js";
|
|
7
7
|
|
|
8
8
|
// src/modules/a2a/a2a.module.ts
|
|
9
9
|
import { randomUUID } from "crypto";
|
|
10
|
-
import {
|
|
10
|
+
import { ClientFactory } from "@a2a-js/sdk/client";
|
|
11
11
|
var A2AModule = class {
|
|
12
12
|
/** Map of A2A server URLs to their corresponding tool instances */
|
|
13
13
|
a2aConnectors = /* @__PURE__ */ new Map();
|
|
@@ -33,8 +33,10 @@ var A2AModule = class {
|
|
|
33
33
|
}
|
|
34
34
|
return connectors;
|
|
35
35
|
}
|
|
36
|
-
getOrCreateClient(connector) {
|
|
37
|
-
|
|
36
|
+
async getOrCreateClient(connector) {
|
|
37
|
+
if (!connector.client) {
|
|
38
|
+
connector.client = await new ClientFactory().createFromUrl(connector.url);
|
|
39
|
+
}
|
|
38
40
|
return connector.client;
|
|
39
41
|
}
|
|
40
42
|
/**
|
|
@@ -52,13 +54,24 @@ var A2AModule = class {
|
|
|
52
54
|
continue;
|
|
53
55
|
}
|
|
54
56
|
try {
|
|
55
|
-
const client = this.getOrCreateClient(conn);
|
|
57
|
+
const client = await this.getOrCreateClient(conn);
|
|
56
58
|
const card = await client.getAgentCard();
|
|
57
59
|
const tool = {
|
|
58
60
|
toolName: card.name.replaceAll(" ", "-"),
|
|
59
61
|
connectorName: name,
|
|
60
62
|
protocol: "A2A" /* A2A */,
|
|
61
|
-
description: card.description
|
|
63
|
+
description: card.description,
|
|
64
|
+
// add thinking_text inputSchema
|
|
65
|
+
inputSchema: {
|
|
66
|
+
type: "object",
|
|
67
|
+
properties: {
|
|
68
|
+
thinking_text: {
|
|
69
|
+
type: "string",
|
|
70
|
+
description: "\uC0AC\uC6A9\uC790\uC758 \uC694\uCCAD\uC744 \uD574\uACB0\uD558\uAE30 \uC704\uD574 \uC774 \uB3C4\uAD6C\uB97C \uC120\uD0DD\uD55C \uAD6C\uCCB4\uC801\uC778 \uC774\uC720\uC640 \uBAA9\uC801 (Why & What). \uD55C\uB450\uC904 \uC815\uB3C4\uC758 \uBD84\uB7C9\uC73C\uB85C \uC785\uB825 \uC5B8\uC5B4\uC640 \uAC19\uC740 \uC5B8\uC5B4\uB85C \uC0DD\uC131\uD55C\uB2E4."
|
|
71
|
+
}
|
|
72
|
+
},
|
|
73
|
+
required: ["thinking_text"]
|
|
74
|
+
}
|
|
62
75
|
};
|
|
63
76
|
tools.push(tool);
|
|
64
77
|
} catch (_error) {
|
|
@@ -108,17 +121,24 @@ var A2AModule = class {
|
|
|
108
121
|
* @param tool - The A2ATool instance to use
|
|
109
122
|
* @param query - The message to send to the agent
|
|
110
123
|
* @param threadId - The session identifier for context tracking
|
|
111
|
-
* @
|
|
124
|
+
* @yields StreamEvent objects for intermediate events
|
|
125
|
+
* @returns Final text response from the agent
|
|
112
126
|
*/
|
|
113
|
-
async useTool(tool, query, threadId) {
|
|
127
|
+
async *useTool(tool, query, threadId) {
|
|
114
128
|
const finalText = [];
|
|
115
129
|
const connector = this.a2aConnectors.get(tool.connectorName);
|
|
130
|
+
if (!connector) {
|
|
131
|
+
loggers.a2a.error("Unknown agent:", { tool });
|
|
132
|
+
const toolResult = `[Bot Called A2A Tool ${tool.connectorName}]
|
|
133
|
+
"Unknown agent connector"`;
|
|
134
|
+
return toolResult;
|
|
135
|
+
}
|
|
116
136
|
const messagePayload = this.getMessagePayload(query, threadId);
|
|
117
137
|
const params = {
|
|
118
138
|
message: messagePayload
|
|
119
139
|
};
|
|
120
140
|
try {
|
|
121
|
-
const client = this.getOrCreateClient(connector);
|
|
141
|
+
const client = await this.getOrCreateClient(connector);
|
|
122
142
|
const stream = client.sendMessageStream(params);
|
|
123
143
|
for await (const event of stream) {
|
|
124
144
|
if (event.kind === "status-update") {
|
|
@@ -126,9 +146,24 @@ var A2AModule = class {
|
|
|
126
146
|
if (typedEvent.final && typedEvent.status.state !== "input-required") {
|
|
127
147
|
this.a2aTasks.delete(threadId);
|
|
128
148
|
}
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
149
|
+
if (typedEvent.status.state === "working") {
|
|
150
|
+
const eventData = JSON.parse(
|
|
151
|
+
(typedEvent.status.message?.parts[0]).text
|
|
152
|
+
);
|
|
153
|
+
yield {
|
|
154
|
+
event: "thinking_process",
|
|
155
|
+
data: eventData
|
|
156
|
+
};
|
|
157
|
+
} else if (typedEvent.status.state === "completed") {
|
|
158
|
+
const texts = typedEvent.status.message?.parts.filter((part) => part.kind === "text").map((part) => part.text).join("\n");
|
|
159
|
+
if (texts) {
|
|
160
|
+
finalText.push(texts);
|
|
161
|
+
yield {
|
|
162
|
+
event: "text_chunk",
|
|
163
|
+
data: { delta: texts }
|
|
164
|
+
};
|
|
165
|
+
}
|
|
166
|
+
} else {
|
|
132
167
|
}
|
|
133
168
|
} else if (event.kind === "message") {
|
|
134
169
|
const msg = event;
|
|
@@ -161,4 +196,4 @@ ${finalText.join("\n")}`;
|
|
|
161
196
|
export {
|
|
162
197
|
A2AModule
|
|
163
198
|
};
|
|
164
|
-
//# sourceMappingURL=chunk-
|
|
199
|
+
//# sourceMappingURL=chunk-FRQSMPPK.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/modules/a2a/a2a.module.ts"],"sourcesContent":["import { randomUUID } from \"node:crypto\";\nimport type {\n\tAgentCard,\n\tMessage,\n\tMessageSendParams,\n\tTask,\n\tTaskStatusUpdateEvent,\n\tTextPart,\n} from \"@a2a-js/sdk\";\nimport { type Client as A2AClient, ClientFactory } from \"@a2a-js/sdk/client\";\nimport {\n\tCONNECTOR_PROTOCOL_TYPE,\n\ttype ConnectorTool,\n} from \"@/types/connector.js\";\nimport { ThreadType } from \"@/types/memory.js\";\nimport type { StreamEvent } from \"@/types/stream.js\";\nimport { loggers } from \"@/utils/logger.js\";\nimport { A2AConnector } from \"./a2a.connector.js\";\n\n/**\n * Module for managing Agent-to-Agent (A2A) protocol connections.\n *\n * This module handles connections to other A2A-compatible agents, manages\n * conversation sessions, and provides an interface for inter-agent communication.\n * Supports multi-turn conversations with task and context tracking.\n */\nexport class A2AModule {\n\t/** Map of A2A server URLs to their corresponding tool instances */\n\tprivate a2aConnectors: Map<string, A2AConnector> = new Map();\n\t/** Map of session IDs to their A2A session state */\n\tprivate a2aTasks: Map<string, string> = new Map();\n\tprivate agentId: string = randomUUID(); /* FIXME */\n\n\t/**\n\t * Registers a new A2A peer server URL for connection.\n\t *\n\t * @param conns - Set of name, url pair\n\t */\n\tpublic async addA2AConnector(conns: {\n\t\t[name: string]: string;\n\t}): Promise<void> {\n\t\tfor (const [name, url] of Object.entries(conns)) {\n\t\t\tconst conn = new A2AConnector(name, url);\n\t\t\tthis.a2aConnectors.set(name, conn);\n\t\t}\n\t}\n\n\tpublic getA2AConnectors(): Array<{ name: string; url: string }> {\n\t\tconst connectors: Array<{ name: string; url: string }> = [];\n\t\tfor (const [name, connector] of this.a2aConnectors.entries()) {\n\t\t\tconnectors.push({ name, url: connector.url });\n\t\t}\n\t\treturn connectors;\n\t}\n\n\tprivate async getOrCreateClient(connector: A2AConnector): Promise<A2AClient> {\n\t\tif (!connector.client) {\n\t\t\tconnector.client = await new ClientFactory().createFromUrl(connector.url);\n\t\t}\n\t\treturn connector.client;\n\t}\n\n\t/**\n\t * Retrieves tools from all registered A2A peer servers.\n\t *\n\t * Attempts to connect to each registered server, fetch their agent cards,\n\t * and create tool instances. Disables tools for unreachable servers.\n\t *\n\t * @returns Promise resolving to array of available A2A tools\n\t */\n\tpublic async getTools(): Promise<ConnectorTool[]> {\n\t\tconst tools: ConnectorTool[] = [];\n\t\tfor (const [name, conn] of this.a2aConnectors.entries()) {\n\t\t\tif (!conn.enabled) {\n\t\t\t\tcontinue; // skip disabled agent\n\t\t\t}\n\n\t\t\ttry {\n\t\t\t\tconst client = await this.getOrCreateClient(conn);\n\t\t\t\tconst card: AgentCard = await client.getAgentCard();\n\t\t\t\t/* TODO: add each skill as tool? */\n\t\t\t\tconst tool: ConnectorTool = {\n\t\t\t\t\ttoolName: card.name.replaceAll(\" \", \"-\"),\n\t\t\t\t\tconnectorName: name,\n\t\t\t\t\tprotocol: CONNECTOR_PROTOCOL_TYPE.A2A,\n\t\t\t\t\tdescription: card.description,\n\t\t\t\t\t// add thinking_text inputSchema\n\t\t\t\t\tinputSchema: {\n\t\t\t\t\t\ttype: \"object\",\n\t\t\t\t\t\tproperties: {\n\t\t\t\t\t\t\tthinking_text: {\n\t\t\t\t\t\t\t\ttype: \"string\",\n\t\t\t\t\t\t\t\tdescription:\n\t\t\t\t\t\t\t\t\t\"사용자의 요청을 해결하기 위해 이 도구를 선택한 구체적인 이유와 목적 (Why & What). 한두줄 정도의 분량으로 입력 언어와 같은 언어로 생성한다.\",\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t\trequired: [\"thinking_text\"],\n\t\t\t\t\t},\n\t\t\t\t};\n\n\t\t\t\ttools.push(tool);\n\t\t\t} catch (_error: any) {\n\t\t\t\t// Agent not responded, just skip\n\t\t\t}\n\t\t}\n\t\treturn tools;\n\t}\n\n\t/**\n\t * Constructs a message payload for A2A communication.\n\t *\n\t * Includes session context (task ID and context ID) if available\n\t * for maintaining conversation continuity.\n\t *\n\t * @param query - The message content to send\n\t * @param threadId - The session identifier\n\t * @returns Formatted Message object for A2A protocol\n\t */\n\tpublic getMessagePayload(query: string, threadId: string): Message {\n\t\tconst messagePayload: Message = {\n\t\t\tmessageId: randomUUID(),\n\t\t\tkind: \"message\",\n\t\t\trole: \"user\", // FIXME: it could be 'agent'\n\t\t\tmetadata: {\n\t\t\t\tagentId: this.agentId,\n\t\t\t\ttype: ThreadType.CHAT,\n\t\t\t},\n\t\t\tparts: [\n\t\t\t\t{\n\t\t\t\t\tkind: \"text\",\n\t\t\t\t\ttext: query,\n\t\t\t\t},\n\t\t\t],\n\t\t\tcontextId: threadId,\n\t\t};\n\n\t\tif (this.a2aTasks.has(threadId)) {\n\t\t\tmessagePayload.taskId = this.a2aTasks.get(threadId);\n\t\t}\n\n\t\treturn messagePayload;\n\t}\n\n\t/**\n\t * Executes an A2A tool by sending a message to the remote agent.\n\t *\n\t * Handles streaming responses, maintains session state, and extracts\n\t * text content from various event types in the response stream.\n\t *\n\t * @param tool - The A2ATool instance to use\n\t * @param query - The message to send to the agent\n\t * @param threadId - The session identifier for context tracking\n\t * @yields StreamEvent objects for intermediate events\n\t * @returns Final text response from the agent\n\t */\n\tpublic async *useTool(\n\t\ttool: ConnectorTool,\n\t\tquery: string,\n\t\tthreadId: string,\n\t): AsyncGenerator<StreamEvent, string, unknown> {\n\t\tconst finalText: string[] = [];\n\t\tconst connector = this.a2aConnectors.get(tool.connectorName);\n\t\tif (!connector) {\n\t\t\tloggers.a2a.error(\"Unknown agent:\", { tool });\n\t\t\tconst toolResult = `[Bot Called A2A Tool ${tool.connectorName}]\\n\"Unknown agent connector\"`;\n\t\t\treturn toolResult;\n\t\t}\n\n\t\tconst messagePayload = this.getMessagePayload(query, threadId);\n\t\tconst params: MessageSendParams = {\n\t\t\tmessage: messagePayload,\n\t\t};\n\n\t\ttry {\n\t\t\tconst client = await this.getOrCreateClient(connector);\n\t\t\tconst stream = client.sendMessageStream(params);\n\t\t\tfor await (const event of stream) {\n\t\t\t\tif (event.kind === \"status-update\") {\n\t\t\t\t\tconst typedEvent = event as TaskStatusUpdateEvent;\n\t\t\t\t\tif (\n\t\t\t\t\t\ttypedEvent.final &&\n\t\t\t\t\t\ttypedEvent.status.state !== \"input-required\"\n\t\t\t\t\t) {\n\t\t\t\t\t\tthis.a2aTasks.delete(threadId);\n\t\t\t\t\t}\n\n\t\t\t\t\tif (typedEvent.status.state === \"working\") {\n\t\t\t\t\t\t// thinking process event\n\t\t\t\t\t\tconst eventData = JSON.parse(\n\t\t\t\t\t\t\t(typedEvent.status.message?.parts[0] as TextPart).text,\n\t\t\t\t\t\t);\n\t\t\t\t\t\tyield {\n\t\t\t\t\t\t\tevent: \"thinking_process\",\n\t\t\t\t\t\t\tdata: eventData,\n\t\t\t\t\t\t};\n\t\t\t\t\t} else if (typedEvent.status.state === \"completed\") {\n\t\t\t\t\t\t// TODO: handle 'file', 'data' parts\n\t\t\t\t\t\tconst texts = typedEvent.status.message?.parts\n\t\t\t\t\t\t\t.filter((part) => part.kind === \"text\")\n\t\t\t\t\t\t\t.map((part: TextPart) => part.text)\n\t\t\t\t\t\t\t.join(\"\\n\");\n\t\t\t\t\t\tif (texts) {\n\t\t\t\t\t\t\tfinalText.push(texts);\n\t\t\t\t\t\t\tyield {\n\t\t\t\t\t\t\t\tevent: \"text_chunk\",\n\t\t\t\t\t\t\t\tdata: { delta: texts },\n\t\t\t\t\t\t\t};\n\t\t\t\t\t\t}\n\t\t\t\t\t} else {\n\t\t\t\t\t\t// ignore other status updates\n\t\t\t\t\t}\n\t\t\t\t} else if (event.kind === \"message\") {\n\t\t\t\t\t// FIXME: handling text in 'message'?\n\t\t\t\t\tconst msg = event as Message;\n\t\t\t\t\tconst taskId = this.a2aTasks.get(threadId);\n\t\t\t\t\tif (msg.taskId && msg.taskId !== taskId) {\n\t\t\t\t\t\tthis.a2aTasks.set(threadId, msg.taskId);\n\t\t\t\t\t}\n\t\t\t\t} else if (event.kind === \"task\") {\n\t\t\t\t\t// establishing the Task ID\n\t\t\t\t\tconst task = event as Task;\n\t\t\t\t\tif (task.id !== this.a2aTasks.get(threadId)) {\n\t\t\t\t\t\tthis.a2aTasks.set(threadId, task.id);\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\tloggers.a2a.warn(\"Received unknown event structure from stream:\", {\n\t\t\t\t\t\tevent,\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t}\n\t\t} catch (error) {\n\t\t\tloggers.a2a.error(\"Error communicating with agent:\", { error });\n\t\t\tconst toolResult = `[Bot Called A2A Tool ${tool.toolName}]\\n${typeof error === \"string\" ? error : JSON.stringify(error, null, 2)}`;\n\t\t\treturn toolResult;\n\t\t}\n\n\t\treturn `[Bot Called A2A Tool ${tool.toolName}]\\n${finalText.join(\"\\n\")}`;\n\t}\n}\n"],"mappings":"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","names":[]}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
// src/utils/isValidUrl.ts
|
|
2
|
+
function isValidUrl(urlString) {
|
|
3
|
+
if (!urlString) {
|
|
4
|
+
return false;
|
|
5
|
+
}
|
|
6
|
+
try {
|
|
7
|
+
const url = new URL(urlString);
|
|
8
|
+
return url.protocol === "http:" || url.protocol === "https:";
|
|
9
|
+
} catch (_error) {
|
|
10
|
+
return false;
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
export {
|
|
15
|
+
isValidUrl
|
|
16
|
+
};
|
|
17
|
+
//# sourceMappingURL=chunk-I5DLV2CU.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/utils/isValidUrl.ts"],"sourcesContent":["/**\n * Validates if a string is a valid HTTP or HTTPS URL.\n *\n * @param urlString - The URL string to validate\n * @returns true if the URL is valid HTTP/HTTPS, false otherwise\n */\nexport default function isValidUrl(urlString: string | undefined): boolean {\n\tif (!urlString) {\n\t\treturn false;\n\t}\n\n\ttry {\n\t\tconst url = new URL(urlString);\n\t\treturn url.protocol === \"http:\" || url.protocol === \"https:\";\n\t} catch (_error) {\n\t\treturn false;\n\t}\n}\n"],"mappings":";AAMe,SAAR,WAA4B,WAAwC;AAC1E,MAAI,CAAC,WAAW;AACf,WAAO;AAAA,EACR;AAEA,MAAI;AACH,UAAM,MAAM,IAAI,IAAI,SAAS;AAC7B,WAAO,IAAI,aAAa,WAAW,IAAI,aAAa;AAAA,EACrD,SAAS,QAAQ;AAChB,WAAO;AAAA,EACR;AACD;","names":[]}
|
|
@@ -1,18 +1,18 @@
|
|
|
1
1
|
import {
|
|
2
2
|
IntentFulfillStreamService
|
|
3
|
-
} from "./chunk-
|
|
4
|
-
import {
|
|
5
|
-
IntentTriggerService
|
|
6
|
-
} from "./chunk-DIW5VDAQ.js";
|
|
3
|
+
} from "./chunk-A5PRJ33H.js";
|
|
7
4
|
import {
|
|
8
5
|
generateTitle
|
|
9
|
-
} from "./chunk-
|
|
6
|
+
} from "./chunk-5IIF5O4A.js";
|
|
7
|
+
import {
|
|
8
|
+
IntentTriggerService
|
|
9
|
+
} from "./chunk-KOCOM7IC.js";
|
|
10
10
|
import {
|
|
11
11
|
AinHttpError
|
|
12
12
|
} from "./chunk-WUNZG3WP.js";
|
|
13
13
|
import {
|
|
14
14
|
loggers
|
|
15
|
-
} from "./chunk-
|
|
15
|
+
} from "./chunk-VUMI4XOY.js";
|
|
16
16
|
|
|
17
17
|
// src/services/query-stream.service.ts
|
|
18
18
|
import { randomUUID } from "crypto";
|
|
@@ -36,6 +36,10 @@ var QueryStreamService = class {
|
|
|
36
36
|
memoryModule
|
|
37
37
|
);
|
|
38
38
|
}
|
|
39
|
+
async addToThreadMessages(userId, threadId, messages) {
|
|
40
|
+
const threadMemory = this.memoryModule?.getThreadMemory();
|
|
41
|
+
await threadMemory?.addMessagesToThread(userId, threadId, messages);
|
|
42
|
+
}
|
|
39
43
|
/**
|
|
40
44
|
* Main entry point for processing streaming user queries.
|
|
41
45
|
*
|
|
@@ -78,7 +82,7 @@ var QueryStreamService = class {
|
|
|
78
82
|
}
|
|
79
83
|
const triggeredIntent = await this.intentTriggerService.intentTriggering(query, thread);
|
|
80
84
|
loggers.intent.debug("Triggered intents", { triggeredIntent });
|
|
81
|
-
await
|
|
85
|
+
await this.addToThreadMessages(userId, threadId, [
|
|
82
86
|
{
|
|
83
87
|
messageId: randomUUID(),
|
|
84
88
|
role: "USER" /* USER */,
|
|
@@ -105,4 +109,4 @@ var QueryStreamService = class {
|
|
|
105
109
|
export {
|
|
106
110
|
QueryStreamService
|
|
107
111
|
};
|
|
108
|
-
//# sourceMappingURL=chunk-
|
|
112
|
+
//# sourceMappingURL=chunk-JCXAHLRN.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/services/query-stream.service.ts"],"sourcesContent":["import { randomUUID } from \"node:crypto\";\nimport { StatusCodes } from \"http-status-codes\";\nimport type {\n\tA2AModule,\n\tMCPModule,\n\tMemoryModule,\n\tModelFetchOptions,\n\tModelModule,\n} from \"@/modules/index.js\";\nimport { AinHttpError } from \"@/types/agent.js\";\nimport {\n\ttype MessageObject,\n\tMessageRole,\n\ttype ThreadMetadata,\n\ttype ThreadObject,\n\ttype ThreadType,\n\ttype TriggeredIntent,\n} from \"@/types/memory.js\";\nimport type { StreamEvent } from \"@/types/stream\";\nimport { loggers } from \"@/utils/logger.js\";\nimport { IntentFulfillStreamService } from \"./intents/fulfill-stream.service\";\nimport { IntentTriggerService } from \"./intents/trigger.service\";\nimport { generateTitle } from \"./utils/query.common\";\n\n/**\n * Service for processing user queries through the agent's AI pipeline.\n *\n * Orchestrates the query processing workflow including intent detection,\n * model inference, tool execution, and response generation. Manages\n * conversation context and coordinates between different modules.\n */\nexport class QueryStreamService {\n\tprivate modelModule: ModelModule;\n\tprivate memoryModule?: MemoryModule;\n\tprivate intentTriggerService: IntentTriggerService;\n\tprivate intentFulfillStreamService: IntentFulfillStreamService;\n\n\tconstructor(\n\t\tmodelModule: ModelModule,\n\t\ta2aModule?: A2AModule,\n\t\tmcpModule?: MCPModule,\n\t\tmemoryModule?: MemoryModule,\n\t) {\n\t\tthis.modelModule = modelModule;\n\t\tthis.memoryModule = memoryModule;\n\t\tthis.intentTriggerService = new IntentTriggerService(\n\t\t\tmodelModule,\n\t\t\tmemoryModule,\n\t\t);\n\t\tthis.intentFulfillStreamService = new IntentFulfillStreamService(\n\t\t\tmodelModule,\n\t\t\ta2aModule,\n\t\t\tmcpModule,\n\t\t\tmemoryModule,\n\t\t);\n\t}\n\n\tpublic async addToThreadMessages(\n\t\tuserId: string,\n\t\tthreadId: string,\n\t\tmessages: Array<MessageObject>,\n\t) {\n\t\tconst threadMemory = this.memoryModule?.getThreadMemory();\n\t\tawait threadMemory?.addMessagesToThread(userId, threadId, messages);\n\t}\n\n\t/**\n\t * Main entry point for processing streaming user queries.\n\t *\n\t * Handles the complete query lifecycle:\n\t * 1. Loads or creates thread from memory\n\t * 2. Detects intent from the query\n\t * 3. Fulfills the intent with streaming AI response\n\t * 4. Updates conversation history in real-time\n\t *\n\t * @param threadMetadata - Metadata containing type, userId, and optional threadId\n\t * @param threadMetadata.type - The type of thread (e.g., chat, workflow)\n\t * @param threadMetadata.userId - The user's unique identifier\n\t * @param threadMetadata.threadId - Optional thread identifier\n\t * @param query - The user's input query\n\t * @returns AsyncGenerator yielding StreamEvent objects for SSE\n\t */\n\tpublic async *handleQueryStream(\n\t\tthreadMetadata: {\n\t\t\ttype: ThreadType;\n\t\t\tuserId: string;\n\t\t\tthreadId?: string;\n\t\t\toptions?: ModelFetchOptions;\n\t\t},\n\t\tquery: string,\n\t\tisA2A?: boolean,\n\t): AsyncGenerator<StreamEvent> {\n\t\tconst { type, userId, options } = threadMetadata;\n\t\tconst threadMemory = this.memoryModule?.getThreadMemory();\n\n\t\t// 1. Load or create thread\n\t\tlet threadId = threadMetadata.threadId;\n\t\tlet thread: ThreadObject | undefined;\n\t\tif (threadId) {\n\t\t\tthread = await threadMemory?.getThread(userId, threadId);\n\t\t\tif (!thread && !isA2A) {\n\t\t\t\tthrow new AinHttpError(StatusCodes.NOT_FOUND, \"Thread not found\");\n\t\t\t}\n\t\t}\n\n\t\tthreadId ??= randomUUID();\n\t\tif (!thread) {\n\t\t\tconst title = await generateTitle(this.modelModule, query, options);\n\t\t\tconst metadata: ThreadMetadata = (await threadMemory?.createThread(\n\t\t\t\ttype,\n\t\t\t\tuserId,\n\t\t\t\tthreadId,\n\t\t\t\ttitle,\n\t\t\t)) || { type, userId, threadId, title };\n\t\t\tthread = { ...metadata, messages: [] };\n\t\t\tloggers.intent.info(`Create new thread: ${threadId}`);\n\t\t\tyield { event: \"thread_id\", data: { type, userId, threadId, title } };\n\t\t}\n\n\t\t// 2. intent triggering\n\t\tconst triggeredIntent: Array<TriggeredIntent> =\n\t\t\tawait this.intentTriggerService.intentTriggering(query, thread);\n\t\tloggers.intent.debug(\"Triggered intents\", { triggeredIntent });\n\n\t\t// only add for storage, not for inference\n\t\tawait this.addToThreadMessages(userId, threadId, [\n\t\t\t{\n\t\t\t\tmessageId: randomUUID(),\n\t\t\t\trole: MessageRole.USER,\n\t\t\t\ttimestamp: Date.now(),\n\t\t\t\tcontent: { type: \"text\", parts: [query] },\n\t\t\t\tmetadata: {\n\t\t\t\t\tintents: triggeredIntent\n\t\t\t\t\t\t.filter((intent) => !!intent.intent)\n\t\t\t\t\t\t.map((intent) => ({\n\t\t\t\t\t\t\tid: intent.intent?.id,\n\t\t\t\t\t\t\tsubquery: intent.subquery,\n\t\t\t\t\t\t})),\n\t\t\t\t},\n\t\t\t},\n\t\t]);\n\n\t\t// 3. intent fulfillment\n\t\tconst stream = this.intentFulfillStreamService.intentFulfillStream(\n\t\t\ttriggeredIntent,\n\t\t\tthread,\n\t\t);\n\n\t\tfor await (const event of stream) {\n\t\t\tyield event;\n\t\t}\n\t}\n}\n"],"mappings":";;;;;;;;;;;;;;;;;AAAA,SAAS,kBAAkB;AAC3B,SAAS,mBAAmB;AA8BrB,IAAM,qBAAN,MAAyB;AAAA,EACvB;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EAER,YACC,aACA,WACA,WACA,cACC;AACD,SAAK,cAAc;AACnB,SAAK,eAAe;AACpB,SAAK,uBAAuB,IAAI;AAAA,MAC/B;AAAA,MACA;AAAA,IACD;AACA,SAAK,6BAA6B,IAAI;AAAA,MACrC;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,IACD;AAAA,EACD;AAAA,EAEA,MAAa,oBACZ,QACA,UACA,UACC;AACD,UAAM,eAAe,KAAK,cAAc,gBAAgB;AACxD,UAAM,cAAc,oBAAoB,QAAQ,UAAU,QAAQ;AAAA,EACnE;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAkBA,OAAc,kBACb,gBAMA,OACA,OAC8B;AAC9B,UAAM,EAAE,MAAM,QAAQ,QAAQ,IAAI;AAClC,UAAM,eAAe,KAAK,cAAc,gBAAgB;AAGxD,QAAI,WAAW,eAAe;AAC9B,QAAI;AACJ,QAAI,UAAU;AACb,eAAS,MAAM,cAAc,UAAU,QAAQ,QAAQ;AACvD,UAAI,CAAC,UAAU,CAAC,OAAO;AACtB,cAAM,IAAI,aAAa,YAAY,WAAW,kBAAkB;AAAA,MACjE;AAAA,IACD;AAEA,iBAAa,WAAW;AACxB,QAAI,CAAC,QAAQ;AACZ,YAAM,QAAQ,MAAM,cAAc,KAAK,aAAa,OAAO,OAAO;AAClE,YAAM,WAA4B,MAAM,cAAc;AAAA,QACrD;AAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,MACD,KAAM,EAAE,MAAM,QAAQ,UAAU,MAAM;AACtC,eAAS,EAAE,GAAG,UAAU,UAAU,CAAC,EAAE;AACrC,cAAQ,OAAO,KAAK,sBAAsB,QAAQ,EAAE;AACpD,YAAM,EAAE,OAAO,aAAa,MAAM,EAAE,MAAM,QAAQ,UAAU,MAAM,EAAE;AAAA,IACrE;AAGA,UAAM,kBACL,MAAM,KAAK,qBAAqB,iBAAiB,OAAO,MAAM;AAC/D,YAAQ,OAAO,MAAM,qBAAqB,EAAE,gBAAgB,CAAC;AAG7D,UAAM,KAAK,oBAAoB,QAAQ,UAAU;AAAA,MAChD;AAAA,QACC,WAAW,WAAW;AAAA,QACtB;AAAA,QACA,WAAW,KAAK,IAAI;AAAA,QACpB,SAAS,EAAE,MAAM,QAAQ,OAAO,CAAC,KAAK,EAAE;AAAA,QACxC,UAAU;AAAA,UACT,SAAS,gBACP,OAAO,CAAC,WAAW,CAAC,CAAC,OAAO,MAAM,EAClC,IAAI,CAAC,YAAY;AAAA,YACjB,IAAI,OAAO,QAAQ;AAAA,YACnB,UAAU,OAAO;AAAA,UAClB,EAAE;AAAA,QACJ;AAAA,MACD;AAAA,IACD,CAAC;AAGD,UAAM,SAAS,KAAK,2BAA2B;AAAA,MAC9C;AAAA,MACA;AAAA,IACD;AAEA,qBAAiB,SAAS,QAAQ;AACjC,YAAM;AAAA,IACP;AAAA,EACD;AACD;","names":[]}
|
|
@@ -3,6 +3,7 @@ import {
|
|
|
3
3
|
} from "./chunk-WUNZG3WP.js";
|
|
4
4
|
|
|
5
5
|
// src/controllers/query.controller.ts
|
|
6
|
+
import { randomUUID } from "crypto";
|
|
6
7
|
import { StatusCodes } from "http-status-codes";
|
|
7
8
|
var QueryController = class {
|
|
8
9
|
queryService;
|
|
@@ -46,12 +47,29 @@ var QueryController = class {
|
|
|
46
47
|
const keepaliveInterval = setInterval(() => {
|
|
47
48
|
res.write(":keepalive\n\n");
|
|
48
49
|
}, 1e4);
|
|
50
|
+
let currentThreadId = threadId;
|
|
49
51
|
const stream = this.queryStreamService.handleQueryStream(
|
|
50
52
|
{ type, userId, threadId },
|
|
51
53
|
message
|
|
52
54
|
);
|
|
53
55
|
try {
|
|
54
56
|
for await (const event of stream) {
|
|
57
|
+
if (event.event === "thread_id") {
|
|
58
|
+
currentThreadId = event.data.threadId;
|
|
59
|
+
} else if (event.event === "thinking_process") {
|
|
60
|
+
this.queryStreamService.addToThreadMessages(userId, currentThreadId, [
|
|
61
|
+
{
|
|
62
|
+
messageId: randomUUID(),
|
|
63
|
+
role: "MODEL" /* MODEL */,
|
|
64
|
+
timestamp: Date.now(),
|
|
65
|
+
content: { type: "text", parts: [event.data.title] },
|
|
66
|
+
metadata: {
|
|
67
|
+
isThinking: true,
|
|
68
|
+
thinkData: event.data
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
]);
|
|
72
|
+
}
|
|
55
73
|
res.write(
|
|
56
74
|
`event: ${event.event}
|
|
57
75
|
data: ${JSON.stringify(event.data)}
|
|
@@ -75,4 +93,4 @@ data: ${errMsg}
|
|
|
75
93
|
export {
|
|
76
94
|
QueryController
|
|
77
95
|
};
|
|
78
|
-
//# sourceMappingURL=chunk-
|
|
96
|
+
//# sourceMappingURL=chunk-JHKBIDPX.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/controllers/query.controller.ts"],"sourcesContent":["import { randomUUID } from \"node:crypto\";\nimport type { NextFunction, Request, Response } from \"express\";\nimport { StatusCodes } from \"http-status-codes\";\nimport type { QueryService, QueryStreamService } from \"@/services\";\nimport { AinHttpError } from \"@/types/agent\";\nimport { MessageRole } from \"@/types/memory\";\n\nexport class QueryController {\n\tprivate queryService;\n\tprivate queryStreamService;\n\n\tconstructor(\n\t\tqueryService: QueryService,\n\t\tqueryStreamService?: QueryStreamService,\n\t) {\n\t\tthis.queryService = queryService;\n\t\tthis.queryStreamService = queryStreamService;\n\t}\n\n\tpublic handleQueryRequest = async (\n\t\treq: Request,\n\t\tres: Response,\n\t\tnext: NextFunction,\n\t) => {\n\t\tconst { type, message, threadId } = req.body;\n\t\tconst userId = res.locals.userId;\n\n\t\ttry {\n\t\t\tconst result = await this.queryService.handleQuery(\n\t\t\t\t{ type, userId, threadId },\n\t\t\t\tmessage,\n\t\t\t);\n\n\t\t\tres.status(200).json(result);\n\t\t} catch (error) {\n\t\t\tnext(error);\n\t\t}\n\t};\n\n\tpublic handleQueryStreamRequest = async (\n\t\treq: Request,\n\t\tres: Response,\n\t\tnext: NextFunction,\n\t) => {\n\t\tconst { type, threadId, message } = req.body;\n\t\tconst userId = res.locals.userId;\n\n\t\tif (!this.queryStreamService) {\n\t\t\tconst error = new AinHttpError(\n\t\t\t\tStatusCodes.NOT_IMPLEMENTED,\n\t\t\t\t\"Stream query not supported\",\n\t\t\t);\n\t\t\treturn next(error);\n\t\t}\n\n\t\tres.writeHead(200, {\n\t\t\t\"Content-Type\": \"text/event-stream\",\n\t\t\t\"Cache-Control\": \"no-cache\",\n\t\t\tConnection: \"keep-alive\",\n\t\t\t\"X-Accel-Buffering\": \"no\", // nginx 버퍼링 비활성화\n\t\t});\n\t\tres.flushHeaders();\n\t\tres.write(\":ok\\n\\n\");\n\n\t\tconst keepaliveInterval = setInterval(() => {\n\t\t\tres.write(\":keepalive\\n\\n\");\n\t\t}, 10000); // 10초마다 keepalive 전송\n\n\t\tlet currentThreadId = threadId;\n\t\tconst stream = this.queryStreamService.handleQueryStream(\n\t\t\t{ type, userId, threadId },\n\t\t\tmessage,\n\t\t);\n\n\t\ttry {\n\t\t\tfor await (const event of stream) {\n\t\t\t\tif (event.event === \"thread_id\") {\n\t\t\t\t\tcurrentThreadId = event.data.threadId;\n\t\t\t\t} else if (event.event === \"thinking_process\") {\n\t\t\t\t\t// a2a 호출에 대해서는 데이터베이스에 추가하지 않기 위해 여기서 thread message에 기록\n\t\t\t\t\tthis.queryStreamService.addToThreadMessages(userId, currentThreadId, [\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tmessageId: randomUUID(),\n\t\t\t\t\t\t\trole: MessageRole.MODEL,\n\t\t\t\t\t\t\ttimestamp: Date.now(),\n\t\t\t\t\t\t\tcontent: { type: \"text\", parts: [event.data.title] },\n\t\t\t\t\t\t\tmetadata: {\n\t\t\t\t\t\t\t\tisThinking: true,\n\t\t\t\t\t\t\t\tthinkData: event.data,\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t]);\n\t\t\t\t}\n\n\t\t\t\tres.write(\n\t\t\t\t\t`event: ${event.event}\\ndata: ${JSON.stringify(event.data)}\\n\\n`,\n\t\t\t\t);\n\t\t\t}\n\t\t} catch (error: unknown) {\n\t\t\tconst errMsg =\n\t\t\t\t(error as Error)?.message || \"Failed to handle query stream\";\n\t\t\tres.write(`event: error\\ndata: ${errMsg}\\n\\n`);\n\t\t} finally {\n\t\t\tclearInterval(keepaliveInterval);\n\t\t\tres.end();\n\t\t}\n\t};\n}\n"],"mappings":";;;;;AAAA,SAAS,kBAAkB;AAE3B,SAAS,mBAAmB;AAKrB,IAAM,kBAAN,MAAsB;AAAA,EACpB;AAAA,EACA;AAAA,EAER,YACC,cACA,oBACC;AACD,SAAK,eAAe;AACpB,SAAK,qBAAqB;AAAA,EAC3B;AAAA,EAEO,qBAAqB,OAC3B,KACA,KACA,SACI;AACJ,UAAM,EAAE,MAAM,SAAS,SAAS,IAAI,IAAI;AACxC,UAAM,SAAS,IAAI,OAAO;AAE1B,QAAI;AACH,YAAM,SAAS,MAAM,KAAK,aAAa;AAAA,QACtC,EAAE,MAAM,QAAQ,SAAS;AAAA,QACzB;AAAA,MACD;AAEA,UAAI,OAAO,GAAG,EAAE,KAAK,MAAM;AAAA,IAC5B,SAAS,OAAO;AACf,WAAK,KAAK;AAAA,IACX;AAAA,EACD;AAAA,EAEO,2BAA2B,OACjC,KACA,KACA,SACI;AACJ,UAAM,EAAE,MAAM,UAAU,QAAQ,IAAI,IAAI;AACxC,UAAM,SAAS,IAAI,OAAO;AAE1B,QAAI,CAAC,KAAK,oBAAoB;AAC7B,YAAM,QAAQ,IAAI;AAAA,QACjB,YAAY;AAAA,QACZ;AAAA,MACD;AACA,aAAO,KAAK,KAAK;AAAA,IAClB;AAEA,QAAI,UAAU,KAAK;AAAA,MAClB,gBAAgB;AAAA,MAChB,iBAAiB;AAAA,MACjB,YAAY;AAAA,MACZ,qBAAqB;AAAA;AAAA,IACtB,CAAC;AACD,QAAI,aAAa;AACjB,QAAI,MAAM,SAAS;AAEnB,UAAM,oBAAoB,YAAY,MAAM;AAC3C,UAAI,MAAM,gBAAgB;AAAA,IAC3B,GAAG,GAAK;AAER,QAAI,kBAAkB;AACtB,UAAM,SAAS,KAAK,mBAAmB;AAAA,MACtC,EAAE,MAAM,QAAQ,SAAS;AAAA,MACzB;AAAA,IACD;AAEA,QAAI;AACH,uBAAiB,SAAS,QAAQ;AACjC,YAAI,MAAM,UAAU,aAAa;AAChC,4BAAkB,MAAM,KAAK;AAAA,QAC9B,WAAW,MAAM,UAAU,oBAAoB;AAE9C,eAAK,mBAAmB,oBAAoB,QAAQ,iBAAiB;AAAA,YACpE;AAAA,cACC,WAAW,WAAW;AAAA,cACtB;AAAA,cACA,WAAW,KAAK,IAAI;AAAA,cACpB,SAAS,EAAE,MAAM,QAAQ,OAAO,CAAC,MAAM,KAAK,KAAK,EAAE;AAAA,cACnD,UAAU;AAAA,gBACT,YAAY;AAAA,gBACZ,WAAW,MAAM;AAAA,cAClB;AAAA,YACD;AAAA,UACD,CAAC;AAAA,QACF;AAEA,YAAI;AAAA,UACH,UAAU,MAAM,KAAK;AAAA,QAAW,KAAK,UAAU,MAAM,IAAI,CAAC;AAAA;AAAA;AAAA,QAC3D;AAAA,MACD;AAAA,IACD,SAAS,OAAgB;AACxB,YAAM,SACJ,OAAiB,WAAW;AAC9B,UAAI,MAAM;AAAA,QAAuB,MAAM;AAAA;AAAA,CAAM;AAAA,IAC9C,UAAE;AACD,oBAAc,iBAAiB;AAC/B,UAAI,IAAI;AAAA,IACT;AAAA,EACD;AACD;","names":[]}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import {
|
|
2
2
|
loggers
|
|
3
|
-
} from "./chunk-
|
|
3
|
+
} from "./chunk-VUMI4XOY.js";
|
|
4
4
|
|
|
5
5
|
// src/services/intents/trigger.service.ts
|
|
6
6
|
var IntentTriggerService = class {
|
|
@@ -111,4 +111,4 @@ Requirements:
|
|
|
111
111
|
export {
|
|
112
112
|
IntentTriggerService
|
|
113
113
|
};
|
|
114
|
-
//# sourceMappingURL=chunk-
|
|
114
|
+
//# sourceMappingURL=chunk-KOCOM7IC.js.map
|
|
@@ -3,7 +3,7 @@ import {
|
|
|
3
3
|
} from "./chunk-IKYOHZYW.js";
|
|
4
4
|
import {
|
|
5
5
|
loggers
|
|
6
|
-
} from "./chunk-
|
|
6
|
+
} from "./chunk-VUMI4XOY.js";
|
|
7
7
|
|
|
8
8
|
// src/modules/mcp/mcp.module.ts
|
|
9
9
|
import { Client as MCPClient } from "@modelcontextprotocol/sdk/client/index.js";
|
|
@@ -89,7 +89,25 @@ var MCPModule = class {
|
|
|
89
89
|
getTools() {
|
|
90
90
|
const allTools = [];
|
|
91
91
|
for (const conn of this.mcpConnectors.values()) {
|
|
92
|
-
|
|
92
|
+
for (const tool of conn.tools) {
|
|
93
|
+
const finalInputSchema = {
|
|
94
|
+
type: "object",
|
|
95
|
+
properties: { ...tool.inputSchema?.properties || {} },
|
|
96
|
+
required: [...tool.inputSchema?.required || []]
|
|
97
|
+
};
|
|
98
|
+
finalInputSchema.properties["thinking_text"] = {
|
|
99
|
+
type: "string",
|
|
100
|
+
description: "\uC0AC\uC6A9\uC790\uC758 \uC694\uCCAD\uC744 \uD574\uACB0\uD558\uAE30 \uC704\uD574 \uC774 \uB3C4\uAD6C\uB97C \uC120\uD0DD\uD55C \uAD6C\uCCB4\uC801\uC778 \uC774\uC720\uC640 \uBAA9\uC801 (Why & What). \uD55C\uB450\uC904 \uC815\uB3C4\uC758 \uBD84\uB7C9\uC73C\uB85C \uC785\uB825 \uC5B8\uC5B4\uC640 \uAC19\uC740 \uC5B8\uC5B4\uB85C \uC0DD\uC131\uD55C\uB2E4."
|
|
101
|
+
};
|
|
102
|
+
finalInputSchema.required.push("thinking_text");
|
|
103
|
+
allTools.push({
|
|
104
|
+
toolName: tool.toolName,
|
|
105
|
+
connectorName: tool.connectorName,
|
|
106
|
+
protocol: tool.protocol,
|
|
107
|
+
description: tool.description,
|
|
108
|
+
inputSchema: finalInputSchema
|
|
109
|
+
});
|
|
110
|
+
}
|
|
93
111
|
}
|
|
94
112
|
return allTools;
|
|
95
113
|
}
|
|
@@ -139,4 +157,4 @@ ${typeof error === "string" ? error : JSON.stringify(error, null, 2)}`;
|
|
|
139
157
|
export {
|
|
140
158
|
MCPModule
|
|
141
159
|
};
|
|
142
|
-
//# sourceMappingURL=chunk-
|
|
160
|
+
//# sourceMappingURL=chunk-PVWOU6LA.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/modules/mcp/mcp.module.ts"],"sourcesContent":["import { Client as MCPClient } from \"@modelcontextprotocol/sdk/client/index.js\";\nimport { SSEClientTransport } from \"@modelcontextprotocol/sdk/client/sse.js\";\nimport { StdioClientTransport } from \"@modelcontextprotocol/sdk/client/stdio.js\";\nimport { StreamableHTTPClientTransport } from \"@modelcontextprotocol/sdk/client/streamableHttp.js\";\nimport { WebSocketClientTransport } from \"@modelcontextprotocol/sdk/client/websocket.js\";\nimport {\n\tCONNECTOR_PROTOCOL_TYPE,\n\ttype ConnectorTool,\n} from \"@/types/connector.js\";\nimport type { MCPConfig } from \"@/types/mcp.js\";\nimport { loggers } from \"@/utils/logger.js\";\nimport { MCPConnector } from \"./mcp.connector.js\";\n\n/**\n * Module for managing Model Context Protocol (MCP) server connections.\n *\n * This module handles the lifecycle of MCP client connections, discovers\n * available tools from connected servers, and provides an interface for\n * executing those tools. Multiple MCP servers can be connected simultaneously.\n */\nexport class MCPModule {\n\tprivate mcpConnectors: Map<string, MCPConnector> = new Map();\n\n\taddMCPConnector(configs: { [name: string]: MCPConfig }): void {\n\t\tfor (const [name, config] of Object.entries(configs)) {\n\t\t\tconst conn = new MCPConnector(name, config);\n\t\t\tthis.mcpConnectors.set(name, conn);\n\t\t}\n\t}\n\n\tprivate getOrCreateClient(connector: MCPConnector): MCPClient {\n\t\tconnector.client ??= new MCPClient({\n\t\t\tname: connector.name,\n\t\t\tversion: \"1.0.0\",\n\t\t});\n\t\treturn connector.client;\n\t}\n\n\tasync connectToServers(): Promise<void> {\n\t\tfor (const [name, conn] of this.mcpConnectors.entries()) {\n\t\t\ttry {\n\t\t\t\tconst mcpClient = this.getOrCreateClient(conn);\n\t\t\t\tconst config = conn.config;\n\t\t\t\tswitch (config.type) {\n\t\t\t\t\tcase \"stdio\": {\n\t\t\t\t\t\tconst transport = new StdioClientTransport(config.params);\n\t\t\t\t\t\tawait mcpClient.connect(transport);\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t\tcase \"websocket\": {\n\t\t\t\t\t\tconst transport = new WebSocketClientTransport(config.url);\n\t\t\t\t\t\tawait mcpClient.connect(transport);\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t\tcase \"sse\": {\n\t\t\t\t\t\tconst transport = new SSEClientTransport(\n\t\t\t\t\t\t\tconfig.url,\n\t\t\t\t\t\t\tconfig.options,\n\t\t\t\t\t\t);\n\t\t\t\t\t\tawait mcpClient.connect(transport);\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t\tcase \"streamableHttp\": {\n\t\t\t\t\t\tconst transport = new StreamableHTTPClientTransport(\n\t\t\t\t\t\t\tconfig.url,\n\t\t\t\t\t\t\tconfig.options,\n\t\t\t\t\t\t);\n\t\t\t\t\t\tawait mcpClient.connect(transport);\n\t\t\t\t\t\tbreak;\n\t\t\t\t\t}\n\t\t\t\t\tdefault:\n\t\t\t\t\t\t// This cannot happen.\n\t\t\t\t\t\tloggers.mcp.error(\"Unsupported MCP config type\");\n\t\t\t\t\t\tbreak;\n\t\t\t\t}\n\n\t\t\t\tconst toolList = await mcpClient.listTools();\n\t\t\t\tconn.tools = toolList.tools.map((tool) => {\n\t\t\t\t\treturn {\n\t\t\t\t\t\ttoolName: `${name}-${tool.name}`, // to avoid tool name duplication\n\t\t\t\t\t\tconnectorName: name,\n\t\t\t\t\t\tprotocol: CONNECTOR_PROTOCOL_TYPE.MCP,\n\t\t\t\t\t\tdescription: tool.description,\n\t\t\t\t\t\tinputSchema: tool.inputSchema,\n\t\t\t\t\t};\n\t\t\t\t});\n\t\t\t\tloggers.mcp.info(\"Connected to MCP server with tools:\", {\n\t\t\t\t\ttools: conn.tools.map((tool) => tool.toolName),\n\t\t\t\t});\n\t\t\t} catch (error) {\n\t\t\t\tloggers.mcp.error(`Failed to connect to MCP server ${name}`, { error });\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t * Returns all available tools from connected MCP servers.\n\t *\n\t * @returns Array of MCPTool instances representing available tools\n\t */\n\tgetTools(): Array<ConnectorTool> {\n\t\tconst allTools: Array<ConnectorTool> = [];\n\t\tfor (const conn of this.mcpConnectors.values()) {\n\t\t\tfor (const tool of conn.tools) {\n\t\t\t\t// add thinking_text inputSchema for each tool\n\t\t\t\tconst finalInputSchema: any = {\n\t\t\t\t\ttype: \"object\",\n\t\t\t\t\tproperties: { ...(tool.inputSchema?.properties || {}) },\n\t\t\t\t\trequired: [...(tool.inputSchema?.required || [])],\n\t\t\t\t};\n\n\t\t\t\tfinalInputSchema.properties[\"thinking_text\"] = {\n\t\t\t\t\ttype: \"string\",\n\t\t\t\t\tdescription:\n\t\t\t\t\t\t\"사용자의 요청을 해결하기 위해 이 도구를 선택한 구체적인 이유와 목적 (Why & What). 한두줄 정도의 분량으로 입력 언어와 같은 언어로 생성한다.\",\n\t\t\t\t};\n\t\t\t\tfinalInputSchema.required.push(\"thinking_text\");\n\n\t\t\t\tallTools.push({\n\t\t\t\t\ttoolName: tool.toolName,\n\t\t\t\t\tconnectorName: tool.connectorName,\n\t\t\t\t\tprotocol: tool.protocol,\n\t\t\t\t\tdescription: tool.description,\n\t\t\t\t\tinputSchema: finalInputSchema,\n\t\t\t\t});\n\t\t\t}\n\t\t}\n\t\treturn allTools;\n\t}\n\n\t/**\n\t * Executes a tool on its corresponding MCP server.\n\t *\n\t * @param tool - The MCPTool instance to execute\n\t * @param _args - Arguments to pass to the tool\n\t * @returns Promise resolving to the tool's execution result\n\t * @throws Error if the MCP server for the tool is not found\n\t */\n\tasync useTool(tool: ConnectorTool, _args?: any): Promise<string> {\n\t\tconst { connectorName, toolName } = tool;\n\t\tconst client = this.mcpConnectors.get(connectorName)?.client;\n\n\t\ttry {\n\t\t\tif (!client) {\n\t\t\t\tthrow new Error(`Invalid MCP Tool ${toolName}`);\n\t\t\t}\n\n\t\t\t// `${name}-${tool.name}` => tool.name\n\t\t\tconst mcpToolName = toolName.slice(connectorName.length + 1);\n\t\t\tconst result = await client.callTool({\n\t\t\t\tname: mcpToolName,\n\t\t\t\targuments: _args,\n\t\t\t});\n\t\t\tconst toolResult =\n\t\t\t\t`[Bot Called Tool ${toolName} with args ${JSON.stringify(_args)}]\\n` +\n\t\t\t\tJSON.stringify(result.content, null, 2);\n\t\t\treturn toolResult;\n\t\t} catch (error) {\n\t\t\tloggers.mcp.error(\"Failed to call tool\", { error });\n\t\t\tconst toolResult = `[Bot Called Tool ${toolName} with args ${JSON.stringify(_args)}]\\n${typeof error === \"string\" ? error : JSON.stringify(error, null, 2)}`;\n\t\t\treturn toolResult;\n\t\t}\n\t}\n\n\t/**\n\t * Closes all MCP client connections.\n\t *\n\t * Should be called when shutting down the application to ensure\n\t * all MCP connections are properly closed.\n\t */\n\tasync cleanup() {\n\t\tfor (const conn of this.mcpConnectors.values()) {\n\t\t\tawait conn.client?.close();\n\t\t}\n\t}\n}\n"],"mappings":"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","names":[]}
|
|
@@ -1,15 +1,15 @@
|
|
|
1
|
-
import {
|
|
2
|
-
createModelApiRouter
|
|
3
|
-
} from "./chunk-AMRKK46V.js";
|
|
4
|
-
import {
|
|
5
|
-
createThreadApiRouter
|
|
6
|
-
} from "./chunk-SPRW6KUR.js";
|
|
7
1
|
import {
|
|
8
2
|
createAgentApiRouter
|
|
9
3
|
} from "./chunk-275JHD5P.js";
|
|
10
4
|
import {
|
|
11
5
|
createIntentApiRouter
|
|
12
6
|
} from "./chunk-F3SGL62A.js";
|
|
7
|
+
import {
|
|
8
|
+
createModelApiRouter
|
|
9
|
+
} from "./chunk-AMRKK46V.js";
|
|
10
|
+
import {
|
|
11
|
+
createThreadApiRouter
|
|
12
|
+
} from "./chunk-SPRW6KUR.js";
|
|
13
13
|
|
|
14
14
|
// src/routes/api.routes.ts
|
|
15
15
|
import { Router } from "express";
|
|
@@ -27,4 +27,4 @@ var createApiRouter = (agent) => {
|
|
|
27
27
|
export {
|
|
28
28
|
createApiRouter
|
|
29
29
|
};
|
|
30
|
-
//# sourceMappingURL=chunk-
|
|
30
|
+
//# sourceMappingURL=chunk-Q7NLA5X4.js.map
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import {
|
|
2
2
|
logger
|
|
3
|
-
} from "./chunk-
|
|
3
|
+
} from "./chunk-VUMI4XOY.js";
|
|
4
4
|
|
|
5
5
|
// src/middlewares/error.middleware.ts
|
|
6
6
|
var errorMiddleware = (error, req, res, next) => {
|
|
@@ -19,4 +19,4 @@ var errorMiddleware = (error, req, res, next) => {
|
|
|
19
19
|
export {
|
|
20
20
|
errorMiddleware
|
|
21
21
|
};
|
|
22
|
-
//# sourceMappingURL=chunk-
|
|
22
|
+
//# sourceMappingURL=chunk-RAHOYMKY.js.map
|
|
@@ -3,7 +3,7 @@ import {
|
|
|
3
3
|
} from "./chunk-7BH6AYP7.js";
|
|
4
4
|
import {
|
|
5
5
|
loggers
|
|
6
|
-
} from "./chunk-
|
|
6
|
+
} from "./chunk-VUMI4XOY.js";
|
|
7
7
|
|
|
8
8
|
// src/services/intents/fulfill.service.ts
|
|
9
9
|
import { randomUUID } from "crypto";
|
|
@@ -94,11 +94,16 @@ var IntentFulfillService = class {
|
|
|
94
94
|
loggers.intent.debug("MCP tool call", { toolName, toolArgs });
|
|
95
95
|
toolResult = await this.mcpModule.useTool(selectedTool, toolArgs);
|
|
96
96
|
} else if (this.a2aModule && selectedTool.protocol === "A2A" /* A2A */) {
|
|
97
|
-
|
|
97
|
+
const a2aGenerator = this.a2aModule.useTool(
|
|
98
98
|
selectedTool,
|
|
99
99
|
query,
|
|
100
100
|
thread.threadId
|
|
101
101
|
);
|
|
102
|
+
let result = await a2aGenerator.next();
|
|
103
|
+
while (!result.done) {
|
|
104
|
+
result = await a2aGenerator.next();
|
|
105
|
+
}
|
|
106
|
+
toolResult = result.value;
|
|
102
107
|
} else {
|
|
103
108
|
loggers.intent.warn(
|
|
104
109
|
`Unrecognized tool type: ${selectedTool.protocol}`
|
|
@@ -160,4 +165,4 @@ var IntentFulfillService = class {
|
|
|
160
165
|
export {
|
|
161
166
|
IntentFulfillService
|
|
162
167
|
};
|
|
163
|
-
//# sourceMappingURL=chunk-
|
|
168
|
+
//# sourceMappingURL=chunk-UEUZ7G5P.js.map
|