@mastra/core 1.7.0 → 1.8.0

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 (498) hide show
  1. package/CHANGELOG.md +218 -0
  2. package/dist/agent/agent-legacy.d.ts +15 -0
  3. package/dist/agent/agent-legacy.d.ts.map +1 -1
  4. package/dist/agent/agent.d.ts +7 -0
  5. package/dist/agent/agent.d.ts.map +1 -1
  6. package/dist/agent/agent.types.d.ts +311 -2
  7. package/dist/agent/agent.types.d.ts.map +1 -1
  8. package/dist/agent/index.cjs +13 -13
  9. package/dist/agent/index.d.ts +3 -1
  10. package/dist/agent/index.d.ts.map +1 -1
  11. package/dist/agent/index.js +2 -2
  12. package/dist/agent/message-list/index.cjs +18 -18
  13. package/dist/agent/message-list/index.js +1 -1
  14. package/dist/agent/message-list/merge/MessageMerger.d.ts.map +1 -1
  15. package/dist/agent/message-list/message-list.d.ts.map +1 -1
  16. package/dist/agent/workflows/prepare-stream/map-results-step.d.ts.map +1 -1
  17. package/dist/agent/workflows/prepare-stream/prepare-tools-step.d.ts.map +1 -1
  18. package/dist/{chunk-A72NTLFT.cjs → chunk-2IO5Q7OZ.cjs} +7 -7
  19. package/dist/{chunk-A72NTLFT.cjs.map → chunk-2IO5Q7OZ.cjs.map} +1 -1
  20. package/dist/{chunk-DFCRXDVK.js → chunk-2KHPZJNU.js} +10 -8
  21. package/dist/chunk-2KHPZJNU.js.map +1 -0
  22. package/dist/{chunk-R4N65TLG.js → chunk-2R5MQMSA.js} +35 -16
  23. package/dist/chunk-2R5MQMSA.js.map +1 -0
  24. package/dist/{chunk-ZSBM2SVU.js → chunk-4H5F6AFP.js} +1064 -226
  25. package/dist/chunk-4H5F6AFP.js.map +1 -0
  26. package/dist/{chunk-BQHWJLXU.js → chunk-63G75DJE.js} +9 -3
  27. package/dist/chunk-63G75DJE.js.map +1 -0
  28. package/dist/{chunk-SBOHDNIZ.cjs → chunk-6GSWC5ZA.cjs} +2 -2
  29. package/dist/{chunk-SBOHDNIZ.cjs.map → chunk-6GSWC5ZA.cjs.map} +1 -1
  30. package/dist/{chunk-QTAS3HND.cjs → chunk-6Q2UD3XF.cjs} +21 -14
  31. package/dist/chunk-6Q2UD3XF.cjs.map +1 -0
  32. package/dist/{chunk-GPJGPARM.js → chunk-DTPR3JAM.js} +2 -2
  33. package/dist/{chunk-GPJGPARM.js.map → chunk-DTPR3JAM.js.map} +1 -1
  34. package/dist/{chunk-NN26FSKL.js → chunk-FHJ2KIU5.js} +3 -3
  35. package/dist/{chunk-NN26FSKL.js.map → chunk-FHJ2KIU5.js.map} +1 -1
  36. package/dist/{chunk-RABITNTG.cjs → chunk-HWG7NPJA.cjs} +55 -55
  37. package/dist/{chunk-RABITNTG.cjs.map → chunk-HWG7NPJA.cjs.map} +1 -1
  38. package/dist/{chunk-HB6T4554.cjs → chunk-KH3G65IS.cjs} +10 -8
  39. package/dist/chunk-KH3G65IS.cjs.map +1 -0
  40. package/dist/{chunk-YQG7NBPR.cjs → chunk-KZ4IKNPN.cjs} +25 -23
  41. package/dist/chunk-KZ4IKNPN.cjs.map +1 -0
  42. package/dist/{chunk-6DUTLERJ.js → chunk-MRV5NCPC.js} +3 -3
  43. package/dist/{chunk-6DUTLERJ.js.map → chunk-MRV5NCPC.js.map} +1 -1
  44. package/dist/{chunk-O7PZ4VOO.cjs → chunk-N3ROEJG4.cjs} +12 -10
  45. package/dist/chunk-N3ROEJG4.cjs.map +1 -0
  46. package/dist/{chunk-7EXW4AAG.js → chunk-NXKI2L4X.js} +6 -4
  47. package/dist/chunk-NXKI2L4X.js.map +1 -0
  48. package/dist/{chunk-QWTB53GS.js → chunk-OSEPGSLN.js} +6 -6
  49. package/dist/{chunk-QWTB53GS.js.map → chunk-OSEPGSLN.js.map} +1 -1
  50. package/dist/{chunk-6OXW5E2O.js → chunk-PI7ONENO.js} +4 -4
  51. package/dist/{chunk-6OXW5E2O.js.map → chunk-PI7ONENO.js.map} +1 -1
  52. package/dist/{chunk-KUXNBWN7.js → chunk-Q4MV4XKX.js} +8 -6
  53. package/dist/chunk-Q4MV4XKX.js.map +1 -0
  54. package/dist/{chunk-7UAJ6LMR.cjs → chunk-QKQGKEN7.cjs} +1078 -241
  55. package/dist/chunk-QKQGKEN7.cjs.map +1 -0
  56. package/dist/{chunk-IC5OUWKJ.js → chunk-SP7P6Z4L.js} +19 -2
  57. package/dist/chunk-SP7P6Z4L.js.map +1 -0
  58. package/dist/{chunk-QDH6MVJ7.cjs → chunk-TGUDI64A.cjs} +14 -14
  59. package/dist/{chunk-QDH6MVJ7.cjs.map → chunk-TGUDI64A.cjs.map} +1 -1
  60. package/dist/{chunk-EAZ6YDCQ.cjs → chunk-U3HBG2GU.cjs} +9 -2
  61. package/dist/chunk-U3HBG2GU.cjs.map +1 -0
  62. package/dist/{chunk-6QBN6MZY.cjs → chunk-VAKB5EXJ.cjs} +42 -23
  63. package/dist/chunk-VAKB5EXJ.cjs.map +1 -0
  64. package/dist/{chunk-QSHV7GPT.js → chunk-VBPU6CLZ.js} +3808 -3026
  65. package/dist/chunk-VBPU6CLZ.js.map +1 -0
  66. package/dist/{chunk-2X66GWF5.cjs → chunk-VTVCMIAI.cjs} +3905 -3121
  67. package/dist/chunk-VTVCMIAI.cjs.map +1 -0
  68. package/dist/{chunk-PHHJLGZU.cjs → chunk-XNWF6CYR.cjs} +6 -6
  69. package/dist/{chunk-PHHJLGZU.cjs.map → chunk-XNWF6CYR.cjs.map} +1 -1
  70. package/dist/{chunk-T6GAM3SQ.js → chunk-ZRPTWYWJ.js} +18 -11
  71. package/dist/chunk-ZRPTWYWJ.js.map +1 -0
  72. package/dist/{chunk-DB7U2C5B.cjs → chunk-ZXOWG32X.cjs} +19 -2
  73. package/dist/chunk-ZXOWG32X.cjs.map +1 -0
  74. package/dist/datasets/experiment/index.d.ts.map +1 -1
  75. package/dist/datasets/experiment/scorer.d.ts +1 -1
  76. package/dist/datasets/experiment/scorer.d.ts.map +1 -1
  77. package/dist/datasets/index.cjs +17 -17
  78. package/dist/datasets/index.js +2 -2
  79. package/dist/docs/SKILL.md +300 -0
  80. package/dist/docs/assets/SOURCE_MAP.json +1423 -0
  81. package/dist/docs/references/docs-agents-adding-voice.md +349 -0
  82. package/dist/docs/references/docs-agents-agent-approval.md +558 -0
  83. package/dist/docs/references/docs-agents-agent-memory.md +209 -0
  84. package/dist/docs/references/docs-agents-guardrails.md +374 -0
  85. package/dist/docs/references/docs-agents-network-approval.md +275 -0
  86. package/dist/docs/references/docs-agents-networks.md +299 -0
  87. package/dist/docs/references/docs-agents-overview.md +304 -0
  88. package/dist/docs/references/docs-agents-processors.md +622 -0
  89. package/dist/docs/references/docs-agents-structured-output.md +273 -0
  90. package/dist/docs/references/docs-agents-supervisor-agents.md +304 -0
  91. package/dist/docs/references/docs-agents-using-tools.md +214 -0
  92. package/dist/docs/references/docs-evals-custom-scorers.md +519 -0
  93. package/dist/docs/references/docs-evals-overview.md +141 -0
  94. package/dist/docs/references/docs-evals-running-in-ci.md +124 -0
  95. package/dist/docs/references/docs-memory-memory-processors.md +314 -0
  96. package/dist/docs/references/docs-memory-observational-memory.md +248 -0
  97. package/dist/docs/references/docs-memory-overview.md +45 -0
  98. package/dist/docs/references/docs-memory-semantic-recall.md +272 -0
  99. package/dist/docs/references/docs-memory-storage.md +261 -0
  100. package/dist/docs/references/docs-memory-working-memory.md +400 -0
  101. package/dist/docs/references/docs-observability-datasets-overview.md +198 -0
  102. package/dist/docs/references/docs-observability-datasets-running-experiments.md +274 -0
  103. package/dist/docs/references/docs-observability-logging.md +99 -0
  104. package/dist/docs/references/docs-observability-overview.md +70 -0
  105. package/dist/docs/references/docs-observability-tracing-bridges-otel.md +209 -0
  106. package/dist/docs/references/docs-observability-tracing-exporters-arize.md +272 -0
  107. package/dist/docs/references/docs-observability-tracing-exporters-braintrust.md +111 -0
  108. package/dist/docs/references/docs-observability-tracing-exporters-cloud.md +127 -0
  109. package/dist/docs/references/docs-observability-tracing-exporters-datadog.md +187 -0
  110. package/dist/docs/references/docs-observability-tracing-exporters-default.md +209 -0
  111. package/dist/docs/references/docs-observability-tracing-exporters-laminar.md +100 -0
  112. package/dist/docs/references/docs-observability-tracing-exporters-langfuse.md +213 -0
  113. package/dist/docs/references/docs-observability-tracing-exporters-langsmith.md +198 -0
  114. package/dist/docs/references/docs-observability-tracing-exporters-otel.md +476 -0
  115. package/dist/docs/references/docs-observability-tracing-exporters-posthog.md +148 -0
  116. package/dist/docs/references/docs-observability-tracing-overview.md +1112 -0
  117. package/dist/docs/references/docs-rag-chunking-and-embedding.md +183 -0
  118. package/dist/docs/references/docs-rag-graph-rag.md +215 -0
  119. package/dist/docs/references/docs-rag-overview.md +72 -0
  120. package/dist/docs/references/docs-rag-retrieval.md +515 -0
  121. package/dist/docs/references/docs-rag-vector-databases.md +645 -0
  122. package/dist/docs/references/docs-server-auth-auth0.md +220 -0
  123. package/dist/docs/references/docs-server-auth-clerk.md +132 -0
  124. package/dist/docs/references/docs-server-auth-composite-auth.md +234 -0
  125. package/dist/docs/references/docs-server-auth-custom-auth-provider.md +513 -0
  126. package/dist/docs/references/docs-server-auth-firebase.md +272 -0
  127. package/dist/docs/references/docs-server-auth-jwt.md +110 -0
  128. package/dist/docs/references/docs-server-auth-simple-auth.md +180 -0
  129. package/dist/docs/references/docs-server-auth-supabase.md +117 -0
  130. package/dist/docs/references/docs-server-auth-workos.md +186 -0
  131. package/dist/docs/references/docs-server-custom-adapters.md +378 -0
  132. package/dist/docs/references/docs-server-custom-api-routes.md +267 -0
  133. package/dist/docs/references/docs-server-mastra-client.md +243 -0
  134. package/dist/docs/references/docs-server-mastra-server.md +71 -0
  135. package/dist/docs/references/docs-server-middleware.md +225 -0
  136. package/dist/docs/references/docs-server-request-context.md +471 -0
  137. package/dist/docs/references/docs-streaming-events.md +237 -0
  138. package/dist/docs/references/docs-streaming-tool-streaming.md +175 -0
  139. package/dist/docs/references/docs-streaming-workflow-streaming.md +109 -0
  140. package/dist/docs/references/docs-voice-overview.md +959 -0
  141. package/dist/docs/references/docs-voice-speech-to-speech.md +102 -0
  142. package/dist/docs/references/docs-voice-speech-to-text.md +79 -0
  143. package/dist/docs/references/docs-voice-text-to-speech.md +83 -0
  144. package/dist/docs/references/docs-workflows-agents-and-tools.md +166 -0
  145. package/dist/docs/references/docs-workflows-control-flow.md +822 -0
  146. package/dist/docs/references/docs-workflows-error-handling.md +360 -0
  147. package/dist/docs/references/docs-workflows-human-in-the-loop.md +215 -0
  148. package/dist/docs/references/docs-workflows-overview.md +370 -0
  149. package/dist/docs/references/docs-workflows-snapshots.md +238 -0
  150. package/dist/docs/references/docs-workflows-suspend-and-resume.md +205 -0
  151. package/dist/docs/references/docs-workflows-time-travel.md +309 -0
  152. package/dist/docs/references/docs-workflows-workflow-state.md +181 -0
  153. package/dist/docs/references/docs-workspace-filesystem.md +164 -0
  154. package/dist/docs/references/docs-workspace-overview.md +239 -0
  155. package/dist/docs/references/docs-workspace-sandbox.md +63 -0
  156. package/dist/docs/references/docs-workspace-search.md +243 -0
  157. package/dist/docs/references/docs-workspace-skills.md +169 -0
  158. package/dist/docs/references/guides-agent-frameworks-ai-sdk.md +140 -0
  159. package/dist/docs/references/reference-agents-agent.md +141 -0
  160. package/dist/docs/references/reference-agents-generate.md +186 -0
  161. package/dist/docs/references/reference-agents-generateLegacy.md +173 -0
  162. package/dist/docs/references/reference-agents-getDefaultGenerateOptions.md +36 -0
  163. package/dist/docs/references/reference-agents-getDefaultOptions.md +34 -0
  164. package/dist/docs/references/reference-agents-getDefaultStreamOptions.md +36 -0
  165. package/dist/docs/references/reference-agents-getDescription.md +21 -0
  166. package/dist/docs/references/reference-agents-getInstructions.md +34 -0
  167. package/dist/docs/references/reference-agents-getLLM.md +37 -0
  168. package/dist/docs/references/reference-agents-getMemory.md +34 -0
  169. package/dist/docs/references/reference-agents-getModel.md +34 -0
  170. package/dist/docs/references/reference-agents-getTools.md +29 -0
  171. package/dist/docs/references/reference-agents-getVoice.md +34 -0
  172. package/dist/docs/references/reference-agents-listAgents.md +35 -0
  173. package/dist/docs/references/reference-agents-listScorers.md +34 -0
  174. package/dist/docs/references/reference-agents-listTools.md +34 -0
  175. package/dist/docs/references/reference-agents-listWorkflows.md +34 -0
  176. package/dist/docs/references/reference-agents-network.md +133 -0
  177. package/dist/docs/references/reference-ai-sdk-chat-route.md +82 -0
  178. package/dist/docs/references/reference-ai-sdk-network-route.md +74 -0
  179. package/dist/docs/references/reference-ai-sdk-to-ai-sdk-stream.md +231 -0
  180. package/dist/docs/references/reference-ai-sdk-with-mastra.md +59 -0
  181. package/dist/docs/references/reference-ai-sdk-workflow-route.md +79 -0
  182. package/dist/docs/references/reference-auth-auth0.md +73 -0
  183. package/dist/docs/references/reference-auth-clerk.md +36 -0
  184. package/dist/docs/references/reference-auth-firebase.md +80 -0
  185. package/dist/docs/references/reference-auth-jwt.md +26 -0
  186. package/dist/docs/references/reference-auth-supabase.md +33 -0
  187. package/dist/docs/references/reference-auth-workos.md +84 -0
  188. package/dist/docs/references/reference-client-js-agents.md +437 -0
  189. package/dist/docs/references/reference-configuration.md +752 -0
  190. package/dist/docs/references/reference-core-addGateway.md +42 -0
  191. package/dist/docs/references/reference-core-getAgent.md +21 -0
  192. package/dist/docs/references/reference-core-getAgentById.md +21 -0
  193. package/dist/docs/references/reference-core-getDeployer.md +22 -0
  194. package/dist/docs/references/reference-core-getGateway.md +38 -0
  195. package/dist/docs/references/reference-core-getGatewayById.md +41 -0
  196. package/dist/docs/references/reference-core-getLogger.md +22 -0
  197. package/dist/docs/references/reference-core-getMCPServer.md +47 -0
  198. package/dist/docs/references/reference-core-getMCPServerById.md +55 -0
  199. package/dist/docs/references/reference-core-getMemory.md +50 -0
  200. package/dist/docs/references/reference-core-getScorer.md +54 -0
  201. package/dist/docs/references/reference-core-getScorerById.md +54 -0
  202. package/dist/docs/references/reference-core-getServer.md +22 -0
  203. package/dist/docs/references/reference-core-getStorage.md +22 -0
  204. package/dist/docs/references/reference-core-getStoredAgentById.md +89 -0
  205. package/dist/docs/references/reference-core-getTelemetry.md +22 -0
  206. package/dist/docs/references/reference-core-getVector.md +22 -0
  207. package/dist/docs/references/reference-core-getWorkflow.md +42 -0
  208. package/dist/docs/references/reference-core-listAgents.md +21 -0
  209. package/dist/docs/references/reference-core-listGateways.md +40 -0
  210. package/dist/docs/references/reference-core-listLogs.md +38 -0
  211. package/dist/docs/references/reference-core-listLogsByRunId.md +36 -0
  212. package/dist/docs/references/reference-core-listMCPServers.md +55 -0
  213. package/dist/docs/references/reference-core-listMemory.md +56 -0
  214. package/dist/docs/references/reference-core-listScorers.md +29 -0
  215. package/dist/docs/references/reference-core-listStoredAgents.md +93 -0
  216. package/dist/docs/references/reference-core-listVectors.md +22 -0
  217. package/dist/docs/references/reference-core-listWorkflows.md +21 -0
  218. package/dist/docs/references/reference-core-mastra-class.md +66 -0
  219. package/dist/docs/references/reference-core-mastra-model-gateway.md +153 -0
  220. package/dist/docs/references/reference-core-setLogger.md +26 -0
  221. package/dist/docs/references/reference-core-setStorage.md +27 -0
  222. package/dist/docs/references/reference-datasets-addItem.md +37 -0
  223. package/dist/docs/references/reference-datasets-addItems.md +35 -0
  224. package/dist/docs/references/reference-datasets-compareExperiments.md +52 -0
  225. package/dist/docs/references/reference-datasets-create.md +51 -0
  226. package/dist/docs/references/reference-datasets-dataset.md +82 -0
  227. package/dist/docs/references/reference-datasets-datasets-manager.md +94 -0
  228. package/dist/docs/references/reference-datasets-delete.md +25 -0
  229. package/dist/docs/references/reference-datasets-deleteExperiment.md +27 -0
  230. package/dist/docs/references/reference-datasets-deleteItem.md +27 -0
  231. package/dist/docs/references/reference-datasets-deleteItems.md +29 -0
  232. package/dist/docs/references/reference-datasets-get.md +31 -0
  233. package/dist/docs/references/reference-datasets-getDetails.md +47 -0
  234. package/dist/docs/references/reference-datasets-getExperiment.md +30 -0
  235. package/dist/docs/references/reference-datasets-getItem.md +33 -0
  236. package/dist/docs/references/reference-datasets-getItemHistory.md +31 -0
  237. package/dist/docs/references/reference-datasets-list.md +31 -0
  238. package/dist/docs/references/reference-datasets-listExperimentResults.md +39 -0
  239. package/dist/docs/references/reference-datasets-listExperiments.md +33 -0
  240. package/dist/docs/references/reference-datasets-listItems.md +46 -0
  241. package/dist/docs/references/reference-datasets-listVersions.md +33 -0
  242. package/dist/docs/references/reference-datasets-startExperiment.md +62 -0
  243. package/dist/docs/references/reference-datasets-startExperimentAsync.md +43 -0
  244. package/dist/docs/references/reference-datasets-update.md +48 -0
  245. package/dist/docs/references/reference-datasets-updateItem.md +38 -0
  246. package/dist/docs/references/reference-evals-answer-relevancy.md +105 -0
  247. package/dist/docs/references/reference-evals-answer-similarity.md +99 -0
  248. package/dist/docs/references/reference-evals-bias.md +120 -0
  249. package/dist/docs/references/reference-evals-completeness.md +136 -0
  250. package/dist/docs/references/reference-evals-content-similarity.md +101 -0
  251. package/dist/docs/references/reference-evals-context-precision.md +196 -0
  252. package/dist/docs/references/reference-evals-create-scorer.md +270 -0
  253. package/dist/docs/references/reference-evals-faithfulness.md +114 -0
  254. package/dist/docs/references/reference-evals-hallucination.md +213 -0
  255. package/dist/docs/references/reference-evals-keyword-coverage.md +128 -0
  256. package/dist/docs/references/reference-evals-mastra-scorer.md +123 -0
  257. package/dist/docs/references/reference-evals-run-evals.md +179 -0
  258. package/dist/docs/references/reference-evals-scorer-utils.md +326 -0
  259. package/dist/docs/references/reference-evals-textual-difference.md +113 -0
  260. package/dist/docs/references/reference-evals-tone-consistency.md +119 -0
  261. package/dist/docs/references/reference-evals-toxicity.md +123 -0
  262. package/dist/docs/references/reference-harness-harness-class.md +708 -0
  263. package/dist/docs/references/reference-logging-pino-logger.md +117 -0
  264. package/dist/docs/references/reference-memory-deleteMessages.md +38 -0
  265. package/dist/docs/references/reference-memory-memory-class.md +147 -0
  266. package/dist/docs/references/reference-memory-observational-memory.md +565 -0
  267. package/dist/docs/references/reference-observability-tracing-bridges-otel.md +131 -0
  268. package/dist/docs/references/reference-observability-tracing-configuration.md +178 -0
  269. package/dist/docs/references/reference-observability-tracing-exporters-console-exporter.md +138 -0
  270. package/dist/docs/references/reference-observability-tracing-exporters-datadog.md +116 -0
  271. package/dist/docs/references/reference-observability-tracing-instances.md +107 -0
  272. package/dist/docs/references/reference-observability-tracing-interfaces.md +743 -0
  273. package/dist/docs/references/reference-observability-tracing-processors-sensitive-data-filter.md +144 -0
  274. package/dist/docs/references/reference-observability-tracing-spans.md +224 -0
  275. package/dist/docs/references/reference-processors-batch-parts-processor.md +61 -0
  276. package/dist/docs/references/reference-processors-language-detector.md +82 -0
  277. package/dist/docs/references/reference-processors-message-history-processor.md +85 -0
  278. package/dist/docs/references/reference-processors-moderation-processor.md +104 -0
  279. package/dist/docs/references/reference-processors-pii-detector.md +108 -0
  280. package/dist/docs/references/reference-processors-processor-interface.md +521 -0
  281. package/dist/docs/references/reference-processors-prompt-injection-detector.md +72 -0
  282. package/dist/docs/references/reference-processors-semantic-recall-processor.md +117 -0
  283. package/dist/docs/references/reference-processors-system-prompt-scrubber.md +80 -0
  284. package/dist/docs/references/reference-processors-token-limiter-processor.md +115 -0
  285. package/dist/docs/references/reference-processors-tool-call-filter.md +85 -0
  286. package/dist/docs/references/reference-processors-tool-search-processor.md +111 -0
  287. package/dist/docs/references/reference-processors-unicode-normalizer.md +62 -0
  288. package/dist/docs/references/reference-processors-working-memory-processor.md +152 -0
  289. package/dist/docs/references/reference-rag-database-config.md +261 -0
  290. package/dist/docs/references/reference-rag-embeddings.md +92 -0
  291. package/dist/docs/references/reference-server-mastra-server.md +298 -0
  292. package/dist/docs/references/reference-server-register-api-route.md +249 -0
  293. package/dist/docs/references/reference-storage-cloudflare-d1.md +218 -0
  294. package/dist/docs/references/reference-storage-composite.md +235 -0
  295. package/dist/docs/references/reference-storage-lance.md +131 -0
  296. package/dist/docs/references/reference-storage-libsql.md +135 -0
  297. package/dist/docs/references/reference-storage-mongodb.md +262 -0
  298. package/dist/docs/references/reference-storage-mssql.md +157 -0
  299. package/dist/docs/references/reference-storage-overview.md +121 -0
  300. package/dist/docs/references/reference-storage-postgresql.md +526 -0
  301. package/dist/docs/references/reference-storage-upstash.md +160 -0
  302. package/dist/docs/references/reference-streaming-ChunkType.md +292 -0
  303. package/dist/docs/references/reference-streaming-agents-MastraModelOutput.md +182 -0
  304. package/dist/docs/references/reference-streaming-agents-streamLegacy.md +142 -0
  305. package/dist/docs/references/reference-streaming-workflows-observeStream.md +42 -0
  306. package/dist/docs/references/reference-streaming-workflows-resumeStream.md +61 -0
  307. package/dist/docs/references/reference-streaming-workflows-stream.md +88 -0
  308. package/dist/docs/references/reference-streaming-workflows-timeTravelStream.md +142 -0
  309. package/dist/docs/references/reference-templates-overview.md +194 -0
  310. package/dist/docs/references/reference-tools-create-tool.md +237 -0
  311. package/dist/docs/references/reference-tools-graph-rag-tool.md +182 -0
  312. package/dist/docs/references/reference-tools-mcp-client.md +954 -0
  313. package/dist/docs/references/reference-tools-mcp-server.md +1271 -0
  314. package/dist/docs/references/reference-tools-vector-query-tool.md +459 -0
  315. package/dist/docs/references/reference-vectors-libsql.md +305 -0
  316. package/dist/docs/references/reference-vectors-mongodb.md +295 -0
  317. package/dist/docs/references/reference-vectors-pg.md +408 -0
  318. package/dist/docs/references/reference-vectors-upstash.md +294 -0
  319. package/dist/docs/references/reference-voice-composite-voice.md +121 -0
  320. package/dist/docs/references/reference-voice-mastra-voice.md +311 -0
  321. package/dist/docs/references/reference-voice-voice.addInstructions.md +55 -0
  322. package/dist/docs/references/reference-voice-voice.addTools.md +67 -0
  323. package/dist/docs/references/reference-voice-voice.connect.md +94 -0
  324. package/dist/docs/references/reference-voice-voice.events.md +37 -0
  325. package/dist/docs/references/reference-voice-voice.listen.md +164 -0
  326. package/dist/docs/references/reference-voice-voice.on.md +111 -0
  327. package/dist/docs/references/reference-voice-voice.speak.md +157 -0
  328. package/dist/docs/references/reference-workflows-run-methods-cancel.md +86 -0
  329. package/dist/docs/references/reference-workflows-run-methods-restart.md +33 -0
  330. package/dist/docs/references/reference-workflows-run-methods-resume.md +59 -0
  331. package/dist/docs/references/reference-workflows-run-methods-start.md +58 -0
  332. package/dist/docs/references/reference-workflows-run-methods-startAsync.md +67 -0
  333. package/dist/docs/references/reference-workflows-run-methods-timeTravel.md +142 -0
  334. package/dist/docs/references/reference-workflows-run.md +59 -0
  335. package/dist/docs/references/reference-workflows-step.md +119 -0
  336. package/dist/docs/references/reference-workflows-workflow-methods-branch.md +25 -0
  337. package/dist/docs/references/reference-workflows-workflow-methods-commit.md +17 -0
  338. package/dist/docs/references/reference-workflows-workflow-methods-create-run.md +63 -0
  339. package/dist/docs/references/reference-workflows-workflow-methods-dountil.md +25 -0
  340. package/dist/docs/references/reference-workflows-workflow-methods-dowhile.md +25 -0
  341. package/dist/docs/references/reference-workflows-workflow-methods-foreach.md +118 -0
  342. package/dist/docs/references/reference-workflows-workflow-methods-map.md +93 -0
  343. package/dist/docs/references/reference-workflows-workflow-methods-parallel.md +21 -0
  344. package/dist/docs/references/reference-workflows-workflow-methods-sleep.md +35 -0
  345. package/dist/docs/references/reference-workflows-workflow-methods-sleepUntil.md +35 -0
  346. package/dist/docs/references/reference-workflows-workflow-methods-then.md +21 -0
  347. package/dist/docs/references/reference-workflows-workflow.md +157 -0
  348. package/dist/docs/references/reference-workspace-filesystem.md +255 -0
  349. package/dist/docs/references/reference-workspace-local-filesystem.md +343 -0
  350. package/dist/docs/references/reference-workspace-local-sandbox.md +301 -0
  351. package/dist/docs/references/reference-workspace-sandbox.md +87 -0
  352. package/dist/docs/references/reference-workspace-workspace-class.md +244 -0
  353. package/dist/docs/references/reference.md +277 -0
  354. package/dist/evals/index.cjs +20 -20
  355. package/dist/evals/index.js +3 -3
  356. package/dist/evals/run/index.d.ts +9 -2
  357. package/dist/evals/run/index.d.ts.map +1 -1
  358. package/dist/evals/scoreTraces/index.cjs +5 -5
  359. package/dist/evals/scoreTraces/index.js +2 -2
  360. package/dist/harness/harness.d.ts +6 -0
  361. package/dist/harness/harness.d.ts.map +1 -1
  362. package/dist/harness/index.cjs +28 -13
  363. package/dist/harness/index.cjs.map +1 -1
  364. package/dist/harness/index.js +20 -5
  365. package/dist/harness/index.js.map +1 -1
  366. package/dist/index.cjs +2 -2
  367. package/dist/index.js +1 -1
  368. package/dist/integration/index.cjs +2 -2
  369. package/dist/integration/index.js +1 -1
  370. package/dist/llm/index.cjs +6 -6
  371. package/dist/llm/index.js +1 -1
  372. package/dist/llm/model/embedding-router.d.ts.map +1 -1
  373. package/dist/llm/model/model.loop.d.ts +1 -1
  374. package/dist/llm/model/model.loop.d.ts.map +1 -1
  375. package/dist/loop/index.cjs +20 -12
  376. package/dist/loop/index.js +1 -1
  377. package/dist/loop/network/index.d.ts.map +1 -1
  378. package/dist/loop/network/validation.d.ts +51 -0
  379. package/dist/loop/network/validation.d.ts.map +1 -1
  380. package/dist/loop/test-utils/generateText.d.ts.map +1 -1
  381. package/dist/loop/test-utils/options.d.ts.map +1 -1
  382. package/dist/loop/test-utils/streamObject.d.ts.map +1 -1
  383. package/dist/loop/types.d.ts +15 -0
  384. package/dist/loop/types.d.ts.map +1 -1
  385. package/dist/loop/workflows/agentic-execution/index.d.ts +3 -0
  386. package/dist/loop/workflows/agentic-execution/index.d.ts.map +1 -1
  387. package/dist/loop/workflows/agentic-execution/is-task-complete-step.d.ts +126 -0
  388. package/dist/loop/workflows/agentic-execution/is-task-complete-step.d.ts.map +1 -0
  389. package/dist/loop/workflows/agentic-execution/llm-execution-step.d.ts +3 -1
  390. package/dist/loop/workflows/agentic-execution/llm-execution-step.d.ts.map +1 -1
  391. package/dist/loop/workflows/agentic-execution/llm-mapping-step.d.ts +1 -0
  392. package/dist/loop/workflows/agentic-execution/llm-mapping-step.d.ts.map +1 -1
  393. package/dist/loop/workflows/agentic-execution/tool-call-step.d.ts.map +1 -1
  394. package/dist/loop/workflows/agentic-loop/index.d.ts +3 -0
  395. package/dist/loop/workflows/agentic-loop/index.d.ts.map +1 -1
  396. package/dist/loop/workflows/schema.d.ts +3 -0
  397. package/dist/loop/workflows/schema.d.ts.map +1 -1
  398. package/dist/mastra/index.cjs +2 -2
  399. package/dist/mastra/index.d.ts +9 -5
  400. package/dist/mastra/index.d.ts.map +1 -1
  401. package/dist/mastra/index.js +1 -1
  402. package/dist/memory/index.cjs +14 -14
  403. package/dist/memory/index.js +1 -1
  404. package/dist/processor-provider/index.cjs +10 -10
  405. package/dist/processor-provider/index.js +1 -1
  406. package/dist/processors/index.cjs +42 -42
  407. package/dist/processors/index.js +1 -1
  408. package/dist/processors/processors/skills.d.ts.map +1 -1
  409. package/dist/relevance/index.cjs +3 -3
  410. package/dist/relevance/index.js +1 -1
  411. package/dist/storage/constants.cjs +56 -56
  412. package/dist/storage/constants.js +1 -1
  413. package/dist/storage/domains/memory/inmemory.d.ts.map +1 -1
  414. package/dist/storage/index.cjs +160 -160
  415. package/dist/storage/index.js +2 -2
  416. package/dist/storage/types.d.ts +2 -3
  417. package/dist/storage/types.d.ts.map +1 -1
  418. package/dist/stream/aisdk/v5/compat/prepare-tools.d.ts.map +1 -1
  419. package/dist/stream/base/output.d.ts +1 -0
  420. package/dist/stream/base/output.d.ts.map +1 -1
  421. package/dist/stream/index.cjs +11 -11
  422. package/dist/stream/index.js +2 -2
  423. package/dist/stream/types.d.ts +27 -1
  424. package/dist/stream/types.d.ts.map +1 -1
  425. package/dist/test-utils/llm-mock.cjs +4 -4
  426. package/dist/test-utils/llm-mock.js +1 -1
  427. package/dist/tool-loop-agent/index.cjs +4 -4
  428. package/dist/tool-loop-agent/index.js +1 -1
  429. package/dist/tools/index.cjs +9 -5
  430. package/dist/tools/index.d.ts +1 -1
  431. package/dist/tools/index.d.ts.map +1 -1
  432. package/dist/tools/index.js +1 -1
  433. package/dist/tools/is-vercel-tool.cjs +2 -2
  434. package/dist/tools/is-vercel-tool.js +1 -1
  435. package/dist/tools/toolchecks.d.ts +10 -0
  436. package/dist/tools/toolchecks.d.ts.map +1 -1
  437. package/dist/utils.cjs +23 -23
  438. package/dist/utils.js +1 -1
  439. package/dist/vector/index.cjs +7 -7
  440. package/dist/vector/index.js +1 -1
  441. package/dist/vector/types.d.ts +9 -1
  442. package/dist/vector/types.d.ts.map +1 -1
  443. package/dist/workflows/evented/index.cjs +10 -10
  444. package/dist/workflows/evented/index.js +1 -1
  445. package/dist/workflows/index.cjs +25 -25
  446. package/dist/workflows/index.js +1 -1
  447. package/dist/workflows/types.d.ts +14 -1
  448. package/dist/workflows/types.d.ts.map +1 -1
  449. package/dist/workflows/workflow.d.ts +3 -17
  450. package/dist/workflows/workflow.d.ts.map +1 -1
  451. package/dist/workspace/filesystem/composite-filesystem.d.ts +5 -0
  452. package/dist/workspace/filesystem/composite-filesystem.d.ts.map +1 -1
  453. package/dist/workspace/filesystem/filesystem.d.ts +12 -0
  454. package/dist/workspace/filesystem/filesystem.d.ts.map +1 -1
  455. package/dist/workspace/filesystem/fs-utils.d.ts +12 -0
  456. package/dist/workspace/filesystem/fs-utils.d.ts.map +1 -1
  457. package/dist/workspace/filesystem/local-filesystem.d.ts +6 -0
  458. package/dist/workspace/filesystem/local-filesystem.d.ts.map +1 -1
  459. package/dist/workspace/index.cjs +66 -66
  460. package/dist/workspace/index.js +1 -1
  461. package/dist/workspace/lsp/client.d.ts +76 -0
  462. package/dist/workspace/lsp/client.d.ts.map +1 -0
  463. package/dist/workspace/lsp/index.d.ts +6 -0
  464. package/dist/workspace/lsp/index.d.ts.map +1 -0
  465. package/dist/workspace/lsp/language.d.ts +16 -0
  466. package/dist/workspace/lsp/language.d.ts.map +1 -0
  467. package/dist/workspace/lsp/manager.d.ts +72 -0
  468. package/dist/workspace/lsp/manager.d.ts.map +1 -0
  469. package/dist/workspace/lsp/servers.d.ts +43 -0
  470. package/dist/workspace/lsp/servers.d.ts.map +1 -0
  471. package/dist/workspace/lsp/types.d.ts +45 -0
  472. package/dist/workspace/lsp/types.d.ts.map +1 -0
  473. package/dist/workspace/tools/ast-edit.d.ts.map +1 -1
  474. package/dist/workspace/tools/edit-file.d.ts.map +1 -1
  475. package/dist/workspace/tools/helpers.d.ts +13 -0
  476. package/dist/workspace/tools/helpers.d.ts.map +1 -1
  477. package/dist/workspace/tools/write-file.d.ts.map +1 -1
  478. package/dist/workspace/workspace.d.ts +33 -0
  479. package/dist/workspace/workspace.d.ts.map +1 -1
  480. package/package.json +10 -8
  481. package/dist/chunk-2X66GWF5.cjs.map +0 -1
  482. package/dist/chunk-6QBN6MZY.cjs.map +0 -1
  483. package/dist/chunk-7EXW4AAG.js.map +0 -1
  484. package/dist/chunk-7UAJ6LMR.cjs.map +0 -1
  485. package/dist/chunk-BQHWJLXU.js.map +0 -1
  486. package/dist/chunk-DB7U2C5B.cjs.map +0 -1
  487. package/dist/chunk-DFCRXDVK.js.map +0 -1
  488. package/dist/chunk-EAZ6YDCQ.cjs.map +0 -1
  489. package/dist/chunk-HB6T4554.cjs.map +0 -1
  490. package/dist/chunk-IC5OUWKJ.js.map +0 -1
  491. package/dist/chunk-KUXNBWN7.js.map +0 -1
  492. package/dist/chunk-O7PZ4VOO.cjs.map +0 -1
  493. package/dist/chunk-QSHV7GPT.js.map +0 -1
  494. package/dist/chunk-QTAS3HND.cjs.map +0 -1
  495. package/dist/chunk-R4N65TLG.js.map +0 -1
  496. package/dist/chunk-T6GAM3SQ.js.map +0 -1
  497. package/dist/chunk-YQG7NBPR.cjs.map +0 -1
  498. package/dist/chunk-ZSBM2SVU.js.map +0 -1
