@mastra/server 1.0.0-beta.2 → 1.0.0-beta.20

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 (394) hide show
  1. package/CHANGELOG.md +691 -0
  2. package/README.md +2 -2
  3. package/dist/chunk-3MN73W4B.cjs +326 -0
  4. package/dist/chunk-3MN73W4B.cjs.map +1 -0
  5. package/dist/chunk-3OUPQHSX.js +314 -0
  6. package/dist/chunk-3OUPQHSX.js.map +1 -0
  7. package/dist/chunk-3PZVR6W3.cjs +1117 -0
  8. package/dist/chunk-3PZVR6W3.cjs.map +1 -0
  9. package/dist/{chunk-SHWNNZBL.js → chunk-3REGEJEN.js} +13 -17
  10. package/dist/chunk-3REGEJEN.js.map +1 -0
  11. package/dist/chunk-3W67K7YE.js +13 -0
  12. package/dist/chunk-3W67K7YE.js.map +1 -0
  13. package/dist/chunk-4EYONQIW.cjs +82 -0
  14. package/dist/chunk-4EYONQIW.cjs.map +1 -0
  15. package/dist/chunk-5NFRDYFN.js +77 -0
  16. package/dist/chunk-5NFRDYFN.js.map +1 -0
  17. package/dist/chunk-5NXQ6QXL.js +116 -0
  18. package/dist/chunk-5NXQ6QXL.js.map +1 -0
  19. package/dist/chunk-5W4RPVTK.cjs +49 -0
  20. package/dist/chunk-5W4RPVTK.cjs.map +1 -0
  21. package/dist/chunk-6HKMJXTF.js +234 -0
  22. package/dist/chunk-6HKMJXTF.js.map +1 -0
  23. package/dist/{chunk-2PLXW4ZX.cjs → chunk-AQI6GLTN.cjs} +74 -74
  24. package/dist/{chunk-2PLXW4ZX.cjs.map → chunk-AQI6GLTN.cjs.map} +1 -1
  25. package/dist/chunk-AVOFMAUS.cjs +125 -0
  26. package/dist/chunk-AVOFMAUS.cjs.map +1 -0
  27. package/dist/chunk-B35F4QEM.cjs +346 -0
  28. package/dist/chunk-B35F4QEM.cjs.map +1 -0
  29. package/dist/chunk-DUZRZLVR.js +302 -0
  30. package/dist/chunk-DUZRZLVR.js.map +1 -0
  31. package/dist/chunk-DVSCJECS.js +250 -0
  32. package/dist/chunk-DVSCJECS.js.map +1 -0
  33. package/dist/chunk-EUBTCHQC.js +83 -0
  34. package/dist/chunk-EUBTCHQC.js.map +1 -0
  35. package/dist/chunk-FEEM6QFN.js +219 -0
  36. package/dist/chunk-FEEM6QFN.js.map +1 -0
  37. package/dist/chunk-FWSKVWS7.cjs +88 -0
  38. package/dist/chunk-FWSKVWS7.cjs.map +1 -0
  39. package/dist/chunk-G2AMUTU4.js +250 -0
  40. package/dist/chunk-G2AMUTU4.js.map +1 -0
  41. package/dist/chunk-G3KUL3RL.cjs +211 -0
  42. package/dist/chunk-G3KUL3RL.cjs.map +1 -0
  43. package/dist/{chunk-W2KMU354.cjs → chunk-GWLR6K3H.cjs} +23 -4
  44. package/dist/chunk-GWLR6K3H.cjs.map +1 -0
  45. package/dist/{chunk-RQK4FQUD.js → chunk-H66LLFDL.js} +4 -46
  46. package/dist/chunk-H66LLFDL.js.map +1 -0
  47. package/dist/chunk-HT4LP3BO.js +75 -0
  48. package/dist/chunk-HT4LP3BO.js.map +1 -0
  49. package/dist/chunk-IMPZBQ5U.cjs +33025 -0
  50. package/dist/chunk-IMPZBQ5U.cjs.map +1 -0
  51. package/dist/chunk-IQEVRCM6.cjs +205 -0
  52. package/dist/chunk-IQEVRCM6.cjs.map +1 -0
  53. package/dist/{chunk-FPBYKMIS.js → chunk-J6DCK7KG.js} +222 -30
  54. package/dist/chunk-J6DCK7KG.js.map +1 -0
  55. package/dist/chunk-JQPDZZLI.js +1018 -0
  56. package/dist/chunk-JQPDZZLI.js.map +1 -0
  57. package/dist/chunk-JXPRNYUC.js +279 -0
  58. package/dist/chunk-JXPRNYUC.js.map +1 -0
  59. package/dist/chunk-K3LMK4KU.js +180 -0
  60. package/dist/chunk-K3LMK4KU.js.map +1 -0
  61. package/dist/chunk-KEW7MXUS.cjs +312 -0
  62. package/dist/chunk-KEW7MXUS.cjs.map +1 -0
  63. package/dist/chunk-KXYDJIKD.cjs +1048 -0
  64. package/dist/chunk-KXYDJIKD.cjs.map +1 -0
  65. package/dist/{chunk-QU6N55W6.cjs → chunk-L2E5RUVT.cjs} +17 -21
  66. package/dist/chunk-L2E5RUVT.cjs.map +1 -0
  67. package/dist/chunk-L7ZFPOGS.js +44 -0
  68. package/dist/chunk-L7ZFPOGS.js.map +1 -0
  69. package/dist/chunk-LJ6YRVDI.cjs +15 -0
  70. package/dist/chunk-LJ6YRVDI.cjs.map +1 -0
  71. package/dist/{chunk-ZULZ2752.js → chunk-LOA7RQYO.js} +3 -3
  72. package/dist/{chunk-ZULZ2752.js.map → chunk-LOA7RQYO.js.map} +1 -1
  73. package/dist/chunk-MCYD5LW7.cjs +90 -0
  74. package/dist/chunk-MCYD5LW7.cjs.map +1 -0
  75. package/dist/chunk-OKURLPIJ.js +32986 -0
  76. package/dist/chunk-OKURLPIJ.js.map +1 -0
  77. package/dist/{chunk-UXGQZUYZ.js → chunk-ONN5EA7E.js} +13 -3
  78. package/dist/chunk-ONN5EA7E.js.map +1 -0
  79. package/dist/chunk-P3H4AZKI.cjs +252 -0
  80. package/dist/chunk-P3H4AZKI.cjs.map +1 -0
  81. package/dist/chunk-PNZQCQY4.cjs +252 -0
  82. package/dist/chunk-PNZQCQY4.cjs.map +1 -0
  83. package/dist/chunk-Q4BOUQ2O.js +1075 -0
  84. package/dist/chunk-Q4BOUQ2O.js.map +1 -0
  85. package/dist/{chunk-D7T74TVR.js → chunk-QKXZF7YS.js} +23 -4
  86. package/dist/chunk-QKXZF7YS.js.map +1 -0
  87. package/dist/chunk-R25YJP3Y.cjs +269 -0
  88. package/dist/chunk-R25YJP3Y.cjs.map +1 -0
  89. package/dist/chunk-SEP5QUTR.js +196 -0
  90. package/dist/chunk-SEP5QUTR.js.map +1 -0
  91. package/dist/{chunk-V5WWQN7P.cjs → chunk-SUKFO7UM.cjs} +13 -2
  92. package/dist/chunk-SUKFO7UM.cjs.map +1 -0
  93. package/dist/chunk-T3ZHTCEI.cjs +928 -0
  94. package/dist/chunk-T3ZHTCEI.cjs.map +1 -0
  95. package/dist/chunk-T4SPG2GP.cjs +82 -0
  96. package/dist/chunk-T4SPG2GP.cjs.map +1 -0
  97. package/dist/chunk-TOGG5Q45.js +328 -0
  98. package/dist/chunk-TOGG5Q45.js.map +1 -0
  99. package/dist/chunk-UKRDDBXY.cjs +225 -0
  100. package/dist/chunk-UKRDDBXY.cjs.map +1 -0
  101. package/dist/chunk-V3RILBZM.cjs +186 -0
  102. package/dist/chunk-V3RILBZM.cjs.map +1 -0
  103. package/dist/chunk-VJNZJAIO.cjs +289 -0
  104. package/dist/chunk-VJNZJAIO.cjs.map +1 -0
  105. package/dist/{chunk-LPM6BBAX.cjs → chunk-VX3VN7FN.cjs} +3 -54
  106. package/dist/chunk-VX3VN7FN.cjs.map +1 -0
  107. package/dist/chunk-X5KAQFOV.js +204 -0
  108. package/dist/chunk-X5KAQFOV.js.map +1 -0
  109. package/dist/chunk-XAVPSRSG.cjs +46 -0
  110. package/dist/chunk-XAVPSRSG.cjs.map +1 -0
  111. package/dist/chunk-XOUK3IYU.js +77 -0
  112. package/dist/chunk-XOUK3IYU.js.map +1 -0
  113. package/dist/chunk-XWGAT2DA.js +44 -0
  114. package/dist/chunk-XWGAT2DA.js.map +1 -0
  115. package/dist/{chunk-KJIDZQRA.cjs → chunk-Y3VSCOCE.cjs} +228 -30
  116. package/dist/chunk-Y3VSCOCE.cjs.map +1 -0
  117. package/dist/chunk-ZRBZESWG.js +903 -0
  118. package/dist/chunk-ZRBZESWG.js.map +1 -0
  119. package/dist/{dist-G2BYZJOC.cjs → dist-7NTDEVLP.cjs} +28 -28
  120. package/dist/{dist-G2BYZJOC.cjs.map → dist-7NTDEVLP.cjs.map} +1 -1
  121. package/dist/{dist-X7XR3M3Z.js → dist-B5GMANA6.js} +3 -3
  122. package/dist/{dist-X7XR3M3Z.js.map → dist-B5GMANA6.js.map} +1 -1
  123. package/dist/dist-EDO7GEGI.js +3 -0
  124. package/dist/{dist-YREX2TJT.js.map → dist-EDO7GEGI.js.map} +1 -1
  125. package/dist/{dist-RFMYFILX.cjs → dist-OF24ZMHH.cjs} +30 -30
  126. package/dist/{dist-RFMYFILX.cjs.map → dist-OF24ZMHH.cjs.map} +1 -1
  127. package/dist/{dist-4MVGNSRL.cjs → dist-P6YSNLL3.cjs} +20 -20
  128. package/dist/{dist-4MVGNSRL.cjs.map → dist-P6YSNLL3.cjs.map} +1 -1
  129. package/dist/{dist-PQZUVLPC.js → dist-SMBO5KVB.js} +3 -3
  130. package/dist/{dist-PQZUVLPC.js.map → dist-SMBO5KVB.js.map} +1 -1
  131. package/dist/{dist-XVBSOGFK.js → dist-THPMW5QR.js} +3 -3
  132. package/dist/{dist-XVBSOGFK.js.map → dist-THPMW5QR.js.map} +1 -1
  133. package/dist/{dist-FZYCV3VB.cjs → dist-VZTG56X2.cjs} +26 -26
  134. package/dist/{dist-FZYCV3VB.cjs.map → dist-VZTG56X2.cjs.map} +1 -1
  135. package/dist/dist-ZLC23RVC.cjs +16 -0
  136. package/dist/{dist-P4MXBQ3U.cjs.map → dist-ZLC23RVC.cjs.map} +1 -1
  137. package/dist/{dist-R7WYX6LC.js → dist-ZOZ6MHJH.js} +3 -3
  138. package/dist/{dist-R7WYX6LC.js.map → dist-ZOZ6MHJH.js.map} +1 -1
  139. package/dist/docs/README.md +31 -0
  140. package/dist/docs/SKILL.md +32 -0
  141. package/dist/docs/SOURCE_MAP.json +6 -0
  142. package/dist/docs/server/01-custom-adapters.md +377 -0
  143. package/dist/docs/server/02-reference.md +828 -0
  144. package/dist/server/auth/defaults.d.ts +3 -0
  145. package/dist/server/auth/defaults.d.ts.map +1 -0
  146. package/dist/server/auth/helpers.d.ts +14 -0
  147. package/dist/server/auth/helpers.d.ts.map +1 -0
  148. package/dist/server/auth/index.cjs +137 -0
  149. package/dist/server/auth/index.cjs.map +1 -0
  150. package/dist/server/auth/index.d.ts +3 -0
  151. package/dist/server/auth/index.d.ts.map +1 -0
  152. package/dist/server/auth/index.js +127 -0
  153. package/dist/server/auth/index.js.map +1 -0
  154. package/dist/server/handlers/a2a.cjs +15 -7
  155. package/dist/server/handlers/a2a.d.ts +482 -0
  156. package/dist/server/handlers/a2a.d.ts.map +1 -1
  157. package/dist/server/handlers/a2a.js +1 -1
  158. package/dist/server/handlers/agent-builder.cjs +31 -43
  159. package/dist/server/handlers/agent-builder.d.ts +624 -77
  160. package/dist/server/handlers/agent-builder.d.ts.map +1 -1
  161. package/dist/server/handlers/agent-builder.js +1 -1
  162. package/dist/server/handlers/agents.cjs +57 -37
  163. package/dist/server/handlers/agents.d.ts +3296 -131
  164. package/dist/server/handlers/agents.d.ts.map +1 -1
  165. package/dist/server/handlers/agents.js +1 -1
  166. package/dist/server/handlers/error.cjs +6 -2
  167. package/dist/server/handlers/error.d.ts +12 -0
  168. package/dist/server/handlers/error.d.ts.map +1 -1
  169. package/dist/server/handlers/error.js +1 -1
  170. package/dist/server/handlers/logs.cjs +7 -7
  171. package/dist/server/handlers/logs.d.ts +135 -27
  172. package/dist/server/handlers/logs.d.ts.map +1 -1
  173. package/dist/server/handlers/logs.js +1 -1
  174. package/dist/server/handlers/mcp.cjs +40 -0
  175. package/dist/server/handlers/mcp.cjs.map +1 -0
  176. package/dist/server/handlers/mcp.d.ts +110 -0
  177. package/dist/server/handlers/mcp.d.ts.map +1 -0
  178. package/dist/server/handlers/mcp.js +3 -0
  179. package/dist/server/handlers/mcp.js.map +1 -0
  180. package/dist/server/handlers/memory.cjs +71 -27
  181. package/dist/server/handlers/memory.d.ts +1016 -95
  182. package/dist/server/handlers/memory.d.ts.map +1 -1
  183. package/dist/server/handlers/memory.js +1 -1
  184. package/dist/server/handlers/observability.cjs +9 -9
  185. package/dist/server/handlers/observability.d.ts +146 -42
  186. package/dist/server/handlers/observability.d.ts.map +1 -1
  187. package/dist/server/handlers/observability.js +1 -1
  188. package/dist/server/handlers/scores.cjs +13 -13
  189. package/dist/server/handlers/scores.d.ts +110 -141
  190. package/dist/server/handlers/scores.d.ts.map +1 -1
  191. package/dist/server/handlers/scores.js +1 -1
  192. package/dist/server/handlers/stored-agents.cjs +28 -0
  193. package/dist/server/handlers/stored-agents.cjs.map +1 -0
  194. package/dist/server/handlers/stored-agents.d.ts +289 -0
  195. package/dist/server/handlers/stored-agents.d.ts.map +1 -0
  196. package/dist/server/handlers/stored-agents.js +3 -0
  197. package/dist/server/handlers/stored-agents.js.map +1 -0
  198. package/dist/server/handlers/system.cjs +12 -0
  199. package/dist/server/handlers/system.cjs.map +1 -0
  200. package/dist/server/handlers/system.d.ts +7 -0
  201. package/dist/server/handlers/system.d.ts.map +1 -0
  202. package/dist/server/handlers/system.js +3 -0
  203. package/dist/server/handlers/system.js.map +1 -0
  204. package/dist/server/handlers/test-utils.cjs +15 -0
  205. package/dist/server/handlers/test-utils.cjs.map +1 -0
  206. package/dist/server/handlers/test-utils.d.ts +6 -0
  207. package/dist/server/handlers/test-utils.d.ts.map +1 -0
  208. package/dist/server/handlers/test-utils.js +13 -0
  209. package/dist/server/handlers/test-utils.js.map +1 -0
  210. package/dist/server/handlers/tools.cjs +11 -11
  211. package/dist/server/handlers/tools.d.ts +69 -23
  212. package/dist/server/handlers/tools.d.ts.map +1 -1
  213. package/dist/server/handlers/tools.js +1 -1
  214. package/dist/server/handlers/utils.cjs +11 -3
  215. package/dist/server/handlers/utils.d.ts +5 -0
  216. package/dist/server/handlers/utils.d.ts.map +1 -1
  217. package/dist/server/handlers/utils.js +1 -1
  218. package/dist/server/handlers/vector.cjs +31 -7
  219. package/dist/server/handlers/vector.d.ts +93 -9
  220. package/dist/server/handlers/vector.d.ts.map +1 -1
  221. package/dist/server/handlers/vector.js +1 -1
  222. package/dist/server/handlers/voice.cjs +21 -9
  223. package/dist/server/handlers/voice.d.ts +81 -40
  224. package/dist/server/handlers/voice.d.ts.map +1 -1
  225. package/dist/server/handlers/voice.js +1 -1
  226. package/dist/server/handlers/workflows.cjs +57 -37
  227. package/dist/server/handlers/workflows.d.ts +980 -74
  228. package/dist/server/handlers/workflows.d.ts.map +1 -1
  229. package/dist/server/handlers/workflows.js +1 -1
  230. package/dist/server/handlers.cjs +36 -31
  231. package/dist/server/handlers.d.ts +1 -0
  232. package/dist/server/handlers.d.ts.map +1 -1
  233. package/dist/server/handlers.js +12 -11
  234. package/dist/server/schemas/a2a.d.ts +786 -0
  235. package/dist/server/schemas/a2a.d.ts.map +1 -0
  236. package/dist/server/schemas/agent-builder.d.ts +225 -0
  237. package/dist/server/schemas/agent-builder.d.ts.map +1 -0
  238. package/dist/server/schemas/agents.d.ts +1401 -0
  239. package/dist/server/schemas/agents.d.ts.map +1 -0
  240. package/dist/server/schemas/common.d.ts +179 -0
  241. package/dist/server/schemas/common.d.ts.map +1 -0
  242. package/dist/server/schemas/logs.d.ts +124 -0
  243. package/dist/server/schemas/logs.d.ts.map +1 -0
  244. package/dist/server/schemas/mcp.d.ts +299 -0
  245. package/dist/server/schemas/mcp.d.ts.map +1 -0
  246. package/dist/server/schemas/memory.d.ts +1128 -0
  247. package/dist/server/schemas/memory.d.ts.map +1 -0
  248. package/dist/server/schemas/scores.d.ts +259 -0
  249. package/dist/server/schemas/scores.d.ts.map +1 -0
  250. package/dist/server/schemas/stored-agents.d.ts +792 -0
  251. package/dist/server/schemas/stored-agents.d.ts.map +1 -0
  252. package/dist/server/schemas/system.d.ts +36 -0
  253. package/dist/server/schemas/system.d.ts.map +1 -0
  254. package/dist/server/schemas/vectors.d.ts +107 -0
  255. package/dist/server/schemas/vectors.d.ts.map +1 -0
  256. package/dist/server/schemas/workflows.d.ts +863 -0
  257. package/dist/server/schemas/workflows.d.ts.map +1 -0
  258. package/dist/server/server-adapter/index.cjs +510 -0
  259. package/dist/server/server-adapter/index.cjs.map +1 -0
  260. package/dist/server/server-adapter/index.d.ts +109 -0
  261. package/dist/server/server-adapter/index.d.ts.map +1 -0
  262. package/dist/server/server-adapter/index.js +482 -0
  263. package/dist/server/server-adapter/index.js.map +1 -0
  264. package/dist/server/server-adapter/openapi-utils.d.ts +59 -0
  265. package/dist/server/server-adapter/openapi-utils.d.ts.map +1 -0
  266. package/dist/server/server-adapter/redact.d.ts +26 -0
  267. package/dist/server/server-adapter/redact.d.ts.map +1 -0
  268. package/dist/server/server-adapter/routes/a2a.d.ts +3 -0
  269. package/dist/server/server-adapter/routes/a2a.d.ts.map +1 -0
  270. package/dist/server/server-adapter/routes/agent-builder.d.ts +3 -0
  271. package/dist/server/server-adapter/routes/agent-builder.d.ts.map +1 -0
  272. package/dist/server/server-adapter/routes/agents.d.ts +3 -0
  273. package/dist/server/server-adapter/routes/agents.d.ts.map +1 -0
  274. package/dist/server/server-adapter/routes/index.d.ts +50 -0
  275. package/dist/server/server-adapter/routes/index.d.ts.map +1 -0
  276. package/dist/server/server-adapter/routes/legacy.d.ts +7 -0
  277. package/dist/server/server-adapter/routes/legacy.d.ts.map +1 -0
  278. package/dist/server/server-adapter/routes/logs.d.ts +3 -0
  279. package/dist/server/server-adapter/routes/logs.d.ts.map +1 -0
  280. package/dist/server/server-adapter/routes/mcp.d.ts +9 -0
  281. package/dist/server/server-adapter/routes/mcp.d.ts.map +1 -0
  282. package/dist/server/server-adapter/routes/memory.d.ts +3 -0
  283. package/dist/server/server-adapter/routes/memory.d.ts.map +1 -0
  284. package/dist/server/server-adapter/routes/observability.d.ts +3 -0
  285. package/dist/server/server-adapter/routes/observability.d.ts.map +1 -0
  286. package/dist/server/server-adapter/routes/route-builder.d.ts +111 -0
  287. package/dist/server/server-adapter/routes/route-builder.d.ts.map +1 -0
  288. package/dist/server/server-adapter/routes/scorers.d.ts +3 -0
  289. package/dist/server/server-adapter/routes/scorers.d.ts.map +1 -0
  290. package/dist/server/server-adapter/routes/stored-agents.d.ts +8 -0
  291. package/dist/server/server-adapter/routes/stored-agents.d.ts.map +1 -0
  292. package/dist/server/server-adapter/routes/stream-types.d.ts +10 -0
  293. package/dist/server/server-adapter/routes/stream-types.d.ts.map +1 -0
  294. package/dist/server/server-adapter/routes/system.d.ts +12 -0
  295. package/dist/server/server-adapter/routes/system.d.ts.map +1 -0
  296. package/dist/server/server-adapter/routes/tools.d.ts +3 -0
  297. package/dist/server/server-adapter/routes/tools.d.ts.map +1 -0
  298. package/dist/server/server-adapter/routes/vectors.d.ts +3 -0
  299. package/dist/server/server-adapter/routes/vectors.d.ts.map +1 -0
  300. package/dist/server/server-adapter/routes/workflows.d.ts +3 -0
  301. package/dist/server/server-adapter/routes/workflows.d.ts.map +1 -0
  302. package/dist/server/utils.d.ts +1 -1
  303. package/dist/server/utils.d.ts.map +1 -1
  304. package/dist/{token-375W3LEI.cjs → token-6GSAFR2W-K2BTU23I-5WBYUIGY.cjs} +11 -12
  305. package/dist/token-6GSAFR2W-K2BTU23I-5WBYUIGY.cjs.map +1 -0
  306. package/dist/{token-C3IMNCC4.js → token-6GSAFR2W-K2BTU23I-NW33N3NU.js} +8 -9
  307. package/dist/token-6GSAFR2W-K2BTU23I-NW33N3NU.js.map +1 -0
  308. package/dist/token-6GSAFR2W-KVDFAJ2M-EPLMGMHT.cjs +63 -0
  309. package/dist/token-6GSAFR2W-KVDFAJ2M-EPLMGMHT.cjs.map +1 -0
  310. package/dist/token-6GSAFR2W-KVDFAJ2M-VW443KIA.js +61 -0
  311. package/dist/token-6GSAFR2W-KVDFAJ2M-VW443KIA.js.map +1 -0
  312. package/dist/token-6GSAFR2W-VLY2XUPA-NCSASMWN.js +61 -0
  313. package/dist/token-6GSAFR2W-VLY2XUPA-NCSASMWN.js.map +1 -0
  314. package/dist/token-6GSAFR2W-VLY2XUPA-RKITWXKR.cjs +63 -0
  315. package/dist/token-6GSAFR2W-VLY2XUPA-RKITWXKR.cjs.map +1 -0
  316. package/dist/token-util-NEHG7TUY-DJYRKLRD-6TH3ODCN.cjs +10 -0
  317. package/dist/token-util-NEHG7TUY-DJYRKLRD-6TH3ODCN.cjs.map +1 -0
  318. package/dist/token-util-NEHG7TUY-DJYRKLRD-EACKYD4V.js +8 -0
  319. package/dist/token-util-NEHG7TUY-DJYRKLRD-EACKYD4V.js.map +1 -0
  320. package/dist/token-util-NEHG7TUY-KSXDO2NO-J6DEINGO.cjs +10 -0
  321. package/dist/token-util-NEHG7TUY-KSXDO2NO-J6DEINGO.cjs.map +1 -0
  322. package/dist/token-util-NEHG7TUY-KSXDO2NO-WH6I3PH3.js +8 -0
  323. package/dist/token-util-NEHG7TUY-KSXDO2NO-WH6I3PH3.js.map +1 -0
  324. package/dist/token-util-NEHG7TUY-TIJ3LMSH-ANFISSXX.cjs +10 -0
  325. package/dist/token-util-NEHG7TUY-TIJ3LMSH-ANFISSXX.cjs.map +1 -0
  326. package/dist/token-util-NEHG7TUY-TIJ3LMSH-SGVKOKXF.js +8 -0
  327. package/dist/token-util-NEHG7TUY-TIJ3LMSH-SGVKOKXF.js.map +1 -0
  328. package/package.json +35 -10
  329. package/dist/chunk-2IS5WICF.js +0 -23036
  330. package/dist/chunk-2IS5WICF.js.map +0 -1
  331. package/dist/chunk-2YZH5PH6.cjs +0 -200
  332. package/dist/chunk-2YZH5PH6.cjs.map +0 -1
  333. package/dist/chunk-3AMNUUZF.js +0 -124
  334. package/dist/chunk-3AMNUUZF.js.map +0 -1
  335. package/dist/chunk-3F52QCI4.js +0 -192
  336. package/dist/chunk-3F52QCI4.js.map +0 -1
  337. package/dist/chunk-4JF5WXPL.js +0 -502
  338. package/dist/chunk-4JF5WXPL.js.map +0 -1
  339. package/dist/chunk-73PAWDM5.js +0 -83
  340. package/dist/chunk-73PAWDM5.js.map +0 -1
  341. package/dist/chunk-A24TSVEZ.cjs +0 -130
  342. package/dist/chunk-A24TSVEZ.cjs.map +0 -1
  343. package/dist/chunk-A2NPD5N6.cjs +0 -517
  344. package/dist/chunk-A2NPD5N6.cjs.map +0 -1
  345. package/dist/chunk-B3Z6J745.js +0 -122
  346. package/dist/chunk-B3Z6J745.js.map +0 -1
  347. package/dist/chunk-BTWIR2B7.cjs +0 -28
  348. package/dist/chunk-BTWIR2B7.cjs.map +0 -1
  349. package/dist/chunk-D7T74TVR.js.map +0 -1
  350. package/dist/chunk-EHACNWDL.cjs +0 -681
  351. package/dist/chunk-EHACNWDL.cjs.map +0 -1
  352. package/dist/chunk-FPBYKMIS.js.map +0 -1
  353. package/dist/chunk-GLAZTMX3.cjs +0 -128
  354. package/dist/chunk-GLAZTMX3.cjs.map +0 -1
  355. package/dist/chunk-ID6JYDNL.cjs +0 -23075
  356. package/dist/chunk-ID6JYDNL.cjs.map +0 -1
  357. package/dist/chunk-KF3RI45U.cjs +0 -172
  358. package/dist/chunk-KF3RI45U.cjs.map +0 -1
  359. package/dist/chunk-KJIDZQRA.cjs.map +0 -1
  360. package/dist/chunk-KWH5QBXP.js +0 -123
  361. package/dist/chunk-KWH5QBXP.js.map +0 -1
  362. package/dist/chunk-LPM6BBAX.cjs.map +0 -1
  363. package/dist/chunk-ND5OKOMT.js +0 -165
  364. package/dist/chunk-ND5OKOMT.js.map +0 -1
  365. package/dist/chunk-PPMIB3FQ.cjs +0 -88
  366. package/dist/chunk-PPMIB3FQ.cjs.map +0 -1
  367. package/dist/chunk-QU6N55W6.cjs.map +0 -1
  368. package/dist/chunk-RQK4FQUD.js.map +0 -1
  369. package/dist/chunk-S54HNARD.cjs +0 -131
  370. package/dist/chunk-S54HNARD.cjs.map +0 -1
  371. package/dist/chunk-SHWNNZBL.js.map +0 -1
  372. package/dist/chunk-SZIFSF4T.js +0 -25
  373. package/dist/chunk-SZIFSF4T.js.map +0 -1
  374. package/dist/chunk-TOCYBDP2.js +0 -46
  375. package/dist/chunk-TOCYBDP2.js.map +0 -1
  376. package/dist/chunk-UXGQZUYZ.js.map +0 -1
  377. package/dist/chunk-V5WWQN7P.cjs.map +0 -1
  378. package/dist/chunk-W2KMU354.cjs.map +0 -1
  379. package/dist/chunk-X3MICMI2.cjs +0 -620
  380. package/dist/chunk-X3MICMI2.cjs.map +0 -1
  381. package/dist/chunk-X6C7BUWN.cjs +0 -48
  382. package/dist/chunk-X6C7BUWN.cjs.map +0 -1
  383. package/dist/chunk-Z2O5YVHY.js +0 -661
  384. package/dist/chunk-Z2O5YVHY.js.map +0 -1
  385. package/dist/chunk-ZJ6KEY6H.js +0 -600
  386. package/dist/chunk-ZJ6KEY6H.js.map +0 -1
  387. package/dist/dist-P4MXBQ3U.cjs +0 -16
  388. package/dist/dist-YREX2TJT.js +0 -3
  389. package/dist/token-375W3LEI.cjs.map +0 -1
  390. package/dist/token-C3IMNCC4.js.map +0 -1
  391. package/dist/token-util-CV3RRG6K.cjs +0 -9
  392. package/dist/token-util-CV3RRG6K.cjs.map +0 -1
  393. package/dist/token-util-E5QO2RCL.js +0 -7
  394. package/dist/token-util-E5QO2RCL.js.map +0 -1
