@mastra/server 0.0.0-fix-ai-sdk-dependency-20251124104209 → 0.0.0-fix-backport-setserver-20251201151948

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 (262) hide show
  1. package/CHANGELOG.md +105 -656
  2. package/README.md +1 -1
  3. package/dist/chunk-2S4IMB6E.cjs +130 -0
  4. package/dist/chunk-2S4IMB6E.cjs.map +1 -0
  5. package/dist/chunk-3SNGNFUJ.cjs +128 -0
  6. package/dist/chunk-3SNGNFUJ.cjs.map +1 -0
  7. package/dist/{chunk-6BISSAIF.js → chunk-4ML6U6RF.js} +1165 -5130
  8. package/dist/chunk-4ML6U6RF.js.map +1 -0
  9. package/dist/chunk-4QCXUEAT.js +25 -0
  10. package/dist/chunk-4QCXUEAT.js.map +1 -0
  11. package/dist/chunk-67GYDFSB.js +160 -0
  12. package/dist/chunk-67GYDFSB.js.map +1 -0
  13. package/dist/chunk-6N3HC6O4.js +705 -0
  14. package/dist/chunk-6N3HC6O4.js.map +1 -0
  15. package/dist/chunk-6ZR275MD.cjs +165 -0
  16. package/dist/chunk-6ZR275MD.cjs.map +1 -0
  17. package/dist/{chunk-64ITUOXI.cjs → chunk-7NADHFD2.cjs} +2 -2
  18. package/dist/{chunk-6QWQZI4Q.js.map → chunk-7NADHFD2.cjs.map} +1 -1
  19. package/dist/{chunk-4ECGVOJZ.cjs → chunk-7RGKOGE4.cjs} +33 -226
  20. package/dist/chunk-7RGKOGE4.cjs.map +1 -0
  21. package/dist/chunk-ABRFV4XP.js +83 -0
  22. package/dist/chunk-ABRFV4XP.js.map +1 -0
  23. package/dist/chunk-AHB4JCIQ.js +160 -0
  24. package/dist/chunk-AHB4JCIQ.js.map +1 -0
  25. package/dist/chunk-AW5BU3RQ.js +192 -0
  26. package/dist/chunk-AW5BU3RQ.js.map +1 -0
  27. package/dist/chunk-BATEJLED.js +124 -0
  28. package/dist/chunk-BATEJLED.js.map +1 -0
  29. package/dist/{chunk-UXGQZUYZ.js → chunk-CY4TP3FK.js} +3 -3
  30. package/dist/{chunk-UXGQZUYZ.js.map → chunk-CY4TP3FK.js.map} +1 -1
  31. package/dist/chunk-CY6R3HLM.cjs +727 -0
  32. package/dist/chunk-CY6R3HLM.cjs.map +1 -0
  33. package/dist/chunk-EP3JQDPD.cjs +131 -0
  34. package/dist/chunk-EP3JQDPD.cjs.map +1 -0
  35. package/dist/chunk-G4PUALCE.cjs +28 -0
  36. package/dist/chunk-G4PUALCE.cjs.map +1 -0
  37. package/dist/chunk-H33KYEMY.cjs +720 -0
  38. package/dist/chunk-H33KYEMY.cjs.map +1 -0
  39. package/dist/chunk-I3C4ODGV.cjs +335 -0
  40. package/dist/chunk-I3C4ODGV.cjs.map +1 -0
  41. package/dist/{chunk-3R5EV3HV.js → chunk-IAE7SFBS.js} +33 -220
  42. package/dist/chunk-IAE7SFBS.js.map +1 -0
  43. package/dist/chunk-LLUOPR3J.js +323 -0
  44. package/dist/chunk-LLUOPR3J.js.map +1 -0
  45. package/dist/{chunk-6QWQZI4Q.js → chunk-MMROOK5J.js} +2 -2
  46. package/dist/chunk-MMROOK5J.js.map +1 -0
  47. package/dist/chunk-MYR4PVGN.js +123 -0
  48. package/dist/chunk-MYR4PVGN.js.map +1 -0
  49. package/dist/chunk-NT5XW5PI.cjs +596 -0
  50. package/dist/chunk-NT5XW5PI.cjs.map +1 -0
  51. package/dist/chunk-PBXWFGEH.js +579 -0
  52. package/dist/chunk-PBXWFGEH.js.map +1 -0
  53. package/dist/chunk-PY2K7VNW.js +698 -0
  54. package/dist/chunk-PY2K7VNW.js.map +1 -0
  55. package/dist/chunk-QQXMIP6C.js +122 -0
  56. package/dist/chunk-QQXMIP6C.js.map +1 -0
  57. package/dist/{chunk-V5WWQN7P.cjs → chunk-RE4RPXT2.cjs} +4 -4
  58. package/dist/{chunk-V5WWQN7P.cjs.map → chunk-RE4RPXT2.cjs.map} +1 -1
  59. package/dist/chunk-SPRRK3P7.cjs +200 -0
  60. package/dist/chunk-SPRRK3P7.cjs.map +1 -0
  61. package/dist/chunk-TRGAMKHX.cjs +167 -0
  62. package/dist/chunk-TRGAMKHX.cjs.map +1 -0
  63. package/dist/{chunk-TBVUN4XN.cjs → chunk-USGGDGWL.cjs} +1998 -5969
  64. package/dist/chunk-USGGDGWL.cjs.map +1 -0
  65. package/dist/{chunk-UZ6CYAOG.cjs → chunk-VY4ENABS.cjs} +7 -6
  66. package/dist/chunk-VY4ENABS.cjs.map +1 -0
  67. package/dist/chunk-XN74I6VW.cjs +88 -0
  68. package/dist/chunk-XN74I6VW.cjs.map +1 -0
  69. package/dist/{chunk-G7BPNX2V.js → chunk-YWOK4F5A.js} +7 -6
  70. package/dist/chunk-YWOK4F5A.js.map +1 -0
  71. package/dist/server/handlers/a2a.cjs +7 -15
  72. package/dist/server/handlers/a2a.d.ts +10 -492
  73. package/dist/server/handlers/a2a.d.ts.map +1 -1
  74. package/dist/server/handlers/a2a.js +1 -1
  75. package/dist/server/handlers/agent-builder.cjs +31 -43
  76. package/dist/server/handlers/agent-builder.d.ts +84 -592
  77. package/dist/server/handlers/agent-builder.d.ts.map +1 -1
  78. package/dist/server/handlers/agent-builder.js +1 -1
  79. package/dist/server/handlers/agents.cjs +41 -49
  80. package/dist/server/handlers/agents.d.ts +148 -3275
  81. package/dist/server/handlers/agents.d.ts.map +1 -1
  82. package/dist/server/handlers/agents.js +1 -1
  83. package/dist/server/handlers/error.cjs +2 -2
  84. package/dist/server/handlers/error.js +1 -1
  85. package/dist/server/handlers/legacyWorkflows.cjs +48 -0
  86. package/dist/server/handlers/legacyWorkflows.cjs.map +1 -0
  87. package/dist/server/handlers/legacyWorkflows.d.ts +59 -0
  88. package/dist/server/handlers/legacyWorkflows.d.ts.map +1 -0
  89. package/dist/server/handlers/legacyWorkflows.js +3 -0
  90. package/dist/server/handlers/legacyWorkflows.js.map +1 -0
  91. package/dist/server/handlers/logs.cjs +7 -7
  92. package/dist/server/handlers/logs.d.ts +27 -135
  93. package/dist/server/handlers/logs.d.ts.map +1 -1
  94. package/dist/server/handlers/logs.js +1 -1
  95. package/dist/server/handlers/memory.cjs +31 -63
  96. package/dist/server/handlers/memory.d.ts +103 -934
  97. package/dist/server/handlers/memory.d.ts.map +1 -1
  98. package/dist/server/handlers/memory.js +1 -1
  99. package/dist/server/handlers/observability.cjs +8 -24
  100. package/dist/server/handlers/observability.d.ts +21 -128
  101. package/dist/server/handlers/observability.d.ts.map +1 -1
  102. package/dist/server/handlers/observability.js +1 -1
  103. package/dist/server/handlers/scores.cjs +13 -13
  104. package/dist/server/handlers/scores.d.ts +141 -110
  105. package/dist/server/handlers/scores.d.ts.map +1 -1
  106. package/dist/server/handlers/scores.js +1 -1
  107. package/dist/server/handlers/telemetry.cjs +20 -0
  108. package/dist/server/handlers/telemetry.cjs.map +1 -0
  109. package/dist/server/handlers/telemetry.d.ts +33 -0
  110. package/dist/server/handlers/telemetry.d.ts.map +1 -0
  111. package/dist/server/handlers/telemetry.js +3 -0
  112. package/dist/server/handlers/telemetry.js.map +1 -0
  113. package/dist/server/handlers/tools.cjs +11 -11
  114. package/dist/server/handlers/tools.d.ts +23 -69
  115. package/dist/server/handlers/tools.d.ts.map +1 -1
  116. package/dist/server/handlers/tools.js +1 -1
  117. package/dist/server/handlers/utils.cjs +3 -11
  118. package/dist/server/handlers/utils.d.ts +0 -5
  119. package/dist/server/handlers/utils.d.ts.map +1 -1
  120. package/dist/server/handlers/utils.js +1 -1
  121. package/dist/server/handlers/vector.cjs +7 -31
  122. package/dist/server/handlers/vector.d.ts +9 -93
  123. package/dist/server/handlers/vector.d.ts.map +1 -1
  124. package/dist/server/handlers/vector.js +1 -1
  125. package/dist/server/handlers/voice.cjs +9 -21
  126. package/dist/server/handlers/voice.d.ts +40 -81
  127. package/dist/server/handlers/voice.d.ts.map +1 -1
  128. package/dist/server/handlers/voice.js +1 -1
  129. package/dist/server/handlers/workflows.cjs +45 -37
  130. package/dist/server/handlers/workflows.d.ts +83 -597
  131. package/dist/server/handlers/workflows.d.ts.map +1 -1
  132. package/dist/server/handlers/workflows.js +1 -1
  133. package/dist/server/handlers.cjs +36 -26
  134. package/dist/server/handlers.d.ts +2 -0
  135. package/dist/server/handlers.d.ts.map +1 -1
  136. package/dist/server/handlers.js +13 -11
  137. package/dist/server/http-exception.d.ts +5 -0
  138. package/dist/server/http-exception.d.ts.map +1 -1
  139. package/dist/server/utils.d.ts +2 -3
  140. package/dist/server/utils.d.ts.map +1 -1
  141. package/package.json +15 -26
  142. package/dist/chunk-2NW6POYK.cjs +0 -89
  143. package/dist/chunk-2NW6POYK.cjs.map +0 -1
  144. package/dist/chunk-35NT4TMQ.cjs +0 -201
  145. package/dist/chunk-35NT4TMQ.cjs.map +0 -1
  146. package/dist/chunk-3R5EV3HV.js.map +0 -1
  147. package/dist/chunk-4ECGVOJZ.cjs.map +0 -1
  148. package/dist/chunk-5PONYNYP.cjs +0 -125
  149. package/dist/chunk-5PONYNYP.cjs.map +0 -1
  150. package/dist/chunk-5W4RPVTK.cjs +0 -49
  151. package/dist/chunk-5W4RPVTK.cjs.map +0 -1
  152. package/dist/chunk-64ITUOXI.cjs.map +0 -1
  153. package/dist/chunk-6BISSAIF.js.map +0 -1
  154. package/dist/chunk-6DTV6NEW.js +0 -116
  155. package/dist/chunk-6DTV6NEW.js.map +0 -1
  156. package/dist/chunk-AEO6IHLK.cjs +0 -368
  157. package/dist/chunk-AEO6IHLK.cjs.map +0 -1
  158. package/dist/chunk-ASZUOBKV.js +0 -310
  159. package/dist/chunk-ASZUOBKV.js.map +0 -1
  160. package/dist/chunk-ECIVTQ4E.js +0 -354
  161. package/dist/chunk-ECIVTQ4E.js.map +0 -1
  162. package/dist/chunk-FAQICBMH.js +0 -164
  163. package/dist/chunk-FAQICBMH.js.map +0 -1
  164. package/dist/chunk-FXDZLX2Y.js +0 -192
  165. package/dist/chunk-FXDZLX2Y.js.map +0 -1
  166. package/dist/chunk-G7BPNX2V.js.map +0 -1
  167. package/dist/chunk-I5VZ5SKG.js +0 -328
  168. package/dist/chunk-I5VZ5SKG.js.map +0 -1
  169. package/dist/chunk-ICANWSEW.js +0 -204
  170. package/dist/chunk-ICANWSEW.js.map +0 -1
  171. package/dist/chunk-KB5NSROG.cjs +0 -211
  172. package/dist/chunk-KB5NSROG.cjs.map +0 -1
  173. package/dist/chunk-MWQQRVQC.cjs +0 -259
  174. package/dist/chunk-MWQQRVQC.cjs.map +0 -1
  175. package/dist/chunk-NDFAQBQD.cjs +0 -792
  176. package/dist/chunk-NDFAQBQD.cjs.map +0 -1
  177. package/dist/chunk-PKRHEXX7.js +0 -74
  178. package/dist/chunk-PKRHEXX7.js.map +0 -1
  179. package/dist/chunk-QGWCNTG6.cjs +0 -797
  180. package/dist/chunk-QGWCNTG6.cjs.map +0 -1
  181. package/dist/chunk-R4M3BSUG.js +0 -226
  182. package/dist/chunk-R4M3BSUG.js.map +0 -1
  183. package/dist/chunk-TBVUN4XN.cjs.map +0 -1
  184. package/dist/chunk-UJNHKFBR.cjs +0 -167
  185. package/dist/chunk-UJNHKFBR.cjs.map +0 -1
  186. package/dist/chunk-UOFV2ZCI.js +0 -878
  187. package/dist/chunk-UOFV2ZCI.js.map +0 -1
  188. package/dist/chunk-UZ6CYAOG.cjs.map +0 -1
  189. package/dist/chunk-VQAT5HX6.js +0 -756
  190. package/dist/chunk-VQAT5HX6.js.map +0 -1
  191. package/dist/chunk-XWGAT2DA.js +0 -44
  192. package/dist/chunk-XWGAT2DA.js.map +0 -1
  193. package/dist/chunk-YJ3VDL3Z.cjs +0 -346
  194. package/dist/chunk-YJ3VDL3Z.cjs.map +0 -1
  195. package/dist/chunk-Z36N2OQA.cjs +0 -907
  196. package/dist/chunk-Z36N2OQA.cjs.map +0 -1
  197. package/dist/chunk-ZLRTFRL4.js +0 -773
  198. package/dist/chunk-ZLRTFRL4.js.map +0 -1
  199. package/dist/chunk-ZODCSH2W.cjs +0 -322
  200. package/dist/chunk-ZODCSH2W.cjs.map +0 -1
  201. package/dist/server/handlers/test-utils.cjs +0 -15
  202. package/dist/server/handlers/test-utils.cjs.map +0 -1
  203. package/dist/server/handlers/test-utils.d.ts +0 -6
  204. package/dist/server/handlers/test-utils.d.ts.map +0 -1
  205. package/dist/server/handlers/test-utils.js +0 -13
  206. package/dist/server/handlers/test-utils.js.map +0 -1
  207. package/dist/server/schemas/a2a.d.ts +0 -786
  208. package/dist/server/schemas/a2a.d.ts.map +0 -1
  209. package/dist/server/schemas/agent-builder.d.ts +0 -195
  210. package/dist/server/schemas/agent-builder.d.ts.map +0 -1
  211. package/dist/server/schemas/agents.d.ts +0 -1375
  212. package/dist/server/schemas/agents.d.ts.map +0 -1
  213. package/dist/server/schemas/common.d.ts +0 -165
  214. package/dist/server/schemas/common.d.ts.map +0 -1
  215. package/dist/server/schemas/logs.d.ts +0 -124
  216. package/dist/server/schemas/logs.d.ts.map +0 -1
  217. package/dist/server/schemas/memory.d.ts +0 -998
  218. package/dist/server/schemas/memory.d.ts.map +0 -1
  219. package/dist/server/schemas/observability.d.ts +0 -402
  220. package/dist/server/schemas/observability.d.ts.map +0 -1
  221. package/dist/server/schemas/scores.d.ts +0 -259
  222. package/dist/server/schemas/scores.d.ts.map +0 -1
  223. package/dist/server/schemas/vectors.d.ts +0 -107
  224. package/dist/server/schemas/vectors.d.ts.map +0 -1
  225. package/dist/server/schemas/workflows.d.ts +0 -505
  226. package/dist/server/schemas/workflows.d.ts.map +0 -1
  227. package/dist/server/server-adapter/index.cjs +0 -323
  228. package/dist/server/server-adapter/index.cjs.map +0 -1
  229. package/dist/server/server-adapter/index.d.ts +0 -52
  230. package/dist/server/server-adapter/index.d.ts.map +0 -1
  231. package/dist/server/server-adapter/index.js +0 -309
  232. package/dist/server/server-adapter/index.js.map +0 -1
  233. package/dist/server/server-adapter/openapi-utils.d.ts +0 -59
  234. package/dist/server/server-adapter/openapi-utils.d.ts.map +0 -1
  235. package/dist/server/server-adapter/routes/a2a.d.ts +0 -3
  236. package/dist/server/server-adapter/routes/a2a.d.ts.map +0 -1
  237. package/dist/server/server-adapter/routes/agent-builder.d.ts +0 -3
  238. package/dist/server/server-adapter/routes/agent-builder.d.ts.map +0 -1
  239. package/dist/server/server-adapter/routes/agents.d.ts +0 -3
  240. package/dist/server/server-adapter/routes/agents.d.ts.map +0 -1
  241. package/dist/server/server-adapter/routes/index.d.ts +0 -41
  242. package/dist/server/server-adapter/routes/index.d.ts.map +0 -1
  243. package/dist/server/server-adapter/routes/legacy.d.ts +0 -7
  244. package/dist/server/server-adapter/routes/legacy.d.ts.map +0 -1
  245. package/dist/server/server-adapter/routes/logs.d.ts +0 -3
  246. package/dist/server/server-adapter/routes/logs.d.ts.map +0 -1
  247. package/dist/server/server-adapter/routes/memory.d.ts +0 -3
  248. package/dist/server/server-adapter/routes/memory.d.ts.map +0 -1
  249. package/dist/server/server-adapter/routes/observability.d.ts +0 -3
  250. package/dist/server/server-adapter/routes/observability.d.ts.map +0 -1
  251. package/dist/server/server-adapter/routes/route-builder.d.ts +0 -52
  252. package/dist/server/server-adapter/routes/route-builder.d.ts.map +0 -1
  253. package/dist/server/server-adapter/routes/scorers.d.ts +0 -3
  254. package/dist/server/server-adapter/routes/scorers.d.ts.map +0 -1
  255. package/dist/server/server-adapter/routes/stream-types.d.ts +0 -10
  256. package/dist/server/server-adapter/routes/stream-types.d.ts.map +0 -1
  257. package/dist/server/server-adapter/routes/tools.d.ts +0 -3
  258. package/dist/server/server-adapter/routes/tools.d.ts.map +0 -1
  259. package/dist/server/server-adapter/routes/vectors.d.ts +0 -3
  260. package/dist/server/server-adapter/routes/vectors.d.ts.map +0 -1
  261. package/dist/server/server-adapter/routes/workflows.d.ts +0 -3
  262. package/dist/server/server-adapter/routes/workflows.d.ts.map +0 -1
