@mastra/server 1.0.4-alpha.2 → 1.0.4

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 (448) hide show
  1. package/CHANGELOG.md +6596 -0
  2. package/LICENSE.md +11 -42
  3. package/README.md +45 -137
  4. package/dist/chunk-2CLS2PYJ.js +1030 -0
  5. package/dist/chunk-2CLS2PYJ.js.map +1 -0
  6. package/dist/chunk-2CYGIE3E.js +1075 -0
  7. package/dist/chunk-2CYGIE3E.js.map +1 -0
  8. package/dist/chunk-33CKPQS4.cjs +175 -0
  9. package/dist/chunk-33CKPQS4.cjs.map +1 -0
  10. package/dist/chunk-3FEYUHHJ.js +116 -0
  11. package/dist/chunk-3FEYUHHJ.js.map +1 -0
  12. package/dist/chunk-3REGEJEN.js +250 -0
  13. package/dist/chunk-3REGEJEN.js.map +1 -0
  14. package/dist/chunk-3W67K7YE.js +13 -0
  15. package/dist/chunk-3W67K7YE.js.map +1 -0
  16. package/dist/chunk-4DJ7EJRB.cjs +186 -0
  17. package/dist/chunk-4DJ7EJRB.cjs.map +1 -0
  18. package/dist/chunk-4EYONQIW.cjs +82 -0
  19. package/dist/chunk-4EYONQIW.cjs.map +1 -0
  20. package/dist/chunk-4R2Z655M.js +1075 -0
  21. package/dist/chunk-4R2Z655M.js.map +1 -0
  22. package/dist/chunk-5NFRDYFN.js +77 -0
  23. package/dist/chunk-5NFRDYFN.js.map +1 -0
  24. package/dist/chunk-5VDI75UV.js +44 -0
  25. package/dist/chunk-5VDI75UV.js.map +1 -0
  26. package/dist/chunk-5W4RPVTK.cjs +49 -0
  27. package/dist/chunk-5W4RPVTK.cjs.map +1 -0
  28. package/dist/{chunk-FV45V6WC.cjs → chunk-64ITUOXI.cjs} +3 -7
  29. package/dist/chunk-64ITUOXI.cjs.map +1 -0
  30. package/dist/chunk-6MP2S6VI.cjs +211 -0
  31. package/dist/chunk-6MP2S6VI.cjs.map +1 -0
  32. package/dist/{chunk-TRDNDNGQ.js → chunk-6QWQZI4Q.js} +4 -7
  33. package/dist/chunk-6QWQZI4Q.js.map +1 -0
  34. package/dist/chunk-7S7ALPCY.js +225 -0
  35. package/dist/chunk-7S7ALPCY.js.map +1 -0
  36. package/dist/chunk-7XPMKW4Y.cjs +447 -0
  37. package/dist/chunk-7XPMKW4Y.cjs.map +1 -0
  38. package/dist/chunk-AQI6GLTN.cjs +2777 -0
  39. package/dist/chunk-AQI6GLTN.cjs.map +1 -0
  40. package/dist/chunk-AV3CN5ZR.cjs +326 -0
  41. package/dist/chunk-AV3CN5ZR.cjs.map +1 -0
  42. package/dist/chunk-AVRO3FIN.cjs +231 -0
  43. package/dist/chunk-AVRO3FIN.cjs.map +1 -0
  44. package/dist/chunk-BRI4GUZ2.cjs +280 -0
  45. package/dist/chunk-BRI4GUZ2.cjs.map +1 -0
  46. package/dist/chunk-CGIGPJRU.js +279 -0
  47. package/dist/chunk-CGIGPJRU.js.map +1 -0
  48. package/dist/chunk-CLAEGIP5.cjs +683 -0
  49. package/dist/chunk-CLAEGIP5.cjs.map +1 -0
  50. package/dist/chunk-DVSCJECS.js +250 -0
  51. package/dist/chunk-DVSCJECS.js.map +1 -0
  52. package/dist/chunk-EUBTCHQC.js +83 -0
  53. package/dist/chunk-EUBTCHQC.js.map +1 -0
  54. package/dist/chunk-FLLJIPD4.cjs +46 -0
  55. package/dist/chunk-FLLJIPD4.cjs.map +1 -0
  56. package/dist/chunk-FWSKVWS7.cjs +88 -0
  57. package/dist/chunk-FWSKVWS7.cjs.map +1 -0
  58. package/dist/chunk-G2AMUTU4.js +250 -0
  59. package/dist/chunk-G2AMUTU4.js.map +1 -0
  60. package/dist/chunk-GHQZIEPS.js +33118 -0
  61. package/dist/chunk-GHQZIEPS.js.map +1 -0
  62. package/dist/chunk-GNCALVLC.js +171 -0
  63. package/dist/chunk-GNCALVLC.js.map +1 -0
  64. package/dist/chunk-GU4EWMZB.cjs +769 -0
  65. package/dist/chunk-GU4EWMZB.cjs.map +1 -0
  66. package/dist/chunk-H34VRYSF.js +196 -0
  67. package/dist/chunk-H34VRYSF.js.map +1 -0
  68. package/dist/chunk-H66LLFDL.js +970 -0
  69. package/dist/chunk-H66LLFDL.js.map +1 -0
  70. package/dist/chunk-HCVDHEDD.cjs +33157 -0
  71. package/dist/chunk-HCVDHEDD.cjs.map +1 -0
  72. package/dist/chunk-HT4LP3BO.js +75 -0
  73. package/dist/chunk-HT4LP3BO.js.map +1 -0
  74. package/dist/chunk-I27H7BEB.js +439 -0
  75. package/dist/chunk-I27H7BEB.js.map +1 -0
  76. package/dist/chunk-IVGQTL3T.js +204 -0
  77. package/dist/chunk-IVGQTL3T.js.map +1 -0
  78. package/dist/chunk-KKY4MSZO.js +314 -0
  79. package/dist/chunk-KKY4MSZO.js.map +1 -0
  80. package/dist/chunk-L2E5RUVT.cjs +252 -0
  81. package/dist/chunk-L2E5RUVT.cjs.map +1 -0
  82. package/dist/chunk-LF2ZLOFP.js +767 -0
  83. package/dist/chunk-LF2ZLOFP.js.map +1 -0
  84. package/dist/chunk-LJ6YRVDI.cjs +15 -0
  85. package/dist/chunk-LJ6YRVDI.cjs.map +1 -0
  86. package/dist/chunk-LOA7RQYO.js +2774 -0
  87. package/dist/chunk-LOA7RQYO.js.map +1 -0
  88. package/dist/chunk-MCYD5LW7.cjs +90 -0
  89. package/dist/chunk-MCYD5LW7.cjs.map +1 -0
  90. package/dist/chunk-MPUVSOEU.cjs +346 -0
  91. package/dist/chunk-MPUVSOEU.cjs.map +1 -0
  92. package/dist/chunk-N4EIZSG2.js +180 -0
  93. package/dist/chunk-N4EIZSG2.js.map +1 -0
  94. package/dist/chunk-NUO7HPOV.cjs +1105 -0
  95. package/dist/chunk-NUO7HPOV.cjs.map +1 -0
  96. package/dist/chunk-O7I5CWRX.cjs +44 -0
  97. package/dist/chunk-O7I5CWRX.cjs.map +1 -0
  98. package/dist/chunk-ONN5EA7E.js +26 -0
  99. package/dist/chunk-ONN5EA7E.js.map +1 -0
  100. package/dist/chunk-P3H4AZKI.cjs +252 -0
  101. package/dist/chunk-P3H4AZKI.cjs.map +1 -0
  102. package/dist/chunk-PNZQCQY4.cjs +252 -0
  103. package/dist/chunk-PNZQCQY4.cjs.map +1 -0
  104. package/dist/chunk-PR4QN5HX.js +39 -0
  105. package/dist/chunk-PR4QN5HX.js.map +1 -0
  106. package/dist/chunk-QPFYN6B5.cjs +125 -0
  107. package/dist/chunk-QPFYN6B5.cjs.map +1 -0
  108. package/dist/chunk-SUKFO7UM.cjs +29 -0
  109. package/dist/chunk-SUKFO7UM.cjs.map +1 -0
  110. package/dist/chunk-T4SPG2GP.cjs +82 -0
  111. package/dist/chunk-T4SPG2GP.cjs.map +1 -0
  112. package/dist/chunk-TMS4LS2J.js +302 -0
  113. package/dist/chunk-TMS4LS2J.js.map +1 -0
  114. package/dist/chunk-UK4FZWNW.cjs +205 -0
  115. package/dist/chunk-UK4FZWNW.cjs.map +1 -0
  116. package/dist/chunk-VX3VN7FN.cjs +992 -0
  117. package/dist/chunk-VX3VN7FN.cjs.map +1 -0
  118. package/dist/chunk-WJ6DNHLW.cjs +312 -0
  119. package/dist/chunk-WJ6DNHLW.cjs.map +1 -0
  120. package/dist/chunk-WLGJVDH4.js +242 -0
  121. package/dist/chunk-WLGJVDH4.js.map +1 -0
  122. package/dist/chunk-XB27LCKO.js +328 -0
  123. package/dist/chunk-XB27LCKO.js.map +1 -0
  124. package/dist/chunk-XCEQ4GQW.cjs +289 -0
  125. package/dist/chunk-XCEQ4GQW.cjs.map +1 -0
  126. package/dist/chunk-XOUK3IYU.js +77 -0
  127. package/dist/chunk-XOUK3IYU.js.map +1 -0
  128. package/dist/chunk-XWGAT2DA.js +44 -0
  129. package/dist/chunk-XWGAT2DA.js.map +1 -0
  130. package/dist/chunk-YK63KHHB.cjs +1059 -0
  131. package/dist/chunk-YK63KHHB.cjs.map +1 -0
  132. package/dist/chunk-YN3FWKVQ.js +669 -0
  133. package/dist/chunk-YN3FWKVQ.js.map +1 -0
  134. package/dist/chunk-ZQ2G6QKS.cjs +1117 -0
  135. package/dist/chunk-ZQ2G6QKS.cjs.map +1 -0
  136. package/dist/dist-7NTDEVLP.cjs +928 -0
  137. package/dist/dist-7NTDEVLP.cjs.map +1 -0
  138. package/dist/dist-B5GMANA6.js +1147 -0
  139. package/dist/dist-B5GMANA6.js.map +1 -0
  140. package/dist/dist-EDO7GEGI.js +3 -0
  141. package/dist/dist-EDO7GEGI.js.map +1 -0
  142. package/dist/dist-OF24ZMHH.cjs +764 -0
  143. package/dist/dist-OF24ZMHH.cjs.map +1 -0
  144. package/dist/dist-P6YSNLL3.cjs +1150 -0
  145. package/dist/dist-P6YSNLL3.cjs.map +1 -0
  146. package/dist/dist-SMBO5KVB.js +937 -0
  147. package/dist/dist-SMBO5KVB.js.map +1 -0
  148. package/dist/dist-THPMW5QR.js +761 -0
  149. package/dist/dist-THPMW5QR.js.map +1 -0
  150. package/dist/dist-VZTG56X2.cjs +940 -0
  151. package/dist/dist-VZTG56X2.cjs.map +1 -0
  152. package/dist/dist-ZLC23RVC.cjs +16 -0
  153. package/dist/dist-ZLC23RVC.cjs.map +1 -0
  154. package/dist/dist-ZOZ6MHJH.js +925 -0
  155. package/dist/dist-ZOZ6MHJH.js.map +1 -0
  156. package/dist/docs/README.md +31 -0
  157. package/dist/docs/SKILL.md +32 -0
  158. package/dist/docs/SOURCE_MAP.json +6 -0
  159. package/dist/docs/server/01-custom-adapters.md +380 -0
  160. package/dist/docs/server/02-reference.md +819 -0
  161. package/dist/index.cjs +6 -0
  162. package/dist/index.cjs.map +1 -0
  163. package/dist/index.d.ts +1 -0
  164. package/dist/index.d.ts.map +1 -0
  165. package/dist/index.js +5 -0
  166. package/dist/index.js.map +1 -0
  167. package/dist/server/a2a/protocol.d.ts +8 -0
  168. package/dist/server/a2a/protocol.d.ts.map +1 -0
  169. package/dist/server/a2a/store.cjs +25 -0
  170. package/dist/server/a2a/store.cjs.map +1 -0
  171. package/dist/server/a2a/store.d.ts +14 -0
  172. package/dist/server/a2a/store.d.ts.map +1 -0
  173. package/dist/server/a2a/store.js +23 -0
  174. package/dist/server/a2a/store.js.map +1 -0
  175. package/dist/server/a2a/tasks.d.ts +20 -0
  176. package/dist/server/a2a/tasks.d.ts.map +1 -0
  177. package/dist/server/auth/defaults.d.ts +3 -0
  178. package/dist/server/auth/defaults.d.ts.map +1 -0
  179. package/dist/server/auth/helpers.d.ts +14 -0
  180. package/dist/server/auth/helpers.d.ts.map +1 -0
  181. package/dist/server/auth/index.cjs +137 -0
  182. package/dist/server/auth/index.cjs.map +1 -0
  183. package/dist/server/auth/index.d.ts +3 -0
  184. package/dist/server/auth/index.d.ts.map +1 -0
  185. package/dist/server/auth/index.js +127 -0
  186. package/dist/server/auth/index.js.map +1 -0
  187. package/dist/server/handlers/a2a.cjs +40 -0
  188. package/dist/server/handlers/a2a.cjs.map +1 -0
  189. package/dist/server/handlers/a2a.d.ts +550 -0
  190. package/dist/server/handlers/a2a.d.ts.map +1 -0
  191. package/dist/server/handlers/a2a.js +3 -0
  192. package/dist/server/handlers/a2a.js.map +1 -0
  193. package/dist/server/handlers/agent-builder.cjs +68 -0
  194. package/dist/server/handlers/agent-builder.cjs.map +1 -0
  195. package/dist/server/handlers/agent-builder.d.ts +632 -0
  196. package/dist/server/handlers/agent-builder.d.ts.map +1 -0
  197. package/dist/server/handlers/agent-builder.js +3 -0
  198. package/dist/server/handlers/agent-builder.js.map +1 -0
  199. package/dist/server/handlers/agents.cjs +99 -13
  200. package/dist/server/handlers/agents.cjs.map +1 -0
  201. package/dist/server/handlers/agents.d.ts +3387 -6
  202. package/dist/server/handlers/agents.d.ts.map +1 -0
  203. package/dist/server/handlers/agents.js +3 -1
  204. package/dist/server/handlers/agents.js.map +1 -0
  205. package/dist/server/handlers/error.cjs +8 -2
  206. package/dist/server/handlers/error.cjs.map +1 -0
  207. package/dist/server/handlers/error.d.ts +14 -1
  208. package/dist/server/handlers/error.d.ts.map +1 -0
  209. package/dist/server/handlers/error.js +3 -1
  210. package/dist/server/handlers/error.js.map +1 -0
  211. package/dist/server/handlers/logs.cjs +9 -7
  212. package/dist/server/handlers/logs.cjs.map +1 -0
  213. package/dist/server/handlers/logs.d.ts +142 -3
  214. package/dist/server/handlers/logs.d.ts.map +1 -0
  215. package/dist/server/handlers/logs.js +3 -1
  216. package/dist/server/handlers/logs.js.map +1 -0
  217. package/dist/server/handlers/mcp.cjs +40 -0
  218. package/dist/server/handlers/mcp.cjs.map +1 -0
  219. package/dist/server/handlers/mcp.d.ts +110 -0
  220. package/dist/server/handlers/mcp.d.ts.map +1 -0
  221. package/dist/server/handlers/mcp.js +3 -0
  222. package/dist/server/handlers/mcp.js.map +1 -0
  223. package/dist/server/handlers/memory.cjs +83 -17
  224. package/dist/server/handlers/memory.cjs.map +1 -0
  225. package/dist/server/handlers/memory.d.ts +1065 -8
  226. package/dist/server/handlers/memory.d.ts.map +1 -0
  227. package/dist/server/handlers/memory.js +3 -1
  228. package/dist/server/handlers/memory.js.map +1 -0
  229. package/dist/server/handlers/observability.cjs +24 -0
  230. package/dist/server/handlers/observability.cjs.map +1 -0
  231. package/dist/server/handlers/observability.d.ts +153 -0
  232. package/dist/server/handlers/observability.d.ts.map +1 -0
  233. package/dist/server/handlers/observability.js +3 -0
  234. package/dist/server/handlers/observability.js.map +1 -0
  235. package/dist/server/handlers/processors.cjs +20 -0
  236. package/dist/server/handlers/processors.cjs.map +1 -0
  237. package/dist/server/handlers/processors.d.ts +181 -0
  238. package/dist/server/handlers/processors.d.ts.map +1 -0
  239. package/dist/server/handlers/processors.js +3 -0
  240. package/dist/server/handlers/processors.js.map +1 -0
  241. package/dist/server/handlers/scores.cjs +32 -0
  242. package/dist/server/handlers/scores.cjs.map +1 -0
  243. package/dist/server/handlers/scores.d.ts +121 -0
  244. package/dist/server/handlers/scores.d.ts.map +1 -0
  245. package/dist/server/handlers/scores.js +3 -0
  246. package/dist/server/handlers/scores.js.map +1 -0
  247. package/dist/server/handlers/stored-agents.cjs +28 -0
  248. package/dist/server/handlers/stored-agents.cjs.map +1 -0
  249. package/dist/server/handlers/stored-agents.d.ts +289 -0
  250. package/dist/server/handlers/stored-agents.d.ts.map +1 -0
  251. package/dist/server/handlers/stored-agents.js +3 -0
  252. package/dist/server/handlers/stored-agents.js.map +1 -0
  253. package/dist/server/handlers/system.cjs +12 -0
  254. package/dist/server/handlers/system.cjs.map +1 -0
  255. package/dist/server/handlers/system.d.ts +7 -0
  256. package/dist/server/handlers/system.d.ts.map +1 -0
  257. package/dist/server/handlers/system.js +3 -0
  258. package/dist/server/handlers/system.js.map +1 -0
  259. package/dist/server/handlers/test-utils.cjs +15 -0
  260. package/dist/server/handlers/test-utils.cjs.map +1 -0
  261. package/dist/server/handlers/test-utils.d.ts +6 -0
  262. package/dist/server/handlers/test-utils.d.ts.map +1 -0
  263. package/dist/server/handlers/test-utils.js +13 -0
  264. package/dist/server/handlers/test-utils.js.map +1 -0
  265. package/dist/server/handlers/tools.cjs +15 -9
  266. package/dist/server/handlers/tools.cjs.map +1 -0
  267. package/dist/server/handlers/tools.d.ts +71 -4
  268. package/dist/server/handlers/tools.d.ts.map +1 -0
  269. package/dist/server/handlers/tools.js +3 -1
  270. package/dist/server/handlers/tools.js.map +1 -0
  271. package/dist/server/handlers/utils.cjs +16 -2
  272. package/dist/server/handlers/utils.cjs.map +1 -0
  273. package/dist/server/handlers/utils.d.ts +13 -1
  274. package/dist/server/handlers/utils.d.ts.map +1 -0
  275. package/dist/server/handlers/utils.js +3 -1
  276. package/dist/server/handlers/utils.js.map +1 -0
  277. package/dist/server/handlers/vector.cjs +33 -7
  278. package/dist/server/handlers/vector.cjs.map +1 -0
  279. package/dist/server/handlers/vector.d.ts +135 -6
  280. package/dist/server/handlers/vector.d.ts.map +1 -0
  281. package/dist/server/handlers/vector.js +3 -1
  282. package/dist/server/handlers/vector.js.map +1 -0
  283. package/dist/server/handlers/voice.cjs +25 -7
  284. package/dist/server/handlers/voice.cjs.map +1 -0
  285. package/dist/server/handlers/voice.d.ts +82 -3
  286. package/dist/server/handlers/voice.d.ts.map +1 -0
  287. package/dist/server/handlers/voice.js +3 -1
  288. package/dist/server/handlers/voice.js.map +1 -0
  289. package/dist/server/handlers/workflows.cjs +75 -21
  290. package/dist/server/handlers/workflows.cjs.map +1 -0
  291. package/dist/server/handlers/workflows.d.ts +994 -10
  292. package/dist/server/handlers/workflows.d.ts.map +1 -0
  293. package/dist/server/handlers/workflows.js +3 -1
  294. package/dist/server/handlers/workflows.js.map +1 -0
  295. package/dist/server/handlers.cjs +41 -24
  296. package/dist/server/handlers.cjs.map +1 -0
  297. package/dist/server/handlers.d.ts +13 -9
  298. package/dist/server/handlers.d.ts.map +1 -0
  299. package/dist/server/handlers.js +14 -9
  300. package/dist/server/handlers.js.map +1 -0
  301. package/dist/server/http-exception.d.ts +82 -0
  302. package/dist/server/http-exception.d.ts.map +1 -0
  303. package/dist/server/schemas/a2a.d.ts +786 -0
  304. package/dist/server/schemas/a2a.d.ts.map +1 -0
  305. package/dist/server/schemas/agent-builder.d.ts +225 -0
  306. package/dist/server/schemas/agent-builder.d.ts.map +1 -0
  307. package/dist/server/schemas/agents.d.ts +1804 -0
  308. package/dist/server/schemas/agents.d.ts.map +1 -0
  309. package/dist/server/schemas/common.d.ts +179 -0
  310. package/dist/server/schemas/common.d.ts.map +1 -0
  311. package/dist/server/schemas/logs.d.ts +124 -0
  312. package/dist/server/schemas/logs.d.ts.map +1 -0
  313. package/dist/server/schemas/mcp.d.ts +299 -0
  314. package/dist/server/schemas/mcp.d.ts.map +1 -0
  315. package/dist/server/schemas/memory.d.ts +1164 -0
  316. package/dist/server/schemas/memory.d.ts.map +1 -0
  317. package/dist/server/schemas/processors.d.ts +519 -0
  318. package/dist/server/schemas/processors.d.ts.map +1 -0
  319. package/dist/server/schemas/scores.d.ts +259 -0
  320. package/dist/server/schemas/scores.d.ts.map +1 -0
  321. package/dist/server/schemas/stored-agents.d.ts +792 -0
  322. package/dist/server/schemas/stored-agents.d.ts.map +1 -0
  323. package/dist/server/schemas/system.d.ts +36 -0
  324. package/dist/server/schemas/system.d.ts.map +1 -0
  325. package/dist/server/schemas/vectors.d.ts +107 -0
  326. package/dist/server/schemas/vectors.d.ts.map +1 -0
  327. package/dist/server/schemas/workflows.d.ts +863 -0
  328. package/dist/server/schemas/workflows.d.ts.map +1 -0
  329. package/dist/server/server-adapter/index.cjs +523 -0
  330. package/dist/server/server-adapter/index.cjs.map +1 -0
  331. package/dist/server/server-adapter/index.d.ts +109 -0
  332. package/dist/server/server-adapter/index.d.ts.map +1 -0
  333. package/dist/server/server-adapter/index.js +495 -0
  334. package/dist/server/server-adapter/index.js.map +1 -0
  335. package/dist/server/server-adapter/openapi-utils.d.ts +59 -0
  336. package/dist/server/server-adapter/openapi-utils.d.ts.map +1 -0
  337. package/dist/server/server-adapter/redact.d.ts +26 -0
  338. package/dist/server/server-adapter/redact.d.ts.map +1 -0
  339. package/dist/server/server-adapter/routes/a2a.d.ts +3 -0
  340. package/dist/server/server-adapter/routes/a2a.d.ts.map +1 -0
  341. package/dist/server/server-adapter/routes/agent-builder.d.ts +3 -0
  342. package/dist/server/server-adapter/routes/agent-builder.d.ts.map +1 -0
  343. package/dist/server/server-adapter/routes/agents.d.ts +3 -0
  344. package/dist/server/server-adapter/routes/agents.d.ts.map +1 -0
  345. package/dist/server/server-adapter/routes/index.d.ts +50 -0
  346. package/dist/server/server-adapter/routes/index.d.ts.map +1 -0
  347. package/dist/server/server-adapter/routes/legacy.d.ts +7 -0
  348. package/dist/server/server-adapter/routes/legacy.d.ts.map +1 -0
  349. package/dist/server/server-adapter/routes/logs.d.ts +3 -0
  350. package/dist/server/server-adapter/routes/logs.d.ts.map +1 -0
  351. package/dist/server/server-adapter/routes/mcp.d.ts +9 -0
  352. package/dist/server/server-adapter/routes/mcp.d.ts.map +1 -0
  353. package/dist/server/server-adapter/routes/memory.d.ts +3 -0
  354. package/dist/server/server-adapter/routes/memory.d.ts.map +1 -0
  355. package/dist/server/server-adapter/routes/observability.d.ts +3 -0
  356. package/dist/server/server-adapter/routes/observability.d.ts.map +1 -0
  357. package/dist/server/server-adapter/routes/processors.d.ts +3 -0
  358. package/dist/server/server-adapter/routes/processors.d.ts.map +1 -0
  359. package/dist/server/server-adapter/routes/route-builder.d.ts +111 -0
  360. package/dist/server/server-adapter/routes/route-builder.d.ts.map +1 -0
  361. package/dist/server/server-adapter/routes/scorers.d.ts +3 -0
  362. package/dist/server/server-adapter/routes/scorers.d.ts.map +1 -0
  363. package/dist/server/server-adapter/routes/stored-agents.d.ts +8 -0
  364. package/dist/server/server-adapter/routes/stored-agents.d.ts.map +1 -0
  365. package/dist/server/server-adapter/routes/stream-types.d.ts +10 -0
  366. package/dist/server/server-adapter/routes/stream-types.d.ts.map +1 -0
  367. package/dist/server/server-adapter/routes/system.d.ts +12 -0
  368. package/dist/server/server-adapter/routes/system.d.ts.map +1 -0
  369. package/dist/server/server-adapter/routes/tools.d.ts +3 -0
  370. package/dist/server/server-adapter/routes/tools.d.ts.map +1 -0
  371. package/dist/server/server-adapter/routes/vectors.d.ts +3 -0
  372. package/dist/server/server-adapter/routes/vectors.d.ts.map +1 -0
  373. package/dist/server/server-adapter/routes/workflows.d.ts +3 -0
  374. package/dist/server/server-adapter/routes/workflows.d.ts.map +1 -0
  375. package/dist/server/types.d.ts +10 -0
  376. package/dist/server/types.d.ts.map +1 -0
  377. package/dist/server/utils.d.ts +45 -0
  378. package/dist/server/utils.d.ts.map +1 -0
  379. package/dist/token-6GSAFR2W-K2BTU23I-5WBYUIGY.cjs +63 -0
  380. package/dist/token-6GSAFR2W-K2BTU23I-5WBYUIGY.cjs.map +1 -0
  381. package/dist/token-6GSAFR2W-K2BTU23I-NW33N3NU.js +61 -0
  382. package/dist/token-6GSAFR2W-K2BTU23I-NW33N3NU.js.map +1 -0
  383. package/dist/token-6GSAFR2W-KVDFAJ2M-EPLMGMHT.cjs +63 -0
  384. package/dist/token-6GSAFR2W-KVDFAJ2M-EPLMGMHT.cjs.map +1 -0
  385. package/dist/token-6GSAFR2W-KVDFAJ2M-VW443KIA.js +61 -0
  386. package/dist/token-6GSAFR2W-KVDFAJ2M-VW443KIA.js.map +1 -0
  387. package/dist/token-6GSAFR2W-VLY2XUPA-NCSASMWN.js +61 -0
  388. package/dist/token-6GSAFR2W-VLY2XUPA-NCSASMWN.js.map +1 -0
  389. package/dist/token-6GSAFR2W-VLY2XUPA-RKITWXKR.cjs +63 -0
  390. package/dist/token-6GSAFR2W-VLY2XUPA-RKITWXKR.cjs.map +1 -0
  391. package/dist/token-util-NEHG7TUY-DJYRKLRD-6TH3ODCN.cjs +10 -0
  392. package/dist/token-util-NEHG7TUY-DJYRKLRD-6TH3ODCN.cjs.map +1 -0
  393. package/dist/token-util-NEHG7TUY-DJYRKLRD-EACKYD4V.js +8 -0
  394. package/dist/token-util-NEHG7TUY-DJYRKLRD-EACKYD4V.js.map +1 -0
  395. package/dist/token-util-NEHG7TUY-KSXDO2NO-J6DEINGO.cjs +10 -0
  396. package/dist/token-util-NEHG7TUY-KSXDO2NO-J6DEINGO.cjs.map +1 -0
  397. package/dist/token-util-NEHG7TUY-KSXDO2NO-WH6I3PH3.js +8 -0
  398. package/dist/token-util-NEHG7TUY-KSXDO2NO-WH6I3PH3.js.map +1 -0
  399. package/dist/token-util-NEHG7TUY-TIJ3LMSH-ANFISSXX.cjs +10 -0
  400. package/dist/token-util-NEHG7TUY-TIJ3LMSH-ANFISSXX.cjs.map +1 -0
  401. package/dist/token-util-NEHG7TUY-TIJ3LMSH-SGVKOKXF.js +8 -0
  402. package/dist/token-util-NEHG7TUY-TIJ3LMSH-SGVKOKXF.js.map +1 -0
  403. package/package.json +72 -20
  404. package/dist/_tsup-dts-rollup.d.cts +0 -573
  405. package/dist/_tsup-dts-rollup.d.ts +0 -573
  406. package/dist/chunk-2FJURXCL.cjs +0 -213
  407. package/dist/chunk-3AHQ5RGN.js +0 -11
  408. package/dist/chunk-3EJZQ6TQ.js +0 -49
  409. package/dist/chunk-3RVHWGWO.js +0 -95
  410. package/dist/chunk-4JINXASC.js +0 -120
  411. package/dist/chunk-67WTHYAV.js +0 -156
  412. package/dist/chunk-A7DF4ETD.cjs +0 -100
  413. package/dist/chunk-B64YROKU.cjs +0 -317
  414. package/dist/chunk-CWSDZEZG.cjs +0 -139
  415. package/dist/chunk-DVPP5S6I.js +0 -135
  416. package/dist/chunk-JLDXUWK7.cjs +0 -126
  417. package/dist/chunk-L7XE5QTW.js +0 -16
  418. package/dist/chunk-M56ECCHK.cjs +0 -128
  419. package/dist/chunk-OPP7H5TW.js +0 -305
  420. package/dist/chunk-PDC4ZBQW.cjs +0 -126
  421. package/dist/chunk-QH6XWSXP.cjs +0 -5579
  422. package/dist/chunk-QN4KF3BH.cjs +0 -18
  423. package/dist/chunk-RBQASTUP.js +0 -203
  424. package/dist/chunk-SKBVVI24.cjs +0 -54
  425. package/dist/chunk-UV4WTEH4.js +0 -120
  426. package/dist/chunk-VK6FX47H.js +0 -5576
  427. package/dist/chunk-YANVFOYA.js +0 -120
  428. package/dist/chunk-Z46X3YCB.cjs +0 -164
  429. package/dist/chunk-ZLBRQFDD.cjs +0 -13
  430. package/dist/index.d.cts +0 -1
  431. package/dist/server/handlers/agents.d.cts +0 -6
  432. package/dist/server/handlers/error.d.cts +0 -1
  433. package/dist/server/handlers/logs.d.cts +0 -3
  434. package/dist/server/handlers/memory.d.cts +0 -8
  435. package/dist/server/handlers/network.cjs +0 -22
  436. package/dist/server/handlers/network.d.cts +0 -4
  437. package/dist/server/handlers/network.d.ts +0 -4
  438. package/dist/server/handlers/network.js +0 -1
  439. package/dist/server/handlers/telemetry.cjs +0 -14
  440. package/dist/server/handlers/telemetry.d.cts +0 -2
  441. package/dist/server/handlers/telemetry.d.ts +0 -2
  442. package/dist/server/handlers/telemetry.js +0 -1
  443. package/dist/server/handlers/tools.d.cts +0 -4
  444. package/dist/server/handlers/utils.d.cts +0 -1
  445. package/dist/server/handlers/vector.d.cts +0 -6
  446. package/dist/server/handlers/voice.d.cts +0 -3
  447. package/dist/server/handlers/workflows.d.cts +0 -10
  448. package/dist/server/handlers.d.cts +0 -9
