@mastra/server 0.0.0-message-ordering-20250415215612 → 0.0.0-mssql-store-20250804200341

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 (211) hide show
  1. package/LICENSE.md +11 -42
  2. package/README.md +48 -135
  3. package/dist/chunk-2XIJW7SV.cjs +310 -0
  4. package/dist/chunk-2XIJW7SV.cjs.map +1 -0
  5. package/dist/chunk-4CEZIJWJ.cjs +150 -0
  6. package/dist/chunk-4CEZIJWJ.cjs.map +1 -0
  7. package/dist/chunk-4MQU6AJN.js +83 -0
  8. package/dist/chunk-4MQU6AJN.js.map +1 -0
  9. package/dist/{chunk-QN4KF3BH.cjs → chunk-4QSNRCOT.cjs} +4 -2
  10. package/dist/chunk-4QSNRCOT.cjs.map +1 -0
  11. package/dist/chunk-4US5W7PH.cjs +120 -0
  12. package/dist/chunk-4US5W7PH.cjs.map +1 -0
  13. package/dist/chunk-7FHF55WA.js +2041 -0
  14. package/dist/chunk-7FHF55WA.js.map +1 -0
  15. package/dist/{chunk-FV45V6WC.cjs → chunk-7NADHFD2.cjs} +3 -7
  16. package/dist/chunk-7NADHFD2.cjs.map +1 -0
  17. package/dist/chunk-BED2O446.cjs +88 -0
  18. package/dist/chunk-BED2O446.cjs.map +1 -0
  19. package/dist/chunk-BUOJL3MN.js +529 -0
  20. package/dist/chunk-BUOJL3MN.js.map +1 -0
  21. package/dist/chunk-CY4TP3FK.js +16 -0
  22. package/dist/chunk-CY4TP3FK.js.map +1 -0
  23. package/dist/{chunk-4JINXASC.js → chunk-G7NVCO5M.js} +7 -4
  24. package/dist/chunk-G7NVCO5M.js.map +1 -0
  25. package/dist/chunk-GASWM5HJ.cjs +514 -0
  26. package/dist/chunk-GASWM5HJ.cjs.map +1 -0
  27. package/dist/chunk-GX25CWC7.cjs +588 -0
  28. package/dist/chunk-GX25CWC7.cjs.map +1 -0
  29. package/dist/{chunk-3RVHWGWO.js → chunk-HWHKM67I.js} +38 -19
  30. package/dist/chunk-HWHKM67I.js.map +1 -0
  31. package/dist/{chunk-CWSDZEZG.cjs → chunk-ILCWPBYQ.cjs} +20 -12
  32. package/dist/chunk-ILCWPBYQ.cjs.map +1 -0
  33. package/dist/chunk-JGVY3KWV.cjs +334 -0
  34. package/dist/chunk-JGVY3KWV.cjs.map +1 -0
  35. package/dist/chunk-LRUH33B4.cjs +2044 -0
  36. package/dist/chunk-LRUH33B4.cjs.map +1 -0
  37. package/dist/{chunk-TRDNDNGQ.js → chunk-MMROOK5J.js} +4 -7
  38. package/dist/chunk-MMROOK5J.js.map +1 -0
  39. package/dist/{chunk-M56ECCHK.cjs → chunk-NCS2OXX6.cjs} +22 -19
  40. package/dist/chunk-NCS2OXX6.cjs.map +1 -0
  41. package/dist/{chunk-PDC4ZBQW.cjs → chunk-O4I563YW.cjs} +30 -26
  42. package/dist/chunk-O4I563YW.cjs.map +1 -0
  43. package/dist/{chunk-L7XE5QTW.js → chunk-OW4FX5TS.js} +3 -1
  44. package/dist/chunk-OW4FX5TS.js.map +1 -0
  45. package/dist/chunk-PZ5AY32C.js +9 -0
  46. package/dist/chunk-PZ5AY32C.js.map +1 -0
  47. package/dist/chunk-Q7SFCCGT.cjs +11 -0
  48. package/dist/chunk-Q7SFCCGT.cjs.map +1 -0
  49. package/dist/chunk-RE4RPXT2.cjs +18 -0
  50. package/dist/chunk-RE4RPXT2.cjs.map +1 -0
  51. package/dist/chunk-S37KCGOR.cjs +546 -0
  52. package/dist/chunk-S37KCGOR.cjs.map +1 -0
  53. package/dist/{chunk-DVPP5S6I.js → chunk-SQ7KKIH3.js} +16 -8
  54. package/dist/chunk-SQ7KKIH3.js.map +1 -0
  55. package/dist/chunk-TRWPUPGD.js +506 -0
  56. package/dist/chunk-TRWPUPGD.js.map +1 -0
  57. package/dist/chunk-TXAQU2XN.js +151 -0
  58. package/dist/chunk-TXAQU2XN.js.map +1 -0
  59. package/dist/{chunk-OPP7H5TW.js → chunk-UVOSITKU.js} +85 -68
  60. package/dist/chunk-UVOSITKU.js.map +1 -0
  61. package/dist/chunk-VIGPWTDA.cjs +159 -0
  62. package/dist/chunk-VIGPWTDA.cjs.map +1 -0
  63. package/dist/chunk-VOY6MGKA.js +301 -0
  64. package/dist/chunk-VOY6MGKA.js.map +1 -0
  65. package/dist/{chunk-YANVFOYA.js → chunk-Y3J45CVZ.js} +58 -34
  66. package/dist/chunk-Y3J45CVZ.js.map +1 -0
  67. package/dist/{chunk-UV4WTEH4.js → chunk-YS66MFDY.js} +13 -9
  68. package/dist/chunk-YS66MFDY.js.map +1 -0
  69. package/dist/chunk-ZKJZQN24.js +571 -0
  70. package/dist/chunk-ZKJZQN24.js.map +1 -0
  71. package/dist/index.cjs +2 -0
  72. package/dist/index.cjs.map +1 -0
  73. package/dist/index.d.ts +1 -0
  74. package/dist/index.d.ts.map +1 -0
  75. package/dist/index.js +2 -0
  76. package/dist/index.js.map +1 -0
  77. package/dist/server/a2a/protocol.d.ts +8 -0
  78. package/dist/server/a2a/protocol.d.ts.map +1 -0
  79. package/dist/server/a2a/store.d.ts +14 -0
  80. package/dist/server/a2a/store.d.ts.map +1 -0
  81. package/dist/server/a2a/tasks.d.ts +20 -0
  82. package/dist/server/a2a/tasks.d.ts.map +1 -0
  83. package/dist/server/handlers/a2a.cjs +32 -0
  84. package/dist/server/handlers/a2a.cjs.map +1 -0
  85. package/dist/server/handlers/a2a.d.ts +66 -0
  86. package/dist/server/handlers/a2a.d.ts.map +1 -0
  87. package/dist/server/handlers/a2a.js +3 -0
  88. package/dist/server/handlers/a2a.js.map +1 -0
  89. package/dist/server/handlers/agents.cjs +13 -7
  90. package/dist/server/handlers/agents.cjs.map +1 -0
  91. package/dist/server/handlers/agents.d.ts +81 -6
  92. package/dist/server/handlers/agents.d.ts.map +1 -0
  93. package/dist/server/handlers/agents.js +3 -1
  94. package/dist/server/handlers/agents.js.map +1 -0
  95. package/dist/server/handlers/error.cjs +4 -2
  96. package/dist/server/handlers/error.cjs.map +1 -0
  97. package/dist/server/handlers/error.d.ts +2 -1
  98. package/dist/server/handlers/error.d.ts.map +1 -0
  99. package/dist/server/handlers/error.js +3 -1
  100. package/dist/server/handlers/error.js.map +1 -0
  101. package/dist/server/handlers/legacyWorkflows.cjs +48 -0
  102. package/dist/server/handlers/legacyWorkflows.cjs.map +1 -0
  103. package/dist/server/handlers/legacyWorkflows.d.ts +59 -0
  104. package/dist/server/handlers/legacyWorkflows.d.ts.map +1 -0
  105. package/dist/server/handlers/legacyWorkflows.js +3 -0
  106. package/dist/server/handlers/legacyWorkflows.js.map +1 -0
  107. package/dist/server/handlers/logs.cjs +6 -4
  108. package/dist/server/handlers/logs.cjs.map +1 -0
  109. package/dist/server/handlers/logs.d.ts +34 -3
  110. package/dist/server/handlers/logs.d.ts.map +1 -0
  111. package/dist/server/handlers/logs.js +3 -1
  112. package/dist/server/handlers/logs.js.map +1 -0
  113. package/dist/server/handlers/memory.cjs +39 -9
  114. package/dist/server/handlers/memory.cjs.map +1 -0
  115. package/dist/server/handlers/memory.d.ts +119 -8
  116. package/dist/server/handlers/memory.d.ts.map +1 -0
  117. package/dist/server/handlers/memory.js +3 -1
  118. package/dist/server/handlers/memory.js.map +1 -0
  119. package/dist/server/handlers/network.cjs +7 -5
  120. package/dist/server/handlers/network.cjs.map +1 -0
  121. package/dist/server/handlers/network.d.ts +50 -4
  122. package/dist/server/handlers/network.d.ts.map +1 -0
  123. package/dist/server/handlers/network.js +3 -1
  124. package/dist/server/handlers/network.js.map +1 -0
  125. package/dist/server/handlers/scores.cjs +32 -0
  126. package/dist/server/handlers/scores.cjs.map +1 -0
  127. package/dist/server/handlers/scores.d.ts +49 -0
  128. package/dist/server/handlers/scores.d.ts.map +1 -0
  129. package/dist/server/handlers/scores.js +3 -0
  130. package/dist/server/handlers/scores.js.map +1 -0
  131. package/dist/server/handlers/telemetry.cjs +5 -3
  132. package/dist/server/handlers/telemetry.cjs.map +1 -0
  133. package/dist/server/handlers/telemetry.d.ts +32 -2
  134. package/dist/server/handlers/telemetry.d.ts.map +1 -0
  135. package/dist/server/handlers/telemetry.js +3 -1
  136. package/dist/server/handlers/telemetry.js.map +1 -0
  137. package/dist/server/handlers/tools.cjs +7 -5
  138. package/dist/server/handlers/tools.cjs.map +1 -0
  139. package/dist/server/handlers/tools.d.ts +21 -4
  140. package/dist/server/handlers/tools.d.ts.map +1 -0
  141. package/dist/server/handlers/tools.js +3 -1
  142. package/dist/server/handlers/tools.js.map +1 -0
  143. package/dist/server/handlers/utils.cjs +4 -2
  144. package/dist/server/handlers/utils.cjs.map +1 -0
  145. package/dist/server/handlers/utils.d.ts +2 -1
  146. package/dist/server/handlers/utils.d.ts.map +1 -0
  147. package/dist/server/handlers/utils.js +3 -1
  148. package/dist/server/handlers/utils.js.map +1 -0
  149. package/dist/server/handlers/vNextNetwork.cjs +220 -0
  150. package/dist/server/handlers/vNextNetwork.cjs.map +1 -0
  151. package/dist/server/handlers/vNextNetwork.d.ts +179 -0
  152. package/dist/server/handlers/vNextNetwork.d.ts.map +1 -0
  153. package/dist/server/handlers/vNextNetwork.js +213 -0
  154. package/dist/server/handlers/vNextNetwork.js.map +1 -0
  155. package/dist/server/handlers/vector.cjs +9 -7
  156. package/dist/server/handlers/vector.cjs.map +1 -0
  157. package/dist/server/handlers/vector.d.ts +51 -6
  158. package/dist/server/handlers/vector.d.ts.map +1 -0
  159. package/dist/server/handlers/vector.js +3 -1
  160. package/dist/server/handlers/vector.js.map +1 -0
  161. package/dist/server/handlers/voice.cjs +10 -4
  162. package/dist/server/handlers/voice.cjs.map +1 -0
  163. package/dist/server/handlers/voice.d.ts +39 -3
  164. package/dist/server/handlers/voice.d.ts.map +1 -0
  165. package/dist/server/handlers/voice.js +3 -1
  166. package/dist/server/handlers/voice.js.map +1 -0
  167. package/dist/server/handlers/workflows.cjs +35 -13
  168. package/dist/server/handlers/workflows.cjs.map +1 -0
  169. package/dist/server/handlers/workflows.d.ts +88 -10
  170. package/dist/server/handlers/workflows.d.ts.map +1 -0
  171. package/dist/server/handlers/workflows.js +3 -1
  172. package/dist/server/handlers/workflows.js.map +1 -0
  173. package/dist/server/handlers.cjs +42 -25
  174. package/dist/server/handlers.cjs.map +1 -0
  175. package/dist/server/handlers.d.ts +13 -9
  176. package/dist/server/handlers.d.ts.map +1 -0
  177. package/dist/server/handlers.js +14 -9
  178. package/dist/server/handlers.js.map +1 -0
  179. package/dist/server/http-exception.d.ts +87 -0
  180. package/dist/server/http-exception.d.ts.map +1 -0
  181. package/dist/server/types.d.ts +10 -0
  182. package/dist/server/types.d.ts.map +1 -0
  183. package/package.json +17 -15
  184. package/dist/_tsup-dts-rollup.d.cts +0 -573
  185. package/dist/_tsup-dts-rollup.d.ts +0 -573
  186. package/dist/chunk-2FJURXCL.cjs +0 -213
  187. package/dist/chunk-3AHQ5RGN.js +0 -11
  188. package/dist/chunk-3EJZQ6TQ.js +0 -49
  189. package/dist/chunk-67WTHYAV.js +0 -156
  190. package/dist/chunk-A7DF4ETD.cjs +0 -100
  191. package/dist/chunk-B64YROKU.cjs +0 -317
  192. package/dist/chunk-JLDXUWK7.cjs +0 -126
  193. package/dist/chunk-QH6XWSXP.cjs +0 -5579
  194. package/dist/chunk-RBQASTUP.js +0 -203
  195. package/dist/chunk-SKBVVI24.cjs +0 -54
  196. package/dist/chunk-VK6FX47H.js +0 -5576
  197. package/dist/chunk-Z46X3YCB.cjs +0 -164
  198. package/dist/chunk-ZLBRQFDD.cjs +0 -13
  199. package/dist/index.d.cts +0 -1
  200. package/dist/server/handlers/agents.d.cts +0 -6
  201. package/dist/server/handlers/error.d.cts +0 -1
  202. package/dist/server/handlers/logs.d.cts +0 -3
  203. package/dist/server/handlers/memory.d.cts +0 -8
  204. package/dist/server/handlers/network.d.cts +0 -4
  205. package/dist/server/handlers/telemetry.d.cts +0 -2
  206. package/dist/server/handlers/tools.d.cts +0 -4
  207. package/dist/server/handlers/utils.d.cts +0 -1
  208. package/dist/server/handlers/vector.d.cts +0 -6
  209. package/dist/server/handlers/voice.d.cts +0 -3
  210. package/dist/server/handlers/workflows.d.cts +0 -10
  211. package/dist/server/handlers.d.cts +0 -9
