@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
|
@@ -1,3 +1,7 @@
|
|
|
1
|
+
import {
|
|
2
|
+
loggers
|
|
3
|
+
} from "./chunk-GHUEA7V5.js";
|
|
4
|
+
|
|
1
5
|
// src/controllers/query.controller.ts
|
|
2
6
|
import { randomUUID } from "crypto";
|
|
3
7
|
var QueryController = class {
|
|
@@ -52,6 +56,14 @@ var QueryController = class {
|
|
|
52
56
|
const keepaliveInterval = setInterval(() => {
|
|
53
57
|
res.write(":keepalive\n\n");
|
|
54
58
|
}, 1e4);
|
|
59
|
+
let aborted = false;
|
|
60
|
+
req.on("close", () => {
|
|
61
|
+
aborted = true;
|
|
62
|
+
loggers.intentStream.info("Client connection closed", {
|
|
63
|
+
threadId: currentThreadId,
|
|
64
|
+
userId
|
|
65
|
+
});
|
|
66
|
+
});
|
|
55
67
|
let currentThreadId = threadId;
|
|
56
68
|
const stream = this.queryService.handleQuery(
|
|
57
69
|
{ type, userId, threadId },
|
|
@@ -59,6 +71,9 @@ var QueryController = class {
|
|
|
59
71
|
);
|
|
60
72
|
try {
|
|
61
73
|
for await (const event of stream) {
|
|
74
|
+
if (aborted) {
|
|
75
|
+
break;
|
|
76
|
+
}
|
|
62
77
|
if (event.event === "thread_id") {
|
|
63
78
|
currentThreadId = event.data.threadId;
|
|
64
79
|
} else if (event.event === "thinking_process") {
|
|
@@ -98,4 +113,4 @@ data: ${errMsg}
|
|
|
98
113
|
export {
|
|
99
114
|
QueryController
|
|
100
115
|
};
|
|
101
|
-
//# sourceMappingURL=chunk-
|
|
116
|
+
//# sourceMappingURL=chunk-RE676AIN.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 type { QueryService } from \"@/services\";\nimport { MessageRole } from \"@/types/memory\";\nimport { loggers } from \"@/utils/logger\";\n\nexport class QueryController {\n\tprivate queryService: QueryService;\n\n\tconstructor(queryService: QueryService) {\n\t\tthis.queryService = queryService;\n\t}\n\n\tpublic handleQueryRequest = async (\n\t\treq: Request,\n\t\tres: Response,\n\t\tnext: NextFunction,\n\t) => {\n\t\tconst {\n\t\t\ttype,\n\t\t\tthreadId,\n\t\t\tmessage: query,\n\t\t\tdisplayMessage: displayQuery,\n\t\t} = req.body;\n\t\tconst userId = res.locals.userId;\n\n\t\ttry {\n\t\t\tconst stream = this.queryService.handleQuery(\n\t\t\t\t{ type, userId, threadId },\n\t\t\t\t{ query, displayQuery },\n\t\t\t);\n\n\t\t\tlet content = \"\";\n\t\t\tlet responseThreadId = threadId;\n\n\t\t\tfor await (const event of stream) {\n\t\t\t\tif (event.event === \"thread_id\") {\n\t\t\t\t\tresponseThreadId = event.data.threadId;\n\t\t\t\t} else if (event.event === \"text_chunk\" && event.data.delta) {\n\t\t\t\t\tcontent += event.data.delta;\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tres.status(200).json({ content, threadId: responseThreadId });\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\t_next: NextFunction,\n\t) => {\n\t\tconst {\n\t\t\ttype,\n\t\t\tthreadId,\n\t\t\tmessage: query,\n\t\t\tdisplayMessage: displayQuery,\n\t\t} = req.body;\n\t\tconst userId = res.locals.userId;\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\t// 클라이언트 연결 끊김 감지\n\t\tlet aborted = false;\n\t\treq.on(\"close\", () => {\n\t\t\taborted = true;\n\t\t\tloggers.intentStream.info(\"Client connection closed\", {\n\t\t\t\tthreadId: currentThreadId,\n\t\t\t\tuserId,\n\t\t\t});\n\t\t});\n\n\t\tlet currentThreadId = threadId;\n\t\tconst stream = this.queryService.handleQuery(\n\t\t\t{ type, userId, threadId },\n\t\t\t{ query, displayQuery },\n\t\t);\n\n\t\ttry {\n\t\t\tfor await (const event of stream) {\n\t\t\t\tif (aborted) {\n\t\t\t\t\tbreak;\n\t\t\t\t}\n\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.queryService.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;AAMpB,IAAM,kBAAN,MAAsB;AAAA,EACpB;AAAA,EAER,YAAY,cAA4B;AACvC,SAAK,eAAe;AAAA,EACrB;AAAA,EAEO,qBAAqB,OAC3B,KACA,KACA,SACI;AACJ,UAAM;AAAA,MACL;AAAA,MACA;AAAA,MACA,SAAS;AAAA,MACT,gBAAgB;AAAA,IACjB,IAAI,IAAI;AACR,UAAM,SAAS,IAAI,OAAO;AAE1B,QAAI;AACH,YAAM,SAAS,KAAK,aAAa;AAAA,QAChC,EAAE,MAAM,QAAQ,SAAS;AAAA,QACzB,EAAE,OAAO,aAAa;AAAA,MACvB;AAEA,UAAI,UAAU;AACd,UAAI,mBAAmB;AAEvB,uBAAiB,SAAS,QAAQ;AACjC,YAAI,MAAM,UAAU,aAAa;AAChC,6BAAmB,MAAM,KAAK;AAAA,QAC/B,WAAW,MAAM,UAAU,gBAAgB,MAAM,KAAK,OAAO;AAC5D,qBAAW,MAAM,KAAK;AAAA,QACvB;AAAA,MACD;AAEA,UAAI,OAAO,GAAG,EAAE,KAAK,EAAE,SAAS,UAAU,iBAAiB,CAAC;AAAA,IAC7D,SAAS,OAAO;AACf,WAAK,KAAK;AAAA,IACX;AAAA,EACD;AAAA,EAEO,2BAA2B,OACjC,KACA,KACA,UACI;AACJ,UAAM;AAAA,MACL;AAAA,MACA;AAAA,MACA,SAAS;AAAA,MACT,gBAAgB;AAAA,IACjB,IAAI,IAAI;AACR,UAAM,SAAS,IAAI,OAAO;AAE1B,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;AAGR,QAAI,UAAU;AACd,QAAI,GAAG,SAAS,MAAM;AACrB,gBAAU;AACV,cAAQ,aAAa,KAAK,4BAA4B;AAAA,QACrD,UAAU;AAAA,QACV;AAAA,MACD,CAAC;AAAA,IACF,CAAC;AAED,QAAI,kBAAkB;AACtB,UAAM,SAAS,KAAK,aAAa;AAAA,MAChC,EAAE,MAAM,QAAQ,SAAS;AAAA,MACzB,EAAE,OAAO,aAAa;AAAA,IACvB;AAEA,QAAI;AACH,uBAAiB,SAAS,QAAQ;AACjC,YAAI,SAAS;AACZ;AAAA,QACD;AAEA,YAAI,MAAM,UAAU,aAAa;AAChC,4BAAkB,MAAM,KAAK;AAAA,QAC9B,WAAW,MAAM,UAAU,oBAAoB;AAE9C,eAAK,aAAa,oBAAoB,QAAQ,iBAAiB;AAAA,YAC9D;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
|
container
|
|
3
|
-
} from "./chunk-
|
|
3
|
+
} from "./chunk-A3CKGK3U.js";
|
|
4
4
|
|
|
5
5
|
// src/routes/query.routes.ts
|
|
6
6
|
import { Router } from "express";
|
|
@@ -15,4 +15,4 @@ var createQueryRouter = () => {
|
|
|
15
15
|
export {
|
|
16
16
|
createQueryRouter
|
|
17
17
|
};
|
|
18
|
-
//# sourceMappingURL=chunk-
|
|
18
|
+
//# sourceMappingURL=chunk-SDABEZSA.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-GHUEA7V5.js";
|
|
7
7
|
|
|
8
8
|
// src/modules/mcp/mcp.module.ts
|
|
9
9
|
import { Client as MCPClient } from "@modelcontextprotocol/sdk/client/index.js";
|
|
@@ -157,4 +157,4 @@ ${typeof error === "string" ? error : JSON.stringify(error, null, 2)}`;
|
|
|
157
157
|
export {
|
|
158
158
|
MCPModule
|
|
159
159
|
};
|
|
160
|
-
//# sourceMappingURL=chunk-
|
|
160
|
+
//# sourceMappingURL=chunk-SV5CKUNN.js.map
|
|
@@ -7,7 +7,7 @@ var WorkflowApiController = class {
|
|
|
7
7
|
}
|
|
8
8
|
handleGetAllWorkflows = async (req, res, next) => {
|
|
9
9
|
try {
|
|
10
|
-
const
|
|
10
|
+
const userId = res.locals.userId || "";
|
|
11
11
|
const workflowMemory = this.memoryModule.getWorkflowMemory();
|
|
12
12
|
const workflows = await workflowMemory?.listWorkflows(userId);
|
|
13
13
|
res.json(workflows);
|
|
@@ -74,4 +74,4 @@ var WorkflowApiController = class {
|
|
|
74
74
|
export {
|
|
75
75
|
WorkflowApiController
|
|
76
76
|
};
|
|
77
|
-
//# sourceMappingURL=chunk-
|
|
77
|
+
//# sourceMappingURL=chunk-TR2QAQEW.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/controllers/api/workflow.api.controller.ts"],"sourcesContent":["import type { NextFunction, Request, Response } from \"express\";\nimport { StatusCodes } from \"http-status-codes\";\nimport type { MemoryModule } from \"@/modules/index.js\";\nimport type { Workflow } from \"@/types/memory\";\n\nexport class WorkflowApiController {\n\tprivate memoryModule: MemoryModule;\n\n\tconstructor(memoryModule: MemoryModule) {\n\t\tthis.memoryModule = memoryModule;\n\t}\n\n\tpublic handleGetAllWorkflows = async (\n\t\treq: Request,\n\t\tres: Response,\n\t\tnext: NextFunction,\n\t) => {\n\t\ttry {\n\t\t\tconst userId = res.locals.userId || \"\";\n\t\t\tconst workflowMemory = this.memoryModule.getWorkflowMemory();\n\t\t\tconst workflows = await workflowMemory?.listWorkflows(userId);\n\t\t\tres.json(workflows);\n\t\t} catch (error) {\n\t\t\tnext(error);\n\t\t}\n\t};\n\n\tpublic handleGetWorkflow = async (\n\t\treq: Request,\n\t\tres: Response,\n\t\tnext: NextFunction,\n\t) => {\n\t\ttry {\n\t\t\tconst { id } = req.params as { id: string };\n\t\t\tconst workflowMemory = this.memoryModule.getWorkflowMemory();\n\t\t\tconst workflow = await workflowMemory?.getWorkflow(id);\n\t\t\tif (!workflow) {\n\t\t\t\tres.status(StatusCodes.NOT_FOUND).send();\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tres.json(workflow);\n\t\t} catch (error) {\n\t\t\tnext(error);\n\t\t}\n\t};\n\n\tpublic handleCreateWorkflow = async (\n\t\treq: Request,\n\t\tres: Response,\n\t\tnext: NextFunction,\n\t) => {\n\t\ttry {\n\t\t\tconst userId = res.locals.userId || \"\";\n\t\t\tconst workflow = req.body as Workflow;\n\t\t\tconst workflowMemory = this.memoryModule.getWorkflowMemory();\n\t\t\tconst created = await workflowMemory?.createWorkflow({\n\t\t\t\t...workflow,\n\t\t\t\tuserId,\n\t\t\t});\n\t\t\tres.status(StatusCodes.CREATED).json(created);\n\t\t} catch (error) {\n\t\t\tnext(error);\n\t\t}\n\t};\n\n\tpublic handleUpdateWorkflow = async (\n\t\treq: Request,\n\t\tres: Response,\n\t\tnext: NextFunction,\n\t) => {\n\t\ttry {\n\t\t\tconst userId = res.locals.userId || \"\";\n\t\t\tconst { id } = req.params as { id: string };\n\t\t\tconst workflow = req.body as Partial<Workflow>;\n\t\t\tconst workflowMemory = this.memoryModule.getWorkflowMemory();\n\t\t\tawait workflowMemory?.updateWorkflow(id, {\n\t\t\t\t...workflow,\n\t\t\t\tuserId,\n\t\t\t});\n\t\t\tres.status(StatusCodes.OK).send();\n\t\t} catch (error) {\n\t\t\tnext(error);\n\t\t}\n\t};\n\n\tpublic handleDeleteWorkflow = async (\n\t\treq: Request,\n\t\tres: Response,\n\t\tnext: NextFunction,\n\t) => {\n\t\ttry {\n\t\t\tconst userId = res.locals.userId || \"\";\n\t\t\tconst { id } = req.params as { id: string };\n\t\t\tconst workflowMemory = this.memoryModule.getWorkflowMemory();\n\t\t\tawait workflowMemory?.deleteWorkflow(id, userId);\n\t\t\tres.status(StatusCodes.OK).send();\n\t\t} catch (error) {\n\t\t\tnext(error);\n\t\t}\n\t};\n}\n"],"mappings":";AACA,SAAS,mBAAmB;AAIrB,IAAM,wBAAN,MAA4B;AAAA,EAC1B;AAAA,EAER,YAAY,cAA4B;AACvC,SAAK,eAAe;AAAA,EACrB;AAAA,EAEO,wBAAwB,OAC9B,KACA,KACA,SACI;AACJ,QAAI;AACH,YAAM,SAAS,IAAI,OAAO,UAAU;AACpC,YAAM,iBAAiB,KAAK,aAAa,kBAAkB;AAC3D,YAAM,YAAY,MAAM,gBAAgB,cAAc,MAAM;AAC5D,UAAI,KAAK,SAAS;AAAA,IACnB,SAAS,OAAO;AACf,WAAK,KAAK;AAAA,IACX;AAAA,EACD;AAAA,EAEO,oBAAoB,OAC1B,KACA,KACA,SACI;AACJ,QAAI;AACH,YAAM,EAAE,GAAG,IAAI,IAAI;AACnB,YAAM,iBAAiB,KAAK,aAAa,kBAAkB;AAC3D,YAAM,WAAW,MAAM,gBAAgB,YAAY,EAAE;AACrD,UAAI,CAAC,UAAU;AACd,YAAI,OAAO,YAAY,SAAS,EAAE,KAAK;AACvC;AAAA,MACD;AACA,UAAI,KAAK,QAAQ;AAAA,IAClB,SAAS,OAAO;AACf,WAAK,KAAK;AAAA,IACX;AAAA,EACD;AAAA,EAEO,uBAAuB,OAC7B,KACA,KACA,SACI;AACJ,QAAI;AACH,YAAM,SAAS,IAAI,OAAO,UAAU;AACpC,YAAM,WAAW,IAAI;AACrB,YAAM,iBAAiB,KAAK,aAAa,kBAAkB;AAC3D,YAAM,UAAU,MAAM,gBAAgB,eAAe;AAAA,QACpD,GAAG;AAAA,QACH;AAAA,MACD,CAAC;AACD,UAAI,OAAO,YAAY,OAAO,EAAE,KAAK,OAAO;AAAA,IAC7C,SAAS,OAAO;AACf,WAAK,KAAK;AAAA,IACX;AAAA,EACD;AAAA,EAEO,uBAAuB,OAC7B,KACA,KACA,SACI;AACJ,QAAI;AACH,YAAM,SAAS,IAAI,OAAO,UAAU;AACpC,YAAM,EAAE,GAAG,IAAI,IAAI;AACnB,YAAM,WAAW,IAAI;AACrB,YAAM,iBAAiB,KAAK,aAAa,kBAAkB;AAC3D,YAAM,gBAAgB,eAAe,IAAI;AAAA,QACxC,GAAG;AAAA,QACH;AAAA,MACD,CAAC;AACD,UAAI,OAAO,YAAY,EAAE,EAAE,KAAK;AAAA,IACjC,SAAS,OAAO;AACf,WAAK,KAAK;AAAA,IACX;AAAA,EACD;AAAA,EAEO,uBAAuB,OAC7B,KACA,KACA,SACI;AACJ,QAAI;AACH,YAAM,SAAS,IAAI,OAAO,UAAU;AACpC,YAAM,EAAE,GAAG,IAAI,IAAI;AACnB,YAAM,iBAAiB,KAAK,aAAa,kBAAkB;AAC3D,YAAM,gBAAgB,eAAe,IAAI,MAAM;AAC/C,UAAI,OAAO,YAAY,EAAE,EAAE,KAAK;AAAA,IACjC,SAAS,OAAO;AACf,WAAK,KAAK;AAAA,IACX;AAAA,EACD;AACD;","names":[]}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import {
|
|
2
2
|
loggers
|
|
3
|
-
} from "./chunk-
|
|
3
|
+
} from "./chunk-GHUEA7V5.js";
|
|
4
4
|
|
|
5
5
|
// src/services/intents/single-trigger.service.ts
|
|
6
6
|
var SingleIntentTriggerService = class {
|
|
@@ -16,19 +16,19 @@ var SingleIntentTriggerService = class {
|
|
|
16
16
|
*
|
|
17
17
|
* @param query - The user's input query
|
|
18
18
|
* @param thread - The thread history
|
|
19
|
-
* @returns
|
|
19
|
+
* @returns IntentTriggerResult with single intent and needsAggregation=false
|
|
20
20
|
*/
|
|
21
21
|
async intentTriggering(query, thread) {
|
|
22
22
|
const modelInstance = this.modelModule.getModel();
|
|
23
23
|
const modelOptions = this.modelModule.getModelOptions();
|
|
24
24
|
const intentMemory = this.memoryModule.getIntentMemory();
|
|
25
25
|
if (!intentMemory) {
|
|
26
|
-
return [{ subquery: query }];
|
|
26
|
+
return { intents: [{ subquery: query }], needsAggregation: false };
|
|
27
27
|
}
|
|
28
28
|
const intents = await intentMemory.listIntents();
|
|
29
29
|
if (intents.length === 0) {
|
|
30
30
|
loggers.intentStream.warn("No intent found");
|
|
31
|
-
return [{ subquery: query }];
|
|
31
|
+
return { intents: [{ subquery: query }], needsAggregation: false };
|
|
32
32
|
}
|
|
33
33
|
const intentList = intents.map((intent) => `- ${intent.name}: ${intent.description}`).join("\n");
|
|
34
34
|
const threadMessages = !thread ? "" : thread.messages.sort((a, b) => a.timestamp - b.timestamp).map((message) => {
|
|
@@ -70,13 +70,13 @@ You MUST return the output in the following JSON format. Do not include any othe
|
|
|
70
70
|
const response = await modelInstance.fetch(messages, modelOptions);
|
|
71
71
|
if (!response.content) {
|
|
72
72
|
loggers.intent.warn("Cannot extract intent from query");
|
|
73
|
-
return [{ subquery: query }];
|
|
73
|
+
return { intents: [{ subquery: query }], needsAggregation: false };
|
|
74
74
|
}
|
|
75
75
|
let parsed;
|
|
76
76
|
try {
|
|
77
77
|
parsed = JSON.parse(response.content);
|
|
78
78
|
} catch (error) {
|
|
79
|
-
return [{ subquery: query }];
|
|
79
|
+
return { intents: [{ subquery: query }], needsAggregation: false };
|
|
80
80
|
}
|
|
81
81
|
const result = {
|
|
82
82
|
subquery: query,
|
|
@@ -85,11 +85,11 @@ You MUST return the output in the following JSON format. Do not include any othe
|
|
|
85
85
|
if (parsed.intentName) {
|
|
86
86
|
result.intent = await intentMemory.getIntentByName(parsed.intentName);
|
|
87
87
|
}
|
|
88
|
-
return [result];
|
|
88
|
+
return { intents: [result], needsAggregation: false };
|
|
89
89
|
}
|
|
90
90
|
};
|
|
91
91
|
|
|
92
92
|
export {
|
|
93
93
|
SingleIntentTriggerService
|
|
94
94
|
};
|
|
95
|
-
//# sourceMappingURL=chunk-
|
|
95
|
+
//# sourceMappingURL=chunk-VGL4ZVNA.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/services/intents/single-trigger.service.ts"],"sourcesContent":["import type { MemoryModule, ModelModule } from \"@/modules\";\nimport type {\n\tIntentTriggerResult,\n\tMessageObject,\n\tThreadObject,\n\tTriggeredIntent,\n} from \"@/types/memory\";\nimport { loggers } from \"@/utils/logger\";\n\n/**\n * Service for single-intent triggering.\n * Identifies a single intent without decomposing queries into subqueries.\n */\nexport class SingleIntentTriggerService {\n\tprivate modelModule: ModelModule;\n\tprivate memoryModule: MemoryModule;\n\n\tconstructor(modelModule: ModelModule, memoryModule: MemoryModule) {\n\t\tthis.modelModule = modelModule;\n\t\tthis.memoryModule = memoryModule;\n\t}\n\n\t/**\n\t * Detects a single intent from context.\n\t * Simpler prompt that doesn't decompose queries into subqueries.\n\t *\n\t * @param query - The user's input query\n\t * @param thread - The thread history\n\t * @returns IntentTriggerResult with single intent and needsAggregation=false\n\t */\n\tpublic async intentTriggering(\n\t\tquery: string,\n\t\tthread: ThreadObject | undefined,\n\t): Promise<IntentTriggerResult> {\n\t\tconst modelInstance = this.modelModule.getModel();\n\t\tconst modelOptions = this.modelModule.getModelOptions();\n\t\tconst intentMemory = this.memoryModule.getIntentMemory();\n\t\tif (!intentMemory) {\n\t\t\treturn { intents: [{ subquery: query }], needsAggregation: false };\n\t\t}\n\n\t\tconst intents = await intentMemory.listIntents();\n\t\tif (intents.length === 0) {\n\t\t\tloggers.intentStream.warn(\"No intent found\");\n\t\t\treturn { intents: [{ subquery: query }], needsAggregation: false };\n\t\t}\n\n\t\tconst intentList = intents\n\t\t\t.map((intent) => `- ${intent.name}: ${intent.description}`)\n\t\t\t.join(\"\\n\");\n\n\t\t// Convert thread messages to a string\n\t\tconst threadMessages = !thread\n\t\t\t? \"\"\n\t\t\t: thread.messages\n\t\t\t\t\t.sort((a, b) => a.timestamp - b.timestamp)\n\t\t\t\t\t.map((message: MessageObject) => {\n\t\t\t\t\t\tconst role =\n\t\t\t\t\t\t\tmessage.role === \"USER\"\n\t\t\t\t\t\t\t\t? \"User\"\n\t\t\t\t\t\t\t\t: message.role === \"MODEL\"\n\t\t\t\t\t\t\t\t\t? \"Assistant\"\n\t\t\t\t\t\t\t\t\t: \"System\";\n\t\t\t\t\t\tconst content = Array.isArray(message.content.parts)\n\t\t\t\t\t\t\t? message.content.parts.join(\" \")\n\t\t\t\t\t\t\t: String(message.content.parts);\n\t\t\t\t\t\treturn `${role}: \"\"\"${content}\"\"\"`;\n\t\t\t\t\t})\n\t\t\t\t\t.join(\"\\n\");\n\n\t\tconst systemPrompt = `\nToday is ${new Date().toLocaleDateString()}.\nYou are an expert in accurately identifying user intentions.\n\nAvailable intent list:\n${intentList}\n\nPlease select and answer only from the above intent list.`;\n\n\t\tconst userMessage = `\n${\n\tthreadMessages !== \"\"\n\t\t? `The following is the conversation history with the user: ${threadMessages}\n\n\t`\n\t\t: \"\"\n}\nUser question: \"${query}\"\n\nBased on the above conversation history, analyze the user question and identify the most relevant intent.\n\nInstructions:\n1. Select the single most appropriate intent from the available intent list\n2. If no intent matches well, do not set intentName\n3. Provide a 2-3 sentence action plan describing what will be done\n\nOutput Format:\nYou MUST return the output in the following JSON format. Do not include any other text before or after the JSON:\n{\n \"intentName\": \"<intent_name or null>\",\n \"actionPlan\": \"<2-3 sentence description of what will be done>\"\n}`;\n\n\t\tconst messages = modelInstance.generateMessages({\n\t\t\tquery: userMessage,\n\t\t\tsystemPrompt,\n\t\t});\n\n\t\tconst response = await modelInstance.fetch(messages, modelOptions);\n\t\tif (!response.content) {\n\t\t\tloggers.intent.warn(\"Cannot extract intent from query\");\n\t\t\treturn { intents: [{ subquery: query }], needsAggregation: false };\n\t\t}\n\n\t\tlet parsed: { intentName?: string; actionPlan?: string };\n\t\ttry {\n\t\t\tparsed = JSON.parse(response.content);\n\t\t} catch (error: unknown) {\n\t\t\treturn { intents: [{ subquery: query }], needsAggregation: false };\n\t\t}\n\n\t\tconst result: TriggeredIntent = {\n\t\t\tsubquery: query,\n\t\t\tactionPlan: parsed.actionPlan,\n\t\t};\n\n\t\tif (parsed.intentName) {\n\t\t\tresult.intent = await intentMemory.getIntentByName(parsed.intentName);\n\t\t}\n\n\t\treturn { intents: [result], needsAggregation: false };\n\t}\n}\n"],"mappings":";;;;;AAaO,IAAM,6BAAN,MAAiC;AAAA,EAC/B;AAAA,EACA;AAAA,EAER,YAAY,aAA0B,cAA4B;AACjE,SAAK,cAAc;AACnB,SAAK,eAAe;AAAA,EACrB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAUA,MAAa,iBACZ,OACA,QAC+B;AAC/B,UAAM,gBAAgB,KAAK,YAAY,SAAS;AAChD,UAAM,eAAe,KAAK,YAAY,gBAAgB;AACtD,UAAM,eAAe,KAAK,aAAa,gBAAgB;AACvD,QAAI,CAAC,cAAc;AAClB,aAAO,EAAE,SAAS,CAAC,EAAE,UAAU,MAAM,CAAC,GAAG,kBAAkB,MAAM;AAAA,IAClE;AAEA,UAAM,UAAU,MAAM,aAAa,YAAY;AAC/C,QAAI,QAAQ,WAAW,GAAG;AACzB,cAAQ,aAAa,KAAK,iBAAiB;AAC3C,aAAO,EAAE,SAAS,CAAC,EAAE,UAAU,MAAM,CAAC,GAAG,kBAAkB,MAAM;AAAA,IAClE;AAEA,UAAM,aAAa,QACjB,IAAI,CAAC,WAAW,KAAK,OAAO,IAAI,KAAK,OAAO,WAAW,EAAE,EACzD,KAAK,IAAI;AAGX,UAAM,iBAAiB,CAAC,SACrB,KACA,OAAO,SACN,KAAK,CAAC,GAAG,MAAM,EAAE,YAAY,EAAE,SAAS,EACxC,IAAI,CAAC,YAA2B;AAChC,YAAM,OACL,QAAQ,SAAS,SACd,SACA,QAAQ,SAAS,UAChB,cACA;AACL,YAAM,UAAU,MAAM,QAAQ,QAAQ,QAAQ,KAAK,IAChD,QAAQ,QAAQ,MAAM,KAAK,GAAG,IAC9B,OAAO,QAAQ,QAAQ,KAAK;AAC/B,aAAO,GAAG,IAAI,QAAQ,OAAO;AAAA,IAC9B,CAAC,EACA,KAAK,IAAI;AAEb,UAAM,eAAe;AAAA,YACZ,oBAAI,KAAK,GAAE,mBAAmB,CAAC;AAAA;AAAA;AAAA;AAAA,EAIxC,UAAU;AAAA;AAAA;AAIV,UAAM,cAAc;AAAA,EAErB,mBAAmB,KAChB,4DAA4D,cAAc;AAAA;AAAA,KAG1E,EACJ;AAAA,kBACkB,KAAK;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAgBrB,UAAM,WAAW,cAAc,iBAAiB;AAAA,MAC/C,OAAO;AAAA,MACP;AAAA,IACD,CAAC;AAED,UAAM,WAAW,MAAM,cAAc,MAAM,UAAU,YAAY;AACjE,QAAI,CAAC,SAAS,SAAS;AACtB,cAAQ,OAAO,KAAK,kCAAkC;AACtD,aAAO,EAAE,SAAS,CAAC,EAAE,UAAU,MAAM,CAAC,GAAG,kBAAkB,MAAM;AAAA,IAClE;AAEA,QAAI;AACJ,QAAI;AACH,eAAS,KAAK,MAAM,SAAS,OAAO;AAAA,IACrC,SAAS,OAAgB;AACxB,aAAO,EAAE,SAAS,CAAC,EAAE,UAAU,MAAM,CAAC,GAAG,kBAAkB,MAAM;AAAA,IAClE;AAEA,UAAM,SAA0B;AAAA,MAC/B,UAAU;AAAA,MACV,YAAY,OAAO;AAAA,IACpB;AAEA,QAAI,OAAO,YAAY;AACtB,aAAO,SAAS,MAAM,aAAa,gBAAgB,OAAO,UAAU;AAAA,IACrE;AAEA,WAAO,EAAE,SAAS,CAAC,MAAM,GAAG,kBAAkB,MAAM;AAAA,EACrD;AACD;","names":[]}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import {
|
|
2
2
|
container
|
|
3
|
-
} from "./chunk-
|
|
3
|
+
} from "./chunk-A3CKGK3U.js";
|
|
4
4
|
import {
|
|
5
5
|
AinHttpError
|
|
6
6
|
} from "./chunk-C5JXXLCW.js";
|
|
@@ -41,4 +41,4 @@ var createThreadApiRouter = () => {
|
|
|
41
41
|
export {
|
|
42
42
|
createThreadApiRouter
|
|
43
43
|
};
|
|
44
|
-
//# sourceMappingURL=chunk-
|
|
44
|
+
//# sourceMappingURL=chunk-VOMI5BAO.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/types/memory.ts"],"sourcesContent":["/**\n * Roles for participants in a message.\n */\nexport enum MessageRole {\n\t/** User/human participant */\n\tUSER = \"USER\",\n\t/** System-generated messages or instructions */\n\tSYSTEM = \"SYSTEM\",\n\t/** AI model responses */\n\tMODEL = \"MODEL\",\n}\n\n/**\n * Content structure for message content.\n *\n * Supports multi-part content with different types (text, images, etc.).\n */\nexport type MessageContentObject = {\n\t/** Content type (e.g., \"text\", \"image\", \"tool_use\") */\n\ttype: string;\n\t/** Array of content parts, structure depends on content type */\n\tparts: any[];\n};\n\n/**\n * Represents a single message in a thread.\n *\n * @example\n * ```typescript\n * const message: MessageObject = {\n * role: MessageRole.USER,\n * content: {\n * type: \"text\",\n * parts: [\"Hello, how can you help me?\"]\n * },\n * timestamp: Date.now(),\n * metadata: { source: \"web-ui\" }\n * };\n * ```\n */\nexport type MessageObject = {\n\tmessageId: string;\n\t/** Role of the message sender */\n\trole: MessageRole;\n\t/** Message content with type and parts */\n\tcontent: MessageContentObject;\n\t/** Unix timestamp when the message was created */\n\ttimestamp: number;\n\t/** Optional metadata for additional context */\n\tmetadata?: { [key: string]: unknown };\n};\n\nexport enum ThreadType {\n\tWORKFLOW = \"WORKFLOW\",\n\tCHAT = \"CHAT\",\n}\n\nexport type ThreadMetadata = {\n\ttype: ThreadType;\n\ttitle: string;\n\tuserId: string;\n\tthreadId: string;\n};\n\n/**\n * Represents a conversation thread containing multiple messages.\n *\n * Messages are stored in a key-value structure where keys are unique message IDs\n * and values are the corresponding message objects.\n *\n * @example\n * ```typescript\n * const thread: ThreadObject = {\n * \t title: \"New conversation\",\n * messages: [\n * { messageId: <UUID_1>, role: MessageRole.USER, content: {...}, timestamp: 1234567890 },\n * { messageId: <UUID_2> ,role: MessageRole.MODEL, content: {...}, timestamp: 1234567891 }\n * ]\n * };\n * ```\n */\nexport type ThreadObject = {\n\tuserId: string;\n\tthreadId: string;\n\ttype: ThreadType;\n\ttitle: string;\n\tmessages: Array<MessageObject>;\n};\n\nexport interface Intent {\n\tid: string;\n\tname: string;\n\tdescription: string;\n\tstatus: string;\n\tprompt?: string;\n\ttriggeringSentences?: Array<string>;\n\ttags?: Array<string>;\n}\n\nexport type TriggeredIntent = {\n\tsubquery: string;\n\tintent?: Intent;\n\tactionPlan?: string;\n};\n\n/**\n * Result of fulfilling a single intent.\n * Used to collect all results before the rewrite step.\n */\nexport type FulfillmentResult = {\n\t/** Original subquery that was processed */\n\tsubquery: string;\n\t/** Matched intent (may be undefined if no match) */\n\tintent?: Intent;\n\t/** Action plan description */\n\tactionPlan?: string;\n\t/** Response text generated for this intent */\n\tresponse: string;\n};\n\nexport interface Workflow {\n\tworkflowId: string;\n\tuserId?: string;\n\ttitle: string;\n\tdescription: string;\n\tactive: boolean;\n\tcontent: string;\n}\n"],"mappings":";AAGO,IAAK,cAAL,kBAAKA,iBAAL;AAEN,EAAAA,aAAA,UAAO;AAEP,EAAAA,aAAA,YAAS;AAET,EAAAA,aAAA,WAAQ;AANG,SAAAA;AAAA,GAAA;AAiDL,IAAK,aAAL,kBAAKC,gBAAL;AACN,EAAAA,YAAA,cAAW;AACX,EAAAA,YAAA,UAAO;AAFI,SAAAA;AAAA,GAAA;","names":["MessageRole","ThreadType"]}
|
|
1
|
+
{"version":3,"sources":["../../src/types/memory.ts"],"sourcesContent":["/**\n * Roles for participants in a message.\n */\nexport enum MessageRole {\n\t/** User/human participant */\n\tUSER = \"USER\",\n\t/** System-generated messages or instructions */\n\tSYSTEM = \"SYSTEM\",\n\t/** AI model responses */\n\tMODEL = \"MODEL\",\n}\n\n/**\n * Content structure for message content.\n *\n * Supports multi-part content with different types (text, images, etc.).\n */\nexport type MessageContentObject = {\n\t/** Content type (e.g., \"text\", \"image\", \"tool_use\") */\n\ttype: string;\n\t/** Array of content parts, structure depends on content type */\n\tparts: any[];\n};\n\n/**\n * Represents a single message in a thread.\n *\n * @example\n * ```typescript\n * const message: MessageObject = {\n * role: MessageRole.USER,\n * content: {\n * type: \"text\",\n * parts: [\"Hello, how can you help me?\"]\n * },\n * timestamp: Date.now(),\n * metadata: { source: \"web-ui\" }\n * };\n * ```\n */\nexport type MessageObject = {\n\tmessageId: string;\n\t/** Role of the message sender */\n\trole: MessageRole;\n\t/** Message content with type and parts */\n\tcontent: MessageContentObject;\n\t/** Unix timestamp when the message was created */\n\ttimestamp: number;\n\t/** Optional metadata for additional context */\n\tmetadata?: { [key: string]: unknown };\n};\n\nexport enum ThreadType {\n\tWORKFLOW = \"WORKFLOW\",\n\tCHAT = \"CHAT\",\n}\n\nexport type ThreadMetadata = {\n\ttype: ThreadType;\n\ttitle: string;\n\tuserId: string;\n\tthreadId: string;\n};\n\n/**\n * Represents a conversation thread containing multiple messages.\n *\n * Messages are stored in a key-value structure where keys are unique message IDs\n * and values are the corresponding message objects.\n *\n * @example\n * ```typescript\n * const thread: ThreadObject = {\n * \t title: \"New conversation\",\n * messages: [\n * { messageId: <UUID_1>, role: MessageRole.USER, content: {...}, timestamp: 1234567890 },\n * { messageId: <UUID_2> ,role: MessageRole.MODEL, content: {...}, timestamp: 1234567891 }\n * ]\n * };\n * ```\n */\nexport type ThreadObject = {\n\tuserId: string;\n\tthreadId: string;\n\ttype: ThreadType;\n\ttitle: string;\n\tmessages: Array<MessageObject>;\n};\n\nexport interface Intent {\n\tid: string;\n\tname: string;\n\tdescription: string;\n\tstatus: string;\n\tprompt?: string;\n\ttriggeringSentences?: Array<string>;\n\ttags?: Array<string>;\n}\n\nexport type TriggeredIntent = {\n\tsubquery: string;\n\tintent?: Intent;\n\tactionPlan?: string;\n};\n\n/**\n * Result of multi-intent triggering.\n * Contains the list of triggered intents and metadata about aggregation.\n */\nexport type IntentTriggerResult = {\n\t/** List of triggered intents */\n\tintents: Array<TriggeredIntent>;\n\t/** Whether the results need to be aggregated into a unified response */\n\tneedsAggregation: boolean;\n};\n\n/**\n * Result of fulfilling a single intent.\n * Used to collect all results before the rewrite step.\n */\nexport type FulfillmentResult = {\n\t/** Original subquery that was processed */\n\tsubquery: string;\n\t/** Matched intent (may be undefined if no match) */\n\tintent?: Intent;\n\t/** Action plan description */\n\tactionPlan?: string;\n\t/** Response text generated for this intent */\n\tresponse: string;\n};\n\nexport interface Workflow {\n\tworkflowId: string;\n\tuserId?: string;\n\ttitle: string;\n\tdescription: string;\n\tactive: boolean;\n\tcontent: string;\n}\n"],"mappings":";AAGO,IAAK,cAAL,kBAAKA,iBAAL;AAEN,EAAAA,aAAA,UAAO;AAEP,EAAAA,aAAA,YAAS;AAET,EAAAA,aAAA,WAAQ;AANG,SAAAA;AAAA,GAAA;AAiDL,IAAK,aAAL,kBAAKC,gBAAL;AACN,EAAAA,YAAA,cAAW;AACX,EAAAA,YAAA,UAAO;AAFI,SAAAA;AAAA,GAAA;","names":["MessageRole","ThreadType"]}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import {
|
|
2
2
|
loggers
|
|
3
|
-
} from "./chunk-
|
|
3
|
+
} from "./chunk-GHUEA7V5.js";
|
|
4
4
|
|
|
5
5
|
// src/services/a2a.service.ts
|
|
6
6
|
import { randomUUID } from "crypto";
|
|
@@ -120,4 +120,4 @@ var A2AService = class {
|
|
|
120
120
|
export {
|
|
121
121
|
A2AService
|
|
122
122
|
};
|
|
123
|
-
//# sourceMappingURL=chunk-
|
|
123
|
+
//# sourceMappingURL=chunk-WMHUZEL2.js.map
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import {
|
|
2
2
|
container
|
|
3
|
-
} from "./chunk-
|
|
3
|
+
} from "./chunk-A3CKGK3U.js";
|
|
4
4
|
|
|
5
5
|
// src/routes/api/model.routes.ts
|
|
6
6
|
import { Router } from "express";
|
|
@@ -14,4 +14,4 @@ var createModelApiRouter = () => {
|
|
|
14
14
|
export {
|
|
15
15
|
createModelApiRouter
|
|
16
16
|
};
|
|
17
|
-
//# sourceMappingURL=chunk-
|
|
17
|
+
//# sourceMappingURL=chunk-XXDILT4B.js.map
|
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
import {
|
|
2
2
|
generateTitle
|
|
3
|
-
} from "./chunk-
|
|
3
|
+
} from "./chunk-HEYSMA5B.js";
|
|
4
4
|
import {
|
|
5
5
|
AinHttpError
|
|
6
6
|
} from "./chunk-C5JXXLCW.js";
|
|
7
7
|
import {
|
|
8
8
|
loggers
|
|
9
|
-
} from "./chunk-
|
|
9
|
+
} from "./chunk-GHUEA7V5.js";
|
|
10
10
|
|
|
11
11
|
// src/services/query.service.ts
|
|
12
12
|
import { randomUUID } from "crypto";
|
|
@@ -67,8 +67,15 @@ var QueryService = class {
|
|
|
67
67
|
loggers.intent.info(`Create new thread: ${threadId}`);
|
|
68
68
|
yield { event: "thread_id", data: { type, userId, threadId, title } };
|
|
69
69
|
}
|
|
70
|
-
const
|
|
71
|
-
|
|
70
|
+
const triggerResult = await this.intentTriggerService.intentTriggering(
|
|
71
|
+
query,
|
|
72
|
+
thread
|
|
73
|
+
);
|
|
74
|
+
const { intents: triggeredIntents, needsAggregation } = triggerResult;
|
|
75
|
+
loggers.intent.debug("Triggered intents", {
|
|
76
|
+
triggeredIntents,
|
|
77
|
+
needsAggregation
|
|
78
|
+
});
|
|
72
79
|
await this.addToThreadMessages(userId, threadId, [
|
|
73
80
|
{
|
|
74
81
|
messageId: randomUUID(),
|
|
@@ -77,7 +84,7 @@ var QueryService = class {
|
|
|
77
84
|
// use displayQuery for better UX in enterprise application
|
|
78
85
|
content: { type: "text", parts: [displayQuery || query] },
|
|
79
86
|
metadata: {
|
|
80
|
-
intents:
|
|
87
|
+
intents: triggeredIntents.filter((intent) => !!intent.intent).map((intent) => ({
|
|
81
88
|
id: intent.intent?.id,
|
|
82
89
|
subquery: intent.subquery
|
|
83
90
|
})),
|
|
@@ -86,9 +93,10 @@ var QueryService = class {
|
|
|
86
93
|
}
|
|
87
94
|
]);
|
|
88
95
|
const stream = this.intentFulfillService.intentFulfill(
|
|
89
|
-
|
|
96
|
+
triggeredIntents,
|
|
90
97
|
thread,
|
|
91
|
-
query
|
|
98
|
+
query,
|
|
99
|
+
needsAggregation
|
|
92
100
|
);
|
|
93
101
|
for await (const event of stream) {
|
|
94
102
|
yield event;
|
|
@@ -99,4 +107,4 @@ var QueryService = class {
|
|
|
99
107
|
export {
|
|
100
108
|
QueryService
|
|
101
109
|
};
|
|
102
|
-
//# sourceMappingURL=chunk-
|
|
110
|
+
//# sourceMappingURL=chunk-ZSWCICNO.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/services/query.service.ts"],"sourcesContent":["import { randomUUID } from \"node:crypto\";\nimport { StatusCodes } from \"http-status-codes\";\nimport type {\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} from \"@/types/memory.js\";\nimport type { StreamEvent } from \"@/types/stream\";\nimport { loggers } from \"@/utils/logger.js\";\nimport type { IntentFulfillService } from \"./intents/fulfill.service\";\nimport type { IntentTriggerService } from \"./intents/trigger.service\";\nimport { generateTitle } from \"./utils/query.common\";\n\n/**\n * Service for processing user queries through the agent's AI pipeline.\n *\n * Orchestrates the query processing workflow including intent detection,\n * model inference, tool execution, and response generation. Manages\n * conversation context and coordinates between different modules.\n */\nexport class QueryService {\n\tprivate modelModule: ModelModule;\n\tprivate memoryModule: MemoryModule;\n\tprivate intentTriggerService: IntentTriggerService;\n\tprivate intentFulfillService: IntentFulfillService;\n\n\tconstructor(\n\t\tmodelModule: ModelModule,\n\t\tmemoryModule: MemoryModule,\n\t\tintentTriggerService: IntentTriggerService,\n\t\tintentFulfillService: IntentFulfillService,\n\t) {\n\t\tthis.modelModule = modelModule;\n\t\tthis.memoryModule = memoryModule;\n\t\tthis.intentTriggerService = intentTriggerService;\n\t\tthis.intentFulfillService = intentFulfillService;\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 *handleQuery(\n\t\tthreadMetadata: {\n\t\t\ttype: ThreadType;\n\t\t\tuserId: string;\n\t\t\tthreadId?: string;\n\t\t\toptions?: ModelFetchOptions;\n\t\t},\n\t\tqueryData: {\n\t\t\tquery: string;\n\t\t\tdisplayQuery?: string;\n\t\t},\n\t\tisA2A?: boolean,\n\t): AsyncGenerator<StreamEvent> {\n\t\tconst { type, userId, options } = threadMetadata;\n\t\tconst { query, displayQuery } = queryData;\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 triggerResult = await this.intentTriggerService.intentTriggering(\n\t\t\tquery,\n\t\t\tthread,\n\t\t);\n\t\tconst { intents: triggeredIntents, needsAggregation } = triggerResult;\n\t\tloggers.intent.debug(\"Triggered intents\", {\n\t\t\ttriggeredIntents,\n\t\t\tneedsAggregation,\n\t\t});\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\t// use displayQuery for better UX in enterprise application\n\t\t\t\tcontent: { type: \"text\", parts: [displayQuery || query] },\n\t\t\t\tmetadata: {\n\t\t\t\t\tintents: triggeredIntents\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\tquery: !displayQuery ? undefined : query,\n\t\t\t\t},\n\t\t\t},\n\t\t]);\n\n\t\t// 3. intent fulfillment (with rewrite step)\n\t\tconst stream = this.intentFulfillService.intentFulfill(\n\t\t\ttriggeredIntents,\n\t\t\tthread,\n\t\t\tquery,\n\t\t\tneedsAggregation,\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;AA2BrB,IAAM,eAAN,MAAmB;AAAA,EACjB;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EAER,YACC,aACA,cACA,sBACA,sBACC;AACD,SAAK,cAAc;AACnB,SAAK,eAAe;AACpB,SAAK,uBAAuB;AAC5B,SAAK,uBAAuB;AAAA,EAC7B;AAAA,EAEA,MAAa,oBACZ,QACA,UACA,UACC;AACD,UAAM,eAAe,KAAK,aAAa,gBAAgB;AACvD,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,YACb,gBAMA,WAIA,OAC8B;AAC9B,UAAM,EAAE,MAAM,QAAQ,QAAQ,IAAI;AAClC,UAAM,EAAE,OAAO,aAAa,IAAI;AAChC,UAAM,eAAe,KAAK,aAAa,gBAAgB;AAGvD,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,gBAAgB,MAAM,KAAK,qBAAqB;AAAA,MACrD;AAAA,MACA;AAAA,IACD;AACA,UAAM,EAAE,SAAS,kBAAkB,iBAAiB,IAAI;AACxD,YAAQ,OAAO,MAAM,qBAAqB;AAAA,MACzC;AAAA,MACA;AAAA,IACD,CAAC;AAGD,UAAM,KAAK,oBAAoB,QAAQ,UAAU;AAAA,MAChD;AAAA,QACC,WAAW,WAAW;AAAA,QACtB;AAAA,QACA,WAAW,KAAK,IAAI;AAAA;AAAA,QAEpB,SAAS,EAAE,MAAM,QAAQ,OAAO,CAAC,gBAAgB,KAAK,EAAE;AAAA,QACxD,UAAU;AAAA,UACT,SAAS,iBACP,OAAO,CAAC,WAAW,CAAC,CAAC,OAAO,MAAM,EAClC,IAAI,CAAC,YAAY;AAAA,YACjB,IAAI,OAAO,QAAQ;AAAA,YACnB,UAAU,OAAO;AAAA,UAClB,EAAE;AAAA,UACH,OAAO,CAAC,eAAe,SAAY;AAAA,QACpC;AAAA,MACD;AAAA,IACD,CAAC;AAGD,UAAM,SAAS,KAAK,qBAAqB;AAAA,MACxC;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,IACD;AAEA,qBAAiB,SAAS,QAAQ;AACjC,YAAM;AAAA,IACP;AAAA,EACD;AACD;","names":[]}
|
|
@@ -3,7 +3,7 @@ import {
|
|
|
3
3
|
} from "./chunk-BZZDVW26.js";
|
|
4
4
|
import {
|
|
5
5
|
loggers
|
|
6
|
-
} from "./chunk-
|
|
6
|
+
} from "./chunk-GHUEA7V5.js";
|
|
7
7
|
|
|
8
8
|
// src/modules/a2a/a2a.module.ts
|
|
9
9
|
import { randomUUID } from "crypto";
|
|
@@ -196,4 +196,4 @@ ${finalText.join("\n")}`;
|
|
|
196
196
|
export {
|
|
197
197
|
A2AModule
|
|
198
198
|
};
|
|
199
|
-
//# sourceMappingURL=chunk-
|
|
199
|
+
//# sourceMappingURL=chunk-ZUVYTTPD.js.map
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import {
|
|
2
2
|
loggers
|
|
3
|
-
} from "./chunk-
|
|
3
|
+
} from "./chunk-GHUEA7V5.js";
|
|
4
4
|
|
|
5
5
|
// src/services/intents/multi-trigger.service.ts
|
|
6
6
|
var MultiIntentTriggerService = class {
|
|
@@ -15,19 +15,19 @@ var MultiIntentTriggerService = class {
|
|
|
15
15
|
*
|
|
16
16
|
* @param query - The user's input query
|
|
17
17
|
* @param thread - The thread history
|
|
18
|
-
* @returns
|
|
18
|
+
* @returns IntentTriggerResult containing intents and aggregation flag
|
|
19
19
|
*/
|
|
20
20
|
async intentTriggering(query, thread) {
|
|
21
21
|
const modelInstance = this.modelModule.getModel();
|
|
22
22
|
const modelOptions = this.modelModule.getModelOptions();
|
|
23
23
|
const intentMemory = this.memoryModule.getIntentMemory();
|
|
24
24
|
if (!intentMemory) {
|
|
25
|
-
return [{ subquery: query }];
|
|
25
|
+
return { intents: [{ subquery: query }], needsAggregation: false };
|
|
26
26
|
}
|
|
27
27
|
const intents = await intentMemory.listIntents();
|
|
28
28
|
if (intents.length === 0) {
|
|
29
29
|
loggers.intentStream.warn("No intent found");
|
|
30
|
-
return [{ subquery: query }];
|
|
30
|
+
return { intents: [{ subquery: query }], needsAggregation: false };
|
|
31
31
|
}
|
|
32
32
|
const intentList = intents.map((intent) => `- ${intent.name}: ${intent.description}`).join("\n");
|
|
33
33
|
const threadMessages = !thread ? "" : thread.messages.sort((a, b) => a.timestamp - b.timestamp).map((message) => {
|
|
@@ -58,29 +58,35 @@ Instructions:
|
|
|
58
58
|
4. Multiple intents can be identified if the question covers various topics or actions
|
|
59
59
|
5. Maintain the logical sequence of the original question when splitting into subqueries
|
|
60
60
|
6. **Important**: If the query cannot be split into multiple subqueries (i.e., it represents a single action or request), treat the entire query as one subquery and still follow the output format
|
|
61
|
+
7. Determine if the final response needs aggregation:
|
|
62
|
+
- Set needsAggregation to TRUE if: multiple subqueries exist AND their results should be combined into a unified response
|
|
63
|
+
- Set needsAggregation to FALSE if: only one subquery exists, OR multiple subqueries are independent and can be answered separately without combining
|
|
61
64
|
|
|
62
65
|
Output Format:
|
|
63
66
|
You MUST return the output in the following JSON format. Do not include any other text before or after the JSON:
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
67
|
+
{
|
|
68
|
+
"needsAggregation": <true or false>,
|
|
69
|
+
"subqueries": [
|
|
70
|
+
{
|
|
71
|
+
"subquery": "<subquery_1>",
|
|
72
|
+
"intentName": "<intent_name_1>",
|
|
73
|
+
"actionPlan": "<2-3 sentence description of what will be done for this subquery>"
|
|
74
|
+
},
|
|
75
|
+
{
|
|
76
|
+
"subquery": "<subquery_2>",
|
|
77
|
+
"intentName": "<intent_name_2>",
|
|
78
|
+
"actionPlan": "<2-3 sentence description of what will be done for this subquery>"
|
|
79
|
+
}
|
|
80
|
+
]
|
|
81
|
+
}
|
|
77
82
|
|
|
78
83
|
Requirements:
|
|
79
84
|
- Each subquery should represent a single, actionable task or request
|
|
80
85
|
- Preserve the original meaning and context when splitting queries
|
|
81
86
|
- Select only from the provided intent list
|
|
82
87
|
- DO NOT set intentName for any subquery that doesn't match available intents.
|
|
83
|
-
- Even if the query is simple and cannot be decomposed, return it as a single-element array with one subquery object
|
|
88
|
+
- Even if the query is simple and cannot be decomposed, return it as a single-element array with one subquery object
|
|
89
|
+
- Set needsAggregation based on whether the user expects a unified combined answer or separate responses`;
|
|
84
90
|
const messages = modelInstance.generateMessages({
|
|
85
91
|
query: userMessage,
|
|
86
92
|
systemPrompt
|
|
@@ -88,28 +94,34 @@ Requirements:
|
|
|
88
94
|
const response = await modelInstance.fetch(messages, modelOptions);
|
|
89
95
|
if (!response.content) {
|
|
90
96
|
loggers.intent.warn("Cannot extract intent from query");
|
|
91
|
-
return [{ subquery: query }];
|
|
97
|
+
return { intents: [{ subquery: query }], needsAggregation: false };
|
|
92
98
|
}
|
|
93
|
-
let
|
|
99
|
+
let parsed;
|
|
94
100
|
try {
|
|
95
|
-
|
|
101
|
+
parsed = JSON.parse(response.content);
|
|
96
102
|
} catch (error) {
|
|
97
|
-
return [{ subquery: query }];
|
|
103
|
+
return { intents: [{ subquery: query }], needsAggregation: false };
|
|
98
104
|
}
|
|
99
|
-
const
|
|
105
|
+
const subqueries = parsed.subqueries ?? [];
|
|
106
|
+
const needsAggregation = parsed.needsAggregation ?? false;
|
|
107
|
+
const triggeredIntents = [];
|
|
100
108
|
for (const { subquery, intentName, actionPlan } of subqueries) {
|
|
101
109
|
if (!subquery) continue;
|
|
102
110
|
const item = { subquery, actionPlan };
|
|
103
111
|
if (intentName) {
|
|
104
112
|
item.intent = await intentMemory.getIntentByName(intentName);
|
|
105
113
|
}
|
|
106
|
-
|
|
114
|
+
triggeredIntents.push(item);
|
|
107
115
|
}
|
|
108
|
-
|
|
116
|
+
loggers.intent.info("Intent triggering result", {
|
|
117
|
+
intentCount: triggeredIntents.length,
|
|
118
|
+
needsAggregation
|
|
119
|
+
});
|
|
120
|
+
return { intents: triggeredIntents, needsAggregation };
|
|
109
121
|
}
|
|
110
122
|
};
|
|
111
123
|
|
|
112
124
|
export {
|
|
113
125
|
MultiIntentTriggerService
|
|
114
126
|
};
|
|
115
|
-
//# sourceMappingURL=chunk-
|
|
127
|
+
//# sourceMappingURL=chunk-ZXRDGIRP.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/services/intents/multi-trigger.service.ts"],"sourcesContent":["import type { MemoryModule, ModelModule } from \"@/modules\";\nimport type {\n\tIntentTriggerResult,\n\tMessageObject,\n\tThreadObject,\n\tTriggeredIntent,\n} from \"@/types/memory\";\nimport { loggers } from \"@/utils/logger\";\n\n/**\n * Service for multi-intent triggering.\n * Decomposes queries into multiple subqueries and maps each to an intent.\n */\nexport class MultiIntentTriggerService {\n\tprivate modelModule: ModelModule;\n\tprivate memoryModule: MemoryModule;\n\n\tconstructor(modelModule: ModelModule, memoryModule: MemoryModule) {\n\t\tthis.modelModule = modelModule;\n\t\tthis.memoryModule = memoryModule;\n\t}\n\n\t/**\n\t * Detects multiple intents from context by decomposing queries into subqueries.\n\t *\n\t * @param query - The user's input query\n\t * @param thread - The thread history\n\t * @returns IntentTriggerResult containing intents and aggregation flag\n\t */\n\tpublic async intentTriggering(\n\t\tquery: string,\n\t\tthread: ThreadObject | undefined,\n\t): Promise<IntentTriggerResult> {\n\t\tconst modelInstance = this.modelModule.getModel();\n\t\tconst modelOptions = this.modelModule.getModelOptions();\n\t\tconst intentMemory = this.memoryModule.getIntentMemory();\n\t\tif (!intentMemory) {\n\t\t\treturn { intents: [{ subquery: query }], needsAggregation: false };\n\t\t}\n\n\t\t// 인텐트 목록 가져오기\n\t\tconst intents = await intentMemory.listIntents();\n\n\t\tif (intents.length === 0) {\n\t\t\tloggers.intentStream.warn(\"No intent found\");\n\t\t\treturn { intents: [{ subquery: query }], needsAggregation: false };\n\t\t}\n\n\t\tconst intentList = intents\n\t\t\t.map((intent) => `- ${intent.name}: ${intent.description}`)\n\t\t\t.join(\"\\n\");\n\n\t\t// Convert thread messages to a string\n\t\tconst threadMessages = !thread\n\t\t\t? \"\"\n\t\t\t: thread.messages\n\t\t\t\t\t.sort((a, b) => a.timestamp - b.timestamp)\n\t\t\t\t\t.map((message: MessageObject) => {\n\t\t\t\t\t\tconst role =\n\t\t\t\t\t\t\tmessage.role === \"USER\"\n\t\t\t\t\t\t\t\t? \"User\"\n\t\t\t\t\t\t\t\t: message.role === \"MODEL\"\n\t\t\t\t\t\t\t\t\t? \"Assistant\"\n\t\t\t\t\t\t\t\t\t: \"System\";\n\t\t\t\t\t\tconst content = Array.isArray(message.content.parts)\n\t\t\t\t\t\t\t? message.content.parts.join(\" \")\n\t\t\t\t\t\t\t: String(message.content.parts);\n\t\t\t\t\t\treturn `${role}: \"\"\"${content}\"\"\"`;\n\t\t\t\t\t})\n\t\t\t\t\t.join(\"\\n\");\n\n\t\tconst systemPrompt = `\nToday is ${new Date().toLocaleDateString()}.\nYou are an expert in accurately identifying user intentions.\n\nAvailable intent list:\n${intentList}\n\nPlease select and answer only from the above intent list.`;\n\n\t\tconst userMessage = `\n${\n\tthreadMessages !== \"\"\n\t\t? `The following is the conversation history with the user: ${threadMessages}\n\n\t`\n\t\t: \"\"\n}\nLast user question: \"${query}\"\n\nBased on the above conversation history, analyze the last user question and identify all relevant intents.\n\nInstructions:\n1. First, decompose the last user question into action-based subqueries (each representing a distinct action or task)\n2. Then, map each subquery to its corresponding intent from the available intent list\n3. For each subquery, provide a 2-3 sentence summary of what actions will be performed\n4. Multiple intents can be identified if the question covers various topics or actions\n5. Maintain the logical sequence of the original question when splitting into subqueries\n6. **Important**: If the query cannot be split into multiple subqueries (i.e., it represents a single action or request), treat the entire query as one subquery and still follow the output format\n7. Determine if the final response needs aggregation:\n - Set needsAggregation to TRUE if: multiple subqueries exist AND their results should be combined into a unified response\n - Set needsAggregation to FALSE if: only one subquery exists, OR multiple subqueries are independent and can be answered separately without combining\n\nOutput Format:\nYou MUST return the output in the following JSON format. Do not include any other text before or after the JSON:\n{\n \"needsAggregation\": <true or false>,\n \"subqueries\": [\n {\n \"subquery\": \"<subquery_1>\",\n \"intentName\": \"<intent_name_1>\",\n \"actionPlan\": \"<2-3 sentence description of what will be done for this subquery>\"\n },\n {\n \"subquery\": \"<subquery_2>\",\n \"intentName\": \"<intent_name_2>\",\n \"actionPlan\": \"<2-3 sentence description of what will be done for this subquery>\"\n }\n ]\n}\n\nRequirements:\n- Each subquery should represent a single, actionable task or request\n- Preserve the original meaning and context when splitting queries\n- Select only from the provided intent list\n- DO NOT set intentName for any subquery that doesn't match available intents.\n- Even if the query is simple and cannot be decomposed, return it as a single-element array with one subquery object\n- Set needsAggregation based on whether the user expects a unified combined answer or separate responses`;\n\n\t\tconst messages = modelInstance.generateMessages({\n\t\t\tquery: userMessage,\n\t\t\tsystemPrompt,\n\t\t});\n\n\t\tconst response = await modelInstance.fetch(messages, modelOptions);\n\t\tif (!response.content) {\n\t\t\tloggers.intent.warn(\"Cannot extract intent from query\");\n\t\t\treturn { intents: [{ subquery: query }], needsAggregation: false };\n\t\t}\n\n\t\tlet parsed: {\n\t\t\tneedsAggregation?: boolean;\n\t\t\tsubqueries?: Array<{\n\t\t\t\tsubquery?: string;\n\t\t\t\tintentName?: string;\n\t\t\t\tactionPlan?: string;\n\t\t\t}>;\n\t\t};\n\t\ttry {\n\t\t\tparsed = JSON.parse(response.content);\n\t\t} catch (error: unknown) {\n\t\t\treturn { intents: [{ subquery: query }], needsAggregation: false };\n\t\t}\n\n\t\tconst subqueries = parsed.subqueries ?? [];\n\t\tconst needsAggregation = parsed.needsAggregation ?? false;\n\n\t\tconst triggeredIntents: Array<TriggeredIntent> = [];\n\t\tfor (const { subquery, intentName, actionPlan } of subqueries) {\n\t\t\tif (!subquery) continue;\n\t\t\tconst item = { subquery, actionPlan } as TriggeredIntent;\n\t\t\tif (intentName) {\n\t\t\t\titem.intent = await intentMemory.getIntentByName(intentName);\n\t\t\t}\n\t\t\ttriggeredIntents.push(item);\n\t\t}\n\n\t\tloggers.intent.info(\"Intent triggering result\", {\n\t\t\tintentCount: triggeredIntents.length,\n\t\t\tneedsAggregation,\n\t\t});\n\n\t\treturn { intents: triggeredIntents, needsAggregation };\n\t}\n}\n"],"mappings":";;;;;AAaO,IAAM,4BAAN,MAAgC;AAAA,EAC9B;AAAA,EACA;AAAA,EAER,YAAY,aAA0B,cAA4B;AACjE,SAAK,cAAc;AACnB,SAAK,eAAe;AAAA,EACrB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASA,MAAa,iBACZ,OACA,QAC+B;AAC/B,UAAM,gBAAgB,KAAK,YAAY,SAAS;AAChD,UAAM,eAAe,KAAK,YAAY,gBAAgB;AACtD,UAAM,eAAe,KAAK,aAAa,gBAAgB;AACvD,QAAI,CAAC,cAAc;AAClB,aAAO,EAAE,SAAS,CAAC,EAAE,UAAU,MAAM,CAAC,GAAG,kBAAkB,MAAM;AAAA,IAClE;AAGA,UAAM,UAAU,MAAM,aAAa,YAAY;AAE/C,QAAI,QAAQ,WAAW,GAAG;AACzB,cAAQ,aAAa,KAAK,iBAAiB;AAC3C,aAAO,EAAE,SAAS,CAAC,EAAE,UAAU,MAAM,CAAC,GAAG,kBAAkB,MAAM;AAAA,IAClE;AAEA,UAAM,aAAa,QACjB,IAAI,CAAC,WAAW,KAAK,OAAO,IAAI,KAAK,OAAO,WAAW,EAAE,EACzD,KAAK,IAAI;AAGX,UAAM,iBAAiB,CAAC,SACrB,KACA,OAAO,SACN,KAAK,CAAC,GAAG,MAAM,EAAE,YAAY,EAAE,SAAS,EACxC,IAAI,CAAC,YAA2B;AAChC,YAAM,OACL,QAAQ,SAAS,SACd,SACA,QAAQ,SAAS,UAChB,cACA;AACL,YAAM,UAAU,MAAM,QAAQ,QAAQ,QAAQ,KAAK,IAChD,QAAQ,QAAQ,MAAM,KAAK,GAAG,IAC9B,OAAO,QAAQ,QAAQ,KAAK;AAC/B,aAAO,GAAG,IAAI,QAAQ,OAAO;AAAA,IAC9B,CAAC,EACA,KAAK,IAAI;AAEb,UAAM,eAAe;AAAA,YACZ,oBAAI,KAAK,GAAE,mBAAmB,CAAC;AAAA;AAAA;AAAA;AAAA,EAIxC,UAAU;AAAA;AAAA;AAIV,UAAM,cAAc;AAAA,EAErB,mBAAmB,KAChB,4DAA4D,cAAc;AAAA;AAAA,KAG1E,EACJ;AAAA,uBACuB,KAAK;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAyC1B,UAAM,WAAW,cAAc,iBAAiB;AAAA,MAC/C,OAAO;AAAA,MACP;AAAA,IACD,CAAC;AAED,UAAM,WAAW,MAAM,cAAc,MAAM,UAAU,YAAY;AACjE,QAAI,CAAC,SAAS,SAAS;AACtB,cAAQ,OAAO,KAAK,kCAAkC;AACtD,aAAO,EAAE,SAAS,CAAC,EAAE,UAAU,MAAM,CAAC,GAAG,kBAAkB,MAAM;AAAA,IAClE;AAEA,QAAI;AAQJ,QAAI;AACH,eAAS,KAAK,MAAM,SAAS,OAAO;AAAA,IACrC,SAAS,OAAgB;AACxB,aAAO,EAAE,SAAS,CAAC,EAAE,UAAU,MAAM,CAAC,GAAG,kBAAkB,MAAM;AAAA,IAClE;AAEA,UAAM,aAAa,OAAO,cAAc,CAAC;AACzC,UAAM,mBAAmB,OAAO,oBAAoB;AAEpD,UAAM,mBAA2C,CAAC;AAClD,eAAW,EAAE,UAAU,YAAY,WAAW,KAAK,YAAY;AAC9D,UAAI,CAAC,SAAU;AACf,YAAM,OAAO,EAAE,UAAU,WAAW;AACpC,UAAI,YAAY;AACf,aAAK,SAAS,MAAM,aAAa,gBAAgB,UAAU;AAAA,MAC5D;AACA,uBAAiB,KAAK,IAAI;AAAA,IAC3B;AAEA,YAAQ,OAAO,KAAK,4BAA4B;AAAA,MAC/C,aAAa,iBAAiB;AAAA,MAC9B;AAAA,IACD,CAAC;AAED,WAAO,EAAE,SAAS,kBAAkB,iBAAiB;AAAA,EACtD;AACD;","names":[]}
|
|
@@ -1,15 +1,16 @@
|
|
|
1
1
|
import {
|
|
2
2
|
ControllerContainer
|
|
3
|
-
} from "../chunk-
|
|
3
|
+
} from "../chunk-GKG27ZGB.js";
|
|
4
4
|
import "../chunk-DFXHJUGV.js";
|
|
5
|
-
import "../chunk-
|
|
6
|
-
import "../chunk-VSQVYW2H.js";
|
|
5
|
+
import "../chunk-TR2QAQEW.js";
|
|
7
6
|
import "../chunk-WKFSYGMH.js";
|
|
8
7
|
import "../chunk-UA44VKFE.js";
|
|
9
8
|
import "../chunk-ZVYC5Y6Z.js";
|
|
10
|
-
import "../chunk-D6STNZ2L.js";
|
|
11
|
-
import "../chunk-4BHU7SPZ.js";
|
|
12
9
|
import "../chunk-YUKPKFX5.js";
|
|
10
|
+
import "../chunk-RE676AIN.js";
|
|
11
|
+
import "../chunk-VX3VWWYW.js";
|
|
12
|
+
import "../chunk-GHUEA7V5.js";
|
|
13
|
+
import "../chunk-VSQVYW2H.js";
|
|
13
14
|
export {
|
|
14
15
|
ControllerContainer
|
|
15
16
|
};
|
|
@@ -1,37 +1,37 @@
|
|
|
1
1
|
import {
|
|
2
2
|
container
|
|
3
|
-
} from "../chunk-
|
|
3
|
+
} from "../chunk-A3CKGK3U.js";
|
|
4
4
|
import {
|
|
5
5
|
ControllerContainer
|
|
6
|
-
} from "../chunk-
|
|
6
|
+
} from "../chunk-GKG27ZGB.js";
|
|
7
7
|
import "../chunk-DFXHJUGV.js";
|
|
8
|
-
import "../chunk-
|
|
8
|
+
import "../chunk-TR2QAQEW.js";
|
|
9
|
+
import "../chunk-WKFSYGMH.js";
|
|
10
|
+
import "../chunk-UA44VKFE.js";
|
|
11
|
+
import "../chunk-ZVYC5Y6Z.js";
|
|
12
|
+
import "../chunk-YUKPKFX5.js";
|
|
13
|
+
import "../chunk-RE676AIN.js";
|
|
9
14
|
import {
|
|
10
15
|
ServiceContainer
|
|
11
|
-
} from "../chunk-
|
|
12
|
-
import "../chunk-
|
|
16
|
+
} from "../chunk-CYP6OTDK.js";
|
|
17
|
+
import "../chunk-DBB7B4PV.js";
|
|
18
|
+
import "../chunk-ZXRDGIRP.js";
|
|
19
|
+
import "../chunk-VGL4ZVNA.js";
|
|
20
|
+
import "../chunk-5FJU67BO.js";
|
|
13
21
|
import "../chunk-7BH6AYP7.js";
|
|
14
|
-
import "../chunk-
|
|
22
|
+
import "../chunk-L447Q33F.js";
|
|
15
23
|
import "../chunk-O3MPFL5J.js";
|
|
16
|
-
import "../chunk-
|
|
17
|
-
import "../chunk-
|
|
18
|
-
import "../chunk-
|
|
19
|
-
import "../chunk-ZJVWC666.js";
|
|
20
|
-
import "../chunk-JXGQVFCO.js";
|
|
21
|
-
import "../chunk-5IIF5O4A.js";
|
|
24
|
+
import "../chunk-WMHUZEL2.js";
|
|
25
|
+
import "../chunk-ZSWCICNO.js";
|
|
26
|
+
import "../chunk-HEYSMA5B.js";
|
|
22
27
|
import "../chunk-V23GKNNJ.js";
|
|
23
28
|
import "../chunk-C5JXXLCW.js";
|
|
24
29
|
import "../chunk-7CULQDJF.js";
|
|
25
30
|
import "../chunk-2J2TQRP4.js";
|
|
26
|
-
import "../chunk-VSQVYW2H.js";
|
|
27
31
|
import "../chunk-CG35V3ZH.js";
|
|
28
|
-
import "../chunk-
|
|
29
|
-
import "../chunk-
|
|
30
|
-
import "../chunk-
|
|
31
|
-
import "../chunk-D6STNZ2L.js";
|
|
32
|
-
import "../chunk-4BHU7SPZ.js";
|
|
33
|
-
import "../chunk-VUMI4XOY.js";
|
|
34
|
-
import "../chunk-YUKPKFX5.js";
|
|
32
|
+
import "../chunk-VX3VWWYW.js";
|
|
33
|
+
import "../chunk-GHUEA7V5.js";
|
|
34
|
+
import "../chunk-VSQVYW2H.js";
|
|
35
35
|
export {
|
|
36
36
|
ControllerContainer,
|
|
37
37
|
ServiceContainer,
|
|
@@ -1,24 +1,24 @@
|
|
|
1
1
|
import {
|
|
2
2
|
ServiceContainer
|
|
3
|
-
} from "../chunk-
|
|
4
|
-
import "../chunk-
|
|
3
|
+
} from "../chunk-CYP6OTDK.js";
|
|
4
|
+
import "../chunk-DBB7B4PV.js";
|
|
5
|
+
import "../chunk-ZXRDGIRP.js";
|
|
6
|
+
import "../chunk-VGL4ZVNA.js";
|
|
7
|
+
import "../chunk-5FJU67BO.js";
|
|
5
8
|
import "../chunk-7BH6AYP7.js";
|
|
6
|
-
import "../chunk-
|
|
9
|
+
import "../chunk-L447Q33F.js";
|
|
7
10
|
import "../chunk-O3MPFL5J.js";
|
|
8
|
-
import "../chunk-
|
|
9
|
-
import "../chunk-
|
|
10
|
-
import "../chunk-
|
|
11
|
-
import "../chunk-ZJVWC666.js";
|
|
12
|
-
import "../chunk-JXGQVFCO.js";
|
|
13
|
-
import "../chunk-5IIF5O4A.js";
|
|
11
|
+
import "../chunk-WMHUZEL2.js";
|
|
12
|
+
import "../chunk-ZSWCICNO.js";
|
|
13
|
+
import "../chunk-HEYSMA5B.js";
|
|
14
14
|
import "../chunk-V23GKNNJ.js";
|
|
15
15
|
import "../chunk-C5JXXLCW.js";
|
|
16
16
|
import "../chunk-7CULQDJF.js";
|
|
17
17
|
import "../chunk-2J2TQRP4.js";
|
|
18
|
-
import "../chunk-VSQVYW2H.js";
|
|
19
18
|
import "../chunk-CG35V3ZH.js";
|
|
20
|
-
import "../chunk-
|
|
21
|
-
import "../chunk-
|
|
19
|
+
import "../chunk-VX3VWWYW.js";
|
|
20
|
+
import "../chunk-GHUEA7V5.js";
|
|
21
|
+
import "../chunk-VSQVYW2H.js";
|
|
22
22
|
export {
|
|
23
23
|
ServiceContainer
|
|
24
24
|
};
|