@mastra/server 0.0.0-feat-support-ai-sdk-5-again-20250813225910 → 0.0.0-feat-improve-processors-20251205191721

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 (374) hide show
  1. package/CHANGELOG.md +4963 -0
  2. package/README.md +1 -6
  3. package/dist/chunk-2NW6POYK.cjs +89 -0
  4. package/dist/chunk-2NW6POYK.cjs.map +1 -0
  5. package/dist/{chunk-25LDKW7R.js → chunk-2PB6VJQX.js} +225 -36
  6. package/dist/chunk-2PB6VJQX.js.map +1 -0
  7. package/dist/chunk-2PLXW4ZX.cjs +2777 -0
  8. package/dist/chunk-2PLXW4ZX.cjs.map +1 -0
  9. package/dist/chunk-4W2SM6CG.js +294 -0
  10. package/dist/chunk-4W2SM6CG.js.map +1 -0
  11. package/dist/chunk-5W4RPVTK.cjs +49 -0
  12. package/dist/chunk-5W4RPVTK.cjs.map +1 -0
  13. package/dist/{chunk-7NADHFD2.cjs → chunk-64ITUOXI.cjs} +2 -2
  14. package/dist/chunk-64ITUOXI.cjs.map +1 -0
  15. package/dist/chunk-6FKQ4DSG.js +23216 -0
  16. package/dist/chunk-6FKQ4DSG.js.map +1 -0
  17. package/dist/{chunk-MMROOK5J.js → chunk-6QWQZI4Q.js} +2 -2
  18. package/dist/{chunk-7NADHFD2.cjs.map → chunk-6QWQZI4Q.js.map} +1 -1
  19. package/dist/chunk-7MKJBWFB.js +328 -0
  20. package/dist/chunk-7MKJBWFB.js.map +1 -0
  21. package/dist/chunk-BMZXKXKN.js +1024 -0
  22. package/dist/chunk-BMZXKXKN.js.map +1 -0
  23. package/dist/chunk-C36PTNGG.js +310 -0
  24. package/dist/chunk-C36PTNGG.js.map +1 -0
  25. package/dist/chunk-CENPXDRK.js +131 -0
  26. package/dist/chunk-CENPXDRK.js.map +1 -0
  27. package/dist/chunk-CLRYA4BH.cjs +125 -0
  28. package/dist/chunk-CLRYA4BH.cjs.map +1 -0
  29. package/dist/chunk-ER3QM7DD.js +46 -0
  30. package/dist/chunk-ER3QM7DD.js.map +1 -0
  31. package/dist/chunk-FCCK5TSS.js +116 -0
  32. package/dist/chunk-FCCK5TSS.js.map +1 -0
  33. package/dist/chunk-FPCGLPLJ.cjs +297 -0
  34. package/dist/chunk-FPCGLPLJ.cjs.map +1 -0
  35. package/dist/chunk-GU4EWMZB.cjs +769 -0
  36. package/dist/chunk-GU4EWMZB.cjs.map +1 -0
  37. package/dist/chunk-GXPLVMB6.cjs +135 -0
  38. package/dist/chunk-GXPLVMB6.cjs.map +1 -0
  39. package/dist/chunk-H2RMXG2Q.cjs +167 -0
  40. package/dist/chunk-H2RMXG2Q.cjs.map +1 -0
  41. package/dist/chunk-ICROWJN4.cjs +23258 -0
  42. package/dist/chunk-ICROWJN4.cjs.map +1 -0
  43. package/dist/{chunk-WNK42E5I.cjs → chunk-KXHMFCVS.cjs} +231 -36
  44. package/dist/chunk-KXHMFCVS.cjs.map +1 -0
  45. package/dist/chunk-LF2ZLOFP.js +767 -0
  46. package/dist/chunk-LF2ZLOFP.js.map +1 -0
  47. package/dist/chunk-LPM6BBAX.cjs +1043 -0
  48. package/dist/chunk-LPM6BBAX.cjs.map +1 -0
  49. package/dist/chunk-MWQQRVQC.cjs +259 -0
  50. package/dist/chunk-MWQQRVQC.cjs.map +1 -0
  51. package/dist/chunk-O7I5CWRX.cjs +44 -0
  52. package/dist/{chunk-Q7SFCCGT.cjs.map → chunk-O7I5CWRX.cjs.map} +1 -1
  53. package/dist/chunk-ORJBWSYB.js +196 -0
  54. package/dist/chunk-ORJBWSYB.js.map +1 -0
  55. package/dist/chunk-PKRHEXX7.js +74 -0
  56. package/dist/chunk-PKRHEXX7.js.map +1 -0
  57. package/dist/chunk-PR4QN5HX.js +39 -0
  58. package/dist/{chunk-PZ5AY32C.js.map → chunk-PR4QN5HX.js.map} +1 -1
  59. package/dist/chunk-PRNUFXPC.cjs +1067 -0
  60. package/dist/chunk-PRNUFXPC.cjs.map +1 -0
  61. package/dist/chunk-QCW6WANZ.cjs +296 -0
  62. package/dist/chunk-QCW6WANZ.cjs.map +1 -0
  63. package/dist/chunk-QS23OV2B.cjs +916 -0
  64. package/dist/chunk-QS23OV2B.cjs.map +1 -0
  65. package/dist/chunk-R4M3BSUG.js +226 -0
  66. package/dist/chunk-R4M3BSUG.js.map +1 -0
  67. package/dist/chunk-RQK4FQUD.js +1012 -0
  68. package/dist/chunk-RQK4FQUD.js.map +1 -0
  69. package/dist/chunk-SWIK2QSP.cjs +346 -0
  70. package/dist/chunk-SWIK2QSP.cjs.map +1 -0
  71. package/dist/chunk-SXVANU23.js +164 -0
  72. package/dist/chunk-SXVANU23.js.map +1 -0
  73. package/dist/chunk-TIX6M3ZD.js +354 -0
  74. package/dist/chunk-TIX6M3ZD.js.map +1 -0
  75. package/dist/chunk-TLA5YDQF.cjs +801 -0
  76. package/dist/chunk-TLA5YDQF.cjs.map +1 -0
  77. package/dist/chunk-TOUBNMVI.cjs +322 -0
  78. package/dist/chunk-TOUBNMVI.cjs.map +1 -0
  79. package/dist/chunk-TT25WHVT.cjs +368 -0
  80. package/dist/chunk-TT25WHVT.cjs.map +1 -0
  81. package/dist/chunk-U565A3UD.js +777 -0
  82. package/dist/chunk-U565A3UD.js.map +1 -0
  83. package/dist/chunk-UPY7WWRA.cjs +205 -0
  84. package/dist/chunk-UPY7WWRA.cjs.map +1 -0
  85. package/dist/{chunk-CY4TP3FK.js → chunk-UXGQZUYZ.js} +3 -3
  86. package/dist/{chunk-CY4TP3FK.js.map → chunk-UXGQZUYZ.js.map} +1 -1
  87. package/dist/chunk-V272B7RM.cjs +255 -0
  88. package/dist/chunk-V272B7RM.cjs.map +1 -0
  89. package/dist/{chunk-RE4RPXT2.cjs → chunk-V5WWQN7P.cjs} +4 -4
  90. package/dist/{chunk-RE4RPXT2.cjs.map → chunk-V5WWQN7P.cjs.map} +1 -1
  91. package/dist/chunk-VJVDLNFK.js +286 -0
  92. package/dist/chunk-VJVDLNFK.js.map +1 -0
  93. package/dist/chunk-WISPJOEJ.js +887 -0
  94. package/dist/chunk-WISPJOEJ.js.map +1 -0
  95. package/dist/chunk-XMKZWHVG.js +204 -0
  96. package/dist/chunk-XMKZWHVG.js.map +1 -0
  97. package/dist/chunk-XQPJ63ZD.cjs +48 -0
  98. package/dist/chunk-XQPJ63ZD.cjs.map +1 -0
  99. package/dist/chunk-XWGAT2DA.js +44 -0
  100. package/dist/chunk-XWGAT2DA.js.map +1 -0
  101. package/dist/chunk-YP34EWWK.js +253 -0
  102. package/dist/chunk-YP34EWWK.js.map +1 -0
  103. package/dist/chunk-Z4GN2JAO.cjs +211 -0
  104. package/dist/chunk-Z4GN2JAO.cjs.map +1 -0
  105. package/dist/chunk-ZULZ2752.js +2774 -0
  106. package/dist/chunk-ZULZ2752.js.map +1 -0
  107. package/dist/dist-4MVGNSRL.cjs +1150 -0
  108. package/dist/dist-4MVGNSRL.cjs.map +1 -0
  109. package/dist/dist-FZYCV3VB.cjs +940 -0
  110. package/dist/dist-FZYCV3VB.cjs.map +1 -0
  111. package/dist/dist-G2BYZJOC.cjs +928 -0
  112. package/dist/dist-G2BYZJOC.cjs.map +1 -0
  113. package/dist/dist-P4MXBQ3U.cjs +16 -0
  114. package/dist/dist-P4MXBQ3U.cjs.map +1 -0
  115. package/dist/dist-PQZUVLPC.js +937 -0
  116. package/dist/dist-PQZUVLPC.js.map +1 -0
  117. package/dist/dist-R7WYX6LC.js +925 -0
  118. package/dist/dist-R7WYX6LC.js.map +1 -0
  119. package/dist/dist-RFMYFILX.cjs +764 -0
  120. package/dist/dist-RFMYFILX.cjs.map +1 -0
  121. package/dist/dist-X7XR3M3Z.js +1147 -0
  122. package/dist/dist-X7XR3M3Z.js.map +1 -0
  123. package/dist/dist-XVBSOGFK.js +761 -0
  124. package/dist/dist-XVBSOGFK.js.map +1 -0
  125. package/dist/dist-YREX2TJT.js +3 -0
  126. package/dist/dist-YREX2TJT.js.map +1 -0
  127. package/dist/index.cjs +4 -0
  128. package/dist/index.cjs.map +1 -1
  129. package/dist/index.js +3 -0
  130. package/dist/index.js.map +1 -1
  131. package/dist/server/auth/defaults.d.ts +3 -0
  132. package/dist/server/auth/defaults.d.ts.map +1 -0
  133. package/dist/server/auth/helpers.d.ts +14 -0
  134. package/dist/server/auth/helpers.d.ts.map +1 -0
  135. package/dist/server/auth/index.cjs +137 -0
  136. package/dist/server/auth/index.cjs.map +1 -0
  137. package/dist/server/auth/index.d.ts +3 -0
  138. package/dist/server/auth/index.d.ts.map +1 -0
  139. package/dist/server/auth/index.js +127 -0
  140. package/dist/server/auth/index.js.map +1 -0
  141. package/dist/server/handlers/a2a.cjs +15 -7
  142. package/dist/server/handlers/a2a.d.ts +492 -10
  143. package/dist/server/handlers/a2a.d.ts.map +1 -1
  144. package/dist/server/handlers/a2a.js +1 -1
  145. package/dist/server/handlers/agent-builder.cjs +80 -0
  146. package/dist/server/handlers/agent-builder.cjs.map +1 -0
  147. package/dist/server/handlers/agent-builder.d.ts +625 -0
  148. package/dist/server/handlers/agent-builder.d.ts.map +1 -0
  149. package/dist/server/handlers/agent-builder.js +3 -0
  150. package/dist/server/handlers/agent-builder.js.map +1 -0
  151. package/dist/server/handlers/agents.cjs +73 -17
  152. package/dist/server/handlers/agents.d.ts +3328 -80
  153. package/dist/server/handlers/agents.d.ts.map +1 -1
  154. package/dist/server/handlers/agents.js +1 -1
  155. package/dist/server/handlers/error.cjs +2 -2
  156. package/dist/server/handlers/error.js +1 -1
  157. package/dist/server/handlers/logs.cjs +7 -7
  158. package/dist/server/handlers/logs.d.ts +135 -27
  159. package/dist/server/handlers/logs.d.ts.map +1 -1
  160. package/dist/server/handlers/logs.js +1 -1
  161. package/dist/server/handlers/mcp.cjs +40 -0
  162. package/dist/server/handlers/mcp.cjs.map +1 -0
  163. package/dist/server/handlers/mcp.d.ts +108 -0
  164. package/dist/server/handlers/mcp.d.ts.map +1 -0
  165. package/dist/server/handlers/mcp.js +3 -0
  166. package/dist/server/handlers/mcp.js.map +1 -0
  167. package/dist/server/handlers/memory.cjs +63 -31
  168. package/dist/server/handlers/memory.d.ts +934 -106
  169. package/dist/server/handlers/memory.d.ts.map +1 -1
  170. package/dist/server/handlers/memory.js +1 -1
  171. package/dist/server/handlers/observability.cjs +40 -0
  172. package/dist/server/handlers/observability.cjs.map +1 -0
  173. package/dist/server/handlers/observability.d.ts +156 -0
  174. package/dist/server/handlers/observability.d.ts.map +1 -0
  175. package/dist/server/handlers/observability.js +3 -0
  176. package/dist/server/handlers/observability.js.map +1 -0
  177. package/dist/server/handlers/scores.cjs +13 -13
  178. package/dist/server/handlers/scores.d.ts +112 -40
  179. package/dist/server/handlers/scores.d.ts.map +1 -1
  180. package/dist/server/handlers/scores.js +1 -1
  181. package/dist/server/handlers/test-utils.cjs +15 -0
  182. package/dist/server/handlers/test-utils.cjs.map +1 -0
  183. package/dist/server/handlers/test-utils.d.ts +6 -0
  184. package/dist/server/handlers/test-utils.d.ts.map +1 -0
  185. package/dist/server/handlers/test-utils.js +13 -0
  186. package/dist/server/handlers/test-utils.js.map +1 -0
  187. package/dist/server/handlers/tools.cjs +13 -9
  188. package/dist/server/handlers/tools.d.ts +69 -19
  189. package/dist/server/handlers/tools.d.ts.map +1 -1
  190. package/dist/server/handlers/tools.js +1 -1
  191. package/dist/server/handlers/utils.cjs +14 -2
  192. package/dist/server/handlers/utils.d.ts +11 -0
  193. package/dist/server/handlers/utils.d.ts.map +1 -1
  194. package/dist/server/handlers/utils.js +1 -1
  195. package/dist/server/handlers/vector.cjs +31 -7
  196. package/dist/server/handlers/vector.d.ts +93 -9
  197. package/dist/server/handlers/vector.d.ts.map +1 -1
  198. package/dist/server/handlers/vector.js +1 -1
  199. package/dist/server/handlers/voice.cjs +21 -9
  200. package/dist/server/handlers/voice.d.ts +81 -38
  201. package/dist/server/handlers/voice.d.ts.map +1 -1
  202. package/dist/server/handlers/voice.js +1 -1
  203. package/dist/server/handlers/workflows.cjs +71 -31
  204. package/dist/server/handlers/workflows.d.ts +936 -79
  205. package/dist/server/handlers/workflows.d.ts.map +1 -1
  206. package/dist/server/handlers/workflows.js +1 -1
  207. package/dist/server/handlers.cjs +35 -35
  208. package/dist/server/handlers.d.ts +3 -3
  209. package/dist/server/handlers.d.ts.map +1 -1
  210. package/dist/server/handlers.js +12 -12
  211. package/dist/server/http-exception.d.ts +0 -5
  212. package/dist/server/http-exception.d.ts.map +1 -1
  213. package/dist/server/schemas/a2a.d.ts +786 -0
  214. package/dist/server/schemas/a2a.d.ts.map +1 -0
  215. package/dist/server/schemas/agent-builder.d.ts +204 -0
  216. package/dist/server/schemas/agent-builder.d.ts.map +1 -0
  217. package/dist/server/schemas/agents.d.ts +1375 -0
  218. package/dist/server/schemas/agents.d.ts.map +1 -0
  219. package/dist/server/schemas/common.d.ts +165 -0
  220. package/dist/server/schemas/common.d.ts.map +1 -0
  221. package/dist/server/schemas/logs.d.ts +124 -0
  222. package/dist/server/schemas/logs.d.ts.map +1 -0
  223. package/dist/server/schemas/mcp.d.ts +293 -0
  224. package/dist/server/schemas/mcp.d.ts.map +1 -0
  225. package/dist/server/schemas/memory.d.ts +998 -0
  226. package/dist/server/schemas/memory.d.ts.map +1 -0
  227. package/dist/server/schemas/observability.d.ts +402 -0
  228. package/dist/server/schemas/observability.d.ts.map +1 -0
  229. package/dist/server/schemas/scores.d.ts +259 -0
  230. package/dist/server/schemas/scores.d.ts.map +1 -0
  231. package/dist/server/schemas/vectors.d.ts +107 -0
  232. package/dist/server/schemas/vectors.d.ts.map +1 -0
  233. package/dist/server/schemas/workflows.d.ts +623 -0
  234. package/dist/server/schemas/workflows.d.ts.map +1 -0
  235. package/dist/server/server-adapter/index.cjs +471 -0
  236. package/dist/server/server-adapter/index.cjs.map +1 -0
  237. package/dist/server/server-adapter/index.d.ts +81 -0
  238. package/dist/server/server-adapter/index.d.ts.map +1 -0
  239. package/dist/server/server-adapter/index.js +456 -0
  240. package/dist/server/server-adapter/index.js.map +1 -0
  241. package/dist/server/server-adapter/openapi-utils.d.ts +59 -0
  242. package/dist/server/server-adapter/openapi-utils.d.ts.map +1 -0
  243. package/dist/server/server-adapter/redact.d.ts +26 -0
  244. package/dist/server/server-adapter/redact.d.ts.map +1 -0
  245. package/dist/server/server-adapter/routes/a2a.d.ts +3 -0
  246. package/dist/server/server-adapter/routes/a2a.d.ts.map +1 -0
  247. package/dist/server/server-adapter/routes/agent-builder.d.ts +3 -0
  248. package/dist/server/server-adapter/routes/agent-builder.d.ts.map +1 -0
  249. package/dist/server/server-adapter/routes/agents.d.ts +3 -0
  250. package/dist/server/server-adapter/routes/agents.d.ts.map +1 -0
  251. package/dist/server/server-adapter/routes/index.d.ts +50 -0
  252. package/dist/server/server-adapter/routes/index.d.ts.map +1 -0
  253. package/dist/server/server-adapter/routes/legacy.d.ts +7 -0
  254. package/dist/server/server-adapter/routes/legacy.d.ts.map +1 -0
  255. package/dist/server/server-adapter/routes/logs.d.ts +3 -0
  256. package/dist/server/server-adapter/routes/logs.d.ts.map +1 -0
  257. package/dist/server/server-adapter/routes/mcp.d.ts +9 -0
  258. package/dist/server/server-adapter/routes/mcp.d.ts.map +1 -0
  259. package/dist/server/server-adapter/routes/memory.d.ts +3 -0
  260. package/dist/server/server-adapter/routes/memory.d.ts.map +1 -0
  261. package/dist/server/server-adapter/routes/observability.d.ts +3 -0
  262. package/dist/server/server-adapter/routes/observability.d.ts.map +1 -0
  263. package/dist/server/server-adapter/routes/route-builder.d.ts +52 -0
  264. package/dist/server/server-adapter/routes/route-builder.d.ts.map +1 -0
  265. package/dist/server/server-adapter/routes/scorers.d.ts +3 -0
  266. package/dist/server/server-adapter/routes/scorers.d.ts.map +1 -0
  267. package/dist/server/server-adapter/routes/stream-types.d.ts +10 -0
  268. package/dist/server/server-adapter/routes/stream-types.d.ts.map +1 -0
  269. package/dist/server/server-adapter/routes/tools.d.ts +3 -0
  270. package/dist/server/server-adapter/routes/tools.d.ts.map +1 -0
  271. package/dist/server/server-adapter/routes/vectors.d.ts +3 -0
  272. package/dist/server/server-adapter/routes/vectors.d.ts.map +1 -0
  273. package/dist/server/server-adapter/routes/workflows.d.ts +3 -0
  274. package/dist/server/server-adapter/routes/workflows.d.ts.map +1 -0
  275. package/dist/server/utils.d.ts +45 -0
  276. package/dist/server/utils.d.ts.map +1 -0
  277. package/dist/token-GVZ7HRD7.js +62 -0
  278. package/dist/token-GVZ7HRD7.js.map +1 -0
  279. package/dist/token-JGA3ZWAN.js +61 -0
  280. package/dist/token-JGA3ZWAN.js.map +1 -0
  281. package/dist/token-VFONFWVS.cjs +64 -0
  282. package/dist/token-VFONFWVS.cjs.map +1 -0
  283. package/dist/token-ZOD6YIQ3.cjs +63 -0
  284. package/dist/token-ZOD6YIQ3.cjs.map +1 -0
  285. package/dist/token-util-7R2ZFIXO.js +7 -0
  286. package/dist/token-util-7R2ZFIXO.js.map +1 -0
  287. package/dist/token-util-BLJZJDBZ.cjs +9 -0
  288. package/dist/token-util-BLJZJDBZ.cjs.map +1 -0
  289. package/dist/token-util-VGZUWSNR.cjs +9 -0
  290. package/dist/token-util-VGZUWSNR.cjs.map +1 -0
  291. package/dist/token-util-VKTPZLSE.js +7 -0
  292. package/dist/token-util-VKTPZLSE.js.map +1 -0
  293. package/package.json +53 -14
  294. package/dist/chunk-25LDKW7R.js.map +0 -1
  295. package/dist/chunk-4MQU6AJN.js +0 -83
  296. package/dist/chunk-4MQU6AJN.js.map +0 -1
  297. package/dist/chunk-4QSNRCOT.cjs +0 -20
  298. package/dist/chunk-4QSNRCOT.cjs.map +0 -1
  299. package/dist/chunk-4US5W7PH.cjs +0 -120
  300. package/dist/chunk-4US5W7PH.cjs.map +0 -1
  301. package/dist/chunk-7FHF55WA.js +0 -2041
  302. package/dist/chunk-7FHF55WA.js.map +0 -1
  303. package/dist/chunk-BED2O446.cjs +0 -88
  304. package/dist/chunk-BED2O446.cjs.map +0 -1
  305. package/dist/chunk-BUOJL3MN.js +0 -529
  306. package/dist/chunk-BUOJL3MN.js.map +0 -1
  307. package/dist/chunk-CERIVHRO.cjs +0 -153
  308. package/dist/chunk-CERIVHRO.cjs.map +0 -1
  309. package/dist/chunk-G7NVCO5M.js +0 -123
  310. package/dist/chunk-G7NVCO5M.js.map +0 -1
  311. package/dist/chunk-HWHKM67I.js +0 -114
  312. package/dist/chunk-HWHKM67I.js.map +0 -1
  313. package/dist/chunk-HXZTRBY4.js +0 -147
  314. package/dist/chunk-HXZTRBY4.js.map +0 -1
  315. package/dist/chunk-ILCWPBYQ.cjs +0 -147
  316. package/dist/chunk-ILCWPBYQ.cjs.map +0 -1
  317. package/dist/chunk-JGVY3KWV.cjs +0 -334
  318. package/dist/chunk-JGVY3KWV.cjs.map +0 -1
  319. package/dist/chunk-KXXJ7Y4H.js +0 -592
  320. package/dist/chunk-KXXJ7Y4H.js.map +0 -1
  321. package/dist/chunk-L7YG7WQH.js +0 -151
  322. package/dist/chunk-L7YG7WQH.js.map +0 -1
  323. package/dist/chunk-LRUH33B4.cjs +0 -2044
  324. package/dist/chunk-LRUH33B4.cjs.map +0 -1
  325. package/dist/chunk-LZASFI6W.cjs +0 -609
  326. package/dist/chunk-LZASFI6W.cjs.map +0 -1
  327. package/dist/chunk-MMROOK5J.js.map +0 -1
  328. package/dist/chunk-NCS2OXX6.cjs +0 -131
  329. package/dist/chunk-NCS2OXX6.cjs.map +0 -1
  330. package/dist/chunk-O4I563YW.cjs +0 -130
  331. package/dist/chunk-O4I563YW.cjs.map +0 -1
  332. package/dist/chunk-OW4FX5TS.js +0 -18
  333. package/dist/chunk-OW4FX5TS.js.map +0 -1
  334. package/dist/chunk-PZ5AY32C.js +0 -9
  335. package/dist/chunk-Q4OQ4DOR.cjs +0 -334
  336. package/dist/chunk-Q4OQ4DOR.cjs.map +0 -1
  337. package/dist/chunk-Q7SFCCGT.cjs +0 -11
  338. package/dist/chunk-RQQNZZAI.cjs +0 -159
  339. package/dist/chunk-RQQNZZAI.cjs.map +0 -1
  340. package/dist/chunk-S37KCGOR.cjs +0 -546
  341. package/dist/chunk-S37KCGOR.cjs.map +0 -1
  342. package/dist/chunk-SQ7KKIH3.js +0 -143
  343. package/dist/chunk-SQ7KKIH3.js.map +0 -1
  344. package/dist/chunk-SXXGIMWO.js +0 -324
  345. package/dist/chunk-SXXGIMWO.js.map +0 -1
  346. package/dist/chunk-UVOSITKU.js +0 -322
  347. package/dist/chunk-UVOSITKU.js.map +0 -1
  348. package/dist/chunk-WNK42E5I.cjs.map +0 -1
  349. package/dist/chunk-YS66MFDY.js +0 -124
  350. package/dist/chunk-YS66MFDY.js.map +0 -1
  351. package/dist/server/handlers/legacyWorkflows.cjs +0 -48
  352. package/dist/server/handlers/legacyWorkflows.cjs.map +0 -1
  353. package/dist/server/handlers/legacyWorkflows.d.ts +0 -59
  354. package/dist/server/handlers/legacyWorkflows.d.ts.map +0 -1
  355. package/dist/server/handlers/legacyWorkflows.js +0 -3
  356. package/dist/server/handlers/legacyWorkflows.js.map +0 -1
  357. package/dist/server/handlers/network.cjs +0 -24
  358. package/dist/server/handlers/network.cjs.map +0 -1
  359. package/dist/server/handlers/network.d.ts +0 -51
  360. package/dist/server/handlers/network.d.ts.map +0 -1
  361. package/dist/server/handlers/network.js +0 -3
  362. package/dist/server/handlers/network.js.map +0 -1
  363. package/dist/server/handlers/telemetry.cjs +0 -16
  364. package/dist/server/handlers/telemetry.cjs.map +0 -1
  365. package/dist/server/handlers/telemetry.d.ts +0 -32
  366. package/dist/server/handlers/telemetry.d.ts.map +0 -1
  367. package/dist/server/handlers/telemetry.js +0 -3
  368. package/dist/server/handlers/telemetry.js.map +0 -1
  369. package/dist/server/handlers/vNextNetwork.cjs +0 -220
  370. package/dist/server/handlers/vNextNetwork.cjs.map +0 -1
  371. package/dist/server/handlers/vNextNetwork.d.ts +0 -179
  372. package/dist/server/handlers/vNextNetwork.d.ts.map +0 -1
  373. package/dist/server/handlers/vNextNetwork.js +0 -213
  374. package/dist/server/handlers/vNextNetwork.js.map +0 -1
