@mastra/server 0.0.0-sidebar-window-undefined-fix-20251029233656 → 0.0.0-standard-schema-20260123120255

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 (461) hide show
  1. package/CHANGELOG.md +2492 -3
  2. package/README.md +2 -2
  3. package/a2a/store.d.ts +1 -0
  4. package/auth.d.ts +1 -0
  5. package/dist/{chunk-SHWNNZBL.js → chunk-24SISJRB.js} +13 -17
  6. package/dist/chunk-24SISJRB.js.map +1 -0
  7. package/dist/chunk-2JNW2CLE.js +180 -0
  8. package/dist/chunk-2JNW2CLE.js.map +1 -0
  9. package/dist/chunk-2UHOWYFV.js +184 -0
  10. package/dist/chunk-2UHOWYFV.js.map +1 -0
  11. package/dist/chunk-3W67K7YE.js +13 -0
  12. package/dist/chunk-3W67K7YE.js.map +1 -0
  13. package/dist/chunk-4HFYR562.cjs +82 -0
  14. package/dist/chunk-4HFYR562.cjs.map +1 -0
  15. package/dist/chunk-55TH4ME5.js +170 -0
  16. package/dist/chunk-55TH4ME5.js.map +1 -0
  17. package/dist/chunk-55XIQCGI.cjs +1128 -0
  18. package/dist/chunk-55XIQCGI.cjs.map +1 -0
  19. package/dist/chunk-5NQ3GWUJ.cjs +1118 -0
  20. package/dist/chunk-5NQ3GWUJ.cjs.map +1 -0
  21. package/dist/chunk-5W4RPVTK.cjs +49 -0
  22. package/dist/chunk-5W4RPVTK.cjs.map +1 -0
  23. package/dist/{chunk-7NADHFD2.cjs → chunk-64ITUOXI.cjs} +2 -2
  24. package/dist/chunk-64ITUOXI.cjs.map +1 -0
  25. package/dist/{chunk-QU6N55W6.cjs → chunk-6G2RQWKA.cjs} +17 -21
  26. package/dist/chunk-6G2RQWKA.cjs.map +1 -0
  27. package/dist/chunk-6NLJ5YC3.cjs +216 -0
  28. package/dist/chunk-6NLJ5YC3.cjs.map +1 -0
  29. package/dist/chunk-6OFKRQQL.js +45 -0
  30. package/dist/chunk-6OFKRQQL.js.map +1 -0
  31. package/dist/{chunk-MMROOK5J.js → chunk-6QWQZI4Q.js} +2 -2
  32. package/dist/{chunk-7NADHFD2.cjs.map → chunk-6QWQZI4Q.js.map} +1 -1
  33. package/dist/chunk-7AINN3FK.js +26 -0
  34. package/dist/chunk-7AINN3FK.js.map +1 -0
  35. package/dist/chunk-7D3UAMQM.cjs +82 -0
  36. package/dist/chunk-7D3UAMQM.cjs.map +1 -0
  37. package/dist/chunk-7ERB6H6K.js +334 -0
  38. package/dist/chunk-7ERB6H6K.js.map +1 -0
  39. package/dist/chunk-AEMLCRS5.cjs +1140 -0
  40. package/dist/chunk-AEMLCRS5.cjs.map +1 -0
  41. package/dist/chunk-BLCHLNBT.js +442 -0
  42. package/dist/chunk-BLCHLNBT.js.map +1 -0
  43. package/dist/chunk-BSOLG32W.js +1089 -0
  44. package/dist/chunk-BSOLG32W.js.map +1 -0
  45. package/dist/chunk-CQUWREB2.js +332 -0
  46. package/dist/chunk-CQUWREB2.js.map +1 -0
  47. package/dist/chunk-CRCXQW5R.cjs +47 -0
  48. package/dist/chunk-CRCXQW5R.cjs.map +1 -0
  49. package/dist/{chunk-MN2TZQ7I.js → chunk-CT7S7VRG.js} +232 -38
  50. package/dist/chunk-CT7S7VRG.js.map +1 -0
  51. package/dist/chunk-D23WBCJ6.js +227 -0
  52. package/dist/chunk-D23WBCJ6.js.map +1 -0
  53. package/dist/chunk-DOU5IGJB.js +242 -0
  54. package/dist/chunk-DOU5IGJB.js.map +1 -0
  55. package/dist/chunk-DUTGH2DM.js +31748 -0
  56. package/dist/chunk-DUTGH2DM.js.map +1 -0
  57. package/dist/chunk-E2SZSFGZ.cjs +128 -0
  58. package/dist/chunk-E2SZSFGZ.cjs.map +1 -0
  59. package/dist/chunk-EH45MGLR.cjs +322 -0
  60. package/dist/chunk-EH45MGLR.cjs.map +1 -0
  61. package/dist/chunk-FRRHYZR6.cjs +88 -0
  62. package/dist/chunk-FRRHYZR6.cjs.map +1 -0
  63. package/dist/{chunk-ZULZ2752.js → chunk-FXW7MD4U.js} +3 -3
  64. package/dist/chunk-FXW7MD4U.js.map +1 -0
  65. package/dist/chunk-GGAV65A7.cjs +352 -0
  66. package/dist/chunk-GGAV65A7.cjs.map +1 -0
  67. package/dist/chunk-HT4LP3BO.js +75 -0
  68. package/dist/chunk-HT4LP3BO.js.map +1 -0
  69. package/dist/chunk-HZINLMHL.cjs +252 -0
  70. package/dist/chunk-HZINLMHL.cjs.map +1 -0
  71. package/dist/{chunk-RQK4FQUD.js → chunk-IGXRQWNN.js} +6 -48
  72. package/dist/chunk-IGXRQWNN.js.map +1 -0
  73. package/dist/chunk-IROUDQSO.js +246 -0
  74. package/dist/chunk-IROUDQSO.js.map +1 -0
  75. package/dist/chunk-IS3HHGL4.js +250 -0
  76. package/dist/chunk-IS3HHGL4.js.map +1 -0
  77. package/dist/chunk-JJLEVKG7.js +576 -0
  78. package/dist/chunk-JJLEVKG7.js.map +1 -0
  79. package/dist/chunk-K34R4R2T.cjs +233 -0
  80. package/dist/chunk-K34R4R2T.cjs.map +1 -0
  81. package/dist/chunk-K4HSW5ZF.js +77 -0
  82. package/dist/chunk-K4HSW5ZF.js.map +1 -0
  83. package/dist/chunk-L2U75ERO.cjs +344 -0
  84. package/dist/chunk-L2U75ERO.cjs.map +1 -0
  85. package/dist/chunk-L2VZFGWH.cjs +31787 -0
  86. package/dist/chunk-L2VZFGWH.cjs.map +1 -0
  87. package/dist/chunk-L7LB66KK.cjs +450 -0
  88. package/dist/chunk-L7LB66KK.cjs.map +1 -0
  89. package/dist/chunk-LJ6YRVDI.cjs +15 -0
  90. package/dist/chunk-LJ6YRVDI.cjs.map +1 -0
  91. package/dist/chunk-MCYD5LW7.cjs +90 -0
  92. package/dist/chunk-MCYD5LW7.cjs.map +1 -0
  93. package/dist/chunk-MF4PZE2D.js +119 -0
  94. package/dist/chunk-MF4PZE2D.js.map +1 -0
  95. package/dist/chunk-MP6TNZXA.cjs +212 -0
  96. package/dist/chunk-MP6TNZXA.cjs.map +1 -0
  97. package/dist/chunk-MPM2W4IS.js +312 -0
  98. package/dist/chunk-MPM2W4IS.js.map +1 -0
  99. package/dist/chunk-NE4CLM6P.cjs +190 -0
  100. package/dist/chunk-NE4CLM6P.cjs.map +1 -0
  101. package/dist/chunk-NL6ELCFS.cjs +603 -0
  102. package/dist/chunk-NL6ELCFS.cjs.map +1 -0
  103. package/dist/chunk-OD6Y7FEM.cjs +280 -0
  104. package/dist/chunk-OD6Y7FEM.cjs.map +1 -0
  105. package/dist/chunk-OS7SAIRA.js +250 -0
  106. package/dist/chunk-OS7SAIRA.js.map +1 -0
  107. package/dist/chunk-PWXUI3OG.cjs +252 -0
  108. package/dist/chunk-PWXUI3OG.cjs.map +1 -0
  109. package/dist/chunk-QAXO2LQT.js +1098 -0
  110. package/dist/chunk-QAXO2LQT.js.map +1 -0
  111. package/dist/chunk-RIX6WEJ2.js +83 -0
  112. package/dist/chunk-RIX6WEJ2.js.map +1 -0
  113. package/dist/chunk-RRVA4RVW.js +203 -0
  114. package/dist/chunk-RRVA4RVW.js.map +1 -0
  115. package/dist/{chunk-LPM6BBAX.cjs → chunk-SLDAFSKJ.cjs} +5 -56
  116. package/dist/chunk-SLDAFSKJ.cjs.map +1 -0
  117. package/dist/{chunk-2PLXW4ZX.cjs → chunk-T6YYVQHJ.cjs} +74 -74
  118. package/dist/chunk-T6YYVQHJ.cjs.map +1 -0
  119. package/dist/chunk-TF4LSD27.cjs +180 -0
  120. package/dist/chunk-TF4LSD27.cjs.map +1 -0
  121. package/dist/chunk-TM6IOINJ.cjs +252 -0
  122. package/dist/chunk-TM6IOINJ.cjs.map +1 -0
  123. package/dist/chunk-UVE6SV6I.js +209 -0
  124. package/dist/chunk-UVE6SV6I.js.map +1 -0
  125. package/dist/chunk-UWYAL2Z3.cjs +29 -0
  126. package/dist/chunk-UWYAL2Z3.cjs.map +1 -0
  127. package/dist/{chunk-CJFKRVED.cjs → chunk-VES6QKOW.cjs} +66 -16
  128. package/dist/chunk-VES6QKOW.cjs.map +1 -0
  129. package/dist/chunk-W7HAZD2A.js +1098 -0
  130. package/dist/chunk-W7HAZD2A.js.map +1 -0
  131. package/dist/{chunk-K5T5A3AL.cjs → chunk-WNQUNLRT.cjs} +238 -38
  132. package/dist/chunk-WNQUNLRT.cjs.map +1 -0
  133. package/dist/chunk-XKLJYRAA.js +77 -0
  134. package/dist/chunk-XKLJYRAA.js.map +1 -0
  135. package/dist/chunk-XWGAT2DA.js +44 -0
  136. package/dist/chunk-XWGAT2DA.js.map +1 -0
  137. package/dist/{dist-G2BYZJOC.cjs → dist-2GQKYJ34.cjs} +28 -28
  138. package/dist/dist-2GQKYJ34.cjs.map +1 -0
  139. package/dist/{dist-X7XR3M3Z.js → dist-C6BUHOEE.js} +3 -3
  140. package/dist/dist-C6BUHOEE.js.map +1 -0
  141. package/dist/dist-DGOEFPQD.cjs +16 -0
  142. package/dist/{dist-P4MXBQ3U.cjs.map → dist-DGOEFPQD.cjs.map} +1 -1
  143. package/dist/dist-FT2OR7OS.js +3 -0
  144. package/dist/{dist-YREX2TJT.js.map → dist-FT2OR7OS.js.map} +1 -1
  145. package/dist/{dist-XVBSOGFK.js → dist-G4CR4WYY.js} +3 -3
  146. package/dist/dist-G4CR4WYY.js.map +1 -0
  147. package/dist/{dist-PQZUVLPC.js → dist-G5QFRYLQ.js} +3 -3
  148. package/dist/dist-G5QFRYLQ.js.map +1 -0
  149. package/dist/{dist-4MVGNSRL.cjs → dist-JPQK5S4K.cjs} +20 -20
  150. package/dist/dist-JPQK5S4K.cjs.map +1 -0
  151. package/dist/{dist-R7WYX6LC.js → dist-MIDN25GT.js} +3 -3
  152. package/dist/dist-MIDN25GT.js.map +1 -0
  153. package/dist/{dist-RFMYFILX.cjs → dist-SNKH6NS2.cjs} +30 -30
  154. package/dist/dist-SNKH6NS2.cjs.map +1 -0
  155. package/dist/{dist-FZYCV3VB.cjs → dist-XBQPKAO4.cjs} +26 -26
  156. package/dist/dist-XBQPKAO4.cjs.map +1 -0
  157. package/dist/docs/README.md +31 -0
  158. package/dist/docs/SKILL.md +32 -0
  159. package/dist/docs/SOURCE_MAP.json +6 -0
  160. package/dist/docs/server/01-custom-adapters.md +380 -0
  161. package/dist/docs/server/02-reference.md +819 -0
  162. package/dist/server/auth/defaults.d.ts +3 -0
  163. package/dist/server/auth/defaults.d.ts.map +1 -0
  164. package/dist/server/auth/helpers.d.ts +14 -0
  165. package/dist/server/auth/helpers.d.ts.map +1 -0
  166. package/dist/server/auth/index.cjs +44 -0
  167. package/dist/server/auth/index.cjs.map +1 -0
  168. package/dist/server/auth/index.d.ts +3 -0
  169. package/dist/server/auth/index.d.ts.map +1 -0
  170. package/dist/server/auth/index.js +3 -0
  171. package/dist/server/auth/index.js.map +1 -0
  172. package/dist/server/auth/path-pattern.d.ts +43 -0
  173. package/dist/server/auth/path-pattern.d.ts.map +1 -0
  174. package/dist/server/handlers/a2a.cjs +15 -7
  175. package/dist/server/handlers/a2a.d.ts +106 -10
  176. package/dist/server/handlers/a2a.d.ts.map +1 -1
  177. package/dist/server/handlers/a2a.js +1 -1
  178. package/dist/server/handlers/agent-builder.cjs +31 -31
  179. package/dist/server/handlers/agent-builder.d.ts +289 -87
  180. package/dist/server/handlers/agent-builder.d.ts.map +1 -1
  181. package/dist/server/handlers/agent-builder.js +1 -1
  182. package/dist/server/handlers/agent-versions.cjs +60 -0
  183. package/dist/server/handlers/agent-versions.cjs.map +1 -0
  184. package/dist/server/handlers/agent-versions.d.ts +425 -0
  185. package/dist/server/handlers/agent-versions.d.ts.map +1 -0
  186. package/dist/server/handlers/agent-versions.js +3 -0
  187. package/dist/server/handlers/agent-versions.js.map +1 -0
  188. package/dist/server/handlers/agents.cjs +71 -39
  189. package/dist/server/handlers/agents.d.ts +730 -151
  190. package/dist/server/handlers/agents.d.ts.map +1 -1
  191. package/dist/server/handlers/agents.js +1 -1
  192. package/dist/server/handlers/error.cjs +6 -2
  193. package/dist/server/handlers/error.d.ts +22 -0
  194. package/dist/server/handlers/error.d.ts.map +1 -1
  195. package/dist/server/handlers/error.js +1 -1
  196. package/dist/server/handlers/logs.cjs +7 -7
  197. package/dist/server/handlers/logs.d.ts +87 -27
  198. package/dist/server/handlers/logs.d.ts.map +1 -1
  199. package/dist/server/handlers/logs.js +1 -1
  200. package/dist/server/handlers/mcp.cjs +40 -0
  201. package/dist/server/handlers/mcp.cjs.map +1 -0
  202. package/dist/server/handlers/mcp.d.ts +92 -0
  203. package/dist/server/handlers/mcp.d.ts.map +1 -0
  204. package/dist/server/handlers/mcp.js +3 -0
  205. package/dist/server/handlers/mcp.js.map +1 -0
  206. package/dist/server/handlers/memory.cjs +67 -31
  207. package/dist/server/handlers/memory.d.ts +424 -105
  208. package/dist/server/handlers/memory.d.ts.map +1 -1
  209. package/dist/server/handlers/memory.js +1 -1
  210. package/dist/server/handlers/observability.cjs +9 -9
  211. package/dist/server/handlers/observability.d.ts +133 -43
  212. package/dist/server/handlers/observability.d.ts.map +1 -1
  213. package/dist/server/handlers/observability.js +1 -1
  214. package/dist/server/handlers/processors.cjs +20 -0
  215. package/dist/server/handlers/processors.cjs.map +1 -0
  216. package/dist/server/handlers/processors.d.ts +90 -0
  217. package/dist/server/handlers/processors.d.ts.map +1 -0
  218. package/dist/server/handlers/processors.js +3 -0
  219. package/dist/server/handlers/processors.js.map +1 -0
  220. package/dist/server/handlers/scores.cjs +13 -13
  221. package/dist/server/handlers/scores.d.ts +78 -145
  222. package/dist/server/handlers/scores.d.ts.map +1 -1
  223. package/dist/server/handlers/scores.js +1 -1
  224. package/dist/server/handlers/stored-agents.cjs +28 -0
  225. package/dist/server/handlers/stored-agents.cjs.map +1 -0
  226. package/dist/server/handlers/stored-agents.d.ts +214 -0
  227. package/dist/server/handlers/stored-agents.d.ts.map +1 -0
  228. package/dist/server/handlers/stored-agents.js +3 -0
  229. package/dist/server/handlers/stored-agents.js.map +1 -0
  230. package/dist/server/handlers/system.cjs +12 -0
  231. package/dist/server/handlers/system.cjs.map +1 -0
  232. package/dist/server/handlers/system.d.ts +7 -0
  233. package/dist/server/handlers/system.d.ts.map +1 -0
  234. package/dist/server/handlers/system.js +3 -0
  235. package/dist/server/handlers/system.js.map +1 -0
  236. package/dist/server/handlers/test-utils.cjs +15 -0
  237. package/dist/server/handlers/test-utils.cjs.map +1 -0
  238. package/dist/server/handlers/test-utils.d.ts +6 -0
  239. package/dist/server/handlers/test-utils.d.ts.map +1 -0
  240. package/dist/server/handlers/test-utils.js +13 -0
  241. package/dist/server/handlers/test-utils.js.map +1 -0
  242. package/dist/server/handlers/tools.cjs +11 -11
  243. package/dist/server/handlers/tools.d.ts +41 -24
  244. package/dist/server/handlers/tools.d.ts.map +1 -1
  245. package/dist/server/handlers/tools.js +1 -1
  246. package/dist/server/handlers/utils.cjs +11 -3
  247. package/dist/server/handlers/utils.d.ts +5 -0
  248. package/dist/server/handlers/utils.d.ts.map +1 -1
  249. package/dist/server/handlers/utils.js +1 -1
  250. package/dist/server/handlers/vector.cjs +31 -7
  251. package/dist/server/handlers/vector.d.ts +52 -9
  252. package/dist/server/handlers/vector.d.ts.map +1 -1
  253. package/dist/server/handlers/vector.js +1 -1
  254. package/dist/server/handlers/voice.cjs +21 -9
  255. package/dist/server/handlers/voice.d.ts +42 -39
  256. package/dist/server/handlers/voice.d.ts.map +1 -1
  257. package/dist/server/handlers/voice.js +1 -1
  258. package/dist/server/handlers/workflows.cjs +53 -41
  259. package/dist/server/handlers/workflows.d.ts +425 -86
  260. package/dist/server/handlers/workflows.d.ts.map +1 -1
  261. package/dist/server/handlers/workflows.js +1 -1
  262. package/dist/server/handlers.cjs +34 -34
  263. package/dist/server/handlers.d.ts +1 -1
  264. package/dist/server/handlers.d.ts.map +1 -1
  265. package/dist/server/handlers.js +12 -12
  266. package/dist/server/http-exception.d.ts +0 -5
  267. package/dist/server/http-exception.d.ts.map +1 -1
  268. package/dist/server/schemas/a2a.d.ts +142 -0
  269. package/dist/server/schemas/a2a.d.ts.map +1 -0
  270. package/dist/server/schemas/agent-builder.d.ts +78 -0
  271. package/dist/server/schemas/agent-builder.d.ts.map +1 -0
  272. package/dist/server/schemas/agent-versions.d.ts +379 -0
  273. package/dist/server/schemas/agent-versions.d.ts.map +1 -0
  274. package/dist/server/schemas/agents.d.ts +496 -0
  275. package/dist/server/schemas/agents.d.ts.map +1 -0
  276. package/dist/server/schemas/common.d.ts +99 -0
  277. package/dist/server/schemas/common.d.ts.map +1 -0
  278. package/dist/server/schemas/logs.d.ts +56 -0
  279. package/dist/server/schemas/logs.d.ts.map +1 -0
  280. package/dist/server/schemas/mcp.d.ts +91 -0
  281. package/dist/server/schemas/mcp.d.ts.map +1 -0
  282. package/dist/server/schemas/memory.d.ts +455 -0
  283. package/dist/server/schemas/memory.d.ts.map +1 -0
  284. package/dist/server/schemas/processors.d.ts +162 -0
  285. package/dist/server/schemas/processors.d.ts.map +1 -0
  286. package/dist/server/schemas/scores.d.ts +77 -0
  287. package/dist/server/schemas/scores.d.ts.map +1 -0
  288. package/dist/server/schemas/stored-agents.d.ts +274 -0
  289. package/dist/server/schemas/stored-agents.d.ts.map +1 -0
  290. package/dist/server/schemas/system.d.ts +14 -0
  291. package/dist/server/schemas/system.d.ts.map +1 -0
  292. package/dist/server/schemas/vectors.d.ts +47 -0
  293. package/dist/server/schemas/vectors.d.ts.map +1 -0
  294. package/dist/server/schemas/workflows.d.ts +371 -0
  295. package/dist/server/schemas/workflows.d.ts.map +1 -0
  296. package/dist/server/server-adapter/index.cjs +627 -0
  297. package/dist/server/server-adapter/index.cjs.map +1 -0
  298. package/dist/server/server-adapter/index.d.ts +130 -0
  299. package/dist/server/server-adapter/index.d.ts.map +1 -0
  300. package/dist/server/server-adapter/index.js +599 -0
  301. package/dist/server/server-adapter/index.js.map +1 -0
  302. package/dist/server/server-adapter/openapi-utils.d.ts +59 -0
  303. package/dist/server/server-adapter/openapi-utils.d.ts.map +1 -0
  304. package/dist/server/server-adapter/redact.d.ts +26 -0
  305. package/dist/server/server-adapter/redact.d.ts.map +1 -0
  306. package/dist/server/server-adapter/routes/a2a.d.ts +3 -0
  307. package/dist/server/server-adapter/routes/a2a.d.ts.map +1 -0
  308. package/dist/server/server-adapter/routes/agent-builder.d.ts +3 -0
  309. package/dist/server/server-adapter/routes/agent-builder.d.ts.map +1 -0
  310. package/dist/server/server-adapter/routes/agents.d.ts +3 -0
  311. package/dist/server/server-adapter/routes/agents.d.ts.map +1 -0
  312. package/dist/server/server-adapter/routes/index.d.ts +52 -0
  313. package/dist/server/server-adapter/routes/index.d.ts.map +1 -0
  314. package/dist/server/server-adapter/routes/legacy.d.ts +7 -0
  315. package/dist/server/server-adapter/routes/legacy.d.ts.map +1 -0
  316. package/dist/server/server-adapter/routes/logs.d.ts +3 -0
  317. package/dist/server/server-adapter/routes/logs.d.ts.map +1 -0
  318. package/dist/server/server-adapter/routes/mcp.d.ts +9 -0
  319. package/dist/server/server-adapter/routes/mcp.d.ts.map +1 -0
  320. package/dist/server/server-adapter/routes/memory.d.ts +3 -0
  321. package/dist/server/server-adapter/routes/memory.d.ts.map +1 -0
  322. package/dist/server/server-adapter/routes/observability.d.ts +3 -0
  323. package/dist/server/server-adapter/routes/observability.d.ts.map +1 -0
  324. package/dist/server/server-adapter/routes/processors.d.ts +3 -0
  325. package/dist/server/server-adapter/routes/processors.d.ts.map +1 -0
  326. package/dist/server/server-adapter/routes/route-builder.d.ts +112 -0
  327. package/dist/server/server-adapter/routes/route-builder.d.ts.map +1 -0
  328. package/dist/server/server-adapter/routes/scorers.d.ts +3 -0
  329. package/dist/server/server-adapter/routes/scorers.d.ts.map +1 -0
  330. package/dist/server/server-adapter/routes/stored-agents.d.ts +8 -0
  331. package/dist/server/server-adapter/routes/stored-agents.d.ts.map +1 -0
  332. package/dist/server/server-adapter/routes/stream-types.d.ts +10 -0
  333. package/dist/server/server-adapter/routes/stream-types.d.ts.map +1 -0
  334. package/dist/server/server-adapter/routes/system.d.ts +12 -0
  335. package/dist/server/server-adapter/routes/system.d.ts.map +1 -0
  336. package/dist/server/server-adapter/routes/tools.d.ts +3 -0
  337. package/dist/server/server-adapter/routes/tools.d.ts.map +1 -0
  338. package/dist/server/server-adapter/routes/vectors.d.ts +3 -0
  339. package/dist/server/server-adapter/routes/vectors.d.ts.map +1 -0
  340. package/dist/server/server-adapter/routes/workflows.d.ts +3 -0
  341. package/dist/server/server-adapter/routes/workflows.d.ts.map +1 -0
  342. package/dist/server/utils.d.ts +4 -3
  343. package/dist/server/utils.d.ts.map +1 -1
  344. package/dist/{token-375W3LEI.cjs → token-6GSAFR2W-ABXTQD64-MC4IMVOB.cjs} +11 -12
  345. package/dist/token-6GSAFR2W-ABXTQD64-MC4IMVOB.cjs.map +1 -0
  346. package/dist/{token-C3IMNCC4.js → token-6GSAFR2W-ABXTQD64-Z6U2TA2C.js} +8 -9
  347. package/dist/token-6GSAFR2W-ABXTQD64-Z6U2TA2C.js.map +1 -0
  348. package/dist/token-6GSAFR2W-F2L44NEJ-B3QIV63M.cjs +63 -0
  349. package/dist/token-6GSAFR2W-F2L44NEJ-B3QIV63M.cjs.map +1 -0
  350. package/dist/token-6GSAFR2W-F2L44NEJ-GFZ37A2V.js +61 -0
  351. package/dist/token-6GSAFR2W-F2L44NEJ-GFZ37A2V.js.map +1 -0
  352. package/dist/token-6GSAFR2W-WGTMOPEU-6HSZQUFZ.cjs +63 -0
  353. package/dist/token-6GSAFR2W-WGTMOPEU-6HSZQUFZ.cjs.map +1 -0
  354. package/dist/token-6GSAFR2W-WGTMOPEU-JKP67ZX4.js +61 -0
  355. package/dist/token-6GSAFR2W-WGTMOPEU-JKP67ZX4.js.map +1 -0
  356. package/dist/token-util-NEHG7TUY-4YJ4EPCL-MBTAVIJ3.js +8 -0
  357. package/dist/token-util-NEHG7TUY-4YJ4EPCL-MBTAVIJ3.js.map +1 -0
  358. package/dist/token-util-NEHG7TUY-4YJ4EPCL-SQ4NADRW.cjs +10 -0
  359. package/dist/token-util-NEHG7TUY-4YJ4EPCL-SQ4NADRW.cjs.map +1 -0
  360. package/dist/token-util-NEHG7TUY-TV2H7N56-GGCGMPDG.js +8 -0
  361. package/dist/token-util-NEHG7TUY-TV2H7N56-GGCGMPDG.js.map +1 -0
  362. package/dist/token-util-NEHG7TUY-TV2H7N56-R7OENTCJ.cjs +10 -0
  363. package/dist/token-util-NEHG7TUY-TV2H7N56-R7OENTCJ.cjs.map +1 -0
  364. package/dist/token-util-NEHG7TUY-XQP3QSPX-BL5O5N7R.cjs +10 -0
  365. package/dist/token-util-NEHG7TUY-XQP3QSPX-BL5O5N7R.cjs.map +1 -0
  366. package/dist/token-util-NEHG7TUY-XQP3QSPX-YCJRRNXO.js +8 -0
  367. package/dist/token-util-NEHG7TUY-XQP3QSPX-YCJRRNXO.js.map +1 -0
  368. package/handlers/server/handlers.d.ts +1 -0
  369. package/handlers.d.ts +1 -0
  370. package/package.json +46 -16
  371. package/server-adapter.d.ts +1 -0
  372. package/dist/chunk-2P4VRXBT.js +0 -533
  373. package/dist/chunk-2P4VRXBT.js.map +0 -1
  374. package/dist/chunk-2PLXW4ZX.cjs.map +0 -1
  375. package/dist/chunk-2S4IMB6E.cjs +0 -130
  376. package/dist/chunk-2S4IMB6E.cjs.map +0 -1
  377. package/dist/chunk-3SNGNFUJ.cjs +0 -128
  378. package/dist/chunk-3SNGNFUJ.cjs.map +0 -1
  379. package/dist/chunk-4QCXUEAT.js +0 -25
  380. package/dist/chunk-4QCXUEAT.js.map +0 -1
  381. package/dist/chunk-6VPAV4ZV.js +0 -692
  382. package/dist/chunk-6VPAV4ZV.js.map +0 -1
  383. package/dist/chunk-7HCPO76Z.js +0 -19548
  384. package/dist/chunk-7HCPO76Z.js.map +0 -1
  385. package/dist/chunk-ABRFV4XP.js +0 -83
  386. package/dist/chunk-ABRFV4XP.js.map +0 -1
  387. package/dist/chunk-AHB4JCIQ.js +0 -160
  388. package/dist/chunk-AHB4JCIQ.js.map +0 -1
  389. package/dist/chunk-AW5BU3RQ.js +0 -192
  390. package/dist/chunk-AW5BU3RQ.js.map +0 -1
  391. package/dist/chunk-B7QWVGQQ.cjs +0 -729
  392. package/dist/chunk-B7QWVGQQ.cjs.map +0 -1
  393. package/dist/chunk-BATEJLED.js +0 -124
  394. package/dist/chunk-BATEJLED.js.map +0 -1
  395. package/dist/chunk-CJFKRVED.cjs.map +0 -1
  396. package/dist/chunk-CY4TP3FK.js +0 -16
  397. package/dist/chunk-CY4TP3FK.js.map +0 -1
  398. package/dist/chunk-EP3JQDPD.cjs +0 -131
  399. package/dist/chunk-EP3JQDPD.cjs.map +0 -1
  400. package/dist/chunk-G4PUALCE.cjs +0 -28
  401. package/dist/chunk-G4PUALCE.cjs.map +0 -1
  402. package/dist/chunk-GDUKGVFI.cjs +0 -550
  403. package/dist/chunk-GDUKGVFI.cjs.map +0 -1
  404. package/dist/chunk-I3C4ODGV.cjs +0 -335
  405. package/dist/chunk-I3C4ODGV.cjs.map +0 -1
  406. package/dist/chunk-K5T5A3AL.cjs.map +0 -1
  407. package/dist/chunk-KDUHLUK4.cjs +0 -19584
  408. package/dist/chunk-KDUHLUK4.cjs.map +0 -1
  409. package/dist/chunk-KSFLUEWV.js +0 -130
  410. package/dist/chunk-KSFLUEWV.js.map +0 -1
  411. package/dist/chunk-LLUOPR3J.js +0 -323
  412. package/dist/chunk-LLUOPR3J.js.map +0 -1
  413. package/dist/chunk-LPM6BBAX.cjs.map +0 -1
  414. package/dist/chunk-MMROOK5J.js.map +0 -1
  415. package/dist/chunk-MN2TZQ7I.js.map +0 -1
  416. package/dist/chunk-MYR4PVGN.js +0 -123
  417. package/dist/chunk-MYR4PVGN.js.map +0 -1
  418. package/dist/chunk-QQXMIP6C.js +0 -122
  419. package/dist/chunk-QQXMIP6C.js.map +0 -1
  420. package/dist/chunk-QU6N55W6.cjs.map +0 -1
  421. package/dist/chunk-RE4RPXT2.cjs +0 -18
  422. package/dist/chunk-RE4RPXT2.cjs.map +0 -1
  423. package/dist/chunk-RQK4FQUD.js.map +0 -1
  424. package/dist/chunk-SHWNNZBL.js.map +0 -1
  425. package/dist/chunk-SPRRK3P7.cjs +0 -200
  426. package/dist/chunk-SPRRK3P7.cjs.map +0 -1
  427. package/dist/chunk-TOCYBDP2.js +0 -46
  428. package/dist/chunk-TOCYBDP2.js.map +0 -1
  429. package/dist/chunk-TRGAMKHX.cjs +0 -167
  430. package/dist/chunk-TRGAMKHX.cjs.map +0 -1
  431. package/dist/chunk-X6C7BUWN.cjs +0 -48
  432. package/dist/chunk-X6C7BUWN.cjs.map +0 -1
  433. package/dist/chunk-XN74I6VW.cjs +0 -88
  434. package/dist/chunk-XN74I6VW.cjs.map +0 -1
  435. package/dist/chunk-YSHNCC6F.cjs +0 -713
  436. package/dist/chunk-YSHNCC6F.cjs.map +0 -1
  437. package/dist/chunk-ZLBL4NQC.js +0 -707
  438. package/dist/chunk-ZLBL4NQC.js.map +0 -1
  439. package/dist/chunk-ZULZ2752.js.map +0 -1
  440. package/dist/dist-4MVGNSRL.cjs.map +0 -1
  441. package/dist/dist-FZYCV3VB.cjs.map +0 -1
  442. package/dist/dist-G2BYZJOC.cjs.map +0 -1
  443. package/dist/dist-P4MXBQ3U.cjs +0 -16
  444. package/dist/dist-PQZUVLPC.js.map +0 -1
  445. package/dist/dist-R7WYX6LC.js.map +0 -1
  446. package/dist/dist-RFMYFILX.cjs.map +0 -1
  447. package/dist/dist-X7XR3M3Z.js.map +0 -1
  448. package/dist/dist-XVBSOGFK.js.map +0 -1
  449. package/dist/dist-YREX2TJT.js +0 -3
  450. package/dist/server/handlers/legacyWorkflows.cjs +0 -48
  451. package/dist/server/handlers/legacyWorkflows.cjs.map +0 -1
  452. package/dist/server/handlers/legacyWorkflows.d.ts +0 -59
  453. package/dist/server/handlers/legacyWorkflows.d.ts.map +0 -1
  454. package/dist/server/handlers/legacyWorkflows.js +0 -3
  455. package/dist/server/handlers/legacyWorkflows.js.map +0 -1
  456. package/dist/token-375W3LEI.cjs.map +0 -1
  457. package/dist/token-C3IMNCC4.js.map +0 -1
  458. package/dist/token-util-CV3RRG6K.cjs +0 -9
  459. package/dist/token-util-CV3RRG6K.cjs.map +0 -1
  460. package/dist/token-util-E5QO2RCL.js +0 -7
  461. package/dist/token-util-E5QO2RCL.js.map +0 -1
