@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.
Files changed (228) hide show
  1. package/README.md +9 -4
  2. package/dist/cjs/chunk-2XND7YNQ.cjs +279 -0
  3. package/dist/cjs/chunk-2XND7YNQ.cjs.map +1 -0
  4. package/dist/cjs/chunk-36ECGO5C.cjs +269 -0
  5. package/dist/cjs/chunk-36ECGO5C.cjs.map +1 -0
  6. package/dist/cjs/chunk-3J3ORQOG.cjs +65 -0
  7. package/dist/cjs/chunk-3J3ORQOG.cjs.map +1 -0
  8. package/dist/cjs/chunk-3QNRWPMM.cjs +37 -0
  9. package/dist/cjs/chunk-3QNRWPMM.cjs.map +1 -0
  10. package/dist/cjs/chunk-4MCEFDVX.cjs +43 -0
  11. package/dist/cjs/chunk-4MCEFDVX.cjs.map +1 -0
  12. package/dist/cjs/chunk-55IME4BG.cjs +114 -0
  13. package/dist/cjs/chunk-55IME4BG.cjs.map +1 -0
  14. package/dist/cjs/chunk-5T53A5X4.cjs +12 -0
  15. package/dist/cjs/chunk-5T53A5X4.cjs.map +1 -0
  16. package/dist/cjs/chunk-65M7DC3L.cjs +172 -0
  17. package/dist/cjs/chunk-65M7DC3L.cjs.map +1 -0
  18. package/dist/cjs/chunk-6BKOR3ZH.cjs +111 -0
  19. package/dist/cjs/chunk-6BKOR3ZH.cjs.map +1 -0
  20. package/dist/cjs/chunk-6YVTJEMQ.cjs +176 -0
  21. package/dist/cjs/chunk-6YVTJEMQ.cjs.map +1 -0
  22. package/dist/cjs/chunk-7EGJAURF.cjs +205 -0
  23. package/dist/cjs/chunk-7EGJAURF.cjs.map +1 -0
  24. package/dist/cjs/chunk-7EOUPEHU.cjs +243 -0
  25. package/dist/cjs/chunk-7EOUPEHU.cjs.map +1 -0
  26. package/dist/cjs/chunk-7K2R2UKB.cjs +8 -0
  27. package/dist/cjs/chunk-7K2R2UKB.cjs.map +1 -0
  28. package/dist/cjs/chunk-7QR5ZJAF.cjs +278 -0
  29. package/dist/cjs/chunk-7QR5ZJAF.cjs.map +1 -0
  30. package/dist/cjs/chunk-7TEDNNSL.cjs +18 -0
  31. package/dist/cjs/chunk-7TEDNNSL.cjs.map +1 -0
  32. package/dist/cjs/chunk-7WYFXLNY.cjs +43 -0
  33. package/dist/cjs/chunk-7WYFXLNY.cjs.map +1 -0
  34. package/dist/cjs/chunk-7XDYJNTA.cjs +35 -0
  35. package/dist/cjs/chunk-7XDYJNTA.cjs.map +1 -0
  36. package/dist/cjs/chunk-BBCZU5VZ.cjs +17 -0
  37. package/dist/cjs/chunk-BBCZU5VZ.cjs.map +1 -0
  38. package/dist/cjs/chunk-BNY3RLYC.cjs +43 -0
  39. package/dist/cjs/chunk-BNY3RLYC.cjs.map +1 -0
  40. package/dist/cjs/chunk-BYD5RS6L.cjs +12 -0
  41. package/dist/cjs/chunk-BYD5RS6L.cjs.map +1 -0
  42. package/dist/cjs/chunk-EAK7MP6X.cjs +22 -0
  43. package/dist/cjs/chunk-EAK7MP6X.cjs.map +1 -0
  44. package/dist/cjs/chunk-GHE5MNHK.cjs +43 -0
  45. package/dist/cjs/chunk-GHE5MNHK.cjs.map +1 -0
  46. package/dist/cjs/chunk-H65RVLWK.cjs +267 -0
  47. package/dist/cjs/chunk-H65RVLWK.cjs.map +1 -0
  48. package/dist/cjs/chunk-IS2IVXXA.cjs +176 -0
  49. package/dist/cjs/chunk-IS2IVXXA.cjs.map +1 -0
  50. package/dist/cjs/chunk-J4Z7ZJUJ.cjs +277 -0
  51. package/dist/cjs/chunk-J4Z7ZJUJ.cjs.map +1 -0
  52. package/dist/cjs/chunk-J6PDRTNM.cjs +37 -0
  53. package/dist/cjs/chunk-J6PDRTNM.cjs.map +1 -0
  54. package/dist/cjs/chunk-JAPFZA2K.cjs +205 -0
  55. package/dist/cjs/chunk-JAPFZA2K.cjs.map +1 -0
  56. package/dist/cjs/chunk-JLWQUJCP.cjs +43 -0
  57. package/dist/cjs/chunk-JLWQUJCP.cjs.map +1 -0
  58. package/dist/cjs/chunk-K4P2MYZF.cjs +43 -0
  59. package/dist/cjs/chunk-K4P2MYZF.cjs.map +1 -0
  60. package/dist/cjs/chunk-KDNNRPBV.cjs +43 -0
  61. package/dist/cjs/chunk-KDNNRPBV.cjs.map +1 -0
  62. package/dist/cjs/chunk-KRLUWTLN.cjs +35 -0
  63. package/dist/cjs/chunk-KRLUWTLN.cjs.map +1 -0
  64. package/dist/cjs/chunk-M4MYRCSF.cjs +18 -0
  65. package/dist/cjs/chunk-M4MYRCSF.cjs.map +1 -0
  66. package/dist/{esm/chunk-3NEV3O2X.js → cjs/chunk-MSFAMZFU.cjs} +41 -39
  67. package/dist/cjs/chunk-MSFAMZFU.cjs.map +1 -0
  68. package/dist/cjs/chunk-MVN5XJGZ.cjs +66 -0
  69. package/dist/cjs/chunk-MVN5XJGZ.cjs.map +1 -0
  70. package/dist/cjs/chunk-O6XQRAWR.cjs +45 -0
  71. package/dist/cjs/chunk-O6XQRAWR.cjs.map +1 -0
  72. package/dist/cjs/chunk-PDF6B6A3.cjs +37 -0
  73. package/dist/cjs/chunk-PDF6B6A3.cjs.map +1 -0
  74. package/dist/cjs/chunk-PT2CVI52.cjs +162 -0
  75. package/dist/cjs/chunk-PT2CVI52.cjs.map +1 -0
  76. package/dist/cjs/chunk-Q75JG4Y6.cjs +43 -0
  77. package/dist/cjs/chunk-Q75JG4Y6.cjs.map +1 -0
  78. package/dist/cjs/chunk-QJJ4NXX6.cjs +37 -0
  79. package/dist/cjs/chunk-QJJ4NXX6.cjs.map +1 -0
  80. package/dist/cjs/chunk-QUSBMECP.cjs +37 -0
  81. package/dist/cjs/chunk-QUSBMECP.cjs.map +1 -0
  82. package/dist/cjs/chunk-SAXFX7U2.cjs +37 -0
  83. package/dist/cjs/chunk-SAXFX7U2.cjs.map +1 -0
  84. package/dist/cjs/chunk-SCOMNXDA.cjs +51 -0
  85. package/dist/cjs/chunk-SCOMNXDA.cjs.map +1 -0
  86. package/dist/cjs/chunk-SGW3CSPD.cjs +43 -0
  87. package/dist/cjs/chunk-SGW3CSPD.cjs.map +1 -0
  88. package/dist/cjs/chunk-SJHSHDJL.cjs +65 -0
  89. package/dist/cjs/chunk-SJHSHDJL.cjs.map +1 -0
  90. package/dist/cjs/chunk-UAWGHNZD.cjs +22 -0
  91. package/dist/cjs/chunk-UAWGHNZD.cjs.map +1 -0
  92. package/dist/cjs/chunk-UBEB55WC.cjs +43 -0
  93. package/dist/cjs/chunk-UBEB55WC.cjs.map +1 -0
  94. package/dist/cjs/chunk-UPNSAV5A.cjs +18 -0
  95. package/dist/cjs/chunk-UPNSAV5A.cjs.map +1 -0
  96. package/dist/cjs/chunk-UW43BI5Z.cjs +17 -0
  97. package/dist/cjs/chunk-UW43BI5Z.cjs.map +1 -0
  98. package/dist/cjs/chunk-WNDA2G4Q.cjs +43 -0
  99. package/dist/cjs/chunk-WNDA2G4Q.cjs.map +1 -0
  100. package/dist/cjs/chunk-X46GJS7X.cjs +17 -0
  101. package/dist/cjs/chunk-X46GJS7X.cjs.map +1 -0
  102. package/dist/cjs/chunk-XPD3ANDG.cjs +267 -0
  103. package/dist/cjs/chunk-XPD3ANDG.cjs.map +1 -0
  104. package/dist/cjs/chunk-XPTRG6IC.cjs +43 -0
  105. package/dist/cjs/chunk-XPTRG6IC.cjs.map +1 -0
  106. package/dist/cjs/chunk-XVMXTCJI.cjs +64 -0
  107. package/dist/cjs/chunk-XVMXTCJI.cjs.map +1 -0
  108. package/dist/cjs/chunk-YQ5P2K3X.cjs +37 -0
  109. package/dist/cjs/chunk-YQ5P2K3X.cjs.map +1 -0
  110. package/dist/cjs/controllers/api/thread.api.controller.cjs +8 -0
  111. package/dist/cjs/controllers/api/thread.api.controller.cjs.map +1 -0
  112. package/dist/cjs/controllers/index.cjs +3 -3
  113. package/dist/cjs/controllers/index.cjs.map +1 -1
  114. package/dist/cjs/controllers/query.controller.cjs +3 -2
  115. package/dist/cjs/controllers/query.controller.cjs.map +1 -1
  116. package/dist/cjs/index.cjs +17 -16
  117. package/dist/cjs/index.cjs.map +1 -1
  118. package/dist/cjs/modules/a2a/a2a.module.cjs +3 -2
  119. package/dist/cjs/modules/a2a/a2a.module.cjs.map +1 -1
  120. package/dist/cjs/modules/index.cjs +5 -4
  121. package/dist/cjs/modules/index.cjs.map +1 -1
  122. package/dist/cjs/modules/memory/memory.module.cjs +2 -2
  123. package/dist/cjs/modules/models/base.model.cjs +2 -2
  124. package/dist/cjs/routes/a2a.routes.cjs +5 -5
  125. package/dist/cjs/routes/api/model.routes.cjs +8 -0
  126. package/dist/cjs/routes/api/model.routes.cjs.map +1 -0
  127. package/dist/cjs/routes/api/thread.routes.cjs +9 -0
  128. package/dist/cjs/routes/api/thread.routes.cjs.map +1 -0
  129. package/dist/cjs/routes/api.routes.cjs +5 -5
  130. package/dist/cjs/routes/index.cjs +12 -12
  131. package/dist/cjs/routes/index.cjs.map +1 -1
  132. package/dist/cjs/routes/query.routes.cjs +7 -6
  133. package/dist/cjs/routes/query.routes.cjs.map +1 -1
  134. package/dist/cjs/services/a2a.service.cjs +2 -2
  135. package/dist/cjs/services/index.cjs +5 -5
  136. package/dist/cjs/services/query-stream.service.cjs +3 -3
  137. package/dist/cjs/services/query.service.cjs +3 -3
  138. package/dist/cjs/types/memory.cjs +2 -2
  139. package/dist/cjs/types/memory.cjs.map +1 -1
  140. package/dist/esm/chunk-2BYUKYVB.js +243 -0
  141. package/dist/esm/chunk-2BYUKYVB.js.map +1 -0
  142. package/dist/esm/{chunk-Y6E73I7I.js → chunk-2RW77MJB.js} +6 -3
  143. package/dist/esm/chunk-2RW77MJB.js.map +1 -0
  144. package/dist/esm/chunk-7D4SKPIS.js +65 -0
  145. package/dist/esm/chunk-7D4SKPIS.js.map +1 -0
  146. package/dist/esm/{chunk-5EPK37PE.js → chunk-ADIAIRNH.js} +10 -10
  147. package/dist/esm/chunk-ADIAIRNH.js.map +1 -0
  148. package/dist/esm/{chunk-2Z7GJVJJ.js → chunk-AMRKK46V.js} +2 -2
  149. package/dist/esm/chunk-AMRKK46V.js.map +1 -0
  150. package/dist/esm/{chunk-2BITOA2R.js → chunk-CDFLKADH.js} +1 -1
  151. package/dist/esm/chunk-CDFLKADH.js.map +1 -0
  152. package/dist/esm/{chunk-DRUCJYPJ.js → chunk-EGR6OTTN.js} +65 -22
  153. package/dist/esm/chunk-EGR6OTTN.js.map +1 -0
  154. package/dist/esm/{chunk-5N4X25IK.js → chunk-G6VR5RSV.js} +5 -5
  155. package/dist/esm/chunk-HOFAK5J2.js +22 -0
  156. package/dist/esm/chunk-HOFAK5J2.js.map +1 -0
  157. package/dist/esm/{chunk-GNWF6QG4.js → chunk-JCWH7LIC.js} +6 -6
  158. package/dist/esm/{chunk-C6SGV7JV.js → chunk-LJVVSUF7.js} +17 -13
  159. package/dist/esm/chunk-LJVVSUF7.js.map +1 -0
  160. package/dist/esm/chunk-MNAWSBYP.js +18 -0
  161. package/dist/esm/chunk-MNAWSBYP.js.map +1 -0
  162. package/dist/esm/chunk-VA3XOZBV.js +17 -0
  163. package/dist/esm/chunk-VA3XOZBV.js.map +1 -0
  164. package/dist/esm/{chunk-CKTURH34.js → chunk-XBMWWTSX.js} +9 -9
  165. package/dist/esm/chunk-XBMWWTSX.js.map +1 -0
  166. package/dist/esm/controllers/a2a.controller.d.ts +1 -1
  167. package/dist/esm/controllers/api/{session.api.controller.d.ts → thread.api.controller.d.ts} +3 -3
  168. package/dist/esm/controllers/api/thread.api.controller.js +8 -0
  169. package/dist/esm/controllers/index.d.ts +2 -2
  170. package/dist/esm/controllers/index.js +7 -7
  171. package/dist/esm/controllers/query.controller.d.ts +1 -1
  172. package/dist/esm/controllers/query.controller.js +2 -1
  173. package/dist/esm/index.d.ts +1 -0
  174. package/dist/esm/index.js +17 -16
  175. package/dist/esm/index.js.map +1 -1
  176. package/dist/esm/modules/a2a/a2a.module.d.ts +6 -15
  177. package/dist/esm/modules/a2a/a2a.module.js +2 -1
  178. package/dist/esm/modules/index.d.ts +1 -1
  179. package/dist/esm/modules/index.js +4 -3
  180. package/dist/esm/modules/memory/base.memory.d.ts +9 -9
  181. package/dist/esm/modules/memory/memory.module.d.ts +4 -4
  182. package/dist/esm/modules/memory/memory.module.js +1 -1
  183. package/dist/esm/modules/models/base.model.d.ts +4 -4
  184. package/dist/esm/modules/models/base.model.js +1 -1
  185. package/dist/esm/routes/a2a.routes.js +4 -4
  186. package/dist/esm/routes/api/{models.routes.js → model.routes.js} +2 -2
  187. package/dist/esm/routes/api/{sessions.routes.d.ts → thread.routes.d.ts} +2 -2
  188. package/dist/esm/routes/api/thread.routes.js +9 -0
  189. package/dist/esm/routes/api.routes.js +4 -4
  190. package/dist/esm/routes/index.d.ts +2 -2
  191. package/dist/esm/routes/index.js +16 -16
  192. package/dist/esm/routes/query.routes.js +6 -5
  193. package/dist/esm/services/a2a.service.d.ts +1 -1
  194. package/dist/esm/services/a2a.service.js +1 -1
  195. package/dist/esm/services/index.d.ts +1 -2
  196. package/dist/esm/services/index.js +6 -6
  197. package/dist/esm/services/query-stream.service.d.ts +13 -8
  198. package/dist/esm/services/query-stream.service.js +2 -2
  199. package/dist/esm/services/query.service.d.ts +19 -8
  200. package/dist/esm/services/query.service.js +2 -2
  201. package/dist/esm/types/memory.d.ts +32 -32
  202. package/dist/esm/types/memory.js +5 -5
  203. package/dist/esm/types/stream.d.ts +32 -2
  204. package/package.json +6 -6
  205. package/dist/esm/chunk-2BITOA2R.js.map +0 -1
  206. package/dist/esm/chunk-2Z7GJVJJ.js.map +0 -1
  207. package/dist/esm/chunk-3NEV3O2X.js.map +0 -1
  208. package/dist/esm/chunk-5EPK37PE.js.map +0 -1
  209. package/dist/esm/chunk-C6SGV7JV.js.map +0 -1
  210. package/dist/esm/chunk-CKTURH34.js.map +0 -1
  211. package/dist/esm/chunk-DRUCJYPJ.js.map +0 -1
  212. package/dist/esm/chunk-Q6HHVAO6.js +0 -45
  213. package/dist/esm/chunk-Q6HHVAO6.js.map +0 -1
  214. package/dist/esm/chunk-QROUPWWO.js +0 -17
  215. package/dist/esm/chunk-QROUPWWO.js.map +0 -1
  216. package/dist/esm/chunk-VAZWF5IK.js +0 -20
  217. package/dist/esm/chunk-VAZWF5IK.js.map +0 -1
  218. package/dist/esm/chunk-Y6E73I7I.js.map +0 -1
  219. package/dist/esm/chunk-YT6PD6UF.js +0 -22
  220. package/dist/esm/chunk-YT6PD6UF.js.map +0 -1
  221. package/dist/esm/controllers/api/session.api.controller.js +0 -8
  222. package/dist/esm/routes/api/sessions.routes.js +0 -9
  223. /package/dist/esm/{chunk-5N4X25IK.js.map → chunk-G6VR5RSV.js.map} +0 -0
  224. /package/dist/esm/{chunk-GNWF6QG4.js.map → chunk-JCWH7LIC.js.map} +0 -0
  225. /package/dist/esm/controllers/api/{session.api.controller.js.map → thread.api.controller.js.map} +0 -0
  226. /package/dist/esm/routes/api/{models.routes.d.ts → model.routes.d.ts} +0 -0
  227. /package/dist/esm/routes/api/{models.routes.js.map → model.routes.js.map} +0 -0
  228. /package/dist/esm/routes/api/{sessions.routes.js.map → thread.routes.js.map} +0 -0