@@ -1,153 +0,0 @@
1
- 'use strict';
2
-
3
- var chunk4QSNRCOT_cjs = require('./chunk-4QSNRCOT.cjs');
4
- var chunkRE4RPXT2_cjs = require('./chunk-RE4RPXT2.cjs');
5
- var chunk7NADHFD2_cjs = require('./chunk-7NADHFD2.cjs');
6
- var chunkQ7SFCCGT_cjs = require('./chunk-Q7SFCCGT.cjs');
7
- var agent = require('@mastra/core/agent');
8
-
9
- // src/server/handlers/network.ts
10
- var network_exports = {};
11
- chunkQ7SFCCGT_cjs.__export(network_exports, {
12
- generateHandler: () => generateHandler,
13
- getNetworkByIdHandler: () => getNetworkByIdHandler,
14
- getNetworksHandler: () => getNetworksHandler,
15
- streamGenerateHandler: () => streamGenerateHandler
16
- });
17
- async function getNetworksHandler({
18
- mastra,
19
- runtimeContext
20
- }) {
21
- try {
22
- const networks = mastra.getNetworks();
23
- const serializedNetworks = await Promise.all(
24
- networks.map(async (network) => {
25
- const routingAgent = network.getRoutingAgent();
26
- const routingLLM = await routingAgent.getLLM({ runtimeContext });
27
- const agents = network.getAgents();
28
- return {
29
- id: network.formatAgentId(routingAgent.name),
30
- name: routingAgent.name,
31
- instructions: routingAgent.instructions,
32
- agents: await Promise.all(
33
- agents.map(async (agent) => {
34
- const llm = await agent.getLLM({ runtimeContext });
35
- return {
36
- name: agent.name,
37
- provider: llm?.getProvider(),
38
- modelId: llm?.getModelId()
39
- };
40
- })
41
- ),
42
- routingModel: {
43
- provider: routingLLM?.getProvider(),
44
- modelId: routingLLM?.getModelId()
45
- }
46
- };
47
- })
48
- );
49
- return serializedNetworks;
50
- } catch (error) {
51
- return chunkRE4RPXT2_cjs.handleError(error, "Error getting networks");
52
- }
53
- }
54
- async function getNetworkByIdHandler({
55
- mastra,
56
- networkId,
57
- runtimeContext
58
- }) {
59
- try {
60
- const networks = mastra.getNetworks();
61
- const network = networks.find((network2) => {
62
- const routingAgent2 = network2.getRoutingAgent();
63
- return network2.formatAgentId(routingAgent2.name) === networkId;
64
- });
65
- if (!network) {
66
- throw new chunk7NADHFD2_cjs.HTTPException(404, { message: "Network not found" });
67
- }
68
- const routingAgent = network.getRoutingAgent();
69
- const routingLLM = await routingAgent.getLLM({ runtimeContext });
70
- const agents = network.getAgents();
71
- const serializedNetwork = {
72
- id: network.formatAgentId(routingAgent.name),
73
- name: routingAgent.name,
74
- instructions: routingAgent.instructions,
75
- agents: await Promise.all(
76
- agents.map(async (agent) => {
77
- const llm = await agent.getLLM({ runtimeContext });
78
- return {
79
- name: agent.name,
80
- provider: llm?.getProvider(),
81
- modelId: llm?.getModelId()
82
- };
83
- })
84
- ),
85
- routingModel: {
86
- provider: routingLLM?.getProvider(),
87
- modelId: routingLLM?.getModelId()
88
- }
89
- };
90
- return serializedNetwork;
91
- } catch (error) {
92
- return chunkRE4RPXT2_cjs.handleError(error, "Error getting network by ID");
93
- }
94
- }
95
- async function generateHandler({
96
- mastra,
97
- runtimeContext,
98
- networkId,
99
- body
100
- }) {
101
- try {
102
- const network = mastra.getNetwork(networkId);
103
- if (!network) {
104
- throw new chunk7NADHFD2_cjs.HTTPException(404, { message: "Network not found" });
105
- }
106
- chunk4QSNRCOT_cjs.validateBody({ messages: body.messages });
107
- const { messages, ...rest } = body;
108
- const result = await network.generate(messages, { ...rest, runtimeContext });
109
- return result;
110
- } catch (error) {
111
- return chunkRE4RPXT2_cjs.handleError(error, "Error generating from network");
112
- }
113
- }
114
- async function streamGenerateHandler({
115
- mastra,
116
- networkId,
117
- body,
118
- runtimeContext,
119
- clientSdkCompat
120
- }) {
121
- try {
122
- const network = mastra.getNetwork(networkId);
123
- if (!network) {
124
- throw new chunk7NADHFD2_cjs.HTTPException(404, { message: "Network not found" });
125
- }
126
- chunk4QSNRCOT_cjs.validateBody({ messages: body.messages });
127
- const { messages, output, ...rest } = body;
128
- const streamResult = await network.stream(messages, {
129
- output,
130
- ...rest,
131
- runtimeContext
132
- });
133
- const useV4Compat = clientSdkCompat === "v4" || mastra.getAiSdkCompatMode() === "v4";
134
- const streamResponse = output ? streamResult.toTextStreamResponse() : streamResult.toUIMessageStreamResponse({
135
- onError: (error) => {
136
- return `An error occurred while processing your request. ${error instanceof Error ? error.message : JSON.stringify(error)}`;
137
- },
138
- sendReasoning: true,
139
- sendSources: true
140
- });
141
- return useV4Compat && !output ? agent.createV4CompatibleResponse(streamResponse.body) : streamResponse;
142
- } catch (error) {
143
- return chunkRE4RPXT2_cjs.handleError(error, "Error streaming from network");
144
- }
145
- }
146
-
147
- exports.generateHandler = generateHandler;
148
- exports.getNetworkByIdHandler = getNetworkByIdHandler;
149
- exports.getNetworksHandler = getNetworksHandler;
150
- exports.network_exports = network_exports;
151
- exports.streamGenerateHandler = streamGenerateHandler;
152
- //# sourceMappingURL=chunk-CERIVHRO.cjs.map
153
- //# sourceMappingURL=chunk-CERIVHRO.cjs.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/server/handlers/network.ts"],"names":["__export","handleError","network","routingAgent","HTTPException","validateBody","createV4CompatibleResponse"],"mappings":"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","file":"chunk-CERIVHRO.cjs","sourcesContent":["import { createV4CompatibleResponse } from '@mastra/core/agent';\nimport type { AgentStreamOptions } from '@mastra/core/agent';\nimport type { GenerateReturn } from '@mastra/core/llm';\nimport type { AgentNetwork } from '@mastra/core/network';\nimport type { RuntimeContext } from '@mastra/core/runtime-context';\nimport { HTTPException } from '../http-exception';\nimport type { Context } from '../types';\nimport { handleError } from './error';\nimport { validateBody } from './utils';\n\ninterface NetworkContext extends Context {\n networkId?: string;\n runtimeContext: RuntimeContext;\n}\n\nexport async function getNetworksHandler({\n mastra,\n runtimeContext,\n}: Pick<NetworkContext, 'mastra' | 'runtimeContext'>) {\n try {\n const networks = mastra.getNetworks();\n\n const serializedNetworks = await Promise.all(\n networks.map(async network => {\n const routingAgent = network.getRoutingAgent();\n const routingLLM = await routingAgent.getLLM({ runtimeContext });\n const agents = network.getAgents();\n return {\n id: network.formatAgentId(routingAgent.name),\n name: routingAgent.name,\n instructions: routingAgent.instructions,\n agents: await Promise.all(\n agents.map(async agent => {\n const llm = await agent.getLLM({ runtimeContext });\n return {\n name: agent.name,\n provider: llm?.getProvider(),\n modelId: llm?.getModelId(),\n };\n }),\n ),\n routingModel: {\n provider: routingLLM?.getProvider(),\n modelId: routingLLM?.getModelId(),\n },\n };\n }),\n );\n\n return serializedNetworks;\n } catch (error) {\n return handleError(error, 'Error getting networks');\n }\n}\n\nexport async function getNetworkByIdHandler({\n mastra,\n networkId,\n runtimeContext,\n}: Pick<NetworkContext, 'mastra' | 'networkId' | 'runtimeContext'>) {\n try {\n const networks = mastra.getNetworks();\n\n const network = networks.find(network => {\n const routingAgent = network.getRoutingAgent();\n return network.formatAgentId(routingAgent.name) === networkId;\n });\n\n if (!network) {\n throw new HTTPException(404, { message: 'Network not found' });\n }\n\n const routingAgent = network.getRoutingAgent();\n const routingLLM = await routingAgent.getLLM({ runtimeContext });\n const agents = network.getAgents();\n\n const serializedNetwork = {\n id: network.formatAgentId(routingAgent.name),\n name: routingAgent.name,\n instructions: routingAgent.instructions,\n agents: await Promise.all(\n agents.map(async agent => {\n const llm = await agent.getLLM({ runtimeContext });\n return {\n name: agent.name,\n provider: llm?.getProvider(),\n modelId: llm?.getModelId(),\n };\n }),\n ),\n routingModel: {\n provider: routingLLM?.getProvider(),\n modelId: routingLLM?.getModelId(),\n },\n };\n\n return serializedNetwork;\n } catch (error) {\n return handleError(error, 'Error getting network by ID');\n }\n}\n\nexport async function generateHandler({\n mastra,\n runtimeContext,\n networkId,\n body,\n}: NetworkContext & {\n runtimeContext: RuntimeContext;\n body: { messages?: Parameters<AgentNetwork['generate']>[0] } & Parameters<AgentNetwork['generate']>[1];\n}): Promise<GenerateReturn<any>> {\n try {\n const network = mastra.getNetwork(networkId!);\n\n if (!network) {\n throw new HTTPException(404, { message: 'Network not found' });\n }\n\n validateBody({ messages: body.messages });\n\n const { messages, ...rest } = body;\n const result = await network.generate(messages!, { ...rest, runtimeContext });\n\n return result;\n } catch (error) {\n return handleError(error, 'Error generating from network');\n }\n}\n\nexport async function streamGenerateHandler({\n mastra,\n networkId,\n body,\n runtimeContext,\n clientSdkCompat,\n}: NetworkContext & {\n runtimeContext: RuntimeContext;\n body: { messages?: Parameters<AgentNetwork['stream']>[0] } & Parameters<AgentNetwork['stream']>[1];\n clientSdkCompat?: string;\n}) {\n try {\n const network = mastra.getNetwork(networkId!);\n\n if (!network) {\n throw new HTTPException(404, { message: 'Network not found' });\n }\n\n validateBody({ messages: body.messages });\n\n const { messages, output, ...rest } = body;\n const streamResult = await network.stream(messages!, {\n output: output as any,\n ...rest,\n runtimeContext,\n } as AgentStreamOptions<any, any>);\n\n // Determine compatibility mode\n // Check for client header override first, then fall back to Mastra config\n const useV4Compat = clientSdkCompat === 'v4' || mastra.getAiSdkCompatMode() === 'v4';\n\n const streamResponse = output\n ? streamResult.toTextStreamResponse()\n : streamResult.toUIMessageStreamResponse({\n onError: (error: any) => {\n return `An error occurred while processing your request. ${error instanceof Error ? error.message : JSON.stringify(error)}`;\n },\n sendReasoning: true,\n sendSources: true,\n });\n\n // Apply v4 compatibility transformation if needed\n return useV4Compat && !output ? createV4CompatibleResponse(streamResponse.body!) : streamResponse;\n } catch (error) {\n return handleError(error, 'Error streaming from network');\n }\n}\n"]}
@@ -1,123 +0,0 @@
1
- import { handleError } from './chunk-CY4TP3FK.js';
2
- import { HTTPException } from './chunk-MMROOK5J.js';
3
- import { __export } from './chunk-PZ5AY32C.js';
4
-
5
- // src/server/handlers/vector.ts
6
- var vector_exports = {};
7
- __export(vector_exports, {
8
- createIndex: () => createIndex,
9
- deleteIndex: () => deleteIndex,
10
- describeIndex: () => describeIndex,
11
- listIndexes: () => listIndexes,
12
- queryVectors: () => queryVectors,
13
- upsertVectors: () => upsertVectors
14
- });
15
- function getVector(mastra, vectorName) {
16
- if (!vectorName) {
17
- throw new HTTPException(400, { message: "Vector name is required" });
18
- }
19
- const vector = mastra.getVector(vectorName);
20
- if (!vector) {
21
- throw new HTTPException(404, { message: `Vector store ${vectorName} not found` });
22
- }
23
- return vector;
24
- }
25
- async function upsertVectors({ mastra, vectorName, index }) {
26
- try {
27
- if (!index?.indexName || !index?.vectors || !Array.isArray(index.vectors)) {
28
- throw new HTTPException(400, { message: "Invalid request index. indexName and vectors array are required." });
29
- }
30
- const vector = getVector(mastra, vectorName);
31
- const result = await vector.upsert(index);
32
- return { ids: result };
33
- } catch (error) {
34
- return handleError(error, "Error upserting vectors");
35
- }
36
- }
37
- async function createIndex({
38
- mastra,
39
- vectorName,
40
- index
41
- }) {
42
- try {
43
- const { indexName, dimension, metric } = index;
44
- if (!indexName || typeof dimension !== "number" || dimension <= 0) {
45
- throw new HTTPException(400, {
46
- message: "Invalid request index, indexName and positive dimension number are required."
47
- });
48
- }
49
- if (metric && !["cosine", "euclidean", "dotproduct"].includes(metric)) {
50
- throw new HTTPException(400, { message: "Invalid metric. Must be one of: cosine, euclidean, dotproduct" });
51
- }
52
- const vector = getVector(mastra, vectorName);
53
- await vector.createIndex({ indexName, dimension, metric });
54
- return { success: true };
55
- } catch (error) {
56
- return handleError(error, "Error creating index");
57
- }
58
- }
59
- async function queryVectors({
60
- mastra,
61
- vectorName,
62
- query
63
- }) {
64
- try {
65
- if (!query?.indexName || !query?.queryVector || !Array.isArray(query.queryVector)) {
66
- throw new HTTPException(400, { message: "Invalid request query. indexName and queryVector array are required." });
67
- }
68
- const vector = getVector(mastra, vectorName);
69
- const results = await vector.query(query);
70
- return results;
71
- } catch (error) {
72
- return handleError(error, "Error querying vectors");
73
- }
74
- }
75
- async function listIndexes({ mastra, vectorName }) {
76
- try {
77
- const vector = getVector(mastra, vectorName);
78
- const indexes = await vector.listIndexes();
79
- return indexes.filter(Boolean);
80
- } catch (error) {
81
- return handleError(error, "Error listing indexes");
82
- }
83
- }
84
- async function describeIndex({
85
- mastra,
86
- vectorName,
87
- indexName
88
- }) {
89
- try {
90
- if (!indexName) {
91
- throw new HTTPException(400, { message: "Index name is required" });
92
- }
93
- const vector = getVector(mastra, vectorName);
94
- const stats = await vector.describeIndex({ indexName });
95
- return {
96
- dimension: stats.dimension,
97
- count: stats.count,
98
- metric: stats.metric?.toLowerCase()
99
- };
100
- } catch (error) {
101
- return handleError(error, "Error describing index");
102
- }
103
- }
104
- async function deleteIndex({
105
- mastra,
106
- vectorName,
107
- indexName
108
- }) {
109
- try {
110
- if (!indexName) {
111
- throw new HTTPException(400, { message: "Index name is required" });
112
- }
113
- const vector = getVector(mastra, vectorName);
114
- await vector.deleteIndex({ indexName });
115
- return { success: true };
116
- } catch (error) {
117
- return handleError(error, "Error deleting index");
118
- }
119
- }
120
-
121
- export { createIndex, deleteIndex, describeIndex, listIndexes, queryVectors, upsertVectors, vector_exports };
122
- //# sourceMappingURL=chunk-G7NVCO5M.js.map
123
- //# sourceMappingURL=chunk-G7NVCO5M.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/server/handlers/vector.ts"],"names":[],"mappings":"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","file":"chunk-G7NVCO5M.js","sourcesContent":["import type { MastraVector, QueryResult, IndexStats } from '@mastra/core/vector';\nimport { HTTPException } from '../http-exception';\nimport type { Context } from '../types';\n\nimport { handleError } from './error';\n\ninterface VectorContext extends Context {\n vectorName?: string;\n}\n\ninterface UpsertRequest {\n indexName: string;\n vectors: number[][];\n metadata?: Record<string, any>[];\n ids?: string[];\n}\n\ninterface CreateIndexRequest {\n indexName: string;\n dimension: number;\n metric?: 'cosine' | 'euclidean' | 'dotproduct';\n}\n\ninterface QueryRequest {\n indexName: string;\n queryVector: number[];\n topK?: number;\n filter?: Record<string, any>;\n includeVector?: boolean;\n}\n\nfunction getVector(mastra: Context['mastra'], vectorName?: string): MastraVector {\n if (!vectorName) {\n throw new HTTPException(400, { message: 'Vector name is required' });\n }\n\n const vector = mastra.getVector(vectorName);\n if (!vector) {\n throw new HTTPException(404, { message: `Vector store ${vectorName} not found` });\n }\n\n return vector;\n}\n\n// Upsert vectors\nexport async function upsertVectors({ mastra, vectorName, index }: VectorContext & { index: UpsertRequest }) {\n try {\n if (!index?.indexName || !index?.vectors || !Array.isArray(index.vectors)) {\n throw new HTTPException(400, { message: 'Invalid request index. indexName and vectors array are required.' });\n }\n\n const vector = getVector(mastra, vectorName);\n const result = await vector.upsert(index);\n return { ids: result };\n } catch (error) {\n return handleError(error, 'Error upserting vectors');\n }\n}\n\n// Create index\nexport async function createIndex({\n mastra,\n vectorName,\n index,\n}: Pick<VectorContext, 'mastra' | 'vectorName'> & { index: CreateIndexRequest }) {\n try {\n const { indexName, dimension, metric } = index;\n\n if (!indexName || typeof dimension !== 'number' || dimension <= 0) {\n throw new HTTPException(400, {\n message: 'Invalid request index, indexName and positive dimension number are required.',\n });\n }\n\n if (metric && !['cosine', 'euclidean', 'dotproduct'].includes(metric)) {\n throw new HTTPException(400, { message: 'Invalid metric. Must be one of: cosine, euclidean, dotproduct' });\n }\n\n const vector = getVector(mastra, vectorName);\n await vector.createIndex({ indexName, dimension, metric });\n return { success: true };\n } catch (error) {\n return handleError(error, 'Error creating index');\n }\n}\n\n// Query vectors\nexport async function queryVectors({\n mastra,\n vectorName,\n query,\n}: Pick<VectorContext, 'mastra' | 'vectorName'> & { query: QueryRequest }) {\n try {\n if (!query?.indexName || !query?.queryVector || !Array.isArray(query.queryVector)) {\n throw new HTTPException(400, { message: 'Invalid request query. indexName and queryVector array are required.' });\n }\n\n const vector = getVector(mastra, vectorName);\n const results: QueryResult[] = await vector.query(query);\n return results;\n } catch (error) {\n return handleError(error, 'Error querying vectors');\n }\n}\n\n// List indexes\nexport async function listIndexes({ mastra, vectorName }: Pick<VectorContext, 'mastra' | 'vectorName'>) {\n try {\n const vector = getVector(mastra, vectorName);\n\n const indexes = await vector.listIndexes();\n return indexes.filter(Boolean);\n } catch (error) {\n return handleError(error, 'Error listing indexes');\n }\n}\n\n// Describe index\nexport async function describeIndex({\n mastra,\n vectorName,\n indexName,\n}: Pick<VectorContext, 'mastra' | 'vectorName'> & { indexName?: string }) {\n try {\n if (!indexName) {\n throw new HTTPException(400, { message: 'Index name is required' });\n }\n\n const vector = getVector(mastra, vectorName);\n const stats: IndexStats = await vector.describeIndex({ indexName });\n\n return {\n dimension: stats.dimension,\n count: stats.count,\n metric: stats.metric?.toLowerCase(),\n };\n } catch (error) {\n return handleError(error, 'Error describing index');\n }\n}\n\n// Delete index\nexport async function deleteIndex({\n mastra,\n vectorName,\n indexName,\n}: Pick<VectorContext, 'mastra' | 'vectorName'> & { indexName?: string }) {\n try {\n if (!indexName) {\n throw new HTTPException(400, { message: 'Index name is required' });\n }\n\n const vector = getVector(mastra, vectorName);\n await vector.deleteIndex({ indexName });\n return { success: true };\n } catch (error) {\n return handleError(error, 'Error deleting index');\n }\n}\n"]}
@@ -1,114 +0,0 @@
1
- import { validateBody } from './chunk-OW4FX5TS.js';
2
- import { handleError } from './chunk-CY4TP3FK.js';
3
- import { HTTPException } from './chunk-MMROOK5J.js';
4
- import { __export } from './chunk-PZ5AY32C.js';
5
- import { Readable } from 'stream';
6
-
7
- // src/server/handlers/voice.ts
8
- var voice_exports = {};
9
- __export(voice_exports, {
10
- generateSpeechHandler: () => generateSpeechHandler,
11
- getListenerHandler: () => getListenerHandler,
12
- getSpeakersHandler: () => getSpeakersHandler,
13
- transcribeSpeechHandler: () => transcribeSpeechHandler
14
- });
15
- async function getSpeakersHandler({ mastra, agentId }) {
16
- try {
17
- if (!agentId) {
18
- throw new HTTPException(400, { message: "Agent ID is required" });
19
- }
20
- const agent = mastra.getAgent(agentId);
21
- if (!agent) {
22
- throw new HTTPException(404, { message: "Agent not found" });
23
- }
24
- const voice = await agent.getVoice();
25
- if (!voice) {
26
- throw new HTTPException(400, { message: "Agent does not have voice capabilities" });
27
- }
28
- const speakers = await voice.getSpeakers();
29
- return speakers;
30
- } catch (error) {
31
- return handleError(error, "Error getting speakers");
32
- }
33
- }
34
- async function generateSpeechHandler({
35
- mastra,
36
- agentId,
37
- body
38
- }) {
39
- try {
40
- if (!agentId) {
41
- throw new HTTPException(400, { message: "Agent ID is required" });
42
- }
43
- validateBody({
44
- text: body?.text
45
- });
46
- const agent = mastra.getAgent(agentId);
47
- if (!agent) {
48
- throw new HTTPException(404, { message: "Agent not found" });
49
- }
50
- const voice = await agent.getVoice();
51
- if (!voice) {
52
- throw new HTTPException(400, { message: "Agent does not have voice capabilities" });
53
- }
54
- const audioStream = await voice.speak(body.text, { speaker: body.speakerId });
55
- if (!audioStream) {
56
- throw new HTTPException(500, { message: "Failed to generate speech" });
57
- }
58
- return audioStream;
59
- } catch (error) {
60
- return handleError(error, "Error generating speech");
61
- }
62
- }
63
- async function transcribeSpeechHandler({
64
- mastra,
65
- agentId,
66
- body
67
- }) {
68
- try {
69
- if (!agentId) {
70
- throw new HTTPException(400, { message: "Agent ID is required" });
71
- }
72
- if (!body?.audioData) {
73
- throw new HTTPException(400, { message: "Audio data is required" });
74
- }
75
- const agent = mastra.getAgent(agentId);
76
- if (!agent) {
77
- throw new HTTPException(404, { message: "Agent not found" });
78
- }
79
- const voice = await agent.getVoice();
80
- if (!voice) {
81
- throw new HTTPException(400, { message: "Agent does not have voice capabilities" });
82
- }
83
- const audioStream = new Readable();
84
- audioStream.push(body.audioData);
85
- audioStream.push(null);
86
- const text = await voice.listen(audioStream, body.options);
87
- return { text };
88
- } catch (error) {
89
- return handleError(error, "Error transcribing speech");
90
- }
91
- }
92
- async function getListenerHandler({ mastra, agentId }) {
93
- try {
94
- if (!agentId) {
95
- throw new HTTPException(400, { message: "Agent ID is required" });
96
- }
97
- const agent = mastra.getAgent(agentId);
98
- if (!agent) {
99
- throw new HTTPException(404, { message: "Agent not found" });
100
- }
101
- const voice = await agent.getVoice();
102
- if (!voice) {
103
- throw new HTTPException(400, { message: "Agent does not have voice capabilities" });
104
- }
105
- const listeners = await voice.getListener();
106
- return listeners;
107
- } catch (error) {
108
- return handleError(error, "Error getting listeners");
109
- }
110
- }
111
-
112
- export { generateSpeechHandler, getListenerHandler, getSpeakersHandler, transcribeSpeechHandler, voice_exports };
113
- //# sourceMappingURL=chunk-HWHKM67I.js.map
114
- //# sourceMappingURL=chunk-HWHKM67I.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/server/handlers/voice.ts"],"names":[],"mappings":"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","file":"chunk-HWHKM67I.js","sourcesContent":["import { Readable } from 'stream';\nimport type { Agent } from '@mastra/core/agent';\nimport { HTTPException } from '../http-exception';\nimport type { Context } from '../types';\n\nimport { handleError } from './error';\nimport { validateBody } from './utils';\n\ninterface VoiceContext extends Context {\n agentId?: string;\n}\n\n/**\n * Get available speakers for an agent\n */\nexport async function getSpeakersHandler({ mastra, agentId }: VoiceContext) {\n try {\n if (!agentId) {\n throw new HTTPException(400, { message: 'Agent ID is required' });\n }\n\n const agent = mastra.getAgent(agentId);\n\n if (!agent) {\n throw new HTTPException(404, { message: 'Agent not found' });\n }\n\n const voice = await agent.getVoice();\n\n if (!voice) {\n throw new HTTPException(400, { message: 'Agent does not have voice capabilities' });\n }\n\n const speakers = await voice.getSpeakers();\n return speakers;\n } catch (error) {\n return handleError(error, 'Error getting speakers');\n }\n}\n\n/**\n * Generate speech from text\n */\nexport async function generateSpeechHandler({\n mastra,\n agentId,\n body,\n}: VoiceContext & {\n body?: {\n text?: string;\n speakerId?: string;\n };\n}) {\n try {\n if (!agentId) {\n throw new HTTPException(400, { message: 'Agent ID is required' });\n }\n\n validateBody({\n text: body?.text,\n });\n\n const agent = mastra.getAgent(agentId);\n\n if (!agent) {\n throw new HTTPException(404, { message: 'Agent not found' });\n }\n\n const voice = await agent.getVoice();\n\n if (!voice) {\n throw new HTTPException(400, { message: 'Agent does not have voice capabilities' });\n }\n\n const audioStream = await voice.speak(body!.text!, { speaker: body!.speakerId! });\n\n if (!audioStream) {\n throw new HTTPException(500, { message: 'Failed to generate speech' });\n }\n\n return audioStream;\n } catch (error) {\n return handleError(error, 'Error generating speech');\n }\n}\n\n/**\n * Transcribe speech to text\n */\nexport async function transcribeSpeechHandler({\n mastra,\n agentId,\n body,\n}: VoiceContext & {\n body?: {\n audioData?: Buffer;\n options?: Parameters<NonNullable<Agent['voice']>['listen']>[1];\n };\n}) {\n try {\n if (!agentId) {\n throw new HTTPException(400, { message: 'Agent ID is required' });\n }\n\n if (!body?.audioData) {\n throw new HTTPException(400, { message: 'Audio data is required' });\n }\n\n const agent = mastra.getAgent(agentId);\n\n if (!agent) {\n throw new HTTPException(404, { message: 'Agent not found' });\n }\n\n const voice = await agent.getVoice();\n\n if (!voice) {\n throw new HTTPException(400, { message: 'Agent does not have voice capabilities' });\n }\n\n const audioStream = new Readable();\n audioStream.push(body.audioData);\n audioStream.push(null);\n\n const text = await voice.listen(audioStream, body.options);\n return { text };\n } catch (error) {\n return handleError(error, 'Error transcribing speech');\n }\n}\n\n/**\n * Get available listeners for an agent\n */\nexport async function getListenerHandler({ mastra, agentId }: VoiceContext) {\n try {\n if (!agentId) {\n throw new HTTPException(400, { message: 'Agent ID is required' });\n }\n\n const agent = mastra.getAgent(agentId);\n\n if (!agent) {\n throw new HTTPException(404, { message: 'Agent not found' });\n }\n\n const voice = await agent.getVoice();\n\n if (!voice) {\n throw new HTTPException(400, { message: 'Agent does not have voice capabilities' });\n }\n\n const listeners = await voice.getListener();\n return listeners;\n } catch (error) {\n return handleError(error, 'Error getting listeners');\n }\n}\n"]}
@@ -1,147 +0,0 @@
1
- import { validateBody } from './chunk-OW4FX5TS.js';
2
- import { handleError } from './chunk-CY4TP3FK.js';
3
- import { HTTPException } from './chunk-MMROOK5J.js';
4
- import { __export } from './chunk-PZ5AY32C.js';
5
- import { createV4CompatibleResponse } from '@mastra/core/agent';
6
-
7
- // src/server/handlers/network.ts
8
- var network_exports = {};
9
- __export(network_exports, {
10
- generateHandler: () => generateHandler,
11
- getNetworkByIdHandler: () => getNetworkByIdHandler,
12
- getNetworksHandler: () => getNetworksHandler,
13
- streamGenerateHandler: () => streamGenerateHandler
14
- });
15
- async function getNetworksHandler({
16
- mastra,
17
- runtimeContext
18
- }) {
19
- try {
20
- const networks = mastra.getNetworks();
21
- const serializedNetworks = await Promise.all(
22
- networks.map(async (network) => {
23
- const routingAgent = network.getRoutingAgent();
24
- const routingLLM = await routingAgent.getLLM({ runtimeContext });
25
- const agents = network.getAgents();
26
- return {
27
- id: network.formatAgentId(routingAgent.name),
28
- name: routingAgent.name,
29
- instructions: routingAgent.instructions,
30
- agents: await Promise.all(
31
- agents.map(async (agent) => {
32
- const llm = await agent.getLLM({ runtimeContext });
33
- return {
34
- name: agent.name,
35
- provider: llm?.getProvider(),
36
- modelId: llm?.getModelId()
37
- };
38
- })
39
- ),
40
- routingModel: {
41
- provider: routingLLM?.getProvider(),
42
- modelId: routingLLM?.getModelId()
43
- }
44
- };
45
- })
46
- );
47
- return serializedNetworks;
48
- } catch (error) {
49
- return handleError(error, "Error getting networks");
50
- }
51
- }
52
- async function getNetworkByIdHandler({
53
- mastra,
54
- networkId,
55
- runtimeContext
56
- }) {
57
- try {
58
- const networks = mastra.getNetworks();
59
- const network = networks.find((network2) => {
60
- const routingAgent2 = network2.getRoutingAgent();
61
- return network2.formatAgentId(routingAgent2.name) === networkId;
62
- });
63
- if (!network) {
64
- throw new HTTPException(404, { message: "Network not found" });
65
- }
66
- const routingAgent = network.getRoutingAgent();
67
- const routingLLM = await routingAgent.getLLM({ runtimeContext });
68
- const agents = network.getAgents();
69
- const serializedNetwork = {
70
- id: network.formatAgentId(routingAgent.name),
71
- name: routingAgent.name,
72
- instructions: routingAgent.instructions,
73
- agents: await Promise.all(
74
- agents.map(async (agent) => {
75
- const llm = await agent.getLLM({ runtimeContext });
76
- return {
77
- name: agent.name,
78
- provider: llm?.getProvider(),
79
- modelId: llm?.getModelId()
80
- };
81
- })
82
- ),
83
- routingModel: {
84
- provider: routingLLM?.getProvider(),
85
- modelId: routingLLM?.getModelId()
86
- }
87
- };
88
- return serializedNetwork;
89
- } catch (error) {
90
- return handleError(error, "Error getting network by ID");
91
- }
92
- }
93
- async function generateHandler({
94
- mastra,
95
- runtimeContext,
96
- networkId,
97
- body
98
- }) {
99
- try {
100
- const network = mastra.getNetwork(networkId);
101
- if (!network) {
102
- throw new HTTPException(404, { message: "Network not found" });
103
- }
104
- validateBody({ messages: body.messages });
105
- const { messages, ...rest } = body;
106
- const result = await network.generate(messages, { ...rest, runtimeContext });
107
- return result;
108
- } catch (error) {
109
- return handleError(error, "Error generating from network");
110
- }
111
- }
112
- async function streamGenerateHandler({
113
- mastra,
114
- networkId,
115
- body,
116
- runtimeContext,
117
- clientSdkCompat
118
- }) {
119
- try {
120
- const network = mastra.getNetwork(networkId);
121
- if (!network) {
122
- throw new HTTPException(404, { message: "Network not found" });
123
- }
124
- validateBody({ messages: body.messages });
125
- const { messages, output, ...rest } = body;
126
- const streamResult = await network.stream(messages, {
127
- output,
128
- ...rest,
129
- runtimeContext
130
- });
131
- const useV4Compat = clientSdkCompat === "v4" || mastra.getAiSdkCompatMode() === "v4";
132
- const streamResponse = output ? streamResult.toTextStreamResponse() : streamResult.toUIMessageStreamResponse({
133
- onError: (error) => {
134
- return `An error occurred while processing your request. ${error instanceof Error ? error.message : JSON.stringify(error)}`;
135
- },
136
- sendReasoning: true,
137
- sendSources: true
138
- });
139
- return useV4Compat && !output ? createV4CompatibleResponse(streamResponse.body) : streamResponse;
140
- } catch (error) {
141
- return handleError(error, "Error streaming from network");
142
- }
143
- }
144
-
145
- export { generateHandler, getNetworkByIdHandler, getNetworksHandler, network_exports, streamGenerateHandler };
146
- //# sourceMappingURL=chunk-HXZTRBY4.js.map
147
- //# sourceMappingURL=chunk-HXZTRBY4.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../src/server/handlers/network.ts"],"names":["network","routingAgent"],"mappings":"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","file":"chunk-HXZTRBY4.js","sourcesContent":["import { createV4CompatibleResponse } from '@mastra/core/agent';\nimport type { AgentStreamOptions } from '@mastra/core/agent';\nimport type { GenerateReturn } from '@mastra/core/llm';\nimport type { AgentNetwork } from '@mastra/core/network';\nimport type { RuntimeContext } from '@mastra/core/runtime-context';\nimport { HTTPException } from '../http-exception';\nimport type { Context } from '../types';\nimport { handleError } from './error';\nimport { validateBody } from './utils';\n\ninterface NetworkContext extends Context {\n networkId?: string;\n runtimeContext: RuntimeContext;\n}\n\nexport async function getNetworksHandler({\n mastra,\n runtimeContext,\n}: Pick<NetworkContext, 'mastra' | 'runtimeContext'>) {\n try {\n const networks = mastra.getNetworks();\n\n const serializedNetworks = await Promise.all(\n networks.map(async network => {\n const routingAgent = network.getRoutingAgent();\n const routingLLM = await routingAgent.getLLM({ runtimeContext });\n const agents = network.getAgents();\n return {\n id: network.formatAgentId(routingAgent.name),\n name: routingAgent.name,\n instructions: routingAgent.instructions,\n agents: await Promise.all(\n agents.map(async agent => {\n const llm = await agent.getLLM({ runtimeContext });\n return {\n name: agent.name,\n provider: llm?.getProvider(),\n modelId: llm?.getModelId(),\n };\n }),\n ),\n routingModel: {\n provider: routingLLM?.getProvider(),\n modelId: routingLLM?.getModelId(),\n },\n };\n }),\n );\n\n return serializedNetworks;\n } catch (error) {\n return handleError(error, 'Error getting networks');\n }\n}\n\nexport async function getNetworkByIdHandler({\n mastra,\n networkId,\n runtimeContext,\n}: Pick<NetworkContext, 'mastra' | 'networkId' | 'runtimeContext'>) {\n try {\n const networks = mastra.getNetworks();\n\n const network = networks.find(network => {\n const routingAgent = network.getRoutingAgent();\n return network.formatAgentId(routingAgent.name) === networkId;\n });\n\n if (!network) {\n throw new HTTPException(404, { message: 'Network not found' });\n }\n\n const routingAgent = network.getRoutingAgent();\n const routingLLM = await routingAgent.getLLM({ runtimeContext });\n const agents = network.getAgents();\n\n const serializedNetwork = {\n id: network.formatAgentId(routingAgent.name),\n name: routingAgent.name,\n instructions: routingAgent.instructions,\n agents: await Promise.all(\n agents.map(async agent => {\n const llm = await agent.getLLM({ runtimeContext });\n return {\n name: agent.name,\n provider: llm?.getProvider(),\n modelId: llm?.getModelId(),\n };\n }),\n ),\n routingModel: {\n provider: routingLLM?.getProvider(),\n modelId: routingLLM?.getModelId(),\n },\n };\n\n return serializedNetwork;\n } catch (error) {\n return handleError(error, 'Error getting network by ID');\n }\n}\n\nexport async function generateHandler({\n mastra,\n runtimeContext,\n networkId,\n body,\n}: NetworkContext & {\n runtimeContext: RuntimeContext;\n body: { messages?: Parameters<AgentNetwork['generate']>[0] } & Parameters<AgentNetwork['generate']>[1];\n}): Promise<GenerateReturn<any>> {\n try {\n const network = mastra.getNetwork(networkId!);\n\n if (!network) {\n throw new HTTPException(404, { message: 'Network not found' });\n }\n\n validateBody({ messages: body.messages });\n\n const { messages, ...rest } = body;\n const result = await network.generate(messages!, { ...rest, runtimeContext });\n\n return result;\n } catch (error) {\n return handleError(error, 'Error generating from network');\n }\n}\n\nexport async function streamGenerateHandler({\n mastra,\n networkId,\n body,\n runtimeContext,\n clientSdkCompat,\n}: NetworkContext & {\n runtimeContext: RuntimeContext;\n body: { messages?: Parameters<AgentNetwork['stream']>[0] } & Parameters<AgentNetwork['stream']>[1];\n clientSdkCompat?: string;\n}) {\n try {\n const network = mastra.getNetwork(networkId!);\n\n if (!network) {\n throw new HTTPException(404, { message: 'Network not found' });\n }\n\n validateBody({ messages: body.messages });\n\n const { messages, output, ...rest } = body;\n const streamResult = await network.stream(messages!, {\n output: output as any,\n ...rest,\n runtimeContext,\n } as AgentStreamOptions<any, any>);\n\n // Determine compatibility mode\n // Check for client header override first, then fall back to Mastra config\n const useV4Compat = clientSdkCompat === 'v4' || mastra.getAiSdkCompatMode() === 'v4';\n\n const streamResponse = output\n ? streamResult.toTextStreamResponse()\n : streamResult.toUIMessageStreamResponse({\n onError: (error: any) => {\n return `An error occurred while processing your request. ${error instanceof Error ? error.message : JSON.stringify(error)}`;\n },\n sendReasoning: true,\n sendSources: true,\n });\n\n // Apply v4 compatibility transformation if needed\n return useV4Compat && !output ? createV4CompatibleResponse(streamResponse.body!) : streamResponse;\n } catch (error) {\n return handleError(error, 'Error streaming from network');\n }\n}\n"]}