@@ -1,5 +1,6 @@
1
- import { handleError } from './chunk-3AHQ5RGN.js';
2
- import { __export, HTTPException } from './chunk-TRDNDNGQ.js';
1
+ import { handleError } from './chunk-CY4TP3FK.js';
2
+ import { HTTPException } from './chunk-MMROOK5J.js';
3
+ import { __export } from './chunk-PZ5AY32C.js';
3
4
 
4
5
  // src/server/handlers/telemetry.ts
5
6
  var telemetry_exports = {};
@@ -15,24 +16,26 @@ async function getTelemetryHandler({ mastra, body }) {
15
16
  throw new HTTPException(400, { message: "Telemetry is not initialized" });
16
17
  }
17
18
  if (!storage) {
18
- throw new HTTPException(400, { message: "Storage is not initialized" });
19
+ return [];
19
20
  }
20
21
  if (!body) {
21
22
  throw new HTTPException(400, { message: "Body is required" });
22
23
  }
23
- const { name, scope, page, perPage, attribute } = body;
24
+ const { name, scope, page, perPage, attribute, fromDate, toDate } = body;
24
25
  const attributes = attribute ? Object.fromEntries(
25
26
  (Array.isArray(attribute) ? attribute : [attribute]).map((attr) => {
26
27
  const [key, value] = attr.split(":");
27
28
  return [key, value];
28
29
  })
29
30
  ) : void 0;
