@ainetwork/adk 0.2.10 → 0.2.12

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 (108) hide show
  1. package/dist/cjs/{chunk-YU3TYLMR.cjs → chunk-4QWJELSL.cjs} +6 -6
  2. package/dist/cjs/{chunk-QXLAC5OS.cjs.map → chunk-4QWJELSL.cjs.map} +1 -1
  3. package/dist/cjs/{chunk-X7FADTCP.cjs → chunk-BXBFJKZC.cjs} +7 -3
  4. package/dist/cjs/chunk-BXBFJKZC.cjs.map +1 -0
  5. package/dist/cjs/{chunk-3X2EKOWC.cjs → chunk-C35ER63S.cjs} +8 -8
  6. package/dist/cjs/chunk-C35ER63S.cjs.map +1 -0
  7. package/dist/cjs/{chunk-SB5GVESM.cjs → chunk-EZE74FHY.cjs} +7 -7
  8. package/dist/cjs/{chunk-SB5GVESM.cjs.map → chunk-EZE74FHY.cjs.map} +1 -1
  9. package/dist/cjs/{chunk-SC6WN4ED.cjs → chunk-IGJXFUHP.cjs} +4 -4
  10. package/dist/cjs/{chunk-BQ6BY5HN.cjs.map → chunk-IGJXFUHP.cjs.map} +1 -1
  11. package/dist/cjs/{chunk-2EPZZPWG.cjs → chunk-JU5AB7AB.cjs} +3 -3
  12. package/dist/cjs/{chunk-SH6JCUEJ.cjs.map → chunk-JU5AB7AB.cjs.map} +1 -1
  13. package/dist/cjs/{chunk-S454SFT6.cjs → chunk-NCYNT6TA.cjs} +3 -3
  14. package/dist/cjs/{chunk-S454SFT6.cjs.map → chunk-NCYNT6TA.cjs.map} +1 -1
  15. package/dist/cjs/chunk-NXD6W2PH.cjs +74 -0
  16. package/dist/cjs/chunk-NXD6W2PH.cjs.map +1 -0
  17. package/dist/cjs/{chunk-BQ6BY5HN.cjs → chunk-QKMB4ET3.cjs} +4 -4
  18. package/dist/cjs/{chunk-SC6WN4ED.cjs.map → chunk-QKMB4ET3.cjs.map} +1 -1
  19. package/dist/cjs/{chunk-QXLAC5OS.cjs → chunk-WVQY5D3N.cjs} +6 -6
  20. package/dist/cjs/{chunk-YU3TYLMR.cjs.map → chunk-WVQY5D3N.cjs.map} +1 -1
  21. package/dist/cjs/{chunk-G3KWCMMQ.cjs → chunk-YMNLHFLD.cjs} +12 -5
  22. package/dist/cjs/chunk-YMNLHFLD.cjs.map +1 -0
  23. package/dist/cjs/controllers/index.cjs +4 -4
  24. package/dist/cjs/index.cjs +22 -22
  25. package/dist/cjs/index.cjs.map +1 -1
  26. package/dist/cjs/modules/a2a/a2a.module.cjs +1 -1
  27. package/dist/cjs/modules/index.cjs +9 -9
  28. package/dist/cjs/modules/index.cjs.map +1 -1
  29. package/dist/cjs/routes/a2a.routes.cjs +7 -7
  30. package/dist/cjs/routes/api.routes.cjs +4 -4
  31. package/dist/cjs/routes/index.cjs +18 -18
  32. package/dist/cjs/routes/index.cjs.map +1 -1
  33. package/dist/cjs/routes/intent.routes.cjs +10 -10
  34. package/dist/cjs/routes/query.routes.cjs +8 -8
  35. package/dist/cjs/services/index.cjs +9 -9
  36. package/dist/cjs/services/intents/fulfill-stream.service.cjs +3 -3
  37. package/dist/cjs/services/intents/fulfill.service.cjs +1 -1
  38. package/dist/cjs/services/intents/trigger.service.cjs +2 -2
  39. package/dist/cjs/services/query-stream.service.cjs +6 -6
  40. package/dist/cjs/services/query.service.cjs +5 -5
  41. package/dist/esm/{chunk-F3I4URTX.js → chunk-3J6YYQRU.js} +7 -7
  42. package/dist/esm/{chunk-JNZCPCEC.js → chunk-7C32OCGS.js} +7 -3
  43. package/dist/esm/chunk-7C32OCGS.js.map +1 -0
  44. package/dist/esm/{chunk-A3UQKLUC.js → chunk-E66MSTWY.js} +2 -2
  45. package/dist/esm/{chunk-6PT5BUHR.js → chunk-GAU3467Q.js} +3 -3
  46. package/dist/esm/{chunk-QCK645XC.js → chunk-LCLBEJNC.js} +12 -5
  47. package/dist/esm/chunk-LCLBEJNC.js.map +1 -0
  48. package/dist/esm/{chunk-7276G7GV.js → chunk-OKC7ARHK.js} +2 -2
  49. package/dist/esm/{chunk-PBGBCH2S.js → chunk-RKE2MTBG.js} +2 -2
  50. package/dist/esm/{chunk-5YU3CTYW.js → chunk-VN4FAX52.js} +6 -4
  51. package/dist/esm/chunk-VN4FAX52.js.map +1 -0
  52. package/dist/esm/index.js +19 -19
  53. package/dist/esm/index.js.map +1 -1
  54. package/dist/esm/modules/index.js +6 -6
  55. package/dist/esm/routes/a2a.routes.js +4 -4
  56. package/dist/esm/routes/api.routes.js +3 -3
  57. package/dist/esm/routes/index.js +15 -15
  58. package/dist/esm/routes/intent.routes.js +6 -6
  59. package/dist/esm/routes/query.routes.js +5 -5
  60. package/dist/esm/services/index.js +4 -4
  61. package/dist/esm/services/intents/fulfill-stream.service.js +1 -1
  62. package/dist/esm/services/intents/trigger.service.js +1 -1
  63. package/dist/esm/services/query-stream.service.js +3 -3
  64. package/dist/esm/services/query.service.js +2 -2
  65. package/package.json +1 -1
  66. package/dist/cjs/chunk-2EPZZPWG.cjs.map +0 -1
  67. package/dist/cjs/chunk-33ZJ74NB.cjs +0 -129
  68. package/dist/cjs/chunk-33ZJ74NB.cjs.map +0 -1
  69. package/dist/cjs/chunk-3X2EKOWC.cjs.map +0 -1
  70. package/dist/cjs/chunk-G3KWCMMQ.cjs.map +0 -1
  71. package/dist/cjs/chunk-IJBFU7GX.cjs +0 -28
  72. package/dist/cjs/chunk-IJBFU7GX.cjs.map +0 -1
  73. package/dist/cjs/chunk-JRFTCDMQ.cjs +0 -132
  74. package/dist/cjs/chunk-JRFTCDMQ.cjs.map +0 -1
  75. package/dist/cjs/chunk-LNLZLOW2.cjs +0 -43
  76. package/dist/cjs/chunk-LNLZLOW2.cjs.map +0 -1
  77. package/dist/cjs/chunk-M6YACFW4.cjs +0 -129
  78. package/dist/cjs/chunk-M6YACFW4.cjs.map +0 -1
  79. package/dist/cjs/chunk-NWIZHGCS.cjs +0 -28
  80. package/dist/cjs/chunk-NWIZHGCS.cjs.map +0 -1
  81. package/dist/cjs/chunk-QIHLINHW.cjs +0 -106
  82. package/dist/cjs/chunk-QIHLINHW.cjs.map +0 -1
  83. package/dist/cjs/chunk-R3K7LK6W.cjs +0 -134
  84. package/dist/cjs/chunk-R3K7LK6W.cjs.map +0 -1
  85. package/dist/cjs/chunk-SH6JCUEJ.cjs +0 -37
  86. package/dist/cjs/chunk-T7444BWH.cjs +0 -134
  87. package/dist/cjs/chunk-T7444BWH.cjs.map +0 -1
  88. package/dist/cjs/chunk-TILUFTIG.cjs +0 -111
  89. package/dist/cjs/chunk-TILUFTIG.cjs.map +0 -1
  90. package/dist/cjs/chunk-VRCXZ4LV.cjs +0 -37
  91. package/dist/cjs/chunk-VRCXZ4LV.cjs.map +0 -1
  92. package/dist/cjs/chunk-WGSFHDDZ.cjs +0 -37
  93. package/dist/cjs/chunk-WGSFHDDZ.cjs.map +0 -1
  94. package/dist/cjs/chunk-X7FADTCP.cjs.map +0 -1
  95. package/dist/cjs/chunk-Y337ZZKZ.cjs +0 -129
  96. package/dist/cjs/chunk-Y337ZZKZ.cjs.map +0 -1
  97. package/dist/cjs/chunk-YIRGAWMS.cjs +0 -30
  98. package/dist/cjs/chunk-YIRGAWMS.cjs.map +0 -1
  99. package/dist/cjs/chunk-ZVPJLZIQ.cjs +0 -107
  100. package/dist/cjs/chunk-ZVPJLZIQ.cjs.map +0 -1
  101. package/dist/esm/chunk-5YU3CTYW.js.map +0 -1
  102. package/dist/esm/chunk-JNZCPCEC.js.map +0 -1
  103. package/dist/esm/chunk-QCK645XC.js.map +0 -1
  104. /package/dist/esm/{chunk-F3I4URTX.js.map → chunk-3J6YYQRU.js.map} +0 -0
  105. /package/dist/esm/{chunk-A3UQKLUC.js.map → chunk-E66MSTWY.js.map} +0 -0
  106. /package/dist/esm/{chunk-6PT5BUHR.js.map → chunk-GAU3467Q.js.map} +0 -0
  107. /package/dist/esm/{chunk-7276G7GV.js.map → chunk-OKC7ARHK.js.map} +0 -0
  108. /package/dist/esm/{chunk-PBGBCH2S.js.map → chunk-RKE2MTBG.js.map} +0 -0