@@ -1,15 +1,15 @@
1
- import {
2
- loggers
3
- } from "./chunk-N7VYM2R5.js";
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
- import { randomUUID } from "crypto";
6
+ var _crypto = require('crypto');
7
7
  var QueryStreamService = class {
8
- modelModule;
9
- a2aModule;
10
- mcpModule;
11
- memoryModule;
12
- prompts;
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?.agent || ""}
49
+ ${_optionalChain([this, 'access', _ => _.prompts, 'optionalAccess', _2 => _2.agent]) || ""}
50
50
 
51
- ${this.prompts?.system || ""}
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?.tool_calls) {
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?.name) {
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?.arguments) {
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?.content) {
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?.getMessagePayload(
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?.getSessionMemory();
212
- const session = !userId || !sessionId ? void 0 : await sessionMemory?.getSession(userId, sessionId);
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?.createSession(userId, sessionId, title) || {
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?.addChatToSession(userId, sessionId, {
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?.addChatToSession(userId, sessionId, {
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
- export {
273
- QueryStreamService
274
- };
275
- //# sourceMappingURL=chunk-3NEV3O2X.js.map
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":"AAAA;AACE;AACF,wDAA6B;AAC7B;AACA;ACmBO,IAAM,aAAA,EAAN,MAAmB;AAAA,EACjB;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EAER,WAAA,CACC,WAAA,EACA,SAAA,EACA,SAAA,EACA,YAAA,EACA,OAAA,EACC;AACD,IAAA,IAAA,CAAK,YAAA,EAAc,WAAA;AACnB,IAAA,IAAA,CAAK,UAAA,EAAY,SAAA;AACjB,IAAA,IAAA,CAAK,UAAA,EAAY,SAAA;AACjB,IAAA,IAAA,CAAK,aAAA,EAAe,YAAA;AACpB,IAAA,IAAA,CAAK,QAAA,EAAU,OAAA;AAAA,EAChB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASA,MAAc,gBAAA,CAAiB,KAAA,EAAe;AAE7C,IAAA,OAAO,KAAA;AAAA,EACR;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAgBA,MAAc,gBAAA,CACb,KAAA,EACA,QAAA,EACA,MAAA,EACC;AAED,IAAA,MAAM,aAAA,EAAe,CAAA;AAAA,SAAA,EAAA,iBACZ,IAAI,IAAA,CAAK,CAAA,CAAA,CAAE,kBAAA,CAAmB,CAAC,CAAA;AAAA;AAAA,kBAExC,IAAA,mBAAK,OAAA,6BAAS,QAAA,GAAS,EAAE,CAAA;AAAA;AAAA,kBAEzB,IAAA,qBAAK,OAAA,6BAAS,SAAA,GAAU,EAAE,CAAA;AAAA,IAAA,CAAA;AAG1B,IAAA,MAAM,cAAA,EAAgB,IAAA,CAAK,WAAA,CAAY,QAAA,CAAS,CAAA;AAChD,IAAA,MAAM,SAAA,EAAW,aAAA,CAAc,gBAAA,CAAiB;AAAA,MAC/C,KAAA;AAAA,MACA,MAAA;AAAA,MACA,YAAA,EAAc,YAAA,CAAa,IAAA,CAAK;AAAA,IACjC,CAAC,CAAA;AAED,IAAA,MAAM,MAAA,EAAsB,CAAC,CAAA;AAC7B,IAAA,GAAA,CAAI,IAAA,CAAK,SAAA,EAAW;AACnB,MAAA,KAAA,CAAM,IAAA,CAAK,GAAG,IAAA,CAAK,SAAA,CAAU,QAAA,CAAS,CAAC,CAAA;AAAA,IACxC;AACA,IAAA,GAAA,CAAI,IAAA,CAAK,SAAA,EAAW;AACnB,MAAA,KAAA,CAAM,IAAA,CAAK,GAAI,MAAM,IAAA,CAAK,SAAA,CAAU,QAAA,CAAS,CAAE,CAAA;AAAA,IAChD;AACA,IAAA,MAAM,UAAA,EAAY,aAAA,CAAc,uBAAA,CAAwB,KAAK,CAAA;AAE7D,IAAA,MAAM,YAAA,EAAwB,CAAC,CAAA;AAC/B,IAAA,IAAI,aAAA,EAAe,EAAA;AACnB,IAAA,IAAI,YAAA,EAAc,KAAA;AAElB,IAAA,MAAA,CAAO,IAAA,EAAM;AACZ,MAAA,MAAM,SAAA,EAAW,MAAM,aAAA,CAAc,uBAAA;AAAA,QACpC,QAAA;AAAA,QACA;AAAA,MACD,CAAA;AACA,MAAA,YAAA,EAAc,KAAA;AAEd,MAAA,yBAAA,CAAQ,MAAA,CAAO,KAAA,CAAM,UAAA,EAAY,EAAE,SAAS,CAAC,CAAA;AAE7C,MAAA,MAAM,EAAE,OAAA,EAAS,UAAU,EAAA,EAAI,QAAA;AAE/B,MAAA,yBAAA,CAAQ,MAAA,CAAO,KAAA,CAAM,SAAA,EAAW,EAAE,QAAQ,CAAC,CAAA;AAC3C,MAAA,yBAAA,CAAQ,MAAA,CAAO,KAAA,CAAM,YAAA,EAAc,EAAE,GAAG,UAAU,CAAC,CAAA;AAEnD,MAAA,GAAA,CAAI,SAAA,EAAW;AACd,QAAA,MAAM,eAAA,kBAAiB,IAAA,qBAAK,SAAA,6BAAW,iBAAA;AAAA,UACtC,KAAA;AAAA,UACA;AAAA,QACD,GAAA;AAEA,QAAA,IAAA,CAAA,MAAW,SAAA,GAAY,SAAA,EAAW;AACjC,UAAA,MAAM,SAAA,EAAW,QAAA,CAAS,IAAA;AAC1B,UAAA,YAAA,EAAc,IAAA;AACd,UAAA,MAAM,aAAA,EAAe,KAAA,CAAM,MAAA,CAAO,CAAC,IAAA,EAAA,GAAS,IAAA,CAAK,GAAA,IAAO,QAAQ,CAAA,CAAE,CAAC,CAAA;AAEnE,UAAA,IAAI,WAAA,EAAa,EAAA;AACjB,UAAA,GAAA,CACC,IAAA,CAAK,UAAA,GACL,YAAA,CAAa,SAAA,IAAA,eAAA,EACZ;AACD,YAAA,MAAM,SAAA,EAAW,QAAA,CAAS,SAAA;AAG1B,YAAA,yBAAA,CAAQ,MAAA,CAAO,KAAA,CAAM,eAAA,EAAiB,EAAE,QAAA,EAAU,SAAS,CAAC,CAAA;AAC5D,YAAA,WAAA,EAAa,MAAM,IAAA,CAAK,SAAA,CAAU,OAAA;AAAA,cACjC,YAAA;AAAA,cACA;AAAA,YACD,CAAA;AAAA,UACD,EAAA,KAAA,GAAA,CACC,IAAA,CAAK,UAAA,GACL,YAAA,CAAa,SAAA,IAAA,eAAA,EACZ;AACD,YAAA,WAAA,EAAa,MAAM,IAAA,CAAK,SAAA,CAAU,OAAA;AAAA,cACjC,YAAA;AAAA,cACA,cAAA;AAAA,cACA;AAAA,YACD,CAAA;AAAA,UACD,EAAA,KAAO;AAEN,YAAA,yBAAA,CAAQ,MAAA,CAAO,IAAA;AAAA,cACd,CAAA,wBAAA,EAA2B,YAAA,CAAa,QAAQ,CAAA;AAAA,YAAA;AAEjD,YAAA;AAAA,UAAA;AAGD,UAAA;AAEA,UAAA;AACA,UAAA;AAAiD,QAAA;AAClD,MAAA;AAEA,QAAA;AACA,QAAA;AAAe,MAAA;AAGhB,MAAA;AAAkB,IAAA;AAGnB,IAAA;AAAoB,MAAA;AACW,MAAA;AACpB,IAAA;AAGX,IAAA;AAAO,EAAA;AACR;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAAA;AAkBC,IAAA;AACA,IAAA;AACA,IAAA;AAKA,IAAA;AAGA,IAAA;AACA,IAAA;AACC,MAAA;AAAyD,QAAA;AACxD,QAAA;AACW,QAAA;AAC6B,MAAA;AAEzC,MAAA;AAAyD,QAAA;AACxD,QAAA;AACoB,QAAA;AAC8B,MAAA;AAClD,IAAA;AAGF,IAAA;AAAkC,EAAA;AAEpC;ADjEA;AACA;AACA;AACA","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