@@ -0,0 +1,225 @@
1
+ # Middleware
2
+
3
+ Mastra servers can execute custom middleware functions before or after an API route handler is invoked. This is useful for things like authentication, logging, injecting request-specific context or adding CORS headers.
4
+
5
+ A middleware receives the [Hono](https://hono.dev) `Context` (`c`) and a `next` function. If it returns a `Response` the request is short-circuited. Calling `next()` continues processing the next middleware or route handler.
6
+
7
+ ```typescript
8
+ import { Mastra } from '@mastra/core'
9
+
10
+ export const mastra = new Mastra({
11
+ server: {
12
+ middleware: [
13
+ {
14
+ handler: async (c, next) => {
15
+ // Example: Add authentication check
16
+ const authHeader = c.req.header('Authorization')
17
+ if (!authHeader) {
18
+ return new Response('Unauthorized', { status: 401 })
19
+ }
20
+
21
+ await next()
22
+ },
23
+ path: '/api/*',
24
+ },
25
+ // Add a global request logger
26
+ async (c, next) => {
27
+ console.log(`${c.req.method} ${c.req.url}`)
28
+ await next()
29
+ },
30
+ ],
31
+ },
32
+ })
33
+ ```
34
+
35
+ To attach middleware to a single route pass the `middleware` option to `registerApiRoute`:
36
+
37
+ ```typescript
38
+ registerApiRoute('/my-custom-route', {
39
+ method: 'GET',
40
+ middleware: [
41
+ async (c, next) => {
42
+ console.log(`${c.req.method} ${c.req.url}`)
43
+ await next()
44
+ },
45
+ ],
46
+ handler: async c => {
47
+ const mastra = c.get('mastra')
48
+ return c.json({ message: 'Hello, world!' })
49
+ },
50
+ })
51
+ ```
52
+
53
+ ## Common examples
54
+
55
+ ### Using `RequestContext`
56
+
57
+ You can populate `RequestContext` dynamically in server middleware by extracting information from the request. In this example, the `temperature-unit` is set based on the Cloudflare `CF-IPCountry` header to ensure responses match the user's locale.
58
+
59
+ ```typescript
60
+ import { Mastra } from '@mastra/core'
61
+ import { RequestContext } from '@mastra/core/request-context'
62
+ import { testWeatherAgent } from './agents/test-weather-agent'
63
+
64
+ export const mastra = new Mastra({
65
+ agents: { testWeatherAgent },
66
+ server: {
67
+ middleware: [
68
+ async (context, next) => {
69
+ const country = context.req.header('CF-IPCountry')
70
+ const requestContext = context.get('requestContext')
71
+
72
+ requestContext.set('temperature-unit', country === 'US' ? 'fahrenheit' : 'celsius')
73
+
74
+ await next()
75
+ },
76
+ ],
77
+ },
78
+ })
79
+ ```
80
+
81
+ ### Authentication
82
+
83
+ ```typescript
84
+ {
85
+ handler: async (c, next) => {
86
+ const authHeader = c.req.header('Authorization');
87
+ if (!authHeader || !authHeader.startsWith('Bearer ')) {
88
+ return new Response('Unauthorized', { status: 401 });
89
+ }
90
+
91
+ // Validate token here
92
+ await next();
93
+ },
94
+ path: '/api/*',
95
+ }
96
+ ```
97
+
98
+ ### Authorization (User Isolation)
99
+
100
+ Authentication verifies who the user is. Authorization controls what they can access. Without authorization middleware, an authenticated user could access other users' threads by guessing IDs or manipulating the `resourceId` parameter.
101
+
102
+ Mastra provides reserved context keys that, when set by middleware, take precedence over client-provided values. The server automatically enforces these keys across memory and agent endpoints:
103
+
104
+ ```typescript
105
+ import { Mastra } from '@mastra/core'
106
+ import { MASTRA_RESOURCE_ID_KEY } from '@mastra/core/request-context'
107
+
108
+ export const mastra = new Mastra({
109
+ server: {
110
+ auth: {
111
+ authenticateToken: async token => {
112
+ // Your auth logic returns the user
113
+ return verifyToken(token) // { id: 'user-123', ... }
114
+ },
115
+ },
116
+ middleware: [
117
+ {
118
+ path: '/api/*',
119
+ handler: async (c, next) => {
120
+ const requestContext = c.get('requestContext')
121
+ const user = requestContext.get('user')
122
+
123
+ if (!user) {
124
+ return c.json({ error: 'Unauthorized' }, 401)
125
+ }
126
+
127
+ // Force all API operations to use this user's ID
128
+ // This takes precedence over any client-provided resourceId
129
+ requestContext.set(MASTRA_RESOURCE_ID_KEY, user.id)
130
+
131
+ return next()
132
+ },
133
+ },
134
+ ],
135
+ },
136
+ })
137
+ ```
138
+
139
+ With this middleware, the server automatically:
140
+
141
+ - **Filters thread listing** to only return threads owned by the user
142
+ - **Validates thread access** and returns 403 if accessing another user's thread
143
+ - **Forces thread creation** to use the authenticated user's ID
144
+ - **Validates message operations** including deletion, ensuring messages belong to owned threads
145
+
146
+ Even if a client passes `?resourceId=other-user-id`, the middleware-set value takes precedence. Attempts to access threads or messages owned by other users will return a 403 error.
147
+
148
+ #### Using `MASTRA_THREAD_ID_KEY`
149
+
150
+ You can also set `MASTRA_THREAD_ID_KEY` to override the client-provided thread ID:
151
+
152
+ ```typescript
153
+ import { MASTRA_RESOURCE_ID_KEY, MASTRA_THREAD_ID_KEY } from '@mastra/core/request-context'
154
+
155
+ // Force operations to use a specific thread
156
+ requestContext.set(MASTRA_THREAD_ID_KEY, validatedThreadId)
157
+ ```
158
+
159
+ This is useful when you want to restrict operations to a specific thread that you've validated through other means.
160
+
161
+ ### CORS support
162
+
163
+ ```typescript
164
+ {
165
+ handler: async (c, next) => {
166
+ c.header('Access-Control-Allow-Origin', '*');
167
+ c.header(
168
+ 'Access-Control-Allow-Methods',
169
+ 'GET, POST, PUT, DELETE, OPTIONS',
170
+ );
171
+ c.header(
172
+ 'Access-Control-Allow-Headers',
173
+ 'Content-Type, Authorization',
174
+ );
175
+
176
+ if (c.req.method === 'OPTIONS') {
177
+ return new Response(null, { status: 204 });
178
+ }
179
+
180
+ await next();
181
+ },
182
+ }
183
+ ```
184
+
185
+ ### Request logging
186
+
187
+ ```typescript
188
+ {
189
+ handler: async (c, next) => {
190
+ const start = Date.now();
191
+ await next();
192
+ const duration = Date.now() - start;
193
+ console.log(`${c.req.method} ${c.req.url} - ${duration}ms`);
194
+ },
195
+ }
196
+ ```
197
+
198
+ ### Special Mastra headers
199
+
200
+ When integrating with Mastra Cloud or custom clients the following headers can be inspected by middleware to tailor behavior:
201
+
202
+ ```typescript
203
+ {
204
+ handler: async (c, next) => {
205
+ const isFromMastraCloud = c.req.header('x-mastra-cloud') === 'true';
206
+ const clientType = c.req.header('x-mastra-client-type');
207
+ const isStudio =
208
+ c.req.header('x-studio') === 'true';
209
+
210
+ if (isFromMastraCloud) {
211
+ // Special handling
212
+ }
213
+ await next();
214
+ },
215
+ }
216
+ ```
217
+
218
+ - `x-mastra-cloud`: request originates from Mastra Cloud
219
+ - `x-mastra-client-type`: identifies the client SDK, e.g. `js` or `python`
220
+ - `x-studio`: request triggered from Studio
221
+
222
+ # Related
223
+
224
+ - [Request Context](https://mastra.ai/docs/server/request-context)
225
+ - [Reserved Keys](https://mastra.ai/docs/server/request-context)
@@ -0,0 +1,471 @@
1
+ # Request Context
2
+
3
+ Agents, tools, and workflows can all accept `RequestContext` as a parameter, making request-specific values available to the underlying primitives.
4
+
5
+ ## When to use `RequestContext`
6
+
7
+ Use `RequestContext` when a primitive's behavior should change based on runtime conditions. For example, you might switch models or storage backends based on user attributes, or adjust instructions and tool selection based on language.
8
+
9
+ > **Note:** **Note:** `RequestContext` is primarily used for passing data into specific requests. It's distinct from agent memory, which handles conversation history and state persistence across multiple calls.
10
+
11
+ ## Setting values
12
+
13
+ Pass `requestContext` into an agent, network, workflow, or tool call to make values available to all underlying primitives during execution. Use `.set()` to define values before making the call.
14
+
15
+ The `.set()` method takes two arguments:
16
+
17
+ 1. **key**: The name used to identify the value.
18
+ 2. **value**: The data to associate with that key.
19
+
20
+ ```typescript
21
+ import { RequestContext } from '@mastra/core/request-context'
22
+
23
+ export type UserTier = {
24
+ 'user-tier': 'enterprise' | 'pro'
25
+ }
26
+
27
+ const requestContext = new RequestContext<UserTier>()
28
+ requestContext.set('user-tier', 'enterprise')
29
+
30
+ const agent = mastra.getAgent('weatherAgent')
31
+ await agent.generate("What's the weather in London?", {
32
+ requestContext,
33
+ })
34
+
35
+ const routingAgent = mastra.getAgent('routingAgent')
36
+ routingAgent.network("What's the weather in London?", {
37
+ requestContext,
38
+ })
39
+
40
+ const run = await mastra.getWorkflow('weatherWorkflow').createRun()
41
+ await run.start({
42
+ inputData: {
43
+ location: 'London',
44
+ },
45
+ requestContext,
46
+ })
47
+ await run.resume({
48
+ resumeData: {
49
+ city: 'New York',
50
+ },
51
+ requestContext,
52
+ })
53
+
54
+ await weatherTool.execute({ location: 'London' }, { requestContext })
55
+ ```
56
+
57
+ ### Setting values based on request headers
58
+
59
+ You can populate `requestContext` dynamically in server middleware by extracting information from the request. In this example, the `temperature-unit` is set based on the Cloudflare `CF-IPCountry` header to ensure responses match the user's locale.
60
+
61
+ ```typescript
62
+ import { Mastra } from '@mastra/core'
63
+ import { RequestContext } from '@mastra/core/request-context'
64
+ import { testWeatherAgent } from './agents/test-weather-agent'
65
+
66
+ export const mastra = new Mastra({
67
+ agents: { testWeatherAgent },
68
+ server: {
69
+ middleware: [
70
+ async (context, next) => {
71
+ const country = context.req.header('CF-IPCountry')
72
+ const requestContext = context.get('requestContext')
73
+
74
+ requestContext.set('temperature-unit', country === 'US' ? 'fahrenheit' : 'celsius')
75
+
76
+ await next()
77
+ },
78
+ ],
79
+ },
80
+ })
81
+ ```
82
+
83
+ > **Info:** Visit [Middleware](https://mastra.ai/docs/server/middleware) for how to use server middleware.
84
+
85
+ ## Accessing values with agents
86
+
87
+ You can access the `requestContext` argument from any supported configuration options in agents. These functions can be sync or `async`. Use the `.get()` method to read values from `requestContext`.
88
+
89
+ ```typescript
90
+ export type UserTier = {
91
+ 'user-tier': 'enterprise' | 'pro'
92
+ }
93
+
94
+ export const weatherAgent = new Agent({
95
+ id: 'weather-agent',
96
+ name: 'Weather Agent',
97
+ instructions: async ({ requestContext }) => {
98
+ const userTier = requestContext.get('user-tier') as UserTier['user-tier']
99
+
100
+ if (userTier === 'enterprise') {
101
+ }
102
+ },
103
+ model: ({ requestContext }) => {},
104
+ tools: ({ requestContext }) => {},
105
+ memory: ({ requestContext }) => {},
106
+ })
107
+ ```
108
+
109
+ You can also use `requestContext` with other options like `agents`, `workflows`, `scorers`, `inputProcessors`, and `outputProcessors`.
110
+
111
+ ### Dynamic instructions
112
+
113
+ Agent instructions can be provided as an async function, enabling you to resolve prompts dynamically at runtime. Combined with `requestContext`, this enables patterns like:
114
+
115
+ - **Personalization**: Tailor instructions based on user attributes, preferences, or tier
116
+ - **Localization**: Adjust tone, language, or behavior based on locale
117
+ - **A/B testing**: Serve different prompt variants for experimentation
118
+ - **External prompt management**: Fetch prompts from registry services without redeploying
119
+
120
+ ```typescript
121
+ import { Agent } from '@mastra/core/agent'
122
+
123
+ export const dynamicAgent = new Agent({
124
+ id: 'dynamic-agent',
125
+ name: 'Dynamic Agent',
126
+ instructions: async ({ requestContext }) => {
127
+ const userTier = requestContext?.get('user-tier')
128
+ const locale = requestContext?.get('locale')
129
+
130
+ // Personalize based on user tier
131
+ const basePrompt =
132
+ userTier === 'enterprise'
133
+ ? 'You are a premium support agent. Provide detailed, thorough responses with technical depth.'
134
+ : 'You are a helpful assistant. Be concise and friendly.'
135
+
136
+ // Localize behavior
137
+ const localeInstructions = locale === 'ja' ? 'Respond in Japanese using formal keigo.' : ''
138
+
139
+ return `${basePrompt} ${localeInstructions}`.trim()
140
+ },
141
+ model: 'openai/gpt-5.1',
142
+ })
143
+ ```
144
+
145
+ #### Fetching from a prompt registry
146
+
147
+ If your organization uses a prompt registry service for central prompt management, you can fetch instructions at runtime. This allows you to update prompts without redeploying, run experiments with variants, and track prompt usage across your agents.
148
+
149
+ ```typescript
150
+ import { Agent } from '@mastra/core/agent'
151
+
152
+ // Your prompt registry client
153
+ import { promptRegistry } from '../lib/prompt-registry'
154
+
155
+ export const registryAgent = new Agent({
156
+ id: 'registry-agent',
157
+ name: 'Registry Agent',
158
+ instructions: async ({ requestContext }) => {
159
+ const prompt = await promptRegistry.getPrompt({
160
+ promptId: 'customer-support-agent',
161
+ // Pass context for variant selection or tracking
162
+ variant: requestContext?.get('experiment-variant'),
163
+ userId: requestContext?.get('user-id'),
164
+ })
165
+
166
+ return prompt.content
167
+ },
168
+ model: 'openai/gpt-5.1',
169
+ })
170
+ ```
171
+
172
+ > **Info:** Visit [Agent](https://mastra.ai/reference/agents/agent) for a full list of configuration options.
173
+
174
+ ## Accessing values from workflow steps
175
+
176
+ You can access the `requestContext` argument from a workflow step's `execute` function. This function can be sync or async. Use the `.get()` method to read values from `requestContext`.
177
+
178
+ ```typescript
179
+ export type UserTier = {
180
+ 'user-tier': 'enterprise' | 'pro'
181
+ }
182
+
183
+ const stepOne = createStep({
184
+ id: 'step-one',
185
+ execute: async ({ requestContext }) => {
186
+ const userTier = requestContext.get('user-tier') as UserTier['user-tier']
187
+
188
+ if (userTier === 'enterprise') {
189
+ }
190
+ },
191
+ })
192
+ ```
193
+
194
+ > **Info:** Visit [createStep()](https://mastra.ai/reference/workflows/step) for a full list of configuration options.
195
+
196
+ ## Accessing values with tools
197
+
198
+ You can access the `requestContext` argument from a tool's `execute` function. This function is `async`. Use the `.get()` method to read values from `requestContext`.
199
+
200
+ ```typescript
201
+ export type UserTier = {
202
+ 'user-tier': 'enterprise' | 'pro'
203
+ }
204
+
205
+ export const weatherTool = createTool({
206
+ id: 'weather-tool',
207
+ execute: async (inputData, context) => {
208
+ const userTier = context?.requestContext?.get('user-tier') as UserTier['user-tier'] | undefined
209
+
210
+ if (userTier === 'enterprise') {
211
+ }
212
+ },
213
+ })
214
+ ```
215
+
216
+ > **Info:** Visit [createTool()](https://mastra.ai/reference/tools/create-tool) for a full list of configuration options.
217
+
218
+ ## Reserved keys
219
+
220
+ Mastra reserves special context keys for security purposes. When set by middleware, these keys take precedence over client-provided values. The server automatically validates ownership and returns 403 errors when users attempt to access resources they don't own.
221
+
222
+ ```typescript
223
+ import { MASTRA_RESOURCE_ID_KEY, MASTRA_THREAD_ID_KEY } from '@mastra/core/request-context'
224
+
225
+ // In middleware: force memory operations to use authenticated user's ID
226
+ requestContext.set(MASTRA_RESOURCE_ID_KEY, user.id)
227
+
228
+ // In middleware: set validated thread ID
229
+ requestContext.set(MASTRA_THREAD_ID_KEY, threadId)
230
+ ```
231
+
232
+ | Key | Purpose |
233
+ | ------------------------ | ------------------------------------------------------------------------------------------------------------------------------------------------ |
234
+ | `MASTRA_RESOURCE_ID_KEY` | Forces all memory operations to use this resource ID. The server validates that accessed threads belong to this resource and returns 403 if not. |
235
+ | `MASTRA_THREAD_ID_KEY` | Forces thread operations to use this thread ID, overriding client-provided values |
236
+
237
+ These keys are used to implement user isolation in multi-tenant applications. See [Authorization middleware](https://mastra.ai/docs/server/middleware) for usage examples.
238
+
239
+ ## TypeScript support
240
+
241
+ When you provide a type parameter to `RequestContext`, all methods are fully typed:
242
+
243
+ ```typescript
244
+ import { RequestContext } from '@mastra/core/request-context'
245
+
246
+ type MyContext = {
247
+ userId: string
248
+ maxTokens: number
249
+ isPremium: boolean
250
+ }
251
+
252
+ const ctx = new RequestContext<MyContext>()
253
+
254
+ // set() enforces correct value types
255
+ ctx.set('userId', 'user-123') // ✓ valid
256
+ ctx.set('maxTokens', 4096) // ✓ valid
257
+ ctx.set('maxTokens', 'wrong') // ✗ TypeScript error: expected number
258
+
259
+ // get() returns the correct type automatically
260
+ const tokens = ctx.get('maxTokens') // inferred as number
261
+ const id = ctx.get('userId') // inferred as string
262
+
263
+ // keys() returns typed keys
264
+ for (const key of ctx.keys()) {
265
+ // key is "userId" | "maxTokens" | "isPremium"
266
+ }
267
+
268
+ // entries() supports type narrowing
269
+ for (const [key, value] of ctx.entries()) {
270
+ if (key === 'maxTokens') {
271
+ // TypeScript knows value is number here
272
+ console.log(value.toFixed(2))
273
+ }
274
+ if (key === 'userId') {
275
+ // TypeScript knows value is string here
276
+ console.log(value.toUpperCase())
277
+ }
278
+ }
279
+ ```
280
+
281
+ ## Schema validation
282
+
283
+ Use `requestContextSchema` to define a Zod schema that validates request context values at runtime. This catches missing or invalid context values early, provides clear error messages, and gives you type inference within your component.
284
+
285
+ ### Agent schema validation
286
+
287
+ When you define `requestContextSchema` on an agent, the context is validated at the start of `generate()` or `stream()`. If validation fails, the agent throws a `MastraError` before any LLM calls are made.
288
+
289
+ ```typescript
290
+ import { Agent } from '@mastra/core/agent'
291
+ import { z } from 'zod'
292
+
293
+ export const validatedAgent = new Agent({
294
+ id: 'validated-agent',
295
+ name: 'Validated Agent',
296
+ requestContextSchema: z.object({
297
+ userId: z.string(),
298
+ apiKey: z.string(),
299
+ }),
300
+ instructions: ({ requestContext }) => {
301
+ // Access all values as a typed object
302
+ const { userId, apiKey } = requestContext.all
303
+ // { userId: string; apiKey: string }
304
+
305
+ // Or retrieve individual values with .get()
306
+ const id = requestContext.get('userId')
307
+ // string
308
+
309
+ return `You are helping user ${userId}`
310
+ },
311
+ model: 'openai/gpt-4o',
312
+ })
313
+ ```
314
+
315
+ When validation fails, the error includes the agent ID and details about which fields failed:
316
+
317
+ ```text
318
+ Request context validation failed for agent 'validated-agent':
319
+ - apiKey: Required
320
+ ```
321
+
322
+ ### Tool schema validation
323
+
324
+ When you define `requestContextSchema` on a tool, the context is validated before `execute()` runs. Unlike agents, tools return a validation error object instead of throwing:
325
+
326
+ ```typescript
327
+ import { createTool } from '@mastra/core/tools'
328
+ import { z } from 'zod'
329
+
330
+ export const validatedTool = createTool({
331
+ id: 'validated-tool',
332
+ description: 'A tool that requires authenticated context',
333
+ inputSchema: z.object({
334
+ query: z.string(),
335
+ }),
336
+ requestContextSchema: z.object({
337
+ userId: z.string(),
338
+ }),
339
+ execute: async (inputData, context) => {
340
+ // Access all values as a typed object
341
+ const { userId } = context.requestContext?.all ?? {}
342
+ // { userId: string }
343
+
344
+ // Or retrieve individual values with .get()
345
+ const id = context.requestContext?.get('userId')
346
+ // string | undefined
347
+
348
+ return { result: `Processed for ${userId}` }
349
+ },
350
+ })
351
+ ```
352
+
353
+ When validation fails, the tool returns an error object instead of throwing:
354
+
355
+ ```json
356
+ {
357
+ "error": true,
358
+ "message": "Request context validation failed for validated-tool. Please fix the following errors and try again:\n- userId: Required\n\nProvided context: {}"
359
+ }
360
+ ```
361
+
362
+ ### Workflow schema validation
363
+
364
+ When you define `requestContextSchema` on a workflow, the context is validated at the start of `run.start()`. If validation fails, the workflow throws an error before any steps execute.
365
+
366
+ ```typescript
367
+ import { createWorkflow, createStep } from '@mastra/core/workflows'
368
+ import { z } from 'zod'
369
+
370
+ // Define schema once and share between workflow and steps
371
+ const workflowContextSchema = z.object({
372
+ tenantId: z.string(),
373
+ })
374
+
375
+ const step1 = createStep({
376
+ id: 'step-1',
377
+ inputSchema: z.object({ message: z.string() }),
378
+ outputSchema: z.object({ result: z.string() }),
379
+ // Add schema to step for type inference
380
+ requestContextSchema: workflowContextSchema,
381
+ execute: async ({ inputData, requestContext }) => {
382
+ // Access all values as a typed object
383
+ const { tenantId } = requestContext.all
384
+ // { tenantId: string }
385
+
386
+ // Or retrieve individual values with .get()
387
+ const id = requestContext.get('tenantId')
388
+ // string
389
+
390
+ return { result: `Processed for tenant ${tenantId}` }
391
+ },
392
+ })
393
+
394
+ export const validatedWorkflow = createWorkflow({
395
+ id: 'validated-workflow',
396
+ inputSchema: z.object({ message: z.string() }),
397
+ outputSchema: z.object({ result: z.string() }),
398
+ requestContextSchema: workflowContextSchema,
399
+ })
400
+ .then(step1)
401
+ .commit()
402
+ ```
403
+
404
+ When validation fails, the workflow throws an error:
405
+
406
+ ```text
407
+ Request context validation failed for workflow 'validated-workflow':
408
+ - tenantId: Required
409
+ ```
410
+
411
+ Steps can also define their own `requestContextSchema` for step-level validation. Step validation runs before the step's `execute()` function.
412
+
413
+ ### Validation behavior
414
+
415
+ | Component | Property | Validation timing | On failure |
416
+ | --------- | ---------------------- | ---------------------------------- | --------------------- |
417
+ | Agent | `requestContextSchema` | Start of `generate()` / `stream()` | Throws `MastraError` |
418
+ | Tool | `requestContextSchema` | Before `execute()` | Returns error object |
419
+ | Workflow | `requestContextSchema` | Start of `run.start()` | Throws `Error` |
420
+ | Step | `requestContextSchema` | Before step `execute()` | Step fails with error |
421
+
422
+ ### Best practices
423
+
424
+ **Match your middleware**: Define the same required fields in your schema that your middleware sets. This ensures the contract between middleware and components is explicit and validated.
425
+
426
+ ```typescript
427
+ // Middleware sets these fields
428
+ requestContext.set('userId', user.id)
429
+ requestContext.set('tenantId', tenant.id)
430
+
431
+ // Schema validates they exist
432
+ requestContextSchema: z.object({
433
+ userId: z.string(),
434
+ tenantId: z.string(),
435
+ })
436
+ ```
437
+
438
+ **Use optional fields for conditional context**: Use `.optional()` for values that may not always be present.
439
+
440
+ ```typescript
441
+ requestContextSchema: z.object({
442
+ userId: z.string(), // Always required
443
+ experimentVariant: z.string().optional(), // May not be set
444
+ })
445
+ ```
446
+
447
+ **Handle tool validation errors**: Since tools return error objects instead of throwing, check for errors in your agent or workflow logic when tool execution is critical.
448
+
449
+ ## Testing with Studio presets
450
+
451
+ When developing locally, you can define named presets in a JSON file and load them into Studio with the [`--request-context-presets`](https://mastra.ai/reference/cli/mastra) CLI flag. This adds a dropdown to the request context editor in Studio so you can quickly switch between configurations without manually editing JSON each time.
452
+
453
+ ```bash
454
+ mastra dev --request-context-presets ./presets.json
455
+ ```
456
+
457
+ ```json
458
+ {
459
+ "development": { "userId": "dev-user", "env": "development" },
460
+ "production": { "userId": "prod-user", "env": "production" }
461
+ }
462
+ ```
463
+
464
+ When you select a preset from the dropdown, the JSON editor populates with that preset's values. Editing the JSON manually switches the dropdown back to "Custom".
465
+
466
+ ## Related
467
+
468
+ - [Agent Request Context](https://mastra.ai/docs/agents/overview)
469
+ - [Workflow Request Context](https://mastra.ai/docs/workflows/overview)
470
+ - [Server Middleware](https://mastra.ai/docs/server/middleware)
471
+ - [Authorization Middleware](https://mastra.ai/docs/server/middleware)