@@ -0,0 +1,180 @@
1
+ import { createRoute, wrapSchemaForQueryParams, pickParams } from './chunk-FEEM6QFN.js';
2
+ import { handleError } from './chunk-ONN5EA7E.js';
3
+ import { HTTPException } from './chunk-6QWQZI4Q.js';
4
+ import { __export } from './chunk-PR4QN5HX.js';
5
+ import { listScoresResponseSchema } from '@mastra/core/evals';
6
+ import { scoreTraces } from '@mastra/core/evals/scoreTraces';
7
+ import { dateRangeSchema, listTracesResponseSchema, tracesFilterSchema, paginationArgsSchema, tracesOrderBySchema, getTraceResponseSchema, getTraceArgsSchema, scoreTracesResponseSchema, scoreTracesRequestSchema, spanIdsSchema } from '@mastra/core/storage';
8
+ import { z } from 'zod';
9
+
10
+ // src/server/handlers/observability.ts
11
+ var observability_exports = {};
12
+ __export(observability_exports, {
13
+ GET_TRACE_ROUTE: () => GET_TRACE_ROUTE,
14
+ LIST_SCORES_BY_SPAN_ROUTE: () => LIST_SCORES_BY_SPAN_ROUTE,
15
+ LIST_TRACES_ROUTE: () => LIST_TRACES_ROUTE,
16
+ SCORE_TRACES_ROUTE: () => SCORE_TRACES_ROUTE
17
+ });
18
+ var legacyQueryParamsSchema = z.object({
19
+ // Old: dateRange was in pagination, now it's startedAt in filters
20
+ dateRange: dateRangeSchema.optional(),
21
+ // Old: name matched span names like "agent run: 'myAgent'"
22
+ name: z.string().optional(),
23
+ // entityType needs preprocessing to handle legacy 'workflow' value
24
+ entityType: z.preprocess((val) => val === "workflow" ? "workflow_run" : val, z.string().optional())
25
+ });
26
+ function transformLegacyParams(params) {
27
+ const result = { ...params };
28
+ if (result.entityType === "workflow") {
29
+ result.entityType = "workflow_run";
30
+ }
31
+ if (params.dateRange && !params.startedAt) {
32
+ result.startedAt = params.dateRange;
33
+ delete result.dateRange;
34
+ }
35
+ if (typeof params.name === "string" && !params.entityId) {
36
+ const agentMatch = params.name.match(/^agent run: '([^']+)'$/);
37
+ const workflowMatch = params.name.match(/^workflow run: '([^']+)'$/);
38
+ if (agentMatch) {
39
+ result.entityId = agentMatch[1];
40
+ result.entityType = "agent";
41
+ } else if (workflowMatch) {
42
+ result.entityId = workflowMatch[1];
43
+ result.entityType = "workflow_run";
44
+ }
45
+ delete result.name;
46
+ }
47
+ return result;
48
+ }
49
+ function getStorage(mastra) {
50
+ const storage = mastra.getStorage();
51
+ if (!storage) {
52
+ throw new HTTPException(500, { message: "Storage is not available" });
53
+ }
54
+ return storage;
55
+ }
56
+ async function getObservabilityStore(mastra) {
57
+ const storage = getStorage(mastra);
58
+ const observability = await storage.getStore("observability");
59
+ if (!observability) {
60
+ throw new HTTPException(500, { message: "Observability storage domain is not available" });
61
+ }
62
+ return observability;
63
+ }
64
+ async function getScoresStore(mastra) {
65
+ const storage = getStorage(mastra);
66
+ const scores = await storage.getStore("scores");
67
+ if (!scores) {
68
+ throw new HTTPException(500, { message: "Scores storage domain is not available" });
69
+ }
70
+ return scores;
71
+ }
72
+ var LIST_TRACES_ROUTE = createRoute({
73
+ method: "GET",
74
+ path: "/api/observability/traces",
75
+ responseType: "json",
76
+ queryParamSchema: wrapSchemaForQueryParams(
77
+ tracesFilterSchema.merge(paginationArgsSchema).merge(tracesOrderBySchema).merge(legacyQueryParamsSchema).partial()
78
+ ),
79
+ responseSchema: listTracesResponseSchema,
80
+ summary: "List traces",
81
+ description: "Returns a paginated list of traces with optional filtering and sorting",
82
+ tags: ["Observability"],
83
+ handler: async ({ mastra, ...params }) => {
84
+ try {
85
+ const transformedParams = transformLegacyParams(params);
86
+ const filters = pickParams(tracesFilterSchema, transformedParams);
87
+ const pagination = pickParams(paginationArgsSchema, transformedParams);
88
+ const orderBy = pickParams(tracesOrderBySchema, transformedParams);
89
+ const observabilityStore = await getObservabilityStore(mastra);
90
+ return await observabilityStore.listTraces({ filters, pagination, orderBy });
91
+ } catch (error) {
92
+ handleError(error, "Error listing traces");
93
+ }
94
+ }
95
+ });
96
+ var GET_TRACE_ROUTE = createRoute({
97
+ method: "GET",
98
+ path: "/api/observability/traces/:traceId",
99
+ responseType: "json",
100
+ pathParamSchema: getTraceArgsSchema,
101
+ responseSchema: getTraceResponseSchema,
102
+ summary: "Get AI trace by ID",
103
+ description: "Returns a complete AI trace with all spans by trace ID",
104
+ tags: ["Observability"],
105
+ handler: async ({ mastra, traceId }) => {
106
+ try {
107
+ const observabilityStore = await getObservabilityStore(mastra);
108
+ const trace = await observabilityStore.getTrace({ traceId });
109
+ if (!trace) {
110
+ throw new HTTPException(404, { message: `Trace with ID '${traceId}' not found` });
111
+ }
112
+ return trace;
113
+ } catch (error) {
114
+ handleError(error, "Error getting trace");
115
+ }
116
+ }
117
+ });
118
+ var SCORE_TRACES_ROUTE = createRoute({
119
+ method: "POST",
120
+ path: "/api/observability/traces/score",
121
+ responseType: "json",
122
+ bodySchema: scoreTracesRequestSchema,
123
+ responseSchema: scoreTracesResponseSchema,
124
+ summary: "Score traces",
125
+ description: "Scores one or more traces using a specified scorer (fire-and-forget)",
126
+ tags: ["Observability"],
127
+ handler: async ({ mastra, ...params }) => {
128
+ try {
129
+ getStorage(mastra);
130
+ const { scorerName, targets } = params;
131
+ const scorer = mastra.getScorerById(scorerName);
132
+ if (!scorer) {
133
+ throw new HTTPException(404, { message: `Scorer '${scorerName}' not found` });
134
+ }
135
+ scoreTraces({
136
+ scorerId: scorer.config.id || scorer.config.name,
137
+ targets,
138
+ mastra
139
+ }).catch((error) => {
140
+ const logger = mastra.getLogger();
141
+ logger?.error(`Background trace scoring failed: ${error.message}`, error);
142
+ });
143
+ return {
144
+ status: "success",
145
+ message: `Scoring started for ${targets.length} ${targets.length === 1 ? "trace" : "traces"}`,
146
+ traceCount: targets.length
147
+ };
148
+ } catch (error) {
149
+ handleError(error, "Error processing trace scoring");
150
+ }
151
+ }
152
+ });
153
+ var LIST_SCORES_BY_SPAN_ROUTE = createRoute({
154
+ method: "GET",
155
+ path: "/api/observability/traces/:traceId/:spanId/scores",
156
+ responseType: "json",
157
+ pathParamSchema: spanIdsSchema,
158
+ queryParamSchema: paginationArgsSchema,
159
+ responseSchema: listScoresResponseSchema,
160
+ summary: "List scores by span",
161
+ description: "Returns all scores for a specific span within a trace",
162
+ tags: ["Observability"],
163
+ handler: async ({ mastra, ...params }) => {
164
+ try {
165
+ const pagination = pickParams(paginationArgsSchema, params);
166
+ const spanIds = pickParams(spanIdsSchema, params);
167
+ const scoresStore = await getScoresStore(mastra);
168
+ return await scoresStore.listScoresBySpan({
169
+ ...spanIds,
170
+ pagination
171
+ });
172
+ } catch (error) {
173
+ handleError(error, "Error getting scores by span");
174
+ }
175
+ }
176
+ });
177
+
178
+ export { GET_TRACE_ROUTE, LIST_SCORES_BY_SPAN_ROUTE, LIST_TRACES_ROUTE, SCORE_TRACES_ROUTE, observability_exports };
179
+ //# sourceMappingURL=chunk-K3LMK4KU.js.map
180
+ //# sourceMappingURL=chunk-K3LMK4KU.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/server/handlers/observability.ts"],"names":[],"mappings":"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","file":"chunk-K3LMK4KU.js","sourcesContent":["import type { Mastra } from '@mastra/core';\nimport { listScoresResponseSchema } from '@mastra/core/evals';\nimport { scoreTraces } from '@mastra/core/evals/scoreTraces';\nimport type { MastraStorage, ScoresStorage, ObservabilityStorage } from '@mastra/core/storage';\nimport {\n tracesFilterSchema,\n tracesOrderBySchema,\n paginationArgsSchema,\n spanIdsSchema,\n listTracesResponseSchema,\n scoreTracesRequestSchema,\n scoreTracesResponseSchema,\n getTraceArgsSchema,\n getTraceResponseSchema,\n dateRangeSchema,\n} from '@mastra/core/storage';\nimport { z } from 'zod';\nimport { HTTPException } from '../http-exception';\nimport { createRoute, pickParams, wrapSchemaForQueryParams } from '../server-adapter/routes/route-builder';\nimport { handleError } from './error';\n\n// ============================================================================\n// Legacy Parameter Support (backward compatibility with main branch API)\n// ============================================================================\n\n/**\n * Legacy query parameters from the old API (main branch).\n * These are accepted for backward compatibility and transformed to new format.\n */\nconst legacyQueryParamsSchema = z.object({\n // Old: dateRange was in pagination, now it's startedAt in filters\n dateRange: dateRangeSchema.optional(),\n // Old: name matched span names like \"agent run: 'myAgent'\"\n name: z.string().optional(),\n // entityType needs preprocessing to handle legacy 'workflow' value\n entityType: z.preprocess(val => (val === 'workflow' ? 'workflow_run' : val), z.string().optional()),\n});\n\n/**\n * Transforms legacy query parameters to the new format.\n * - dateRange -> startedAt (if startedAt not already set)\n * - name=\"agent run: 'x'\" -> entityId='x', entityType='agent'\n * - name=\"workflow run: 'x'\" -> entityId='x', entityType='workflow_run'\n * - entityType='workflow' -> entityType='workflow_run' (enum value fix)\n */\nfunction transformLegacyParams(params: Record<string, unknown>): Record<string, unknown> {\n const result = { ...params };\n\n // Transform old entityType='workflow' -> 'workflow_run' (the Zod validation would have already transformed this)\n if (result.entityType === 'workflow') {\n result.entityType = 'workflow_run';\n }\n\n // Transform old dateRange -> new startedAt\n if (params.dateRange && !params.startedAt) {\n result.startedAt = params.dateRange;\n delete result.dateRange;\n }\n\n // Transform old name -> entityId + entityType\n // Old format: name matched span names like \"agent run: 'myAgent'\" or \"workflow run: 'myWorkflow'\"\n if (typeof params.name === 'string' && !params.entityId) {\n const agentMatch = params.name.match(/^agent run: '([^']+)'$/);\n const workflowMatch = params.name.match(/^workflow run: '([^']+)'$/);\n\n if (agentMatch) {\n result.entityId = agentMatch[1];\n result.entityType = 'agent';\n } else if (workflowMatch) {\n result.entityId = workflowMatch[1];\n result.entityType = 'workflow_run';\n }\n delete result.name;\n }\n\n return result;\n}\n\n// ============================================================================\n// Route Definitions (new pattern - handlers defined inline with createRoute)\n// ============================================================================\n\nfunction getStorage(mastra: Mastra): MastraStorage {\n const storage = mastra.getStorage();\n if (!storage) {\n throw new HTTPException(500, { message: 'Storage is not available' });\n }\n return storage;\n}\n\nasync function getObservabilityStore(mastra: Mastra): Promise<ObservabilityStorage> {\n const storage = getStorage(mastra);\n const observability = await storage.getStore('observability');\n if (!observability) {\n throw new HTTPException(500, { message: 'Observability storage domain is not available' });\n }\n return observability;\n}\n\nasync function getScoresStore(mastra: Mastra): Promise<ScoresStorage> {\n const storage = getStorage(mastra);\n const scores = await storage.getStore('scores');\n if (!scores) {\n throw new HTTPException(500, { message: 'Scores storage domain is not available' });\n }\n return scores;\n}\n\nexport const LIST_TRACES_ROUTE = createRoute({\n method: 'GET',\n path: '/api/observability/traces',\n responseType: 'json',\n queryParamSchema: wrapSchemaForQueryParams(\n tracesFilterSchema\n .merge(paginationArgsSchema)\n .merge(tracesOrderBySchema)\n .merge(legacyQueryParamsSchema) // Accept legacy params for backward compatibility\n .partial(),\n ),\n responseSchema: listTracesResponseSchema,\n summary: 'List traces',\n description: 'Returns a paginated list of traces with optional filtering and sorting',\n tags: ['Observability'],\n handler: async ({ mastra, ...params }) => {\n try {\n // Transform legacy params to new format before processing\n const transformedParams = transformLegacyParams(params);\n\n const filters = pickParams(tracesFilterSchema, transformedParams);\n const pagination = pickParams(paginationArgsSchema, transformedParams);\n const orderBy = pickParams(tracesOrderBySchema, transformedParams);\n\n const observabilityStore = await getObservabilityStore(mastra);\n return await observabilityStore.listTraces({ filters, pagination, orderBy });\n } catch (error) {\n handleError(error, 'Error listing traces');\n }\n },\n});\n\nexport const GET_TRACE_ROUTE = createRoute({\n method: 'GET',\n path: '/api/observability/traces/:traceId',\n responseType: 'json',\n pathParamSchema: getTraceArgsSchema,\n responseSchema: getTraceResponseSchema,\n summary: 'Get AI trace by ID',\n description: 'Returns a complete AI trace with all spans by trace ID',\n tags: ['Observability'],\n handler: async ({ mastra, traceId }) => {\n try {\n const observabilityStore = await getObservabilityStore(mastra);\n const trace = await observabilityStore.getTrace({ traceId });\n\n if (!trace) {\n throw new HTTPException(404, { message: `Trace with ID '${traceId}' not found` });\n }\n\n return trace;\n } catch (error) {\n handleError(error, 'Error getting trace');\n }\n },\n});\n\nexport const SCORE_TRACES_ROUTE = createRoute({\n method: 'POST',\n path: '/api/observability/traces/score',\n responseType: 'json',\n bodySchema: scoreTracesRequestSchema,\n responseSchema: scoreTracesResponseSchema,\n summary: 'Score traces',\n description: 'Scores one or more traces using a specified scorer (fire-and-forget)',\n tags: ['Observability'],\n handler: async ({ mastra, ...params }) => {\n try {\n // Validate storage exists before starting background task\n getStorage(mastra);\n\n const { scorerName, targets } = params;\n\n const scorer = mastra.getScorerById(scorerName);\n if (!scorer) {\n throw new HTTPException(404, { message: `Scorer '${scorerName}' not found` });\n }\n\n scoreTraces({\n scorerId: scorer.config.id || scorer.config.name,\n targets,\n mastra,\n }).catch(error => {\n const logger = mastra.getLogger();\n logger?.error(`Background trace scoring failed: ${error.message}`, error);\n });\n\n return {\n status: 'success',\n message: `Scoring started for ${targets.length} ${targets.length === 1 ? 'trace' : 'traces'}`,\n traceCount: targets.length,\n };\n } catch (error) {\n handleError(error, 'Error processing trace scoring');\n }\n },\n});\n\nexport const LIST_SCORES_BY_SPAN_ROUTE = createRoute({\n method: 'GET',\n path: '/api/observability/traces/:traceId/:spanId/scores',\n responseType: 'json',\n pathParamSchema: spanIdsSchema,\n queryParamSchema: paginationArgsSchema,\n responseSchema: listScoresResponseSchema,\n summary: 'List scores by span',\n description: 'Returns all scores for a specific span within a trace',\n tags: ['Observability'],\n handler: async ({ mastra, ...params }) => {\n try {\n const pagination = pickParams(paginationArgsSchema, params);\n const spanIds = pickParams(spanIdsSchema, params);\n\n const scoresStore = await getScoresStore(mastra);\n\n return await scoresStore.listScoresBySpan({\n ...spanIds,\n pagination,\n });\n } catch (error) {\n handleError(error, 'Error getting scores by span');\n }\n },\n});\n"]}
@@ -0,0 +1,312 @@
1
+ 'use strict';
2
+
3
+ var chunkMCYD5LW7_cjs = require('./chunk-MCYD5LW7.cjs');
4
+ var chunkUKRDDBXY_cjs = require('./chunk-UKRDDBXY.cjs');
5
+ var chunk64ITUOXI_cjs = require('./chunk-64ITUOXI.cjs');
6
+ var chunkO7I5CWRX_cjs = require('./chunk-O7I5CWRX.cjs');
7
+ var zod = require('zod');
8
+
9
+ // src/server/handlers/mcp.ts
10
+ var mcp_exports = {};
11
+ chunkO7I5CWRX_cjs.__export(mcp_exports, {
12
+ EXECUTE_MCP_SERVER_TOOL_ROUTE: () => EXECUTE_MCP_SERVER_TOOL_ROUTE,
13
+ GET_MCP_SERVER_DETAIL_ROUTE: () => GET_MCP_SERVER_DETAIL_ROUTE,
14
+ GET_MCP_SERVER_TOOL_DETAIL_ROUTE: () => GET_MCP_SERVER_TOOL_DETAIL_ROUTE,
15
+ LIST_MCP_SERVERS_ROUTE: () => LIST_MCP_SERVERS_ROUTE,
16
+ LIST_MCP_SERVER_TOOLS_ROUTE: () => LIST_MCP_SERVER_TOOLS_ROUTE,
17
+ MCP_HTTP_TRANSPORT_ROUTE: () => MCP_HTTP_TRANSPORT_ROUTE,
18
+ MCP_SSE_MESSAGES_ROUTE: () => MCP_SSE_MESSAGES_ROUTE,
19
+ MCP_SSE_TRANSPORT_ROUTE: () => MCP_SSE_TRANSPORT_ROUTE
20
+ });
21
+ var mcpServerIdPathParams = zod.z.object({
22
+ serverId: zod.z.string().describe("MCP server ID")
23
+ });
24
+ var mcpServerDetailPathParams = zod.z.object({
25
+ id: zod.z.string().describe("MCP server ID")
26
+ });
27
+ var mcpServerToolPathParams = zod.z.object({
28
+ serverId: zod.z.string().describe("MCP server ID"),
29
+ toolId: zod.z.string().describe("Tool ID")
30
+ });
31
+ var executeToolBodySchema = zod.z.object({
32
+ data: zod.z.unknown().optional()
33
+ });
34
+ var listMcpServersQuerySchema = chunkMCYD5LW7_cjs.createCombinedPaginationSchema();
35
+ var getMcpServerDetailQuerySchema = zod.z.object({
36
+ version: zod.z.string().optional()
37
+ });
38
+ var versionDetailSchema = zod.z.object({
39
+ version: zod.z.string(),
40
+ release_date: zod.z.string(),
41
+ is_latest: zod.z.boolean()
42
+ });
43
+ var serverInfoSchema = zod.z.object({
44
+ id: zod.z.string(),
45
+ name: zod.z.string(),
46
+ version_detail: versionDetailSchema
47
+ });
48
+ var listMcpServersResponseSchema = zod.z.object({
49
+ servers: zod.z.array(serverInfoSchema),
50
+ total_count: zod.z.number(),
51
+ next: zod.z.string().nullable()
52
+ });
53
+ var serverDetailSchema = zod.z.object({
54
+ id: zod.z.string(),
55
+ name: zod.z.string(),
56
+ description: zod.z.string().optional(),
57
+ version_detail: versionDetailSchema,
58
+ package_canonical: zod.z.string().optional(),
59
+ packages: zod.z.array(zod.z.unknown()).optional(),
60
+ remotes: zod.z.array(zod.z.unknown()).optional()
61
+ });
62
+ var mcpToolInfoSchema = zod.z.object({
63
+ name: zod.z.string(),
64
+ description: zod.z.string().optional(),
65
+ inputSchema: zod.z.unknown(),
66
+ outputSchema: zod.z.unknown().optional(),
67
+ toolType: zod.z.string().optional()
68
+ });
69
+ var listMcpServerToolsResponseSchema = zod.z.object({
70
+ tools: zod.z.array(mcpToolInfoSchema)
71
+ });
72
+ var executeToolResponseSchema = zod.z.object({
73
+ result: zod.z.unknown()
74
+ });
75
+ zod.z.object({
76
+ jsonrpc: zod.z.literal("2.0"),
77
+ error: zod.z.object({
78
+ code: zod.z.number(),
79
+ message: zod.z.string()
80
+ }),
81
+ id: zod.z.null()
82
+ });
83
+
84
+ // src/server/handlers/mcp.ts
85
+ var LIST_MCP_SERVERS_ROUTE = chunkUKRDDBXY_cjs.createRoute({
86
+ method: "GET",
87
+ path: "/api/mcp/v0/servers",
88
+ responseType: "json",
89
+ queryParamSchema: listMcpServersQuerySchema,
90
+ responseSchema: listMcpServersResponseSchema,
91
+ summary: "List MCP servers",
92
+ description: "Returns a list of registered MCP servers with pagination support",
93
+ tags: ["MCP"],
94
+ handler: async ({
95
+ mastra,
96
+ page,
97
+ perPage,
98
+ limit,
99
+ offset
100
+ }) => {
101
+ if (!mastra || typeof mastra.listMCPServers !== "function") {
102
+ throw new chunk64ITUOXI_cjs.HTTPException(500, { message: "Mastra instance or listMCPServers method not available" });
103
+ }
104
+ const servers = mastra.listMCPServers();
105
+ if (!servers) {
106
+ return { servers: [], total_count: 0, next: null };
107
+ }
108
+ const serverList = Object.values(servers);
109
+ const totalCount = serverList.length;
110
+ const useLegacyFormat = (limit !== void 0 || offset !== void 0) && page === void 0 && perPage === void 0;
111
+ const finalPerPage = perPage ?? limit;
112
+ let finalPage = page;
113
+ if (finalPage === void 0 && offset !== void 0 && finalPerPage !== void 0 && finalPerPage > 0) {
114
+ finalPage = Math.floor(offset / finalPerPage);
115
+ }
116
+ const actualOffset = finalPage !== void 0 && finalPerPage !== void 0 ? finalPage * finalPerPage : 0;
117
+ let paginatedServers = serverList;
118
+ let nextUrl = null;
119
+ if (finalPerPage !== void 0) {
120
+ paginatedServers = serverList.slice(actualOffset, actualOffset + finalPerPage);
121
+ if (actualOffset + finalPerPage < totalCount) {
122
+ const nextPage = (finalPage ?? 0) + 1;
123
+ if (useLegacyFormat) {
124
+ const nextOffset = actualOffset + finalPerPage;
125
+ nextUrl = `/api/mcp/v0/servers?limit=${finalPerPage}&offset=${nextOffset}`;
126
+ } else {
127
+ nextUrl = `/api/mcp/v0/servers?perPage=${finalPerPage}&page=${nextPage}`;
128
+ }
129
+ }
130
+ }
131
+ const serverInfoList = paginatedServers.map((server) => server.getServerInfo());
132
+ return {
133
+ servers: serverInfoList,
134
+ total_count: totalCount,
135
+ next: nextUrl
136
+ };
137
+ }
138
+ });
139
+ var GET_MCP_SERVER_DETAIL_ROUTE = chunkUKRDDBXY_cjs.createRoute({
140
+ method: "GET",
141
+ path: "/api/mcp/v0/servers/:id",
142
+ responseType: "json",
143
+ pathParamSchema: mcpServerDetailPathParams,
144
+ queryParamSchema: getMcpServerDetailQuerySchema,
145
+ responseSchema: serverDetailSchema,
146
+ summary: "Get MCP server details",
147
+ description: "Returns detailed information about a specific MCP server",
148
+ tags: ["MCP"],
149
+ handler: async ({ mastra, id, version }) => {
150
+ if (!mastra || typeof mastra.getMCPServerById !== "function") {
151
+ throw new chunk64ITUOXI_cjs.HTTPException(500, { message: "Mastra instance or getMCPServerById method not available" });
152
+ }
153
+ const server = mastra.getMCPServerById(id);
154
+ if (!server) {
155
+ throw new chunk64ITUOXI_cjs.HTTPException(404, { message: `MCP server with ID '${id}' not found` });
156
+ }
157
+ const serverDetail = server.getServerDetail();
158
+ if (version && serverDetail.version_detail.version !== version) {
159
+ throw new chunk64ITUOXI_cjs.HTTPException(404, {
160
+ message: `MCP server with ID '${id}' found, but not version '${version}'. Available version: ${serverDetail.version_detail.version}`
161
+ });
162
+ }
163
+ return serverDetail;
164
+ }
165
+ });
166
+ var LIST_MCP_SERVER_TOOLS_ROUTE = chunkUKRDDBXY_cjs.createRoute({
167
+ method: "GET",
168
+ path: "/api/mcp/:serverId/tools",
169
+ responseType: "json",
170
+ pathParamSchema: mcpServerIdPathParams,
171
+ responseSchema: listMcpServerToolsResponseSchema,
172
+ summary: "List MCP server tools",
173
+ description: "Returns a list of tools available on the specified MCP server",
174
+ tags: ["MCP"],
175
+ handler: async ({ mastra, serverId }) => {
176
+ if (!mastra || typeof mastra.getMCPServerById !== "function") {
177
+ throw new chunk64ITUOXI_cjs.HTTPException(500, { message: "Mastra instance or getMCPServerById method not available" });
178
+ }
179
+ const server = mastra.getMCPServerById(serverId);
180
+ if (!server) {
181
+ throw new chunk64ITUOXI_cjs.HTTPException(404, { message: `MCP server with ID '${serverId}' not found` });
182
+ }
183
+ if (typeof server.getToolListInfo !== "function") {
184
+ throw new chunk64ITUOXI_cjs.HTTPException(501, { message: `Server '${serverId}' cannot list tools in this way.` });
185
+ }
186
+ return server.getToolListInfo();
187
+ }
188
+ });
189
+ var GET_MCP_SERVER_TOOL_DETAIL_ROUTE = chunkUKRDDBXY_cjs.createRoute({
190
+ method: "GET",
191
+ path: "/api/mcp/:serverId/tools/:toolId",
192
+ responseType: "json",
193
+ pathParamSchema: mcpServerToolPathParams,
194
+ responseSchema: mcpToolInfoSchema,
195
+ summary: "Get MCP server tool details",
196
+ description: "Returns detailed information about a specific tool on the MCP server",
197
+ tags: ["MCP"],
198
+ handler: async ({ mastra, serverId, toolId }) => {
199
+ if (!mastra || typeof mastra.getMCPServerById !== "function") {
200
+ throw new chunk64ITUOXI_cjs.HTTPException(500, { message: "Mastra instance or getMCPServerById method not available" });
201
+ }
202
+ const server = mastra.getMCPServerById(serverId);
203
+ if (!server) {
204
+ throw new chunk64ITUOXI_cjs.HTTPException(404, { message: `MCP server with ID '${serverId}' not found` });
205
+ }
206
+ if (typeof server.getToolInfo !== "function") {
207
+ throw new chunk64ITUOXI_cjs.HTTPException(501, { message: `Server '${serverId}' cannot provide tool details in this way.` });
208
+ }
209
+ const toolInfo = server.getToolInfo(toolId);
210
+ if (!toolInfo) {
211
+ throw new chunk64ITUOXI_cjs.HTTPException(404, { message: `Tool with ID '${toolId}' not found on MCP server '${serverId}'` });
212
+ }
213
+ return toolInfo;
214
+ }
215
+ });
216
+ var EXECUTE_MCP_SERVER_TOOL_ROUTE = chunkUKRDDBXY_cjs.createRoute({
217
+ method: "POST",
218
+ path: "/api/mcp/:serverId/tools/:toolId/execute",
219
+ responseType: "json",
220
+ pathParamSchema: mcpServerToolPathParams,
221
+ bodySchema: executeToolBodySchema,
222
+ responseSchema: executeToolResponseSchema,
223
+ summary: "Execute MCP server tool",
224
+ description: "Executes a tool on the specified MCP server with the provided arguments",
225
+ tags: ["MCP"],
226
+ handler: async ({
227
+ mastra,
228
+ serverId,
229
+ toolId,
230
+ data
231
+ }) => {
232
+ if (!mastra || typeof mastra.getMCPServerById !== "function") {
233
+ throw new chunk64ITUOXI_cjs.HTTPException(500, { message: "Mastra instance or getMCPServerById method not available" });
234
+ }
235
+ const server = mastra.getMCPServerById(serverId);
236
+ if (!server) {
237
+ throw new chunk64ITUOXI_cjs.HTTPException(404, { message: `MCP server with ID '${serverId}' not found` });
238
+ }
239
+ if (typeof server.executeTool !== "function") {
240
+ throw new chunk64ITUOXI_cjs.HTTPException(501, { message: `Server '${serverId}' cannot execute tools in this way.` });
241
+ }
242
+ const result = await server.executeTool(toolId, data);
243
+ return { result };
244
+ }
245
+ });
246
+ var MCP_HTTP_TRANSPORT_ROUTE = chunkUKRDDBXY_cjs.createRoute({
247
+ method: "ALL",
248
+ path: "/api/mcp/:serverId/mcp",
249
+ responseType: "mcp-http",
250
+ pathParamSchema: mcpServerIdPathParams,
251
+ summary: "MCP HTTP Transport",
252
+ description: "Streamable HTTP transport endpoint for MCP protocol communication",
253
+ tags: ["MCP"],
254
+ handler: async ({ mastra, serverId }) => {
255
+ if (!mastra || typeof mastra.getMCPServerById !== "function") {
256
+ throw new chunk64ITUOXI_cjs.HTTPException(500, { message: "Mastra instance or getMCPServerById method not available" });
257
+ }
258
+ const server = mastra.getMCPServerById(serverId);
259
+ if (!server) {
260
+ throw new chunk64ITUOXI_cjs.HTTPException(404, { message: `MCP server '${serverId}' not found` });
261
+ }
262
+ return {
263
+ server,
264
+ httpPath: `/api/mcp/${serverId}/mcp`
265
+ };
266
+ }
267
+ });
268
+ var MCP_SSE_TRANSPORT_ROUTE = chunkUKRDDBXY_cjs.createRoute({
269
+ method: "ALL",
270
+ path: "/api/mcp/:serverId/sse",
271
+ responseType: "mcp-sse",
272
+ pathParamSchema: mcpServerIdPathParams,
273
+ summary: "MCP SSE Transport",
274
+ description: "SSE transport endpoint for MCP protocol communication",
275
+ tags: ["MCP"],
276
+ handler: async ({ mastra, serverId }) => {
277
+ if (!mastra || typeof mastra.getMCPServerById !== "function") {
278
+ throw new chunk64ITUOXI_cjs.HTTPException(500, { message: "Mastra instance or getMCPServerById method not available" });
279
+ }
280
+ const server = mastra.getMCPServerById(serverId);
281
+ if (!server) {
282
+ throw new chunk64ITUOXI_cjs.HTTPException(404, { message: `MCP server '${serverId}' not found` });
283
+ }
284
+ return {
285
+ server,
286
+ ssePath: `/api/mcp/${serverId}/sse`,
287
+ messagePath: `/api/mcp/${serverId}/messages`
288
+ };
289
+ }
290
+ });
291
+ var MCP_SSE_MESSAGES_ROUTE = chunkUKRDDBXY_cjs.createRoute({
292
+ method: "POST",
293
+ path: "/api/mcp/:serverId/messages",
294
+ responseType: "mcp-sse",
295
+ pathParamSchema: mcpServerIdPathParams,
296
+ summary: "MCP SSE Messages",
297
+ description: "Message endpoint for SSE transport (posts messages to active SSE streams)",
298
+ tags: ["MCP"],
299
+ handler: MCP_SSE_TRANSPORT_ROUTE.handler
300
+ });
301
+
302
+ exports.EXECUTE_MCP_SERVER_TOOL_ROUTE = EXECUTE_MCP_SERVER_TOOL_ROUTE;
303
+ exports.GET_MCP_SERVER_DETAIL_ROUTE = GET_MCP_SERVER_DETAIL_ROUTE;
304
+ exports.GET_MCP_SERVER_TOOL_DETAIL_ROUTE = GET_MCP_SERVER_TOOL_DETAIL_ROUTE;
305
+ exports.LIST_MCP_SERVERS_ROUTE = LIST_MCP_SERVERS_ROUTE;
306
+ exports.LIST_MCP_SERVER_TOOLS_ROUTE = LIST_MCP_SERVER_TOOLS_ROUTE;
307
+ exports.MCP_HTTP_TRANSPORT_ROUTE = MCP_HTTP_TRANSPORT_ROUTE;
308
+ exports.MCP_SSE_MESSAGES_ROUTE = MCP_SSE_MESSAGES_ROUTE;
309
+ exports.MCP_SSE_TRANSPORT_ROUTE = MCP_SSE_TRANSPORT_ROUTE;
310
+ exports.mcp_exports = mcp_exports;
311
+ //# sourceMappingURL=chunk-KEW7MXUS.cjs.map
312
+ //# sourceMappingURL=chunk-KEW7MXUS.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/server/handlers/mcp.ts","../src/server/schemas/mcp.ts"],"names":["__export","z","createCombinedPaginationSchema","createRoute","HTTPException"],"mappings":"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","file":"chunk-KEW7MXUS.cjs","sourcesContent":["import type { MCPServerBase as MastraMCPServerImplementation, ServerInfo } from '@mastra/core/mcp';\nimport { HTTPException } from '../http-exception';\nimport {\n mcpServerDetailPathParams,\n mcpServerToolPathParams,\n executeToolBodySchema,\n listMcpServersQuerySchema,\n getMcpServerDetailQuerySchema,\n listMcpServersResponseSchema,\n serverDetailSchema,\n mcpServerIdPathParams,\n listMcpServerToolsResponseSchema,\n mcpToolInfoSchema,\n executeToolResponseSchema,\n} from '../schemas/mcp';\nimport type { ServerContext } from '../server-adapter';\nimport { createRoute } from '../server-adapter/routes/route-builder';\n\n// ============================================================================\n// Route Definitions (createRoute pattern for server adapters)\n// ============================================================================\n\nexport const LIST_MCP_SERVERS_ROUTE = createRoute({\n method: 'GET',\n path: '/api/mcp/v0/servers',\n responseType: 'json',\n queryParamSchema: listMcpServersQuerySchema,\n responseSchema: listMcpServersResponseSchema,\n summary: 'List MCP servers',\n description: 'Returns a list of registered MCP servers with pagination support',\n tags: ['MCP'],\n handler: async ({\n mastra,\n page,\n perPage,\n limit,\n offset,\n }: ServerContext & { page?: number; perPage?: number; limit?: number; offset?: number }) => {\n if (!mastra || typeof mastra.listMCPServers !== 'function') {\n throw new HTTPException(500, { message: 'Mastra instance or listMCPServers method not available' });\n }\n\n const servers = mastra.listMCPServers();\n\n if (!servers) {\n return { servers: [], total_count: 0, next: null };\n }\n\n const serverList = Object.values(servers) as MastraMCPServerImplementation[];\n const totalCount = serverList.length;\n\n // Support both page/perPage and limit/offset for backwards compatibility\n // Detect which format user is using - prefer page/perPage if both provided\n const useLegacyFormat =\n (limit !== undefined || offset !== undefined) && page === undefined && perPage === undefined;\n\n // If perPage provided, use it; otherwise fall back to limit\n const finalPerPage = perPage ?? limit;\n // If page provided, use it; otherwise convert from offset\n let finalPage = page;\n if (finalPage === undefined && offset !== undefined && finalPerPage !== undefined && finalPerPage > 0) {\n finalPage = Math.floor(offset / finalPerPage);\n }\n\n // Calculate offset from page/perPage\n const actualOffset = finalPage !== undefined && finalPerPage !== undefined ? finalPage * finalPerPage : 0;\n\n // Apply pagination\n let paginatedServers = serverList;\n let nextUrl: string | null = null;\n\n if (finalPerPage !== undefined) {\n paginatedServers = serverList.slice(actualOffset, actualOffset + finalPerPage);\n\n // Calculate next URL if there are more results\n if (actualOffset + finalPerPage < totalCount) {\n const nextPage = (finalPage ?? 0) + 1;\n // Return next URL in same format as request (legacy limit/offset or page/perPage)\n if (useLegacyFormat) {\n const nextOffset = actualOffset + finalPerPage;\n nextUrl = `/api/mcp/v0/servers?limit=${finalPerPage}&offset=${nextOffset}`;\n } else {\n nextUrl = `/api/mcp/v0/servers?perPage=${finalPerPage}&page=${nextPage}`;\n }\n }\n }\n\n // Get server info for each server\n const serverInfoList: ServerInfo[] = paginatedServers.map(server => server.getServerInfo());\n\n return {\n servers: serverInfoList,\n total_count: totalCount,\n next: nextUrl,\n };\n },\n});\n\nexport const GET_MCP_SERVER_DETAIL_ROUTE = createRoute({\n method: 'GET',\n path: '/api/mcp/v0/servers/:id',\n responseType: 'json',\n pathParamSchema: mcpServerDetailPathParams,\n queryParamSchema: getMcpServerDetailQuerySchema,\n responseSchema: serverDetailSchema,\n summary: 'Get MCP server details',\n description: 'Returns detailed information about a specific MCP server',\n tags: ['MCP'],\n handler: async ({ mastra, id, version }: ServerContext & { id: string; version?: string }) => {\n if (!mastra || typeof mastra.getMCPServerById !== 'function') {\n throw new HTTPException(500, { message: 'Mastra instance or getMCPServerById method not available' });\n }\n\n const server = mastra.getMCPServerById(id);\n\n if (!server) {\n throw new HTTPException(404, { message: `MCP server with ID '${id}' not found` });\n }\n\n const serverDetail = server.getServerDetail();\n\n // If a specific version was requested, check if it matches\n if (version && serverDetail.version_detail.version !== version) {\n throw new HTTPException(404, {\n message: `MCP server with ID '${id}' found, but not version '${version}'. Available version: ${serverDetail.version_detail.version}`,\n });\n }\n\n return serverDetail;\n },\n});\n\nexport const LIST_MCP_SERVER_TOOLS_ROUTE = createRoute({\n method: 'GET',\n path: '/api/mcp/:serverId/tools',\n responseType: 'json',\n pathParamSchema: mcpServerIdPathParams,\n responseSchema: listMcpServerToolsResponseSchema,\n summary: 'List MCP server tools',\n description: 'Returns a list of tools available on the specified MCP server',\n tags: ['MCP'],\n handler: async ({ mastra, serverId }: ServerContext & { serverId: string }) => {\n if (!mastra || typeof mastra.getMCPServerById !== 'function') {\n throw new HTTPException(500, { message: 'Mastra instance or getMCPServerById method not available' });\n }\n\n const server = mastra.getMCPServerById(serverId);\n\n if (!server) {\n throw new HTTPException(404, { message: `MCP server with ID '${serverId}' not found` });\n }\n\n if (typeof server.getToolListInfo !== 'function') {\n throw new HTTPException(501, { message: `Server '${serverId}' cannot list tools in this way.` });\n }\n\n return server.getToolListInfo();\n },\n});\n\nexport const GET_MCP_SERVER_TOOL_DETAIL_ROUTE = createRoute({\n method: 'GET',\n path: '/api/mcp/:serverId/tools/:toolId',\n responseType: 'json',\n pathParamSchema: mcpServerToolPathParams,\n responseSchema: mcpToolInfoSchema,\n summary: 'Get MCP server tool details',\n description: 'Returns detailed information about a specific tool on the MCP server',\n tags: ['MCP'],\n handler: async ({ mastra, serverId, toolId }: ServerContext & { serverId: string; toolId: string }) => {\n if (!mastra || typeof mastra.getMCPServerById !== 'function') {\n throw new HTTPException(500, { message: 'Mastra instance or getMCPServerById method not available' });\n }\n\n const server = mastra.getMCPServerById(serverId);\n\n if (!server) {\n throw new HTTPException(404, { message: `MCP server with ID '${serverId}' not found` });\n }\n\n if (typeof server.getToolInfo !== 'function') {\n throw new HTTPException(501, { message: `Server '${serverId}' cannot provide tool details in this way.` });\n }\n\n const toolInfo = server.getToolInfo(toolId);\n if (!toolInfo) {\n throw new HTTPException(404, { message: `Tool with ID '${toolId}' not found on MCP server '${serverId}'` });\n }\n\n return toolInfo;\n },\n});\n\nexport const EXECUTE_MCP_SERVER_TOOL_ROUTE = createRoute({\n method: 'POST',\n path: '/api/mcp/:serverId/tools/:toolId/execute',\n responseType: 'json',\n pathParamSchema: mcpServerToolPathParams,\n bodySchema: executeToolBodySchema,\n responseSchema: executeToolResponseSchema,\n summary: 'Execute MCP server tool',\n description: 'Executes a tool on the specified MCP server with the provided arguments',\n tags: ['MCP'],\n handler: async ({\n mastra,\n serverId,\n toolId,\n data,\n }: ServerContext & { serverId: string; toolId: string; data?: unknown }) => {\n if (!mastra || typeof mastra.getMCPServerById !== 'function') {\n throw new HTTPException(500, { message: 'Mastra instance or getMCPServerById method not available' });\n }\n\n const server = mastra.getMCPServerById(serverId);\n\n if (!server) {\n throw new HTTPException(404, { message: `MCP server with ID '${serverId}' not found` });\n }\n\n if (typeof server.executeTool !== 'function') {\n throw new HTTPException(501, { message: `Server '${serverId}' cannot execute tools in this way.` });\n }\n\n const result = await server.executeTool(toolId, data);\n return { result };\n },\n});\n\n// ============================================================================\n// MCP Transport Routes (Streamable HTTP and SSE)\n// ============================================================================\n\n/**\n * MCP HTTP Transport response type.\n * Adapters use this to set up the HTTP transport via MCPServer.startHTTP()\n */\nexport interface MCPHttpTransportResult {\n server: MastraMCPServerImplementation;\n httpPath: string;\n}\n\n/**\n * MCP SSE Transport response type.\n * Adapters use this to set up the SSE transport via MCPServer.startSSE() or startHonoSSE()\n */\nexport interface MCPSseTransportResult {\n server: MastraMCPServerImplementation;\n ssePath: string;\n messagePath: string;\n}\n\nexport const MCP_HTTP_TRANSPORT_ROUTE = createRoute({\n method: 'ALL',\n path: '/api/mcp/:serverId/mcp',\n responseType: 'mcp-http',\n pathParamSchema: mcpServerIdPathParams,\n summary: 'MCP HTTP Transport',\n description: 'Streamable HTTP transport endpoint for MCP protocol communication',\n tags: ['MCP'],\n handler: async ({ mastra, serverId }: ServerContext & { serverId: string }): Promise<MCPHttpTransportResult> => {\n if (!mastra || typeof mastra.getMCPServerById !== 'function') {\n throw new HTTPException(500, { message: 'Mastra instance or getMCPServerById method not available' });\n }\n\n const server = mastra.getMCPServerById(serverId);\n\n if (!server) {\n throw new HTTPException(404, { message: `MCP server '${serverId}' not found` });\n }\n\n return {\n server,\n httpPath: `/api/mcp/${serverId}/mcp`,\n };\n },\n});\n\nexport const MCP_SSE_TRANSPORT_ROUTE = createRoute({\n method: 'ALL',\n path: '/api/mcp/:serverId/sse',\n responseType: 'mcp-sse',\n pathParamSchema: mcpServerIdPathParams,\n summary: 'MCP SSE Transport',\n description: 'SSE transport endpoint for MCP protocol communication',\n tags: ['MCP'],\n handler: async ({ mastra, serverId }: ServerContext & { serverId: string }): Promise<MCPSseTransportResult> => {\n if (!mastra || typeof mastra.getMCPServerById !== 'function') {\n throw new HTTPException(500, { message: 'Mastra instance or getMCPServerById method not available' });\n }\n\n const server = mastra.getMCPServerById(serverId);\n\n if (!server) {\n throw new HTTPException(404, { message: `MCP server '${serverId}' not found` });\n }\n\n return {\n server,\n ssePath: `/api/mcp/${serverId}/sse`,\n messagePath: `/api/mcp/${serverId}/messages`,\n };\n },\n});\n\nexport const MCP_SSE_MESSAGES_ROUTE = createRoute({\n method: 'POST',\n path: '/api/mcp/:serverId/messages',\n responseType: 'mcp-sse',\n pathParamSchema: mcpServerIdPathParams,\n summary: 'MCP SSE Messages',\n description: 'Message endpoint for SSE transport (posts messages to active SSE streams)',\n tags: ['MCP'],\n handler: MCP_SSE_TRANSPORT_ROUTE.handler,\n});\n","import { z } from 'zod';\nimport { createCombinedPaginationSchema } from './common';\n\n// Path parameters\nexport const mcpServerIdPathParams = z.object({\n serverId: z.string().describe('MCP server ID'),\n});\n\nexport const mcpServerDetailPathParams = z.object({\n id: z.string().describe('MCP server ID'),\n});\n\nexport const mcpServerToolPathParams = z.object({\n serverId: z.string().describe('MCP server ID'),\n toolId: z.string().describe('Tool ID'),\n});\n\nexport const executeToolBodySchema = z.object({\n data: z.unknown().optional(),\n});\n\n// Query parameters\n// Supports both page/perPage and limit/offset for backwards compatibility\nexport const listMcpServersQuerySchema = createCombinedPaginationSchema();\n\nexport const getMcpServerDetailQuerySchema = z.object({\n version: z.string().optional(),\n});\n\n// Response schemas\nexport const versionDetailSchema = z.object({\n version: z.string(),\n release_date: z.string(),\n is_latest: z.boolean(),\n});\n\nexport const serverInfoSchema = z.object({\n id: z.string(),\n name: z.string(),\n version_detail: versionDetailSchema,\n});\n\nexport const listMcpServersResponseSchema = z.object({\n servers: z.array(serverInfoSchema),\n total_count: z.number(),\n next: z.string().nullable(),\n});\n\nexport const serverDetailSchema = z.object({\n id: z.string(),\n name: z.string(),\n description: z.string().optional(),\n version_detail: versionDetailSchema,\n package_canonical: z.string().optional(),\n packages: z.array(z.unknown()).optional(),\n remotes: z.array(z.unknown()).optional(),\n});\n\n// Tool schemas\nexport const mcpToolInfoSchema = z.object({\n name: z.string(),\n description: z.string().optional(),\n inputSchema: z.unknown(),\n outputSchema: z.unknown().optional(),\n toolType: z.string().optional(),\n});\n\nexport const listMcpServerToolsResponseSchema = z.object({\n tools: z.array(mcpToolInfoSchema),\n});\n\nexport const executeToolResponseSchema = z.object({\n result: z.unknown(),\n});\n\n// JSON-RPC error response schema\nexport const jsonRpcErrorSchema = z.object({\n jsonrpc: z.literal('2.0'),\n error: z.object({\n code: z.number(),\n message: z.string(),\n }),\n id: z.null(),\n});\n"]}