@@ -0,0 +1,1030 @@
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-WLGJVDH4.js';
3
+ import { stringify } from './chunk-LF2ZLOFP.js';
4
+ import { createRoute } from './chunk-7S7ALPCY.js';
5
+ import { handleError } from './chunk-ONN5EA7E.js';
6
+ import { HTTPException } from './chunk-6QWQZI4Q.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
+ };
202
+ }
203
+ async function getAgentFromSystem({ mastra, agentId }) {
204
+ const logger = mastra.getLogger();
205
+ if (!agentId) {
206
+ throw new HTTPException(400, { message: "Agent ID is required" });
207
+ }
208
+ let agent;
209
+ try {
210
+ agent = mastra.getAgentById(agentId);
211
+ } catch (error) {
212
+ logger.debug("Error getting agent from mastra, searching agents for agent", error);
213
+ }
214
+ if (!agent) {
215
+ logger.debug(`Agent ${agentId} not found, looking through sub-agents`);
216
+ const agents = mastra.listAgents();
217
+ if (Object.keys(agents || {}).length) {
218
+ for (const [_, ag] of Object.entries(agents)) {
219
+ try {
220
+ const subAgents = await ag.listAgents();
221
+ if (subAgents[agentId]) {
222
+ agent = subAgents[agentId];
223
+ break;
224
+ }
225
+ } catch (error) {
226
+ logger.debug("Error getting agent from agent", error);
227
+ }
228
+ }
229
+ }
230
+ }
231
+ if (!agent) {
232
+ throw new HTTPException(404, { message: `Agent with id ${agentId} not found` });
233
+ }
234
+ return agent;
235
+ }
236
+ async function formatAgent({
237
+ mastra,
238
+ agent,
239
+ requestContext,
240
+ isStudio
241
+ }) {
242
+ const description = agent.getDescription();
243
+ const tools = await agent.listTools({ requestContext });
244
+ const serializedAgentTools = await getSerializedAgentTools(tools);
245
+ let serializedAgentWorkflows = {};
246
+ if ("listWorkflows" in agent) {
247
+ const logger = mastra.getLogger();
248
+ try {
249
+ const workflows = await agent.listWorkflows({ requestContext });
250
+ serializedAgentWorkflows = Object.entries(workflows || {}).reduce((acc, [key, workflow]) => {
251
+ return {
252
+ ...acc,
253
+ [key]: {
254
+ name: workflow.name || "Unnamed workflow",
255
+ steps: Object.entries(workflow.steps).reduce(
256
+ (acc2, [key2, step]) => {
257
+ return {
258
+ ...acc2,
259
+ [key2]: {
260
+ id: step.id,
261
+ description: step.description
262
+ }
263
+ };
264
+ },
265
+ {}
266
+ )
267
+ }
268
+ };
269
+ }, {});
270
+ } catch (error) {
271
+ logger.error("Error getting workflows for agent", { agentName: agent.name, error });
272
+ }
273
+ }
274
+ let proxyRequestContext = requestContext;
275
+ const instructions = await agent.getInstructions({ requestContext: proxyRequestContext });
276
+ const llm = await agent.getLLM({ requestContext });
277
+ const defaultGenerateOptionsLegacy = await agent.getDefaultGenerateOptionsLegacy({
278
+ requestContext: proxyRequestContext
279
+ });
280
+ const defaultStreamOptionsLegacy = await agent.getDefaultStreamOptionsLegacy({ requestContext: proxyRequestContext });
281
+ const defaultOptions = await agent.getDefaultOptions({ requestContext: proxyRequestContext });
282
+ const model = llm?.getModel();
283
+ const models = await agent.getModelList(requestContext);
284
+ const modelList = models?.map((md) => ({
285
+ ...md,
286
+ model: {
287
+ modelId: md.model.modelId,
288
+ provider: md.model.provider,
289
+ modelVersion: md.model.specificationVersion
290
+ }
291
+ }));
292
+ const serializedAgentAgents = await getSerializedAgentDefinition({ agent, requestContext: proxyRequestContext });
293
+ let serializedInputProcessors = [];
294
+ let serializedOutputProcessors = [];
295
+ try {
296
+ const configuredProcessorWorkflows = await agent.getConfiguredProcessorWorkflows();
297
+ const inputProcessorWorkflows = configuredProcessorWorkflows.filter((w) => w.id.endsWith("-input-processor"));
298
+ const outputProcessorWorkflows = configuredProcessorWorkflows.filter((w) => w.id.endsWith("-output-processor"));
299
+ serializedInputProcessors = getSerializedProcessors(inputProcessorWorkflows);
300
+ serializedOutputProcessors = getSerializedProcessors(outputProcessorWorkflows);
301
+ } catch (error) {
302
+ mastra.getLogger().error("Error getting configured processors for agent", { agentName: agent.name, error });
303
+ }
304
+ return {
305
+ name: agent.name,
306
+ description,
307
+ instructions,
308
+ tools: serializedAgentTools,
309
+ agents: serializedAgentAgents,
310
+ workflows: serializedAgentWorkflows,
311
+ inputProcessors: serializedInputProcessors,
312
+ outputProcessors: serializedOutputProcessors,
313
+ provider: llm?.getProvider(),
314
+ modelId: llm?.getModelId(),
315
+ modelVersion: model?.specificationVersion,
316
+ modelList,
317
+ defaultOptions,
318
+ defaultGenerateOptionsLegacy,
319
+ defaultStreamOptionsLegacy
320
+ };
321
+ }
322
+ var LIST_AGENTS_ROUTE = createRoute({
323
+ method: "GET",
324
+ path: "/api/agents",
325
+ responseType: "json",
326
+ queryParamSchema: z.object({
327
+ partial: z.string().optional()
328
+ }),
329
+ responseSchema: listAgentsResponseSchema,
330
+ summary: "List all agents",
331
+ description: "Returns a list of all available agents in the system",
332
+ tags: ["Agents"],
333
+ handler: async ({ mastra, requestContext, partial }) => {
334
+ try {
335
+ const agents = mastra.listAgents();
336
+ const isPartial = partial === "true";
337
+ const serializedAgentsMap = await Promise.all(
338
+ Object.entries(agents).map(async ([id, agent]) => {
339
+ return formatAgentList({ id, mastra, agent, requestContext, partial: isPartial });
340
+ })
341
+ );
342
+ const serializedAgents = serializedAgentsMap.reduce(
343
+ (acc, { id, ...rest }) => {
344
+ acc[id] = { id, ...rest };
345
+ return acc;
346
+ },
347
+ {}
348
+ );
349
+ return serializedAgents;
350
+ } catch (error) {
351
+ return handleError(error, "Error getting agents");
352
+ }
353
+ }
354
+ });
355
+ var GET_AGENT_BY_ID_ROUTE = createRoute({
356
+ method: "GET",
357
+ path: "/api/agents/:agentId",
358
+ responseType: "json",
359
+ pathParamSchema: agentIdPathParams,
360
+ responseSchema: serializedAgentSchema,
361
+ summary: "Get agent by ID",
362
+ description: "Returns details for a specific agent including configuration, tools, and memory settings",
363
+ tags: ["Agents"],
364
+ handler: async ({ agentId, mastra, requestContext }) => {
365
+ try {
366
+ const agent = await getAgentFromSystem({ mastra, agentId });
367
+ const isStudio = false;
368
+ const result = await formatAgent({
369
+ mastra,
370
+ agent,
371
+ requestContext,
372
+ isStudio
373
+ });
374
+ return result;
375
+ } catch (error) {
376
+ return handleError(error, "Error getting agent");
377
+ }
378
+ }
379
+ });
380
+ var GENERATE_AGENT_ROUTE = createRoute({
381
+ method: "POST",
382
+ path: "/api/agents/:agentId/generate",
383
+ responseType: "json",
384
+ pathParamSchema: agentIdPathParams,
385
+ bodySchema: agentExecutionBodySchema,
386
+ responseSchema: generateResponseSchema,
387
+ summary: "Generate agent response",
388
+ description: "Executes an agent with the provided messages and returns the complete response",
389
+ tags: ["Agents"],
390
+ handler: async ({ agentId, mastra, abortSignal, ...params }) => {
391
+ try {
392
+ const agent = await getAgentFromSystem({ mastra, agentId });
393
+ sanitizeBody(params, ["tools"]);
394
+ const { messages, ...rest } = params;
395
+ validateBody({ messages });
396
+ const result = await agent.generate(messages, {
397
+ ...rest,
398
+ abortSignal
399
+ });
400
+ return result;
401
+ } catch (error) {
402
+ return handleError(error, "Error generating from agent");
403
+ }
404
+ }
405
+ });
406
+ var GENERATE_LEGACY_ROUTE = createRoute({
407
+ method: "POST",
408
+ path: "/api/agents/:agentId/generate-legacy",
409
+ responseType: "json",
410
+ pathParamSchema: agentIdPathParams,
411
+ bodySchema: agentExecutionLegacyBodySchema,
412
+ responseSchema: generateResponseSchema,
413
+ summary: "[DEPRECATED] Generate with legacy format",
414
+ description: "Legacy endpoint for generating agent responses. Use /api/agents/:agentId/generate instead.",
415
+ tags: ["Agents", "Legacy"],
416
+ handler: async ({ mastra, agentId, abortSignal, ...params }) => {
417
+ try {
418
+ const agent = await getAgentFromSystem({ mastra, agentId });
419
+ sanitizeBody(params, ["tools"]);
420
+ const { messages, resourceId, resourceid, threadId, ...rest } = params;
421
+ const finalResourceId = resourceId ?? resourceid;
422
+ validateBody({ messages });
423
+ if (threadId && !finalResourceId || !threadId && finalResourceId) {
424
+ throw new HTTPException(400, { message: "Both threadId or resourceId must be provided" });
425
+ }
426
+ const result = await agent.generateLegacy(messages, {
427
+ ...rest,
428
+ abortSignal,
429
+ resourceId: finalResourceId ?? "",
430
+ threadId: threadId ?? ""
431
+ });
432
+ return result;
433
+ } catch (error) {
434
+ return handleError(error, "Error generating from agent");
435
+ }
436
+ }
437
+ });
438
+ var STREAM_GENERATE_LEGACY_ROUTE = createRoute({
439
+ method: "POST",
440
+ path: "/api/agents/:agentId/stream-legacy",
441
+ responseType: "datastream-response",
442
+ pathParamSchema: agentIdPathParams,
443
+ bodySchema: agentExecutionLegacyBodySchema,
444
+ responseSchema: streamResponseSchema,
445
+ summary: "[DEPRECATED] Stream with legacy format",
446
+ description: "Legacy endpoint for streaming agent responses. Use /api/agents/:agentId/stream instead.",
447
+ tags: ["Agents", "Legacy"],
448
+ handler: async ({ mastra, agentId, abortSignal, ...params }) => {
449
+ try {
450
+ const agent = await getAgentFromSystem({ mastra, agentId });
451
+ sanitizeBody(params, ["tools"]);
452
+ const { messages, resourceId, resourceid, threadId, ...rest } = params;
453
+ const finalResourceId = resourceId ?? resourceid;
454
+ validateBody({ messages });
455
+ if (threadId && !finalResourceId || !threadId && finalResourceId) {
456
+ throw new HTTPException(400, { message: "Both threadId or resourceId must be provided" });
457
+ }
458
+ const streamResult = await agent.streamLegacy(messages, {
459
+ ...rest,
460
+ abortSignal,
461
+ resourceId: finalResourceId ?? "",
462
+ threadId: threadId ?? ""
463
+ });
464
+ const streamResponse = rest.output ? streamResult.toTextStreamResponse({
465
+ headers: {
466
+ "Transfer-Encoding": "chunked"
467
+ }
468
+ }) : streamResult.toDataStreamResponse({
469
+ sendUsage: true,
470
+ sendReasoning: true,
471
+ getErrorMessage: (error) => {
472
+ return `An error occurred while processing your request. ${error instanceof Error ? error.message : JSON.stringify(error)}`;
473
+ },
474
+ headers: {
475
+ "Transfer-Encoding": "chunked"
476
+ }
477
+ });
478
+ return streamResponse;
479
+ } catch (error) {
480
+ return handleError(error, "error streaming agent response");
481
+ }
482
+ }
483
+ });
484
+ var GET_PROVIDERS_ROUTE = createRoute({
485
+ method: "GET",
486
+ path: "/api/agents/providers",
487
+ responseType: "json",
488
+ responseSchema: providersResponseSchema,
489
+ summary: "List AI providers",
490
+ description: "Returns a list of all configured AI model providers",
491
+ tags: ["Agents"],
492
+ handler: async () => {
493
+ try {
494
+ const providers = Object.entries(PROVIDER_REGISTRY).map(([id, provider]) => {
495
+ return {
496
+ id,
497
+ name: provider.name,
498
+ label: provider.label || provider.name,
499
+ description: provider.description || "",
500
+ envVar: provider.apiKeyEnvVar,
501
+ connected: isProviderConnected(id),
502
+ docUrl: provider.docUrl,
503
+ models: [...provider.models]
504
+ // Convert readonly array to regular array
505
+ };
506
+ });
507
+ return { providers };
508
+ } catch (error) {
509
+ return handleError(error, "Error fetching providers");
510
+ }
511
+ }
512
+ });
513
+ var GENERATE_AGENT_VNEXT_ROUTE = createRoute({
514
+ method: "POST",
515
+ path: "/api/agents/:agentId/generate/vnext",
516
+ responseType: "json",
517
+ pathParamSchema: agentIdPathParams,
518
+ bodySchema: agentExecutionBodySchema,
519
+ responseSchema: generateResponseSchema,
520
+ summary: "Generate a response from an agent",
521
+ description: "Generate a response from an agent",
522
+ tags: ["Agents"],
523
+ handler: GENERATE_AGENT_ROUTE.handler
524
+ });
525
+ var STREAM_GENERATE_ROUTE = createRoute({
526
+ method: "POST",
527
+ path: "/api/agents/:agentId/stream",
528
+ responseType: "stream",
529
+ streamFormat: "sse",
530
+ pathParamSchema: agentIdPathParams,
531
+ bodySchema: agentExecutionBodySchema,
532
+ responseSchema: streamResponseSchema,
533
+ summary: "Stream agent response",
534
+ description: "Executes an agent with the provided messages and streams the response in real-time",
535
+ tags: ["Agents"],
536
+ handler: async ({ mastra, agentId, abortSignal, ...params }) => {
537
+ try {
538
+ const agent = await getAgentFromSystem({ mastra, agentId });
539
+ sanitizeBody(params, ["tools"]);
540
+ const { messages, ...rest } = params;
541
+ validateBody({ messages });
542
+ const streamResult = await agent.stream(messages, {
543
+ ...rest,
544
+ abortSignal
545
+ });
546
+ return streamResult.fullStream;
547
+ } catch (error) {
548
+ return handleError(error, "error streaming agent response");
549
+ }
550
+ }
551
+ });
552
+ var STREAM_GENERATE_VNEXT_DEPRECATED_ROUTE = createRoute({
553
+ method: "POST",
554
+ path: "/api/agents/:agentId/stream/vnext",
555
+ responseType: "stream",
556
+ pathParamSchema: agentIdPathParams,
557
+ bodySchema: agentExecutionBodySchema,
558
+ responseSchema: streamResponseSchema,
559
+ summary: "Stream a response from an agent",
560
+ description: "[DEPRECATED] This endpoint is deprecated. Please use /stream instead.",
561
+ tags: ["Agents"],
562
+ deprecated: true,
563
+ handler: STREAM_GENERATE_ROUTE.handler
564
+ });
565
+ var APPROVE_TOOL_CALL_ROUTE = createRoute({
566
+ method: "POST",
567
+ path: "/api/agents/:agentId/approve-tool-call",
568
+ responseType: "stream",
569
+ streamFormat: "sse",
570
+ pathParamSchema: agentIdPathParams,
571
+ bodySchema: approveToolCallBodySchema,
572
+ responseSchema: toolCallResponseSchema,
573
+ summary: "Approve tool call",
574
+ description: "Approves a pending tool call and continues agent execution",
575
+ tags: ["Agents", "Tools"],
576
+ handler: async ({ mastra, agentId, abortSignal, ...params }) => {
577
+ try {
578
+ const agent = await getAgentFromSystem({ mastra, agentId });
579
+ if (!params.runId) {
580
+ throw new HTTPException(400, { message: "Run id is required" });
581
+ }
582
+ if (!params.toolCallId) {
583
+ throw new HTTPException(400, { message: "Tool call id is required" });
584
+ }
585
+ sanitizeBody(params, ["tools"]);
586
+ const streamResult = await agent.approveToolCall({
587
+ ...params,
588
+ abortSignal
589
+ });
590
+ return streamResult.fullStream;
591
+ } catch (error) {
592
+ return handleError(error, "error approving tool call");
593
+ }
594
+ }
595
+ });
596
+ var DECLINE_TOOL_CALL_ROUTE = createRoute({
597
+ method: "POST",
598
+ path: "/api/agents/:agentId/decline-tool-call",
599
+ responseType: "stream",
600
+ streamFormat: "sse",
601
+ pathParamSchema: agentIdPathParams,
602
+ bodySchema: declineToolCallBodySchema,
603
+ responseSchema: toolCallResponseSchema,
604
+ summary: "Decline tool call",
605
+ description: "Declines a pending tool call and continues agent execution without executing the tool",
606
+ tags: ["Agents", "Tools"],
607
+ handler: async ({ mastra, agentId, abortSignal, ...params }) => {
608
+ try {
609
+ const agent = await getAgentFromSystem({ mastra, agentId });
610
+ if (!params.runId) {
611
+ throw new HTTPException(400, { message: "Run id is required" });
612
+ }
613
+ if (!params.toolCallId) {
614
+ throw new HTTPException(400, { message: "Tool call id is required" });
615
+ }
616
+ sanitizeBody(params, ["tools"]);
617
+ const streamResult = await agent.declineToolCall({
618
+ ...params,
619
+ abortSignal
620
+ });
621
+ return streamResult.fullStream;
622
+ } catch (error) {
623
+ return handleError(error, "error declining tool call");
624
+ }
625
+ }
626
+ });
627
+ var APPROVE_TOOL_CALL_GENERATE_ROUTE = createRoute({
628
+ method: "POST",
629
+ path: "/api/agents/:agentId/approve-tool-call-generate",
630
+ responseType: "json",
631
+ pathParamSchema: agentIdPathParams,
632
+ bodySchema: approveToolCallBodySchema,
633
+ responseSchema: generateResponseSchema,
634
+ summary: "Approve tool call (non-streaming)",
635
+ description: "Approves a pending tool call and returns the complete response",
636
+ tags: ["Agents", "Tools"],
637
+ handler: async ({ mastra, agentId, abortSignal, ...params }) => {
638
+ try {
639
+ const agent = await getAgentFromSystem({ mastra, agentId });
640
+ if (!params.runId) {
641
+ throw new HTTPException(400, { message: "Run id is required" });
642
+ }
643
+ if (!params.toolCallId) {
644
+ throw new HTTPException(400, { message: "Tool call id is required" });
645
+ }
646
+ sanitizeBody(params, ["tools"]);
647
+ const result = await agent.approveToolCallGenerate({
648
+ ...params,
649
+ abortSignal
650
+ });
651
+ return result;
652
+ } catch (error) {
653
+ return handleError(error, "error approving tool call");
654
+ }
655
+ }
656
+ });
657
+ var DECLINE_TOOL_CALL_GENERATE_ROUTE = createRoute({
658
+ method: "POST",
659
+ path: "/api/agents/:agentId/decline-tool-call-generate",
660
+ responseType: "json",
661
+ pathParamSchema: agentIdPathParams,
662
+ bodySchema: declineToolCallBodySchema,
663
+ responseSchema: generateResponseSchema,
664
+ summary: "Decline tool call (non-streaming)",
665
+ description: "Declines a pending tool call and returns the complete response",
666
+ tags: ["Agents", "Tools"],
667
+ handler: async ({ mastra, agentId, abortSignal, ...params }) => {
668
+ try {
669
+ const agent = await getAgentFromSystem({ mastra, agentId });
670
+ if (!params.runId) {
671
+ throw new HTTPException(400, { message: "Run id is required" });
672
+ }
673
+ if (!params.toolCallId) {
674
+ throw new HTTPException(400, { message: "Tool call id is required" });
675
+ }
676
+ sanitizeBody(params, ["tools"]);
677
+ const result = await agent.declineToolCallGenerate({
678
+ ...params,
679
+ abortSignal
680
+ });
681
+ return result;
682
+ } catch (error) {
683
+ return handleError(error, "error declining tool call");
684
+ }
685
+ }
686
+ });
687
+ var STREAM_NETWORK_ROUTE = createRoute({
688
+ method: "POST",
689
+ path: "/api/agents/:agentId/network",
690
+ responseType: "stream",
691
+ streamFormat: "sse",
692
+ pathParamSchema: agentIdPathParams,
693
+ bodySchema: agentExecutionBodySchema,
694
+ responseSchema: streamResponseSchema,
695
+ summary: "Stream agent network",
696
+ description: "Executes an agent network with multiple agents and streams the response",
697
+ tags: ["Agents"],
698
+ handler: async ({ mastra, messages, agentId, ...params }) => {
699
+ try {
700
+ const agent = await getAgentFromSystem({ mastra, agentId });
701
+ sanitizeBody(params, ["tools"]);
702
+ validateBody({ messages });
703
+ const streamResult = await agent.network(messages, {
704
+ ...params
705
+ });
706
+ return streamResult;
707
+ } catch (error) {
708
+ return handleError(error, "error streaming agent loop response");
709
+ }
710
+ }
711
+ });
712
+ var APPROVE_NETWORK_TOOL_CALL_ROUTE = createRoute({
713
+ method: "POST",
714
+ path: "/api/agents/:agentId/approve-network-tool-call",
715
+ responseType: "stream",
716
+ streamFormat: "sse",
717
+ pathParamSchema: agentIdPathParams,
718
+ bodySchema: approveNetworkToolCallBodySchema,
719
+ responseSchema: streamResponseSchema,
720
+ summary: "Approve network tool call",
721
+ description: "Approves a pending network tool call and continues network agent execution",
722
+ tags: ["Agents", "Tools"],
723
+ handler: async ({ mastra, agentId, ...params }) => {
724
+ try {
725
+ const agent = await getAgentFromSystem({ mastra, agentId });
726
+ if (!params.runId) {
727
+ throw new HTTPException(400, { message: "Run id is required" });
728
+ }
729
+ sanitizeBody(params, ["tools"]);
730
+ const streamResult = await agent.approveNetworkToolCall({
731
+ ...params
732
+ });
733
+ return streamResult;
734
+ } catch (error) {
735
+ return handleError(error, "error approving network tool call");
736
+ }
737
+ }
738
+ });
739
+ var DECLINE_NETWORK_TOOL_CALL_ROUTE = createRoute({
740
+ method: "POST",
741
+ path: "/api/agents/:agentId/decline-network-tool-call",
742
+ responseType: "stream",
743
+ streamFormat: "sse",
744
+ pathParamSchema: agentIdPathParams,
745
+ bodySchema: declineNetworkToolCallBodySchema,
746
+ responseSchema: streamResponseSchema,
747
+ summary: "Decline network tool call",
748
+ description: "Declines a pending network tool call and continues network agent execution without executing the tool",
749
+ tags: ["Agents", "Tools"],
750
+ handler: async ({ mastra, agentId, ...params }) => {
751
+ try {
752
+ const agent = await getAgentFromSystem({ mastra, agentId });
753
+ if (!params.runId) {
754
+ throw new HTTPException(400, { message: "Run id is required" });
755
+ }
756
+ sanitizeBody(params, ["tools"]);
757
+ const streamResult = await agent.declineNetworkToolCall({
758
+ ...params
759
+ });
760
+ return streamResult;
761
+ } catch (error) {
762
+ return handleError(error, "error declining network tool call");
763
+ }
764
+ }
765
+ });
766
+ var UPDATE_AGENT_MODEL_ROUTE = createRoute({
767
+ method: "POST",
768
+ path: "/api/agents/:agentId/model",
769
+ responseType: "json",
770
+ pathParamSchema: agentIdPathParams,
771
+ bodySchema: updateAgentModelBodySchema,
772
+ responseSchema: modelManagementResponseSchema,
773
+ summary: "Update agent model",
774
+ description: "Updates the AI model used by the agent",
775
+ tags: ["Agents", "Models"],
776
+ handler: async ({ mastra, agentId, modelId, provider }) => {
777
+ try {
778
+ const agent = await getAgentFromSystem({ mastra, agentId });
779
+ const newModel = `${provider}/${modelId}`;
780
+ agent.__updateModel({ model: newModel });
781
+ return { message: "Agent model updated" };
782
+ } catch (error) {
783
+ return handleError(error, "error updating agent model");
784
+ }
785
+ }
786
+ });
787
+ var RESET_AGENT_MODEL_ROUTE = createRoute({
788
+ method: "POST",
789
+ path: "/api/agents/:agentId/model/reset",
790
+ responseType: "json",
791
+ pathParamSchema: agentIdPathParams,
792
+ responseSchema: modelManagementResponseSchema,
793
+ summary: "Reset agent model",
794
+ description: "Resets the agent model to its original configuration",
795
+ tags: ["Agents", "Models"],
796
+ handler: async ({ mastra, agentId }) => {
797
+ try {
798
+ const agent = await getAgentFromSystem({ mastra, agentId });
799
+ agent.__resetToOriginalModel();
800
+ return { message: "Agent model reset to original" };
801
+ } catch (error) {
802
+ return handleError(error, "error resetting agent model");
803
+ }
804
+ }
805
+ });
806
+ var REORDER_AGENT_MODEL_LIST_ROUTE = createRoute({
807
+ method: "POST",
808
+ path: "/api/agents/:agentId/models/reorder",
809
+ responseType: "json",
810
+ pathParamSchema: agentIdPathParams,
811
+ bodySchema: reorderAgentModelListBodySchema,
812
+ responseSchema: modelManagementResponseSchema,
813
+ summary: "Reorder agent model list",
814
+ description: "Reorders the model list for agents with multiple model configurations",
815
+ tags: ["Agents", "Models"],
816
+ handler: async ({ mastra, agentId, reorderedModelIds }) => {
817
+ try {
818
+ const agent = await getAgentFromSystem({ mastra, agentId });
819
+ const modelList = await agent.getModelList();
820
+ if (!modelList || modelList.length === 0) {
821
+ throw new HTTPException(400, { message: "Agent model list is not found or empty" });
822
+ }
823
+ agent.reorderModels(reorderedModelIds);
824
+ return { message: "Model list reordered" };
825
+ } catch (error) {
826
+ return handleError(error, "error reordering model list");
827
+ }
828
+ }
829
+ });
830
+ var UPDATE_AGENT_MODEL_IN_MODEL_LIST_ROUTE = createRoute({
831
+ method: "POST",
832
+ path: "/api/agents/:agentId/models/:modelConfigId",
833
+ responseType: "json",
834
+ pathParamSchema: modelConfigIdPathParams,
835
+ bodySchema: updateAgentModelInModelListBodySchema,
836
+ responseSchema: modelManagementResponseSchema,
837
+ summary: "Update model in model list",
838
+ description: "Updates a specific model configuration in the agent model list",
839
+ tags: ["Agents", "Models"],
840
+ handler: async ({ mastra, agentId, modelConfigId, model: bodyModel, maxRetries, enabled }) => {
841
+ try {
842
+ const agent = await getAgentFromSystem({ mastra, agentId });
843
+ const modelList = await agent.getModelList();
844
+ if (!modelList || modelList.length === 0) {
845
+ throw new HTTPException(400, { message: "Agent model list is not found or empty" });
846
+ }
847
+ const modelConfig = modelList.find((config) => config.id === modelConfigId);
848
+ if (!modelConfig) {
849
+ throw new HTTPException(404, { message: `Model config with id ${modelConfigId} not found` });
850
+ }
851
+ const newModel = bodyModel?.modelId && bodyModel?.provider ? `${bodyModel.provider}/${bodyModel.modelId}` : modelConfig.model;
852
+ const updated = {
853
+ ...modelConfig,
854
+ model: newModel,
855
+ ...maxRetries !== void 0 ? { maxRetries } : {},
856
+ ...enabled !== void 0 ? { enabled } : {}
857
+ };
858
+ agent.updateModelInModelList(updated);
859
+ return { message: "Model updated in model list" };
860
+ } catch (error) {
861
+ return handleError(error, "error updating model in model list");
862
+ }
863
+ }
864
+ });
865
+ 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.
866
+
867
+ Follow these steps to analyze and enhance the instructions:
868
+
869
+ 1. ANALYSIS PHASE
870
+ - Identify the core purpose and goals
871
+ - Extract key constraints and requirements
872
+ - Recognize domain-specific terminology and concepts
873
+ - Note any implicit assumptions that should be made explicit
874
+
875
+ 2. PROMPT STRUCTURE
876
+ Create a system prompt with these components:
877
+ a) ROLE DEFINITION
878
+ - Clear statement of the AI's role and purpose
879
+ - Key responsibilities and scope
880
+ - Primary stakeholders and users
881
+ b) CORE CAPABILITIES
882
+ - Main functions and abilities
883
+ - Specific domain knowledge required
884
+ - Tools and resources available
885
+ c) BEHAVIORAL GUIDELINES
886
+ - Communication style and tone
887
+ - Decision-making framework
888
+ - Error handling approach
889
+ - Ethical considerations
890
+ d) CONSTRAINTS & BOUNDARIES
891
+ - Explicit limitations
892
+ - Out-of-scope activities
893
+ - Security and privacy considerations
894
+ e) SUCCESS CRITERIA
895
+ - Quality standards
896
+ - Expected outcomes
897
+ - Performance metrics
898
+
899
+ 3. QUALITY CHECKS
900
+ Ensure the prompt is:
901
+ - Clear and unambiguous
902
+ - Comprehensive yet concise
903
+ - Properly scoped
904
+ - Technically accurate
905
+ - Ethically sound
906
+
907
+ 4. OUTPUT FORMAT
908
+ Return a structured response with:
909
+ - Enhanced system prompt
910
+ - Analysis of key components
911
+ - Identified goals and constraints
912
+ - Core domain concepts
913
+
914
+ 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.`;
915
+ async function findConnectedModel(agent) {
916
+ const modelList = await agent.getModelList();
917
+ if (modelList && modelList.length > 0) {
918
+ for (const modelConfig of modelList) {
919
+ if (modelConfig.enabled !== false) {
920
+ const model = modelConfig.model;
921
+ if (isProviderConnected(model.provider)) {
922
+ return model;
923
+ }
924
+ }
925
+ }
926
+ return null;
927
+ }
928
+ const defaultModel = await agent.getModel();
929
+ if (isProviderConnected(defaultModel.provider)) {
930
+ return defaultModel;
931
+ }
932
+ return null;
933
+ }
934
+ var ENHANCE_INSTRUCTIONS_ROUTE = createRoute({
935
+ method: "POST",
936
+ path: "/api/agents/:agentId/instructions/enhance",
937
+ responseType: "json",
938
+ pathParamSchema: agentIdPathParams,
939
+ bodySchema: enhanceInstructionsBodySchema,
940
+ responseSchema: enhanceInstructionsResponseSchema,
941
+ summary: "Enhance agent instructions",
942
+ description: "Uses AI to enhance or modify agent instructions based on user feedback",
943
+ tags: ["Agents"],
944
+ handler: async ({ mastra, agentId, instructions, comment }) => {
945
+ try {
946
+ const agent = await getAgentFromSystem({ mastra, agentId });
947
+ const model = await findConnectedModel(agent);
948
+ if (!model) {
949
+ throw new HTTPException(400, {
950
+ message: "No model with a configured API key found. Please set the required environment variable for your model provider."
951
+ });
952
+ }
953
+ const systemPromptAgent = new Agent({
954
+ id: "system-prompt-enhancer",
955
+ name: "system-prompt-enhancer",
956
+ instructions: ENHANCE_SYSTEM_PROMPT_INSTRUCTIONS,
957
+ model
958
+ });
959
+ const result = await systemPromptAgent.generate(
960
+ `We need to improve the system prompt.
961
+ Current: ${instructions}
962
+ ${comment ? `User feedback: ${comment}` : ""}`,
963
+ {
964
+ structuredOutput: {
965
+ schema: enhanceInstructionsResponseSchema
966
+ }
967
+ }
968
+ );
969
+ return await result.object;
970
+ } catch (error) {
971
+ return handleError(error, "Error enhancing instructions");
972
+ }
973
+ }
974
+ });
975
+ var STREAM_VNEXT_DEPRECATED_ROUTE = createRoute({
976
+ method: "POST",
977
+ path: "/api/agents/:agentId/streamVNext",
978
+ responseType: "stream",
979
+ pathParamSchema: agentIdPathParams,
980
+ bodySchema: agentExecutionBodySchema,
981
+ responseSchema: streamResponseSchema,
982
+ summary: "Stream a response from an agent",
983
+ description: "[DEPRECATED] This endpoint is deprecated. Please use /stream instead.",
984
+ tags: ["Agents"],
985
+ deprecated: true,
986
+ handler: async () => {
987
+ throw new HTTPException(410, { message: "This endpoint is deprecated. Please use /stream instead." });
988
+ }
989
+ });
990
+ var STREAM_UI_MESSAGE_VNEXT_DEPRECATED_ROUTE = createRoute({
991
+ method: "POST",
992
+ path: "/api/agents/:agentId/stream/vnext/ui",
993
+ responseType: "stream",
994
+ pathParamSchema: agentIdPathParams,
995
+ bodySchema: agentExecutionBodySchema,
996
+ responseSchema: streamResponseSchema,
997
+ summary: "Stream UI messages from an agent",
998
+ description: "[DEPRECATED] This endpoint is deprecated. Please use the @mastra/ai-sdk package for uiMessage transformations",
999
+ tags: ["Agents"],
1000
+ deprecated: true,
1001
+ handler: async () => {
1002
+ try {
1003
+ throw new MastraError({
1004
+ category: ErrorCategory.USER,
1005
+ domain: ErrorDomain.MASTRA_SERVER,
1006
+ id: "DEPRECATED_ENDPOINT",
1007
+ text: "This endpoint is deprecated. Please use the @mastra/ai-sdk package to for uiMessage transformations"
1008
+ });
1009
+ } catch (error) {
1010
+ return handleError(error, "error streaming agent response");
1011
+ }
1012
+ }
1013
+ });
1014
+ var STREAM_UI_MESSAGE_DEPRECATED_ROUTE = createRoute({
1015
+ method: "POST",
1016
+ path: "/api/agents/:agentId/stream/ui",
1017
+ responseType: "stream",
1018
+ pathParamSchema: agentIdPathParams,
1019
+ bodySchema: agentExecutionBodySchema,
1020
+ responseSchema: streamResponseSchema,
1021
+ summary: "Stream UI messages from an agent",
1022
+ description: "[DEPRECATED] This endpoint is deprecated. Please use the @mastra/ai-sdk package for uiMessage transformations",
1023
+ tags: ["Agents"],
1024
+ deprecated: true,
1025
+ handler: STREAM_UI_MESSAGE_VNEXT_DEPRECATED_ROUTE.handler
1026
+ });
1027
+
1028
+ 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 };
1029
+ //# sourceMappingURL=chunk-2CLS2PYJ.js.map
1030
+ //# sourceMappingURL=chunk-2CLS2PYJ.js.map