@ainetwork/adk 0.1.11 → 0.1.13
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/README.md +9 -4
- package/dist/cjs/chunk-2XND7YNQ.cjs +279 -0
- package/dist/cjs/chunk-2XND7YNQ.cjs.map +1 -0
- package/dist/cjs/chunk-36ECGO5C.cjs +269 -0
- package/dist/cjs/chunk-36ECGO5C.cjs.map +1 -0
- package/dist/cjs/chunk-3J3ORQOG.cjs +65 -0
- package/dist/cjs/chunk-3J3ORQOG.cjs.map +1 -0
- package/dist/cjs/chunk-3QNRWPMM.cjs +37 -0
- package/dist/cjs/chunk-3QNRWPMM.cjs.map +1 -0
- package/dist/cjs/chunk-4MCEFDVX.cjs +43 -0
- package/dist/cjs/chunk-4MCEFDVX.cjs.map +1 -0
- package/dist/cjs/chunk-55IME4BG.cjs +114 -0
- package/dist/cjs/chunk-55IME4BG.cjs.map +1 -0
- package/dist/cjs/chunk-5T53A5X4.cjs +12 -0
- package/dist/cjs/chunk-5T53A5X4.cjs.map +1 -0
- package/dist/cjs/chunk-65M7DC3L.cjs +172 -0
- package/dist/cjs/chunk-65M7DC3L.cjs.map +1 -0
- package/dist/cjs/chunk-6BKOR3ZH.cjs +111 -0
- package/dist/cjs/chunk-6BKOR3ZH.cjs.map +1 -0
- package/dist/cjs/chunk-6YVTJEMQ.cjs +176 -0
- package/dist/cjs/chunk-6YVTJEMQ.cjs.map +1 -0
- package/dist/cjs/chunk-7EGJAURF.cjs +205 -0
- package/dist/cjs/chunk-7EGJAURF.cjs.map +1 -0
- package/dist/cjs/chunk-7EOUPEHU.cjs +243 -0
- package/dist/cjs/chunk-7EOUPEHU.cjs.map +1 -0
- package/dist/cjs/chunk-7K2R2UKB.cjs +8 -0
- package/dist/cjs/chunk-7K2R2UKB.cjs.map +1 -0
- package/dist/cjs/chunk-7QR5ZJAF.cjs +278 -0
- package/dist/cjs/chunk-7QR5ZJAF.cjs.map +1 -0
- package/dist/cjs/chunk-7TEDNNSL.cjs +18 -0
- package/dist/cjs/chunk-7TEDNNSL.cjs.map +1 -0
- package/dist/cjs/chunk-7WYFXLNY.cjs +43 -0
- package/dist/cjs/chunk-7WYFXLNY.cjs.map +1 -0
- package/dist/cjs/chunk-7XDYJNTA.cjs +35 -0
- package/dist/cjs/chunk-7XDYJNTA.cjs.map +1 -0
- package/dist/cjs/chunk-BBCZU5VZ.cjs +17 -0
- package/dist/cjs/chunk-BBCZU5VZ.cjs.map +1 -0
- package/dist/cjs/chunk-BNY3RLYC.cjs +43 -0
- package/dist/cjs/chunk-BNY3RLYC.cjs.map +1 -0
- package/dist/cjs/chunk-BYD5RS6L.cjs +12 -0
- package/dist/cjs/chunk-BYD5RS6L.cjs.map +1 -0
- package/dist/cjs/chunk-EAK7MP6X.cjs +22 -0
- package/dist/cjs/chunk-EAK7MP6X.cjs.map +1 -0
- package/dist/cjs/chunk-GHE5MNHK.cjs +43 -0
- package/dist/cjs/chunk-GHE5MNHK.cjs.map +1 -0
- package/dist/cjs/chunk-H65RVLWK.cjs +267 -0
- package/dist/cjs/chunk-H65RVLWK.cjs.map +1 -0
- package/dist/cjs/chunk-IS2IVXXA.cjs +176 -0
- package/dist/cjs/chunk-IS2IVXXA.cjs.map +1 -0
- package/dist/cjs/chunk-J4Z7ZJUJ.cjs +277 -0
- package/dist/cjs/chunk-J4Z7ZJUJ.cjs.map +1 -0
- package/dist/cjs/chunk-J6PDRTNM.cjs +37 -0
- package/dist/cjs/chunk-J6PDRTNM.cjs.map +1 -0
- package/dist/cjs/chunk-JAPFZA2K.cjs +205 -0
- package/dist/cjs/chunk-JAPFZA2K.cjs.map +1 -0
- package/dist/cjs/chunk-JLWQUJCP.cjs +43 -0
- package/dist/cjs/chunk-JLWQUJCP.cjs.map +1 -0
- package/dist/cjs/chunk-K4P2MYZF.cjs +43 -0
- package/dist/cjs/chunk-K4P2MYZF.cjs.map +1 -0
- package/dist/cjs/chunk-KDNNRPBV.cjs +43 -0
- package/dist/cjs/chunk-KDNNRPBV.cjs.map +1 -0
- package/dist/cjs/chunk-KRLUWTLN.cjs +35 -0
- package/dist/cjs/chunk-KRLUWTLN.cjs.map +1 -0
- package/dist/cjs/chunk-M4MYRCSF.cjs +18 -0
- package/dist/cjs/chunk-M4MYRCSF.cjs.map +1 -0
- package/dist/{esm/chunk-3NEV3O2X.js → cjs/chunk-MSFAMZFU.cjs} +41 -39
- package/dist/cjs/chunk-MSFAMZFU.cjs.map +1 -0
- package/dist/cjs/chunk-MVN5XJGZ.cjs +66 -0
- package/dist/cjs/chunk-MVN5XJGZ.cjs.map +1 -0
- package/dist/cjs/chunk-O6XQRAWR.cjs +45 -0
- package/dist/cjs/chunk-O6XQRAWR.cjs.map +1 -0
- package/dist/cjs/chunk-PDF6B6A3.cjs +37 -0
- package/dist/cjs/chunk-PDF6B6A3.cjs.map +1 -0
- package/dist/cjs/chunk-PT2CVI52.cjs +162 -0
- package/dist/cjs/chunk-PT2CVI52.cjs.map +1 -0
- package/dist/cjs/chunk-Q75JG4Y6.cjs +43 -0
- package/dist/cjs/chunk-Q75JG4Y6.cjs.map +1 -0
- package/dist/cjs/chunk-QJJ4NXX6.cjs +37 -0
- package/dist/cjs/chunk-QJJ4NXX6.cjs.map +1 -0
- package/dist/cjs/chunk-QUSBMECP.cjs +37 -0
- package/dist/cjs/chunk-QUSBMECP.cjs.map +1 -0
- package/dist/cjs/chunk-SAXFX7U2.cjs +37 -0
- package/dist/cjs/chunk-SAXFX7U2.cjs.map +1 -0
- package/dist/cjs/chunk-SCOMNXDA.cjs +51 -0
- package/dist/cjs/chunk-SCOMNXDA.cjs.map +1 -0
- package/dist/cjs/chunk-SGW3CSPD.cjs +43 -0
- package/dist/cjs/chunk-SGW3CSPD.cjs.map +1 -0
- package/dist/cjs/chunk-SJHSHDJL.cjs +65 -0
- package/dist/cjs/chunk-SJHSHDJL.cjs.map +1 -0
- package/dist/cjs/chunk-UAWGHNZD.cjs +22 -0
- package/dist/cjs/chunk-UAWGHNZD.cjs.map +1 -0
- package/dist/cjs/chunk-UBEB55WC.cjs +43 -0
- package/dist/cjs/chunk-UBEB55WC.cjs.map +1 -0
- package/dist/cjs/chunk-UPNSAV5A.cjs +18 -0
- package/dist/cjs/chunk-UPNSAV5A.cjs.map +1 -0
- package/dist/cjs/chunk-UW43BI5Z.cjs +17 -0
- package/dist/cjs/chunk-UW43BI5Z.cjs.map +1 -0
- package/dist/cjs/chunk-WNDA2G4Q.cjs +43 -0
- package/dist/cjs/chunk-WNDA2G4Q.cjs.map +1 -0
- package/dist/cjs/chunk-X46GJS7X.cjs +17 -0
- package/dist/cjs/chunk-X46GJS7X.cjs.map +1 -0
- package/dist/cjs/chunk-XPD3ANDG.cjs +267 -0
- package/dist/cjs/chunk-XPD3ANDG.cjs.map +1 -0
- package/dist/cjs/chunk-XPTRG6IC.cjs +43 -0
- package/dist/cjs/chunk-XPTRG6IC.cjs.map +1 -0
- package/dist/cjs/chunk-XVMXTCJI.cjs +64 -0
- package/dist/cjs/chunk-XVMXTCJI.cjs.map +1 -0
- package/dist/cjs/chunk-YQ5P2K3X.cjs +37 -0
- package/dist/cjs/chunk-YQ5P2K3X.cjs.map +1 -0
- package/dist/cjs/controllers/api/thread.api.controller.cjs +8 -0
- package/dist/cjs/controllers/api/thread.api.controller.cjs.map +1 -0
- package/dist/cjs/controllers/index.cjs +3 -3
- package/dist/cjs/controllers/index.cjs.map +1 -1
- package/dist/cjs/controllers/query.controller.cjs +3 -2
- package/dist/cjs/controllers/query.controller.cjs.map +1 -1
- package/dist/cjs/index.cjs +17 -16
- package/dist/cjs/index.cjs.map +1 -1
- package/dist/cjs/modules/a2a/a2a.module.cjs +3 -2
- package/dist/cjs/modules/a2a/a2a.module.cjs.map +1 -1
- package/dist/cjs/modules/index.cjs +5 -4
- package/dist/cjs/modules/index.cjs.map +1 -1
- package/dist/cjs/modules/memory/memory.module.cjs +2 -2
- package/dist/cjs/modules/models/base.model.cjs +2 -2
- package/dist/cjs/routes/a2a.routes.cjs +5 -5
- package/dist/cjs/routes/api/model.routes.cjs +8 -0
- package/dist/cjs/routes/api/model.routes.cjs.map +1 -0
- package/dist/cjs/routes/api/thread.routes.cjs +9 -0
- package/dist/cjs/routes/api/thread.routes.cjs.map +1 -0
- package/dist/cjs/routes/api.routes.cjs +5 -5
- package/dist/cjs/routes/index.cjs +12 -12
- package/dist/cjs/routes/index.cjs.map +1 -1
- package/dist/cjs/routes/query.routes.cjs +7 -6
- package/dist/cjs/routes/query.routes.cjs.map +1 -1
- package/dist/cjs/services/a2a.service.cjs +2 -2
- package/dist/cjs/services/index.cjs +5 -5
- package/dist/cjs/services/query-stream.service.cjs +3 -3
- package/dist/cjs/services/query.service.cjs +3 -3
- package/dist/cjs/types/memory.cjs +2 -2
- package/dist/cjs/types/memory.cjs.map +1 -1
- package/dist/esm/chunk-2BYUKYVB.js +243 -0
- package/dist/esm/chunk-2BYUKYVB.js.map +1 -0
- package/dist/esm/{chunk-Y6E73I7I.js → chunk-2RW77MJB.js} +6 -3
- package/dist/esm/chunk-2RW77MJB.js.map +1 -0
- package/dist/esm/chunk-7D4SKPIS.js +65 -0
- package/dist/esm/chunk-7D4SKPIS.js.map +1 -0
- package/dist/esm/{chunk-5EPK37PE.js → chunk-ADIAIRNH.js} +10 -10
- package/dist/esm/chunk-ADIAIRNH.js.map +1 -0
- package/dist/esm/{chunk-2Z7GJVJJ.js → chunk-AMRKK46V.js} +2 -2
- package/dist/esm/chunk-AMRKK46V.js.map +1 -0
- package/dist/esm/{chunk-2BITOA2R.js → chunk-CDFLKADH.js} +1 -1
- package/dist/esm/chunk-CDFLKADH.js.map +1 -0
- package/dist/esm/{chunk-DRUCJYPJ.js → chunk-EGR6OTTN.js} +65 -22
- package/dist/esm/chunk-EGR6OTTN.js.map +1 -0
- package/dist/esm/{chunk-5N4X25IK.js → chunk-G6VR5RSV.js} +5 -5
- package/dist/esm/chunk-HOFAK5J2.js +22 -0
- package/dist/esm/chunk-HOFAK5J2.js.map +1 -0
- package/dist/esm/{chunk-GNWF6QG4.js → chunk-JCWH7LIC.js} +6 -6
- package/dist/esm/{chunk-C6SGV7JV.js → chunk-LJVVSUF7.js} +17 -13
- package/dist/esm/chunk-LJVVSUF7.js.map +1 -0
- package/dist/esm/chunk-MNAWSBYP.js +18 -0
- package/dist/esm/chunk-MNAWSBYP.js.map +1 -0
- package/dist/esm/chunk-VA3XOZBV.js +17 -0
- package/dist/esm/chunk-VA3XOZBV.js.map +1 -0
- package/dist/esm/{chunk-CKTURH34.js → chunk-XBMWWTSX.js} +9 -9
- package/dist/esm/chunk-XBMWWTSX.js.map +1 -0
- package/dist/esm/controllers/a2a.controller.d.ts +1 -1
- package/dist/esm/controllers/api/{session.api.controller.d.ts → thread.api.controller.d.ts} +3 -3
- package/dist/esm/controllers/api/thread.api.controller.js +8 -0
- package/dist/esm/controllers/index.d.ts +2 -2
- package/dist/esm/controllers/index.js +7 -7
- package/dist/esm/controllers/query.controller.d.ts +1 -1
- package/dist/esm/controllers/query.controller.js +2 -1
- package/dist/esm/index.d.ts +1 -0
- package/dist/esm/index.js +17 -16
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/modules/a2a/a2a.module.d.ts +6 -15
- package/dist/esm/modules/a2a/a2a.module.js +2 -1
- package/dist/esm/modules/index.d.ts +1 -1
- package/dist/esm/modules/index.js +4 -3
- package/dist/esm/modules/memory/base.memory.d.ts +9 -9
- package/dist/esm/modules/memory/memory.module.d.ts +4 -4
- package/dist/esm/modules/memory/memory.module.js +1 -1
- package/dist/esm/modules/models/base.model.d.ts +4 -4
- package/dist/esm/modules/models/base.model.js +1 -1
- package/dist/esm/routes/a2a.routes.js +4 -4
- package/dist/esm/routes/api/{models.routes.js → model.routes.js} +2 -2
- package/dist/esm/routes/api/{sessions.routes.d.ts → thread.routes.d.ts} +2 -2
- package/dist/esm/routes/api/thread.routes.js +9 -0
- package/dist/esm/routes/api.routes.js +4 -4
- package/dist/esm/routes/index.d.ts +2 -2
- package/dist/esm/routes/index.js +16 -16
- package/dist/esm/routes/query.routes.js +6 -5
- package/dist/esm/services/a2a.service.d.ts +1 -1
- package/dist/esm/services/a2a.service.js +1 -1
- package/dist/esm/services/index.d.ts +1 -2
- package/dist/esm/services/index.js +6 -6
- package/dist/esm/services/query-stream.service.d.ts +13 -8
- package/dist/esm/services/query-stream.service.js +2 -2
- package/dist/esm/services/query.service.d.ts +19 -8
- package/dist/esm/services/query.service.js +2 -2
- package/dist/esm/types/memory.d.ts +32 -32
- package/dist/esm/types/memory.js +5 -5
- package/dist/esm/types/stream.d.ts +32 -2
- package/package.json +6 -6
- package/dist/esm/chunk-2BITOA2R.js.map +0 -1
- package/dist/esm/chunk-2Z7GJVJJ.js.map +0 -1
- package/dist/esm/chunk-3NEV3O2X.js.map +0 -1
- package/dist/esm/chunk-5EPK37PE.js.map +0 -1
- package/dist/esm/chunk-C6SGV7JV.js.map +0 -1
- package/dist/esm/chunk-CKTURH34.js.map +0 -1
- package/dist/esm/chunk-DRUCJYPJ.js.map +0 -1
- package/dist/esm/chunk-Q6HHVAO6.js +0 -45
- package/dist/esm/chunk-Q6HHVAO6.js.map +0 -1
- package/dist/esm/chunk-QROUPWWO.js +0 -17
- package/dist/esm/chunk-QROUPWWO.js.map +0 -1
- package/dist/esm/chunk-VAZWF5IK.js +0 -20
- package/dist/esm/chunk-VAZWF5IK.js.map +0 -1
- package/dist/esm/chunk-Y6E73I7I.js.map +0 -1
- package/dist/esm/chunk-YT6PD6UF.js +0 -22
- package/dist/esm/chunk-YT6PD6UF.js.map +0 -1
- package/dist/esm/controllers/api/session.api.controller.js +0 -8
- package/dist/esm/routes/api/sessions.routes.js +0 -9
- /package/dist/esm/{chunk-5N4X25IK.js.map → chunk-G6VR5RSV.js.map} +0 -0
- /package/dist/esm/{chunk-GNWF6QG4.js.map → chunk-JCWH7LIC.js.map} +0 -0
- /package/dist/esm/controllers/api/{session.api.controller.js.map → thread.api.controller.js.map} +0 -0
- /package/dist/esm/routes/api/{models.routes.d.ts → model.routes.d.ts} +0 -0
- /package/dist/esm/routes/api/{models.routes.js.map → model.routes.js.map} +0 -0
- /package/dist/esm/routes/api/{sessions.routes.js.map → thread.routes.js.map} +0 -0
|
@@ -1,15 +1,15 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
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 _chunk466ED5WNcjs = require('./chunk-466ED5WN.cjs');
|
|
4
4
|
|
|
5
5
|
// src/services/query-stream.service.ts
|
|
6
|
-
|
|
6
|
+
var _crypto = require('crypto');
|
|
7
7
|
var QueryStreamService = class {
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
8
|
+
|
|
9
|
+
|
|
10
|
+
|
|
11
|
+
|
|
12
|
+
|
|
13
13
|
constructor(modelModule, a2aModule, mcpModule, memoryModule, prompts) {
|
|
14
14
|
this.modelModule = modelModule;
|
|
15
15
|
this.a2aModule = a2aModule;
|
|
@@ -46,9 +46,9 @@ var QueryStreamService = class {
|
|
|
46
46
|
const systemPrompt = `
|
|
47
47
|
Today is ${(/* @__PURE__ */ new Date()).toLocaleDateString()}.
|
|
48
48
|
|
|
49
|
-
${this.prompts
|
|
49
|
+
${_optionalChain([this, 'access', _ => _.prompts, 'optionalAccess', _2 => _2.agent]) || ""}
|
|
50
50
|
|
|
51
|
-
${this.prompts
|
|
51
|
+
${_optionalChain([this, 'access', _3 => _3.prompts, 'optionalAccess', _4 => _4.system]) || ""}
|
|
52
52
|
`;
|
|
53
53
|
const modelInstance = this.modelModule.getModel();
|
|
54
54
|
const messages = modelInstance.generateMessages({
|
|
@@ -63,7 +63,9 @@ ${this.prompts?.system || ""}
|
|
|
63
63
|
if (this.a2aModule) {
|
|
64
64
|
tools.push(...await this.a2aModule.getTools());
|
|
65
65
|
}
|
|
66
|
+
console.log(tools);
|
|
66
67
|
const functions = modelInstance.convertToolsToFunctions(tools);
|
|
68
|
+
console.log(functions);
|
|
67
69
|
const processList = [];
|
|
68
70
|
let didCallTool = false;
|
|
69
71
|
while (true) {
|
|
@@ -73,10 +75,10 @@ ${this.prompts?.system || ""}
|
|
|
73
75
|
);
|
|
74
76
|
didCallTool = false;
|
|
75
77
|
const assembledToolCalls = [];
|
|
76
|
-
loggers.intentStream.debug("messages", { messages });
|
|
78
|
+
_chunk466ED5WNcjs.loggers.intentStream.debug("messages", { messages });
|
|
77
79
|
for await (const chunk of responseStream) {
|
|
78
80
|
const delta = chunk.delta;
|
|
79
|
-
if (delta
|
|
81
|
+
if (_optionalChain([delta, 'optionalAccess', _5 => _5.tool_calls])) {
|
|
80
82
|
didCallTool = true;
|
|
81
83
|
for (const toolCallDelta of delta.tool_calls) {
|
|
82
84
|
const index = toolCallDelta.index;
|
|
@@ -90,28 +92,28 @@ ${this.prompts?.system || ""}
|
|
|
90
92
|
if (toolCallDelta.id) {
|
|
91
93
|
assembledToolCalls[index].id = toolCallDelta.id;
|
|
92
94
|
}
|
|
93
|
-
if (toolCallDelta.function
|
|
95
|
+
if (_optionalChain([toolCallDelta, 'access', _6 => _6.function, 'optionalAccess', _7 => _7.name])) {
|
|
94
96
|
assembledToolCalls[index].function.name = toolCallDelta.function.name;
|
|
95
97
|
}
|
|
96
|
-
if (toolCallDelta.function
|
|
98
|
+
if (_optionalChain([toolCallDelta, 'access', _8 => _8.function, 'optionalAccess', _9 => _9.arguments])) {
|
|
97
99
|
assembledToolCalls[index].function.arguments += toolCallDelta.function.arguments;
|
|
98
100
|
}
|
|
99
101
|
}
|
|
100
|
-
} else if (chunk.delta
|
|
102
|
+
} else if (_optionalChain([chunk, 'access', _10 => _10.delta, 'optionalAccess', _11 => _11.content])) {
|
|
101
103
|
yield {
|
|
102
104
|
event: "text_chunk",
|
|
103
105
|
data: { delta: chunk.delta.content }
|
|
104
106
|
};
|
|
105
107
|
}
|
|
106
108
|
}
|
|
107
|
-
loggers.intentStream.debug("assembledToolCalls", {
|
|
109
|
+
_chunk466ED5WNcjs.loggers.intentStream.debug("assembledToolCalls", {
|
|
108
110
|
assembledToolCalls
|
|
109
111
|
});
|
|
110
112
|
if (didCallTool && assembledToolCalls.length > 0) {
|
|
111
|
-
const messagePayload = this.a2aModule
|
|
113
|
+
const messagePayload = _optionalChain([this, 'access', _12 => _12.a2aModule, 'optionalAccess', _13 => _13.getMessagePayload, 'call', _14 => _14(
|
|
112
114
|
query,
|
|
113
115
|
sessionId
|
|
114
|
-
);
|
|
116
|
+
)]);
|
|
115
117
|
for (const toolCall of assembledToolCalls) {
|
|
116
118
|
const toolName = toolCall.function.name;
|
|
117
119
|
const toolArgs = JSON.parse(toolCall.function.arguments);
|
|
@@ -122,7 +124,7 @@ ${this.prompts?.system || ""}
|
|
|
122
124
|
let toolResult = "";
|
|
123
125
|
if (this.mcpModule && selectedTool.protocol === "MCP" /* MCP */) {
|
|
124
126
|
const toolArgs2 = JSON.parse(toolCall.function.arguments);
|
|
125
|
-
loggers.intent.debug("MCP tool call", { toolName, toolArgs: toolArgs2 });
|
|
127
|
+
_chunk466ED5WNcjs.loggers.intent.debug("MCP tool call", { toolName, toolArgs: toolArgs2 });
|
|
126
128
|
toolResult = await this.mcpModule.useTool(
|
|
127
129
|
selectedTool,
|
|
128
130
|
toolArgs2
|
|
@@ -134,7 +136,7 @@ ${this.prompts?.system || ""}
|
|
|
134
136
|
sessionId
|
|
135
137
|
);
|
|
136
138
|
} else {
|
|
137
|
-
loggers.intent.warn(
|
|
139
|
+
_chunk466ED5WNcjs.loggers.intent.warn(
|
|
138
140
|
`Unrecognized tool type: ${selectedTool.protocol}`
|
|
139
141
|
);
|
|
140
142
|
continue;
|
|
@@ -143,7 +145,7 @@ ${this.prompts?.system || ""}
|
|
|
143
145
|
event: "tool_output",
|
|
144
146
|
data: { toolName, result: toolResult }
|
|
145
147
|
};
|
|
146
|
-
loggers.intent.debug("toolResult", { toolResult });
|
|
148
|
+
_chunk466ED5WNcjs.loggers.intent.debug("toolResult", { toolResult });
|
|
147
149
|
processList.push(toolResult);
|
|
148
150
|
modelInstance.appendMessages(messages, toolResult);
|
|
149
151
|
}
|
|
@@ -151,7 +153,7 @@ ${this.prompts?.system || ""}
|
|
|
151
153
|
if (!didCallTool) break;
|
|
152
154
|
}
|
|
153
155
|
} catch (error) {
|
|
154
|
-
loggers.intent.error("Error in intentFulfilling generator", { error });
|
|
156
|
+
_chunk466ED5WNcjs.loggers.intent.error("Error in intentFulfilling generator", { error });
|
|
155
157
|
if (error instanceof Error) {
|
|
156
158
|
yield {
|
|
157
159
|
event: "error",
|
|
@@ -185,7 +187,7 @@ ${this.prompts?.system || ""}
|
|
|
185
187
|
const response = await modelInstance.fetch(messages);
|
|
186
188
|
return response.content || DEFAULT_TITLE;
|
|
187
189
|
} catch (error) {
|
|
188
|
-
loggers.intentStream.error("Error generating title", {
|
|
190
|
+
_chunk466ED5WNcjs.loggers.intentStream.error("Error generating title", {
|
|
189
191
|
error,
|
|
190
192
|
query
|
|
191
193
|
});
|
|
@@ -208,18 +210,18 @@ ${this.prompts?.system || ""}
|
|
|
208
210
|
async handleQueryStream(query, userId, res, _sessionId) {
|
|
209
211
|
let sessionId = _sessionId;
|
|
210
212
|
const queryStartAt = Date.now();
|
|
211
|
-
const sessionMemory = this.memoryModule
|
|
212
|
-
const session = !userId || !sessionId ? void 0 : await sessionMemory
|
|
213
|
+
const sessionMemory = _optionalChain([this, 'access', _15 => _15.memoryModule, 'optionalAccess', _16 => _16.getSessionMemory, 'call', _17 => _17()]);
|
|
214
|
+
const session = !userId || !sessionId ? void 0 : await _optionalChain([sessionMemory, 'optionalAccess', _18 => _18.getSession, 'call', _19 => _19(userId, sessionId)]);
|
|
213
215
|
try {
|
|
214
216
|
if (!sessionId) {
|
|
215
|
-
sessionId = randomUUID();
|
|
217
|
+
sessionId = _crypto.randomUUID.call(void 0, );
|
|
216
218
|
const title = await this.generateTitle(query);
|
|
217
|
-
const metadata = await sessionMemory
|
|
219
|
+
const metadata = await _optionalChain([sessionMemory, 'optionalAccess', _20 => _20.createSession, 'call', _21 => _21(userId, sessionId, title)]) || {
|
|
218
220
|
sessionId,
|
|
219
221
|
title,
|
|
220
222
|
updatedAt: Date.now()
|
|
221
223
|
};
|
|
222
|
-
loggers.intentStream.info("Create new session", { metadata });
|
|
224
|
+
_chunk466ED5WNcjs.loggers.intentStream.info("Create new session", { metadata });
|
|
223
225
|
res.write(`event: session_id
|
|
224
226
|
data: ${JSON.stringify(metadata)}
|
|
225
227
|
|
|
@@ -234,7 +236,7 @@ data: ${JSON.stringify(metadata)}
|
|
|
234
236
|
let finalResponseText = "";
|
|
235
237
|
for await (const event of stream) {
|
|
236
238
|
if (event.event === "text_chunk" && event.data.delta) {
|
|
237
|
-
loggers.intentStream.debug("text_chunk", { event });
|
|
239
|
+
_chunk466ED5WNcjs.loggers.intentStream.debug("text_chunk", { event });
|
|
238
240
|
finalResponseText += event.data.delta;
|
|
239
241
|
}
|
|
240
242
|
const sseFormattedEvent = `event: ${event.event}
|
|
@@ -244,19 +246,19 @@ data: ${JSON.stringify(event.data)}
|
|
|
244
246
|
res.write(sseFormattedEvent);
|
|
245
247
|
}
|
|
246
248
|
if (userId) {
|
|
247
|
-
await sessionMemory
|
|
249
|
+
await _optionalChain([sessionMemory, 'optionalAccess', _22 => _22.addChatToSession, 'call', _23 => _23(userId, sessionId, {
|
|
248
250
|
role: "USER" /* USER */,
|
|
249
251
|
timestamp: queryStartAt,
|
|
250
252
|
content: { type: "text", parts: [query] }
|
|
251
|
-
});
|
|
252
|
-
await sessionMemory
|
|
253
|
+
})]);
|
|
254
|
+
await _optionalChain([sessionMemory, 'optionalAccess', _24 => _24.addChatToSession, 'call', _25 => _25(userId, sessionId, {
|
|
253
255
|
role: "MODEL" /* MODEL */,
|
|
254
256
|
timestamp: Date.now(),
|
|
255
257
|
content: { type: "text", parts: [finalResponseText] }
|
|
256
|
-
});
|
|
258
|
+
})]);
|
|
257
259
|
}
|
|
258
260
|
} catch (error) {
|
|
259
|
-
loggers.intent.error("Error in handleQuery", { error });
|
|
261
|
+
_chunk466ED5WNcjs.loggers.intent.error("Error in handleQuery", { error });
|
|
260
262
|
res.write(
|
|
261
263
|
`event: error
|
|
262
264
|
data: ${JSON.stringify({ message: "Stream failed" })}
|
|
@@ -269,7 +271,7 @@ data: ${JSON.stringify({ message: "Stream failed" })}
|
|
|
269
271
|
}
|
|
270
272
|
};
|
|
271
273
|
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
//# sourceMappingURL=chunk-
|
|
274
|
+
|
|
275
|
+
|
|
276
|
+
exports.QueryStreamService = QueryStreamService;
|
|
277
|
+
//# sourceMappingURL=chunk-MSFAMZFU.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-MSFAMZFU.cjs","../../src/services/query-stream.service.ts"],"names":["toolArgs"],"mappings":"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","file":"/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-MSFAMZFU.cjs","sourcesContent":[null,"import { randomUUID } from \"node:crypto\";\nimport type { Response } from \"express\";\nimport type {\n\tA2AModule,\n\tMCPModule,\n\tMemoryModule,\n\tModelModule,\n} from \"@/modules/index.js\";\nimport type { AinAgentPrompts } from \"@/types/agent.js\";\nimport {\n\tChatRole,\n\ttype SessionMetadata,\n\ttype SessionObject,\n} from \"@/types/memory.js\";\nimport type { StreamEvent } from \"@/types/stream\";\nimport {\n\ttype IA2ATool,\n\ttype IAgentTool,\n\ttype IMCPTool,\n\tTOOL_PROTOCOL_TYPE,\n} from \"@/types/tool.js\";\nimport { loggers } from \"@/utils/logger.js\";\n\n/**\n * Service for processing user queries through the agent's AI pipeline.\n *\n * Orchestrates the query processing workflow including intent detection,\n * model inference, tool execution, and response generation. Manages\n * conversation context and coordinates between different modules.\n */\nexport class QueryStreamService {\n\tprivate modelModule: ModelModule;\n\tprivate a2aModule?: A2AModule;\n\tprivate mcpModule?: MCPModule;\n\tprivate memoryModule?: MemoryModule;\n\tprivate prompts?: AinAgentPrompts;\n\n\tconstructor(\n\t\tmodelModule: ModelModule,\n\t\ta2aModule?: A2AModule,\n\t\tmcpModule?: MCPModule,\n\t\tmemoryModule?: MemoryModule,\n\t\tprompts?: AinAgentPrompts,\n\t) {\n\t\tthis.modelModule = modelModule;\n\t\tthis.a2aModule = a2aModule;\n\t\tthis.mcpModule = mcpModule;\n\t\tthis.memoryModule = memoryModule;\n\t\tthis.prompts = prompts;\n\t}\n\n\t/**\n\t * Detects the intent from a user query.\n\t *\n\t * @param query - The user's input query\n\t * @returns The detected intent (currently returns the query as-is)\n\t * @todo Implement actual intent detection logic\n\t */\n\tprivate async intentTriggering(query: string) {\n\t\t/* TODO */\n\t\treturn query;\n\t}\n\n\t/**\n\t * Fulfills the detected intent by generating a 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 *\n\t * @param query - The user's input query\n\t * @param sessionId - Session identifier for context\n\t * @param sessionHistory - Previous conversation history\n\t * @returns Object containing process steps and final response\n\t */\n\tpublic async *intentFulfilling(\n\t\tquery: string,\n\t\tsessionId: string,\n\t\tsessionHistory?: SessionObject,\n\t): AsyncGenerator<StreamEvent> {\n\t\ttry {\n\t\t\tconst systemPrompt = `\nToday is ${new Date().toLocaleDateString()}.\n\n${this.prompts?.agent || \"\"}\n\n${this.prompts?.system || \"\"}\n `;\n\n\t\t\tconst modelInstance = this.modelModule.getModel();\n\t\t\tconst messages = modelInstance.generateMessages({\n\t\t\t\tquery,\n\t\t\t\tsessionHistory,\n\t\t\t\tsystemPrompt: systemPrompt.trim(),\n\t\t\t});\n\n\t\t\tconst tools: IAgentTool[] = [];\n\t\t\tif (this.mcpModule) {\n\t\t\t\ttools.push(...this.mcpModule.getTools());\n\t\t\t}\n\t\t\tif (this.a2aModule) {\n\t\t\t\ttools.push(...(await this.a2aModule.getTools()));\n\t\t\t}\n\t\t\tconsole.log(tools);\n\t\t\tconst functions = modelInstance.convertToolsToFunctions(tools);\n\t\t\tconsole.log(functions);\n\n\t\t\tconst processList: string[] = [];\n\t\t\tlet didCallTool = false;\n\n\t\t\twhile (true) {\n\t\t\t\tconst responseStream =\n\t\t\t\t\tawait modelInstance.fetchStreamWithContextMessage(\n\t\t\t\t\t\tmessages,\n\t\t\t\t\t\tfunctions,\n\t\t\t\t\t);\n\t\t\t\tdidCallTool = false;\n\n\t\t\t\tconst assembledToolCalls: {\n\t\t\t\t\tid: string;\n\t\t\t\t\ttype: \"function\";\n\t\t\t\t\tfunction: { name: string; arguments: string };\n\t\t\t\t}[] = [];\n\n\t\t\t\tloggers.intentStream.debug(\"messages\", { messages });\n\n\t\t\t\tfor await (const chunk of responseStream) {\n\t\t\t\t\tconst delta = chunk.delta;\n\t\t\t\t\tif (delta?.tool_calls) {\n\t\t\t\t\t\tdidCallTool = true;\n\t\t\t\t\t\tfor (const toolCallDelta of delta.tool_calls) {\n\t\t\t\t\t\t\tconst index = toolCallDelta.index;\n\n\t\t\t\t\t\t\tif (!assembledToolCalls[index]) {\n\t\t\t\t\t\t\t\tassembledToolCalls[index] = {\n\t\t\t\t\t\t\t\t\tid: \"\",\n\t\t\t\t\t\t\t\t\ttype: \"function\",\n\t\t\t\t\t\t\t\t\tfunction: { name: \"\", arguments: \"\" },\n\t\t\t\t\t\t\t\t};\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tif (toolCallDelta.id) {\n\t\t\t\t\t\t\t\tassembledToolCalls[index].id = toolCallDelta.id;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tif (toolCallDelta.function?.name) {\n\t\t\t\t\t\t\t\tassembledToolCalls[index].function.name =\n\t\t\t\t\t\t\t\t\ttoolCallDelta.function.name;\n\t\t\t\t\t\t\t}\n\n\t\t\t\t\t\t\tif (toolCallDelta.function?.arguments) {\n\t\t\t\t\t\t\t\tassembledToolCalls[index].function.arguments +=\n\t\t\t\t\t\t\t\t\ttoolCallDelta.function.arguments;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t} else if (chunk.delta?.content) {\n\t\t\t\t\t\tyield {\n\t\t\t\t\t\t\tevent: \"text_chunk\",\n\t\t\t\t\t\t\tdata: { delta: chunk.delta.content },\n\t\t\t\t\t\t};\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tloggers.intentStream.debug(\"assembledToolCalls\", {\n\t\t\t\t\tassembledToolCalls,\n\t\t\t\t});\n\n\t\t\t\tif (didCallTool && assembledToolCalls.length > 0) {\n\t\t\t\t\tconst messagePayload = this.a2aModule?.getMessagePayload(\n\t\t\t\t\t\tquery,\n\t\t\t\t\t\tsessionId,\n\t\t\t\t\t);\n\t\t\t\t\tfor (const toolCall of assembledToolCalls) {\n\t\t\t\t\t\tconst toolName = toolCall.function.name;\n\t\t\t\t\t\tconst toolArgs = JSON.parse(toolCall.function.arguments);\n\t\t\t\t\t\tconst selectedTool = tools.filter(\n\t\t\t\t\t\t\t(tool) => tool.id === toolName,\n\t\t\t\t\t\t)[0];\n\n\t\t\t\t\t\tyield { event: \"tool_start\", data: { toolName, toolArgs } };\n\n\t\t\t\t\t\tlet toolResult = \"\";\n\n\t\t\t\t\t\tif (\n\t\t\t\t\t\t\tthis.mcpModule &&\n\t\t\t\t\t\t\tselectedTool.protocol === TOOL_PROTOCOL_TYPE.MCP\n\t\t\t\t\t\t) {\n\t\t\t\t\t\t\tconst toolArgs = JSON.parse(toolCall.function.arguments) as\n\t\t\t\t\t\t\t\t| { [x: string]: unknown }\n\t\t\t\t\t\t\t\t| undefined;\n\t\t\t\t\t\t\tloggers.intent.debug(\"MCP tool call\", { toolName, toolArgs });\n\t\t\t\t\t\t\ttoolResult = await this.mcpModule.useTool(\n\t\t\t\t\t\t\t\tselectedTool as IMCPTool,\n\t\t\t\t\t\t\t\ttoolArgs,\n\t\t\t\t\t\t\t);\n\t\t\t\t\t\t} else if (\n\t\t\t\t\t\t\tthis.a2aModule &&\n\t\t\t\t\t\t\tselectedTool.protocol === TOOL_PROTOCOL_TYPE.A2A\n\t\t\t\t\t\t) {\n\t\t\t\t\t\t\ttoolResult = await this.a2aModule.useTool(\n\t\t\t\t\t\t\t\tselectedTool as IA2ATool,\n\t\t\t\t\t\t\t\tmessagePayload!,\n\t\t\t\t\t\t\t\tsessionId,\n\t\t\t\t\t\t\t);\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t// Unrecognized tool type. It cannot be happened...\n\t\t\t\t\t\t\tloggers.intent.warn(\n\t\t\t\t\t\t\t\t`Unrecognized tool type: ${selectedTool.protocol}`,\n\t\t\t\t\t\t\t);\n\t\t\t\t\t\t\tcontinue;\n\t\t\t\t\t\t}\n\t\t\t\t\t\tyield {\n\t\t\t\t\t\t\tevent: \"tool_output\",\n\t\t\t\t\t\t\tdata: { toolName, result: toolResult },\n\t\t\t\t\t\t};\n\t\t\t\t\t\tloggers.intent.debug(\"toolResult\", { toolResult });\n\n\t\t\t\t\t\tprocessList.push(toolResult);\n\t\t\t\t\t\tmodelInstance.appendMessages(messages, toolResult);\n\t\t\t\t\t}\n\t\t\t\t}\n\n\t\t\t\tif (!didCallTool) break;\n\t\t\t}\n\t\t} catch (error) {\n\t\t\tloggers.intent.error(\"Error in intentFulfilling generator\", { error });\n\t\t\tif (error instanceof Error) {\n\t\t\t\tyield {\n\t\t\t\t\tevent: \"error\",\n\t\t\t\t\tdata: { message: error.message || \"An unknown error occurred.\" },\n\t\t\t\t};\n\t\t\t} else {\n\t\t\t\tyield {\n\t\t\t\t\tevent: \"error\",\n\t\t\t\t\tdata: { message: \"An unknown error occurred.\" },\n\t\t\t\t};\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t * Generates a title for the conversation based on the query.\n\t *\n\t * @param query - The user's input query\n\t * @returns Promise resolving to a generated title\n\t */\n\n\tprivate async generateTitle(query: string): Promise<string> {\n\t\tconst DEFAULT_TITLE = \"New Chat\";\n\t\ttry {\n\t\t\tconst modelInstance = this.modelModule.getModel();\n\t\t\tconst messages = modelInstance.generateMessages({\n\t\t\t\tquery,\n\t\t\t\tsystemPrompt: `You are a helpful assistant that generates titles for conversations.\n Please analyze the user's query and create a concise title that accurately reflects the conversation's core topic.\n The title must be no more than 5 words long.\n Respond with only the title. Do not include any punctuation or extra explanations.`,\n\t\t\t});\n\t\t\tconst response = await modelInstance.fetch(messages);\n\t\t\treturn response.content || DEFAULT_TITLE;\n\t\t} catch (error) {\n\t\t\tloggers.intentStream.error(\"Error generating title\", {\n\t\t\t\terror,\n\t\t\t\tquery,\n\t\t\t});\n\t\t\treturn DEFAULT_TITLE;\n\t\t}\n\t}\n\n\t/**\n\t * Main entry point for processing user queries.\n\t *\n\t * Handles the complete query lifecycle:\n\t * 1. Loads session history from memory\n\t * 2. Detects intent from the query\n\t * 3. Fulfills the intent with AI response\n\t * 4. Updates conversation history\n\t *\n\t * @param query - The user's input query\n\t * @param sessionId - Unique session identifier\n\t * @returns Object containing the AI-generated response\n\t */\n\tpublic async handleQueryStream(\n\t\tquery: string,\n\t\tuserId: string,\n\t\tres: Response,\n\t\t_sessionId?: string,\n\t) {\n\t\t// 1. Load session history with sessionId\n\t\tlet sessionId = _sessionId;\n\t\tconst queryStartAt = Date.now();\n\t\tconst sessionMemory = this.memoryModule?.getSessionMemory();\n\t\tconst session =\n\t\t\t!userId || !sessionId\n\t\t\t\t? undefined\n\t\t\t\t: await sessionMemory?.getSession(userId, sessionId);\n\n\t\ttry {\n\t\t\tif (!sessionId) {\n\t\t\t\tsessionId = randomUUID();\n\t\t\t\tconst title = await this.generateTitle(query);\n\n\t\t\t\tconst metadata =\n\t\t\t\t\t(await sessionMemory?.createSession(userId, sessionId, title)) ||\n\t\t\t\t\t({\n\t\t\t\t\t\tsessionId,\n\t\t\t\t\t\ttitle,\n\t\t\t\t\t\tupdatedAt: Date.now(),\n\t\t\t\t\t} as SessionMetadata);\n\t\t\t\tloggers.intentStream.info(\"Create new session\", { metadata });\n\t\t\t\tres.write(`event: session_id\\ndata: ${JSON.stringify(metadata)}\\n\\n`);\n\t\t\t}\n\t\t} catch (error) {\n\t\t\tthrow new Error(\"Failed to create new session\");\n\t\t}\n\n\t\t// 2. intent triggering\n\t\tconst intent = this.intentTriggering(query);\n\n\t\ttry {\n\t\t\t// 3. intent fulfillment\n\t\t\tconst stream = await this.intentFulfilling(query, sessionId, session);\n\n\t\t\tlet finalResponseText = \"\";\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\tloggers.intentStream.debug(\"text_chunk\", { event });\n\t\t\t\t\tfinalResponseText += event.data.delta;\n\t\t\t\t}\n\n\t\t\t\tconst sseFormattedEvent = `event: ${event.event}\\ndata: ${JSON.stringify(event.data)}\\n\\n`;\n\t\t\t\tres.write(sseFormattedEvent);\n\t\t\t}\n\n\t\t\tif (userId) {\n\t\t\t\tawait sessionMemory?.addChatToSession(userId, sessionId, {\n\t\t\t\t\trole: ChatRole.USER,\n\t\t\t\t\ttimestamp: queryStartAt,\n\t\t\t\t\tcontent: { type: \"text\", parts: [query] },\n\t\t\t\t});\n\t\t\t\tawait sessionMemory?.addChatToSession(userId, sessionId, {\n\t\t\t\t\trole: ChatRole.MODEL,\n\t\t\t\t\ttimestamp: Date.now(),\n\t\t\t\t\tcontent: { type: \"text\", parts: [finalResponseText] },\n\t\t\t\t});\n\t\t\t}\n\t\t} catch (error) {\n\t\t\tloggers.intent.error(\"Error in handleQuery\", { error });\n\t\t\tres.write(\n\t\t\t\t`event: error\\ndata: ${JSON.stringify({ message: \"Stream failed\" })}\\n\\n`,\n\t\t\t);\n\t\t} finally {\n\t\t\tres.end();\n\t\t}\n\t}\n}\n"]}
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports, "__esModule", {value: true}); var _class;
|
|
2
|
+
|
|
3
|
+
var _chunkDX2JH3FJcjs = require('./chunk-DX2JH3FJ.cjs');
|
|
4
|
+
|
|
5
|
+
// src/controllers/query.controller.ts
|
|
6
|
+
var _httpstatuscodes = require('http-status-codes');
|
|
7
|
+
var QueryController = (_class = class {
|
|
8
|
+
|
|
9
|
+
|
|
10
|
+
constructor(queryService, queryStreamService) {;_class.prototype.__init.call(this);_class.prototype.__init2.call(this);
|
|
11
|
+
this.queryService = queryService;
|
|
12
|
+
this.queryStreamService = queryStreamService;
|
|
13
|
+
}
|
|
14
|
+
__init() {this.handleQueryRequest = async (req, res, next) => {
|
|
15
|
+
const { type, message, threadId } = req.body;
|
|
16
|
+
const userId = res.locals.userId;
|
|
17
|
+
try {
|
|
18
|
+
const result = await this.queryService.handleQuery(
|
|
19
|
+
{ type, userId, threadId },
|
|
20
|
+
message
|
|
21
|
+
);
|
|
22
|
+
res.status(200).json(result);
|
|
23
|
+
} catch (error) {
|
|
24
|
+
next(error);
|
|
25
|
+
}
|
|
26
|
+
}}
|
|
27
|
+
__init2() {this.handleQueryStreamRequest = async (req, res, next) => {
|
|
28
|
+
const { type, threadId, message } = req.body;
|
|
29
|
+
const userId = res.locals.userId;
|
|
30
|
+
console.log(type, threadId, message);
|
|
31
|
+
if (!this.queryStreamService) {
|
|
32
|
+
const error = new (0, _chunkDX2JH3FJcjs.AinHttpError)(
|
|
33
|
+
_httpstatuscodes.StatusCodes.NOT_IMPLEMENTED,
|
|
34
|
+
"Stream query not supported"
|
|
35
|
+
);
|
|
36
|
+
return next(error);
|
|
37
|
+
}
|
|
38
|
+
const stream = this.queryStreamService.handleQueryStream(
|
|
39
|
+
{ type, userId, threadId },
|
|
40
|
+
message
|
|
41
|
+
);
|
|
42
|
+
try {
|
|
43
|
+
for await (const event of stream) {
|
|
44
|
+
console.log("Event:", event);
|
|
45
|
+
res.write(
|
|
46
|
+
`event: ${event.event}
|
|
47
|
+
data: ${JSON.stringify(event.data)}
|
|
48
|
+
|
|
49
|
+
`
|
|
50
|
+
);
|
|
51
|
+
}
|
|
52
|
+
} catch (error) {
|
|
53
|
+
res.write(`event: error
|
|
54
|
+
data: ${JSON.stringify(error)}
|
|
55
|
+
|
|
56
|
+
`);
|
|
57
|
+
} finally {
|
|
58
|
+
res.end();
|
|
59
|
+
}
|
|
60
|
+
}}
|
|
61
|
+
}, _class);
|
|
62
|
+
|
|
63
|
+
|
|
64
|
+
|
|
65
|
+
exports.QueryController = QueryController;
|
|
66
|
+
//# sourceMappingURL=chunk-MVN5XJGZ.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-MVN5XJGZ.cjs","../../src/controllers/query.controller.ts"],"names":[],"mappings":"AAAA;AACE;AACF,wDAA6B;AAC7B;AACA;ACHA,oDAA4B;AAIrB,IAAM,gBAAA,YAAN,MAAsB;AAAA,EACpB;AAAA,EACA;AAAA,EAER,WAAA,CACC,YAAA,EACA,kBAAA,EACC;AACD,IAAA,IAAA,CAAK,aAAA,EAAe,YAAA;AACpB,IAAA,IAAA,CAAK,mBAAA,EAAqB,kBAAA;AAAA,EAC3B;AAAA,iBAEO,mBAAA,EAAqB,MAAA,CAC3B,GAAA,EACA,GAAA,EACA,IAAA,EAAA,GACI;AACJ,IAAA,MAAM,EAAE,IAAA,EAAM,OAAA,EAAS,SAAS,EAAA,EAAI,GAAA,CAAI,IAAA;AACxC,IAAA,MAAM,OAAA,EAAS,GAAA,CAAI,MAAA,CAAO,MAAA;AAE1B,IAAA,IAAI;AACH,MAAA,MAAM,OAAA,EAAS,MAAM,IAAA,CAAK,YAAA,CAAa,WAAA;AAAA,QACtC,EAAE,IAAA,EAAM,MAAA,EAAQ,SAAS,CAAA;AAAA,QACzB;AAAA,MACD,CAAA;AAEA,MAAA,GAAA,CAAI,MAAA,CAAO,GAAG,CAAA,CAAE,IAAA,CAAK,MAAM,CAAA;AAAA,IAC5B,EAAA,MAAA,CAAS,KAAA,EAAO;AACf,MAAA,IAAA,CAAK,KAAK,CAAA;AAAA,IACX;AAAA,EACD,EAAA;AAAA,kBAEO,yBAAA,EAA2B,MAAA,CACjC,GAAA,EACA,GAAA,EACA,IAAA,EAAA,GACI;AACJ,IAAA,MAAM,EAAE,IAAA,EAAM,QAAA,EAAU,QAAQ,EAAA,EAAI,GAAA,CAAI,IAAA;AACxC,IAAA,MAAM,OAAA,EAAS,GAAA,CAAI,MAAA,CAAO,MAAA;AAE1B,IAAA,OAAA,CAAQ,GAAA,CAAI,IAAA,EAAM,QAAA,EAAU,OAAO,CAAA;AAEnC,IAAA,GAAA,CAAI,CAAC,IAAA,CAAK,kBAAA,EAAoB;AAC7B,MAAA,MAAM,MAAA,EAAQ,IAAI,mCAAA;AAAA,QACjB,4BAAA,CAAY,eAAA;AAAA,QACZ;AAAA,MACD,CAAA;AACA,MAAA,OAAO,IAAA,CAAK,KAAK,CAAA;AAAA,IAClB;AAEA,IAAA,MAAM,OAAA,EAAS,IAAA,CAAK,kBAAA,CAAmB,iBAAA;AAAA,MACtC,EAAE,IAAA,EAAM,MAAA,EAAQ,SAAS,CAAA;AAAA,MACzB;AAAA,IACD,CAAA;AAEA,IAAA,IAAI;AACH,MAAA,IAAA,MAAA,CAAA,MAAiB,MAAA,GAAS,MAAA,EAAQ;AACjC,QAAA,OAAA,CAAQ,GAAA,CAAI,QAAA,EAAU,KAAK,CAAA;AAC3B,QAAA,GAAA,CAAI,KAAA;AAAA,UACH,CAAA,OAAA,EAAU,KAAA,CAAM,KAAK,CAAA;AAAA,MAAA,EAAW,IAAA,CAAK,SAAA,CAAU,KAAA,CAAM,IAAI,CAAC,CAAA;AAAA;AAAA;AAAA,QAC3D,CAAA;AAAA,MACD;AAAA,IACD,EAAA,MAAA,CAAS,KAAA,EAAO;AACf,MAAA,GAAA,CAAI,KAAA,CAAM,CAAA;AAAA,MAAA,EAAuB,IAAA,CAAK,SAAA,CAAU,KAAK,CAAC,CAAA;AAAA;AAAA,CAAM,CAAA;AAAA,IAC7D,EAAA,QAAE;AACD,MAAA,GAAA,CAAI,GAAA,CAAI,CAAA;AAAA,IACT;AAAA,EACD,EAAA;AACD,UAAA;ADZA;AACA;AACE;AACF,0CAAC","file":"/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-MVN5XJGZ.cjs","sourcesContent":[null,"import type { NextFunction, Request, Response } from \"express\";\nimport { StatusCodes } from \"http-status-codes\";\nimport type { QueryService, QueryStreamService } from \"@/services\";\nimport { AinHttpError } from \"@/types/agent\";\n\nexport class QueryController {\n\tprivate queryService;\n\tprivate queryStreamService;\n\n\tconstructor(\n\t\tqueryService: QueryService,\n\t\tqueryStreamService?: QueryStreamService,\n\t) {\n\t\tthis.queryService = queryService;\n\t\tthis.queryStreamService = queryStreamService;\n\t}\n\n\tpublic handleQueryRequest = async (\n\t\treq: Request,\n\t\tres: Response,\n\t\tnext: NextFunction,\n\t) => {\n\t\tconst { type, message, threadId } = req.body;\n\t\tconst userId = res.locals.userId;\n\n\t\ttry {\n\t\t\tconst result = await this.queryService.handleQuery(\n\t\t\t\t{ type, userId, threadId },\n\t\t\t\tmessage,\n\t\t\t);\n\n\t\t\tres.status(200).json(result);\n\t\t} catch (error) {\n\t\t\tnext(error);\n\t\t}\n\t};\n\n\tpublic handleQueryStreamRequest = async (\n\t\treq: Request,\n\t\tres: Response,\n\t\tnext: NextFunction,\n\t) => {\n\t\tconst { type, threadId, message } = req.body;\n\t\tconst userId = res.locals.userId;\n\n\t\tconsole.log(type, threadId, message);\n\n\t\tif (!this.queryStreamService) {\n\t\t\tconst error = new AinHttpError(\n\t\t\t\tStatusCodes.NOT_IMPLEMENTED,\n\t\t\t\t\"Stream query not supported\",\n\t\t\t);\n\t\t\treturn next(error);\n\t\t}\n\n\t\tconst stream = this.queryStreamService.handleQueryStream(\n\t\t\t{ type, userId, threadId },\n\t\t\tmessage,\n\t\t);\n\n\t\ttry {\n\t\t\tfor await (const event of stream) {\n\t\t\t\tconsole.log(\"Event:\", event);\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) {\n\t\t\tres.write(`event: error\\ndata: ${JSON.stringify(error)}\\n\\n`);\n\t\t} finally {\n\t\t\tres.end();\n\t\t}\n\t};\n}\n"]}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports, "__esModule", {value: true}); var _class;// src/controllers/query.controller.ts
|
|
2
|
+
var QueryController = (_class = class {
|
|
3
|
+
|
|
4
|
+
|
|
5
|
+
constructor(queryService, queryStreamService) {;_class.prototype.__init.call(this);_class.prototype.__init2.call(this);
|
|
6
|
+
this.queryService = queryService;
|
|
7
|
+
this.queryStreamService = queryStreamService;
|
|
8
|
+
}
|
|
9
|
+
__init() {this.handleQueryRequest = async (req, res, next) => {
|
|
10
|
+
const { message, threadId } = req.body;
|
|
11
|
+
const userId = res.locals.userId;
|
|
12
|
+
try {
|
|
13
|
+
const result = await this.queryService.handleQuery(
|
|
14
|
+
message,
|
|
15
|
+
threadId,
|
|
16
|
+
userId
|
|
17
|
+
);
|
|
18
|
+
res.status(200).json(result);
|
|
19
|
+
} catch (error) {
|
|
20
|
+
next(error);
|
|
21
|
+
}
|
|
22
|
+
}}
|
|
23
|
+
__init2() {this.handleQueryStreamRequest = async (req, res, next) => {
|
|
24
|
+
const { message, threadId } = req.body;
|
|
25
|
+
const userId = res.locals.userId;
|
|
26
|
+
if (!this.queryStreamService) {
|
|
27
|
+
throw new Error("This Agent does not support stream query");
|
|
28
|
+
}
|
|
29
|
+
try {
|
|
30
|
+
await this.queryStreamService.handleQueryStream(
|
|
31
|
+
message,
|
|
32
|
+
userId,
|
|
33
|
+
res,
|
|
34
|
+
threadId
|
|
35
|
+
);
|
|
36
|
+
} catch (error) {
|
|
37
|
+
next(error);
|
|
38
|
+
}
|
|
39
|
+
}}
|
|
40
|
+
}, _class);
|
|
41
|
+
|
|
42
|
+
|
|
43
|
+
|
|
44
|
+
exports.QueryController = QueryController;
|
|
45
|
+
//# sourceMappingURL=chunk-O6XQRAWR.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-O6XQRAWR.cjs","../../src/controllers/query.controller.ts"],"names":[],"mappings":"AAAA;ACGO,IAAM,gBAAA,YAAN,MAAsB;AAAA,EACpB;AAAA,EACA;AAAA,EAER,WAAA,CACC,YAAA,EACA,kBAAA,EACC;AACD,IAAA,IAAA,CAAK,aAAA,EAAe,YAAA;AACpB,IAAA,IAAA,CAAK,mBAAA,EAAqB,kBAAA;AAAA,EAC3B;AAAA,iBAEO,mBAAA,EAAqB,MAAA,CAC3B,GAAA,EACA,GAAA,EACA,IAAA,EAAA,GACI;AACJ,IAAA,MAAM,EAAE,OAAA,EAAS,SAAS,EAAA,EAAI,GAAA,CAAI,IAAA;AAClC,IAAA,MAAM,OAAA,EAAS,GAAA,CAAI,MAAA,CAAO,MAAA;AAE1B,IAAA,IAAI;AACH,MAAA,MAAM,OAAA,EAAS,MAAM,IAAA,CAAK,YAAA,CAAa,WAAA;AAAA,QACtC,OAAA;AAAA,QACA,QAAA;AAAA,QACA;AAAA,MACD,CAAA;AAEA,MAAA,GAAA,CAAI,MAAA,CAAO,GAAG,CAAA,CAAE,IAAA,CAAK,MAAM,CAAA;AAAA,IAC5B,EAAA,MAAA,CAAS,KAAA,EAAO;AACf,MAAA,IAAA,CAAK,KAAK,CAAA;AAAA,IACX;AAAA,EACD,EAAA;AAAA,kBAEO,yBAAA,EAA2B,MAAA,CACjC,GAAA,EACA,GAAA,EACA,IAAA,EAAA,GACI;AACJ,IAAA,MAAM,EAAE,OAAA,EAAS,SAAS,EAAA,EAAI,GAAA,CAAI,IAAA;AAClC,IAAA,MAAM,OAAA,EAAS,GAAA,CAAI,MAAA,CAAO,MAAA;AAE1B,IAAA,GAAA,CAAI,CAAC,IAAA,CAAK,kBAAA,EAAoB;AAC7B,MAAA,MAAM,IAAI,KAAA,CAAM,0CAA0C,CAAA;AAAA,IAC3D;AAEA,IAAA,IAAI;AACH,MAAA,MAAM,IAAA,CAAK,kBAAA,CAAmB,iBAAA;AAAA,QAC7B,OAAA;AAAA,QACA,MAAA;AAAA,QACA,GAAA;AAAA,QACA;AAAA,MACD,CAAA;AAAA,IACD,EAAA,MAAA,CAAS,KAAA,EAAO;AACf,MAAA,IAAA,CAAK,KAAK,CAAA;AAAA,IACX;AAAA,EACD,EAAA;AACD,UAAA;ADnBA;AACA;AACE;AACF,0CAAC","file":"/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-O6XQRAWR.cjs","sourcesContent":[null,"import type { NextFunction, Request, Response } from \"express\";\nimport type { QueryService, QueryStreamService } from \"@/services\";\n\nexport class QueryController {\n\tprivate queryService;\n\tprivate queryStreamService;\n\n\tconstructor(\n\t\tqueryService: QueryService,\n\t\tqueryStreamService?: QueryStreamService,\n\t) {\n\t\tthis.queryService = queryService;\n\t\tthis.queryStreamService = queryStreamService;\n\t}\n\n\tpublic handleQueryRequest = async (\n\t\treq: Request,\n\t\tres: Response,\n\t\tnext: NextFunction,\n\t) => {\n\t\tconst { message, threadId } = req.body;\n\t\tconst userId = res.locals.userId;\n\n\t\ttry {\n\t\t\tconst result = await this.queryService.handleQuery(\n\t\t\t\tmessage,\n\t\t\t\tthreadId,\n\t\t\t\tuserId,\n\t\t\t);\n\n\t\t\tres.status(200).json(result);\n\t\t} catch (error) {\n\t\t\tnext(error);\n\t\t}\n\t};\n\n\tpublic handleQueryStreamRequest = async (\n\t\treq: Request,\n\t\tres: Response,\n\t\tnext: NextFunction,\n\t) => {\n\t\tconst { message, threadId } = req.body;\n\t\tconst userId = res.locals.userId;\n\n\t\tif (!this.queryStreamService) {\n\t\t\tthrow new Error(\"This Agent does not support stream query\");\n\t\t}\n\n\t\ttry {\n\t\t\tawait this.queryStreamService.handleQueryStream(\n\t\t\t\tmessage,\n\t\t\t\tuserId,\n\t\t\t\tres,\n\t\t\t\tthreadId,\n\t\t\t);\n\t\t} catch (error) {\n\t\t\tnext(error);\n\t\t}\n\t};\n}\n"]}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports, "__esModule", {value: true});
|
|
2
|
+
|
|
3
|
+
var _chunk55IME4BGcjs = require('./chunk-55IME4BG.cjs');
|
|
4
|
+
|
|
5
|
+
|
|
6
|
+
var _chunk7EGJAURFcjs = require('./chunk-7EGJAURF.cjs');
|
|
7
|
+
|
|
8
|
+
|
|
9
|
+
var _chunkICFTUZP5cjs = require('./chunk-ICFTUZP5.cjs');
|
|
10
|
+
|
|
11
|
+
// src/routes/a2a.routes.ts
|
|
12
|
+
var _server = require('@a2a-js/sdk/server');
|
|
13
|
+
var _express = require('express');
|
|
14
|
+
var createA2ARouter = (agent) => {
|
|
15
|
+
const router = _express.Router.call(void 0, );
|
|
16
|
+
const taskStore = new (0, _server.InMemoryTaskStore)();
|
|
17
|
+
const queryService = new (0, _chunk7EGJAURFcjs.QueryService)(
|
|
18
|
+
agent.modelModule,
|
|
19
|
+
agent.a2aModule,
|
|
20
|
+
agent.mcpModule,
|
|
21
|
+
agent.memoryModule,
|
|
22
|
+
agent.manifest.prompts
|
|
23
|
+
);
|
|
24
|
+
const a2aService = new (0, _chunk55IME4BGcjs.A2AService)(queryService);
|
|
25
|
+
const a2aController = new (0, _chunkICFTUZP5cjs.A2AController)(
|
|
26
|
+
a2aService,
|
|
27
|
+
taskStore,
|
|
28
|
+
agent.generateAgentCard
|
|
29
|
+
);
|
|
30
|
+
router.post("/", a2aController.handleA2ARequest);
|
|
31
|
+
return router;
|
|
32
|
+
};
|
|
33
|
+
|
|
34
|
+
|
|
35
|
+
|
|
36
|
+
exports.createA2ARouter = createA2ARouter;
|
|
37
|
+
//# sourceMappingURL=chunk-PDF6B6A3.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-PDF6B6A3.cjs","../../src/routes/a2a.routes.ts"],"names":[],"mappings":"AAAA;AACE;AACF,wDAA6B;AAC7B;AACE;AACF,wDAA6B;AAC7B;AACE;AACF,wDAA6B;AAC7B;AACA;ACVA,4CAAkC;AAClC,kCAAuB;AAchB,IAAM,gBAAA,EAAkB,CAAC,KAAA,EAAA,GAA4B;AAC3D,EAAA,MAAM,OAAA,EAAS,6BAAA,CAAO;AAGtB,EAAA,MAAM,UAAA,EAAY,IAAI,8BAAA,CAAkB,CAAA;AACxC,EAAA,MAAM,aAAA,EAAe,IAAI,mCAAA;AAAA,IACxB,KAAA,CAAM,WAAA;AAAA,IACN,KAAA,CAAM,SAAA;AAAA,IACN,KAAA,CAAM,SAAA;AAAA,IACN,KAAA,CAAM,YAAA;AAAA,IACN,KAAA,CAAM,QAAA,CAAS;AAAA,EAChB,CAAA;AACA,EAAA,MAAM,WAAA,EAAa,IAAI,iCAAA,CAAW,YAAY,CAAA;AAC9C,EAAA,MAAM,cAAA,EAAgB,IAAI,oCAAA;AAAA,IACzB,UAAA;AAAA,IACA,SAAA;AAAA,IACA,KAAA,CAAM;AAAA,EACP,CAAA;AAGA,EAAA,MAAA,CAAO,IAAA,CAAK,GAAA,EAAK,aAAA,CAAc,gBAAgB,CAAA;AAE/C,EAAA,OAAO,MAAA;AACR,CAAA;ADNA;AACA;AACE;AACF,0CAAC","file":"/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-PDF6B6A3.cjs","sourcesContent":[null,"import { InMemoryTaskStore } from \"@a2a-js/sdk/server\";\nimport { Router } from \"express\";\nimport type { AINAgent } from \"@/index.js\";\nimport { QueryService } from \"@/services/query.service.js\";\nimport { A2AController } from \"../controllers/a2a.controller.js\";\nimport { A2AService } from \"../services/a2a.service.js\";\n\n/**\n * Creates and configures the A2A router.\n * This function is a \"composition root\" for the A2A feature,\n * creating and injecting all necessary dependencies.\n * @param intentAnalyzer The core intent analyzer.\n * @param agentCard The agent's card.\n * @returns An Express Router instance.\n */\nexport const createA2ARouter = (agent: AINAgent): Router => {\n\tconst router = Router();\n\n\t// 1. Create dependencies for the A2A feature\n\tconst taskStore = new InMemoryTaskStore();\n\tconst queryService = new QueryService(\n\t\tagent.modelModule,\n\t\tagent.a2aModule,\n\t\tagent.mcpModule,\n\t\tagent.memoryModule,\n\t\tagent.manifest.prompts,\n\t);\n\tconst a2aService = new A2AService(queryService);\n\tconst a2aController = new A2AController(\n\t\ta2aService,\n\t\ttaskStore,\n\t\tagent.generateAgentCard,\n\t);\n\n\t// 2. Define the route\n\trouter.post(\"/\", a2aController.handleA2ARequest);\n\n\treturn router;\n};\n"]}
|
|
@@ -0,0 +1,162 @@
|
|
|
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 _chunk466ED5WNcjs = require('./chunk-466ED5WN.cjs');
|
|
4
|
+
|
|
5
|
+
// src/services/query.service.ts
|
|
6
|
+
var QueryService = class {
|
|
7
|
+
|
|
8
|
+
|
|
9
|
+
|
|
10
|
+
|
|
11
|
+
|
|
12
|
+
constructor(modelModule, a2aModule, mcpModule, memoryModule, prompts) {
|
|
13
|
+
this.modelModule = modelModule;
|
|
14
|
+
this.a2aModule = a2aModule;
|
|
15
|
+
this.mcpModule = mcpModule;
|
|
16
|
+
this.memoryModule = memoryModule;
|
|
17
|
+
this.prompts = prompts;
|
|
18
|
+
}
|
|
19
|
+
/**
|
|
20
|
+
* Detects the intent from a user query.
|
|
21
|
+
*
|
|
22
|
+
* @param query - The user's input query
|
|
23
|
+
* @returns The detected intent (currently returns the query as-is)
|
|
24
|
+
* @todo Implement actual intent detection logic
|
|
25
|
+
*/
|
|
26
|
+
async intentTriggering(query) {
|
|
27
|
+
return query;
|
|
28
|
+
}
|
|
29
|
+
/**
|
|
30
|
+
* Fulfills the detected intent by generating a response.
|
|
31
|
+
*
|
|
32
|
+
* Manages the complete inference loop including:
|
|
33
|
+
* - Loading prompts and conversation history
|
|
34
|
+
* - Collecting available tools from modules
|
|
35
|
+
* - Executing model inference with tool support
|
|
36
|
+
* - Processing tool calls iteratively until completion
|
|
37
|
+
*
|
|
38
|
+
* @param query - The user's input query
|
|
39
|
+
* @param threadId - Thread identifier for context
|
|
40
|
+
* @param thread - Previous conversation history
|
|
41
|
+
* @returns Object containing process steps and final response
|
|
42
|
+
*/
|
|
43
|
+
async intentFulfilling(query, threadId, thread) {
|
|
44
|
+
const systemPrompt = `
|
|
45
|
+
Today is ${(/* @__PURE__ */ new Date()).toLocaleDateString()}.
|
|
46
|
+
|
|
47
|
+
${_optionalChain([this, 'access', _ => _.prompts, 'optionalAccess', _2 => _2.agent]) || ""}
|
|
48
|
+
|
|
49
|
+
${_optionalChain([this, 'access', _3 => _3.prompts, 'optionalAccess', _4 => _4.system]) || ""}
|
|
50
|
+
`;
|
|
51
|
+
const modelInstance = this.modelModule.getModel();
|
|
52
|
+
const messages = modelInstance.generateMessages({
|
|
53
|
+
query,
|
|
54
|
+
thread,
|
|
55
|
+
systemPrompt: systemPrompt.trim()
|
|
56
|
+
});
|
|
57
|
+
const tools = [];
|
|
58
|
+
if (this.mcpModule) {
|
|
59
|
+
tools.push(...this.mcpModule.getTools());
|
|
60
|
+
}
|
|
61
|
+
if (this.a2aModule) {
|
|
62
|
+
tools.push(...await this.a2aModule.getTools());
|
|
63
|
+
}
|
|
64
|
+
const functions = modelInstance.convertToolsToFunctions(tools);
|
|
65
|
+
const processList = [];
|
|
66
|
+
let finalMessage = "";
|
|
67
|
+
let didCallTool = false;
|
|
68
|
+
while (true) {
|
|
69
|
+
const response = await modelInstance.fetchWithContextMessage(
|
|
70
|
+
messages,
|
|
71
|
+
functions
|
|
72
|
+
);
|
|
73
|
+
didCallTool = false;
|
|
74
|
+
_chunk466ED5WNcjs.loggers.intent.debug("messages", { messages });
|
|
75
|
+
const { content, toolCalls } = response;
|
|
76
|
+
_chunk466ED5WNcjs.loggers.intent.debug("content", { content });
|
|
77
|
+
_chunk466ED5WNcjs.loggers.intent.debug("tool_calls", { ...toolCalls });
|
|
78
|
+
if (toolCalls) {
|
|
79
|
+
const messagePayload = _optionalChain([this, 'access', _5 => _5.a2aModule, 'optionalAccess', _6 => _6.getMessagePayload, 'call', _7 => _7(
|
|
80
|
+
query,
|
|
81
|
+
threadId
|
|
82
|
+
)]);
|
|
83
|
+
for (const toolCall of toolCalls) {
|
|
84
|
+
const toolName = toolCall.name;
|
|
85
|
+
didCallTool = true;
|
|
86
|
+
const selectedTool = tools.filter((tool) => tool.id === toolName)[0];
|
|
87
|
+
let toolResult = "";
|
|
88
|
+
if (this.mcpModule && selectedTool.protocol === "MCP" /* MCP */) {
|
|
89
|
+
const toolArgs = toolCall.arguments;
|
|
90
|
+
_chunk466ED5WNcjs.loggers.intent.debug("MCP tool call", { toolName, toolArgs });
|
|
91
|
+
toolResult = await this.mcpModule.useTool(
|
|
92
|
+
selectedTool,
|
|
93
|
+
toolArgs
|
|
94
|
+
);
|
|
95
|
+
} else if (this.a2aModule && selectedTool.protocol === "A2A" /* A2A */) {
|
|
96
|
+
toolResult = await this.a2aModule.useTool(
|
|
97
|
+
selectedTool,
|
|
98
|
+
messagePayload,
|
|
99
|
+
threadId
|
|
100
|
+
);
|
|
101
|
+
} else {
|
|
102
|
+
_chunk466ED5WNcjs.loggers.intent.warn(
|
|
103
|
+
`Unrecognized tool type: ${selectedTool.protocol}`
|
|
104
|
+
);
|
|
105
|
+
continue;
|
|
106
|
+
}
|
|
107
|
+
_chunk466ED5WNcjs.loggers.intent.debug("toolResult", { toolResult });
|
|
108
|
+
processList.push(toolResult);
|
|
109
|
+
modelInstance.appendMessages(messages, toolResult);
|
|
110
|
+
}
|
|
111
|
+
} else if (content) {
|
|
112
|
+
processList.push(content);
|
|
113
|
+
finalMessage = content;
|
|
114
|
+
}
|
|
115
|
+
if (!didCallTool) break;
|
|
116
|
+
}
|
|
117
|
+
const botResponse = {
|
|
118
|
+
process: processList.join("\n"),
|
|
119
|
+
response: finalMessage
|
|
120
|
+
};
|
|
121
|
+
return botResponse;
|
|
122
|
+
}
|
|
123
|
+
/**
|
|
124
|
+
* Main entry point for processing user queries.
|
|
125
|
+
*
|
|
126
|
+
* Handles the complete query lifecycle:
|
|
127
|
+
* 1. Loads thread history from memory
|
|
128
|
+
* 2. Detects intent from the query
|
|
129
|
+
* 3. Fulfills the intent with AI response
|
|
130
|
+
* 4. Updates conversation history
|
|
131
|
+
*
|
|
132
|
+
* @param query - The user's input query
|
|
133
|
+
* @param threadId - Unique thread identifier
|
|
134
|
+
* @param userId - Unique user identifier
|
|
135
|
+
* @returns Object containing the AI-generated response
|
|
136
|
+
*/
|
|
137
|
+
async handleQuery(query, threadId, userId) {
|
|
138
|
+
const queryStartAt = Date.now();
|
|
139
|
+
const threadMemory = _optionalChain([this, 'access', _8 => _8.memoryModule, 'optionalAccess', _9 => _9.getThreadMemory, 'call', _10 => _10()]);
|
|
140
|
+
const thread = !userId ? void 0 : await _optionalChain([threadMemory, 'optionalAccess', _11 => _11.getThread, 'call', _12 => _12(userId, threadId)]);
|
|
141
|
+
const intent = this.intentTriggering(query);
|
|
142
|
+
const result = await this.intentFulfilling(query, threadId, thread);
|
|
143
|
+
if (userId) {
|
|
144
|
+
await _optionalChain([threadMemory, 'optionalAccess', _13 => _13.addMessageToThread, 'call', _14 => _14(userId, threadId, {
|
|
145
|
+
role: "USER" /* USER */,
|
|
146
|
+
timestamp: queryStartAt,
|
|
147
|
+
content: { type: "text", parts: [query] }
|
|
148
|
+
})]);
|
|
149
|
+
await _optionalChain([threadMemory, 'optionalAccess', _15 => _15.addMessageToThread, 'call', _16 => _16(userId, threadId, {
|
|
150
|
+
role: "MODEL" /* MODEL */,
|
|
151
|
+
timestamp: Date.now(),
|
|
152
|
+
content: { type: "text", parts: [result.response] }
|
|
153
|
+
})]);
|
|
154
|
+
}
|
|
155
|
+
return { content: result.response };
|
|
156
|
+
}
|
|
157
|
+
};
|
|
158
|
+
|
|
159
|
+
|
|
160
|
+
|
|
161
|
+
exports.QueryService = QueryService;
|
|
162
|
+
//# sourceMappingURL=chunk-PT2CVI52.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-PT2CVI52.cjs","../../src/services/query.service.ts"],"names":[],"mappings":"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","file":"/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-PT2CVI52.cjs","sourcesContent":[null,"import type {\n\tA2AModule,\n\tMCPModule,\n\tMemoryModule,\n\tModelModule,\n} from \"@/modules/index.js\";\nimport type { AinAgentPrompts } from \"@/types/agent.js\";\nimport { MessageRole, type ThreadObject } from \"@/types/memory.js\";\nimport {\n\ttype IA2ATool,\n\ttype IAgentTool,\n\ttype IMCPTool,\n\tTOOL_PROTOCOL_TYPE,\n} from \"@/types/tool.js\";\nimport { loggers } from \"@/utils/logger.js\";\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 a2aModule?: A2AModule;\n\tprivate mcpModule?: MCPModule;\n\tprivate memoryModule?: MemoryModule;\n\tprivate prompts?: AinAgentPrompts;\n\n\tconstructor(\n\t\tmodelModule: ModelModule,\n\t\ta2aModule?: A2AModule,\n\t\tmcpModule?: MCPModule,\n\t\tmemoryModule?: MemoryModule,\n\t\tprompts?: AinAgentPrompts,\n\t) {\n\t\tthis.modelModule = modelModule;\n\t\tthis.a2aModule = a2aModule;\n\t\tthis.mcpModule = mcpModule;\n\t\tthis.memoryModule = memoryModule;\n\t\tthis.prompts = prompts;\n\t}\n\n\t/**\n\t * Detects the intent from a user query.\n\t *\n\t * @param query - The user's input query\n\t * @returns The detected intent (currently returns the query as-is)\n\t * @todo Implement actual intent detection logic\n\t */\n\tprivate async intentTriggering(query: string) {\n\t\t/* TODO */\n\t\treturn query;\n\t}\n\n\t/**\n\t * Fulfills the detected intent by generating a 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 *\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 * @returns Object containing process steps and final response\n\t */\n\tprivate async intentFulfilling(\n\t\tquery: string,\n\t\tthreadId: string,\n\t\tthread?: ThreadObject,\n\t) {\n\t\t// 1. Load agent / system prompt from memory\n\t\tconst systemPrompt = `\nToday is ${new Date().toLocaleDateString()}.\n\n${this.prompts?.agent || \"\"}\n\n${this.prompts?.system || \"\"}\n `;\n\n\t\tconst modelInstance = this.modelModule.getModel();\n\t\tconst messages = modelInstance.generateMessages({\n\t\t\tquery,\n\t\t\tthread,\n\t\t\tsystemPrompt: systemPrompt.trim(),\n\t\t});\n\n\t\tconst tools: IAgentTool[] = [];\n\t\tif (this.mcpModule) {\n\t\t\ttools.push(...this.mcpModule.getTools());\n\t\t}\n\t\tif (this.a2aModule) {\n\t\t\ttools.push(...(await this.a2aModule.getTools()));\n\t\t}\n\t\tconst functions = modelInstance.convertToolsToFunctions(tools);\n\n\t\tconst processList: string[] = [];\n\t\tlet finalMessage = \"\";\n\t\tlet didCallTool = false;\n\n\t\twhile (true) {\n\t\t\tconst response = await modelInstance.fetchWithContextMessage(\n\t\t\t\tmessages,\n\t\t\t\tfunctions,\n\t\t\t);\n\t\t\tdidCallTool = false;\n\n\t\t\tloggers.intent.debug(\"messages\", { messages });\n\n\t\t\tconst { content, toolCalls } = response;\n\n\t\t\tloggers.intent.debug(\"content\", { content });\n\t\t\tloggers.intent.debug(\"tool_calls\", { ...toolCalls });\n\n\t\t\tif (toolCalls) {\n\t\t\t\tconst messagePayload = this.a2aModule?.getMessagePayload(\n\t\t\t\t\tquery,\n\t\t\t\t\tthreadId,\n\t\t\t\t);\n\n\t\t\t\tfor (const toolCall of toolCalls) {\n\t\t\t\t\tconst toolName = toolCall.name;\n\t\t\t\t\tdidCallTool = true;\n\t\t\t\t\tconst selectedTool = tools.filter((tool) => tool.id === toolName)[0];\n\n\t\t\t\t\tlet toolResult = \"\";\n\t\t\t\t\tif (\n\t\t\t\t\t\tthis.mcpModule &&\n\t\t\t\t\t\tselectedTool.protocol === TOOL_PROTOCOL_TYPE.MCP\n\t\t\t\t\t) {\n\t\t\t\t\t\tconst toolArgs = toolCall.arguments as\n\t\t\t\t\t\t\t| { [x: string]: unknown }\n\t\t\t\t\t\t\t| undefined;\n\t\t\t\t\t\tloggers.intent.debug(\"MCP tool call\", { toolName, toolArgs });\n\t\t\t\t\t\ttoolResult = await this.mcpModule.useTool(\n\t\t\t\t\t\t\tselectedTool as IMCPTool,\n\t\t\t\t\t\t\ttoolArgs,\n\t\t\t\t\t\t);\n\t\t\t\t\t} else if (\n\t\t\t\t\t\tthis.a2aModule &&\n\t\t\t\t\t\tselectedTool.protocol === TOOL_PROTOCOL_TYPE.A2A\n\t\t\t\t\t) {\n\t\t\t\t\t\ttoolResult = await this.a2aModule.useTool(\n\t\t\t\t\t\t\tselectedTool as IA2ATool,\n\t\t\t\t\t\t\tmessagePayload!,\n\t\t\t\t\t\t\tthreadId,\n\t\t\t\t\t\t);\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(\"toolResult\", { 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 if (content) {\n\t\t\t\tprocessList.push(content);\n\t\t\t\tfinalMessage = content;\n\t\t\t}\n\n\t\t\tif (!didCallTool) break;\n\t\t}\n\n\t\tconst botResponse = {\n\t\t\tprocess: processList.join(\"\\n\"),\n\t\t\tresponse: finalMessage,\n\t\t};\n\n\t\treturn botResponse;\n\t}\n\n\t/**\n\t * Main entry point for processing user queries.\n\t *\n\t * Handles the complete query lifecycle:\n\t * 1. Loads thread history from memory\n\t * 2. Detects intent from the query\n\t * 3. Fulfills the intent with AI response\n\t * 4. Updates conversation history\n\t *\n\t * @param query - The user's input query\n\t * @param threadId - Unique thread identifier\n\t * @param userId - Unique user identifier\n\t * @returns Object containing the AI-generated response\n\t */\n\tpublic async handleQuery(query: string, threadId: string, userId?: string) {\n\t\t// 1. Load thread with threadId\n\t\tconst queryStartAt = Date.now();\n\t\tconst threadMemory = this.memoryModule?.getThreadMemory();\n\t\tconst thread = !userId\n\t\t\t? undefined\n\t\t\t: await threadMemory?.getThread(userId, threadId);\n\n\t\t// 2. intent triggering\n\t\tconst intent = this.intentTriggering(query);\n\n\t\t// 3. intent fulfillment\n\t\tconst result = await this.intentFulfilling(query, threadId, thread);\n\t\tif (userId) {\n\t\t\tawait threadMemory?.addMessageToThread(userId, threadId, {\n\t\t\t\trole: MessageRole.USER,\n\t\t\t\ttimestamp: queryStartAt,\n\t\t\t\tcontent: { type: \"text\", parts: [query] },\n\t\t\t});\n\t\t\tawait threadMemory?.addMessageToThread(userId, threadId, {\n\t\t\t\trole: MessageRole.MODEL,\n\t\t\t\ttimestamp: Date.now(),\n\t\t\t\tcontent: { type: \"text\", parts: [result.response] },\n\t\t\t});\n\t\t}\n\n\t\treturn { content: result.response };\n\t}\n}\n"]}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
"use strict";Object.defineProperty(exports, "__esModule", {value: true});
|
|
2
|
+
|
|
3
|
+
var _chunkMSFAMZFUcjs = require('./chunk-MSFAMZFU.cjs');
|
|
4
|
+
|
|
5
|
+
|
|
6
|
+
var _chunkEH4MLPFYcjs = require('./chunk-EH4MLPFY.cjs');
|
|
7
|
+
|
|
8
|
+
|
|
9
|
+
var _chunkDQP6RGIRcjs = require('./chunk-DQP6RGIR.cjs');
|
|
10
|
+
|
|
11
|
+
// src/routes/query.routes.ts
|
|
12
|
+
var _express = require('express');
|
|
13
|
+
var createQueryRouter = (agent, allowStream = false) => {
|
|
14
|
+
const router = _express.Router.call(void 0, );
|
|
15
|
+
const queryService = new (0, _chunkDQP6RGIRcjs.QueryService)(
|
|
16
|
+
agent.modelModule,
|
|
17
|
+
agent.a2aModule,
|
|
18
|
+
agent.mcpModule,
|
|
19
|
+
agent.memoryModule,
|
|
20
|
+
agent.manifest.prompts
|
|
21
|
+
);
|
|
22
|
+
let queryStreamService;
|
|
23
|
+
if (allowStream) {
|
|
24
|
+
queryStreamService = new (0, _chunkMSFAMZFUcjs.QueryStreamService)(
|
|
25
|
+
agent.modelModule,
|
|
26
|
+
agent.a2aModule,
|
|
27
|
+
agent.mcpModule,
|
|
28
|
+
agent.memoryModule,
|
|
29
|
+
agent.manifest.prompts
|
|
30
|
+
);
|
|
31
|
+
}
|
|
32
|
+
const queryController = new (0, _chunkEH4MLPFYcjs.QueryController)(queryService, queryStreamService);
|
|
33
|
+
router.post("/", queryController.handleQueryRequest);
|
|
34
|
+
if (allowStream) {
|
|
35
|
+
router.post("/stream", queryController.handleQueryStreamRequest);
|
|
36
|
+
}
|
|
37
|
+
return router;
|
|
38
|
+
};
|
|
39
|
+
|
|
40
|
+
|
|
41
|
+
|
|
42
|
+
exports.createQueryRouter = createQueryRouter;
|
|
43
|
+
//# sourceMappingURL=chunk-Q75JG4Y6.cjs.map
|