@@ -1,134 +0,0 @@
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 _chunkG3KWCMMQcjs = require('./chunk-G3KWCMMQ.cjs');
4
-
5
-
6
- var _chunkQIHLINHWcjs = require('./chunk-QIHLINHW.cjs');
7
-
8
-
9
- var _chunkQHQLU7BIcjs = require('./chunk-QHQLU7BI.cjs');
10
-
11
-
12
- var _chunk466ED5WNcjs = require('./chunk-466ED5WN.cjs');
13
-
14
- // src/services/query-stream.service.ts
15
- var _crypto = require('crypto');
16
- var _httpstatuscodes = require('http-status-codes');
17
- var QueryStreamService = class {
18
-
19
-
20
-
21
-
22
- constructor(modelModule, a2aModule, mcpModule, memoryModule, prompts) {
23
- this.modelModule = modelModule;
24
- this.memoryModule = memoryModule;
25
- this.intentTriggerService = new (0, _chunkQIHLINHWcjs.IntentTriggerService)(
26
- modelModule,
27
- memoryModule
28
- );
29
- this.intentFulfillStreamService = new (0, _chunkG3KWCMMQcjs.IntentFulfillStreamService)(
30
- modelModule,
31
- a2aModule,
32
- mcpModule,
33
- memoryModule,
34
- prompts
35
- );
36
- }
37
- /**
38
- * Generates a title for the conversation based on the query.
39
- *
40
- * @param query - The user's input query
41
- * @returns Promise resolving to a generated title
42
- */
43
- async generateTitle(query) {
44
- const DEFAULT_TITLE = "New Chat";
45
- try {
46
- const modelInstance = this.modelModule.getModel();
47
- const messages = modelInstance.generateMessages({
48
- query,
49
- systemPrompt: `You are a helpful assistant that generates titles for conversations.
50
- Please analyze the user's query and create a concise title that accurately reflects the conversation's core topic.
51
- The title must be no more than 5 words long.
52
- Respond with only the title. Do not include any punctuation or extra explanations.`
53
- });
54
- const response = await modelInstance.fetch(messages);
55
- return response.content || DEFAULT_TITLE;
56
- } catch (error) {
57
- _chunk466ED5WNcjs.loggers.intentStream.error("Error generating title", {
58
- error,
59
- query
60
- });
61
- return DEFAULT_TITLE;
62
- }
63
- }
64
- /**
65
- * Main entry point for processing streaming user queries.
66
- *
67
- * Handles the complete query lifecycle:
68
- * 1. Loads or creates thread from memory
69
- * 2. Detects intent from the query
70
- * 3. Fulfills the intent with streaming AI response
71
- * 4. Updates conversation history in real-time
72
- *
73
- * @param threadMetadata - Metadata containing type, userId, and optional threadId
74
- * @param threadMetadata.type - The type of thread (e.g., chat, workflow)
75
- * @param threadMetadata.userId - The user's unique identifier
76
- * @param threadMetadata.threadId - Optional thread identifier
77
- * @param query - The user's input query
78
- * @returns AsyncGenerator yielding StreamEvent objects for SSE
79
- */
80
- async *handleQueryStream(threadMetadata, query, isA2A) {
81
- const { type, userId } = threadMetadata;
82
- const threadMemory = _optionalChain([this, 'access', _ => _.memoryModule, 'optionalAccess', _2 => _2.getThreadMemory, 'call', _3 => _3()]);
83
- let threadId = threadMetadata.threadId;
84
- let thread;
85
- if (threadId) {
86
- thread = await _optionalChain([threadMemory, 'optionalAccess', _4 => _4.getThread, 'call', _5 => _5(userId, threadId)]);
87
- if (!thread && !isA2A) {
88
- throw new (0, _chunkQHQLU7BIcjs.AinHttpError)(_httpstatuscodes.StatusCodes.NOT_FOUND, "Thread not found");
89
- }
90
- }
91
- threadId ??= _crypto.randomUUID.call(void 0, );
92
- if (!thread) {
93
- const title = await this.generateTitle(query);
94
- const metadata = await _optionalChain([threadMemory, 'optionalAccess', _6 => _6.createThread, 'call', _7 => _7(
95
- type,
96
- userId,
97
- threadId,
98
- title
99
- )]) || { type, userId, threadId, title };
100
- thread = { ...metadata, messages: [] };
101
- _chunk466ED5WNcjs.loggers.intent.info(`Create new thread: ${threadId}`);
102
- yield { event: "thread_id", data: { type, userId, threadId, title } };
103
- }
104
- _chunk466ED5WNcjs.loggers.intent.debug("Check intent triggering");
105
- const triggeredIntent = await this.intentTriggerService.intentTriggering(query, thread);
106
- _chunk466ED5WNcjs.loggers.intent.debug(`Triggered intents: ${JSON.stringify(triggeredIntent)}`);
107
- await _optionalChain([threadMemory, 'optionalAccess', _8 => _8.addMessagesToThread, 'call', _9 => _9(userId, threadId, [
108
- {
109
- messageId: _crypto.randomUUID.call(void 0, ),
110
- role: "USER" /* USER */,
111
- timestamp: Date.now(),
112
- content: { type: "text", parts: [query] },
113
- metadata: {
114
- intents: triggeredIntent.filter((intent) => !!intent.intent).map((intent) => ({
115
- id: _optionalChain([intent, 'access', _10 => _10.intent, 'optionalAccess', _11 => _11.id]),
116
- subquery: intent.subquery
117
- }))
118
- }
119
- }
120
- ])]);
121
- const stream = this.intentFulfillStreamService.intentFulfillStream(
122
- triggeredIntent,
123
- thread
124
- );
125
- for await (const event of stream) {
126
- yield event;
127
- }
128
- }
129
- };
130
-
131
-
132
-
133
- exports.QueryStreamService = QueryStreamService;
134
- //# sourceMappingURL=chunk-R3K7LK6W.cjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-R3K7LK6W.cjs","../../src/services/query-stream.service.ts"],"names":[],"mappings":"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","file":"/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-R3K7LK6W.cjs","sourcesContent":[null,"import { randomUUID } from \"node:crypto\";\nimport { StatusCodes } from \"http-status-codes\";\nimport type {\n\tA2AModule,\n\tMCPModule,\n\tMemoryModule,\n\tModelModule,\n} from \"@/modules/index.js\";\nimport { type AinAgentPrompts, AinHttpError } from \"@/types/agent.js\";\nimport {\n\tMessageRole,\n\ttype ThreadMetadata,\n\ttype ThreadObject,\n\ttype ThreadType,\n\ttype TriggeredIntent,\n} from \"@/types/memory.js\";\nimport type { StreamEvent } from \"@/types/stream\";\nimport { loggers } from \"@/utils/logger.js\";\nimport { IntentFulfillStreamService } from \"./intents/fulfill-stream.service\";\nimport { IntentTriggerService } from \"./intents/trigger.service\";\n\n/**\n * Service for processing user queries through the agent's AI pipeline.\n *\n * Orchestrates the query processing workflow including intent detection,\n * model inference, tool execution, and response generation. Manages\n * conversation context and coordinates between different modules.\n */\nexport class QueryStreamService {\n\tprivate modelModule: ModelModule;\n\tprivate memoryModule?: MemoryModule;\n\tprivate intentTriggerService: IntentTriggerService;\n\tprivate intentFulfillStreamService: IntentFulfillStreamService;\n\n\tconstructor(\n\t\tmodelModule: ModelModule,\n\t\ta2aModule?: A2AModule,\n\t\tmcpModule?: MCPModule,\n\t\tmemoryModule?: MemoryModule,\n\t\tprompts?: AinAgentPrompts,\n\t) {\n\t\tthis.modelModule = modelModule;\n\t\tthis.memoryModule = memoryModule;\n\t\tthis.intentTriggerService = new IntentTriggerService(\n\t\t\tmodelModule,\n\t\t\tmemoryModule,\n\t\t);\n\t\tthis.intentFulfillStreamService = new IntentFulfillStreamService(\n\t\t\tmodelModule,\n\t\t\ta2aModule,\n\t\t\tmcpModule,\n\t\t\tmemoryModule,\n\t\t\tprompts,\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 streaming user queries.\n\t *\n\t * Handles the complete query lifecycle:\n\t * 1. Loads or creates thread from memory\n\t * 2. Detects intent from the query\n\t * 3. Fulfills the intent with streaming AI response\n\t * 4. Updates conversation history in real-time\n\t *\n\t * @param threadMetadata - Metadata containing type, userId, and optional threadId\n\t * @param threadMetadata.type - The type of thread (e.g., chat, workflow)\n\t * @param threadMetadata.userId - The user's unique identifier\n\t * @param threadMetadata.threadId - Optional thread identifier\n\t * @param query - The user's input query\n\t * @returns AsyncGenerator yielding StreamEvent objects for SSE\n\t */\n\tpublic async *handleQueryStream(\n\t\tthreadMetadata: {\n\t\t\ttype: ThreadType;\n\t\t\tuserId: string;\n\t\t\tthreadId?: string;\n\t\t},\n\t\tquery: string,\n\t\tisA2A?: boolean,\n\t): AsyncGenerator<StreamEvent> {\n\t\tconst { type, userId } = threadMetadata;\n\t\tconst threadMemory = this.memoryModule?.getThreadMemory();\n\n\t\t// 1. Load or create thread\n\t\tlet threadId = threadMetadata.threadId;\n\t\tlet thread: ThreadObject | undefined;\n\t\tif (threadId) {\n\t\t\tthread = await threadMemory?.getThread(userId, threadId);\n\t\t\tif (!thread && !isA2A) {\n\t\t\t\tthrow new AinHttpError(StatusCodes.NOT_FOUND, \"Thread not found\");\n\t\t\t}\n\t\t}\n\n\t\tthreadId ??= randomUUID();\n\t\tif (!thread) {\n\t\t\tconst title = await this.generateTitle(query);\n\t\t\tconst metadata: ThreadMetadata = (await threadMemory?.createThread(\n\t\t\t\ttype,\n\t\t\t\tuserId,\n\t\t\t\tthreadId,\n\t\t\t\ttitle,\n\t\t\t)) || { type, userId, threadId, title };\n\t\t\tthread = { ...metadata, messages: [] };\n\t\t\tloggers.intent.info(`Create new thread: ${threadId}`);\n\t\t\tyield { event: \"thread_id\", data: { type, userId, threadId, title } };\n\t\t}\n\n\t\tloggers.intent.debug(\"Check intent triggering\");\n\n\t\t// 2. intent triggering\n\t\tconst triggeredIntent: Array<TriggeredIntent> =\n\t\t\tawait this.intentTriggerService.intentTriggering(query, thread);\n\n\t\tloggers.intent.debug(`Triggered intents: ${JSON.stringify(triggeredIntent)}`);\n\n\t\t// only add for storage, not for inference\n\t\tawait threadMemory?.addMessagesToThread(userId, threadId, [\n\t\t\t{\n\t\t\t\tmessageId: randomUUID(),\n\t\t\t\trole: MessageRole.USER,\n\t\t\t\ttimestamp: Date.now(),\n\t\t\t\tcontent: { type: \"text\", parts: [query] },\n\t\t\t\tmetadata: {\n\t\t\t\t\tintents: triggeredIntent\n\t\t\t\t\t\t.filter((intent) => !!intent.intent)\n\t\t\t\t\t\t.map((intent) => ({\n\t\t\t\t\t\t\tid: intent.intent?.id,\n\t\t\t\t\t\t\tsubquery: intent.subquery,\n\t\t\t\t\t\t})),\n\t\t\t\t},\n\t\t\t},\n\t\t]);\n\n\t\t// 3. intent fulfillment\n\t\tconst stream = this.intentFulfillStreamService.intentFulfillStream(\n\t\t\ttriggeredIntent,\n\t\t\tthread,\n\t\t);\n\n\t\tfor await (const event of stream) {\n\t\t\tyield event;\n\t\t}\n\t}\n}\n"]}
@@ -1,37 +0,0 @@
1
- "use strict";Object.defineProperty(exports, "__esModule", {value: true});
2
-
3
- var _chunkBDQDZXZIcjs = require('./chunk-BDQDZXZI.cjs');
4
-
5
-
6
- var _chunkT7444BWHcjs = require('./chunk-T7444BWH.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 queryStreamService = new (0, _chunkT7444BWHcjs.QueryStreamService)(
18
- agent.modelModule,
19
- agent.a2aModule,
20
- agent.mcpModule,
21
- agent.memoryModule,
22
- agent.manifest.prompts
23
- );
24
- const a2aService = new (0, _chunkBDQDZXZIcjs.A2AService)(queryStreamService);
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-SH6JCUEJ.cjs.map
@@ -1,134 +0,0 @@
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 _chunkG3KWCMMQcjs = require('./chunk-G3KWCMMQ.cjs');
4
-
5
-
6
- var _chunkTILUFTIGcjs = require('./chunk-TILUFTIG.cjs');
7
-
8
-
9
- var _chunkQHQLU7BIcjs = require('./chunk-QHQLU7BI.cjs');
10
-
11
-
12
- var _chunk466ED5WNcjs = require('./chunk-466ED5WN.cjs');
13
-
14
- // src/services/query-stream.service.ts
15
- var _crypto = require('crypto');
16
- var _httpstatuscodes = require('http-status-codes');
17
- var QueryStreamService = class {
18
-
19
-
20
-
21
-
22
- constructor(modelModule, a2aModule, mcpModule, memoryModule, prompts) {
23
- this.modelModule = modelModule;
24
- this.memoryModule = memoryModule;
25
- this.intentTriggerService = new (0, _chunkTILUFTIGcjs.IntentTriggerService)(
26
- modelModule,
27
- memoryModule
28
- );
29
- this.intentFulfillStreamService = new (0, _chunkG3KWCMMQcjs.IntentFulfillStreamService)(
30
- modelModule,
31
- a2aModule,
32
- mcpModule,
33
- memoryModule,
34
- prompts
35
- );
36
- }
37
- /**
38
- * Generates a title for the conversation based on the query.
39
- *
40
- * @param query - The user's input query
41
- * @returns Promise resolving to a generated title
42
- */
43
- async generateTitle(query) {
44
- const DEFAULT_TITLE = "New Chat";
45
- try {
46
- const modelInstance = this.modelModule.getModel();
47
- const messages = modelInstance.generateMessages({
48
- query,
49
- systemPrompt: `You are a helpful assistant that generates titles for conversations.
50
- Please analyze the user's query and create a concise title that accurately reflects the conversation's core topic.
51
- The title must be no more than 5 words long.
52
- Respond with only the title. Do not include any punctuation or extra explanations.`
53
- });
54
- const response = await modelInstance.fetch(messages);
55
- return response.content || DEFAULT_TITLE;
56
- } catch (error) {
57
- _chunk466ED5WNcjs.loggers.intentStream.error("Error generating title", {
58
- error,
59
- query
60
- });
61
- return DEFAULT_TITLE;
62
- }
63
- }
64
- /**
65
- * Main entry point for processing streaming user queries.
66
- *
67
- * Handles the complete query lifecycle:
68
- * 1. Loads or creates thread from memory
69
- * 2. Detects intent from the query
70
- * 3. Fulfills the intent with streaming AI response
71
- * 4. Updates conversation history in real-time
72
- *
73
- * @param threadMetadata - Metadata containing type, userId, and optional threadId
74
- * @param threadMetadata.type - The type of thread (e.g., chat, workflow)
75
- * @param threadMetadata.userId - The user's unique identifier
76
- * @param threadMetadata.threadId - Optional thread identifier
77
- * @param query - The user's input query
78
- * @returns AsyncGenerator yielding StreamEvent objects for SSE
79
- */
80
- async *handleQueryStream(threadMetadata, query, isA2A) {
81
- const { type, userId } = threadMetadata;
82
- const threadMemory = _optionalChain([this, 'access', _ => _.memoryModule, 'optionalAccess', _2 => _2.getThreadMemory, 'call', _3 => _3()]);
83
- let threadId = threadMetadata.threadId;
84
- let thread;
85
- if (threadId) {
86
- thread = await _optionalChain([threadMemory, 'optionalAccess', _4 => _4.getThread, 'call', _5 => _5(userId, threadId)]);
87
- if (!thread && !isA2A) {
88
- throw new (0, _chunkQHQLU7BIcjs.AinHttpError)(_httpstatuscodes.StatusCodes.NOT_FOUND, "Thread not found");
89
- }
90
- }
91
- threadId ??= _crypto.randomUUID.call(void 0, );
92
- if (!thread) {
93
- const title = await this.generateTitle(query);
94
- const metadata = await _optionalChain([threadMemory, 'optionalAccess', _6 => _6.createThread, 'call', _7 => _7(
95
- type,
96
- userId,
97
- threadId,
98
- title
99
- )]) || { type, userId, threadId, title };
100
- thread = { ...metadata, messages: [] };
101
- _chunk466ED5WNcjs.loggers.intent.info(`Create new thread: ${threadId}`);
102
- yield { event: "thread_id", data: { type, userId, threadId, title } };
103
- }
104
- _chunk466ED5WNcjs.loggers.intent.debug("Check intent triggering");
105
- const triggeredIntent = await this.intentTriggerService.intentTriggering(query, thread);
106
- _chunk466ED5WNcjs.loggers.intent.debug(`Triggered intents: ${JSON.stringify(triggeredIntent)}`);
107
- await _optionalChain([threadMemory, 'optionalAccess', _8 => _8.addMessagesToThread, 'call', _9 => _9(userId, threadId, [
108
- {
109
- messageId: _crypto.randomUUID.call(void 0, ),
110
- role: "USER" /* USER */,
111
- timestamp: Date.now(),
112
- content: { type: "text", parts: [query] },
113
- metadata: {
114
- intents: triggeredIntent.filter((intent) => !!intent.intent).map((intent) => ({
115
- id: _optionalChain([intent, 'access', _10 => _10.intent, 'optionalAccess', _11 => _11.id]),
116
- subquery: intent.subquery
117
- }))
118
- }
119
- }
120
- ])]);
121
- const stream = this.intentFulfillStreamService.intentFulfillStream(
122
- triggeredIntent,
123
- thread
124
- );
125
- for await (const event of stream) {
126
- yield event;
127
- }
128
- }
129
- };
130
-
131
-
132
-
133
- exports.QueryStreamService = QueryStreamService;
134
- //# sourceMappingURL=chunk-T7444BWH.cjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-T7444BWH.cjs","../../src/services/query-stream.service.ts"],"names":[],"mappings":"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","file":"/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-T7444BWH.cjs","sourcesContent":[null,"import { randomUUID } from \"node:crypto\";\nimport { StatusCodes } from \"http-status-codes\";\nimport type {\n\tA2AModule,\n\tMCPModule,\n\tMemoryModule,\n\tModelModule,\n} from \"@/modules/index.js\";\nimport { type AinAgentPrompts, AinHttpError } from \"@/types/agent.js\";\nimport {\n\tMessageRole,\n\ttype ThreadMetadata,\n\ttype ThreadObject,\n\ttype ThreadType,\n\ttype TriggeredIntent,\n} from \"@/types/memory.js\";\nimport type { StreamEvent } from \"@/types/stream\";\nimport { loggers } from \"@/utils/logger.js\";\nimport { IntentFulfillStreamService } from \"./intents/fulfill-stream.service\";\nimport { IntentTriggerService } from \"./intents/trigger.service\";\n\n/**\n * Service for processing user queries through the agent's AI pipeline.\n *\n * Orchestrates the query processing workflow including intent detection,\n * model inference, tool execution, and response generation. Manages\n * conversation context and coordinates between different modules.\n */\nexport class QueryStreamService {\n\tprivate modelModule: ModelModule;\n\tprivate memoryModule?: MemoryModule;\n\tprivate intentTriggerService: IntentTriggerService;\n\tprivate intentFulfillStreamService: IntentFulfillStreamService;\n\n\tconstructor(\n\t\tmodelModule: ModelModule,\n\t\ta2aModule?: A2AModule,\n\t\tmcpModule?: MCPModule,\n\t\tmemoryModule?: MemoryModule,\n\t\tprompts?: AinAgentPrompts,\n\t) {\n\t\tthis.modelModule = modelModule;\n\t\tthis.memoryModule = memoryModule;\n\t\tthis.intentTriggerService = new IntentTriggerService(\n\t\t\tmodelModule,\n\t\t\tmemoryModule,\n\t\t);\n\t\tthis.intentFulfillStreamService = new IntentFulfillStreamService(\n\t\t\tmodelModule,\n\t\t\ta2aModule,\n\t\t\tmcpModule,\n\t\t\tmemoryModule,\n\t\t\tprompts,\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 streaming user queries.\n\t *\n\t * Handles the complete query lifecycle:\n\t * 1. Loads or creates thread from memory\n\t * 2. Detects intent from the query\n\t * 3. Fulfills the intent with streaming AI response\n\t * 4. Updates conversation history in real-time\n\t *\n\t * @param threadMetadata - Metadata containing type, userId, and optional threadId\n\t * @param threadMetadata.type - The type of thread (e.g., chat, workflow)\n\t * @param threadMetadata.userId - The user's unique identifier\n\t * @param threadMetadata.threadId - Optional thread identifier\n\t * @param query - The user's input query\n\t * @returns AsyncGenerator yielding StreamEvent objects for SSE\n\t */\n\tpublic async *handleQueryStream(\n\t\tthreadMetadata: {\n\t\t\ttype: ThreadType;\n\t\t\tuserId: string;\n\t\t\tthreadId?: string;\n\t\t},\n\t\tquery: string,\n\t\tisA2A?: boolean,\n\t): AsyncGenerator<StreamEvent> {\n\t\tconst { type, userId } = threadMetadata;\n\t\tconst threadMemory = this.memoryModule?.getThreadMemory();\n\n\t\t// 1. Load or create thread\n\t\tlet threadId = threadMetadata.threadId;\n\t\tlet thread: ThreadObject | undefined;\n\t\tif (threadId) {\n\t\t\tthread = await threadMemory?.getThread(userId, threadId);\n\t\t\tif (!thread && !isA2A) {\n\t\t\t\tthrow new AinHttpError(StatusCodes.NOT_FOUND, \"Thread not found\");\n\t\t\t}\n\t\t}\n\n\t\tthreadId ??= randomUUID();\n\t\tif (!thread) {\n\t\t\tconst title = await this.generateTitle(query);\n\t\t\tconst metadata: ThreadMetadata = (await threadMemory?.createThread(\n\t\t\t\ttype,\n\t\t\t\tuserId,\n\t\t\t\tthreadId,\n\t\t\t\ttitle,\n\t\t\t)) || { type, userId, threadId, title };\n\t\t\tthread = { ...metadata, messages: [] };\n\t\t\tloggers.intent.info(`Create new thread: ${threadId}`);\n\t\t\tyield { event: \"thread_id\", data: { type, userId, threadId, title } };\n\t\t}\n\n\t\tloggers.intent.debug(\"Check intent triggering\");\n\n\t\t// 2. intent triggering\n\t\tconst triggeredIntent: Array<TriggeredIntent> =\n\t\t\tawait this.intentTriggerService.intentTriggering(query, thread);\n\n\t\tloggers.intent.debug(`Triggered intents: ${JSON.stringify(triggeredIntent)}`);\n\n\t\t// only add for storage, not for inference\n\t\tawait threadMemory?.addMessagesToThread(userId, threadId, [\n\t\t\t{\n\t\t\t\tmessageId: randomUUID(),\n\t\t\t\trole: MessageRole.USER,\n\t\t\t\ttimestamp: Date.now(),\n\t\t\t\tcontent: { type: \"text\", parts: [query] },\n\t\t\t\tmetadata: {\n\t\t\t\t\tintents: triggeredIntent\n\t\t\t\t\t\t.filter((intent) => !!intent.intent)\n\t\t\t\t\t\t.map((intent) => ({\n\t\t\t\t\t\t\tid: intent.intent?.id,\n\t\t\t\t\t\t\tsubquery: intent.subquery,\n\t\t\t\t\t\t})),\n\t\t\t\t},\n\t\t\t},\n\t\t]);\n\n\t\t// 3. intent fulfillment\n\t\tconst stream = this.intentFulfillStreamService.intentFulfillStream(\n\t\t\ttriggeredIntent,\n\t\t\tthread,\n\t\t);\n\n\t\tfor await (const event of stream) {\n\t\t\tyield event;\n\t\t}\n\t}\n}\n"]}
@@ -1,111 +0,0 @@
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/intents/trigger.service.ts
6
- var IntentTriggerService = class {
7
-
8
-
9
- constructor(modelModule, memoryModule) {
10
- this.modelModule = modelModule;
11
- this.memoryModule = memoryModule;
12
- }
13
- /**
14
- * Detects the intent from context.
15
- *
16
- * @param query - The user's input query
17
- * @param thread - The thread history
18
- * @returns The detected intent
19
- */
20
- async intentTriggering(query, thread) {
21
- const modelInstance = this.modelModule.getModel();
22
- const intentMemory = _optionalChain([this, 'access', _ => _.memoryModule, 'optionalAccess', _2 => _2.getIntentMemory, 'call', _3 => _3()]);
23
- if (!intentMemory) {
24
- return [{ subquery: query }];
25
- }
26
- const intents = await intentMemory.listIntents();
27
- if (intents.length === 0) {
28
- _chunk466ED5WNcjs.loggers.intentStream.warn("No intent found");
29
- return [{ subquery: query }];
30
- }
31
- const intentList = intents.map((intent) => `- ${intent.name}: ${intent.description}`).join("\n");
32
- const threadMessages = !thread ? "" : thread.messages.sort((a, b) => a.timestamp - b.timestamp).map((message) => {
33
- const role = message.role === "USER" ? "User" : message.role === "MODEL" ? "Assistant" : "System";
34
- const content = Array.isArray(message.content.parts) ? message.content.parts.join(" ") : String(message.content.parts);
35
- return `${role}: """${content}"""`;
36
- }).join("\n");
37
- const systemPrompt = `You are an expert in accurately identifying user intentions.
38
-
39
- Available intent list:
40
- ${intentList}
41
-
42
- Please select and answer only from the above intent list.
43
- Please return only the exact intent name without any additional explanations or text.`;
44
- const userMessage = `The following is the conversation history with the user:
45
-
46
- ${threadMessages}
47
-
48
- Last user question: "${query}"
49
-
50
- Based on the above conversation history, analyze the last user question and identify all relevant intents.
51
-
52
- Instructions:
53
- 1. First, decompose the last user question into action-based subqueries (each representing a distinct action or task)
54
- 2. Then, map each subquery to its corresponding intent from the available intent list
55
- 3. For each subquery, provide a 2-3 sentence summary of what actions will be performed
56
- 4. Multiple intents can be identified if the question covers various topics or actions
57
- 5. Maintain the logical sequence of the original question when splitting into subqueries
58
-
59
- Output Format:
60
- You MUST return the output in the following JSON format. Do not include any other text before or after the JSON:
61
- [
62
- {
63
- "subquery": "<subquery_1>",
64
- "intentName": "<intent_name_1>",
65
- "actionPlan": "<2-3 sentence description of what will be done for this subquery>"
66
- },
67
- {
68
- "subquery": "<subquery_2>",
69
- "intentName": "<intent_name_2>",
70
- "actionPlan": "<2-3 sentence description of what will be done for this subquery>"
71
- },
72
- ...
73
- ]
74
-
75
- Requirements:
76
- - Each subquery should represent a single, actionable task or request
77
- - Preserve the original meaning and context when splitting queries
78
- - Select only from the provided intent list
79
- - DO NOT set intentName for any subquery that doesn't match available intents.`;
80
- const messages = modelInstance.generateMessages({
81
- query: userMessage,
82
- systemPrompt
83
- });
84
- const response = await modelInstance.fetch(messages);
85
- if (!response.content) {
86
- _chunk466ED5WNcjs.loggers.intent.warn("Cannot extract intent from query");
87
- return [{ subquery: query }];
88
- }
89
- _chunk466ED5WNcjs.loggers.intent.debug(`Intent triggering response: ${response.content}`);
90
- let subqueries;
91
- try {
92
- subqueries = JSON.parse(response.content);
93
- } catch (error) {
94
- subqueries = [{ subquery: query }];
95
- }
96
- const triggeredIntent = [];
97
- for (const { subquery, intentName, actionPlan } of subqueries) {
98
- const item = { subquery, actionPlan };
99
- if (intentName) {
100
- item.intent = await intentMemory.getIntentByName(intentName);
101
- }
102
- triggeredIntent.push(item);
103
- }
104
- return triggeredIntent;
105
- }
106
- };
107
-
108
-
109
-
110
- exports.IntentTriggerService = IntentTriggerService;
111
- //# sourceMappingURL=chunk-TILUFTIG.cjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-TILUFTIG.cjs","../../src/services/intents/trigger.service.ts"],"names":[],"mappings":"AAAA;AACE;AACF,wDAA6B;AAC7B;AACA;ACIO,IAAM,qBAAA,EAAN,MAA2B;AAAA,EACzB;AAAA,EACA;AAAA,EAER,WAAA,CAAY,WAAA,EAA0B,YAAA,EAA6B;AAClE,IAAA,IAAA,CAAK,YAAA,EAAc,WAAA;AACnB,IAAA,IAAA,CAAK,aAAA,EAAe,YAAA;AAAA,EACrB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASA,MAAa,gBAAA,CACZ,KAAA,EACA,MAAA,EACkC;AAClC,IAAA,MAAM,cAAA,EAAgB,IAAA,CAAK,WAAA,CAAY,QAAA,CAAS,CAAA;AAChD,IAAA,MAAM,aAAA,kBAAe,IAAA,mBAAK,YAAA,6BAAc,eAAA,mBAAgB,GAAA;AACxD,IAAA,GAAA,CAAI,CAAC,YAAA,EAAc;AAClB,MAAA,OAAO,CAAC,EAAE,QAAA,EAAU,MAAM,CAAC,CAAA;AAAA,IAC5B;AAGA,IAAA,MAAM,QAAA,EAAU,MAAM,YAAA,CAAa,WAAA,CAAY,CAAA;AAE/C,IAAA,GAAA,CAAI,OAAA,CAAQ,OAAA,IAAW,CAAA,EAAG;AACzB,MAAA,yBAAA,CAAQ,YAAA,CAAa,IAAA,CAAK,iBAAiB,CAAA;AAC3C,MAAA,OAAO,CAAC,EAAE,QAAA,EAAU,MAAM,CAAC,CAAA;AAAA,IAC5B;AAEA,IAAA,MAAM,WAAA,EAAa,OAAA,CACjB,GAAA,CAAI,CAAC,MAAA,EAAA,GAAW,CAAA,EAAA,EAAK,MAAA,CAAO,IAAI,CAAA,EAAA,EAAK,MAAA,CAAO,WAAW,CAAA,CAAA;AAOxB,IAAA;AAMxB,MAAA;AAGoB,MAAA;AAEI,MAAA;AAEpB,IAAA;AAEQ,IAAA;AAAA;AAAA;AAGX;AAAA;AAAA;AAAA,qFAAA;AAKU,IAAA;AAAA;AAEN;AAAA;AAEY,qBAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,8EAAA;AAiCsB,IAAA;AACxC,MAAA;AACP,MAAA;AACA,IAAA;AAEkD,IAAA;AAC5B,IAAA;AACgC,MAAA;AAC3B,MAAA;AAC5B,IAAA;AAEsE,IAAA;AAElE,IAAA;AACA,IAAA;AACqC,MAAA;AACzB,IAAA;AACkB,MAAA;AAClC,IAAA;AAEiD,IAAA;AACc,IAAA;AAC1B,MAAA;AACpB,MAAA;AAC4C,QAAA;AAC5D,MAAA;AACyB,MAAA;AAC1B,IAAA;AAEO,IAAA;AACR,EAAA;AACD;ADnCuF;AACA;AACA;AACA","file":"/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-TILUFTIG.cjs","sourcesContent":[null,"import type { MemoryModule, ModelModule } from \"@/modules\";\nimport type {\n\tMessageObject,\n\tThreadObject,\n\tTriggeredIntent,\n} from \"@/types/memory\";\nimport { loggers } from \"@/utils/logger\";\n\nexport class IntentTriggerService {\n\tprivate modelModule: ModelModule;\n\tprivate memoryModule?: MemoryModule;\n\n\tconstructor(modelModule: ModelModule, memoryModule?: MemoryModule) {\n\t\tthis.modelModule = modelModule;\n\t\tthis.memoryModule = memoryModule;\n\t}\n\n\t/**\n\t * Detects the intent from context.\n\t *\n\t * @param query - The user's input query\n\t * @param thread - The thread history\n\t * @returns The detected intent\n\t */\n\tpublic async intentTriggering(\n\t\tquery: string,\n\t\tthread: ThreadObject | undefined,\n\t): Promise<Array<TriggeredIntent>> {\n\t\tconst modelInstance = this.modelModule.getModel();\n\t\tconst intentMemory = this.memoryModule?.getIntentMemory();\n\t\tif (!intentMemory) {\n\t\t\treturn [{ subquery: query }];\n\t\t}\n\n\t\t// 인텐트 목록 가져오기\n\t\tconst intents = await intentMemory.listIntents();\n\n\t\tif (intents.length === 0) {\n\t\t\tloggers.intentStream.warn(\"No intent found\");\n\t\t\treturn [{ subquery: query }];\n\t\t}\n\n\t\tconst intentList = intents\n\t\t\t.map((intent) => `- ${intent.name}: ${intent.description}`)\n\t\t\t.join(\"\\n\");\n\n\t\t// Convert thread messages to a string\n\t\tconst threadMessages = !thread\n\t\t\t? \"\"\n\t\t\t: thread.messages\n\t\t\t\t\t.sort((a, b) => a.timestamp - b.timestamp)\n\t\t\t\t\t.map((message: MessageObject) => {\n\t\t\t\t\t\tconst role =\n\t\t\t\t\t\t\tmessage.role === \"USER\"\n\t\t\t\t\t\t\t\t? \"User\"\n\t\t\t\t\t\t\t\t: message.role === \"MODEL\"\n\t\t\t\t\t\t\t\t\t? \"Assistant\"\n\t\t\t\t\t\t\t\t\t: \"System\";\n\t\t\t\t\t\tconst content = Array.isArray(message.content.parts)\n\t\t\t\t\t\t\t? message.content.parts.join(\" \")\n\t\t\t\t\t\t\t: String(message.content.parts);\n\t\t\t\t\t\treturn `${role}: \"\"\"${content}\"\"\"`;\n\t\t\t\t\t})\n\t\t\t\t\t.join(\"\\n\");\n\n\t\tconst systemPrompt = `You are an expert in accurately identifying user intentions.\n\nAvailable intent list:\n${intentList}\n\nPlease select and answer only from the above intent list. \nPlease return only the exact intent name without any additional explanations or text.`;\n\n\t\tconst userMessage = `The following is the conversation history with the user:\n\n${threadMessages}\n\nLast user question: \"${query}\"\n\nBased on the above conversation history, analyze the last user question and identify all relevant intents.\n\nInstructions:\n1. First, decompose the last user question into action-based subqueries (each representing a distinct action or task)\n2. Then, map each subquery to its corresponding intent from the available intent list\n3. For each subquery, provide a 2-3 sentence summary of what actions will be performed\n4. Multiple intents can be identified if the question covers various topics or actions\n5. Maintain the logical sequence of the original question when splitting into subqueries\n\nOutput Format:\nYou MUST return the output in the following JSON format. Do not include any other text before or after the JSON:\n[\n {\n \"subquery\": \"<subquery_1>\",\n \"intentName\": \"<intent_name_1>\",\n\t\t\"actionPlan\": \"<2-3 sentence description of what will be done for this subquery>\"\n\t},\n {\n \"subquery\": \"<subquery_2>\",\n \"intentName\": \"<intent_name_2>\",\n\t\t\"actionPlan\": \"<2-3 sentence description of what will be done for this subquery>\"\n },\n ...\n]\n\nRequirements:\n- Each subquery should represent a single, actionable task or request\n- Preserve the original meaning and context when splitting queries\n- Select only from the provided intent list\n- DO NOT set intentName for any subquery that doesn't match available intents.`;\n\n\t\tconst messages = modelInstance.generateMessages({\n\t\t\tquery: userMessage,\n\t\t\tsystemPrompt,\n\t\t});\n\n\t\tconst response = await modelInstance.fetch(messages);\n\t\tif (!response.content) {\n\t\t\tloggers.intent.warn(\"Cannot extract intent from query\");\n\t\t\treturn [{ subquery: query }];\n\t\t}\n\n\t\tloggers.intent.debug(`Intent triggering response: ${response.content}`);\n\n\t\tlet subqueries: any;\n\t\ttry {\n\t\t\tsubqueries = JSON.parse(response.content);\n\t\t} catch (error) {\n\t\t\tsubqueries = [{ subquery: query }];\n\t\t}\n\n\t\tconst triggeredIntent: Array<TriggeredIntent> = [];\n\t\tfor (const { subquery, intentName, actionPlan } of subqueries) {\n\t\t\tconst item = { subquery, actionPlan } as TriggeredIntent;\n\t\t\tif (intentName) {\n\t\t\t\titem.intent = await intentMemory.getIntentByName(intentName);\n\t\t\t}\n\t\t\ttriggeredIntent.push(item);\n\t\t}\n\n\t\treturn triggeredIntent;\n\t}\n}\n"]}
@@ -1,37 +0,0 @@
1
- "use strict";Object.defineProperty(exports, "__esModule", {value: true});
2
-
3
- var _chunkBDQDZXZIcjs = require('./chunk-BDQDZXZI.cjs');
4
-
5
-
6
- var _chunkR3K7LK6Wcjs = require('./chunk-R3K7LK6W.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 queryStreamService = new (0, _chunkR3K7LK6Wcjs.QueryStreamService)(
18
- agent.modelModule,
19
- agent.a2aModule,
20
- agent.mcpModule,
21
- agent.memoryModule,
22
- agent.manifest.prompts
23
- );
24
- const a2aService = new (0, _chunkBDQDZXZIcjs.A2AService)(queryStreamService);
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-VRCXZ4LV.cjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-VRCXZ4LV.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,mBAAA,EAAqB,IAAI,yCAAA;AAAA,IAC9B,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,kBAAkB,CAAA;AACpD,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-VRCXZ4LV.cjs","sourcesContent":[null,"import { InMemoryTaskStore } from \"@a2a-js/sdk/server\";\nimport { Router } from \"express\";\nimport type { AINAgent } from \"@/index.js\";\nimport { QueryStreamService } from \"@/services/query-stream.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 queryStreamService = new QueryStreamService(\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(queryStreamService);\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"]}
@@ -1,37 +0,0 @@
1
- "use strict";Object.defineProperty(exports, "__esModule", {value: true});
2
-
3
- var _chunkBDQDZXZIcjs = require('./chunk-BDQDZXZI.cjs');
4
-
5
-
6
- var _chunk3X2EKOWCcjs = require('./chunk-3X2EKOWC.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 queryStreamService = new (0, _chunk3X2EKOWCcjs.QueryStreamService)(
18
- agent.modelModule,
19
- agent.a2aModule,
20
- agent.mcpModule,
21
- agent.memoryModule,
22
- agent.manifest.prompts
23
- );
24
- const a2aService = new (0, _chunkBDQDZXZIcjs.A2AService)(queryStreamService);
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-WGSFHDDZ.cjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-WGSFHDDZ.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,mBAAA,EAAqB,IAAI,yCAAA;AAAA,IAC9B,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,kBAAkB,CAAA;AACpD,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-WGSFHDDZ.cjs","sourcesContent":[null,"import { InMemoryTaskStore } from \"@a2a-js/sdk/server\";\nimport { Router } from \"express\";\nimport type { AINAgent } from \"@/index.js\";\nimport { QueryStreamService } from \"@/services/query-stream.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 queryStreamService = new QueryStreamService(\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(queryStreamService);\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"]}
@@ -1 +0,0 @@
1
- {"version":3,"sources":["/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-X7FADTCP.cjs","../../src/services/intents/trigger.service.ts"],"names":[],"mappings":"AAAA;AACE;AACF,wDAA6B;AAC7B;AACA;ACIO,IAAM,qBAAA,EAAN,MAA2B;AAAA,EACzB;AAAA,EACA;AAAA,EAER,WAAA,CAAY,WAAA,EAA0B,YAAA,EAA6B;AAClE,IAAA,IAAA,CAAK,YAAA,EAAc,WAAA;AACnB,IAAA,IAAA,CAAK,aAAA,EAAe,YAAA;AAAA,EACrB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASA,MAAa,gBAAA,CACZ,KAAA,EACA,MAAA,EACkC;AAClC,IAAA,MAAM,cAAA,EAAgB,IAAA,CAAK,WAAA,CAAY,QAAA,CAAS,CAAA;AAChD,IAAA,MAAM,aAAA,kBAAe,IAAA,mBAAK,YAAA,6BAAc,eAAA,mBAAgB,GAAA;AACxD,IAAA,GAAA,CAAI,CAAC,YAAA,EAAc;AAClB,MAAA,OAAO,CAAC,EAAE,QAAA,EAAU,MAAM,CAAC,CAAA;AAAA,IAC5B;AAGA,IAAA,MAAM,QAAA,EAAU,MAAM,YAAA,CAAa,WAAA,CAAY,CAAA;AAE/C,IAAA,GAAA,CAAI,OAAA,CAAQ,OAAA,IAAW,CAAA,EAAG;AACzB,MAAA,yBAAA,CAAQ,YAAA,CAAa,IAAA,CAAK,iBAAiB,CAAA;AAC3C,MAAA,OAAO,CAAC,EAAE,QAAA,EAAU,MAAM,CAAC,CAAA;AAAA,IAC5B;AAEA,IAAA,MAAM,WAAA,EAAa,OAAA,CACjB,GAAA,CAAI,CAAC,MAAA,EAAA,GAAW,CAAA,EAAA,EAAK,MAAA,CAAO,IAAI,CAAA,EAAA,EAAK,MAAA,CAAO,WAAW,CAAA,CAAA;AAOxB,IAAA;AAMxB,MAAA;AAGoB,MAAA;AAEI,MAAA;AAEpB,IAAA;AAEQ,IAAA;AAAA;AAAA;AAGX;AAAA;AAAA;AAAA,qFAAA;AAKU,IAAA;AAAA;AAEN;AAAA;AAEY,qBAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,8EAAA;AAiCsB,IAAA;AACxC,MAAA;AACP,MAAA;AACA,IAAA;AAEkD,IAAA;AAC5B,IAAA;AACgC,MAAA;AAC3B,MAAA;AAC5B,IAAA;AAEI,IAAA;AACA,IAAA;AACqC,MAAA;AAChB,IAAA;AACG,MAAA;AAC5B,IAAA;AAEiD,IAAA;AACc,IAAA;AAC1B,MAAA;AACpB,MAAA;AAC4C,QAAA;AAC5D,MAAA;AACyB,MAAA;AAC1B,IAAA;AAEO,IAAA;AACR,EAAA;AACD;ADlCuF;AACA;AACA;AACA","file":"/Users/shyun/comcom/ain-agent/ain-adk/dist/cjs/chunk-X7FADTCP.cjs","sourcesContent":[null,"import type { MemoryModule, ModelModule } from \"@/modules\";\nimport type {\n\tMessageObject,\n\tThreadObject,\n\tTriggeredIntent,\n} from \"@/types/memory\";\nimport { loggers } from \"@/utils/logger\";\n\nexport class IntentTriggerService {\n\tprivate modelModule: ModelModule;\n\tprivate memoryModule?: MemoryModule;\n\n\tconstructor(modelModule: ModelModule, memoryModule?: MemoryModule) {\n\t\tthis.modelModule = modelModule;\n\t\tthis.memoryModule = memoryModule;\n\t}\n\n\t/**\n\t * Detects the intent from context.\n\t *\n\t * @param query - The user's input query\n\t * @param thread - The thread history\n\t * @returns The detected intent\n\t */\n\tpublic async intentTriggering(\n\t\tquery: string,\n\t\tthread: ThreadObject | undefined,\n\t): Promise<Array<TriggeredIntent>> {\n\t\tconst modelInstance = this.modelModule.getModel();\n\t\tconst intentMemory = this.memoryModule?.getIntentMemory();\n\t\tif (!intentMemory) {\n\t\t\treturn [{ subquery: query }];\n\t\t}\n\n\t\t// 인텐트 목록 가져오기\n\t\tconst intents = await intentMemory.listIntents();\n\n\t\tif (intents.length === 0) {\n\t\t\tloggers.intentStream.warn(\"No intent found\");\n\t\t\treturn [{ subquery: query }];\n\t\t}\n\n\t\tconst intentList = intents\n\t\t\t.map((intent) => `- ${intent.name}: ${intent.description}`)\n\t\t\t.join(\"\\n\");\n\n\t\t// Convert thread messages to a string\n\t\tconst threadMessages = !thread\n\t\t\t? \"\"\n\t\t\t: thread.messages\n\t\t\t\t\t.sort((a, b) => a.timestamp - b.timestamp)\n\t\t\t\t\t.map((message: MessageObject) => {\n\t\t\t\t\t\tconst role =\n\t\t\t\t\t\t\tmessage.role === \"USER\"\n\t\t\t\t\t\t\t\t? \"User\"\n\t\t\t\t\t\t\t\t: message.role === \"MODEL\"\n\t\t\t\t\t\t\t\t\t? \"Assistant\"\n\t\t\t\t\t\t\t\t\t: \"System\";\n\t\t\t\t\t\tconst content = Array.isArray(message.content.parts)\n\t\t\t\t\t\t\t? message.content.parts.join(\" \")\n\t\t\t\t\t\t\t: String(message.content.parts);\n\t\t\t\t\t\treturn `${role}: \"\"\"${content}\"\"\"`;\n\t\t\t\t\t})\n\t\t\t\t\t.join(\"\\n\");\n\n\t\tconst systemPrompt = `You are an expert in accurately identifying user intentions.\n\nAvailable intent list:\n${intentList}\n\nPlease select and answer only from the above intent list. \nPlease return only the exact intent name without any additional explanations or text.`;\n\n\t\tconst userMessage = `The following is the conversation history with the user:\n\n${threadMessages}\n\nLast user question: \"${query}\"\n\nBased on the above conversation history, analyze the last user question and identify all relevant intents.\n\nInstructions:\n1. First, decompose the last user question into action-based subqueries (each representing a distinct action or task)\n2. Then, map each subquery to its corresponding intent from the available intent list\n3. For each subquery, provide a 2-3 sentence summary of what actions will be performed\n4. Multiple intents can be identified if the question covers various topics or actions\n5. Maintain the logical sequence of the original question when splitting into subqueries\n\nOutput Format:\nYou MUST return the output in the following JSON format. Do not include any other text before or after the JSON:\n[\n {\n \"subquery\": \"<subquery_1>\",\n \"intentName\": \"<intent_name_1>\",\n\t\t\"actionPlan\": \"<2-3 sentence description of what will be done for this subquery>\"\n\t},\n {\n \"subquery\": \"<subquery_2>\",\n \"intentName\": \"<intent_name_2>\",\n\t\t\"actionPlan\": \"<2-3 sentence description of what will be done for this subquery>\"\n },\n ...\n]\n\nRequirements:\n- Each subquery should represent a single, actionable task or request\n- Preserve the original meaning and context when splitting queries\n- Select only from the provided intent list\n- DO NOT set intentName for any subquery that doesn't match available intents.`;\n\n\t\tconst messages = modelInstance.generateMessages({\n\t\t\tquery: userMessage,\n\t\t\tsystemPrompt,\n\t\t});\n\n\t\tconst response = await modelInstance.fetch(messages);\n\t\tif (!response.content) {\n\t\t\tloggers.intent.warn(\"Cannot extract intent from query\");\n\t\t\treturn [{ subquery: query }];\n\t\t}\n\n\t\tlet subqueries: any;\n\t\ttry {\n\t\t\tsubqueries = JSON.parse(response.content);\n\t\t} catch (error: unknown) {\n\t\t\treturn [{ subquery: query }];\n\t\t}\n\n\t\tconst triggeredIntent: Array<TriggeredIntent> = [];\n\t\tfor (const { subquery, intentName, actionPlan } of subqueries) {\n\t\t\tconst item = { subquery, actionPlan } as TriggeredIntent;\n\t\t\tif (intentName) {\n\t\t\t\titem.intent = await intentMemory.getIntentByName(intentName);\n\t\t\t}\n\t\t\ttriggeredIntent.push(item);\n\t\t}\n\n\t\treturn triggeredIntent;\n\t}\n}\n"]}