@ainetwork/adk 0.3.5 → 0.3.6
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-24RRJOOI.cjs +362 -0
- package/dist/cjs/chunk-24RRJOOI.cjs.map +1 -0
- package/dist/cjs/chunk-25RWHBEF.cjs +62 -0
- package/dist/cjs/chunk-25RWHBEF.cjs.map +1 -0
- package/dist/cjs/chunk-2BUYQCWK.cjs +44 -0
- package/dist/cjs/chunk-2BUYQCWK.cjs.map +1 -0
- package/dist/cjs/chunk-2CQQ34ED.cjs +83 -0
- package/dist/cjs/chunk-2CQQ34ED.cjs.map +1 -0
- package/dist/cjs/chunk-2KGEFVQ2.cjs +111 -0
- package/dist/cjs/chunk-2KGEFVQ2.cjs.map +1 -0
- package/dist/cjs/chunk-2LUY44JT.cjs +74 -0
- package/dist/cjs/chunk-2LUY44JT.cjs.map +1 -0
- package/dist/cjs/chunk-2OOV44LV.cjs +22 -0
- package/dist/cjs/chunk-2OOV44LV.cjs.map +1 -0
- package/dist/cjs/chunk-4IROMVRW.cjs +29 -0
- package/dist/cjs/chunk-4IROMVRW.cjs.map +1 -0
- package/dist/cjs/chunk-4QGJ7JWW.cjs +17 -0
- package/dist/cjs/chunk-4QGJ7JWW.cjs.map +1 -0
- package/dist/cjs/chunk-5Q2KJ4H4.cjs +45 -0
- package/dist/cjs/chunk-5Q2KJ4H4.cjs.map +1 -0
- package/dist/cjs/chunk-5RLT7IZP.cjs +38 -0
- package/dist/cjs/chunk-5RLT7IZP.cjs.map +1 -0
- package/dist/cjs/chunk-6EBDGU4W.cjs +74 -0
- package/dist/cjs/chunk-6EBDGU4W.cjs.map +1 -0
- package/dist/cjs/chunk-7DEPTYG3.cjs +17 -0
- package/dist/cjs/chunk-7DEPTYG3.cjs.map +1 -0
- package/dist/cjs/chunk-7ZZOQCNU.cjs +17 -0
- package/dist/cjs/chunk-7ZZOQCNU.cjs.map +1 -0
- package/dist/cjs/chunk-A3FKCCSJ.cjs +44 -0
- package/dist/cjs/chunk-A3FKCCSJ.cjs.map +1 -0
- package/dist/cjs/chunk-A4ZX4Y47.cjs +45 -0
- package/dist/cjs/chunk-A4ZX4Y47.cjs.map +1 -0
- package/dist/cjs/chunk-AD6V5E5Q.cjs +89 -0
- package/dist/cjs/chunk-AD6V5E5Q.cjs.map +1 -0
- package/dist/cjs/chunk-AURUUSKY.cjs +44 -0
- package/dist/cjs/chunk-AURUUSKY.cjs.map +1 -0
- package/dist/cjs/chunk-AY4FE732.cjs +44 -0
- package/dist/cjs/chunk-AY4FE732.cjs.map +1 -0
- package/dist/cjs/chunk-BMXLCOSM.cjs +110 -0
- package/dist/cjs/chunk-BMXLCOSM.cjs.map +1 -0
- package/dist/cjs/chunk-BYU2KBHQ.cjs +89 -0
- package/dist/cjs/chunk-BYU2KBHQ.cjs.map +1 -0
- package/dist/cjs/chunk-CII4HFTO.cjs +44 -0
- package/dist/cjs/chunk-CII4HFTO.cjs.map +1 -0
- package/dist/cjs/chunk-CIOM5KV3.cjs +17 -0
- package/dist/cjs/chunk-CIOM5KV3.cjs.map +1 -0
- package/dist/cjs/chunk-CPXITYT4.cjs +104 -0
- package/dist/cjs/chunk-CPXITYT4.cjs.map +1 -0
- package/dist/cjs/chunk-CZ46DNRL.cjs +44 -0
- package/dist/cjs/chunk-CZ46DNRL.cjs.map +1 -0
- package/dist/cjs/chunk-DFUGFIB7.cjs +17 -0
- package/dist/cjs/chunk-DFUGFIB7.cjs.map +1 -0
- package/dist/cjs/chunk-DYQVBJUW.cjs +74 -0
- package/dist/cjs/chunk-DYQVBJUW.cjs.map +1 -0
- package/dist/cjs/chunk-DZZFES73.cjs +29 -0
- package/dist/cjs/chunk-DZZFES73.cjs.map +1 -0
- package/dist/cjs/chunk-E4MOFVBQ.cjs +29 -0
- package/dist/cjs/chunk-E4MOFVBQ.cjs.map +1 -0
- package/dist/cjs/chunk-EO6SZ6Y2.cjs +18 -0
- package/dist/cjs/chunk-EO6SZ6Y2.cjs.map +1 -0
- package/dist/cjs/chunk-ESLEPGTR.cjs +17 -0
- package/dist/cjs/chunk-ESLEPGTR.cjs.map +1 -0
- package/dist/cjs/chunk-EYWBSYOP.cjs +44 -0
- package/dist/cjs/chunk-EYWBSYOP.cjs.map +1 -0
- package/dist/cjs/chunk-F34KCFDI.cjs +38 -0
- package/dist/cjs/chunk-F34KCFDI.cjs.map +1 -0
- package/dist/cjs/chunk-FJCNUHOK.cjs +123 -0
- package/dist/cjs/chunk-FJCNUHOK.cjs.map +1 -0
- package/dist/cjs/chunk-FK2PASX2.cjs +89 -0
- package/dist/cjs/chunk-FK2PASX2.cjs.map +1 -0
- package/dist/cjs/chunk-GF3T2PUU.cjs +89 -0
- package/dist/cjs/chunk-GF3T2PUU.cjs.map +1 -0
- package/dist/cjs/chunk-GNOOMK7W.cjs +17 -0
- package/dist/cjs/chunk-GNOOMK7W.cjs.map +1 -0
- package/dist/cjs/chunk-HNFRGOJS.cjs +38 -0
- package/dist/cjs/chunk-HNFRGOJS.cjs.map +1 -0
- package/dist/cjs/chunk-HQ2XGXLM.cjs +44 -0
- package/dist/cjs/chunk-HQ2XGXLM.cjs.map +1 -0
- package/dist/cjs/chunk-HR3PYWGD.cjs +108 -0
- package/dist/cjs/chunk-HR3PYWGD.cjs.map +1 -0
- package/dist/cjs/chunk-HRZFYMBV.cjs +89 -0
- package/dist/cjs/chunk-HRZFYMBV.cjs.map +1 -0
- package/dist/cjs/chunk-IDDQKX45.cjs +18 -0
- package/dist/cjs/chunk-IDDQKX45.cjs.map +1 -0
- package/dist/cjs/chunk-IRTWZKRL.cjs +29 -0
- package/dist/cjs/chunk-IRTWZKRL.cjs.map +1 -0
- package/dist/cjs/chunk-IS6Q542T.cjs +18 -0
- package/dist/cjs/chunk-IS6Q542T.cjs.map +1 -0
- package/dist/cjs/chunk-IVNKHMZI.cjs +199 -0
- package/dist/cjs/chunk-IVNKHMZI.cjs.map +1 -0
- package/dist/cjs/chunk-JCC4WECX.cjs +17 -0
- package/dist/cjs/chunk-JCC4WECX.cjs.map +1 -0
- package/dist/cjs/chunk-JCHBG2CK.cjs +29 -0
- package/dist/cjs/chunk-JCHBG2CK.cjs.map +1 -0
- package/dist/cjs/chunk-K3UELZ4W.cjs +127 -0
- package/dist/cjs/chunk-K3UELZ4W.cjs.map +1 -0
- package/dist/cjs/chunk-K4BDE4VQ.cjs +17 -0
- package/dist/cjs/chunk-K4BDE4VQ.cjs.map +1 -0
- package/dist/cjs/chunk-K54PUMX5.cjs +44 -0
- package/dist/cjs/chunk-K54PUMX5.cjs.map +1 -0
- package/dist/cjs/chunk-KNYVRACQ.cjs +62 -0
- package/dist/cjs/chunk-KNYVRACQ.cjs.map +1 -0
- package/dist/cjs/chunk-KP4L7527.cjs +17 -0
- package/dist/cjs/chunk-KP4L7527.cjs.map +1 -0
- package/dist/cjs/chunk-LAX3Y732.cjs +18 -0
- package/dist/cjs/chunk-LAX3Y732.cjs.map +1 -0
- package/dist/cjs/chunk-LETDXZVR.cjs +17 -0
- package/dist/cjs/chunk-LETDXZVR.cjs.map +1 -0
- package/dist/cjs/chunk-LNJJUOEN.cjs +160 -0
- package/dist/cjs/chunk-LNJJUOEN.cjs.map +1 -0
- package/dist/cjs/chunk-LS3KARP2.cjs +29 -0
- package/dist/cjs/chunk-LS3KARP2.cjs.map +1 -0
- package/dist/cjs/chunk-M6OZBNV3.cjs +17 -0
- package/dist/cjs/chunk-M6OZBNV3.cjs.map +1 -0
- package/dist/cjs/chunk-MIPD6XXN.cjs +17 -0
- package/dist/cjs/chunk-MIPD6XXN.cjs.map +1 -0
- package/dist/cjs/chunk-MYFVFI5F.cjs +74 -0
- package/dist/cjs/chunk-MYFVFI5F.cjs.map +1 -0
- package/dist/cjs/chunk-NFAEF6W7.cjs +62 -0
- package/dist/cjs/chunk-NFAEF6W7.cjs.map +1 -0
- package/dist/cjs/chunk-NFFV5YMX.cjs +44 -0
- package/dist/cjs/chunk-NFFV5YMX.cjs.map +1 -0
- package/dist/cjs/chunk-NN7IOMRL.cjs +62 -0
- package/dist/cjs/chunk-NN7IOMRL.cjs.map +1 -0
- package/dist/cjs/chunk-NZXQID5S.cjs +104 -0
- package/dist/cjs/chunk-NZXQID5S.cjs.map +1 -0
- package/dist/cjs/chunk-O4WIK7YI.cjs +95 -0
- package/dist/cjs/chunk-O4WIK7YI.cjs.map +1 -0
- package/dist/cjs/chunk-O7WYT77Q.cjs +62 -0
- package/dist/cjs/chunk-O7WYT77Q.cjs.map +1 -0
- package/dist/cjs/chunk-OJM4BUY2.cjs +89 -0
- package/dist/cjs/chunk-OJM4BUY2.cjs.map +1 -0
- package/dist/cjs/chunk-P64FBXOS.cjs +104 -0
- package/dist/cjs/chunk-P64FBXOS.cjs.map +1 -0
- package/dist/cjs/chunk-PTJST6LH.cjs +38 -0
- package/dist/cjs/chunk-PTJST6LH.cjs.map +1 -0
- package/dist/cjs/chunk-QK26HLOI.cjs +38 -0
- package/dist/cjs/chunk-QK26HLOI.cjs.map +1 -0
- package/dist/cjs/chunk-QOFTRHCH.cjs +62 -0
- package/dist/cjs/chunk-QOFTRHCH.cjs.map +1 -0
- package/dist/cjs/chunk-RAL7YD6T.cjs +44 -0
- package/dist/cjs/chunk-RAL7YD6T.cjs.map +1 -0
- package/dist/cjs/chunk-S6T455CQ.cjs +17 -0
- package/dist/cjs/chunk-S6T455CQ.cjs.map +1 -0
- package/dist/cjs/chunk-SC7EAJGH.cjs +17 -0
- package/dist/cjs/chunk-SC7EAJGH.cjs.map +1 -0
- package/dist/cjs/chunk-SD3MWNJS.cjs +38 -0
- package/dist/cjs/chunk-SD3MWNJS.cjs.map +1 -0
- package/dist/cjs/chunk-SFLERIBX.cjs +44 -0
- package/dist/cjs/chunk-SFLERIBX.cjs.map +1 -0
- package/dist/cjs/chunk-SFZRVWAS.cjs +116 -0
- package/dist/cjs/chunk-SFZRVWAS.cjs.map +1 -0
- package/dist/cjs/chunk-SSKGQ6Q6.cjs +44 -0
- package/dist/cjs/chunk-SSKGQ6Q6.cjs.map +1 -0
- package/dist/cjs/chunk-SV2K3QIF.cjs +89 -0
- package/dist/cjs/chunk-SV2K3QIF.cjs.map +1 -0
- package/dist/cjs/chunk-SVO42FE4.cjs +199 -0
- package/dist/cjs/chunk-SVO42FE4.cjs.map +1 -0
- package/dist/cjs/chunk-SVWQ7SSG.cjs +17 -0
- package/dist/cjs/chunk-SVWQ7SSG.cjs.map +1 -0
- package/dist/cjs/chunk-SWXYI6B3.cjs +17 -0
- package/dist/cjs/chunk-SWXYI6B3.cjs.map +1 -0
- package/dist/cjs/chunk-SYRDNATI.cjs +18 -0
- package/dist/cjs/chunk-SYRDNATI.cjs.map +1 -0
- package/dist/cjs/chunk-T6JV6NPL.cjs +29 -0
- package/dist/cjs/chunk-T6JV6NPL.cjs.map +1 -0
- package/dist/cjs/chunk-TA7HWVVM.cjs +44 -0
- package/dist/cjs/chunk-TA7HWVVM.cjs.map +1 -0
- package/dist/cjs/chunk-TR6LECJD.cjs +17 -0
- package/dist/cjs/chunk-TR6LECJD.cjs.map +1 -0
- package/dist/cjs/chunk-TUCSLVSF.cjs +74 -0
- package/dist/cjs/chunk-TUCSLVSF.cjs.map +1 -0
- package/dist/cjs/chunk-UNJZ3SCR.cjs +38 -0
- package/dist/cjs/chunk-UNJZ3SCR.cjs.map +1 -0
- package/dist/cjs/chunk-UOTEA2IY.cjs +104 -0
- package/dist/cjs/chunk-UOTEA2IY.cjs.map +1 -0
- package/dist/cjs/chunk-UQFLEWWA.cjs +362 -0
- package/dist/cjs/chunk-UQFLEWWA.cjs.map +1 -0
- package/dist/cjs/chunk-UVPSBGW7.cjs +74 -0
- package/dist/cjs/chunk-UVPSBGW7.cjs.map +1 -0
- package/dist/cjs/chunk-VDXJGAFA.cjs +17 -0
- package/dist/cjs/chunk-VDXJGAFA.cjs.map +1 -0
- package/dist/cjs/chunk-WCTCFUE2.cjs +367 -0
- package/dist/cjs/chunk-WCTCFUE2.cjs.map +1 -0
- package/dist/cjs/chunk-WIS6QBYF.cjs +77 -0
- package/dist/cjs/chunk-WIS6QBYF.cjs.map +1 -0
- package/dist/cjs/chunk-WL657FMV.cjs +17 -0
- package/dist/cjs/chunk-WL657FMV.cjs.map +1 -0
- package/dist/cjs/chunk-WZEICEMD.cjs +62 -0
- package/dist/cjs/chunk-WZEICEMD.cjs.map +1 -0
- package/dist/cjs/chunk-XIVWRYNJ.cjs +38 -0
- package/dist/cjs/chunk-XIVWRYNJ.cjs.map +1 -0
- package/dist/cjs/chunk-XZUUYWF4.cjs +74 -0
- package/dist/cjs/chunk-XZUUYWF4.cjs.map +1 -0
- package/dist/cjs/chunk-Y524IIF6.cjs +199 -0
- package/dist/cjs/chunk-Y524IIF6.cjs.map +1 -0
- package/dist/cjs/chunk-YNPHQW5S.cjs +17 -0
- package/dist/cjs/chunk-YNPHQW5S.cjs.map +1 -0
- package/dist/cjs/chunk-Z57RTBQ6.cjs +18 -0
- package/dist/cjs/chunk-Z57RTBQ6.cjs.map +1 -0
- package/dist/cjs/chunk-ZO4B7BJ3.cjs +38 -0
- package/dist/cjs/chunk-ZO4B7BJ3.cjs.map +1 -0
- package/dist/cjs/chunk-ZUIRE3CM.cjs +18 -0
- package/dist/cjs/chunk-ZUIRE3CM.cjs.map +1 -0
- package/dist/cjs/container/controllers.cjs +6 -5
- package/dist/cjs/container/controllers.cjs.map +1 -1
- package/dist/cjs/container/index.cjs +20 -20
- package/dist/cjs/container/services.cjs +16 -16
- package/dist/cjs/controllers/a2a.controller.cjs +3 -3
- package/dist/cjs/controllers/api/workflow.api.controller.cjs +2 -2
- package/dist/cjs/controllers/index.cjs +5 -5
- package/dist/cjs/controllers/query.controller.cjs +4 -3
- package/dist/cjs/controllers/query.controller.cjs.map +1 -1
- package/dist/cjs/index.cjs +41 -41
- package/dist/cjs/index.cjs.map +1 -1
- package/dist/cjs/middlewares/error.middleware.cjs +3 -3
- package/dist/cjs/modules/a2a/a2a.module.cjs +4 -4
- package/dist/cjs/modules/index.cjs +8 -8
- 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 +23 -23
- package/dist/cjs/routes/api/agent.routes.cjs +21 -21
- package/dist/cjs/routes/api/intent.routes.cjs +21 -21
- package/dist/cjs/routes/api/model.routes.cjs +21 -21
- package/dist/cjs/routes/api/threads.routes.cjs +21 -21
- package/dist/cjs/routes/api/workflow.routes.cjs +21 -21
- package/dist/cjs/routes/api.routes.cjs +26 -26
- package/dist/cjs/routes/index.cjs +30 -30
- package/dist/cjs/routes/intent.routes.cjs +21 -21
- package/dist/cjs/routes/query.routes.cjs +21 -21
- package/dist/cjs/services/a2a.service.cjs +3 -3
- package/dist/cjs/services/index.cjs +14 -14
- package/dist/cjs/services/index.cjs.map +1 -1
- package/dist/cjs/services/intents/aggregate.service.cjs +3 -3
- package/dist/cjs/services/intents/fulfill.service.cjs +6 -6
- package/dist/cjs/services/intents/multi-trigger.service.cjs +3 -3
- package/dist/cjs/services/intents/single-trigger.service.cjs +3 -3
- package/dist/cjs/services/intents/trigger.service.cjs +5 -5
- package/dist/cjs/services/query.service.cjs +5 -5
- package/dist/cjs/services/utils/query.common.cjs +3 -3
- package/dist/cjs/types/memory.cjs +2 -2
- package/dist/cjs/utils/logger.cjs +4 -2
- package/dist/cjs/utils/logger.cjs.map +1 -1
- package/dist/esm/{chunk-ZTYRQOCO.js → chunk-3IG6HCSA.js} +2 -2
- package/dist/esm/{chunk-FISBL7OM.js → chunk-5FJU67BO.js} +54 -13
- package/dist/esm/chunk-5FJU67BO.js.map +1 -0
- package/dist/esm/{chunk-T3FCCMU6.js → chunk-A3CKGK3U.js} +3 -3
- package/dist/esm/{chunk-RAHOYMKY.js → chunk-BYGS3GS6.js} +2 -2
- package/dist/esm/{chunk-MB7ZI64O.js → chunk-CYP6OTDK.js} +10 -10
- package/dist/esm/{chunk-MDQEA2US.js → chunk-D66QTWUY.js} +2 -2
- package/dist/esm/{chunk-ZNZZZ4NN.js → chunk-DBB7B4PV.js} +4 -4
- package/dist/esm/chunk-DBB7B4PV.js.map +1 -0
- package/dist/esm/{chunk-VUMI4XOY.js → chunk-GHUEA7V5.js} +23 -2
- package/dist/esm/chunk-GHUEA7V5.js.map +1 -0
- package/dist/esm/{chunk-HNKYLU4R.js → chunk-GKG27ZGB.js} +10 -10
- package/dist/esm/{chunk-5IIF5O4A.js → chunk-HEYSMA5B.js} +2 -2
- package/dist/esm/{chunk-MC5KX7MQ.js → chunk-L447Q33F.js} +31 -2
- package/dist/esm/chunk-L447Q33F.js.map +1 -0
- package/dist/esm/{chunk-SUBXSJXS.js → chunk-LLYDI3LD.js} +5 -5
- package/dist/esm/{chunk-YMSNW2SU.js → chunk-MVVAEPGR.js} +2 -2
- package/dist/esm/{chunk-LC5XQGWK.js → chunk-MXPZHEDH.js} +10 -10
- package/dist/esm/{chunk-A5CFFQUV.js → chunk-MZRZVF5Q.js} +2 -2
- package/dist/esm/{chunk-HZC52S2R.js → chunk-R2R3AMCG.js} +2 -2
- package/dist/esm/{chunk-D6STNZ2L.js → chunk-RE676AIN.js} +16 -1
- package/dist/esm/chunk-RE676AIN.js.map +1 -0
- package/dist/esm/{chunk-S46LW2P7.js → chunk-SDABEZSA.js} +2 -2
- package/dist/esm/{chunk-PVWOU6LA.js → chunk-SV5CKUNN.js} +2 -2
- package/dist/esm/{chunk-YUFYGSSY.js → chunk-TR2QAQEW.js} +2 -2
- package/dist/esm/chunk-TR2QAQEW.js.map +1 -0
- package/dist/esm/{chunk-CC6DWPHZ.js → chunk-VGL4ZVNA.js} +8 -8
- package/dist/esm/chunk-VGL4ZVNA.js.map +1 -0
- package/dist/esm/{chunk-VRFQFDSM.js → chunk-VOMI5BAO.js} +2 -2
- package/dist/esm/{chunk-4BHU7SPZ.js → chunk-VX3VWWYW.js} +1 -1
- package/dist/esm/{chunk-4BHU7SPZ.js.map → chunk-VX3VWWYW.js.map} +1 -1
- package/dist/esm/{chunk-ZJVWC666.js → chunk-WMHUZEL2.js} +2 -2
- package/dist/esm/{chunk-RKLWSV24.js → chunk-XXDILT4B.js} +2 -2
- package/dist/esm/{chunk-JXGQVFCO.js → chunk-ZSWCICNO.js} +16 -8
- package/dist/esm/chunk-ZSWCICNO.js.map +1 -0
- package/dist/esm/{chunk-FRQSMPPK.js → chunk-ZUVYTTPD.js} +2 -2
- package/dist/esm/{chunk-QQZ5ANSD.js → chunk-ZXRDGIRP.js} +38 -26
- package/dist/esm/chunk-ZXRDGIRP.js.map +1 -0
- package/dist/esm/container/controllers.js +6 -5
- package/dist/esm/container/index.js +20 -20
- package/dist/esm/container/services.js +12 -12
- package/dist/esm/controllers/a2a.controller.js +2 -2
- package/dist/esm/controllers/api/workflow.api.controller.js +1 -1
- package/dist/esm/controllers/index.js +6 -6
- package/dist/esm/controllers/query.controller.js +3 -2
- package/dist/esm/index.js +37 -37
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/middlewares/error.middleware.js +2 -2
- package/dist/esm/modules/a2a/a2a.module.js +3 -3
- package/dist/esm/modules/index.js +10 -10
- package/dist/esm/modules/mcp/mcp.module.js +2 -2
- package/dist/esm/routes/a2a.routes.js +23 -23
- package/dist/esm/routes/api/agent.routes.js +21 -21
- package/dist/esm/routes/api/intent.routes.js +21 -21
- package/dist/esm/routes/api/model.routes.js +21 -21
- package/dist/esm/routes/api/threads.routes.js +21 -21
- package/dist/esm/routes/api/workflow.routes.js +21 -21
- package/dist/esm/routes/api.routes.js +26 -26
- package/dist/esm/routes/index.js +32 -32
- package/dist/esm/routes/intent.routes.js +21 -21
- package/dist/esm/routes/query.routes.js +21 -21
- package/dist/esm/services/a2a.service.js +2 -2
- package/dist/esm/services/index.js +12 -12
- package/dist/esm/services/intents/aggregate.service.d.ts +10 -0
- package/dist/esm/services/intents/aggregate.service.js +2 -2
- package/dist/esm/services/intents/fulfill.service.d.ts +5 -4
- package/dist/esm/services/intents/fulfill.service.js +4 -4
- package/dist/esm/services/intents/multi-trigger.service.d.ts +3 -3
- package/dist/esm/services/intents/multi-trigger.service.js +2 -2
- package/dist/esm/services/intents/single-trigger.service.d.ts +3 -3
- package/dist/esm/services/intents/single-trigger.service.js +2 -2
- package/dist/esm/services/intents/trigger.service.d.ts +3 -3
- package/dist/esm/services/intents/trigger.service.js +4 -4
- package/dist/esm/services/query.service.js +4 -4
- package/dist/esm/services/utils/query.common.js +2 -2
- package/dist/esm/types/memory.d.ts +11 -1
- package/dist/esm/types/memory.js +1 -1
- package/dist/esm/utils/logger.d.ts +2 -1
- package/dist/esm/utils/logger.js +3 -1
- package/package.json +1 -1
- package/dist/esm/chunk-CC6DWPHZ.js.map +0 -1
- package/dist/esm/chunk-D6STNZ2L.js.map +0 -1
- package/dist/esm/chunk-FISBL7OM.js.map +0 -1
- package/dist/esm/chunk-JXGQVFCO.js.map +0 -1
- package/dist/esm/chunk-MC5KX7MQ.js.map +0 -1
- package/dist/esm/chunk-QQZ5ANSD.js.map +0 -1
- package/dist/esm/chunk-VUMI4XOY.js.map +0 -1
- package/dist/esm/chunk-YUFYGSSY.js.map +0 -1
- package/dist/esm/chunk-ZNZZZ4NN.js.map +0 -1
- /package/dist/esm/{chunk-ZTYRQOCO.js.map → chunk-3IG6HCSA.js.map} +0 -0
- /package/dist/esm/{chunk-T3FCCMU6.js.map → chunk-A3CKGK3U.js.map} +0 -0
- /package/dist/esm/{chunk-RAHOYMKY.js.map → chunk-BYGS3GS6.js.map} +0 -0
- /package/dist/esm/{chunk-MB7ZI64O.js.map → chunk-CYP6OTDK.js.map} +0 -0
- /package/dist/esm/{chunk-MDQEA2US.js.map → chunk-D66QTWUY.js.map} +0 -0
- /package/dist/esm/{chunk-HNKYLU4R.js.map → chunk-GKG27ZGB.js.map} +0 -0
- /package/dist/esm/{chunk-5IIF5O4A.js.map → chunk-HEYSMA5B.js.map} +0 -0
- /package/dist/esm/{chunk-SUBXSJXS.js.map → chunk-LLYDI3LD.js.map} +0 -0
- /package/dist/esm/{chunk-YMSNW2SU.js.map → chunk-MVVAEPGR.js.map} +0 -0
- /package/dist/esm/{chunk-LC5XQGWK.js.map → chunk-MXPZHEDH.js.map} +0 -0
- /package/dist/esm/{chunk-A5CFFQUV.js.map → chunk-MZRZVF5Q.js.map} +0 -0
- /package/dist/esm/{chunk-HZC52S2R.js.map → chunk-R2R3AMCG.js.map} +0 -0
- /package/dist/esm/{chunk-S46LW2P7.js.map → chunk-SDABEZSA.js.map} +0 -0
- /package/dist/esm/{chunk-PVWOU6LA.js.map → chunk-SV5CKUNN.js.map} +0 -0
- /package/dist/esm/{chunk-VRFQFDSM.js.map → chunk-VOMI5BAO.js.map} +0 -0
- /package/dist/esm/{chunk-ZJVWC666.js.map → chunk-WMHUZEL2.js.map} +0 -0
- /package/dist/esm/{chunk-RKLWSV24.js.map → chunk-XXDILT4B.js.map} +0 -0
- /package/dist/esm/{chunk-FRQSMPPK.js.map → chunk-ZUVYTTPD.js.map} +0 -0
|
@@ -0,0 +1,362 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _optionalChain(ops) { let lastAccessLHS = undefined; let value = ops[0]; let i = 1; while (i < ops.length) { const op = ops[i]; const fn = ops[i + 1]; i += 2; if ((op === 'optionalAccess' || op === 'optionalCall') && value == null) { return undefined; } if (op === 'access' || op === 'optionalAccess') { lastAccessLHS = value; value = fn(value); } else if (op === 'call' || op === 'optionalCall') { value = fn((...args) => value.call(lastAccessLHS, ...args)); lastAccessLHS = undefined; } } return value; }
|
|
2
|
+
|
|
3
|
+
var _chunk7HBOMBZGcjs = require('./chunk-7HBOMBZG.cjs');
|
|
4
|
+
|
|
5
|
+
|
|
6
|
+
var _chunkY524IIF6cjs = require('./chunk-Y524IIF6.cjs');
|
|
7
|
+
|
|
8
|
+
|
|
9
|
+
var _chunkO5X5QT63cjs = require('./chunk-O5X5QT63.cjs');
|
|
10
|
+
|
|
11
|
+
|
|
12
|
+
var _chunk2CQQ34EDcjs = require('./chunk-2CQQ34ED.cjs');
|
|
13
|
+
|
|
14
|
+
// src/services/intents/fulfill.service.ts
|
|
15
|
+
var _crypto = require('crypto');
|
|
16
|
+
var IntentFulfillService = class {
|
|
17
|
+
|
|
18
|
+
|
|
19
|
+
|
|
20
|
+
|
|
21
|
+
|
|
22
|
+
|
|
23
|
+
constructor(modelModule, memoryModule, a2aModule, mcpModule, onIntentFallback) {
|
|
24
|
+
this.modelModule = modelModule;
|
|
25
|
+
this.memoryModule = memoryModule;
|
|
26
|
+
this.a2aModule = a2aModule;
|
|
27
|
+
this.mcpModule = mcpModule;
|
|
28
|
+
this.onIntentFallback = onIntentFallback;
|
|
29
|
+
this.aggregateService = new (0, _chunkY524IIF6cjs.AggregateService)(modelModule);
|
|
30
|
+
}
|
|
31
|
+
async addToThreadMessages(thread, params) {
|
|
32
|
+
try {
|
|
33
|
+
const threadMemory = this.memoryModule.getThreadMemory();
|
|
34
|
+
const { userId, threadId } = thread;
|
|
35
|
+
const newMessage = {
|
|
36
|
+
messageId: _crypto.randomUUID.call(void 0, ),
|
|
37
|
+
role: params.role,
|
|
38
|
+
timestamp: Date.now(),
|
|
39
|
+
content: { type: "text", parts: [params.content] },
|
|
40
|
+
metadata: params.metadata
|
|
41
|
+
};
|
|
42
|
+
thread.messages.push(newMessage);
|
|
43
|
+
await _optionalChain([threadMemory, 'optionalAccess', _ => _.addMessagesToThread, 'call', _2 => _2(userId, threadId, [newMessage])]);
|
|
44
|
+
} catch (error) {
|
|
45
|
+
_chunk2CQQ34EDcjs.loggers.intentStream.error("Error adding message to thread", error);
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
/**
|
|
49
|
+
* Fulfills the detected intent by generating a streaming response.
|
|
50
|
+
*
|
|
51
|
+
* Manages the complete inference loop including:
|
|
52
|
+
* - Loading prompts and conversation history
|
|
53
|
+
* - Collecting available tools from modules
|
|
54
|
+
* - Executing model inference with tool support
|
|
55
|
+
* - Processing tool calls iteratively until completion
|
|
56
|
+
* - Streaming results as Server-Sent Events
|
|
57
|
+
*
|
|
58
|
+
* @param query - The user's input query
|
|
59
|
+
* @param threadId - Thread identifier for context
|
|
60
|
+
* @param thread - Previous conversation history
|
|
61
|
+
* @param intent - Optional detected intent with custom prompt
|
|
62
|
+
* @returns AsyncGenerator yielding StreamEvent objects
|
|
63
|
+
*/
|
|
64
|
+
async *intentFulfilling(query, thread, intent) {
|
|
65
|
+
const agentMemory = this.memoryModule.getAgentMemory();
|
|
66
|
+
const fulfillPrompt = await _chunk7HBOMBZGcjs.createFulfillPrompt.call(void 0, agentMemory, intent);
|
|
67
|
+
const modelInstance = this.modelModule.getModel();
|
|
68
|
+
const modelOptions = this.modelModule.getModelOptions();
|
|
69
|
+
const messages = modelInstance.generateMessages({
|
|
70
|
+
query,
|
|
71
|
+
thread,
|
|
72
|
+
systemPrompt: fulfillPrompt.trim()
|
|
73
|
+
});
|
|
74
|
+
_chunk2CQQ34EDcjs.loggers.intent.debug("Intent fulfillment start", {
|
|
75
|
+
threadId: thread.threadId,
|
|
76
|
+
messages
|
|
77
|
+
});
|
|
78
|
+
const tools = [];
|
|
79
|
+
this.mcpModule && tools.push(...this.mcpModule.getTools());
|
|
80
|
+
this.a2aModule && tools.push(...await this.a2aModule.getTools());
|
|
81
|
+
const processList = [];
|
|
82
|
+
while (true) {
|
|
83
|
+
const functions = modelInstance.convertToolsToFunctions(tools);
|
|
84
|
+
const responseStream = await modelInstance.fetchStreamWithContextMessage(
|
|
85
|
+
messages,
|
|
86
|
+
functions,
|
|
87
|
+
modelOptions
|
|
88
|
+
);
|
|
89
|
+
const assembledToolCalls = [];
|
|
90
|
+
for await (const chunk of responseStream) {
|
|
91
|
+
const delta = chunk.delta;
|
|
92
|
+
if (_optionalChain([delta, 'optionalAccess', _3 => _3.tool_calls])) {
|
|
93
|
+
for (const { index, id, function: func } of delta.tool_calls) {
|
|
94
|
+
assembledToolCalls[index] ??= {
|
|
95
|
+
id: "",
|
|
96
|
+
type: "function",
|
|
97
|
+
function: { name: "", arguments: "" }
|
|
98
|
+
};
|
|
99
|
+
if (id) assembledToolCalls[index].id = id;
|
|
100
|
+
if (_optionalChain([func, 'optionalAccess', _4 => _4.name])) assembledToolCalls[index].function.name = func.name;
|
|
101
|
+
if (_optionalChain([func, 'optionalAccess', _5 => _5.arguments]))
|
|
102
|
+
assembledToolCalls[index].function.arguments += func.arguments;
|
|
103
|
+
}
|
|
104
|
+
} else if (_optionalChain([chunk, 'access', _6 => _6.delta, 'optionalAccess', _7 => _7.content])) {
|
|
105
|
+
yield {
|
|
106
|
+
event: "text_chunk",
|
|
107
|
+
data: { delta: chunk.delta.content }
|
|
108
|
+
};
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
_chunk2CQQ34EDcjs.loggers.intentStream.debug("assembledToolCalls", {
|
|
112
|
+
threadId: thread.threadId,
|
|
113
|
+
assembledToolCalls
|
|
114
|
+
});
|
|
115
|
+
if (assembledToolCalls.length > 0) {
|
|
116
|
+
for (const toolCall of assembledToolCalls) {
|
|
117
|
+
const toolName = toolCall.function.name;
|
|
118
|
+
let selectedTool;
|
|
119
|
+
for (const [index, toolTmp] of tools.entries()) {
|
|
120
|
+
if (toolTmp.toolName === toolName) {
|
|
121
|
+
if (toolTmp.protocol === "A2A" /* A2A */) {
|
|
122
|
+
selectedTool = tools.splice(index, 1)[0];
|
|
123
|
+
break;
|
|
124
|
+
}
|
|
125
|
+
selectedTool = toolTmp;
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
if (!selectedTool) {
|
|
129
|
+
continue;
|
|
130
|
+
}
|
|
131
|
+
const toolArgs = JSON.parse(toolCall.function.arguments);
|
|
132
|
+
const thinkData = {
|
|
133
|
+
title: `[${_chunkO5X5QT63cjs.getManifest.call(void 0, ).name}] ${selectedTool.protocol} \uC2E4\uD589: ${toolName}`,
|
|
134
|
+
description: `${toolArgs.thinking_text || ""}`
|
|
135
|
+
};
|
|
136
|
+
yield {
|
|
137
|
+
event: "thinking_process",
|
|
138
|
+
data: thinkData
|
|
139
|
+
};
|
|
140
|
+
let toolResult = "";
|
|
141
|
+
if (this.mcpModule && selectedTool.protocol === "MCP" /* MCP */) {
|
|
142
|
+
_chunk2CQQ34EDcjs.loggers.intent.info("MCP tool call", { toolName, toolArgs });
|
|
143
|
+
toolResult = await this.mcpModule.useTool(selectedTool, toolArgs);
|
|
144
|
+
} else if (this.a2aModule && selectedTool.protocol === "A2A" /* A2A */) {
|
|
145
|
+
_chunk2CQQ34EDcjs.loggers.intent.info("A2A tool call", { toolName });
|
|
146
|
+
const a2aStream = this.a2aModule.useTool(
|
|
147
|
+
selectedTool,
|
|
148
|
+
query,
|
|
149
|
+
thread.threadId
|
|
150
|
+
);
|
|
151
|
+
let result = await a2aStream.next();
|
|
152
|
+
while (!result.done) {
|
|
153
|
+
if (result.value.event === "thinking_process") {
|
|
154
|
+
yield result.value;
|
|
155
|
+
}
|
|
156
|
+
result = await a2aStream.next();
|
|
157
|
+
}
|
|
158
|
+
toolResult = result.value;
|
|
159
|
+
} else {
|
|
160
|
+
_chunk2CQQ34EDcjs.loggers.intent.warn(
|
|
161
|
+
`Unrecognized tool type: ${selectedTool.protocol}`
|
|
162
|
+
);
|
|
163
|
+
continue;
|
|
164
|
+
}
|
|
165
|
+
_chunk2CQQ34EDcjs.loggers.intent.debug("Tool Result", { toolResult });
|
|
166
|
+
processList.push(toolResult);
|
|
167
|
+
modelInstance.appendMessages(messages, toolResult);
|
|
168
|
+
}
|
|
169
|
+
} else {
|
|
170
|
+
break;
|
|
171
|
+
}
|
|
172
|
+
}
|
|
173
|
+
_chunk2CQQ34EDcjs.loggers.intent.debug("Intent fulfillment completed", {
|
|
174
|
+
threadId: thread.threadId,
|
|
175
|
+
toolCallsExecuted: processList.length,
|
|
176
|
+
intentName: _optionalChain([intent, 'optionalAccess', _8 => _8.name])
|
|
177
|
+
});
|
|
178
|
+
}
|
|
179
|
+
/**
|
|
180
|
+
* Returns the appropriate stream for a triggered intent.
|
|
181
|
+
* Uses fallback handler if no intent matched and fallback is configured.
|
|
182
|
+
*/
|
|
183
|
+
getIntentStream(triggeredIntent, thread) {
|
|
184
|
+
const { subquery = "", intent } = triggeredIntent;
|
|
185
|
+
if (!intent && this.onIntentFallback) {
|
|
186
|
+
_chunk2CQQ34EDcjs.loggers.intent.info("No intent matched, calling fallback handler");
|
|
187
|
+
const fallbackStream = this.onIntentFallback({
|
|
188
|
+
triggeredIntent,
|
|
189
|
+
thread
|
|
190
|
+
});
|
|
191
|
+
if (fallbackStream !== void 0) {
|
|
192
|
+
return fallbackStream;
|
|
193
|
+
}
|
|
194
|
+
}
|
|
195
|
+
return this.intentFulfilling(subquery, thread, intent);
|
|
196
|
+
}
|
|
197
|
+
/**
|
|
198
|
+
* Processes all triggered intents and generates a unified response.
|
|
199
|
+
*
|
|
200
|
+
* Workflow:
|
|
201
|
+
* 1. Process each intent sequentially, collecting results
|
|
202
|
+
* 2. Yield thinking_process events for progress visibility
|
|
203
|
+
* 3. Use AggregateService to unify results if needsAggregation is true
|
|
204
|
+
* 4. Stream the final (possibly aggregated) response
|
|
205
|
+
*
|
|
206
|
+
* @param intents - Array of triggered intents to process
|
|
207
|
+
* @param thread - The thread history
|
|
208
|
+
* @param originalQuery - The user's original query (for aggregate context)
|
|
209
|
+
* @param needsAggregation - Whether the results need to be aggregated
|
|
210
|
+
* @returns AsyncGenerator yielding StreamEvent objects
|
|
211
|
+
*/
|
|
212
|
+
async *intentFulfill(intents, thread, originalQuery, needsAggregation) {
|
|
213
|
+
const streamStartTime = Date.now();
|
|
214
|
+
_chunk2CQQ34EDcjs.loggers.intentStream.info("Stream session started", {
|
|
215
|
+
threadId: thread.threadId,
|
|
216
|
+
intentCount: intents.length,
|
|
217
|
+
needsAggregation,
|
|
218
|
+
startTime: new Date(streamStartTime).toISOString()
|
|
219
|
+
});
|
|
220
|
+
let finalResponseText = "";
|
|
221
|
+
if (intents.length <= 1) {
|
|
222
|
+
const triggeredIntent = intents[0];
|
|
223
|
+
if (!triggeredIntent) {
|
|
224
|
+
return;
|
|
225
|
+
}
|
|
226
|
+
const { subquery = "", intent, actionPlan } = triggeredIntent;
|
|
227
|
+
_chunk2CQQ34EDcjs.loggers.intent.info(
|
|
228
|
+
`Process single intent: ${subquery}, ${_optionalChain([intent, 'optionalAccess', _9 => _9.name])}`
|
|
229
|
+
);
|
|
230
|
+
_chunk2CQQ34EDcjs.loggers.intent.info(`Action plan: ${actionPlan}`);
|
|
231
|
+
yield {
|
|
232
|
+
event: "thinking_process",
|
|
233
|
+
data: {
|
|
234
|
+
title: `[${_chunkO5X5QT63cjs.getManifest.call(void 0, ).name}] ${subquery}`,
|
|
235
|
+
description: actionPlan || ""
|
|
236
|
+
}
|
|
237
|
+
};
|
|
238
|
+
const stream = this.getIntentStream(triggeredIntent, thread);
|
|
239
|
+
if (!stream) {
|
|
240
|
+
return;
|
|
241
|
+
}
|
|
242
|
+
for await (const event of stream) {
|
|
243
|
+
if (event.event === "text_chunk" && event.data.delta) {
|
|
244
|
+
finalResponseText += event.data.delta;
|
|
245
|
+
}
|
|
246
|
+
yield event;
|
|
247
|
+
}
|
|
248
|
+
} else if (!needsAggregation) {
|
|
249
|
+
for (let i = 0; i < intents.length; i++) {
|
|
250
|
+
const triggeredIntent = intents[i];
|
|
251
|
+
const { subquery = "", intent, actionPlan } = triggeredIntent;
|
|
252
|
+
_chunk2CQQ34EDcjs.loggers.intent.info(`Process query: ${subquery}, ${_optionalChain([intent, 'optionalAccess', _10 => _10.name])}`);
|
|
253
|
+
_chunk2CQQ34EDcjs.loggers.intent.info(`Action plan: ${actionPlan}`);
|
|
254
|
+
const isLastIntent = i === intents.length - 1;
|
|
255
|
+
yield {
|
|
256
|
+
event: "thinking_process",
|
|
257
|
+
data: {
|
|
258
|
+
title: `[${_chunkO5X5QT63cjs.getManifest.call(void 0, ).name}] ${subquery}`,
|
|
259
|
+
description: actionPlan || ""
|
|
260
|
+
}
|
|
261
|
+
};
|
|
262
|
+
const stream = this.getIntentStream(triggeredIntent, thread);
|
|
263
|
+
if (!stream) {
|
|
264
|
+
continue;
|
|
265
|
+
}
|
|
266
|
+
if (isLastIntent) {
|
|
267
|
+
for await (const event of stream) {
|
|
268
|
+
if (event.event === "text_chunk" && event.data.delta) {
|
|
269
|
+
finalResponseText += event.data.delta;
|
|
270
|
+
}
|
|
271
|
+
yield event;
|
|
272
|
+
}
|
|
273
|
+
} else {
|
|
274
|
+
let responseText = "";
|
|
275
|
+
for await (const event of stream) {
|
|
276
|
+
if (event.event === "text_chunk" && event.data.delta) {
|
|
277
|
+
responseText += event.data.delta;
|
|
278
|
+
} else if (event.event === "thinking_process") {
|
|
279
|
+
yield event;
|
|
280
|
+
}
|
|
281
|
+
}
|
|
282
|
+
thread.messages.push({
|
|
283
|
+
messageId: _crypto.randomUUID.call(void 0, ),
|
|
284
|
+
role: "MODEL" /* MODEL */,
|
|
285
|
+
timestamp: Date.now(),
|
|
286
|
+
content: { type: "text", parts: [responseText] },
|
|
287
|
+
metadata: { isThinking: true }
|
|
288
|
+
});
|
|
289
|
+
}
|
|
290
|
+
}
|
|
291
|
+
} else {
|
|
292
|
+
const fulfillmentResults = [];
|
|
293
|
+
for (let i = 0; i < intents.length; i++) {
|
|
294
|
+
const triggeredIntent = intents[i];
|
|
295
|
+
const { subquery = "", intent, actionPlan } = triggeredIntent;
|
|
296
|
+
_chunk2CQQ34EDcjs.loggers.intent.info(`Process query: ${subquery}, ${_optionalChain([intent, 'optionalAccess', _11 => _11.name])}`);
|
|
297
|
+
_chunk2CQQ34EDcjs.loggers.intent.info(`Action plan: ${actionPlan}`);
|
|
298
|
+
if (fulfillmentResults.length > 0) {
|
|
299
|
+
const lastResult = fulfillmentResults[fulfillmentResults.length - 1];
|
|
300
|
+
thread.messages.push({
|
|
301
|
+
messageId: _crypto.randomUUID.call(void 0, ),
|
|
302
|
+
role: "MODEL" /* MODEL */,
|
|
303
|
+
timestamp: Date.now(),
|
|
304
|
+
content: { type: "text", parts: [lastResult.response] },
|
|
305
|
+
metadata: { isThinking: true }
|
|
306
|
+
});
|
|
307
|
+
}
|
|
308
|
+
yield {
|
|
309
|
+
event: "thinking_process",
|
|
310
|
+
data: {
|
|
311
|
+
title: `[${_chunkO5X5QT63cjs.getManifest.call(void 0, ).name}] ${subquery}`,
|
|
312
|
+
description: actionPlan || ""
|
|
313
|
+
}
|
|
314
|
+
};
|
|
315
|
+
const stream = this.getIntentStream(triggeredIntent, thread);
|
|
316
|
+
if (!stream) {
|
|
317
|
+
continue;
|
|
318
|
+
}
|
|
319
|
+
let responseText = "";
|
|
320
|
+
for await (const event of stream) {
|
|
321
|
+
if (event.event === "text_chunk" && event.data.delta) {
|
|
322
|
+
responseText += event.data.delta;
|
|
323
|
+
} else if (event.event === "thinking_process") {
|
|
324
|
+
yield event;
|
|
325
|
+
}
|
|
326
|
+
}
|
|
327
|
+
fulfillmentResults.push({
|
|
328
|
+
subquery,
|
|
329
|
+
intent,
|
|
330
|
+
actionPlan,
|
|
331
|
+
response: responseText
|
|
332
|
+
});
|
|
333
|
+
}
|
|
334
|
+
const aggregateStream = this.aggregateService.aggregate(
|
|
335
|
+
originalQuery,
|
|
336
|
+
fulfillmentResults
|
|
337
|
+
);
|
|
338
|
+
for await (const event of aggregateStream) {
|
|
339
|
+
if (event.event === "text_chunk" && event.data.delta) {
|
|
340
|
+
finalResponseText += event.data.delta;
|
|
341
|
+
}
|
|
342
|
+
yield event;
|
|
343
|
+
}
|
|
344
|
+
}
|
|
345
|
+
await this.addToThreadMessages(thread, {
|
|
346
|
+
role: "MODEL" /* MODEL */,
|
|
347
|
+
content: finalResponseText
|
|
348
|
+
});
|
|
349
|
+
const streamEndTime = Date.now();
|
|
350
|
+
const streamDuration = streamEndTime - streamStartTime;
|
|
351
|
+
_chunk2CQQ34EDcjs.loggers.intentStream.info("Stream session completed", {
|
|
352
|
+
threadId: thread.threadId,
|
|
353
|
+
duration: `${streamDuration}ms`,
|
|
354
|
+
endTime: new Date(streamEndTime).toISOString()
|
|
355
|
+
});
|
|
356
|
+
}
|
|
357
|
+
};
|
|
358
|
+
|
|
359
|
+
|
|
360
|
+
|
|
361
|
+
exports.IntentFulfillService = IntentFulfillService;
|
|
362
|
+
//# sourceMappingURL=chunk-UQFLEWWA.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-UQFLEWWA.cjs","../../src/services/intents/fulfill.service.ts"],"names":[],"mappings":"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","file":"/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-UQFLEWWA.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 type { OnIntentFallback } from \"@/types/agent\";\nimport { CONNECTOR_PROTOCOL_TYPE, type ConnectorTool } from \"@/types/connector\";\nimport {\n\ttype FulfillmentResult,\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\";\nimport { AggregateService } from \"./aggregate.service\";\n\nexport class IntentFulfillService {\n\tprivate modelModule: ModelModule;\n\tprivate memoryModule: MemoryModule;\n\tprivate a2aModule?: A2AModule;\n\tprivate mcpModule?: MCPModule;\n\tprivate onIntentFallback?: OnIntentFallback;\n\tprivate aggregateService: AggregateService;\n\n\tconstructor(\n\t\tmodelModule: ModelModule,\n\t\tmemoryModule: MemoryModule,\n\t\ta2aModule?: A2AModule,\n\t\tmcpModule?: MCPModule,\n\t\tonIntentFallback?: OnIntentFallback,\n\t) {\n\t\tthis.modelModule = modelModule;\n\t\tthis.memoryModule = memoryModule;\n\t\tthis.a2aModule = a2aModule;\n\t\tthis.mcpModule = mcpModule;\n\t\tthis.onIntentFallback = onIntentFallback;\n\t\tthis.aggregateService = new AggregateService(modelModule);\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 * Returns the appropriate stream for a triggered intent.\n\t * Uses fallback handler if no intent matched and fallback is configured.\n\t */\n\tprivate getIntentStream(\n\t\ttriggeredIntent: TriggeredIntent,\n\t\tthread: ThreadObject,\n\t): AsyncGenerator<StreamEvent> | undefined {\n\t\tconst { subquery = \"\", intent } = triggeredIntent;\n\n\t\tif (!intent && this.onIntentFallback) {\n\t\t\tloggers.intent.info(\"No intent matched, calling fallback handler\");\n\t\t\tconst fallbackStream = this.onIntentFallback({\n\t\t\t\ttriggeredIntent,\n\t\t\t\tthread,\n\t\t\t});\n\t\t\tif (fallbackStream !== undefined) {\n\t\t\t\treturn fallbackStream;\n\t\t\t}\n\t\t}\n\n\t\treturn this.intentFulfilling(subquery, thread, intent);\n\t}\n\n\t/**\n\t * Processes all triggered intents and generates a unified response.\n\t *\n\t * Workflow:\n\t * 1. Process each intent sequentially, collecting results\n\t * 2. Yield thinking_process events for progress visibility\n\t * 3. Use AggregateService to unify results if needsAggregation is true\n\t * 4. Stream the final (possibly aggregated) response\n\t *\n\t * @param intents - Array of triggered intents to process\n\t * @param thread - The thread history\n\t * @param originalQuery - The user's original query (for aggregate context)\n\t * @param needsAggregation - Whether the results need to be aggregated\n\t * @returns AsyncGenerator yielding StreamEvent objects\n\t */\n\tpublic async *intentFulfill(\n\t\tintents: Array<TriggeredIntent>,\n\t\tthread: ThreadObject,\n\t\toriginalQuery: string,\n\t\tneedsAggregation: boolean,\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\tneedsAggregation,\n\t\t\tstartTime: new Date(streamStartTime).toISOString(),\n\t\t});\n\n\t\tlet finalResponseText = \"\";\n\n\t\tif (intents.length <= 1) {\n\t\t\t// Single intent: stream response directly\n\t\t\tconst triggeredIntent = intents[0];\n\t\t\tif (!triggeredIntent) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\tconst { subquery = \"\", intent, actionPlan } = triggeredIntent;\n\t\t\tloggers.intent.info(\n\t\t\t\t`Process single intent: ${subquery}, ${intent?.name}`,\n\t\t\t);\n\t\t\tloggers.intent.info(`Action plan: ${actionPlan}`);\n\n\t\t\t// Yield thinking_process for progress visibility\n\t\t\tyield {\n\t\t\t\tevent: \"thinking_process\",\n\t\t\t\tdata: {\n\t\t\t\t\ttitle: `[${getManifest().name}] ${subquery}`,\n\t\t\t\t\tdescription: actionPlan || \"\",\n\t\t\t\t},\n\t\t\t};\n\n\t\t\t// Get the stream for this intent\n\t\t\tconst stream = this.getIntentStream(triggeredIntent, thread);\n\t\t\tif (!stream) {\n\t\t\t\treturn;\n\t\t\t}\n\n\t\t\t// Stream response directly\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\t\t\t\tyield event;\n\t\t\t}\n\t\t} else if (!needsAggregation) {\n\t\t\t// Multiple intents but no aggregation needed: collect intermediate results, stream only last\n\t\t\tfor (let i = 0; i < intents.length; i++) {\n\t\t\t\tconst triggeredIntent = intents[i];\n\t\t\t\tconst { subquery = \"\", intent, actionPlan } = triggeredIntent;\n\t\t\t\tloggers.intent.info(`Process query: ${subquery}, ${intent?.name}`);\n\t\t\t\tloggers.intent.info(`Action plan: ${actionPlan}`);\n\n\t\t\t\tconst isLastIntent = i === intents.length - 1;\n\n\t\t\t\t// Yield thinking_process for progress visibility\n\t\t\t\tyield {\n\t\t\t\t\tevent: \"thinking_process\",\n\t\t\t\t\tdata: {\n\t\t\t\t\t\ttitle: `[${getManifest().name}] ${subquery}`,\n\t\t\t\t\t\tdescription: actionPlan || \"\",\n\t\t\t\t\t},\n\t\t\t\t};\n\n\t\t\t\t// Get the stream for this intent\n\t\t\t\tconst stream = this.getIntentStream(triggeredIntent, thread);\n\t\t\t\tif (!stream) {\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\n\t\t\t\tif (isLastIntent) {\n\t\t\t\t\t// Stream last intent response directly\n\t\t\t\t\tfor await (const event of stream) {\n\t\t\t\t\t\tif (event.event === \"text_chunk\" && event.data.delta) {\n\t\t\t\t\t\t\tfinalResponseText += event.data.delta;\n\t\t\t\t\t\t}\n\t\t\t\t\t\tyield event;\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\t// Collect intermediate results without streaming text_chunk\n\t\t\t\t\tlet responseText = \"\";\n\t\t\t\t\tfor await (const event of stream) {\n\t\t\t\t\t\tif (event.event === \"text_chunk\" && event.data.delta) {\n\t\t\t\t\t\t\tresponseText += event.data.delta;\n\t\t\t\t\t\t} else if (event.event === \"thinking_process\") {\n\t\t\t\t\t\t\t// Tool execution thinking_process events are yielded immediately\n\t\t\t\t\t\t\tyield event;\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t\t// Add intermediate result to thread context for next intent\n\t\t\t\t\tthread.messages.push({\n\t\t\t\t\t\tmessageId: randomUUID(),\n\t\t\t\t\t\trole: MessageRole.MODEL,\n\t\t\t\t\t\ttimestamp: Date.now(),\n\t\t\t\t\t\tcontent: { type: \"text\", parts: [responseText] },\n\t\t\t\t\t\tmetadata: { isThinking: true },\n\t\t\t\t\t});\n\t\t\t\t}\n\t\t\t}\n\t\t} else {\n\t\t\t// Multi-intent mode with aggregation: collect all results then aggregate\n\t\t\tconst fulfillmentResults: FulfillmentResult[] = [];\n\n\t\t\tfor (let i = 0; i < intents.length; i++) {\n\t\t\t\tconst triggeredIntent = intents[i];\n\t\t\t\tconst { subquery = \"\", intent, actionPlan } = triggeredIntent;\n\t\t\t\tloggers.intent.info(`Process query: ${subquery}, ${intent?.name}`);\n\t\t\t\tloggers.intent.info(`Action plan: ${actionPlan}`);\n\n\t\t\t\t// Add previous result to thread context for inference (not stored in memory)\n\t\t\t\tif (fulfillmentResults.length > 0) {\n\t\t\t\t\tconst lastResult = fulfillmentResults[fulfillmentResults.length - 1];\n\t\t\t\t\tthread.messages.push({\n\t\t\t\t\t\tmessageId: randomUUID(),\n\t\t\t\t\t\trole: MessageRole.MODEL,\n\t\t\t\t\t\ttimestamp: Date.now(),\n\t\t\t\t\t\tcontent: { type: \"text\", parts: [lastResult.response] },\n\t\t\t\t\t\tmetadata: { isThinking: true },\n\t\t\t\t\t});\n\t\t\t\t}\n\n\t\t\t\t// Yield thinking_process for progress visibility\n\t\t\t\tyield {\n\t\t\t\t\tevent: \"thinking_process\",\n\t\t\t\t\tdata: {\n\t\t\t\t\t\ttitle: `[${getManifest().name}] ${subquery}`,\n\t\t\t\t\t\tdescription: actionPlan || \"\",\n\t\t\t\t\t},\n\t\t\t\t};\n\n\t\t\t\t// Get the stream for this intent\n\t\t\t\tconst stream = this.getIntentStream(triggeredIntent, thread);\n\t\t\t\tif (!stream) {\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\n\t\t\t\t// Collect response text (don't yield text_chunk yet)\n\t\t\t\tlet responseText = \"\";\n\t\t\t\tfor await (const event of stream) {\n\t\t\t\t\tif (event.event === \"text_chunk\" && event.data.delta) {\n\t\t\t\t\t\tresponseText += event.data.delta;\n\t\t\t\t\t} else if (event.event === \"thinking_process\") {\n\t\t\t\t\t\t// Tool execution thinking_process events are yielded immediately\n\t\t\t\t\t\tyield event;\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tfulfillmentResults.push({\n\t\t\t\t\tsubquery,\n\t\t\t\t\tintent,\n\t\t\t\t\tactionPlan,\n\t\t\t\t\tresponse: responseText,\n\t\t\t\t});\n\t\t\t}\n\n\t\t\t// Aggregate step: generate unified response\n\t\t\tconst aggregateStream = this.aggregateService.aggregate(\n\t\t\t\toriginalQuery,\n\t\t\t\tfulfillmentResults,\n\t\t\t);\n\n\t\t\tfor await (const event of aggregateStream) {\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\t\t\t\tyield event;\n\t\t\t}\n\t\t}\n\n\t\t// Save final response to memory\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"]}
|
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports, "__esModule", {value: true});
|
|
2
|
+
|
|
3
|
+
var _chunkCPXITYT4cjs = require('./chunk-CPXITYT4.cjs');
|
|
4
|
+
|
|
5
|
+
|
|
6
|
+
var _chunkFK2PASX2cjs = require('./chunk-FK2PASX2.cjs');
|
|
7
|
+
|
|
8
|
+
// src/container/index.ts
|
|
9
|
+
var Container = class {
|
|
10
|
+
|
|
11
|
+
|
|
12
|
+
constructor() {
|
|
13
|
+
this._services = new (0, _chunkFK2PASX2cjs.ServiceContainer)();
|
|
14
|
+
this._controllers = new (0, _chunkCPXITYT4cjs.ControllerContainer)(this._services);
|
|
15
|
+
}
|
|
16
|
+
// Services
|
|
17
|
+
get services() {
|
|
18
|
+
return this._services;
|
|
19
|
+
}
|
|
20
|
+
// Controllers
|
|
21
|
+
get controllers() {
|
|
22
|
+
return this._controllers;
|
|
23
|
+
}
|
|
24
|
+
// Convenience methods for direct access
|
|
25
|
+
getThreadService() {
|
|
26
|
+
return this._services.getThreadService();
|
|
27
|
+
}
|
|
28
|
+
getIntentTriggerService() {
|
|
29
|
+
return this._services.getIntentTriggerService();
|
|
30
|
+
}
|
|
31
|
+
getIntentFulfillService() {
|
|
32
|
+
return this._services.getIntentFulfillService();
|
|
33
|
+
}
|
|
34
|
+
getQueryService() {
|
|
35
|
+
return this._services.getQueryService();
|
|
36
|
+
}
|
|
37
|
+
getA2AService() {
|
|
38
|
+
return this._services.getA2AService();
|
|
39
|
+
}
|
|
40
|
+
getQueryController() {
|
|
41
|
+
return this._controllers.getQueryController();
|
|
42
|
+
}
|
|
43
|
+
getIntentController() {
|
|
44
|
+
return this._controllers.getIntentController();
|
|
45
|
+
}
|
|
46
|
+
getModelApiController() {
|
|
47
|
+
return this._controllers.getModelApiController();
|
|
48
|
+
}
|
|
49
|
+
getAgentApiController() {
|
|
50
|
+
return this._controllers.getAgentApiController();
|
|
51
|
+
}
|
|
52
|
+
getThreadApiController() {
|
|
53
|
+
return this._controllers.getThreadApiController();
|
|
54
|
+
}
|
|
55
|
+
getIntentApiController() {
|
|
56
|
+
return this._controllers.getIntentApiController();
|
|
57
|
+
}
|
|
58
|
+
getWorkflowApiController() {
|
|
59
|
+
return this._controllers.getWorkflowApiController();
|
|
60
|
+
}
|
|
61
|
+
/**
|
|
62
|
+
* Reset all instances (useful for testing)
|
|
63
|
+
*/
|
|
64
|
+
reset() {
|
|
65
|
+
this._services.reset();
|
|
66
|
+
this._controllers.reset();
|
|
67
|
+
}
|
|
68
|
+
};
|
|
69
|
+
var container = new Container();
|
|
70
|
+
|
|
71
|
+
|
|
72
|
+
|
|
73
|
+
exports.container = container;
|
|
74
|
+
//# sourceMappingURL=chunk-UVPSBGW7.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-UVPSBGW7.cjs","../../src/container/index.ts"],"names":[],"mappings":"AAAA;AACE;AACF,wDAA6B;AAC7B;AACE;AACF,wDAA6B;AAC7B;AACA;ACKA,IAAM,UAAA,EAAN,MAAgB;AAAA,EACP;AAAA,EACA;AAAA,EAER,WAAA,CAAA,EAAc;AACb,IAAA,IAAA,CAAK,UAAA,EAAY,IAAI,uCAAA,CAAiB,CAAA;AACtC,IAAA,IAAA,CAAK,aAAA,EAAe,IAAI,0CAAA,CAAoB,IAAA,CAAK,SAAS,CAAA;AAAA,EAC3D;AAAA;AAAA,EAGA,IAAI,QAAA,CAAA,EAA6B;AAChC,IAAA,OAAO,IAAA,CAAK,SAAA;AAAA,EACb;AAAA;AAAA,EAGA,IAAI,WAAA,CAAA,EAAmC;AACtC,IAAA,OAAO,IAAA,CAAK,YAAA;AAAA,EACb;AAAA;AAAA,EAGA,gBAAA,CAAA,EAAmB;AAClB,IAAA,OAAO,IAAA,CAAK,SAAA,CAAU,gBAAA,CAAiB,CAAA;AAAA,EACxC;AAAA,EACA,uBAAA,CAAA,EAA0B;AACzB,IAAA,OAAO,IAAA,CAAK,SAAA,CAAU,uBAAA,CAAwB,CAAA;AAAA,EAC/C;AAAA,EACA,uBAAA,CAAA,EAA0B;AACzB,IAAA,OAAO,IAAA,CAAK,SAAA,CAAU,uBAAA,CAAwB,CAAA;AAAA,EAC/C;AAAA,EACA,eAAA,CAAA,EAAkB;AACjB,IAAA,OAAO,IAAA,CAAK,SAAA,CAAU,eAAA,CAAgB,CAAA;AAAA,EACvC;AAAA,EACA,aAAA,CAAA,EAAgB;AACf,IAAA,OAAO,IAAA,CAAK,SAAA,CAAU,aAAA,CAAc,CAAA;AAAA,EACrC;AAAA,EAEA,kBAAA,CAAA,EAAqB;AACpB,IAAA,OAAO,IAAA,CAAK,YAAA,CAAa,kBAAA,CAAmB,CAAA;AAAA,EAC7C;AAAA,EACA,mBAAA,CAAA,EAAsB;AACrB,IAAA,OAAO,IAAA,CAAK,YAAA,CAAa,mBAAA,CAAoB,CAAA;AAAA,EAC9C;AAAA,EACA,qBAAA,CAAA,EAAwB;AACvB,IAAA,OAAO,IAAA,CAAK,YAAA,CAAa,qBAAA,CAAsB,CAAA;AAAA,EAChD;AAAA,EACA,qBAAA,CAAA,EAAwB;AACvB,IAAA,OAAO,IAAA,CAAK,YAAA,CAAa,qBAAA,CAAsB,CAAA;AAAA,EAChD;AAAA,EACA,sBAAA,CAAA,EAAyB;AACxB,IAAA,OAAO,IAAA,CAAK,YAAA,CAAa,sBAAA,CAAuB,CAAA;AAAA,EACjD;AAAA,EACA,sBAAA,CAAA,EAAyB;AACxB,IAAA,OAAO,IAAA,CAAK,YAAA,CAAa,sBAAA,CAAuB,CAAA;AAAA,EACjD;AAAA,EACA,wBAAA,CAAA,EAA2B;AAC1B,IAAA,OAAO,IAAA,CAAK,YAAA,CAAa,wBAAA,CAAyB,CAAA;AAAA,EACnD;AAAA;AAAA;AAAA;AAAA,EAKA,KAAA,CAAA,EAAc;AACb,IAAA,IAAA,CAAK,SAAA,CAAU,KAAA,CAAM,CAAA;AACrB,IAAA,IAAA,CAAK,YAAA,CAAa,KAAA,CAAM,CAAA;AAAA,EACzB;AACD,CAAA;AAGO,IAAM,UAAA,EAAY,IAAI,SAAA,CAAU,CAAA;ADXvC;AACA;AACE;AACF,8BAAC","file":"/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-UVPSBGW7.cjs","sourcesContent":[null,"import { ControllerContainer } from \"./controllers\";\nimport { ServiceContainer } from \"./services\";\n\n/**\n * Dependency Injection Container\n *\n * Provides singleton instances of services and controllers with proper dependency injection.\n * Benefits:\n * - Services maintain DI pattern (testable with mocks)\n * - Routes use clean, simple API\n * - Dependencies are explicit and traceable\n */\nclass Container {\n\tprivate _services: ServiceContainer;\n\tprivate _controllers: ControllerContainer;\n\n\tconstructor() {\n\t\tthis._services = new ServiceContainer();\n\t\tthis._controllers = new ControllerContainer(this._services);\n\t}\n\n\t// Services\n\tget services(): ServiceContainer {\n\t\treturn this._services;\n\t}\n\n\t// Controllers\n\tget controllers(): ControllerContainer {\n\t\treturn this._controllers;\n\t}\n\n\t// Convenience methods for direct access\n\tgetThreadService() {\n\t\treturn this._services.getThreadService();\n\t}\n\tgetIntentTriggerService() {\n\t\treturn this._services.getIntentTriggerService();\n\t}\n\tgetIntentFulfillService() {\n\t\treturn this._services.getIntentFulfillService();\n\t}\n\tgetQueryService() {\n\t\treturn this._services.getQueryService();\n\t}\n\tgetA2AService() {\n\t\treturn this._services.getA2AService();\n\t}\n\n\tgetQueryController() {\n\t\treturn this._controllers.getQueryController();\n\t}\n\tgetIntentController() {\n\t\treturn this._controllers.getIntentController();\n\t}\n\tgetModelApiController() {\n\t\treturn this._controllers.getModelApiController();\n\t}\n\tgetAgentApiController() {\n\t\treturn this._controllers.getAgentApiController();\n\t}\n\tgetThreadApiController() {\n\t\treturn this._controllers.getThreadApiController();\n\t}\n\tgetIntentApiController() {\n\t\treturn this._controllers.getIntentApiController();\n\t}\n\tgetWorkflowApiController() {\n\t\treturn this._controllers.getWorkflowApiController();\n\t}\n\n\t/**\n\t * Reset all instances (useful for testing)\n\t */\n\treset(): void {\n\t\tthis._services.reset();\n\t\tthis._controllers.reset();\n\t}\n}\n\n// Export singleton instance\nexport const container = new Container();\n\n// Export types for testing\nexport { ControllerContainer } from \"./controllers\";\nexport { ServiceContainer } from \"./services\";\n"]}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports, "__esModule", {value: true});
|
|
2
|
+
|
|
3
|
+
var _chunk2LUY44JTcjs = require('./chunk-2LUY44JT.cjs');
|
|
4
|
+
|
|
5
|
+
// src/routes/api/model.routes.ts
|
|
6
|
+
var _express = require('express');
|
|
7
|
+
var createModelApiRouter = () => {
|
|
8
|
+
const router = _express.Router.call(void 0, );
|
|
9
|
+
const modelApiController = _chunk2LUY44JTcjs.container.getModelApiController();
|
|
10
|
+
router.get("/", modelApiController.handleModelList);
|
|
11
|
+
return router;
|
|
12
|
+
};
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
|
|
16
|
+
exports.createModelApiRouter = createModelApiRouter;
|
|
17
|
+
//# sourceMappingURL=chunk-VDXJGAFA.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-VDXJGAFA.cjs","../../src/routes/api/model.routes.ts"],"names":[],"mappings":"AAAA;AACE;AACF,wDAA6B;AAC7B;AACA;ACJA,kCAAuB;AAGhB,IAAM,qBAAA,EAAuB,CAAA,EAAA,GAAc;AACjD,EAAA,MAAM,OAAA,EAAS,6BAAA,CAAO;AACtB,EAAA,MAAM,mBAAA,EAAqB,2BAAA,CAAU,qBAAA,CAAsB,CAAA;AAG3D,EAAA,MAAA,CAAO,GAAA,CAAI,GAAA,EAAK,kBAAA,CAAmB,eAAe,CAAA;AAElD,EAAA,OAAO,MAAA;AACR,CAAA;ADCA;AACA;AACE;AACF,oDAAC","file":"/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-VDXJGAFA.cjs","sourcesContent":[null,"import { Router } from \"express\";\nimport { container } from \"@/container\";\n\nexport const createModelApiRouter = (): Router => {\n\tconst router = Router();\n\tconst modelApiController = container.getModelApiController();\n\n\t// APIs (prefix: /api/model)\n\trouter.get(\"/\", modelApiController.handleModelList);\n\n\treturn router;\n};\n"]}
|