@@ -1,20 +1,13 @@
1
1
  'use strict';
2
2
 
3
- var chunkUZ6CYAOG_cjs = require('./chunk-UZ6CYAOG.cjs');
4
- var chunkUJNHKFBR_cjs = require('./chunk-UJNHKFBR.cjs');
3
+ var chunkVY4ENABS_cjs = require('./chunk-VY4ENABS.cjs');
5
4
  var chunkO7I5CWRX_cjs = require('./chunk-O7I5CWRX.cjs');
6
5
  var a2a = require('@mastra/core/a2a');
7
- var z = require('zod');
8
-
9
- function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
10
-
11
- var z__default = /*#__PURE__*/_interopDefault(z);
6
+ var zod = require('zod');
12
7
 
13
8
  // src/server/handlers/a2a.ts
14
9
  var a2a_exports = {};
15
10
  chunkO7I5CWRX_cjs.__export(a2a_exports, {
16
- AGENT_EXECUTION_ROUTE: () => AGENT_EXECUTION_ROUTE,
17
- GET_AGENT_CARD_ROUTE: () => GET_AGENT_CARD_ROUTE,
18
11
  getAgentCardByIdHandler: () => getAgentCardByIdHandler,
19
12
  getAgentExecutionHandler: () => getAgentExecutionHandler,
20
13
  handleMessageSend: () => handleMessageSend,
@@ -187,138 +180,24 @@ function createTaskContext({
187
180
  isCancelled: () => activeCancellations.has(task.id)
188
181
  };
189
182
  }
190
- var a2aAgentIdPathParams = z__default.default.object({
191
- agentId: z__default.default.string().describe("Unique identifier for the agent")
192
- });
193
- a2aAgentIdPathParams.extend({
194
- taskId: z__default.default.string().describe("Unique identifier for the task")
195
- });
196
- var pushNotificationAuthenticationInfoSchema = z__default.default.object({
197
- schemes: z__default.default.array(z__default.default.string()).describe("Supported authentication schemes - e.g. Basic, Bearer"),
198
- credentials: z__default.default.string().optional().describe("Optional credentials")
199
- });
200
- var pushNotificationConfigSchema = z__default.default.object({
201
- url: z__default.default.string().describe("URL for sending the push notifications"),
202
- id: z__default.default.string().optional().describe("Push Notification ID - created by server to support multiple callbacks"),
203
- token: z__default.default.string().optional().describe("Token unique to this task/session"),
204
- authentication: pushNotificationAuthenticationInfoSchema.optional()
205
- });
206
- var messageSendConfigurationSchema = z__default.default.object({
207
- acceptedOutputModes: z__default.default.array(z__default.default.string()).describe("Accepted output modalities by the client"),
208
- blocking: z__default.default.boolean().optional().describe("If the server should treat the client as a blocking request"),
209
- historyLength: z__default.default.number().optional().describe("Number of recent messages to be retrieved"),
210
- pushNotificationConfig: pushNotificationConfigSchema.optional()
211
- });
212
- var textPartSchema = z__default.default.object({
213
- kind: z__default.default.literal("text").describe("Part type - text for TextParts"),
214
- text: z__default.default.string().describe("Text content"),
215
- metadata: z__default.default.record(z__default.default.unknown()).optional().describe("Optional metadata associated with the part")
216
- });
217
- var fileWithBytesSchema = z__default.default.object({
218
- bytes: z__default.default.string().describe("base64 encoded content of the file"),
219
- mimeType: z__default.default.string().optional().describe("Optional mimeType for the file"),
220
- name: z__default.default.string().optional().describe("Optional name for the file")
221
- });
222
- var fileWithUriSchema = z__default.default.object({
223
- uri: z__default.default.string().describe("URL for the File content"),
224
- mimeType: z__default.default.string().optional().describe("Optional mimeType for the file"),
225
- name: z__default.default.string().optional().describe("Optional name for the file")
226
- });
227
- var filePartSchema = z__default.default.object({
228
- kind: z__default.default.literal("file").describe("Part type - file for FileParts"),
229
- file: z__default.default.union([fileWithBytesSchema, fileWithUriSchema]).describe("File content either as url or bytes"),
230
- metadata: z__default.default.record(z__default.default.unknown()).optional().describe("Optional metadata associated with the part")
231
- });
232
- var dataPartSchema = z__default.default.object({
233
- kind: z__default.default.literal("data").describe("Part type - data for DataParts"),
234
- data: z__default.default.record(z__default.default.unknown()).describe("Structured data content"),
235
- metadata: z__default.default.record(z__default.default.unknown()).optional().describe("Optional metadata associated with the part")
236
- });
237
- var partSchema = z__default.default.union([textPartSchema, filePartSchema, dataPartSchema]);
238
- var messageSchema = z__default.default.object({
239
- kind: z__default.default.literal("message").describe("Event type"),
240
- messageId: z__default.default.string().describe("Identifier created by the message creator"),
241
- role: z__default.default.enum(["user", "agent"]).describe("Message sender's role"),
242
- parts: z__default.default.array(partSchema).describe("Message content"),
243
- contextId: z__default.default.string().optional().describe("The context the message is associated with"),
244
- taskId: z__default.default.string().optional().describe("Identifier of task the message is related to"),
245
- referenceTaskIds: z__default.default.array(z__default.default.string()).optional().describe("List of tasks referenced as context by this message"),
246
- extensions: z__default.default.array(z__default.default.string()).optional().describe("The URIs of extensions that are present or contributed to this Message"),
247
- metadata: z__default.default.record(z__default.default.unknown()).optional().describe("Extension metadata")
248
- });
249
- var messageSendParamsSchema = z__default.default.object({
250
- message: messageSchema,
251
- configuration: messageSendConfigurationSchema.optional(),
252
- metadata: z__default.default.record(z__default.default.unknown()).optional().describe("Extension metadata")
253
- });
254
- var taskQueryParamsSchema = z__default.default.object({
255
- id: z__default.default.string().describe("Task id"),
256
- historyLength: z__default.default.number().optional().describe("Number of recent messages to be retrieved"),
257
- metadata: z__default.default.record(z__default.default.unknown()).optional()
258
- });
259
- var taskIdParamsSchema = z__default.default.object({
260
- id: z__default.default.string().describe("Task id"),
261
- metadata: z__default.default.record(z__default.default.unknown()).optional()
262
- });
263
- z__default.default.object({
264
- message: messageSchema,
265
- metadata: z__default.default.record(z__default.default.any()).optional()
266
- });
267
- z__default.default.object({
268
- id: z__default.default.string()
269
- });
270
- var agentExecutionParamsSchema = z__default.default.union([messageSendParamsSchema, taskQueryParamsSchema, taskIdParamsSchema]);
271
- var agentExecutionBodySchema = z__default.default.object({
272
- jsonrpc: z__default.default.literal("2.0"),
273
- id: z__default.default.union([z__default.default.string(), z__default.default.number()]),
274
- method: z__default.default.enum(["message/send", "message/stream", "tasks/get", "tasks/cancel"]),
275
- params: agentExecutionParamsSchema
276
- });
277
- var agentCardResponseSchema = z__default.default.object({
278
- name: z__default.default.string(),
279
- description: z__default.default.string(),
280
- url: z__default.default.string(),
281
- provider: z__default.default.object({
282
- organization: z__default.default.string(),
283
- url: z__default.default.string()
284
- }).optional(),
285
- version: z__default.default.string(),
286
- capabilities: z__default.default.object({
287
- streaming: z__default.default.boolean().optional(),
288
- pushNotifications: z__default.default.boolean().optional(),
289
- stateTransitionHistory: z__default.default.boolean().optional()
290
- }),
291
- defaultInputModes: z__default.default.array(z__default.default.string()),
292
- defaultOutputModes: z__default.default.array(z__default.default.string()),
293
- skills: z__default.default.array(
294
- z__default.default.object({
295
- id: z__default.default.string(),
296
- name: z__default.default.string(),
297
- description: z__default.default.string(),
298
- tags: z__default.default.array(z__default.default.string()).optional()
299
- })
300
- )
301
- });
302
- z__default.default.unknown();
303
- var agentExecutionResponseSchema = z__default.default.unknown();
304
183
 
305
184
  // src/server/handlers/a2a.ts
306
- var messageSendParamsSchema2 = z.z.object({
307
- message: z.z.object({
308
- role: z.z.enum(["user", "agent"]),
309
- parts: z.z.array(
310
- z.z.object({
311
- kind: z.z.enum(["text"]),
312
- text: z.z.string()
185
+ var messageSendParamsSchema = zod.z.object({
186
+ message: zod.z.object({
187
+ role: zod.z.enum(["user", "agent"]),
188
+ parts: zod.z.array(
189
+ zod.z.object({
190
+ kind: zod.z.enum(["text"]),
191
+ text: zod.z.string()
313
192
  })
314
193
  ),
315
- kind: z.z.literal("message"),
316
- messageId: z.z.string(),
317
- contextId: z.z.string().optional(),
318
- taskId: z.z.string().optional(),
319
- referenceTaskIds: z.z.array(z.z.string()).optional(),
320
- extensions: z.z.array(z.z.string()).optional(),
321
- metadata: z.z.record(z.z.any()).optional()
194
+ kind: zod.z.literal("message"),
195
+ messageId: zod.z.string(),
196
+ contextId: zod.z.string().optional(),
197
+ taskId: zod.z.string().optional(),
198
+ referenceTaskIds: zod.z.array(zod.z.string()).optional(),
199
+ extensions: zod.z.array(zod.z.string()).optional(),
200
+ metadata: zod.z.record(zod.z.any()).optional()
322
201
  })
323
202
  });
324
203
  async function getAgentCardByIdHandler({
@@ -330,19 +209,19 @@ async function getAgentCardByIdHandler({
330
209
  url: "https://mastra.ai"
331
210
  },
332
211
  version = "1.0",
333
- requestContext
212
+ runtimeContext
334
213
  }) {
335
- const agent = mastra.getAgent(agentId);
214
+ const agent = mastra.getAgentById(agentId);
336
215
  if (!agent) {
337
216
  throw new Error(`Agent with ID ${agentId} not found`);
338
217
  }
339
218
  const [instructions, tools] = await Promise.all([
340
- agent.getInstructions({ requestContext }),
341
- agent.listTools({ requestContext })
219
+ agent.getInstructions({ runtimeContext }),
220
+ agent.getTools({ runtimeContext })
342
221
  ]);
343
222
  const agentCard = {
344
223
  name: agent.id || agentId,
345
- description: chunkUZ6CYAOG_cjs.convertInstructionsToString(instructions),
224
+ description: chunkVY4ENABS_cjs.convertInstructionsToString(instructions),
346
225
  url: executionUrl,
347
226
  provider,
348
227
  version,
@@ -367,9 +246,9 @@ async function getAgentCardByIdHandler({
367
246
  }
368
247
  function validateMessageSendParams(params) {
369
248
  try {
370
- messageSendParamsSchema2.parse(params);
249
+ messageSendParamsSchema.parse(params);
371
250
  } catch (error) {
372
- if (error instanceof z.z.ZodError) {
251
+ if (error instanceof zod.z.ZodError) {
373
252
  throw a2a.MastraA2AError.invalidParams(error.errors[0].message);
374
253
  }
375
254
  throw error;
@@ -382,7 +261,7 @@ async function handleMessageSend({
382
261
  agent,
383
262
  agentId,
384
263
  logger,
385
- requestContext
264
+ runtimeContext
386
265
  }) {
387
266
  validateMessageSendParams(params);
388
267
  const { message, metadata } = params;
@@ -405,7 +284,7 @@ async function handleMessageSend({
405
284
  try {
406
285
  const { text } = await agent.generate([convertToCoreMessage(message)], {
407
286
  runId: taskId,
408
- requestContext
287
+ runtimeContext
409
288
  });
410
289
  currentData = applyUpdateToTask(currentData, {
411
290
  state: "completed",
@@ -466,7 +345,7 @@ async function* handleMessageStream({
466
345
  agent,
467
346
  agentId,
468
347
  logger,
469
- requestContext
348
+ runtimeContext
470
349
  }) {
471
350
  yield createSuccessResponse(requestId, {
472
351
  state: "working",
@@ -485,7 +364,7 @@ async function* handleMessageStream({
485
364
  taskStore,
486
365
  agent,
487
366
  agentId,
488
- requestContext,
367
+ runtimeContext,
489
368
  logger
490
369
  });
491
370
  } catch (err) {
@@ -534,13 +413,13 @@ async function getAgentExecutionHandler({
534
413
  requestId,
535
414
  mastra,
536
415
  agentId,
537
- requestContext,
416
+ runtimeContext,
538
417
  method,
539
418
  params,
540
419
  taskStore,
541
420
  logger
542
421
  }) {
543
- const agent = mastra.getAgent(agentId);
422
+ const agent = mastra.getAgentById(agentId);
544
423
  let taskId;
545
424
  try {
546
425
  taskId = "id" in params ? params.id : params.message?.taskId || "No task ID provided";
@@ -552,7 +431,7 @@ async function getAgentExecutionHandler({
552
431
  taskStore,
553
432
  agent,
554
433
  agentId,
555
- requestContext
434
+ runtimeContext
556
435
  });
557
436
  return result2;
558
437
  }
@@ -563,7 +442,7 @@ async function getAgentExecutionHandler({
563
442
  params,
564
443
  agent,
565
444
  agentId,
566
- requestContext
445
+ runtimeContext
567
446
  });
568
447
  return result;
569
448
  case "tasks/get": {
@@ -594,79 +473,7 @@ async function getAgentExecutionHandler({
594
473
  return normalizeError(error, requestId, taskId, logger);
595
474
  }
596
475
  }
597
- var GET_AGENT_CARD_ROUTE = chunkUJNHKFBR_cjs.createRoute({
598
- method: "GET",
599
- path: "/.well-known/:agentId/agent-card.json",
600
- responseType: "json",
601
- pathParamSchema: a2aAgentIdPathParams,
602
- responseSchema: agentCardResponseSchema,
603
- summary: "Get agent card",
604
- description: "Returns the agent card information for A2A protocol discovery",
605
- tags: ["Agent-to-Agent"],
606
- handler: async ({ mastra, agentId, requestContext }) => {
607
- const executionUrl = `/a2a/${agentId}`;
608
- const provider = {
609
- organization: "Mastra",
610
- url: "https://mastra.ai"
611
- };
612
- const version = "1.0";
613
- const agent = mastra.getAgent(agentId);
614
- if (!agent) {
615
- throw new Error(`Agent with ID ${agentId} not found`);
616
- }
617
- const [instructions, tools] = await Promise.all([
618
- agent.getInstructions({ requestContext }),
619
- agent.listTools({ requestContext })
620
- ]);
621
- const agentCard = {
622
- name: agent.id || agentId,
623
- description: chunkUZ6CYAOG_cjs.convertInstructionsToString(instructions),
624
- url: executionUrl,
625
- provider,
626
- version,
627
- capabilities: {
628
- streaming: true,
629
- pushNotifications: false,
630
- stateTransitionHistory: false
631
- },
632
- defaultInputModes: ["text"],
633
- defaultOutputModes: ["text"],
634
- skills: Object.entries(tools).map(([toolId, tool]) => ({
635
- id: toolId,
636
- name: toolId,
637
- description: tool.description || `Tool: ${toolId}`,
638
- tags: ["tool"]
639
- }))
640
- };
641
- return agentCard;
642
- }
643
- });
644
- var AGENT_EXECUTION_ROUTE = chunkUJNHKFBR_cjs.createRoute({
645
- method: "POST",
646
- path: "/a2a/:agentId",
647
- responseType: "json",
648
- pathParamSchema: a2aAgentIdPathParams,
649
- bodySchema: agentExecutionBodySchema,
650
- responseSchema: agentExecutionResponseSchema,
651
- summary: "Execute agent",
652
- description: "Executes an agent action via JSON-RPC 2.0 over A2A protocol",
653
- tags: ["Agent-to-Agent"],
654
- handler: async ({ mastra, agentId, requestContext, taskStore, ...bodyParams }) => {
655
- const { id: requestId, method, params } = bodyParams;
656
- return await getAgentExecutionHandler({
657
- requestId: String(requestId),
658
- mastra,
659
- agentId,
660
- requestContext,
661
- method,
662
- params,
663
- taskStore
664
- });
665
- }
666
- });
667
476
 
668
- exports.AGENT_EXECUTION_ROUTE = AGENT_EXECUTION_ROUTE;
669
- exports.GET_AGENT_CARD_ROUTE = GET_AGENT_CARD_ROUTE;
670
477
  exports.a2a_exports = a2a_exports;
671
478
  exports.getAgentCardByIdHandler = getAgentCardByIdHandler;
672
479
  exports.getAgentExecutionHandler = getAgentExecutionHandler;
@@ -674,5 +481,5 @@ exports.handleMessageSend = handleMessageSend;
674
481
  exports.handleMessageStream = handleMessageStream;
675
482
  exports.handleTaskCancel = handleTaskCancel;
676
483
  exports.handleTaskGet = handleTaskGet;
677
- //# sourceMappingURL=chunk-4ECGVOJZ.cjs.map
678
- //# sourceMappingURL=chunk-4ECGVOJZ.cjs.map
484
+ //# sourceMappingURL=chunk-7RGKOGE4.cjs.map
485
+ //# sourceMappingURL=chunk-7RGKOGE4.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/server/handlers/a2a.ts","../src/server/a2a/protocol.ts","../src/server/a2a/tasks.ts"],"names":["__export","MastraA2AError","z","convertInstructionsToString","result"],"mappings":";;;;;;;;AAAA,IAAA,WAAA,GAAA;AAAAA,0BAAA,CAAA,WAAA,EAAA;AAAA,EAAA,uBAAA,EAAA,MAAA,uBAAA;AAAA,EAAA,wBAAA,EAAA,MAAA,wBAAA;AAAA,EAAA,iBAAA,EAAA,MAAA,iBAAA;AAAA,EAAA,mBAAA,EAAA,MAAA,mBAAA;AAAA,EAAA,gBAAA,EAAA,MAAA,gBAAA;AAAA,EAAA,aAAA,EAAA,MAAA;AAAA,CAAA,CAAA;ACMO,SAAS,cAAA,CACd,KAAA,EACA,KAAA,EACA,MAAA,EACA,MAAA,EACgC;AAChC,EAAA,IAAI,QAAA;AACJ,EAAA,IAAI,iBAAiBC,kBAAA,EAAgB;AACnC,IAAA,QAAA,GAAW,KAAA;AAAA,EACb,CAAA,MAAA,IAAW,iBAAiB,KAAA,EAAO;AAEjC,IAAA,QAAA,GAAWA,kBAAA,CAAe,cAAc,KAAA,CAAM,OAAA,EAAS,EAAE,KAAA,EAAO,KAAA,CAAM,OAAO,CAAA;AAAA,EAC/E,CAAA,MAAO;AAEL,IAAA,QAAA,GAAWA,kBAAA,CAAe,aAAA,CAAc,4BAAA,EAA8B,KAAK,CAAA;AAAA,EAC7E;AAGA,EAAA,IAAI,MAAA,IAAU,CAAC,QAAA,CAAS,MAAA,EAAQ;AAC9B,IAAA,QAAA,CAAS,MAAA,GAAS,MAAA;AAAA,EACpB;AAEA,EAAA,MAAA,EAAQ,KAAA,CAAM,mCAAmC,QAAA,CAAS,MAAA,IAAU,KAAK,CAAA,SAAA,EAAY,KAAA,IAAS,KAAK,CAAA,EAAA,CAAA,EAAM,QAAQ,CAAA;AAEjH,EAAA,OAAO,mBAAA,CAAoB,KAAA,EAAO,QAAA,CAAS,cAAA,EAAgB,CAAA;AAC7D;AAEO,SAAS,mBAAA,CACd,IACA,KAAA,EACgC;AAEhC,EAAA,OAAO;AAAA,IACL,OAAA,EAAS,KAAA;AAAA,IACT,EAAA;AAAA;AAAA,IACA;AAAA,GACF;AACF;AAEO,SAAS,qBAAA,CAAyB,IAA4B,MAAA,EAA+B;AAClG,EAAA,IAAI,CAAC,EAAA,EAAI;AAEP,IAAA,MAAMA,kBAAA,CAAe,cAAc,6CAA6C,CAAA;AAAA,EAClF;AAEA,EAAA,OAAO;AAAA,IACL,OAAA,EAAS,KAAA;AAAA,IACT,EAAA;AAAA,IACA;AAAA,GACF;AACF;AAEO,SAAS,qBAAqB,OAAA,EAA+B;AAClE,EAAA,OAAO;AAAA,IACL,IAAA,EAAM,OAAA,CAAQ,IAAA,KAAS,MAAA,GAAS,MAAA,GAAS,WAAA;AAAA,IACzC,SAAS,OAAA,CAAQ,KAAA,CAAM,IAAI,CAAA,GAAA,KAAO,wBAAA,CAAyB,GAAG,CAAC;AAAA,GACjE;AACF;AAEA,SAAS,yBAAyB,IAAA,EAAY;AAC5C,EAAA,QAAQ,KAAK,IAAA;AAAM,IACjB,KAAK,MAAA;AACH,MAAA,OAAO;AAAA,QACL,IAAA,EAAM,MAAA;AAAA,QACN,MAAM,IAAA,CAAK;AAAA,OACb;AAAA,IACF,KAAK,MAAA;AACH,MAAA,OAAO;AAAA,QACL,IAAA,EAAM,MAAA;AAAA,QACN,IAAA,EAAM,KAAA,IAAS,IAAA,CAAK,IAAA,GAAO,IAAI,GAAA,CAAI,IAAA,CAAK,IAAA,CAAK,GAAG,CAAA,GAAI,IAAA,CAAK,IAAA,CAAK,KAAA;AAAA,QAC9D,QAAA,EAAU,KAAK,IAAA,CAAK;AAAA,OACtB;AAAA,IACF,KAAK,MAAA;AACH,MAAA,MAAM,IAAI,MAAM,+CAA+C,CAAA;AAAA;AAErE;;;ACrEA,SAAS,mBAAmB,MAAA,EAAuF;AACjH,EAAA,OAAO,OAAA,IAAW,MAAA,IAAU,EAAE,OAAA,IAAW,MAAA,CAAA;AAC3C;AAEA,SAAS,iBAAiB,MAAA,EAAiF;AACzG,EAAA,OAAO,MAAA,IAAU,MAAA,IAAU,MAAA,CAAO,IAAA,KAAS,iBAAA;AAC7C;AAEO,SAAS,iBAAA,CACd,SACA,MAAA,EACM;AACN,EAAA,IAAI,OAAA,GAAU,gBAAgB,OAAO,CAAA;AAErC,EAAA,IAAI,kBAAA,CAAmB,MAAM,CAAA,EAAG;AAE9B,IAAA,OAAA,CAAQ,MAAA,GAAS;AAAA,MACf,GAAG,OAAA,CAAQ,MAAA;AAAA;AAAA,MACX,GAAG,MAAA;AAAA;AAAA,MACH,SAAA,EAAA,iBAAW,IAAI,IAAA,EAAK,EAAE,WAAA;AAAY,KACpC;AAAA,EACF,CAAA,MAAA,IAAW,gBAAA,CAAiB,MAAM,CAAA,EAAG;AAEnC,IAAA,IAAI,CAAC,QAAQ,SAAA,EAAW;AACtB,MAAA,OAAA,CAAQ,YAAY,EAAC;AAAA,IACvB,CAAA,MAAO;AAEL,MAAA,OAAA,CAAQ,SAAA,GAAY,CAAC,GAAG,OAAA,CAAQ,SAAS,CAAA;AAAA,IAC3C;AAEA,IAAA,MAAM,WAAW,MAAA,CAAO,QAAA;AACxB,IAAA,MAAM,aAAA,GAAgB,QAAQ,SAAA,CAAU,SAAA,CAAU,OAAK,CAAA,CAAE,IAAA,KAAS,SAAS,IAAI,CAAA;AAC/E,IAAA,MAAM,gBAAA,GAAmB,OAAA,CAAQ,SAAA,CAAU,aAAa,CAAA;AAExD,IAAA,IAAI,gBAAA,EAAkB;AACpB,MAAA,IAAI,OAAO,MAAA,EAAQ;AAEjB,QAAA,MAAM,mBAAmB,IAAA,CAAK,KAAA,CAAM,IAAA,CAAK,SAAA,CAAU,gBAAgB,CAAC,CAAA;AACpE,QAAA,gBAAA,CAAiB,KAAA,CAAM,IAAA,CAAK,GAAG,QAAA,CAAS,KAAK,CAAA;AAC7C,QAAA,IAAI,SAAS,QAAA,EAAU;AACrB,UAAA,gBAAA,CAAiB,QAAA,GAAW;AAAA,YAC1B,GAAI,gBAAA,CAAiB,QAAA,IAAY,EAAC;AAAA,YAClC,GAAG,QAAA,CAAS;AAAA,WACd;AAAA,QACF;AACA,QAAA,IAAI,QAAA,CAAS,WAAA,EAAa,gBAAA,CAAiB,WAAA,GAAc,QAAA,CAAS,WAAA;AAClE,QAAA,OAAA,CAAQ,SAAA,CAAU,aAAa,CAAA,GAAI,gBAAA;AAAA,MACrC,CAAA,MAAO;AAEL,QAAA,OAAA,CAAQ,SAAA,CAAU,aAAa,CAAA,GAAI,EAAE,GAAG,QAAA,EAAS;AAAA,MACnD;AAAA,IACF,CAAA,MAAO;AACL,MAAA,OAAA,CAAQ,SAAA,CAAU,IAAA,CAAK,EAAE,GAAG,UAAU,CAAA;AAAA,IACxC;AAAA,EACF;AAEA,EAAA,OAAO,OAAA;AACT;AAEA,eAAsB,gBAAA,CAAiB;AAAA,EACrC,OAAA;AAAA,EACA,MAAA;AAAA,EACA,SAAA;AAAA,EACA,OAAA;AAAA,EACA,SAAA;AAAA,EACA,QAAA;AAAA,EACA;AACF,CAAA,EAQkB;AAChB,EAAA,MAAM,OAAO,MAAM,SAAA,CAAU,KAAK,EAAE,OAAA,EAAS,QAAQ,CAAA;AAGrD,EAAA,IAAI,CAAC,IAAA,EAAM;AACT,IAAA,MAAM,WAAA,GAAoB;AAAA,MACxB,EAAA,EAAI,MAAA;AAAA,MACJ,SAAA,EAAW,SAAA,IAAa,MAAA,CAAO,UAAA,EAAW;AAAA,MAC1C,MAAA,EAAQ;AAAA,QACN,KAAA,EAAO,WAAA;AAAA,QACP,SAAA,EAAA,iBAAW,IAAI,IAAA,EAAK,EAAE,WAAA,EAAY;AAAA,QAClC,OAAA,EAAS;AAAA,OACX;AAAA,MACA,WAAW,EAAC;AAAA,MACZ,OAAA,EAAS,CAAC,OAAO,CAAA;AAAA,MACjB,QAAA;AAAA,MACA,IAAA,EAAM;AAAA,KACR;AAEA,IAAA,MAAA,EAAQ,IAAA,CAAK,CAAA,MAAA,EAAS,MAAM,CAAA,mBAAA,CAAqB,CAAA;AACjD,IAAA,MAAM,UAAU,IAAA,CAAK,EAAE,OAAA,EAAS,IAAA,EAAM,aAAa,CAAA;AAEnD,IAAA,OAAO,WAAA;AAAA,EACT;AAGA,EAAA,MAAA,EAAQ,IAAA,CAAK,CAAA,MAAA,EAAS,MAAM,CAAA,uBAAA,CAAyB,CAAA;AAGrD,EAAA,IAAI,WAAA,GAAc,IAAA;AAClB,EAAA,WAAA,CAAY,UAAU,CAAC,GAAI,KAAK,OAAA,IAAW,IAAK,OAAO,CAAA;AAGvD,EAAA,MAAM,EAAE,QAAO,GAAI,IAAA;AACnB,EAAA,MAAM,WAAA,GAA2B,CAAC,WAAA,EAAa,QAAA,EAAU,UAAU,CAAA;AAEnE,EAAA,IAAI,WAAA,CAAY,QAAA,CAAS,MAAA,CAAO,KAAK,CAAA,EAAG;AACtC,IAAA,MAAA,EAAQ,KAAK,CAAA,MAAA,EAAS,MAAM,CAAA,2CAAA,EAA8C,MAAA,CAAO,KAAK,CAAA,aAAA,CAAe,CAAA;AACrG,IAAA,WAAA,GAAc,kBAAkB,WAAA,EAAa;AAAA,MAC3C,KAAA,EAAO,WAAA;AAAA,MACP,OAAA,EAAS;AAAA,KACV,CAAA;AAAA,EACH,CAAA,MAAA,IAAW,MAAA,CAAO,KAAA,KAAU,gBAAA,EAAkB;AAC5C,IAAA,MAAA,EAAQ,IAAA,CAAK,CAAA,MAAA,EAAS,MAAM,CAAA,oDAAA,CAAsD,CAAA;AAClF,IAAA,WAAA,GAAc,iBAAA,CAAkB,WAAA,EAAa,EAAE,KAAA,EAAO,WAAW,CAAA;AAAA,EACnE,CAAA,MAAA,IAAW,MAAA,CAAO,KAAA,KAAU,SAAA,EAAW;AACrC,IAAA,MAAA,EAAQ,IAAA,CAAK,CAAA,MAAA,EAAS,MAAM,CAAA,uDAAA,CAAyD,CAAA;AAAA,EACvF;AAEA,EAAA,MAAM,UAAU,IAAA,CAAK,EAAE,OAAA,EAAS,IAAA,EAAM,aAAa,CAAA;AAEnD,EAAA,OAAO,WAAA;AACT;AAEO,SAAS,iBAAA,CAAkB;AAAA,EAChC,IAAA;AAAA,EACA,WAAA;AAAA,EACA,OAAA;AAAA,EACA;AACF,CAAA,EAKgB;AACd,EAAA,OAAO;AAAA,IACL,IAAA,EAAM,gBAAgB,IAAI,CAAA;AAAA,IAC1B,WAAA;AAAA,IACA,OAAA,EAAS,gBAAgB,OAAO,CAAA;AAAA,IAChC,WAAA,EAAa,MAAM,mBAAA,CAAoB,GAAA,CAAI,KAAK,EAAE;AAAA,GACpD;AACF;;;AF3IA,IAAM,uBAAA,GAA0BC,MAAE,MAAA,CAAO;AAAA,EACvC,OAAA,EAASA,MAAE,MAAA,CAAO;AAAA,IAChB,MAAMA,KAAA,CAAE,IAAA,CAAK,CAAC,MAAA,EAAQ,OAAO,CAAC,CAAA;AAAA,IAC9B,OAAOA,KAAA,CAAE,KAAA;AAAA,MACPA,MAAE,MAAA,CAAO;AAAA,QACP,IAAA,EAAMA,KAAA,CAAE,IAAA,CAAK,CAAC,MAAM,CAAC,CAAA;AAAA,QACrB,IAAA,EAAMA,MAAE,MAAA;AAAO,OAChB;AAAA,KACH;AAAA,IACA,IAAA,EAAMA,KAAA,CAAE,OAAA,CAAQ,SAAS,CAAA;AAAA,IACzB,SAAA,EAAWA,MAAE,MAAA,EAAO;AAAA,IACpB,SAAA,EAAWA,KAAA,CAAE,MAAA,EAAO,CAAE,QAAA,EAAS;AAAA,IAC/B,MAAA,EAAQA,KAAA,CAAE,MAAA,EAAO,CAAE,QAAA,EAAS;AAAA,IAC5B,kBAAkBA,KAAA,CAAE,KAAA,CAAMA,MAAE,MAAA,EAAQ,EAAE,QAAA,EAAS;AAAA,IAC/C,YAAYA,KAAA,CAAE,KAAA,CAAMA,MAAE,MAAA,EAAQ,EAAE,QAAA,EAAS;AAAA,IACzC,UAAUA,KAAA,CAAE,MAAA,CAAOA,MAAE,GAAA,EAAK,EAAE,QAAA;AAAS,GACtC;AACH,CAAC,CAAA;AAED,eAAsB,uBAAA,CAAwB;AAAA,EAC5C,MAAA;AAAA,EACA,OAAA;AAAA,EACA,YAAA,GAAe,QAAQ,OAAO,CAAA,CAAA;AAAA,EAC9B,QAAA,GAAW;AAAA,IACT,YAAA,EAAc,QAAA;AAAA,IACd,GAAA,EAAK;AAAA,GACP;AAAA,EACA,OAAA,GAAU,KAAA;AAAA,EACV;AACF,CAAA,EASuB;AACrB,EAAA,MAAM,KAAA,GAAQ,MAAA,CAAO,YAAA,CAAa,OAAO,CAAA;AAEzC,EAAA,IAAI,CAAC,KAAA,EAAO;AACV,IAAA,MAAM,IAAI,KAAA,CAAM,CAAA,cAAA,EAAiB,OAAO,CAAA,UAAA,CAAY,CAAA;AAAA,EACtD;AAEA,EAAA,MAAM,CAAC,YAAA,EAAc,KAAK,CAAA,GAAI,MAAM,QAAQ,GAAA,CAAI;AAAA,IAC9C,KAAA,CAAM,eAAA,CAAgB,EAAE,cAAA,EAAgB,CAAA;AAAA,IACxC,KAAA,CAAM,QAAA,CAAS,EAAE,cAAA,EAAgB;AAAA,GAClC,CAAA;AAGD,EAAA,MAAM,SAAA,GAAuB;AAAA,IAC3B,IAAA,EAAM,MAAM,EAAA,IAAM,OAAA;AAAA,IAClB,WAAA,EAAaC,8CAA4B,YAAY,CAAA;AAAA,IACrD,GAAA,EAAK,YAAA;AAAA,IACL,QAAA;AAAA,IACA,OAAA;AAAA,IACA,YAAA,EAAc;AAAA,MACZ,SAAA,EAAW,IAAA;AAAA;AAAA,MACX,iBAAA,EAAmB,KAAA;AAAA,MACnB,sBAAA,EAAwB;AAAA,KAC1B;AAAA,IACA,iBAAA,EAAmB,CAAC,MAAM,CAAA;AAAA,IAC1B,kBAAA,EAAoB,CAAC,MAAM,CAAA;AAAA;AAAA,IAE3B,MAAA,EAAQ,MAAA,CAAO,OAAA,CAAQ,KAAK,CAAA,CAAE,IAAI,CAAC,CAAC,MAAA,EAAQ,IAAI,CAAA,MAAO;AAAA,MACrD,EAAA,EAAI,MAAA;AAAA,MACJ,IAAA,EAAM,MAAA;AAAA,MACN,WAAA,EAAa,IAAA,CAAK,WAAA,IAAe,CAAA,MAAA,EAAS,MAAM,CAAA,CAAA;AAAA;AAAA,MAEhD,IAAA,EAAM,CAAC,MAAM;AAAA,KACf,CAAE;AAAA,GACJ;AAEA,EAAA,OAAO,SAAA;AACT;AAEA,SAAS,0BAA0B,MAAA,EAA2B;AAC5D,EAAA,IAAI;AACF,IAAA,uBAAA,CAAwB,MAAM,MAAM,CAAA;AAAA,EACtC,SAAS,KAAA,EAAO;AACd,IAAA,IAAI,KAAA,YAAiBD,MAAE,QAAA,EAAU;AAC/B,MAAA,MAAMD,mBAAe,aAAA,CAAe,KAAA,CAAqB,MAAA,CAAO,CAAC,EAAG,OAAO,CAAA;AAAA,IAC7E;AAEA,IAAA,MAAM,KAAA;AAAA,EACR;AACF;AAEA,eAAsB,iBAAA,CAAkB;AAAA,EACtC,SAAA;AAAA,EACA,MAAA;AAAA,EACA,SAAA;AAAA,EACA,KAAA;AAAA,EACA,OAAA;AAAA,EACA,MAAA;AAAA,EACA;AACF,CAAA,EAQG;AACD,EAAA,yBAAA,CAA0B,MAAM,CAAA;AAEhC,EAAA,MAAM,EAAE,OAAA,EAAS,QAAA,EAAS,GAAI,MAAA;AAC9B,EAAA,MAAM,EAAE,WAAU,GAAI,OAAA;AACtB,EAAA,MAAM,MAAA,GAAS,OAAA,CAAQ,MAAA,IAAU,MAAA,CAAO,UAAA,EAAW;AAGnD,EAAA,IAAI,WAAA,GAAc,MAAM,gBAAA,CAAiB;AAAA,IACvC,MAAA;AAAA,IACA,SAAA;AAAA,IACA,OAAA;AAAA,IACA,OAAA;AAAA,IACA,SAAA;AAAA,IACA;AAAA,GACD,CAAA;AAGD,EAAgB,iBAAA,CAAkB;AAAA,IAChC,IAAA,EAAM,WAAA;AAAA,IACN,WAAA,EAAa,OAAA;AAAA,IACb,OAAA,EAAS,WAAA,CAAY,OAAA,IAAW,EAAC;AAAA,IACjC,qBAAqB,SAAA,CAAU;AAAA,GAChC;AAED,EAAA,IAAI;AACF,IAAA,MAAM,EAAE,IAAA,EAAK,GAAI,MAAM,KAAA,CAAM,SAAS,CAAC,oBAAA,CAAqB,OAAO,CAAC,CAAA,EAAG;AAAA,MACrE,KAAA,EAAO,MAAA;AAAA,MACP;AAAA,KACD,CAAA;AAED,IAAA,WAAA,GAAc,kBAAkB,WAAA,EAAa;AAAA,MAC3C,KAAA,EAAO,WAAA;AAAA,MACP,OAAA,EAAS;AAAA,QACP,SAAA,EAAW,OAAO,UAAA,EAAW;AAAA,QAC7B,IAAA,EAAM,OAAA;AAAA,QACN,KAAA,EAAO;AAAA,UACL;AAAA,YACE,IAAA,EAAM,MAAA;AAAA,YACN;AAAA;AACF,SACF;AAAA,QACA,IAAA,EAAM;AAAA;AACR,KACD,CAAA;AAED,IAAA,MAAM,UAAU,IAAA,CAAK,EAAE,OAAA,EAAS,IAAA,EAAM,aAAa,CAAA;AACpC,EACjB,SAAS,YAAA,EAAc;AAErB,IAAA,MAAM,mBAAA,GAAqD;AAAA,MACzD,KAAA,EAAO,QAAA;AAAA,MACP,OAAA,EAAS;AAAA,QACP,SAAA,EAAW,OAAO,UAAA,EAAW;AAAA,QAC7B,IAAA,EAAM,OAAA;AAAA,QACN,KAAA,EAAO;AAAA,UACL;AAAA,YACE,IAAA,EAAM,MAAA;AAAA,YACN,IAAA,EAAM,mBAAmB,YAAA,YAAwB,KAAA,GAAQ,aAAa,OAAA,GAAU,MAAA,CAAO,YAAY,CAAC,CAAA;AAAA;AACtG,SACF;AAAA,QACA,IAAA,EAAM;AAAA;AACR,KACF;AACA,IAAA,WAAA,GAAc,iBAAA,CAAkB,aAAa,mBAAmB,CAAA;AAEhE,IAAA,IAAI;AACF,MAAA,MAAM,UAAU,IAAA,CAAK,EAAE,OAAA,EAAS,IAAA,EAAM,aAAa,CAAA;AAAA,IACrD,SAAS,SAAA,EAAW;AAElB,MAAA,MAAA,EAAQ,MAAM,CAAA,oBAAA,EAAuB,WAAA,CAAY,EAAE,CAAA,qBAAA,CAAA,EAAyB,WAAW,OAAO,CAAA;AAAA,IAChG;AAEA,IAAA,OAAO,cAAA,CAAe,YAAA,EAAc,SAAA,EAAW,WAAA,CAAY,IAAI,MAAM,CAAA;AAAA,EACvE;AAGA,EAAA,OAAO,qBAAA,CAAsB,WAAW,WAAW,CAAA;AACrD;AAEA,eAAsB,aAAA,CAAc;AAAA,EAClC,SAAA;AAAA,EACA,SAAA;AAAA,EACA,OAAA;AAAA,EACA;AACF,CAAA,EAKG;AACD,EAAA,MAAM,OAAO,MAAM,SAAA,CAAU,KAAK,EAAE,OAAA,EAAS,QAAQ,CAAA;AAErD,EAAA,IAAI,CAAC,IAAA,EAAM;AACT,IAAA,MAAMA,kBAAAA,CAAe,aAAa,MAAM,CAAA;AAAA,EAC1C;AAEA,EAAA,OAAO,qBAAA,CAAsB,WAAW,IAAI,CAAA;AAC9C;AAEA,gBAAuB,mBAAA,CAAoB;AAAA,EACzC,SAAA;AAAA,EACA,MAAA;AAAA,EACA,SAAA;AAAA,EACA,KAAA;AAAA,EACA,OAAA;AAAA,EACA,MAAA;AAAA,EACA;AACF,CAAA,EAQG;AACD,EAAA,MAAM,sBAAsB,SAAA,EAAW;AAAA,IACrC,KAAA,EAAO,SAAA;AAAA,IACP,OAAA,EAAS;AAAA,MACP,SAAA,EAAW,OAAO,UAAA,EAAW;AAAA,MAC7B,IAAA,EAAM,SAAA;AAAA,MACN,IAAA,EAAM,OAAA;AAAA,MACN,OAAO,CAAC,EAAE,MAAM,MAAA,EAAQ,IAAA,EAAM,0BAA0B;AAAA;AAC1D,GACD,CAAA;AAED,EAAA,IAAI,MAAA;AACJ,EAAA,IAAI;AACF,IAAA,MAAA,GAAS,MAAM,iBAAA,CAAkB;AAAA,MAC/B,SAAA;AAAA,MACA,MAAA;AAAA,MACA,SAAA;AAAA,MACA,KAAA;AAAA,MACA,OAAA;AAAA,MACA,cAAA;AAAA,MACA;AAAA,KACD,CAAA;AAAA,EACH,SAAS,GAAA,EAAK;AACZ,IAAA,IAAI,EAAE,eAAeA,kBAAAA,CAAAA,EAAiB;AACpC,MAAA,MAAM,GAAA;AAAA,IACR;AAEA,IAAA,MAAA,GAAS,mBAAA,CAAoB,SAAA,EAAW,GAAA,CAAI,cAAA,EAAgB,CAAA;AAAA,EAC9D;AAEA,EAAA,MAAM,MAAA;AACR;AAEA,eAAsB,gBAAA,CAAiB;AAAA,EACrC,SAAA;AAAA,EACA,SAAA;AAAA,EACA,OAAA;AAAA,EACA,MAAA;AAAA,EACA;AACF,CAAA,EAMG;AAED,EAAA,IAAI,IAAA,GAAO,MAAM,SAAA,CAAU,IAAA,CAAK;AAAA,IAC9B,OAAA;AAAA,IACA;AAAA,GACD,CAAA;AAED,EAAA,IAAI,CAAC,IAAA,EAAM;AACT,IAAA,MAAMA,kBAAAA,CAAe,aAAa,MAAM,CAAA;AAAA,EAC1C;AAGA,EAAA,MAAM,WAAA,GAA2B,CAAC,WAAA,EAAa,QAAA,EAAU,UAAU,CAAA;AAEnE,EAAA,IAAI,WAAA,CAAY,QAAA,CAAS,IAAA,CAAK,MAAA,CAAO,KAAK,CAAA,EAAG;AAC3C,IAAA,MAAA,EAAQ,KAAK,CAAA,KAAA,EAAQ,MAAM,2BAA2B,IAAA,CAAK,MAAA,CAAO,KAAK,CAAA,gBAAA,CAAkB,CAAA;AACzF,IAAA,OAAO,qBAAA,CAAsB,WAAW,IAAI,CAAA;AAAA,EAC9C;AAGA,EAAA,SAAA,CAAU,mBAAA,CAAoB,IAAI,MAAM,CAAA;AAGxC,EAAA,MAAM,YAAA,GAA8C;AAAA,IAClD,KAAA,EAAO,UAAA;AAAA,IACP,OAAA,EAAS;AAAA,MACP,IAAA,EAAM,OAAA;AAAA,MACN,OAAO,CAAC,EAAE,MAAM,MAAA,EAAQ,IAAA,EAAM,8BAA8B,CAAA;AAAA,MAC5D,IAAA,EAAM,SAAA;AAAA,MACN,SAAA,EAAW,OAAO,UAAA;AAAW;AAC/B,GACF;AAEA,EAAA,IAAA,GAAO,iBAAA,CAAkB,MAAM,YAAY,CAAA;AAG3C,EAAA,MAAM,SAAA,CAAU,IAAA,CAAK,EAAE,OAAA,EAAS,MAAM,CAAA;AAGtC,EAAA,SAAA,CAAU,mBAAA,CAAoB,OAAO,MAAM,CAAA;AAG3C,EAAA,OAAO,qBAAA,CAAsB,WAAW,IAAI,CAAA;AAC9C;AAEA,eAAsB,wBAAA,CAAyB;AAAA,EAC7C,SAAA;AAAA,EACA,MAAA;AAAA,EACA,OAAA;AAAA,EACA,cAAA;AAAA,EACA,MAAA;AAAA,EACA,MAAA;AAAA,EACA,SAAA;AAAA,EACA;AACF,CAAA,EAQiB;AACf,EAAA,MAAM,KAAA,GAAQ,MAAA,CAAO,YAAA,CAAa,OAAO,CAAA;AAEzC,EAAA,IAAI,MAAA;AAEJ,EAAA,IAAI;AAGF,IAAA,MAAA,GAAS,QAAQ,MAAA,GAAS,MAAA,CAAO,EAAA,GAAK,MAAA,CAAO,SAAS,MAAA,IAAU,qBAAA;AAGhE,IAAA,QAAQ,MAAA;AAAQ,MACd,KAAK,cAAA,EAAgB;AACnB,QAAA,MAAMG,OAAAA,GAAS,MAAM,iBAAA,CAAkB;AAAA,UACrC,SAAA;AAAA,UACA,MAAA;AAAA,UACA,SAAA;AAAA,UACA,KAAA;AAAA,UACA,OAAA;AAAA,UACA;AAAA,SACD,CAAA;AACD,QAAA,OAAOA,OAAAA;AAAA,MACT;AAAA,MACA,KAAK,gBAAA;AACH,QAAA,MAAM,MAAA,GAAS,MAAM,mBAAA,CAAoB;AAAA,UACvC,SAAA;AAAA,UACA,SAAA;AAAA,UACA,MAAA;AAAA,UACA,KAAA;AAAA,UACA,OAAA;AAAA,UACA;AAAA,SACD,CAAA;AACD,QAAA,OAAO,MAAA;AAAA,MAET,KAAK,WAAA,EAAa;AAChB,QAAA,MAAMA,OAAAA,GAAS,MAAM,aAAA,CAAc;AAAA,UACjC,SAAA;AAAA,UACA,SAAA;AAAA,UACA,OAAA;AAAA,UACA;AAAA,SACD,CAAA;AAED,QAAA,OAAOA,OAAAA;AAAA,MACT;AAAA,MACA,KAAK,cAAA,EAAgB;AACnB,QAAA,MAAMA,OAAAA,GAAS,MAAM,gBAAA,CAAiB;AAAA,UACpC,SAAA;AAAA,UACA,SAAA;AAAA,UACA,OAAA;AAAA,UACA;AAAA,SACD,CAAA;AAED,QAAA,OAAOA,OAAAA;AAAA,MACT;AAAA,MACA;AACE,QAAA,MAAMH,kBAAAA,CAAe,eAAe,MAAM,CAAA;AAAA;AAC9C,EACF,SAAS,KAAA,EAAO;AACd,IAAA,IAAI,KAAA,YAAiBA,kBAAAA,IAAkB,MAAA,IAAU,CAAC,MAAM,MAAA,EAAQ;AAC9D,MAAA,KAAA,CAAM,MAAA,GAAS,MAAA;AAAA,IACjB;AAEA,IAAA,OAAO,cAAA,CAAe,KAAA,EAAO,SAAA,EAAW,MAAA,EAAQ,MAAM,CAAA;AAAA,EACxD;AACF","file":"chunk-7RGKOGE4.cjs","sourcesContent":["import { MastraA2AError } from '@mastra/core/a2a';\nimport type {\n MessageSendParams,\n TaskQueryParams,\n TaskIdParams,\n AgentCard,\n TaskStatus,\n TaskState,\n} 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 type { InMemoryTaskStore } from '../a2a/store';\nimport { applyUpdateToTask, createTaskContext, loadOrCreateTask } from '../a2a/tasks';\nimport type { Context } from '../types';\nimport { convertInstructionsToString } from '../utils';\n\nconst messageSendParamsSchema = z.object({\n message: z.object({\n role: z.enum(['user', 'agent']),\n parts: z.array(\n z.object({\n kind: z.enum(['text']),\n text: z.string(),\n }),\n ),\n kind: z.literal('message'),\n messageId: z.string(),\n contextId: z.string().optional(),\n taskId: z.string().optional(),\n referenceTaskIds: z.array(z.string()).optional(),\n extensions: z.array(z.string()).optional(),\n metadata: z.record(z.any()).optional(),\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.getAgentById(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: convertInstructionsToString(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 validateMessageSendParams(params: MessageSendParams) {\n try {\n messageSendParamsSchema.parse(params);\n } catch (error) {\n if (error instanceof z.ZodError) {\n throw MastraA2AError.invalidParams((error as z.ZodError).errors[0]!.message);\n }\n\n throw error;\n }\n}\n\nexport async function handleMessageSend({\n requestId,\n params,\n taskStore,\n agent,\n agentId,\n logger,\n runtimeContext,\n}: {\n requestId: string;\n params: MessageSendParams;\n taskStore: InMemoryTaskStore;\n agent: Agent;\n agentId: string;\n logger?: IMastraLogger;\n runtimeContext: RuntimeContext;\n}) {\n validateMessageSendParams(params);\n\n const { message, metadata } = params;\n const { contextId } = message;\n const taskId = message.taskId || crypto.randomUUID();\n\n // Load or create task\n let currentData = await loadOrCreateTask({\n taskId,\n taskStore,\n agentId,\n message,\n contextId,\n metadata,\n });\n\n // Use the new TaskContext definition, passing history\n const context = createTaskContext({\n task: currentData,\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 = applyUpdateToTask(currentData, {\n state: 'completed',\n message: {\n messageId: crypto.randomUUID(),\n role: 'agent',\n parts: [\n {\n kind: 'text',\n text: text,\n },\n ],\n kind: 'message',\n },\n });\n\n await taskStore.save({ agentId, data: currentData });\n context.task = currentData;\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 messageId: crypto.randomUUID(),\n role: 'agent',\n parts: [\n {\n kind: 'text',\n text: `Handler failed: ${handlerError instanceof Error ? handlerError.message : String(handlerError)}`,\n },\n ],\n kind: 'message',\n },\n };\n currentData = applyUpdateToTask(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 ${currentData.id} after handler error:`, saveError?.message);\n }\n\n return normalizeError(handlerError, requestId, currentData.id, logger); // Rethrow original error\n }\n\n // The loop finished, send the final task state\n return createSuccessResponse(requestId, currentData);\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 MastraA2AError.taskNotFound(taskId);\n }\n\n return createSuccessResponse(requestId, task);\n}\n\nexport async function* handleMessageStream({\n requestId,\n params,\n taskStore,\n agent,\n agentId,\n logger,\n runtimeContext,\n}: {\n requestId: string;\n params: MessageSendParams;\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 messageId: crypto.randomUUID(),\n kind: 'message',\n role: 'agent',\n parts: [{ kind: 'text', text: 'Generating response...' }],\n },\n });\n\n let result;\n try {\n result = await handleMessageSend({\n requestId,\n params,\n taskStore,\n agent,\n agentId,\n runtimeContext,\n logger,\n });\n } catch (err) {\n if (!(err instanceof MastraA2AError)) {\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 MastraA2AError.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.status.state)) {\n logger?.info(`Task ${taskId} already in final state ${data.status.state}, cannot cancel.`);\n return createSuccessResponse(requestId, data);\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: [{ kind: 'text', text: 'Task cancelled by request.' }],\n kind: 'message',\n messageId: crypto.randomUUID(),\n },\n };\n\n data = applyUpdateToTask(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);\n}\n\nexport async function getAgentExecutionHandler({\n requestId,\n mastra,\n agentId,\n runtimeContext,\n method,\n params,\n taskStore,\n logger,\n}: Context & {\n requestId: string;\n runtimeContext: RuntimeContext;\n agentId: string;\n method: 'message/send' | 'message/stream' | 'tasks/get' | 'tasks/cancel';\n params: MessageSendParams | TaskQueryParams | TaskIdParams;\n taskStore: InMemoryTaskStore;\n logger?: IMastraLogger;\n}): Promise<any> {\n const agent = mastra.getAgentById(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 = 'id' in params ? params.id : params.message?.taskId || 'No task ID provided';\n\n // 2. Route based on method\n switch (method) {\n case 'message/send': {\n const result = await handleMessageSend({\n requestId,\n params: params as MessageSendParams,\n taskStore,\n agent,\n agentId,\n runtimeContext,\n });\n return result;\n }\n case 'message/stream':\n const result = await handleMessageStream({\n requestId,\n taskStore,\n params: params as MessageSendParams,\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 MastraA2AError.methodNotFound(method);\n }\n } catch (error) {\n if (error instanceof MastraA2AError && 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 { MastraA2AError } 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: MastraA2AError;\n if (error instanceof MastraA2AError) {\n a2aError = error;\n } else if (error instanceof Error) {\n // Generic JS error\n a2aError = MastraA2AError.internalError(error.message, { stack: error.stack });\n } else {\n // Unknown error type\n a2aError = MastraA2AError.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 MastraA2AError.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.kind) {\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: 'uri' in part.file ? new URL(part.file.uri) : part.file.bytes,\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 {\n Message,\n Task,\n TaskState,\n TaskStatus,\n TaskContext,\n TaskArtifactUpdateEvent,\n Artifact,\n} from '@mastra/core/a2a';\nimport type { IMastraLogger } from '@mastra/core/logger';\nimport type { InMemoryTaskStore } from './store';\n\nfunction isTaskStatusUpdate(update: TaskStatus | TaskArtifactUpdateEvent): update is Omit<TaskStatus, 'timestamp'> {\n return 'state' in update && !('parts' in update);\n}\n\nfunction isArtifactUpdate(update: TaskStatus | TaskArtifactUpdateEvent): update is TaskArtifactUpdateEvent {\n return 'kind' in update && update.kind === 'artifact-update';\n}\n\nexport function applyUpdateToTask(\n current: Task,\n update: Omit<TaskStatus, 'timestamp'> | TaskArtifactUpdateEvent,\n): Task {\n let newTask = structuredClone(current);\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 } 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 artifact = update.artifact;\n const existingIndex = newTask.artifacts.findIndex(a => a.name === artifact.name);\n const existingArtifact = newTask.artifacts[existingIndex];\n\n if (existingArtifact) {\n if (update.append) {\n // Create a deep copy for modification to avoid mutating original\n const appendedArtifact = JSON.parse(JSON.stringify(existingArtifact)) as Artifact;\n appendedArtifact.parts.push(...artifact.parts);\n if (artifact.metadata) {\n appendedArtifact.metadata = {\n ...(appendedArtifact.metadata || {}),\n ...artifact.metadata,\n };\n }\n if (artifact.description) appendedArtifact.description = artifact.description;\n newTask.artifacts[existingIndex] = appendedArtifact; // Replace with appended version\n } else {\n // Overwrite artifact at index (with a copy of the update)\n newTask.artifacts[existingIndex] = { ...artifact };\n }\n } else {\n newTask.artifacts.push({ ...artifact });\n }\n }\n\n return newTask;\n}\n\nexport async function loadOrCreateTask({\n agentId,\n taskId,\n taskStore,\n message,\n contextId,\n metadata,\n logger,\n}: {\n agentId: string;\n taskId: string;\n taskStore: InMemoryTaskStore;\n message: Message;\n contextId?: string;\n metadata?: Record<string, unknown>;\n logger?: IMastraLogger;\n}): Promise<Task> {\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 contextId: contextId || crypto.randomUUID(),\n status: {\n state: 'submitted',\n timestamp: new Date().toISOString(),\n message: undefined,\n },\n artifacts: [],\n history: [message],\n metadata: metadata,\n kind: 'task',\n };\n\n logger?.info(`[Task ${taskId}] Created new task.`);\n await taskStore.save({ agentId, data: initialTask });\n\n return initialTask;\n }\n\n // Handle existing task\n logger?.info(`[Task ${taskId}] Loaded existing task.`);\n\n // Add message to history and prepare updated data\n let updatedData = data;\n updatedData.history = [...(data.history || []), message];\n\n // Handle state transitions\n const { status } = data;\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 = applyUpdateToTask(updatedData, {\n state: 'submitted',\n message: undefined,\n });\n } else if (status.state === 'input-required') {\n logger?.info(`[Task ${taskId}] Changing state from 'input-required' to 'working'.`);\n updatedData = applyUpdateToTask(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 updatedData;\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"]}
@@ -0,0 +1,83 @@
1
+ import { validateBody } from './chunk-4QCXUEAT.js';
2
+ import { handleError } from './chunk-CY4TP3FK.js';
3
+ import { __export } from './chunk-PR4QN5HX.js';
4
+
5
+ // src/server/handlers/logs.ts
6
+ var logs_exports = {};
7
+ __export(logs_exports, {
8
+ getLogTransports: () => getLogTransports,
9
+ getLogsByRunIdHandler: () => getLogsByRunIdHandler,
10
+ getLogsHandler: () => getLogsHandler
11
+ });
12
+ async function getLogsHandler({
13
+ mastra,
14
+ transportId,
15
+ params
16
+ }) {
17
+ try {
18
+ validateBody({ transportId });
19
+ const { fromDate, toDate, logLevel, filters: _filters, page, perPage } = params || {};
20
+ const filters = _filters ? Object.fromEntries(
21
+ (Array.isArray(_filters) ? _filters : [_filters]).map((attr) => {
22
+ const [key, value] = attr.split(":");
23
+ return [key, value];
24
+ })
25
+ ) : void 0;
26
+ const logs = await mastra.getLogs(transportId, {
27
+ fromDate,
28
+ toDate,
29
+ logLevel,
30
+ filters,
31
+ page: page ? Number(page) : void 0,
32
+ perPage: perPage ? Number(perPage) : void 0
33
+ });
34
+ return logs;
35
+ } catch (error) {
36
+ return handleError(error, "Error getting logs");
37
+ }
38
+ }
39
+ async function getLogsByRunIdHandler({
40
+ mastra,
41
+ runId,
42
+ transportId,
43
+ params
44
+ }) {
45
+ try {
46
+ validateBody({ runId, transportId });
47
+ const { fromDate, toDate, logLevel, filters: _filters, page, perPage } = params || {};
48
+ const filters = _filters ? Object.fromEntries(
49
+ (Array.isArray(_filters) ? _filters : [_filters]).map((attr) => {
50
+ const [key, value] = attr.split(":");
51
+ return [key, value];
52
+ })
53
+ ) : void 0;
54
+ const logs = await mastra.getLogsByRunId({
55
+ runId,
56
+ transportId,
57
+ fromDate,
58
+ toDate,
59
+ logLevel,
60
+ filters,
61
+ page: page ? Number(page) : void 0,
62
+ perPage: perPage ? Number(perPage) : void 0
63
+ });
64
+ return logs;
65
+ } catch (error) {
66
+ return handleError(error, "Error getting logs by run ID");
67
+ }
68
+ }
69
+ async function getLogTransports({ mastra }) {
70
+ try {
71
+ const logger = mastra.getLogger();
72
+ const transports = logger.getTransports();
73
+ return {
74
+ transports: transports ? [...transports.keys()] : []
75
+ };
76
+ } catch (error) {
77
+ return handleError(error, "Error getting log Transports");
78
+ }
79
+ }
80
+
81
+ export { getLogTransports, getLogsByRunIdHandler, getLogsHandler, logs_exports };
82
+ //# sourceMappingURL=chunk-ABRFV4XP.js.map
83
+ //# sourceMappingURL=chunk-ABRFV4XP.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/server/handlers/logs.ts"],"names":[],"mappings":"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","file":"chunk-ABRFV4XP.js","sourcesContent":["import type { BaseLogMessage, LogLevel } from '@mastra/core/logger';\nimport type { Mastra } from '@mastra/core/mastra';\nimport { handleError } from './error';\nimport { validateBody } from './utils';\n\ntype LogsContext = {\n mastra: Mastra;\n transportId?: string;\n runId?: string;\n params?: {\n fromDate?: Date;\n toDate?: Date;\n logLevel?: LogLevel;\n filters?: string | string[];\n page?: number;\n perPage?: number;\n };\n};\n\nexport async function getLogsHandler({\n mastra,\n transportId,\n params,\n}: Pick<LogsContext, 'mastra' | 'transportId' | 'params'>): Promise<{\n logs: BaseLogMessage[];\n total: number;\n page: number;\n perPage: number;\n hasMore: boolean;\n}> {\n try {\n validateBody({ transportId });\n\n const { fromDate, toDate, logLevel, filters: _filters, page, perPage } = params || {};\n\n // Parse filter query parameter if present\n const filters = _filters\n ? Object.fromEntries(\n (Array.isArray(_filters) ? _filters : [_filters]).map(attr => {\n const [key, value] = attr.split(':');\n return [key, value];\n }),\n )\n : undefined;\n\n const logs = await mastra.getLogs(transportId!, {\n fromDate,\n toDate,\n logLevel,\n filters,\n page: page ? Number(page) : undefined,\n perPage: perPage ? Number(perPage) : undefined,\n });\n return logs;\n } catch (error) {\n return handleError(error, 'Error getting logs');\n }\n}\n\nexport async function getLogsByRunIdHandler({\n mastra,\n runId,\n transportId,\n params,\n}: Pick<LogsContext, 'mastra' | 'runId' | 'transportId' | 'params'>) {\n try {\n validateBody({ runId, transportId });\n\n const { fromDate, toDate, logLevel, filters: _filters, page, perPage } = params || {};\n\n // Parse filter query parameter if present\n const filters = _filters\n ? Object.fromEntries(\n (Array.isArray(_filters) ? _filters : [_filters]).map(attr => {\n const [key, value] = attr.split(':');\n return [key, value];\n }),\n )\n : undefined;\n\n const logs = await mastra.getLogsByRunId({\n runId: runId!,\n transportId: transportId!,\n fromDate,\n toDate,\n logLevel,\n filters,\n page: page ? Number(page) : undefined,\n perPage: perPage ? Number(perPage) : undefined,\n });\n return logs;\n } catch (error) {\n return handleError(error, 'Error getting logs by run ID');\n }\n}\n\nexport async function getLogTransports({ mastra }: Pick<LogsContext, 'mastra'>) {\n try {\n const logger = mastra.getLogger();\n const transports = logger.getTransports();\n\n return {\n transports: transports ? [...transports.keys()] : [],\n };\n } catch (error) {\n return handleError(error, 'Error getting log Transports');\n }\n}\n"]}