30
- const traces = await storage.__getTraces({
31
+ const traces = await storage.getTraces({
31
32
  name,
32
33
  scope,
33
34
  page: Number(page ?? 0),
34
35
  perPage: Number(perPage ?? 100),
35
- attributes
36
+ attributes,
37
+ fromDate: fromDate ? new Date(fromDate) : void 0,
38
+ toDate: toDate ? new Date(toDate) : void 0
36
39
  });
37
40
  return traces;
38
41
  } catch (error2) {
@@ -44,7 +47,10 @@ async function storeTelemetryHandler({ mastra, body }) {
44
47
  const storage = mastra.getStorage();
45
48
  const logger = mastra.getLogger();
46
49
  if (!storage) {
47
- throw new HTTPException(400, { message: "Storage is not initialized" });
50
+ return {
51
+ status: "error",
52
+ message: "Storage is not initialized"
53
+ };
48
54
  }
49
55
  const now = /* @__PURE__ */ new Date();
50
56
  const items = body?.resourceSpans?.[0]?.scopeSpans;
@@ -105,7 +111,7 @@ async function storeTelemetryHandler({ mastra, body }) {
105
111
  }
106
112
  return acc;
107
113
  }, []);
108
- return storage.__batchTraceInsert({
114
+ return storage.batchTraceInsert({
109
115
  records: allSpans
110
116
  }).then(() => {
111
117
  return {
@@ -133,3 +139,5 @@ async function storeTelemetryHandler({ mastra, body }) {
133
139
  }
134
140
 
135
141
  export { getTelemetryHandler, storeTelemetryHandler, telemetry_exports };
142
+ //# sourceMappingURL=chunk-SQ7KKIH3.js.map
143
+ //# sourceMappingURL=chunk-SQ7KKIH3.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/server/handlers/telemetry.ts"],"names":["error","acc"],"mappings":"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","file":"chunk-SQ7KKIH3.js","sourcesContent":["import { HTTPException } from '../http-exception';\nimport type { Context } from '../types';\n\nimport { handleError } from './error';\n\ninterface TelemetryContext extends Context {\n body?: {\n name?: string;\n scope?: string;\n page?: number;\n perPage?: number;\n attribute?: string | string[];\n fromDate?: Date;\n toDate?: Date;\n };\n}\n\nexport async function getTelemetryHandler({ mastra, body }: TelemetryContext) {\n try {\n const telemetry = mastra.getTelemetry();\n const storage = mastra.getStorage();\n\n if (!telemetry) {\n throw new HTTPException(400, { message: 'Telemetry is not initialized' });\n }\n\n if (!storage) {\n return [];\n }\n\n if (!body) {\n throw new HTTPException(400, { message: 'Body is required' });\n }\n\n const { name, scope, page, perPage, attribute, fromDate, toDate } = body;\n\n // Parse attribute query parameter if present\n const attributes = attribute\n ? Object.fromEntries(\n (Array.isArray(attribute) ? attribute : [attribute]).map(attr => {\n const [key, value] = attr.split(':');\n return [key, value];\n }),\n )\n : undefined;\n\n const traces = await storage.getTraces({\n name,\n scope,\n page: Number(page ?? 0),\n perPage: Number(perPage ?? 100),\n attributes,\n fromDate: fromDate ? new Date(fromDate) : undefined,\n toDate: toDate ? new Date(toDate) : undefined,\n });\n\n return traces;\n } catch (error) {\n return handleError(error, 'Error getting telemetry');\n }\n}\n\nexport async function storeTelemetryHandler({ mastra, body }: Context & { body: { resourceSpans: any[] } }) {\n try {\n const storage = mastra.getStorage();\n const logger = mastra.getLogger();\n\n if (!storage) {\n return {\n status: 'error',\n message: 'Storage is not initialized',\n };\n }\n\n const now = new Date();\n\n const items = body?.resourceSpans?.[0]?.scopeSpans;\n logger.debug('[Telemetry Handler] Received spans:', {\n totalSpans: items?.reduce((acc: number, scope: { spans: any[] }) => acc + scope.spans.length, 0) || 0,\n timestamp: now.toISOString(),\n });\n if (!items?.length) {\n return {\n status: 'success',\n message: 'No spans to process',\n traceCount: 0,\n };\n }\n\n const allSpans: any[] = items.reduce((acc: any, scopedSpans: any) => {\n const { scope, spans } = scopedSpans;\n for (const span of spans) {\n const {\n spanId,\n parentSpanId,\n traceId,\n name,\n kind,\n attributes,\n status,\n events,\n links,\n startTimeUnixNano,\n endTimeUnixNano,\n ...rest\n } = span;\n\n const startTime = Number(BigInt(startTimeUnixNano) / 1000n);\n const endTime = Number(BigInt(endTimeUnixNano) / 1000n);\n\n acc.push({\n id: spanId,\n parentSpanId,\n traceId,\n name,\n scope: scope.name,\n kind,\n status: JSON.stringify(status),\n events: JSON.stringify(events),\n links: JSON.stringify(links),\n attributes: JSON.stringify(\n attributes.reduce((acc: Record<string, any>, attr: any) => {\n const valueKey = Object.keys(attr.value)[0];\n if (valueKey) {\n acc[attr.key] = attr.value[valueKey];\n }\n return acc;\n }, {}),\n ),\n startTime,\n endTime,\n other: JSON.stringify(rest),\n createdAt: now,\n });\n }\n return acc;\n }, []);\n\n return storage\n .batchTraceInsert({\n records: allSpans,\n })\n .then(() => {\n return {\n status: 'success',\n message: 'Traces received and processed successfully',\n traceCount: body.resourceSpans?.length || 0,\n };\n })\n .catch(() => {\n return {\n status: 'error',\n message: 'Failed to process traces',\n // @ts-ignore\n error: error.message,\n };\n });\n\n // Return a simple response\n } catch (error) {\n console.error('Error processing traces:', error);\n return {\n status: 'error',\n message: 'Failed to process traces',\n // @ts-ignore\n error: error.message,\n };\n }\n}\n"]}
@@ -0,0 +1,506 @@
1
+ import { __export } from './chunk-PZ5AY32C.js';
2
+ import { A2AError } from '@mastra/core/a2a';
3
+ import { z } from 'zod';
4
+
5
+ // src/server/handlers/a2a.ts
6
+ var a2a_exports = {};
7
+ __export(a2a_exports, {
8
+ getAgentCardByIdHandler: () => getAgentCardByIdHandler,
9
+ getAgentExecutionHandler: () => getAgentExecutionHandler,
10
+ handleTaskCancel: () => handleTaskCancel,
11
+ handleTaskGet: () => handleTaskGet,
12
+ handleTaskSend: () => handleTaskSend,
13
+ handleTaskSendSubscribe: () => handleTaskSendSubscribe
14
+ });
15
+ function normalizeError(error, reqId, taskId, logger) {
16
+ let a2aError;
17
+ if (error instanceof A2AError) {
18
+ a2aError = error;
19
+ } else if (error instanceof Error) {
20
+ a2aError = A2AError.internalError(error.message, { stack: error.stack });
21
+ } else {
22
+ a2aError = A2AError.internalError("An unknown error occurred.", error);
23
+ }
24
+ if (taskId && !a2aError.taskId) {
25
+ a2aError.taskId = taskId;
26
+ }
27
+ logger?.error(`Error processing request (Task: ${a2aError.taskId ?? "N/A"}, ReqID: ${reqId ?? "N/A"}):`, a2aError);
28
+ return createErrorResponse(reqId, a2aError.toJSONRPCError());
29
+ }
30
+ function createErrorResponse(id, error) {
31
+ return {
32
+ jsonrpc: "2.0",
33
+ id,
34
+ // Can be null if request ID was invalid/missing
35
+ error
36
+ };
37
+ }
38
+ function createSuccessResponse(id, result) {
39
+ if (!id) {
40
+ throw A2AError.internalError("Cannot create success response for null ID.");
41
+ }
42
+ return {
43
+ jsonrpc: "2.0",
44
+ id,
45
+ result
46
+ };
47
+ }
48
+ function convertToCoreMessage(message) {
49
+ return {
50
+ role: message.role === "user" ? "user" : "assistant",
51
+ content: message.parts.map((msg) => convertToCoreMessagePart(msg))
52
+ };
53
+ }
54
+ function convertToCoreMessagePart(part) {
55
+ switch (part.type) {
56
+ case "text":
57
+ return {
58
+ type: "text",
59
+ text: part.text
60
+ };
61
+ case "file":
62
+ return {
63
+ type: "file",
64
+ data: new URL(part.file.uri),
65
+ mimeType: part.file.mimeType
66
+ };
67
+ case "data":
68
+ throw new Error("Data parts are not supported in core messages");
69
+ }
70
+ }
71
+
72
+ // src/server/a2a/store.ts
73
+ var InMemoryTaskStore = class {
74
+ store = /* @__PURE__ */ new Map();
75
+ activeCancellations = /* @__PURE__ */ new Set();
76
+ async load({ agentId, taskId }) {
77
+ const entry = this.store.get(`${agentId}-${taskId}`);
78
+ if (!entry) {
79
+ return null;
80
+ }
81
+ return { task: { ...entry.task }, history: [...entry.history] };
82
+ }
83
+ async save({ agentId, data }) {
84
+ const key = `${agentId}-${data.task.id}`;
85
+ if (!data.task.id) {
86
+ throw new Error("Task ID is required");
87
+ }
88
+ this.store.set(key, {
89
+ task: { ...data.task },
90
+ history: [...data.history]
91
+ });
92
+ }
93
+ };
94
+
95
+ // src/server/a2a/tasks.ts
96
+ function isTaskStatusUpdate(update) {
97
+ return "state" in update && !("parts" in update);
98
+ }
99
+ function isArtifactUpdate(update) {
100
+ return "parts" in update;
101
+ }
102
+ function applyUpdateToTaskAndHistory(current, update) {
103
+ let newTask = structuredClone(current.task);
104
+ let newHistory = structuredClone(current.history);
105
+ if (isTaskStatusUpdate(update)) {
106
+ newTask.status = {
107
+ ...newTask.status,
108
+ // Keep existing properties if not overwritten
109
+ ...update,
110
+ // Apply updates
111
+ timestamp: (/* @__PURE__ */ new Date()).toISOString()
112
+ };
113
+ if (update.message?.role === "agent") {
114
+ newHistory.push(update.message);
115
+ }
116
+ } else if (isArtifactUpdate(update)) {
117
+ if (!newTask.artifacts) {
118
+ newTask.artifacts = [];
119
+ } else {
120
+ newTask.artifacts = [...newTask.artifacts];
121
+ }
122
+ const existingIndex = update.index ?? -1;
123
+ let replaced = false;
124
+ if (existingIndex >= 0 && existingIndex < newTask.artifacts.length) {
125
+ const existingArtifact = newTask.artifacts[existingIndex];
126
+ if (update.append) {
127
+ const appendedArtifact = JSON.parse(JSON.stringify(existingArtifact));
128
+ appendedArtifact.parts.push(...update.parts);
129
+ if (update.metadata) {
130
+ appendedArtifact.metadata = {
131
+ ...appendedArtifact.metadata || {},
132
+ ...update.metadata
133
+ };
134
+ }
135
+ if (update.lastChunk !== void 0) appendedArtifact.lastChunk = update.lastChunk;
136
+ if (update.description) appendedArtifact.description = update.description;
137
+ newTask.artifacts[existingIndex] = appendedArtifact;
138
+ replaced = true;
139
+ } else {
140
+ newTask.artifacts[existingIndex] = { ...update };
141
+ replaced = true;
142
+ }
143
+ } else if (update.name) {
144
+ const namedIndex = newTask.artifacts.findIndex((a) => a.name === update.name);
145
+ if (namedIndex >= 0) {
146
+ newTask.artifacts[namedIndex] = { ...update };
147
+ replaced = true;
148
+ }
149
+ }
150
+ if (!replaced) {
151
+ newTask.artifacts.push({ ...update });
152
+ if (newTask.artifacts.some((a) => a.index !== void 0)) {
153
+ newTask.artifacts.sort((a, b) => (a.index ?? 0) - (b.index ?? 0));
154
+ }
155
+ }
156
+ }
157
+ return { task: newTask, history: newHistory };
158
+ }
159
+ async function loadOrCreateTaskAndHistory({
160
+ agentId,
161
+ taskId,
162
+ taskStore,
163
+ message,
164
+ sessionId,
165
+ metadata,
166
+ logger
167
+ }) {
168
+ const data = await taskStore.load({ agentId, taskId });
169
+ if (!data) {
170
+ const initialTask = {
171
+ id: taskId,
172
+ sessionId,
173
+ status: {
174
+ state: "submitted",
175
+ timestamp: (/* @__PURE__ */ new Date()).toISOString(),
176
+ message: null
177
+ },
178
+ artifacts: [],
179
+ metadata
180
+ };
181
+ const initialData = {
182
+ task: initialTask,
183
+ history: [message]
184
+ };
185
+ logger?.info(`[Task ${taskId}] Created new task and history.`);
186
+ await taskStore.save({ agentId, data: initialData });
187
+ return initialData;
188
+ }
189
+ logger?.info(`[Task ${taskId}] Loaded existing task and history.`);
190
+ let updatedData = {
191
+ task: data.task,
192
+ history: [...data.history, message]
193
+ };
194
+ const { status } = data.task;
195
+ const finalStates = ["completed", "failed", "canceled"];
196
+ if (finalStates.includes(status.state)) {
197
+ logger?.warn(`[Task ${taskId}] Received message for task in final state ${status.state}. Restarting.`);
198
+ updatedData = applyUpdateToTaskAndHistory(updatedData, {
199
+ state: "submitted",
200
+ message: null
201
+ });
202
+ } else if (status.state === "input-required") {
203
+ logger?.info(`[Task ${taskId}] Changing state from 'input-required' to 'working'.`);
204
+ updatedData = applyUpdateToTaskAndHistory(updatedData, { state: "working" });
205
+ } else if (status.state === "working") {
206
+ logger?.warn(`[Task ${taskId}] Received message while already 'working'. Proceeding.`);
207
+ }
208
+ await taskStore.save({ agentId, data: updatedData });
209
+ return {
210
+ task: { ...updatedData.task },
211
+ history: [...updatedData.history]
212
+ };
213
+ }
214
+ function createTaskContext({
215
+ task,
216
+ userMessage,
217
+ history,
218
+ activeCancellations
219
+ }) {
220
+ return {
221
+ task: structuredClone(task),
222
+ userMessage,
223
+ history: structuredClone(history),
224
+ isCancelled: () => activeCancellations.has(task.id)
225
+ };
226
+ }
227
+
228
+ // src/server/handlers/a2a.ts
229
+ var taskSendParamsSchema = z.object({
230
+ id: z.string().min(1, "Invalid or missing task ID (params.id)."),
231
+ message: z.object({
232
+ parts: z.array(
233
+ z.object({
234
+ type: z.enum(["text"]),
235
+ text: z.string()
236
+ })
237
+ )
238
+ })
239
+ });
240
+ async function getAgentCardByIdHandler({
241
+ mastra,
242
+ agentId,
243
+ executionUrl = `/a2a/${agentId}`,
244
+ provider = {
245
+ organization: "Mastra",
246
+ url: "https://mastra.ai"
247
+ },
248
+ version = "1.0",
249
+ runtimeContext
250
+ }) {
251
+ const agent = mastra.getAgent(agentId);
252
+ if (!agent) {
253
+ throw new Error(`Agent with ID ${agentId} not found`);
254
+ }
255
+ const [instructions, tools] = await Promise.all([
256
+ agent.getInstructions({ runtimeContext }),
257
+ agent.getTools({ runtimeContext })
258
+ ]);
259
+ const agentCard = {
260
+ name: agent.id || agentId,
261
+ description: instructions,
262
+ url: executionUrl,
263
+ provider,
264
+ version,
265
+ capabilities: {
266
+ streaming: true,
267
+ // All agents support streaming
268
+ pushNotifications: false,
269
+ stateTransitionHistory: false
270
+ },
271
+ defaultInputModes: ["text"],
272
+ defaultOutputModes: ["text"],
273
+ // Convert agent tools to skills format for A2A protocol
274
+ skills: Object.entries(tools).map(([toolId, tool]) => ({
275
+ id: toolId,
276
+ name: toolId,
277
+ description: tool.description || `Tool: ${toolId}`,
278
+ // Optional fields
279
+ tags: ["tool"]
280
+ }))
281
+ };
282
+ return agentCard;
283
+ }
284
+ function validateTaskSendParams(params) {
285
+ try {
286
+ taskSendParamsSchema.parse(params);
287
+ } catch (error) {
288
+ if (error instanceof z.ZodError) {
289
+ throw A2AError.invalidParams(error.errors[0].message);
290
+ }
291
+ throw error;
292
+ }
293
+ }
294
+ async function handleTaskSend({
295
+ requestId,
296
+ params,
297
+ taskStore,
298
+ agent,
299
+ agentId,
300
+ logger,
301
+ runtimeContext
302
+ }) {
303
+ validateTaskSendParams(params);
304
+ const { id: taskId, message, sessionId, metadata } = params;
305
+ let currentData = await loadOrCreateTaskAndHistory({
306
+ taskId,
307
+ taskStore,
308
+ agentId,
309
+ message,
310
+ sessionId,
311
+ metadata
312
+ });
313
+ createTaskContext({
314
+ task: currentData.task,
315
+ userMessage: message,
316
+ history: currentData.history,
317
+ activeCancellations: taskStore.activeCancellations
318
+ });
319
+ try {
320
+ const { text } = await agent.generate([convertToCoreMessage(message)], {
321
+ runId: taskId,
322
+ runtimeContext
323
+ });
324
+ currentData = applyUpdateToTaskAndHistory(currentData, {
325
+ state: "completed",
326
+ message: {
327
+ role: "agent",
328
+ parts: [
329
+ {
330
+ type: "text",
331
+ text
332
+ }
333
+ ]
334
+ }
335
+ });
336
+ await taskStore.save({ agentId, data: currentData });
337
+ } catch (handlerError) {
338
+ const failureStatusUpdate = {
339
+ state: "failed",
340
+ message: {
341
+ role: "agent",
342
+ parts: [
343
+ {
344
+ type: "text",
345
+ text: `Handler failed: ${handlerError instanceof Error ? handlerError.message : String(handlerError)}`
346
+ }
347
+ ]
348
+ }
349
+ };
350
+ currentData = applyUpdateToTaskAndHistory(currentData, failureStatusUpdate);
351
+ try {
352
+ await taskStore.save({ agentId, data: currentData });
353
+ } catch (saveError) {
354
+ logger?.error(`Failed to save task ${taskId} after handler error:`, saveError?.message);
355
+ }
356
+ return normalizeError(handlerError, requestId, taskId, logger);
357
+ }
358
+ return createSuccessResponse(requestId, currentData.task);
359
+ }
360
+ async function handleTaskGet({
361
+ requestId,
362
+ taskStore,
363
+ agentId,
364
+ taskId
365
+ }) {
366
+ const task = await taskStore.load({ agentId, taskId });
367
+ if (!task) {
368
+ throw A2AError.taskNotFound(taskId);
369
+ }
370
+ return createSuccessResponse(requestId, task);
371
+ }
372
+ async function* handleTaskSendSubscribe({
373
+ requestId,
374
+ params,
375
+ taskStore,
376
+ agent,
377
+ agentId,
378
+ logger,
379
+ runtimeContext
380
+ }) {
381
+ yield createSuccessResponse(requestId, {
382
+ state: "working",
383
+ message: {
384
+ role: "agent",
385
+ parts: [{ type: "text", text: "Generating response..." }]
386
+ }
387
+ });
388
+ let result;
389
+ try {
390
+ result = await handleTaskSend({
391
+ requestId,
392
+ params,
393
+ taskStore,
394
+ agent,
395
+ agentId,
396
+ runtimeContext,
397
+ logger
398
+ });
399
+ } catch (err) {
400
+ if (!(err instanceof A2AError)) {
401
+ throw err;
402
+ }
403
+ result = createErrorResponse(requestId, err.toJSONRPCError());
404
+ }
405
+ yield result;
406
+ }
407
+ async function handleTaskCancel({
408
+ requestId,
409
+ taskStore,
410
+ agentId,
411
+ taskId,
412
+ logger
413
+ }) {
414
+ let data = await taskStore.load({
415
+ agentId,
416
+ taskId
417
+ });
418
+ if (!data) {
419
+ throw A2AError.taskNotFound(taskId);
420
+ }
421
+ const finalStates = ["completed", "failed", "canceled"];
422
+ if (finalStates.includes(data.task.status.state)) {
423
+ logger?.info(`Task ${taskId} already in final state ${data.task.status.state}, cannot cancel.`);
424
+ return createSuccessResponse(requestId, data.task);
425
+ }
426
+ taskStore.activeCancellations.add(taskId);
427
+ const cancelUpdate = {
428
+ state: "canceled",
429
+ message: {
430
+ role: "agent",
431
+ parts: [{ type: "text", text: "Task cancelled by request." }]
432
+ }
433
+ };
434
+ data = applyUpdateToTaskAndHistory(data, cancelUpdate);
435
+ await taskStore.save({ agentId, data });
436
+ taskStore.activeCancellations.delete(taskId);
437
+ return createSuccessResponse(requestId, data.task);
438
+ }
439
+ async function getAgentExecutionHandler({
440
+ requestId,
441
+ mastra,
442
+ agentId,
443
+ runtimeContext,
444
+ method,
445
+ params,
446
+ taskStore = new InMemoryTaskStore(),
447
+ logger
448
+ }) {
449
+ const agent = mastra.getAgent(agentId);
450
+ let taskId;
451
+ try {
452
+ taskId = params.id;
453
+ switch (method) {
454
+ case "tasks/send": {
455
+ const result2 = await handleTaskSend({
456
+ requestId,
457
+ params,
458
+ taskStore,
459
+ agent,
460
+ agentId,
461
+ runtimeContext
462
+ });
463
+ return result2;
464
+ }
465
+ case "tasks/sendSubscribe":
466
+ const result = await handleTaskSendSubscribe({
467
+ requestId,
468
+ taskStore,
469
+ params,
470
+ agent,
471
+ agentId,
472
+ runtimeContext
473
+ });
474
+ return result;
475
+ case "tasks/get": {
476
+ const result2 = await handleTaskGet({
477
+ requestId,
478
+ taskStore,
479
+ agentId,
480
+ taskId
481
+ });
482
+ return result2;
483
+ }
484
+ case "tasks/cancel": {
485
+ const result2 = await handleTaskCancel({
486
+ requestId,
487
+ taskStore,
488
+ agentId,
489
+ taskId
490
+ });
491
+ return result2;
492
+ }
493
+ default:
494
+ throw A2AError.methodNotFound(method);
495
+ }
496
+ } catch (error) {
497
+ if (error instanceof A2AError && taskId && !error.taskId) {
498
+ error.taskId = taskId;
499
+ }
500
+ return normalizeError(error, requestId, taskId, logger);
501
+ }
502
+ }
503
+
504
+ export { a2a_exports, getAgentCardByIdHandler, getAgentExecutionHandler, handleTaskCancel, handleTaskGet, handleTaskSend, handleTaskSendSubscribe };
505
+ //# sourceMappingURL=chunk-TRWPUPGD.js.map
506
+ //# sourceMappingURL=chunk-TRWPUPGD.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/server/handlers/a2a.ts","../src/server/a2a/protocol.ts","../src/server/a2a/store.ts","../src/server/a2a/tasks.ts"],"names":["A2AError","result"],"mappings":"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","file":"chunk-TRWPUPGD.js","sourcesContent":["import { A2AError } from '@mastra/core/a2a';\nimport type { TaskSendParams, TaskQueryParams, TaskIdParams, AgentCard, TaskStatus, TaskState } from '@mastra/core/a2a';\nimport type { Agent } from '@mastra/core/agent';\nimport type { IMastraLogger } from '@mastra/core/logger';\nimport type { RuntimeContext } from '@mastra/core/runtime-context';\nimport { z } from 'zod';\nimport { convertToCoreMessage, normalizeError, createSuccessResponse, createErrorResponse } from '../a2a/protocol';\nimport { InMemoryTaskStore } from '../a2a/store';\nimport { applyUpdateToTaskAndHistory, createTaskContext, loadOrCreateTaskAndHistory } from '../a2a/tasks';\nimport type { Context } from '../types';\n\nconst taskSendParamsSchema = z.object({\n id: z.string().min(1, 'Invalid or missing task ID (params.id).'),\n message: z.object({\n parts: z.array(\n z.object({\n type: z.enum(['text']),\n text: z.string(),\n }),\n ),\n }),\n});\n\nexport async function getAgentCardByIdHandler({\n mastra,\n agentId,\n executionUrl = `/a2a/${agentId}`,\n provider = {\n organization: 'Mastra',\n url: 'https://mastra.ai',\n },\n version = '1.0',\n runtimeContext,\n}: Context & {\n runtimeContext: RuntimeContext;\n agentId: keyof ReturnType<typeof mastra.getAgents>;\n executionUrl?: string;\n version?: string;\n provider?: {\n organization: string;\n url: string;\n };\n}): Promise<AgentCard> {\n const agent = mastra.getAgent(agentId);\n\n if (!agent) {\n throw new Error(`Agent with ID ${agentId} not found`);\n }\n\n const [instructions, tools] = await Promise.all([\n agent.getInstructions({ runtimeContext }),\n agent.getTools({ runtimeContext }),\n ]);\n\n // Extract agent information to create the AgentCard\n const agentCard: AgentCard = {\n name: agent.id || agentId,\n description: instructions,\n url: executionUrl,\n provider,\n version,\n capabilities: {\n streaming: true, // All agents support streaming\n pushNotifications: false,\n stateTransitionHistory: false,\n },\n defaultInputModes: ['text'],\n defaultOutputModes: ['text'],\n // Convert agent tools to skills format for A2A protocol\n skills: Object.entries(tools).map(([toolId, tool]) => ({\n id: toolId,\n name: toolId,\n description: tool.description || `Tool: ${toolId}`,\n // Optional fields\n tags: ['tool'],\n })),\n };\n\n return agentCard;\n}\n\nfunction validateTaskSendParams(params: TaskSendParams) {\n try {\n taskSendParamsSchema.parse(params);\n } catch (error) {\n if (error instanceof z.ZodError) {\n throw A2AError.invalidParams((error as z.ZodError).errors[0]!.message);\n }\n\n throw error;\n }\n}\n\nexport async function handleTaskSend({\n requestId,\n params,\n taskStore,\n agent,\n agentId,\n logger,\n runtimeContext,\n}: {\n requestId: string;\n params: TaskSendParams;\n taskStore: InMemoryTaskStore;\n agent: Agent;\n agentId: string;\n logger?: IMastraLogger;\n runtimeContext: RuntimeContext;\n}) {\n validateTaskSendParams(params);\n\n const { id: taskId, message, sessionId, metadata } = params;\n\n // Load or create task AND history\n let currentData = await loadOrCreateTaskAndHistory({\n taskId,\n taskStore,\n agentId,\n message,\n sessionId,\n metadata,\n });\n\n // Use the new TaskContext definition, passing history\n const context = createTaskContext({\n task: currentData.task,\n userMessage: message,\n history: currentData.history,\n activeCancellations: taskStore.activeCancellations,\n });\n\n try {\n const { text } = await agent.generate([convertToCoreMessage(message)], {\n runId: taskId,\n runtimeContext,\n });\n\n currentData = applyUpdateToTaskAndHistory(currentData, {\n state: 'completed',\n message: {\n role: 'agent',\n parts: [\n {\n type: 'text',\n text: text,\n },\n ],\n },\n });\n\n await taskStore.save({ agentId, data: currentData });\n context.task = currentData.task;\n } catch (handlerError) {\n // If handler throws, apply 'failed' status, save, and rethrow\n const failureStatusUpdate: Omit<TaskStatus, 'timestamp'> = {\n state: 'failed',\n message: {\n role: 'agent',\n parts: [\n {\n type: 'text',\n text: `Handler failed: ${handlerError instanceof Error ? handlerError.message : String(handlerError)}`,\n },\n ],\n },\n };\n currentData = applyUpdateToTaskAndHistory(currentData, failureStatusUpdate);\n\n try {\n await taskStore.save({ agentId, data: currentData });\n } catch (saveError) {\n // @ts-expect-error saveError is an unknown error\n logger?.error(`Failed to save task ${taskId} after handler error:`, saveError?.message);\n }\n\n return normalizeError(handlerError, requestId, taskId, logger); // Rethrow original error\n }\n\n // The loop finished, send the final task state\n return createSuccessResponse(requestId, currentData.task);\n}\n\nexport async function handleTaskGet({\n requestId,\n taskStore,\n agentId,\n taskId,\n}: {\n requestId: string;\n taskStore: InMemoryTaskStore;\n agentId: string;\n taskId: string;\n}) {\n const task = await taskStore.load({ agentId, taskId });\n\n if (!task) {\n throw A2AError.taskNotFound(taskId);\n }\n\n return createSuccessResponse(requestId, task);\n}\n\nexport async function* handleTaskSendSubscribe({\n requestId,\n params,\n taskStore,\n agent,\n agentId,\n logger,\n runtimeContext,\n}: {\n requestId: string;\n params: TaskSendParams;\n taskStore: InMemoryTaskStore;\n agent: Agent;\n agentId: string;\n logger?: IMastraLogger;\n runtimeContext: RuntimeContext;\n}) {\n yield createSuccessResponse(requestId, {\n state: 'working',\n message: {\n role: 'agent',\n parts: [{ type: 'text', text: 'Generating response...' }],\n },\n });\n\n let result;\n try {\n result = await handleTaskSend({\n requestId,\n params,\n taskStore,\n agent,\n agentId,\n runtimeContext,\n logger,\n });\n } catch (err) {\n if (!(err instanceof A2AError)) {\n throw err;\n }\n\n result = createErrorResponse(requestId, err.toJSONRPCError());\n }\n\n yield result;\n}\n\nexport async function handleTaskCancel({\n requestId,\n taskStore,\n agentId,\n taskId,\n logger,\n}: {\n requestId: string;\n taskStore: InMemoryTaskStore;\n agentId: string;\n taskId: string;\n logger?: IMastraLogger;\n}) {\n // Load task and history\n let data = await taskStore.load({\n agentId,\n taskId,\n });\n\n if (!data) {\n throw A2AError.taskNotFound(taskId);\n }\n\n // Check if cancelable (not already in a final state)\n const finalStates: TaskState[] = ['completed', 'failed', 'canceled'];\n\n if (finalStates.includes(data.task.status.state)) {\n logger?.info(`Task ${taskId} already in final state ${data.task.status.state}, cannot cancel.`);\n return createSuccessResponse(requestId, data.task);\n }\n\n // Signal cancellation\n taskStore.activeCancellations.add(taskId);\n\n // Apply 'canceled' state update\n const cancelUpdate: Omit<TaskStatus, 'timestamp'> = {\n state: 'canceled',\n message: {\n role: 'agent',\n parts: [{ type: 'text', text: 'Task cancelled by request.' }],\n },\n };\n\n data = applyUpdateToTaskAndHistory(data, cancelUpdate);\n\n // Save the updated state\n await taskStore.save({ agentId, data });\n\n // Remove from active cancellations *after* saving\n taskStore.activeCancellations.delete(taskId);\n\n // Return the updated task object\n return createSuccessResponse(requestId, data.task);\n}\n\nexport async function getAgentExecutionHandler({\n requestId,\n mastra,\n agentId,\n runtimeContext,\n method,\n params,\n taskStore = new InMemoryTaskStore(),\n logger,\n}: Context & {\n requestId: string;\n runtimeContext: RuntimeContext;\n agentId: string;\n method: 'tasks/send' | 'tasks/sendSubscribe' | 'tasks/get' | 'tasks/cancel';\n params: TaskSendParams | TaskQueryParams | TaskIdParams;\n taskStore?: InMemoryTaskStore;\n logger?: IMastraLogger;\n}): Promise<any> {\n const agent = mastra.getAgent(agentId);\n\n let taskId: string | undefined; // For error context\n\n try {\n // Attempt to get task ID early for error context. Cast params to any to access id.\n // Proper validation happens within specific handlers.\n taskId = params.id;\n\n // 2. Route based on method\n switch (method) {\n case 'tasks/send': {\n const result = await handleTaskSend({\n requestId,\n params: params as TaskSendParams,\n taskStore,\n agent,\n agentId,\n runtimeContext,\n });\n return result;\n }\n case 'tasks/sendSubscribe':\n const result = await handleTaskSendSubscribe({\n requestId,\n taskStore,\n params: params as TaskSendParams,\n agent,\n agentId,\n runtimeContext,\n });\n return result;\n\n case 'tasks/get': {\n const result = await handleTaskGet({\n requestId,\n taskStore,\n agentId,\n taskId,\n });\n\n return result;\n }\n case 'tasks/cancel': {\n const result = await handleTaskCancel({\n requestId,\n taskStore,\n agentId,\n taskId,\n });\n\n return result;\n }\n default:\n throw A2AError.methodNotFound(method);\n }\n } catch (error) {\n if (error instanceof A2AError && taskId && !error.taskId) {\n error.taskId = taskId; // Add task ID context if missing\n }\n\n return normalizeError(error, requestId, taskId, logger);\n }\n}\n","import { A2AError } from '@mastra/core/a2a';\n\nimport type { JSONRPCError, JSONRPCResponse, Message, Part } from '@mastra/core/a2a';\nimport type { CoreMessage } from '@mastra/core/llm';\nimport type { IMastraLogger } from '@mastra/core/logger';\n\nexport function normalizeError(\n error: any,\n reqId: number | string | null,\n taskId?: string,\n logger?: IMastraLogger,\n): JSONRPCResponse<null, unknown> {\n let a2aError: A2AError;\n if (error instanceof A2AError) {\n a2aError = error;\n } else if (error instanceof Error) {\n // Generic JS error\n a2aError = A2AError.internalError(error.message, { stack: error.stack });\n } else {\n // Unknown error type\n a2aError = A2AError.internalError('An unknown error occurred.', error);\n }\n\n // Ensure Task ID context is present if possible\n if (taskId && !a2aError.taskId) {\n a2aError.taskId = taskId;\n }\n\n logger?.error(`Error processing request (Task: ${a2aError.taskId ?? 'N/A'}, ReqID: ${reqId ?? 'N/A'}):`, a2aError);\n\n return createErrorResponse(reqId, a2aError.toJSONRPCError());\n}\n\nexport function createErrorResponse(\n id: number | string | null,\n error: JSONRPCError<unknown>,\n): JSONRPCResponse<null, unknown> {\n // For errors, ID should be the same as request ID, or null if that couldn't be determined\n return {\n jsonrpc: '2.0',\n id: id, // Can be null if request ID was invalid/missing\n error: error,\n };\n}\n\nexport function createSuccessResponse<T>(id: number | string | null, result: T): JSONRPCResponse<T> {\n if (!id) {\n // This shouldn't happen for methods that expect a response, but safeguard\n throw A2AError.internalError('Cannot create success response for null ID.');\n }\n\n return {\n jsonrpc: '2.0',\n id: id,\n result: result,\n };\n}\n\nexport function convertToCoreMessage(message: Message): CoreMessage {\n return {\n role: message.role === 'user' ? 'user' : 'assistant',\n content: message.parts.map(msg => convertToCoreMessagePart(msg)),\n };\n}\n\nfunction convertToCoreMessagePart(part: Part) {\n switch (part.type) {\n case 'text':\n return {\n type: 'text',\n text: part.text,\n } as const;\n case 'file':\n return {\n type: 'file',\n data: new URL(part.file.uri!),\n mimeType: part.file.mimeType!,\n } as const;\n case 'data':\n throw new Error('Data parts are not supported in core messages');\n }\n}\n","import type { TaskAndHistory } from '@mastra/core/a2a';\n\nexport class InMemoryTaskStore {\n private store: Map<string, TaskAndHistory> = new Map();\n public activeCancellations = new Set<string>();\n\n async load({ agentId, taskId }: { agentId: string; taskId: string }): Promise<TaskAndHistory | null> {\n const entry = this.store.get(`${agentId}-${taskId}`);\n\n if (!entry) {\n return null;\n }\n\n // Return copies to prevent external mutation\n return { task: { ...entry.task }, history: [...entry.history] };\n }\n\n async save({ agentId, data }: { agentId: string; data: TaskAndHistory }): Promise<void> {\n // Store copies to prevent internal mutation if caller reuses objects\n const key = `${agentId}-${data.task.id}`;\n if (!data.task.id) {\n throw new Error('Task ID is required');\n }\n this.store.set(key, {\n task: { ...data.task },\n history: [...data.history],\n });\n }\n}\n","import type { Message, TaskContext, TaskAndHistory, Task, TaskState, TaskStatus, Artifact } from '@mastra/core/a2a';\nimport type { IMastraLogger } from '@mastra/core/logger';\nimport type { InMemoryTaskStore } from './store';\n\nfunction isTaskStatusUpdate(update: TaskStatus | Artifact): update is Omit<TaskStatus, 'timestamp'> {\n return 'state' in update && !('parts' in update);\n}\n\nfunction isArtifactUpdate(update: TaskStatus | Artifact): update is Artifact {\n return 'parts' in update;\n}\n\nexport function applyUpdateToTaskAndHistory(\n current: TaskAndHistory,\n update: Omit<TaskStatus, 'timestamp'> | Artifact,\n): TaskAndHistory {\n let newTask = structuredClone(current.task);\n let newHistory = structuredClone(current.history);\n\n if (isTaskStatusUpdate(update)) {\n // Merge status update\n newTask.status = {\n ...newTask.status, // Keep existing properties if not overwritten\n ...update, // Apply updates\n timestamp: new Date().toISOString(),\n };\n\n // If the update includes an agent message, add it to history\n if (update.message?.role === 'agent') {\n newHistory.push(update.message);\n }\n } else if (isArtifactUpdate(update)) {\n // Handle artifact update\n if (!newTask.artifacts) {\n newTask.artifacts = [];\n } else {\n // Ensure we're working with a copy of the artifacts array\n newTask.artifacts = [...newTask.artifacts];\n }\n\n const existingIndex = update.index ?? -1; // Use index if provided\n let replaced = false;\n\n if (existingIndex >= 0 && existingIndex < newTask.artifacts.length) {\n const existingArtifact = newTask.artifacts[existingIndex];\n if (update.append) {\n // Create a deep copy for modification to avoid mutating original\n const appendedArtifact = JSON.parse(JSON.stringify(existingArtifact));\n appendedArtifact.parts.push(...update.parts);\n if (update.metadata) {\n appendedArtifact.metadata = {\n ...(appendedArtifact.metadata || {}),\n ...update.metadata,\n };\n }\n if (update.lastChunk !== undefined) appendedArtifact.lastChunk = update.lastChunk;\n if (update.description) appendedArtifact.description = update.description;\n newTask.artifacts[existingIndex] = appendedArtifact; // Replace with appended version\n replaced = true;\n } else {\n // Overwrite artifact at index (with a copy of the update)\n newTask.artifacts[existingIndex] = { ...update };\n replaced = true;\n }\n } else if (update.name) {\n const namedIndex = newTask.artifacts.findIndex(a => a.name === update.name);\n if (namedIndex >= 0) {\n newTask.artifacts[namedIndex] = { ...update }; // Replace by name (with copy)\n replaced = true;\n }\n }\n\n if (!replaced) {\n newTask.artifacts.push({ ...update }); // Add as a new artifact (copy)\n // Sort if indices are present\n if (newTask.artifacts.some(a => a.index !== undefined)) {\n newTask.artifacts.sort((a, b) => (a.index ?? 0) - (b.index ?? 0));\n }\n }\n }\n\n return { task: newTask, history: newHistory };\n}\n\nexport async function loadOrCreateTaskAndHistory({\n agentId,\n taskId,\n taskStore,\n message,\n sessionId,\n metadata,\n logger,\n}: {\n agentId: string;\n taskId: string;\n taskStore: InMemoryTaskStore;\n message: Message;\n sessionId?: string | null;\n metadata?: Record<string, unknown> | null;\n logger?: IMastraLogger;\n}): Promise<TaskAndHistory> {\n const data = await taskStore.load({ agentId, taskId });\n\n // Create new task if none exists\n if (!data) {\n const initialTask: Task = {\n id: taskId,\n sessionId: sessionId,\n status: {\n state: 'submitted',\n timestamp: new Date().toISOString(),\n message: null,\n },\n artifacts: [],\n metadata: metadata,\n };\n\n const initialData = {\n task: initialTask,\n history: [message],\n };\n\n logger?.info(`[Task ${taskId}] Created new task and history.`);\n await taskStore.save({ agentId, data: initialData });\n\n return initialData;\n }\n\n // Handle existing task\n logger?.info(`[Task ${taskId}] Loaded existing task and history.`);\n\n // Add message to history and prepare updated data\n let updatedData = {\n task: data.task,\n history: [...data.history, message],\n };\n\n // Handle state transitions\n const { status } = data.task;\n const finalStates: TaskState[] = ['completed', 'failed', 'canceled'];\n\n if (finalStates.includes(status.state)) {\n logger?.warn(`[Task ${taskId}] Received message for task in final state ${status.state}. Restarting.`);\n updatedData = applyUpdateToTaskAndHistory(updatedData, {\n state: 'submitted',\n message: null,\n });\n } else if (status.state === 'input-required') {\n logger?.info(`[Task ${taskId}] Changing state from 'input-required' to 'working'.`);\n updatedData = applyUpdateToTaskAndHistory(updatedData, { state: 'working' });\n } else if (status.state === 'working') {\n logger?.warn(`[Task ${taskId}] Received message while already 'working'. Proceeding.`);\n }\n\n await taskStore.save({ agentId, data: updatedData });\n\n return {\n task: { ...updatedData.task },\n history: [...updatedData.history],\n };\n}\n\nexport function createTaskContext({\n task,\n userMessage,\n history,\n activeCancellations,\n}: {\n task: Task;\n userMessage: Message;\n history: Message[];\n activeCancellations: Set<string>;\n}): TaskContext {\n return {\n task: structuredClone(task),\n userMessage,\n history: structuredClone(history),\n isCancelled: () => activeCancellations.has(task.id),\n };\n}\n"]}