@@ -0,0 +1,1089 @@
1
+ import { sanitizeBody, validateBody } from './chunk-XWGAT2DA.js';
2
+ import { listAgentsResponseSchema, serializedAgentSchema, agentIdPathParams, generateResponseSchema, agentExecutionBodySchema, agentExecutionLegacyBodySchema, streamResponseSchema, providersResponseSchema, toolCallResponseSchema, approveToolCallBodySchema, declineToolCallBodySchema, approveNetworkToolCallBodySchema, declineNetworkToolCallBodySchema, modelManagementResponseSchema, updateAgentModelBodySchema, reorderAgentModelListBodySchema, updateAgentModelInModelListBodySchema, modelConfigIdPathParams, enhanceInstructionsResponseSchema, enhanceInstructionsBodySchema } from './chunk-DOU5IGJB.js';
3
+ import { stringify } from './chunk-LF2ZLOFP.js';
4
+ import { handleError } from './chunk-7AINN3FK.js';
5
+ import { HTTPException } from './chunk-6QWQZI4Q.js';
6
+ import { createRoute } from './chunk-D23WBCJ6.js';
7
+ import { __export } from './chunk-PR4QN5HX.js';
8
+ import { Agent } from '@mastra/core/agent';
9
+ import { MastraError, ErrorDomain, ErrorCategory } from '@mastra/core/error';
10
+ import { PROVIDER_REGISTRY } from '@mastra/core/llm';
11
+ import { zodToJsonSchema } from '@mastra/core/utils/zod-to-json';
12
+ import { z } from 'zod';
13
+
14
+ // src/server/handlers/agents.ts
15
+ var agents_exports = {};
16
+ __export(agents_exports, {
17
+ APPROVE_NETWORK_TOOL_CALL_ROUTE: () => APPROVE_NETWORK_TOOL_CALL_ROUTE,
18
+ APPROVE_TOOL_CALL_GENERATE_ROUTE: () => APPROVE_TOOL_CALL_GENERATE_ROUTE,
19
+ APPROVE_TOOL_CALL_ROUTE: () => APPROVE_TOOL_CALL_ROUTE,
20
+ DECLINE_NETWORK_TOOL_CALL_ROUTE: () => DECLINE_NETWORK_TOOL_CALL_ROUTE,
21
+ DECLINE_TOOL_CALL_GENERATE_ROUTE: () => DECLINE_TOOL_CALL_GENERATE_ROUTE,
22
+ DECLINE_TOOL_CALL_ROUTE: () => DECLINE_TOOL_CALL_ROUTE,
23
+ ENHANCE_INSTRUCTIONS_ROUTE: () => ENHANCE_INSTRUCTIONS_ROUTE,
24
+ GENERATE_AGENT_ROUTE: () => GENERATE_AGENT_ROUTE,
25
+ GENERATE_AGENT_VNEXT_ROUTE: () => GENERATE_AGENT_VNEXT_ROUTE,
26
+ GENERATE_LEGACY_ROUTE: () => GENERATE_LEGACY_ROUTE,
27
+ GET_AGENT_BY_ID_ROUTE: () => GET_AGENT_BY_ID_ROUTE,
28
+ GET_PROVIDERS_ROUTE: () => GET_PROVIDERS_ROUTE,
29
+ LIST_AGENTS_ROUTE: () => LIST_AGENTS_ROUTE,
30
+ REORDER_AGENT_MODEL_LIST_ROUTE: () => REORDER_AGENT_MODEL_LIST_ROUTE,
31
+ RESET_AGENT_MODEL_ROUTE: () => RESET_AGENT_MODEL_ROUTE,
32
+ STREAM_GENERATE_LEGACY_ROUTE: () => STREAM_GENERATE_LEGACY_ROUTE,
33
+ STREAM_GENERATE_ROUTE: () => STREAM_GENERATE_ROUTE,
34
+ STREAM_GENERATE_VNEXT_DEPRECATED_ROUTE: () => STREAM_GENERATE_VNEXT_DEPRECATED_ROUTE,
35
+ STREAM_NETWORK_ROUTE: () => STREAM_NETWORK_ROUTE,
36
+ STREAM_UI_MESSAGE_DEPRECATED_ROUTE: () => STREAM_UI_MESSAGE_DEPRECATED_ROUTE,
37
+ STREAM_UI_MESSAGE_VNEXT_DEPRECATED_ROUTE: () => STREAM_UI_MESSAGE_VNEXT_DEPRECATED_ROUTE,
38
+ STREAM_VNEXT_DEPRECATED_ROUTE: () => STREAM_VNEXT_DEPRECATED_ROUTE,
39
+ UPDATE_AGENT_MODEL_IN_MODEL_LIST_ROUTE: () => UPDATE_AGENT_MODEL_IN_MODEL_LIST_ROUTE,
40
+ UPDATE_AGENT_MODEL_ROUTE: () => UPDATE_AGENT_MODEL_ROUTE,
41
+ getAgentFromSystem: () => getAgentFromSystem,
42
+ getSerializedAgentTools: () => getSerializedAgentTools,
43
+ getSerializedProcessors: () => getSerializedProcessors
44
+ });
45
+ function isProviderConnected(providerId) {
46
+ const cleanId = providerId.includes(".") ? providerId.split(".")[0] : providerId;
47
+ const provider = PROVIDER_REGISTRY[cleanId];
48
+ if (!provider) return false;
49
+ const envVars = Array.isArray(provider.apiKeyEnvVar) ? provider.apiKeyEnvVar : [provider.apiKeyEnvVar];
50
+ return envVars.every((envVar) => !!process.env[envVar]);
51
+ }
52
+ async function getSerializedAgentTools(tools, partial = false) {
53
+ return Object.entries(tools || {}).reduce((acc, [key, tool]) => {
54
+ const toolId = tool.id ?? `tool-${key}`;
55
+ let inputSchemaForReturn = void 0;
56
+ let outputSchemaForReturn = void 0;
57
+ if (!partial) {
58
+ try {
59
+ if (tool.inputSchema) {
60
+ if (tool.inputSchema && typeof tool.inputSchema === "object" && "jsonSchema" in tool.inputSchema) {
61
+ inputSchemaForReturn = stringify(tool.inputSchema.jsonSchema);
62
+ } else if (typeof tool.inputSchema === "function") {
63
+ const inputSchema = tool.inputSchema();
64
+ if (inputSchema && inputSchema.jsonSchema) {
65
+ inputSchemaForReturn = stringify(inputSchema.jsonSchema);
66
+ }
67
+ } else if (tool.inputSchema) {
68
+ inputSchemaForReturn = stringify(
69
+ zodToJsonSchema(tool.inputSchema)
70
+ );
71
+ }
72
+ }
73
+ if (tool.outputSchema) {
74
+ if (tool.outputSchema && typeof tool.outputSchema === "object" && "jsonSchema" in tool.outputSchema) {
75
+ outputSchemaForReturn = stringify(tool.outputSchema.jsonSchema);
76
+ } else if (typeof tool.outputSchema === "function") {
77
+ const outputSchema = tool.outputSchema();
78
+ if (outputSchema && outputSchema.jsonSchema) {
79
+ outputSchemaForReturn = stringify(outputSchema.jsonSchema);
80
+ }
81
+ } else if (tool.outputSchema) {
82
+ outputSchemaForReturn = stringify(
83
+ zodToJsonSchema(tool.outputSchema)
84
+ );
85
+ }
86
+ }
87
+ } catch (error) {
88
+ console.error(`Error getting serialized tool`, {
89
+ toolId: tool.id,
90
+ error
91
+ });
92
+ }
93
+ }
94
+ acc[key] = {
95
+ ...tool,
96
+ id: toolId,
97
+ inputSchema: inputSchemaForReturn,
98
+ outputSchema: outputSchemaForReturn
99
+ };
100
+ return acc;
101
+ }, {});
102
+ }
103
+ function getSerializedProcessors(processors) {
104
+ return processors.map((processor) => {
105
+ return {
106
+ id: processor.id,
107
+ name: processor.name || processor.constructor.name
108
+ };
109
+ });
110
+ }
111
+ async function getSerializedAgentDefinition({
112
+ agent,
113
+ requestContext
114
+ }) {
115
+ let serializedAgentAgents = {};
116
+ if ("listAgents" in agent) {
117
+ const agents = await agent.listAgents({ requestContext });
118
+ serializedAgentAgents = Object.entries(agents || {}).reduce(
119
+ (acc, [key, agent2]) => {
120
+ return {
121
+ ...acc,
122
+ [key]: { id: agent2.id, name: agent2.name }
123
+ };
124
+ },
125
+ {}
126
+ );
127
+ }
128
+ return serializedAgentAgents;
129
+ }
130
+ async function formatAgentList({
131
+ id,
132
+ mastra,
133
+ agent,
134
+ requestContext,
135
+ partial = false
136
+ }) {
137
+ const description = agent.getDescription();
138
+ const instructions = await agent.getInstructions({ requestContext });
139
+ const tools = await agent.listTools({ requestContext });
140
+ const llm = await agent.getLLM({ requestContext });
141
+ const defaultGenerateOptionsLegacy = await agent.getDefaultGenerateOptionsLegacy({ requestContext });
142
+ const defaultStreamOptionsLegacy = await agent.getDefaultStreamOptionsLegacy({ requestContext });
143
+ const defaultOptions = await agent.getDefaultOptions({ requestContext });
144
+ const serializedAgentTools = await getSerializedAgentTools(tools, partial);
145
+ let serializedAgentWorkflows = {};
146
+ const logger = mastra.getLogger();
147
+ if ("listWorkflows" in agent) {
148
+ try {
149
+ const workflows = await agent.listWorkflows({ requestContext });
150
+ serializedAgentWorkflows = Object.entries(workflows || {}).reduce((acc, [key, workflow]) => {
151
+ return {
152
+ ...acc,
153
+ [key]: {
154
+ name: workflow.name || "Unnamed workflow"
155
+ }
156
+ };
157
+ }, {});
158
+ } catch (error) {
159
+ logger.error("Error getting workflows for agent", { agentName: agent.name, error });
160
+ }
161
+ }
162
+ const serializedAgentAgents = await getSerializedAgentDefinition({ agent, requestContext });
163
+ let serializedInputProcessors = [];
164
+ let serializedOutputProcessors = [];
165
+ try {
166
+ const configuredProcessorWorkflows = await agent.getConfiguredProcessorWorkflows();
167
+ const inputProcessorWorkflows = configuredProcessorWorkflows.filter((w) => w.id.endsWith("-input-processor"));
168
+ const outputProcessorWorkflows = configuredProcessorWorkflows.filter((w) => w.id.endsWith("-output-processor"));
169
+ serializedInputProcessors = getSerializedProcessors(inputProcessorWorkflows);
170
+ serializedOutputProcessors = getSerializedProcessors(outputProcessorWorkflows);
171
+ } catch (error) {
172
+ logger.error("Error getting configured processors for agent", { agentName: agent.name, error });
173
+ }
174
+ const model = llm?.getModel();
175
+ const models = await agent.getModelList(requestContext);
176
+ const modelList = models?.map((md) => ({
177
+ ...md,
178
+ model: {
179
+ modelId: md.model.modelId,
180
+ provider: md.model.provider,
181
+ modelVersion: md.model.specificationVersion
182
+ }
183
+ }));
184
+ return {
185
+ id: agent.id || id,
186
+ name: agent.name,
187
+ description,
188
+ instructions,
189
+ agents: serializedAgentAgents,
190
+ tools: serializedAgentTools,
191
+ workflows: serializedAgentWorkflows,
192
+ inputProcessors: serializedInputProcessors,
193
+ outputProcessors: serializedOutputProcessors,
194
+ provider: llm?.getProvider(),
195
+ modelId: llm?.getModelId(),
196
+ modelVersion: model?.specificationVersion,
197
+ defaultOptions,
198
+ modelList,
199
+ defaultGenerateOptionsLegacy,
200
+ defaultStreamOptionsLegacy,
201
+ source: agent.source ?? "code"
202
+ };
203
+ }
204
+ async function getAgentFromSystem({ mastra, agentId }) {
205
+ const logger = mastra.getLogger();
206
+ if (!agentId) {
207
+ throw new HTTPException(400, { message: "Agent ID is required" });
208
+ }
209
+ let agent;
210
+ try {
211
+ agent = mastra.getAgentById(agentId);
212
+ } catch (error) {
213
+ logger.debug("Error getting agent from mastra, searching agents for agent", error);
214
+ }
215
+ if (!agent) {
216
+ logger.debug(`Agent ${agentId} not found, looking through sub-agents`);
217
+ const agents = mastra.listAgents();
218
+ if (Object.keys(agents || {}).length) {
219
+ for (const [_, ag] of Object.entries(agents)) {
220
+ try {
221
+ const subAgents = await ag.listAgents();
222
+ if (subAgents[agentId]) {
223
+ agent = subAgents[agentId];
224
+ break;
225
+ }
226
+ } catch (error) {
227
+ logger.debug("Error getting agent from agent", error);
228
+ }
229
+ }
230
+ }
231
+ }
232
+ if (!agent) {
233
+ logger.debug(`Agent ${agentId} not found in code-defined agents, looking in stored agents`);
234
+ try {
235
+ agent = await mastra.getStoredAgentById(agentId);
236
+ } catch (error) {
237
+ logger.debug("Error getting stored agent", error);
238
+ }
239
+ }
240
+ if (!agent) {
241
+ throw new HTTPException(404, { message: `Agent with id ${agentId} not found` });
242
+ }
243
+ return agent;
244
+ }
245
+ async function formatAgent({
246
+ mastra,
247
+ agent,
248
+ requestContext,
249
+ isStudio
250
+ }) {
251
+ const description = agent.getDescription();
252
+ const tools = await agent.listTools({ requestContext });
253
+ const serializedAgentTools = await getSerializedAgentTools(tools);
254
+ let serializedAgentWorkflows = {};
255
+ if ("listWorkflows" in agent) {
256
+ const logger = mastra.getLogger();
257
+ try {
258
+ const workflows = await agent.listWorkflows({ requestContext });
259
+ serializedAgentWorkflows = Object.entries(workflows || {}).reduce((acc, [key, workflow]) => {
260
+ return {
261
+ ...acc,
262
+ [key]: {
263
+ name: workflow.name || "Unnamed workflow",
264
+ steps: Object.entries(workflow.steps).reduce(
265
+ (acc2, [key2, step]) => {
266
+ return {
267
+ ...acc2,
268
+ [key2]: {
269
+ id: step.id,
270
+ description: step.description
271
+ }
272
+ };
273
+ },
274
+ {}
275
+ )
276
+ }
277
+ };
278
+ }, {});
279
+ } catch (error) {
280
+ logger.error("Error getting workflows for agent", { agentName: agent.name, error });
281
+ }
282
+ }
283
+ let proxyRequestContext = requestContext;
284
+ const instructions = await agent.getInstructions({ requestContext: proxyRequestContext });
285
+ const llm = await agent.getLLM({ requestContext });
286
+ const defaultGenerateOptionsLegacy = await agent.getDefaultGenerateOptionsLegacy({
287
+ requestContext: proxyRequestContext
288
+ });
289
+ const defaultStreamOptionsLegacy = await agent.getDefaultStreamOptionsLegacy({ requestContext: proxyRequestContext });
290
+ const defaultOptions = await agent.getDefaultOptions({ requestContext: proxyRequestContext });
291
+ const model = llm?.getModel();
292
+ const models = await agent.getModelList(requestContext);
293
+ const modelList = models?.map((md) => ({
294
+ ...md,
295
+ model: {
296
+ modelId: md.model.modelId,
297
+ provider: md.model.provider,
298
+ modelVersion: md.model.specificationVersion
299
+ }
300
+ }));
301
+ const serializedAgentAgents = await getSerializedAgentDefinition({ agent, requestContext: proxyRequestContext });
302
+ let serializedInputProcessors = [];
303
+ let serializedOutputProcessors = [];
304
+ try {
305
+ const configuredProcessorWorkflows = await agent.getConfiguredProcessorWorkflows();
306
+ const inputProcessorWorkflows = configuredProcessorWorkflows.filter((w) => w.id.endsWith("-input-processor"));
307
+ const outputProcessorWorkflows = configuredProcessorWorkflows.filter((w) => w.id.endsWith("-output-processor"));
308
+ serializedInputProcessors = getSerializedProcessors(inputProcessorWorkflows);
309
+ serializedOutputProcessors = getSerializedProcessors(outputProcessorWorkflows);
310
+ } catch (error) {
311
+ mastra.getLogger().error("Error getting configured processors for agent", { agentName: agent.name, error });
312
+ }
313
+ return {
314
+ name: agent.name,
315
+ description,
316
+ instructions,
317
+ tools: serializedAgentTools,
318
+ agents: serializedAgentAgents,
319
+ workflows: serializedAgentWorkflows,
320
+ inputProcessors: serializedInputProcessors,
321
+ outputProcessors: serializedOutputProcessors,
322
+ provider: llm?.getProvider(),
323
+ modelId: llm?.getModelId(),
324
+ modelVersion: model?.specificationVersion,
325
+ modelList,
326
+ defaultOptions,
327
+ defaultGenerateOptionsLegacy,
328
+ defaultStreamOptionsLegacy,
329
+ source: agent.source ?? "code"
330
+ };
331
+ }
332
+ var LIST_AGENTS_ROUTE = createRoute({
333
+ method: "GET",
334
+ path: "/agents",
335
+ responseType: "json",
336
+ queryParamSchema: z.object({
337
+ partial: z.string().optional()
338
+ }),
339
+ responseSchema: listAgentsResponseSchema,
340
+ summary: "List all agents",
341
+ description: "Returns a list of all available agents in the system (both code-defined and stored)",
342
+ tags: ["Agents"],
343
+ requiresAuth: true,
344
+ handler: async ({ mastra, requestContext, partial }) => {
345
+ try {
346
+ const codeAgents = mastra.listAgents();
347
+ const isPartial = partial === "true";
348
+ const serializedCodeAgentsMap = await Promise.all(
349
+ Object.entries(codeAgents).map(async ([id, agent]) => {
350
+ return formatAgentList({ id, mastra, agent, requestContext, partial: isPartial });
351
+ })
352
+ );
353
+ const serializedAgents = serializedCodeAgentsMap.reduce(
354
+ (acc, { id, ...rest }) => {
355
+ acc[id] = { id, ...rest };
356
+ return acc;
357
+ },
358
+ {}
359
+ );
360
+ try {
361
+ const storedAgentsResult = await mastra.listStoredAgents();
362
+ if (storedAgentsResult?.agents) {
363
+ for (const agent of storedAgentsResult.agents) {
364
+ try {
365
+ const serialized = await formatAgentList({
366
+ id: agent.id,
367
+ mastra,
368
+ agent,
369
+ requestContext,
370
+ partial: isPartial
371
+ });
372
+ if (!serializedAgents[serialized.id]) {
373
+ serializedAgents[serialized.id] = serialized;
374
+ }
375
+ } catch (agentError) {
376
+ const logger = mastra.getLogger();
377
+ logger.warn("Failed to serialize stored agent", { agentId: agent.id, error: agentError });
378
+ }
379
+ }
380
+ }
381
+ } catch (storageError) {
382
+ const logger = mastra.getLogger();
383
+ logger.debug("Could not fetch stored agents", { error: storageError });
384
+ }
385
+ return serializedAgents;
386
+ } catch (error) {
387
+ return handleError(error, "Error getting agents");
388
+ }
389
+ }
390
+ });
391
+ var GET_AGENT_BY_ID_ROUTE = createRoute({
392
+ method: "GET",
393
+ path: "/agents/:agentId",
394
+ responseType: "json",
395
+ pathParamSchema: agentIdPathParams,
396
+ responseSchema: serializedAgentSchema,
397
+ summary: "Get agent by ID",
398
+ description: "Returns details for a specific agent including configuration, tools, and memory settings",
399
+ tags: ["Agents"],
400
+ requiresAuth: true,
401
+ handler: async ({ agentId, mastra, requestContext }) => {
402
+ try {
403
+ const agent = await getAgentFromSystem({ mastra, agentId });
404
+ const isStudio = false;
405
+ const result = await formatAgent({
406
+ mastra,
407
+ agent,
408
+ requestContext,
409
+ isStudio
410
+ });
411
+ return result;
412
+ } catch (error) {
413
+ return handleError(error, "Error getting agent");
414
+ }
415
+ }
416
+ });
417
+ var GENERATE_AGENT_ROUTE = createRoute({
418
+ method: "POST",
419
+ path: "/agents/:agentId/generate",
420
+ responseType: "json",
421
+ pathParamSchema: agentIdPathParams,
422
+ bodySchema: agentExecutionBodySchema,
423
+ responseSchema: generateResponseSchema,
424
+ summary: "Generate agent response",
425
+ description: "Executes an agent with the provided messages and returns the complete response",
426
+ tags: ["Agents"],
427
+ requiresAuth: true,
428
+ handler: async ({ agentId, mastra, abortSignal, ...params }) => {
429
+ try {
430
+ const agent = await getAgentFromSystem({ mastra, agentId });
431
+ sanitizeBody(params, ["tools"]);
432
+ const { messages, ...rest } = params;
433
+ validateBody({ messages });
434
+ const result = await agent.generate(messages, {
435
+ ...rest,
436
+ abortSignal
437
+ });
438
+ return result;
439
+ } catch (error) {
440
+ return handleError(error, "Error generating from agent");
441
+ }
442
+ }
443
+ });
444
+ var GENERATE_LEGACY_ROUTE = createRoute({
445
+ method: "POST",
446
+ path: "/agents/:agentId/generate-legacy",
447
+ responseType: "json",
448
+ pathParamSchema: agentIdPathParams,
449
+ bodySchema: agentExecutionLegacyBodySchema,
450
+ responseSchema: generateResponseSchema,
451
+ summary: "[DEPRECATED] Generate with legacy format",
452
+ description: "Legacy endpoint for generating agent responses. Use /agents/:agentId/generate instead.",
453
+ tags: ["Agents", "Legacy"],
454
+ requiresAuth: true,
455
+ handler: async ({ mastra, agentId, abortSignal, ...params }) => {
456
+ try {
457
+ const agent = await getAgentFromSystem({ mastra, agentId });
458
+ sanitizeBody(params, ["tools"]);
459
+ const { messages, resourceId, resourceid, threadId, ...rest } = params;
460
+ const finalResourceId = resourceId ?? resourceid;
461
+ validateBody({ messages });
462
+ if (threadId && !finalResourceId || !threadId && finalResourceId) {
463
+ throw new HTTPException(400, { message: "Both threadId or resourceId must be provided" });
464
+ }
465
+ const result = await agent.generateLegacy(messages, {
466
+ ...rest,
467
+ abortSignal,
468
+ resourceId: finalResourceId ?? "",
469
+ threadId: threadId ?? ""
470
+ });
471
+ return result;
472
+ } catch (error) {
473
+ return handleError(error, "Error generating from agent");
474
+ }
475
+ }
476
+ });
477
+ var STREAM_GENERATE_LEGACY_ROUTE = createRoute({
478
+ method: "POST",
479
+ path: "/agents/:agentId/stream-legacy",
480
+ responseType: "datastream-response",
481
+ pathParamSchema: agentIdPathParams,
482
+ bodySchema: agentExecutionLegacyBodySchema,
483
+ responseSchema: streamResponseSchema,
484
+ summary: "[DEPRECATED] Stream with legacy format",
485
+ description: "Legacy endpoint for streaming agent responses. Use /agents/:agentId/stream instead.",
486
+ tags: ["Agents", "Legacy"],
487
+ requiresAuth: true,
488
+ handler: async ({ mastra, agentId, abortSignal, ...params }) => {
489
+ try {
490
+ const agent = await getAgentFromSystem({ mastra, agentId });
491
+ sanitizeBody(params, ["tools"]);
492
+ const { messages, resourceId, resourceid, threadId, ...rest } = params;
493
+ const finalResourceId = resourceId ?? resourceid;
494
+ validateBody({ messages });
495
+ if (threadId && !finalResourceId || !threadId && finalResourceId) {
496
+ throw new HTTPException(400, { message: "Both threadId or resourceId must be provided" });
497
+ }
498
+ const streamResult = await agent.streamLegacy(messages, {
499
+ ...rest,
500
+ abortSignal,
501
+ resourceId: finalResourceId ?? "",
502
+ threadId: threadId ?? ""
503
+ });
504
+ const streamResponse = rest.output ? streamResult.toTextStreamResponse({
505
+ headers: {
506
+ "Transfer-Encoding": "chunked"
507
+ }
508
+ }) : streamResult.toDataStreamResponse({
509
+ sendUsage: true,
510
+ sendReasoning: true,
511
+ getErrorMessage: (error) => {
512
+ return `An error occurred while processing your request. ${error instanceof Error ? error.message : JSON.stringify(error)}`;
513
+ },
514
+ headers: {
515
+ "Transfer-Encoding": "chunked"
516
+ }
517
+ });
518
+ return streamResponse;
519
+ } catch (error) {
520
+ return handleError(error, "error streaming agent response");
521
+ }
522
+ }
523
+ });
524
+ var GET_PROVIDERS_ROUTE = createRoute({
525
+ method: "GET",
526
+ path: "/agents/providers",
527
+ responseType: "json",
528
+ responseSchema: providersResponseSchema,
529
+ summary: "List AI providers",
530
+ description: "Returns a list of all configured AI model providers",
531
+ tags: ["Agents"],
532
+ requiresAuth: true,
533
+ handler: async () => {
534
+ try {
535
+ const providers = Object.entries(PROVIDER_REGISTRY).map(([id, provider]) => {
536
+ return {
537
+ id,
538
+ name: provider.name,
539
+ label: provider.label || provider.name,
540
+ description: provider.description || "",
541
+ envVar: provider.apiKeyEnvVar,
542
+ connected: isProviderConnected(id),
543
+ docUrl: provider.docUrl,
544
+ models: [...provider.models]
545
+ // Convert readonly array to regular array
546
+ };
547
+ });
548
+ return { providers };
549
+ } catch (error) {
550
+ return handleError(error, "Error fetching providers");
551
+ }
552
+ }
553
+ });
554
+ var GENERATE_AGENT_VNEXT_ROUTE = createRoute({
555
+ method: "POST",
556
+ path: "/agents/:agentId/generate/vnext",
557
+ responseType: "json",
558
+ pathParamSchema: agentIdPathParams,
559
+ bodySchema: agentExecutionBodySchema,
560
+ responseSchema: generateResponseSchema,
561
+ summary: "Generate a response from an agent",
562
+ description: "Generate a response from an agent",
563
+ tags: ["Agents"],
564
+ requiresAuth: true,
565
+ handler: GENERATE_AGENT_ROUTE.handler
566
+ });
567
+ var STREAM_GENERATE_ROUTE = createRoute({
568
+ method: "POST",
569
+ path: "/agents/:agentId/stream",
570
+ responseType: "stream",
571
+ streamFormat: "sse",
572
+ pathParamSchema: agentIdPathParams,
573
+ bodySchema: agentExecutionBodySchema,
574
+ responseSchema: streamResponseSchema,
575
+ summary: "Stream agent response",
576
+ description: "Executes an agent with the provided messages and streams the response in real-time",
577
+ tags: ["Agents"],
578
+ requiresAuth: true,
579
+ handler: async ({ mastra, agentId, abortSignal, ...params }) => {
580
+ try {
581
+ const agent = await getAgentFromSystem({ mastra, agentId });
582
+ sanitizeBody(params, ["tools"]);
583
+ const { messages, ...rest } = params;
584
+ validateBody({ messages });
585
+ const streamResult = await agent.stream(messages, {
586
+ ...rest,
587
+ abortSignal
588
+ });
589
+ return streamResult.fullStream;
590
+ } catch (error) {
591
+ return handleError(error, "error streaming agent response");
592
+ }
593
+ }
594
+ });
595
+ var STREAM_GENERATE_VNEXT_DEPRECATED_ROUTE = createRoute({
596
+ method: "POST",
597
+ path: "/agents/:agentId/stream/vnext",
598
+ responseType: "stream",
599
+ pathParamSchema: agentIdPathParams,
600
+ bodySchema: agentExecutionBodySchema,
601
+ responseSchema: streamResponseSchema,
602
+ summary: "Stream a response from an agent",
603
+ description: "[DEPRECATED] This endpoint is deprecated. Please use /stream instead.",
604
+ tags: ["Agents"],
605
+ requiresAuth: true,
606
+ deprecated: true,
607
+ handler: STREAM_GENERATE_ROUTE.handler
608
+ });
609
+ var APPROVE_TOOL_CALL_ROUTE = createRoute({
610
+ method: "POST",
611
+ path: "/agents/:agentId/approve-tool-call",
612
+ responseType: "stream",
613
+ streamFormat: "sse",
614
+ pathParamSchema: agentIdPathParams,
615
+ bodySchema: approveToolCallBodySchema,
616
+ responseSchema: toolCallResponseSchema,
617
+ summary: "Approve tool call",
618
+ description: "Approves a pending tool call and continues agent execution",
619
+ tags: ["Agents", "Tools"],
620
+ requiresAuth: true,
621
+ handler: async ({ mastra, agentId, abortSignal, ...params }) => {
622
+ try {
623
+ const agent = await getAgentFromSystem({ mastra, agentId });
624
+ if (!params.runId) {
625
+ throw new HTTPException(400, { message: "Run id is required" });
626
+ }
627
+ if (!params.toolCallId) {
628
+ throw new HTTPException(400, { message: "Tool call id is required" });
629
+ }
630
+ sanitizeBody(params, ["tools"]);
631
+ const streamResult = await agent.approveToolCall({
632
+ ...params,
633
+ abortSignal
634
+ });
635
+ return streamResult.fullStream;
636
+ } catch (error) {
637
+ return handleError(error, "error approving tool call");
638
+ }
639
+ }
640
+ });
641
+ var DECLINE_TOOL_CALL_ROUTE = createRoute({
642
+ method: "POST",
643
+ path: "/agents/:agentId/decline-tool-call",
644
+ responseType: "stream",
645
+ streamFormat: "sse",
646
+ pathParamSchema: agentIdPathParams,
647
+ bodySchema: declineToolCallBodySchema,
648
+ responseSchema: toolCallResponseSchema,
649
+ summary: "Decline tool call",
650
+ description: "Declines a pending tool call and continues agent execution without executing the tool",
651
+ tags: ["Agents", "Tools"],
652
+ requiresAuth: true,
653
+ handler: async ({ mastra, agentId, abortSignal, ...params }) => {
654
+ try {
655
+ const agent = await getAgentFromSystem({ mastra, agentId });
656
+ if (!params.runId) {
657
+ throw new HTTPException(400, { message: "Run id is required" });
658
+ }
659
+ if (!params.toolCallId) {
660
+ throw new HTTPException(400, { message: "Tool call id is required" });
661
+ }
662
+ sanitizeBody(params, ["tools"]);
663
+ const streamResult = await agent.declineToolCall({
664
+ ...params,
665
+ abortSignal
666
+ });
667
+ return streamResult.fullStream;
668
+ } catch (error) {
669
+ return handleError(error, "error declining tool call");
670
+ }
671
+ }
672
+ });
673
+ var APPROVE_TOOL_CALL_GENERATE_ROUTE = createRoute({
674
+ method: "POST",
675
+ path: "/agents/:agentId/approve-tool-call-generate",
676
+ responseType: "json",
677
+ pathParamSchema: agentIdPathParams,
678
+ bodySchema: approveToolCallBodySchema,
679
+ responseSchema: generateResponseSchema,
680
+ summary: "Approve tool call (non-streaming)",
681
+ description: "Approves a pending tool call and returns the complete response",
682
+ tags: ["Agents", "Tools"],
683
+ requiresAuth: true,
684
+ handler: async ({ mastra, agentId, abortSignal, ...params }) => {
685
+ try {
686
+ const agent = await getAgentFromSystem({ mastra, agentId });
687
+ if (!params.runId) {
688
+ throw new HTTPException(400, { message: "Run id is required" });
689
+ }
690
+ if (!params.toolCallId) {
691
+ throw new HTTPException(400, { message: "Tool call id is required" });
692
+ }
693
+ sanitizeBody(params, ["tools"]);
694
+ const result = await agent.approveToolCallGenerate({
695
+ ...params,
696
+ abortSignal
697
+ });
698
+ return result;
699
+ } catch (error) {
700
+ return handleError(error, "error approving tool call");
701
+ }
702
+ }
703
+ });
704
+ var DECLINE_TOOL_CALL_GENERATE_ROUTE = createRoute({
705
+ method: "POST",
706
+ path: "/agents/:agentId/decline-tool-call-generate",
707
+ responseType: "json",
708
+ pathParamSchema: agentIdPathParams,
709
+ bodySchema: declineToolCallBodySchema,
710
+ responseSchema: generateResponseSchema,
711
+ summary: "Decline tool call (non-streaming)",
712
+ description: "Declines a pending tool call and returns the complete response",
713
+ tags: ["Agents", "Tools"],
714
+ requiresAuth: true,
715
+ handler: async ({ mastra, agentId, abortSignal, ...params }) => {
716
+ try {
717
+ const agent = await getAgentFromSystem({ mastra, agentId });
718
+ if (!params.runId) {
719
+ throw new HTTPException(400, { message: "Run id is required" });
720
+ }
721
+ if (!params.toolCallId) {
722
+ throw new HTTPException(400, { message: "Tool call id is required" });
723
+ }
724
+ sanitizeBody(params, ["tools"]);
725
+ const result = await agent.declineToolCallGenerate({
726
+ ...params,
727
+ abortSignal
728
+ });
729
+ return result;
730
+ } catch (error) {
731
+ return handleError(error, "error declining tool call");
732
+ }
733
+ }
734
+ });
735
+ var STREAM_NETWORK_ROUTE = createRoute({
736
+ method: "POST",
737
+ path: "/agents/:agentId/network",
738
+ responseType: "stream",
739
+ streamFormat: "sse",
740
+ pathParamSchema: agentIdPathParams,
741
+ bodySchema: agentExecutionBodySchema,
742
+ responseSchema: streamResponseSchema,
743
+ summary: "Stream agent network",
744
+ description: "Executes an agent network with multiple agents and streams the response",
745
+ tags: ["Agents"],
746
+ requiresAuth: true,
747
+ handler: async ({ mastra, messages, agentId, ...params }) => {
748
+ try {
749
+ const agent = await getAgentFromSystem({ mastra, agentId });
750
+ sanitizeBody(params, ["tools"]);
751
+ validateBody({ messages });
752
+ const streamResult = await agent.network(messages, {
753
+ ...params
754
+ });
755
+ return streamResult;
756
+ } catch (error) {
757
+ return handleError(error, "error streaming agent loop response");
758
+ }
759
+ }
760
+ });
761
+ var APPROVE_NETWORK_TOOL_CALL_ROUTE = createRoute({
762
+ method: "POST",
763
+ path: "/agents/:agentId/approve-network-tool-call",
764
+ responseType: "stream",
765
+ streamFormat: "sse",
766
+ pathParamSchema: agentIdPathParams,
767
+ bodySchema: approveNetworkToolCallBodySchema,
768
+ responseSchema: streamResponseSchema,
769
+ summary: "Approve network tool call",
770
+ description: "Approves a pending network tool call and continues network agent execution",
771
+ tags: ["Agents", "Tools"],
772
+ requiresAuth: true,
773
+ handler: async ({ mastra, agentId, ...params }) => {
774
+ try {
775
+ const agent = await getAgentFromSystem({ mastra, agentId });
776
+ if (!params.runId) {
777
+ throw new HTTPException(400, { message: "Run id is required" });
778
+ }
779
+ sanitizeBody(params, ["tools"]);
780
+ const streamResult = await agent.approveNetworkToolCall({
781
+ ...params
782
+ });
783
+ return streamResult;
784
+ } catch (error) {
785
+ return handleError(error, "error approving network tool call");
786
+ }
787
+ }
788
+ });
789
+ var DECLINE_NETWORK_TOOL_CALL_ROUTE = createRoute({
790
+ method: "POST",
791
+ path: "/agents/:agentId/decline-network-tool-call",
792
+ responseType: "stream",
793
+ streamFormat: "sse",
794
+ pathParamSchema: agentIdPathParams,
795
+ bodySchema: declineNetworkToolCallBodySchema,
796
+ responseSchema: streamResponseSchema,
797
+ summary: "Decline network tool call",
798
+ description: "Declines a pending network tool call and continues network agent execution without executing the tool",
799
+ tags: ["Agents", "Tools"],
800
+ requiresAuth: true,
801
+ handler: async ({ mastra, agentId, ...params }) => {
802
+ try {
803
+ const agent = await getAgentFromSystem({ mastra, agentId });
804
+ if (!params.runId) {
805
+ throw new HTTPException(400, { message: "Run id is required" });
806
+ }
807
+ sanitizeBody(params, ["tools"]);
808
+ const streamResult = await agent.declineNetworkToolCall({
809
+ ...params
810
+ });
811
+ return streamResult;
812
+ } catch (error) {
813
+ return handleError(error, "error declining network tool call");
814
+ }
815
+ }
816
+ });
817
+ var UPDATE_AGENT_MODEL_ROUTE = createRoute({
818
+ method: "POST",
819
+ path: "/agents/:agentId/model",
820
+ responseType: "json",
821
+ pathParamSchema: agentIdPathParams,
822
+ bodySchema: updateAgentModelBodySchema,
823
+ responseSchema: modelManagementResponseSchema,
824
+ summary: "Update agent model",
825
+ description: "Updates the AI model used by the agent",
826
+ tags: ["Agents", "Models"],
827
+ requiresAuth: true,
828
+ handler: async ({ mastra, agentId, modelId, provider }) => {
829
+ try {
830
+ const agent = await getAgentFromSystem({ mastra, agentId });
831
+ const newModel = `${provider}/${modelId}`;
832
+ agent.__updateModel({ model: newModel });
833
+ return { message: "Agent model updated" };
834
+ } catch (error) {
835
+ return handleError(error, "error updating agent model");
836
+ }
837
+ }
838
+ });
839
+ var RESET_AGENT_MODEL_ROUTE = createRoute({
840
+ method: "POST",
841
+ path: "/agents/:agentId/model/reset",
842
+ responseType: "json",
843
+ pathParamSchema: agentIdPathParams,
844
+ responseSchema: modelManagementResponseSchema,
845
+ summary: "Reset agent model",
846
+ description: "Resets the agent model to its original configuration",
847
+ tags: ["Agents", "Models"],
848
+ requiresAuth: true,
849
+ handler: async ({ mastra, agentId }) => {
850
+ try {
851
+ const agent = await getAgentFromSystem({ mastra, agentId });
852
+ agent.__resetToOriginalModel();
853
+ return { message: "Agent model reset to original" };
854
+ } catch (error) {
855
+ return handleError(error, "error resetting agent model");
856
+ }
857
+ }
858
+ });
859
+ var REORDER_AGENT_MODEL_LIST_ROUTE = createRoute({
860
+ method: "POST",
861
+ path: "/agents/:agentId/models/reorder",
862
+ responseType: "json",
863
+ pathParamSchema: agentIdPathParams,
864
+ bodySchema: reorderAgentModelListBodySchema,
865
+ responseSchema: modelManagementResponseSchema,
866
+ summary: "Reorder agent model list",
867
+ description: "Reorders the model list for agents with multiple model configurations",
868
+ tags: ["Agents", "Models"],
869
+ requiresAuth: true,
870
+ handler: async ({ mastra, agentId, reorderedModelIds }) => {
871
+ try {
872
+ const agent = await getAgentFromSystem({ mastra, agentId });
873
+ const modelList = await agent.getModelList();
874
+ if (!modelList || modelList.length === 0) {
875
+ throw new HTTPException(400, { message: "Agent model list is not found or empty" });
876
+ }
877
+ agent.reorderModels(reorderedModelIds);
878
+ return { message: "Model list reordered" };
879
+ } catch (error) {
880
+ return handleError(error, "error reordering model list");
881
+ }
882
+ }
883
+ });
884
+ var UPDATE_AGENT_MODEL_IN_MODEL_LIST_ROUTE = createRoute({
885
+ method: "POST",
886
+ path: "/agents/:agentId/models/:modelConfigId",
887
+ responseType: "json",
888
+ pathParamSchema: modelConfigIdPathParams,
889
+ bodySchema: updateAgentModelInModelListBodySchema,
890
+ responseSchema: modelManagementResponseSchema,
891
+ summary: "Update model in model list",
892
+ description: "Updates a specific model configuration in the agent model list",
893
+ tags: ["Agents", "Models"],
894
+ requiresAuth: true,
895
+ handler: async ({ mastra, agentId, modelConfigId, model: bodyModel, maxRetries, enabled }) => {
896
+ try {
897
+ const agent = await getAgentFromSystem({ mastra, agentId });
898
+ const modelList = await agent.getModelList();
899
+ if (!modelList || modelList.length === 0) {
900
+ throw new HTTPException(400, { message: "Agent model list is not found or empty" });
901
+ }
902
+ const modelConfig = modelList.find((config) => config.id === modelConfigId);
903
+ if (!modelConfig) {
904
+ throw new HTTPException(404, { message: `Model config with id ${modelConfigId} not found` });
905
+ }
906
+ const newModel = bodyModel?.modelId && bodyModel?.provider ? `${bodyModel.provider}/${bodyModel.modelId}` : modelConfig.model;
907
+ const updated = {
908
+ ...modelConfig,
909
+ model: newModel,
910
+ ...maxRetries !== void 0 ? { maxRetries } : {},
911
+ ...enabled !== void 0 ? { enabled } : {}
912
+ };
913
+ agent.updateModelInModelList(updated);
914
+ return { message: "Model updated in model list" };
915
+ } catch (error) {
916
+ return handleError(error, "error updating model in model list");
917
+ }
918
+ }
919
+ });
920
+ var ENHANCE_SYSTEM_PROMPT_INSTRUCTIONS = `You are an expert system prompt engineer, specialized in analyzing and enhancing instructions to create clear, effective, and comprehensive system prompts. Your goal is to help users transform their basic instructions into well-structured system prompts that will guide AI behavior effectively.
921
+
922
+ Follow these steps to analyze and enhance the instructions:
923
+
924
+ 1. ANALYSIS PHASE
925
+ - Identify the core purpose and goals
926
+ - Extract key constraints and requirements
927
+ - Recognize domain-specific terminology and concepts
928
+ - Note any implicit assumptions that should be made explicit
929
+
930
+ 2. PROMPT STRUCTURE
931
+ Create a system prompt with these components:
932
+ a) ROLE DEFINITION
933
+ - Clear statement of the AI's role and purpose
934
+ - Key responsibilities and scope
935
+ - Primary stakeholders and users
936
+ b) CORE CAPABILITIES
937
+ - Main functions and abilities
938
+ - Specific domain knowledge required
939
+ - Tools and resources available
940
+ c) BEHAVIORAL GUIDELINES
941
+ - Communication style and tone
942
+ - Decision-making framework
943
+ - Error handling approach
944
+ - Ethical considerations
945
+ d) CONSTRAINTS & BOUNDARIES
946
+ - Explicit limitations
947
+ - Out-of-scope activities
948
+ - Security and privacy considerations
949
+ e) SUCCESS CRITERIA
950
+ - Quality standards
951
+ - Expected outcomes
952
+ - Performance metrics
953
+
954
+ 3. QUALITY CHECKS
955
+ Ensure the prompt is:
956
+ - Clear and unambiguous
957
+ - Comprehensive yet concise
958
+ - Properly scoped
959
+ - Technically accurate
960
+ - Ethically sound
961
+
962
+ 4. OUTPUT FORMAT
963
+ Return a structured response with:
964
+ - Enhanced system prompt
965
+ - Analysis of key components
966
+ - Identified goals and constraints
967
+ - Core domain concepts
968
+
969
+ Remember: A good system prompt should be specific enough to guide behavior but flexible enough to handle edge cases. Focus on creating prompts that are clear, actionable, and aligned with the intended use case.`;
970
+ async function findConnectedModel(agent) {
971
+ const modelList = await agent.getModelList();
972
+ if (modelList && modelList.length > 0) {
973
+ for (const modelConfig of modelList) {
974
+ if (modelConfig.enabled !== false) {
975
+ const model = modelConfig.model;
976
+ if (isProviderConnected(model.provider)) {
977
+ return model;
978
+ }
979
+ }
980
+ }
981
+ return null;
982
+ }
983
+ const defaultModel = await agent.getModel();
984
+ if (isProviderConnected(defaultModel.provider)) {
985
+ return defaultModel;
986
+ }
987
+ return null;
988
+ }
989
+ var ENHANCE_INSTRUCTIONS_ROUTE = createRoute({
990
+ method: "POST",
991
+ path: "/agents/:agentId/instructions/enhance",
992
+ responseType: "json",
993
+ pathParamSchema: agentIdPathParams,
994
+ bodySchema: enhanceInstructionsBodySchema,
995
+ responseSchema: enhanceInstructionsResponseSchema,
996
+ summary: "Enhance agent instructions",
997
+ description: "Uses AI to enhance or modify agent instructions based on user feedback",
998
+ tags: ["Agents"],
999
+ requiresAuth: true,
1000
+ handler: async ({ mastra, agentId, instructions, comment }) => {
1001
+ try {
1002
+ const agent = await getAgentFromSystem({ mastra, agentId });
1003
+ const model = await findConnectedModel(agent);
1004
+ if (!model) {
1005
+ throw new HTTPException(400, {
1006
+ message: "No model with a configured API key found. Please set the required environment variable for your model provider."
1007
+ });
1008
+ }
1009
+ const systemPromptAgent = new Agent({
1010
+ id: "system-prompt-enhancer",
1011
+ name: "system-prompt-enhancer",
1012
+ instructions: ENHANCE_SYSTEM_PROMPT_INSTRUCTIONS,
1013
+ model
1014
+ });
1015
+ const result = await systemPromptAgent.generate(
1016
+ `We need to improve the system prompt.
1017
+ Current: ${instructions}
1018
+ ${comment ? `User feedback: ${comment}` : ""}`,
1019
+ {
1020
+ structuredOutput: {
1021
+ schema: enhanceInstructionsResponseSchema
1022
+ }
1023
+ }
1024
+ );
1025
+ return await result.object;
1026
+ } catch (error) {
1027
+ return handleError(error, "Error enhancing instructions");
1028
+ }
1029
+ }
1030
+ });
1031
+ var STREAM_VNEXT_DEPRECATED_ROUTE = createRoute({
1032
+ method: "POST",
1033
+ path: "/agents/:agentId/streamVNext",
1034
+ responseType: "stream",
1035
+ pathParamSchema: agentIdPathParams,
1036
+ bodySchema: agentExecutionBodySchema,
1037
+ responseSchema: streamResponseSchema,
1038
+ summary: "Stream a response from an agent",
1039
+ description: "[DEPRECATED] This endpoint is deprecated. Please use /stream instead.",
1040
+ tags: ["Agents"],
1041
+ requiresAuth: true,
1042
+ deprecated: true,
1043
+ handler: async () => {
1044
+ throw new HTTPException(410, { message: "This endpoint is deprecated. Please use /stream instead." });
1045
+ }
1046
+ });
1047
+ var STREAM_UI_MESSAGE_VNEXT_DEPRECATED_ROUTE = createRoute({
1048
+ method: "POST",
1049
+ path: "/agents/:agentId/stream/vnext/ui",
1050
+ responseType: "stream",
1051
+ pathParamSchema: agentIdPathParams,
1052
+ bodySchema: agentExecutionBodySchema,
1053
+ responseSchema: streamResponseSchema,
1054
+ summary: "Stream UI messages from an agent",
1055
+ description: "[DEPRECATED] This endpoint is deprecated. Please use the @mastra/ai-sdk package for uiMessage transformations",
1056
+ tags: ["Agents"],
1057
+ requiresAuth: true,
1058
+ deprecated: true,
1059
+ handler: async () => {
1060
+ try {
1061
+ throw new MastraError({
1062
+ category: ErrorCategory.USER,
1063
+ domain: ErrorDomain.MASTRA_SERVER,
1064
+ id: "DEPRECATED_ENDPOINT",
1065
+ text: "This endpoint is deprecated. Please use the @mastra/ai-sdk package to for uiMessage transformations"
1066
+ });
1067
+ } catch (error) {
1068
+ return handleError(error, "error streaming agent response");
1069
+ }
1070
+ }
1071
+ });
1072
+ var STREAM_UI_MESSAGE_DEPRECATED_ROUTE = createRoute({
1073
+ method: "POST",
1074
+ path: "/agents/:agentId/stream/ui",
1075
+ responseType: "stream",
1076
+ pathParamSchema: agentIdPathParams,
1077
+ bodySchema: agentExecutionBodySchema,
1078
+ responseSchema: streamResponseSchema,
1079
+ summary: "Stream UI messages from an agent",
1080
+ description: "[DEPRECATED] This endpoint is deprecated. Please use the @mastra/ai-sdk package for uiMessage transformations",
1081
+ tags: ["Agents"],
1082
+ requiresAuth: true,
1083
+ deprecated: true,
1084
+ handler: STREAM_UI_MESSAGE_VNEXT_DEPRECATED_ROUTE.handler
1085
+ });
1086
+
1087
+ export { APPROVE_NETWORK_TOOL_CALL_ROUTE, APPROVE_TOOL_CALL_GENERATE_ROUTE, APPROVE_TOOL_CALL_ROUTE, DECLINE_NETWORK_TOOL_CALL_ROUTE, DECLINE_TOOL_CALL_GENERATE_ROUTE, DECLINE_TOOL_CALL_ROUTE, ENHANCE_INSTRUCTIONS_ROUTE, GENERATE_AGENT_ROUTE, GENERATE_AGENT_VNEXT_ROUTE, GENERATE_LEGACY_ROUTE, GET_AGENT_BY_ID_ROUTE, GET_PROVIDERS_ROUTE, LIST_AGENTS_ROUTE, REORDER_AGENT_MODEL_LIST_ROUTE, RESET_AGENT_MODEL_ROUTE, STREAM_GENERATE_LEGACY_ROUTE, STREAM_GENERATE_ROUTE, STREAM_GENERATE_VNEXT_DEPRECATED_ROUTE, STREAM_NETWORK_ROUTE, STREAM_UI_MESSAGE_DEPRECATED_ROUTE, STREAM_UI_MESSAGE_VNEXT_DEPRECATED_ROUTE, STREAM_VNEXT_DEPRECATED_ROUTE, UPDATE_AGENT_MODEL_IN_MODEL_LIST_ROUTE, UPDATE_AGENT_MODEL_ROUTE, agents_exports, getAgentFromSystem, getSerializedAgentTools, getSerializedProcessors };
1088
+ //# sourceMappingURL=chunk-BSOLG32W.js.map
1089
+ //# sourceMappingURL=chunk-BSOLG32W.js.map