@mastra/mcp-docs-server 1.0.0-beta.1 → 1.0.0-beta.11

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 (491) hide show
  1. package/.docs/organized/changelogs/%40internal%2Fchangeset-cli.md +1 -15
  2. package/.docs/organized/changelogs/%40internal%2Fexternal-types.md +1 -7
  3. package/.docs/organized/changelogs/%40internal%2Fstorage-test-utils.md +201 -1
  4. package/.docs/organized/changelogs/%40internal%2Ftypes-builder.md +1 -55
  5. package/.docs/organized/changelogs/%40mastra%2Fagent-builder.md +201 -1
  6. package/.docs/organized/changelogs/%40mastra%2Fai-sdk.md +276 -76
  7. package/.docs/organized/changelogs/%40mastra%2Fastra.md +201 -1
  8. package/.docs/organized/changelogs/%40mastra%2Fauth.md +6 -0
  9. package/.docs/organized/changelogs/%40mastra%2Fchroma.md +201 -1
  10. package/.docs/organized/changelogs/%40mastra%2Fclickhouse.md +201 -1
  11. package/.docs/organized/changelogs/%40mastra%2Fclient-js.md +200 -0
  12. package/.docs/organized/changelogs/%40mastra%2Fcloudflare-d1.md +201 -1
  13. package/.docs/organized/changelogs/%40mastra%2Fcloudflare.md +201 -1
  14. package/.docs/organized/changelogs/%40mastra%2Fcodemod.md +26 -0
  15. package/.docs/organized/changelogs/%40mastra%2Fconvex.md +89 -0
  16. package/.docs/organized/changelogs/%40mastra%2Fcore.md +392 -192
  17. package/.docs/organized/changelogs/%40mastra%2Fcouchbase.md +201 -1
  18. package/.docs/organized/changelogs/%40mastra%2Fdeployer-cloud.md +201 -1
  19. package/.docs/organized/changelogs/%40mastra%2Fdeployer-cloudflare.md +201 -1
  20. package/.docs/organized/changelogs/%40mastra%2Fdeployer-netlify.md +201 -1
  21. package/.docs/organized/changelogs/%40mastra%2Fdeployer-vercel.md +201 -1
  22. package/.docs/organized/changelogs/%40mastra%2Fdeployer.md +200 -0
  23. package/.docs/organized/changelogs/%40mastra%2Fduckdb.md +42 -0
  24. package/.docs/organized/changelogs/%40mastra%2Fdynamodb.md +201 -1
  25. package/.docs/organized/changelogs/%40mastra%2Felasticsearch.md +61 -0
  26. package/.docs/organized/changelogs/%40mastra%2Fevals.md +201 -1
  27. package/.docs/organized/changelogs/%40mastra%2Flance.md +201 -1
  28. package/.docs/organized/changelogs/%40mastra%2Flibsql.md +201 -1
  29. package/.docs/organized/changelogs/%40mastra%2Floggers.md +201 -1
  30. package/.docs/organized/changelogs/%40mastra%2Fmcp-docs-server.md +201 -1
  31. package/.docs/organized/changelogs/%40mastra%2Fmcp-registry-registry.md +201 -1
  32. package/.docs/organized/changelogs/%40mastra%2Fmcp.md +201 -1
  33. package/.docs/organized/changelogs/%40mastra%2Fmemory.md +201 -1
  34. package/.docs/organized/changelogs/%40mastra%2Fmongodb.md +201 -1
  35. package/.docs/organized/changelogs/%40mastra%2Fmssql.md +201 -1
  36. package/.docs/organized/changelogs/%40mastra%2Fopensearch.md +201 -1
  37. package/.docs/organized/changelogs/%40mastra%2Fpg.md +201 -1
  38. package/.docs/organized/changelogs/%40mastra%2Fpinecone.md +201 -1
  39. package/.docs/organized/changelogs/%40mastra%2Fplayground-ui.md +263 -63
  40. package/.docs/organized/changelogs/%40mastra%2Fqdrant.md +201 -1
  41. package/.docs/organized/changelogs/%40mastra%2Frag.md +201 -1
  42. package/.docs/organized/changelogs/%40mastra%2Freact.md +154 -1
  43. package/.docs/organized/changelogs/%40mastra%2Fs3vectors.md +18 -0
  44. package/.docs/organized/changelogs/%40mastra%2Fschema-compat.md +42 -0
  45. package/.docs/organized/changelogs/%40mastra%2Fserver.md +274 -74
  46. package/.docs/organized/changelogs/%40mastra%2Fturbopuffer.md +201 -1
  47. package/.docs/organized/changelogs/%40mastra%2Fupstash.md +201 -1
  48. package/.docs/organized/changelogs/%40mastra%2Fvectorize.md +201 -1
  49. package/.docs/organized/changelogs/%40mastra%2Fvoice-azure.md +201 -1
  50. package/.docs/organized/changelogs/%40mastra%2Fvoice-cloudflare.md +201 -1
  51. package/.docs/organized/changelogs/%40mastra%2Fvoice-deepgram.md +201 -1
  52. package/.docs/organized/changelogs/%40mastra%2Fvoice-elevenlabs.md +201 -1
  53. package/.docs/organized/changelogs/%40mastra%2Fvoice-gladia.md +92 -1
  54. package/.docs/organized/changelogs/%40mastra%2Fvoice-google-gemini-live.md +67 -1
  55. package/.docs/organized/changelogs/%40mastra%2Fvoice-google.md +201 -1
  56. package/.docs/organized/changelogs/%40mastra%2Fvoice-murf.md +201 -1
  57. package/.docs/organized/changelogs/%40mastra%2Fvoice-openai-realtime.md +201 -1
  58. package/.docs/organized/changelogs/%40mastra%2Fvoice-openai.md +201 -1
  59. package/.docs/organized/changelogs/%40mastra%2Fvoice-playai.md +201 -1
  60. package/.docs/organized/changelogs/%40mastra%2Fvoice-sarvam.md +201 -1
  61. package/.docs/organized/changelogs/%40mastra%2Fvoice-speechify.md +201 -1
  62. package/.docs/organized/changelogs/create-mastra.md +201 -1
  63. package/.docs/organized/changelogs/mastra.md +201 -1
  64. package/.docs/organized/code-examples/agui.md +1 -0
  65. package/.docs/organized/code-examples/ai-elements.md +2 -2
  66. package/.docs/organized/code-examples/ai-sdk-useChat.md +2 -2
  67. package/.docs/organized/code-examples/ai-sdk-v5.md +3 -2
  68. package/.docs/organized/code-examples/assistant-ui.md +2 -2
  69. package/.docs/organized/code-examples/bird-checker-with-express.md +1 -1
  70. package/.docs/organized/code-examples/bird-checker-with-nextjs-and-eval.md +2 -2
  71. package/.docs/organized/code-examples/bird-checker-with-nextjs.md +2 -2
  72. package/.docs/organized/code-examples/client-side-tools.md +1 -1
  73. package/.docs/organized/code-examples/crypto-chatbot.md +2 -2
  74. package/.docs/organized/code-examples/fireworks-r1.md +1 -1
  75. package/.docs/organized/code-examples/heads-up-game.md +1 -1
  76. package/.docs/organized/code-examples/mcp-configuration.md +0 -3
  77. package/.docs/organized/code-examples/mcp-server-adapters.md +720 -0
  78. package/.docs/organized/code-examples/memory-per-resource-example.md +1 -1
  79. package/.docs/organized/code-examples/memory-with-processors.md +1 -1
  80. package/.docs/organized/code-examples/openapi-spec-writer.md +1 -1
  81. package/.docs/organized/code-examples/processors-with-ai-sdk.md +14 -0
  82. package/.docs/organized/code-examples/quick-start.md +2 -2
  83. package/.docs/organized/code-examples/server-app-access.md +342 -0
  84. package/.docs/organized/code-examples/server-express-adapter.md +87 -0
  85. package/.docs/organized/code-examples/server-hono-adapter.md +85 -0
  86. package/.docs/organized/code-examples/stock-price-tool.md +1 -21
  87. package/.docs/organized/code-examples/workflow-ai-recruiter.md +1 -1
  88. package/.docs/organized/code-examples/workflow-with-inline-steps.md +1 -1
  89. package/.docs/organized/code-examples/workflow-with-memory.md +1 -1
  90. package/.docs/organized/code-examples/workflow-with-separate-steps.md +1 -1
  91. package/.docs/organized/code-examples/workflow-with-suspend-resume.md +1 -1
  92. package/.docs/raw/agents/adding-voice.mdx +56 -10
  93. package/.docs/raw/agents/agent-approval.mdx +189 -0
  94. package/.docs/raw/agents/agent-memory.mdx +1 -1
  95. package/.docs/raw/agents/guardrails.mdx +70 -30
  96. package/.docs/raw/agents/networks.mdx +3 -3
  97. package/.docs/raw/agents/overview.mdx +18 -167
  98. package/.docs/raw/agents/processors.mdx +430 -0
  99. package/.docs/raw/agents/structured-output.mdx +224 -0
  100. package/.docs/raw/agents/using-tools.mdx +14 -14
  101. package/.docs/raw/auth/auth0.mdx +1 -1
  102. package/.docs/raw/auth/clerk.mdx +1 -1
  103. package/.docs/raw/auth/firebase.mdx +1 -1
  104. package/.docs/raw/auth/index.mdx +1 -1
  105. package/.docs/raw/auth/jwt.mdx +1 -1
  106. package/.docs/raw/auth/supabase.mdx +1 -1
  107. package/.docs/raw/auth/workos.mdx +1 -1
  108. package/.docs/raw/community/contributing-templates.mdx +1 -1
  109. package/.docs/raw/community/discord.mdx +2 -2
  110. package/.docs/raw/community/licensing.mdx +1 -1
  111. package/.docs/raw/course/01-first-agent/05-running-playground.md +5 -5
  112. package/.docs/raw/course/01-first-agent/09-testing-your-agent.md +3 -3
  113. package/.docs/raw/course/01-first-agent/13-testing-your-tool.md +3 -3
  114. package/.docs/raw/course/01-first-agent/17-testing-memory.md +2 -2
  115. package/.docs/raw/course/04-workflows/07-using-playground.md +1 -1
  116. package/.docs/raw/deployment/{server-deployment.mdx → building-mastra.mdx} +4 -4
  117. package/.docs/raw/deployment/cloud-providers/amazon-ec2.mdx +2 -2
  118. package/.docs/raw/deployment/cloud-providers/aws-lambda.mdx +3 -3
  119. package/.docs/raw/deployment/cloud-providers/azure-app-services.mdx +2 -2
  120. package/.docs/raw/deployment/{serverless-platforms → cloud-providers}/cloudflare-deployer.mdx +1 -1
  121. package/.docs/raw/deployment/cloud-providers/digital-ocean.mdx +2 -2
  122. package/.docs/raw/deployment/cloud-providers/index.mdx +26 -29
  123. package/.docs/raw/deployment/{serverless-platforms → cloud-providers}/netlify-deployer.mdx +45 -14
  124. package/.docs/raw/deployment/{serverless-platforms → cloud-providers}/vercel-deployer.mdx +1 -1
  125. package/.docs/raw/{mastra-cloud → deployment/mastra-cloud}/dashboard.mdx +3 -3
  126. package/.docs/raw/deployment/mastra-cloud/observability.mdx +53 -0
  127. package/.docs/raw/{mastra-cloud → deployment/mastra-cloud}/overview.mdx +3 -3
  128. package/.docs/raw/{mastra-cloud → deployment/mastra-cloud}/setting-up.mdx +4 -4
  129. package/.docs/raw/deployment/monorepo.mdx +3 -3
  130. package/.docs/raw/deployment/overview.mdx +7 -7
  131. package/.docs/raw/deployment/web-framework.mdx +6 -6
  132. package/.docs/raw/evals/{off-the-shelf-scorers.mdx → built-in-scorers.mdx} +17 -15
  133. package/.docs/raw/evals/custom-scorers.mdx +4 -6
  134. package/.docs/raw/evals/overview.mdx +5 -6
  135. package/.docs/raw/evals/running-in-ci.mdx +2 -4
  136. package/.docs/raw/getting-started/{installation.mdx → manual-install.mdx} +6 -80
  137. package/.docs/raw/getting-started/mcp-docs-server.mdx +63 -6
  138. package/.docs/raw/getting-started/project-structure.mdx +2 -2
  139. package/.docs/raw/getting-started/start.mdx +72 -0
  140. package/.docs/raw/getting-started/studio.mdx +32 -7
  141. package/.docs/raw/guides/agent-frameworks/ai-sdk.mdx +147 -0
  142. package/.docs/raw/guides/build-your-ui/ai-sdk-ui.mdx +627 -0
  143. package/.docs/raw/{frameworks/agentic-uis → guides/build-your-ui}/assistant-ui.mdx +71 -19
  144. package/.docs/raw/guides/build-your-ui/copilotkit.mdx +206 -0
  145. package/.docs/raw/{frameworks/web-frameworks → guides/getting-started}/astro.mdx +24 -26
  146. package/.docs/raw/{frameworks/servers → guides/getting-started}/express.mdx +4 -5
  147. package/.docs/raw/guides/{quickstarts/nextjs.mdx → getting-started/next-js.mdx} +26 -25
  148. package/.docs/raw/guides/getting-started/quickstart.mdx +97 -0
  149. package/.docs/raw/{frameworks/web-frameworks → guides/getting-started}/sveltekit.mdx +24 -26
  150. package/.docs/raw/{frameworks/web-frameworks → guides/getting-started}/vite-react.mdx +7 -7
  151. package/.docs/raw/guides/guide/ai-recruiter.mdx +2 -3
  152. package/.docs/raw/guides/guide/chef-michel.mdx +2 -3
  153. package/.docs/raw/guides/guide/notes-mcp-server.mdx +2 -2
  154. package/.docs/raw/guides/guide/research-assistant.mdx +7 -8
  155. package/.docs/raw/guides/guide/stock-agent.mdx +4 -6
  156. package/.docs/raw/guides/guide/web-search.mdx +12 -10
  157. package/.docs/raw/guides/guide/whatsapp-chat-bot.mdx +421 -0
  158. package/.docs/raw/guides/index.mdx +3 -35
  159. package/.docs/raw/guides/migrations/agentnetwork.mdx +4 -4
  160. package/.docs/raw/guides/migrations/ai-sdk-v4-to-v5.mdx +119 -0
  161. package/.docs/raw/guides/migrations/upgrade-to-v1/agent.mdx +121 -1
  162. package/.docs/raw/guides/migrations/upgrade-to-v1/client.mdx +42 -2
  163. package/.docs/raw/guides/migrations/upgrade-to-v1/evals.mdx +31 -1
  164. package/.docs/raw/guides/migrations/upgrade-to-v1/mastra.mdx +27 -3
  165. package/.docs/raw/guides/migrations/upgrade-to-v1/mcp.mdx +1 -1
  166. package/.docs/raw/guides/migrations/upgrade-to-v1/memory.mdx +28 -0
  167. package/.docs/raw/guides/migrations/upgrade-to-v1/overview.mdx +25 -3
  168. package/.docs/raw/guides/migrations/upgrade-to-v1/storage.mdx +80 -0
  169. package/.docs/raw/guides/migrations/upgrade-to-v1/tools.mdx +68 -3
  170. package/.docs/raw/guides/migrations/upgrade-to-v1/vectors.mdx +25 -1
  171. package/.docs/raw/guides/migrations/upgrade-to-v1/workflows.mdx +174 -1
  172. package/.docs/raw/guides/migrations/vnext-to-standard-apis.mdx +2 -2
  173. package/.docs/raw/index.mdx +3 -3
  174. package/.docs/raw/mcp/overview.mdx +358 -0
  175. package/.docs/raw/mcp/publishing-mcp-server.mdx +139 -0
  176. package/.docs/raw/memory/conversation-history.mdx +1 -1
  177. package/.docs/raw/memory/memory-processors.mdx +265 -80
  178. package/.docs/raw/memory/overview.mdx +2 -2
  179. package/.docs/raw/memory/semantic-recall.mdx +9 -9
  180. package/.docs/raw/memory/storage/memory-with-libsql.mdx +3 -8
  181. package/.docs/raw/memory/storage/memory-with-mongodb.mdx +150 -0
  182. package/.docs/raw/memory/storage/memory-with-pg.mdx +3 -8
  183. package/.docs/raw/memory/storage/memory-with-upstash.mdx +3 -8
  184. package/.docs/raw/memory/threads-and-resources.mdx +4 -4
  185. package/.docs/raw/memory/working-memory.mdx +16 -8
  186. package/.docs/raw/{logging.mdx → observability/logging.mdx} +7 -7
  187. package/.docs/raw/observability/overview.mdx +3 -4
  188. package/.docs/raw/observability/tracing/bridges/otel.mdx +200 -0
  189. package/.docs/raw/observability/tracing/exporters/arize.mdx +37 -1
  190. package/.docs/raw/observability/tracing/exporters/braintrust.mdx +20 -1
  191. package/.docs/raw/observability/tracing/exporters/cloud.mdx +2 -2
  192. package/.docs/raw/observability/tracing/exporters/default.mdx +1 -1
  193. package/.docs/raw/observability/tracing/exporters/langfuse.mdx +84 -1
  194. package/.docs/raw/observability/tracing/exporters/langsmith.mdx +13 -1
  195. package/.docs/raw/observability/tracing/exporters/otel.mdx +123 -25
  196. package/.docs/raw/observability/tracing/exporters/posthog.mdx +127 -0
  197. package/.docs/raw/observability/tracing/overview.mdx +80 -9
  198. package/.docs/raw/observability/tracing/processors/sensitive-data-filter.mdx +1 -2
  199. package/.docs/raw/rag/chunking-and-embedding.mdx +16 -17
  200. package/.docs/raw/rag/overview.mdx +4 -3
  201. package/.docs/raw/rag/retrieval.mdx +44 -39
  202. package/.docs/raw/rag/vector-databases.mdx +94 -3
  203. package/.docs/raw/reference/agents/agent.mdx +19 -16
  204. package/.docs/raw/reference/agents/generate.mdx +67 -99
  205. package/.docs/raw/reference/agents/generateLegacy.mdx +3 -3
  206. package/.docs/raw/reference/agents/getDefaultGenerateOptions.mdx +1 -1
  207. package/.docs/raw/reference/agents/getDefaultOptions.mdx +1 -1
  208. package/.docs/raw/reference/agents/getDefaultStreamOptions.mdx +1 -1
  209. package/.docs/raw/reference/agents/getDescription.mdx +1 -1
  210. package/.docs/raw/reference/agents/getInstructions.mdx +1 -1
  211. package/.docs/raw/reference/agents/getLLM.mdx +2 -2
  212. package/.docs/raw/reference/agents/getMemory.mdx +1 -1
  213. package/.docs/raw/reference/agents/getModel.mdx +1 -1
  214. package/.docs/raw/reference/agents/getTools.mdx +69 -0
  215. package/.docs/raw/reference/agents/getVoice.mdx +1 -1
  216. package/.docs/raw/reference/agents/listAgents.mdx +1 -1
  217. package/.docs/raw/reference/agents/listScorers.mdx +1 -1
  218. package/.docs/raw/reference/agents/listTools.mdx +2 -2
  219. package/.docs/raw/reference/agents/listWorkflows.mdx +1 -1
  220. package/.docs/raw/reference/agents/network.mdx +33 -72
  221. package/.docs/raw/reference/ai-sdk/chat-route.mdx +127 -0
  222. package/.docs/raw/reference/ai-sdk/handle-chat-stream.mdx +117 -0
  223. package/.docs/raw/reference/ai-sdk/handle-network-stream.mdx +64 -0
  224. package/.docs/raw/reference/ai-sdk/handle-workflow-stream.mdx +116 -0
  225. package/.docs/raw/reference/ai-sdk/network-route.mdx +99 -0
  226. package/.docs/raw/reference/ai-sdk/to-ai-sdk-stream.mdx +289 -0
  227. package/.docs/raw/reference/ai-sdk/with-mastra.mdx +119 -0
  228. package/.docs/raw/reference/ai-sdk/workflow-route.mdx +110 -0
  229. package/.docs/raw/reference/auth/auth0.mdx +1 -1
  230. package/.docs/raw/reference/auth/clerk.mdx +1 -1
  231. package/.docs/raw/reference/auth/firebase.mdx +1 -1
  232. package/.docs/raw/reference/auth/jwt.mdx +1 -1
  233. package/.docs/raw/reference/auth/supabase.mdx +1 -1
  234. package/.docs/raw/reference/auth/workos.mdx +1 -1
  235. package/.docs/raw/reference/cli/create-mastra.mdx +1 -1
  236. package/.docs/raw/reference/cli/mastra.mdx +19 -6
  237. package/.docs/raw/reference/client-js/agents.mdx +252 -68
  238. package/.docs/raw/reference/client-js/error-handling.mdx +1 -1
  239. package/.docs/raw/reference/client-js/logs.mdx +1 -1
  240. package/.docs/raw/reference/client-js/mastra-client.mdx +4 -4
  241. package/.docs/raw/reference/client-js/memory.mdx +48 -2
  242. package/.docs/raw/reference/client-js/observability.mdx +1 -1
  243. package/.docs/raw/reference/client-js/telemetry.mdx +1 -1
  244. package/.docs/raw/reference/client-js/tools.mdx +1 -1
  245. package/.docs/raw/reference/client-js/vectors.mdx +1 -1
  246. package/.docs/raw/reference/client-js/workflows.mdx +93 -64
  247. package/.docs/raw/reference/core/addGateway.mdx +59 -0
  248. package/.docs/raw/reference/core/getAgent.mdx +1 -1
  249. package/.docs/raw/reference/core/getAgentById.mdx +1 -1
  250. package/.docs/raw/reference/core/getDeployer.mdx +1 -1
  251. package/.docs/raw/reference/core/getGateway.mdx +59 -0
  252. package/.docs/raw/reference/core/getGatewayById.mdx +62 -0
  253. package/.docs/raw/reference/core/getLogger.mdx +2 -2
  254. package/.docs/raw/reference/core/getMCPServer.mdx +2 -2
  255. package/.docs/raw/reference/core/getMCPServerById.mdx +2 -2
  256. package/.docs/raw/reference/core/getMemory.mdx +73 -0
  257. package/.docs/raw/reference/core/getScorer.mdx +1 -1
  258. package/.docs/raw/reference/core/getScorerById.mdx +1 -1
  259. package/.docs/raw/reference/core/getServer.mdx +3 -3
  260. package/.docs/raw/reference/core/getStorage.mdx +1 -1
  261. package/.docs/raw/reference/core/getStoredAgentById.mdx +183 -0
  262. package/.docs/raw/reference/core/getTelemetry.mdx +1 -1
  263. package/.docs/raw/reference/core/getVector.mdx +1 -1
  264. package/.docs/raw/reference/core/getWorkflow.mdx +1 -1
  265. package/.docs/raw/reference/core/listAgents.mdx +1 -1
  266. package/.docs/raw/reference/core/listGateways.mdx +53 -0
  267. package/.docs/raw/reference/core/listLogs.mdx +2 -2
  268. package/.docs/raw/reference/core/listLogsByRunId.mdx +2 -2
  269. package/.docs/raw/reference/core/listMCPServers.mdx +2 -2
  270. package/.docs/raw/reference/core/listMemory.mdx +70 -0
  271. package/.docs/raw/reference/core/listScorers.mdx +1 -1
  272. package/.docs/raw/reference/core/listStoredAgents.mdx +151 -0
  273. package/.docs/raw/reference/core/listVectors.mdx +1 -1
  274. package/.docs/raw/reference/core/listWorkflows.mdx +1 -1
  275. package/.docs/raw/reference/core/mastra-class.mdx +17 -1
  276. package/.docs/raw/reference/core/mastra-model-gateway.mdx +227 -0
  277. package/.docs/raw/reference/core/setLogger.mdx +2 -2
  278. package/.docs/raw/reference/core/setStorage.mdx +1 -1
  279. package/.docs/raw/reference/core/setTelemetry.mdx +2 -2
  280. package/.docs/raw/reference/deployer/cloudflare.mdx +1 -1
  281. package/.docs/raw/reference/deployer/deployer.mdx +1 -1
  282. package/.docs/raw/reference/deployer/netlify.mdx +2 -3
  283. package/.docs/raw/reference/deployer/vercel.mdx +1 -1
  284. package/.docs/raw/reference/evals/answer-relevancy.mdx +29 -99
  285. package/.docs/raw/reference/evals/answer-similarity.mdx +13 -259
  286. package/.docs/raw/reference/evals/bias.mdx +30 -88
  287. package/.docs/raw/reference/evals/completeness.mdx +32 -91
  288. package/.docs/raw/reference/evals/content-similarity.mdx +29 -89
  289. package/.docs/raw/reference/evals/context-precision.mdx +29 -131
  290. package/.docs/raw/reference/evals/context-relevance.mdx +12 -12
  291. package/.docs/raw/reference/evals/create-scorer.mdx +1 -1
  292. package/.docs/raw/reference/evals/faithfulness.mdx +29 -102
  293. package/.docs/raw/reference/evals/hallucination.mdx +29 -104
  294. package/.docs/raw/reference/evals/keyword-coverage.mdx +29 -108
  295. package/.docs/raw/reference/evals/mastra-scorer.mdx +1 -1
  296. package/.docs/raw/reference/evals/noise-sensitivity.mdx +12 -12
  297. package/.docs/raw/reference/evals/prompt-alignment.mdx +16 -16
  298. package/.docs/raw/reference/evals/run-evals.mdx +1 -1
  299. package/.docs/raw/reference/evals/scorer-utils.mdx +362 -0
  300. package/.docs/raw/reference/evals/textual-difference.mdx +28 -101
  301. package/.docs/raw/reference/evals/tone-consistency.mdx +26 -99
  302. package/.docs/raw/reference/evals/tool-call-accuracy.mdx +8 -8
  303. package/.docs/raw/reference/evals/toxicity.mdx +30 -93
  304. package/.docs/raw/reference/index.mdx +1 -0
  305. package/.docs/raw/reference/logging/pino-logger.mdx +2 -2
  306. package/.docs/raw/reference/memory/createThread.mdx +1 -1
  307. package/.docs/raw/reference/memory/deleteMessages.mdx +1 -1
  308. package/.docs/raw/reference/memory/getThreadById.mdx +1 -1
  309. package/.docs/raw/reference/memory/listThreadsByResourceId.mdx +1 -1
  310. package/.docs/raw/reference/memory/memory-class.mdx +6 -8
  311. package/.docs/raw/reference/memory/query.mdx +1 -1
  312. package/.docs/raw/reference/memory/recall.mdx +1 -1
  313. package/.docs/raw/reference/observability/tracing/bridges/otel.mdx +177 -0
  314. package/.docs/raw/reference/observability/tracing/configuration.mdx +1 -5
  315. package/.docs/raw/reference/observability/tracing/exporters/arize.mdx +30 -1
  316. package/.docs/raw/reference/observability/tracing/exporters/braintrust.mdx +1 -1
  317. package/.docs/raw/reference/observability/tracing/exporters/cloud-exporter.mdx +1 -1
  318. package/.docs/raw/reference/observability/tracing/exporters/console-exporter.mdx +1 -1
  319. package/.docs/raw/reference/observability/tracing/exporters/default-exporter.mdx +1 -1
  320. package/.docs/raw/reference/observability/tracing/exporters/langfuse.mdx +44 -1
  321. package/.docs/raw/reference/observability/tracing/exporters/langsmith.mdx +18 -2
  322. package/.docs/raw/reference/observability/tracing/exporters/otel.mdx +34 -44
  323. package/.docs/raw/reference/observability/tracing/exporters/posthog.mdx +132 -0
  324. package/.docs/raw/reference/observability/tracing/instances.mdx +1 -5
  325. package/.docs/raw/reference/observability/tracing/interfaces.mdx +30 -5
  326. package/.docs/raw/reference/observability/tracing/processors/sensitive-data-filter.mdx +1 -1
  327. package/.docs/raw/reference/observability/tracing/spans.mdx +1 -5
  328. package/.docs/raw/reference/processors/batch-parts-processor.mdx +2 -2
  329. package/.docs/raw/reference/processors/language-detector.mdx +11 -4
  330. package/.docs/raw/reference/processors/message-history-processor.mdx +131 -0
  331. package/.docs/raw/reference/processors/moderation-processor.mdx +13 -6
  332. package/.docs/raw/reference/processors/pii-detector.mdx +13 -6
  333. package/.docs/raw/reference/processors/processor-interface.mdx +803 -0
  334. package/.docs/raw/reference/processors/prompt-injection-detector.mdx +11 -4
  335. package/.docs/raw/reference/processors/semantic-recall-processor.mdx +197 -0
  336. package/.docs/raw/reference/processors/system-prompt-scrubber.mdx +4 -5
  337. package/.docs/raw/reference/processors/token-limiter-processor.mdx +3 -3
  338. package/.docs/raw/reference/processors/tool-call-filter.mdx +125 -0
  339. package/.docs/raw/reference/processors/unicode-normalizer.mdx +2 -2
  340. package/.docs/raw/reference/processors/working-memory-processor.mdx +221 -0
  341. package/.docs/raw/reference/rag/chunk.mdx +1 -1
  342. package/.docs/raw/reference/rag/database-config.mdx +1 -1
  343. package/.docs/raw/reference/rag/document.mdx +1 -1
  344. package/.docs/raw/reference/rag/embeddings.mdx +6 -6
  345. package/.docs/raw/reference/rag/extract-params.mdx +1 -1
  346. package/.docs/raw/reference/rag/graph-rag.mdx +1 -1
  347. package/.docs/raw/reference/rag/metadata-filters.mdx +1 -1
  348. package/.docs/raw/reference/rag/rerank.mdx +2 -3
  349. package/.docs/raw/reference/rag/rerankWithScorer.mdx +1 -2
  350. package/.docs/raw/reference/server/create-route.mdx +328 -0
  351. package/.docs/raw/reference/server/express-adapter.mdx +260 -0
  352. package/.docs/raw/reference/server/hono-adapter.mdx +242 -0
  353. package/.docs/raw/reference/server/mastra-server.mdx +345 -0
  354. package/.docs/raw/reference/server/routes.mdx +250 -0
  355. package/.docs/raw/reference/storage/cloudflare-d1.mdx +38 -1
  356. package/.docs/raw/reference/storage/cloudflare.mdx +1 -1
  357. package/.docs/raw/reference/storage/convex.mdx +164 -0
  358. package/.docs/raw/reference/storage/dynamodb.mdx +1 -1
  359. package/.docs/raw/reference/storage/lance.mdx +34 -1
  360. package/.docs/raw/reference/storage/libsql.mdx +38 -1
  361. package/.docs/raw/reference/storage/mongodb.mdx +40 -1
  362. package/.docs/raw/reference/storage/mssql.mdx +38 -1
  363. package/.docs/raw/reference/storage/postgresql.mdx +38 -1
  364. package/.docs/raw/reference/storage/upstash.mdx +1 -1
  365. package/.docs/raw/reference/streaming/ChunkType.mdx +25 -4
  366. package/.docs/raw/reference/streaming/agents/MastraModelOutput.mdx +1 -1
  367. package/.docs/raw/reference/streaming/agents/stream.mdx +84 -124
  368. package/.docs/raw/reference/streaming/agents/streamLegacy.mdx +1 -1
  369. package/.docs/raw/reference/streaming/workflows/observeStream.mdx +8 -10
  370. package/.docs/raw/reference/streaming/workflows/{resumeStreamVNext.mdx → resumeStream.mdx} +51 -11
  371. package/.docs/raw/reference/streaming/workflows/stream.mdx +84 -25
  372. package/.docs/raw/reference/streaming/workflows/timeTravelStream.mdx +170 -0
  373. package/.docs/raw/reference/templates/overview.mdx +2 -5
  374. package/.docs/raw/reference/tools/client.mdx +2 -3
  375. package/.docs/raw/reference/tools/create-tool.mdx +135 -4
  376. package/.docs/raw/reference/tools/document-chunker-tool.mdx +1 -1
  377. package/.docs/raw/reference/tools/graph-rag-tool.mdx +7 -7
  378. package/.docs/raw/reference/tools/mcp-client.mdx +131 -23
  379. package/.docs/raw/reference/tools/mcp-server.mdx +56 -8
  380. package/.docs/raw/reference/tools/vector-query-tool.mdx +16 -17
  381. package/.docs/raw/reference/vectors/astra.mdx +1 -1
  382. package/.docs/raw/reference/vectors/chroma.mdx +82 -2
  383. package/.docs/raw/reference/vectors/convex.mdx +429 -0
  384. package/.docs/raw/reference/vectors/couchbase.mdx +25 -18
  385. package/.docs/raw/reference/vectors/duckdb.mdx +462 -0
  386. package/.docs/raw/reference/vectors/elasticsearch.mdx +310 -0
  387. package/.docs/raw/reference/vectors/lance.mdx +39 -23
  388. package/.docs/raw/reference/vectors/libsql.mdx +36 -3
  389. package/.docs/raw/reference/vectors/mongodb.mdx +36 -3
  390. package/.docs/raw/reference/vectors/opensearch.mdx +38 -17
  391. package/.docs/raw/reference/vectors/pg.mdx +44 -37
  392. package/.docs/raw/reference/vectors/pinecone.mdx +70 -3
  393. package/.docs/raw/reference/vectors/qdrant.mdx +37 -2
  394. package/.docs/raw/reference/vectors/s3vectors.mdx +1 -1
  395. package/.docs/raw/reference/vectors/turbopuffer.mdx +75 -1
  396. package/.docs/raw/reference/vectors/upstash.mdx +1 -1
  397. package/.docs/raw/reference/vectors/vectorize.mdx +1 -1
  398. package/.docs/raw/reference/voice/azure.mdx +96 -81
  399. package/.docs/raw/reference/voice/cloudflare.mdx +1 -1
  400. package/.docs/raw/reference/voice/composite-voice.mdx +72 -29
  401. package/.docs/raw/reference/voice/deepgram.mdx +1 -1
  402. package/.docs/raw/reference/voice/elevenlabs.mdx +1 -1
  403. package/.docs/raw/reference/voice/google-gemini-live.mdx +1 -1
  404. package/.docs/raw/reference/voice/google.mdx +160 -21
  405. package/.docs/raw/reference/voice/mastra-voice.mdx +1 -1
  406. package/.docs/raw/reference/voice/murf.mdx +1 -1
  407. package/.docs/raw/reference/voice/openai-realtime.mdx +3 -3
  408. package/.docs/raw/reference/voice/openai.mdx +1 -1
  409. package/.docs/raw/reference/voice/playai.mdx +1 -1
  410. package/.docs/raw/reference/voice/sarvam.mdx +1 -1
  411. package/.docs/raw/reference/voice/speechify.mdx +1 -1
  412. package/.docs/raw/reference/voice/voice.addInstructions.mdx +3 -4
  413. package/.docs/raw/reference/voice/voice.addTools.mdx +2 -2
  414. package/.docs/raw/reference/voice/voice.answer.mdx +2 -2
  415. package/.docs/raw/reference/voice/voice.close.mdx +2 -2
  416. package/.docs/raw/reference/voice/voice.connect.mdx +2 -2
  417. package/.docs/raw/reference/voice/voice.events.mdx +1 -1
  418. package/.docs/raw/reference/voice/voice.getSpeakers.mdx +1 -1
  419. package/.docs/raw/reference/voice/voice.listen.mdx +87 -53
  420. package/.docs/raw/reference/voice/voice.off.mdx +2 -2
  421. package/.docs/raw/reference/voice/voice.on.mdx +2 -2
  422. package/.docs/raw/reference/voice/voice.send.mdx +2 -2
  423. package/.docs/raw/reference/voice/voice.speak.mdx +76 -41
  424. package/.docs/raw/reference/voice/voice.updateConfig.mdx +2 -2
  425. package/.docs/raw/reference/workflows/run-methods/cancel.mdx +1 -1
  426. package/.docs/raw/reference/workflows/run-methods/restart.mdx +142 -0
  427. package/.docs/raw/reference/workflows/run-methods/resume.mdx +45 -1
  428. package/.docs/raw/reference/workflows/run-methods/start.mdx +48 -4
  429. package/.docs/raw/reference/workflows/run-methods/timeTravel.mdx +310 -0
  430. package/.docs/raw/reference/workflows/run.mdx +28 -6
  431. package/.docs/raw/reference/workflows/step.mdx +65 -1
  432. package/.docs/raw/reference/workflows/workflow-methods/branch.mdx +1 -1
  433. package/.docs/raw/reference/workflows/workflow-methods/commit.mdx +1 -1
  434. package/.docs/raw/reference/workflows/workflow-methods/create-run.mdx +1 -1
  435. package/.docs/raw/reference/workflows/workflow-methods/dountil.mdx +1 -1
  436. package/.docs/raw/reference/workflows/workflow-methods/dowhile.mdx +1 -1
  437. package/.docs/raw/reference/workflows/workflow-methods/foreach.mdx +69 -4
  438. package/.docs/raw/reference/workflows/workflow-methods/map.mdx +1 -1
  439. package/.docs/raw/reference/workflows/workflow-methods/parallel.mdx +1 -1
  440. package/.docs/raw/reference/workflows/workflow-methods/sendEvent.mdx +1 -1
  441. package/.docs/raw/reference/workflows/workflow-methods/sleep.mdx +1 -1
  442. package/.docs/raw/reference/workflows/workflow-methods/sleepUntil.mdx +1 -1
  443. package/.docs/raw/reference/workflows/workflow-methods/then.mdx +1 -1
  444. package/.docs/raw/reference/workflows/workflow-methods/waitForEvent.mdx +1 -1
  445. package/.docs/raw/reference/workflows/workflow.mdx +44 -2
  446. package/.docs/raw/server-db/custom-adapters.mdx +386 -0
  447. package/.docs/raw/server-db/custom-api-routes.mdx +6 -6
  448. package/.docs/raw/server-db/mastra-client.mdx +3 -4
  449. package/.docs/raw/server-db/{production-server.mdx → mastra-server.mdx} +22 -12
  450. package/.docs/raw/server-db/middleware.mdx +31 -31
  451. package/.docs/raw/server-db/request-context.mdx +3 -4
  452. package/.docs/raw/server-db/server-adapters.mdx +312 -0
  453. package/.docs/raw/server-db/storage.mdx +12 -1
  454. package/.docs/raw/streaming/events.mdx +1 -1
  455. package/.docs/raw/streaming/overview.mdx +27 -16
  456. package/.docs/raw/streaming/tool-streaming.mdx +58 -19
  457. package/.docs/raw/streaming/workflow-streaming.mdx +6 -12
  458. package/.docs/raw/tools-mcp/advanced-usage.mdx +2 -3
  459. package/.docs/raw/tools-mcp/mcp-overview.mdx +4 -6
  460. package/.docs/raw/tools-mcp/overview.mdx +1 -1
  461. package/.docs/raw/voice/overview.mdx +88 -41
  462. package/.docs/raw/voice/speech-to-speech.mdx +5 -5
  463. package/.docs/raw/voice/speech-to-text.mdx +2 -3
  464. package/.docs/raw/voice/text-to-speech.mdx +2 -3
  465. package/.docs/raw/workflows/agents-and-tools.mdx +43 -5
  466. package/.docs/raw/workflows/control-flow.mdx +534 -3
  467. package/.docs/raw/workflows/error-handling.mdx +5 -4
  468. package/.docs/raw/workflows/human-in-the-loop.mdx +160 -213
  469. package/.docs/raw/workflows/inngest-workflow.mdx +1 -1
  470. package/.docs/raw/workflows/input-data-mapping.mdx +1 -1
  471. package/.docs/raw/workflows/overview.mdx +67 -47
  472. package/.docs/raw/workflows/snapshots.mdx +5 -3
  473. package/.docs/raw/workflows/suspend-and-resume.mdx +121 -204
  474. package/.docs/raw/workflows/time-travel.mdx +313 -0
  475. package/.docs/raw/workflows/workflow-state.mdx +190 -0
  476. package/CHANGELOG.md +88 -0
  477. package/dist/{chunk-5NJC7NRO.js → chunk-4CM2BQNP.js} +24 -4
  478. package/dist/prepare-docs/package-changes.d.ts.map +1 -1
  479. package/dist/prepare-docs/prepare.js +1 -1
  480. package/dist/stdio.js +17 -19
  481. package/package.json +10 -14
  482. package/.docs/raw/deployment/serverless-platforms/index.mdx +0 -58
  483. package/.docs/raw/frameworks/agentic-uis/ai-sdk.mdx +0 -688
  484. package/.docs/raw/frameworks/agentic-uis/cedar-os.mdx +0 -123
  485. package/.docs/raw/frameworks/agentic-uis/copilotkit.mdx +0 -382
  486. package/.docs/raw/frameworks/agentic-uis/openrouter.mdx +0 -179
  487. package/.docs/raw/frameworks/web-frameworks/next-js.mdx +0 -379
  488. package/.docs/raw/getting-started/templates.mdx +0 -73
  489. package/.docs/raw/mastra-cloud/observability.mdx +0 -51
  490. package/.docs/raw/reference/streaming/workflows/observeStreamVNext.mdx +0 -47
  491. package/.docs/raw/reference/streaming/workflows/streamVNext.mdx +0 -153
@@ -0,0 +1,803 @@
1
+ ---
2
+ title: "Reference: Processor Interface | Processors"
3
+ description: "API reference for the Processor interface in Mastra, which defines the contract for transforming, validating, and controlling messages in agent pipelines."
4
+ ---
5
+
6
+ # Processor Interface
7
+
8
+ The `Processor` interface defines the contract for all processors in Mastra. Processors can implement one or more methods to handle different stages of the agent execution pipeline.
9
+
10
+ ## When processor methods run
11
+
12
+ The five processor methods run at different points in the agent execution lifecycle:
13
+
14
+ ```
15
+ ┌─────────────────────────────────────────────────────────────────┐
16
+ │ Agent Execution Flow │
17
+ ├─────────────────────────────────────────────────────────────────┤
18
+ │ │
19
+ │ User Input │
20
+ │ │ │
21
+ │ ▼ │
22
+ │ ┌─────────────────┐ │
23
+ │ │ processInput │ ← Runs ONCE at start │
24
+ │ └────────┬────────┘ │
25
+ │ │ │
26
+ │ ▼ │
27
+ │ ┌─────────────────────────────────────────────────────────┐ │
28
+ │ │ Agentic Loop │ │
29
+ │ │ ┌─────────────────────┐ │ │
30
+ │ │ │ processInputStep │ ← Runs at EACH step │ │
31
+ │ │ └──────────┬──────────┘ │ │
32
+ │ │ │ │ │
33
+ │ │ ▼ │ │
34
+ │ │ LLM Execution │ │
35
+ │ │ │ │ │
36
+ │ │ ▼ │ │
37
+ │ │ ┌──────────────────────┐ │ │
38
+ │ │ │ processOutputStream │ ← Runs on EACH stream chunk │ │
39
+ │ │ └──────────┬───────────┘ │ │
40
+ │ │ │ │ │
41
+ │ │ ▼ │ │
42
+ │ │ ┌──────────────────────┐ │ │
43
+ │ │ │ processOutputStep │ ← Runs after EACH LLM step │ │
44
+ │ │ └──────────┬───────────┘ │ │
45
+ │ │ │ │ │
46
+ │ │ ▼ │ │
47
+ │ │ Tool Execution (if needed) │ │
48
+ │ │ │ │ │
49
+ │ │ └──────── Loop back if tools called ────────│ │
50
+ │ └─────────────────────────────────────────────────────────┘ │
51
+ │ │ │
52
+ │ ▼ │
53
+ │ ┌─────────────────────┐ │
54
+ │ │ processOutputResult │ ← Runs ONCE after completion │
55
+ │ └─────────────────────┘ │
56
+ │ │ │
57
+ │ ▼ │
58
+ │ Final Response │
59
+ │ │
60
+ └─────────────────────────────────────────────────────────────────┘
61
+ ```
62
+
63
+ | Method | When it runs | Use case |
64
+ |--------|--------------|----------|
65
+ | `processInput` | Once at the start, before the agentic loop | Validate/transform initial user input, add context |
66
+ | `processInputStep` | At each step of the agentic loop, before each LLM call | Transform messages between steps, handle tool results |
67
+ | `processOutputStream` | On each streaming chunk during LLM response | Filter/modify streaming content, detect patterns in real-time |
68
+ | `processOutputStep` | After each LLM response, before tool execution | Validate output quality, implement guardrails with retry |
69
+ | `processOutputResult` | Once after generation completes | Post-process final response, log results |
70
+
71
+ ## Interface definition
72
+
73
+ ```typescript copy
74
+ interface Processor<TId extends string = string> {
75
+ readonly id: TId;
76
+ readonly name?: string;
77
+
78
+ processInput?(args: ProcessInputArgs): Promise<ProcessInputResult> | ProcessInputResult;
79
+ processInputStep?(args: ProcessInputStepArgs): ProcessorMessageResult;
80
+ processOutputStream?(args: ProcessOutputStreamArgs): Promise<ChunkType | null | undefined>;
81
+ processOutputStep?(args: ProcessOutputStepArgs): ProcessorMessageResult;
82
+ processOutputResult?(args: ProcessOutputResultArgs): ProcessorMessageResult;
83
+ }
84
+ ```
85
+
86
+ ## Properties
87
+
88
+ <PropertiesTable
89
+ content={[
90
+ {
91
+ name: "id",
92
+ type: "string",
93
+ description: "Unique identifier for the processor. Used for tracing and debugging.",
94
+ isOptional: false,
95
+ },
96
+ {
97
+ name: "name",
98
+ type: "string",
99
+ description: "Optional display name for the processor. Falls back to id if not provided.",
100
+ isOptional: true,
101
+ },
102
+ ]}
103
+ />
104
+
105
+ ## Methods
106
+
107
+ ### processInput
108
+
109
+ Processes input messages before they are sent to the LLM. Runs once at the start of agent execution.
110
+
111
+ ```typescript copy
112
+ processInput?(args: ProcessInputArgs): Promise<ProcessInputResult> | ProcessInputResult;
113
+ ```
114
+
115
+ #### ProcessInputArgs
116
+
117
+ <PropertiesTable
118
+ content={[
119
+ {
120
+ name: "messages",
121
+ type: "MastraDBMessage[]",
122
+ description: "User and assistant messages to process (excludes system messages).",
123
+ isOptional: false,
124
+ },
125
+ {
126
+ name: "systemMessages",
127
+ type: "CoreMessage[]",
128
+ description: "All system messages (agent instructions, memory context, user-provided). Can be modified and returned.",
129
+ isOptional: false,
130
+ },
131
+ {
132
+ name: "messageList",
133
+ type: "MessageList",
134
+ description: "Full MessageList instance for advanced message management.",
135
+ isOptional: false,
136
+ },
137
+ {
138
+ name: "abort",
139
+ type: "(reason?: string, options?: { retry?: boolean; metadata?: unknown }) => never",
140
+ description: "Function to abort processing. Throws a TripWire error that stops execution. Pass `retry: true` to request the LLM retry the step with feedback.",
141
+ isOptional: false,
142
+ },
143
+ {
144
+ name: "retryCount",
145
+ type: "number",
146
+ description: "Number of times processors have triggered retry for this generation. Use this to limit retry attempts.",
147
+ isOptional: true,
148
+ },
149
+ {
150
+ name: "tracingContext",
151
+ type: "TracingContext",
152
+ description: "Tracing context for observability.",
153
+ isOptional: true,
154
+ },
155
+ {
156
+ name: "requestContext",
157
+ type: "RequestContext",
158
+ description: "Request-scoped context with execution metadata like threadId and resourceId.",
159
+ isOptional: true,
160
+ },
161
+ ]}
162
+ />
163
+
164
+ #### ProcessInputResult
165
+
166
+ The method can return one of three types:
167
+
168
+ <PropertiesTable
169
+ content={[
170
+ {
171
+ name: "MastraDBMessage[]",
172
+ type: "array",
173
+ description: "Transformed messages array. System messages remain unchanged.",
174
+ },
175
+ {
176
+ name: "MessageList",
177
+ type: "MessageList",
178
+ description: "The same messageList instance passed in. Indicates you've mutated it directly.",
179
+ },
180
+ {
181
+ name: "{ messages, systemMessages }",
182
+ type: "object",
183
+ description: "Object with both transformed messages and modified system messages.",
184
+ },
185
+ ]}
186
+ />
187
+
188
+ ---
189
+
190
+ ### processInputStep
191
+
192
+ Processes input messages at each step of the agentic loop, before they are sent to the LLM. Unlike `processInput` which runs once at the start, this runs at every step including tool call continuations.
193
+
194
+ ```typescript copy
195
+ processInputStep?(args: ProcessInputStepArgs): ProcessorMessageResult;
196
+ ```
197
+
198
+ #### Execution order in the agentic loop
199
+
200
+ 1. `processInput` (once at start)
201
+ 2. `processInputStep` from inputProcessors (at each step, before LLM call)
202
+ 3. `prepareStep` callback (runs as part of the processInputStep pipeline, after inputProcessors)
203
+ 4. LLM execution
204
+ 5. Tool execution (if needed)
205
+ 6. Repeat from step 2 if tools were called
206
+
207
+ #### ProcessInputStepArgs
208
+
209
+ <PropertiesTable
210
+ content={[
211
+ {
212
+ name: "messages",
213
+ type: "MastraDBMessage[]",
214
+ description: "All messages including tool calls and results from previous steps (read-only snapshot).",
215
+ isOptional: false,
216
+ },
217
+ {
218
+ name: "messageList",
219
+ type: "MessageList",
220
+ description: "MessageList instance for managing messages. Can mutate directly or return in result.",
221
+ isOptional: false,
222
+ },
223
+ {
224
+ name: "stepNumber",
225
+ type: "number",
226
+ description: "Current step number (0-indexed). Step 0 is the initial LLM call.",
227
+ isOptional: false,
228
+ },
229
+ {
230
+ name: "steps",
231
+ type: "StepResult[]",
232
+ description: "Results from previous steps, including text, toolCalls, and toolResults.",
233
+ isOptional: false,
234
+ },
235
+ {
236
+ name: "systemMessages",
237
+ type: "CoreMessage[]",
238
+ description: "All system messages (read-only snapshot). Return in result to replace.",
239
+ isOptional: false,
240
+ },
241
+ {
242
+ name: "model",
243
+ type: "MastraLanguageModelV2",
244
+ description: "Current model being used. Return a different model in result to switch.",
245
+ isOptional: false,
246
+ },
247
+ {
248
+ name: "toolChoice",
249
+ type: "ToolChoice",
250
+ description: "Current tool choice setting ('auto', 'none', 'required', or specific tool).",
251
+ isOptional: true,
252
+ },
253
+ {
254
+ name: "activeTools",
255
+ type: "string[]",
256
+ description: "Currently active tool names. Return filtered array to limit tools.",
257
+ isOptional: true,
258
+ },
259
+ {
260
+ name: "tools",
261
+ type: "ToolSet",
262
+ description: "Current tools available for this step. Return in result to add/replace tools.",
263
+ isOptional: true,
264
+ },
265
+ {
266
+ name: "providerOptions",
267
+ type: "SharedV2ProviderOptions",
268
+ description: "Provider-specific options (e.g., Anthropic cacheControl, OpenAI reasoningEffort).",
269
+ isOptional: true,
270
+ },
271
+ {
272
+ name: "modelSettings",
273
+ type: "CallSettings",
274
+ description: "Model settings like temperature, maxTokens, topP.",
275
+ isOptional: true,
276
+ },
277
+ {
278
+ name: "structuredOutput",
279
+ type: "StructuredOutputOptions",
280
+ description: "Structured output configuration (schema, output mode). Return in result to modify.",
281
+ isOptional: true,
282
+ },
283
+ {
284
+ name: "abort",
285
+ type: "(reason?: string) => never",
286
+ description: "Function to abort processing.",
287
+ isOptional: false,
288
+ },
289
+ {
290
+ name: "tracingContext",
291
+ type: "TracingContext",
292
+ description: "Tracing context for observability.",
293
+ isOptional: true,
294
+ },
295
+ {
296
+ name: "requestContext",
297
+ type: "RequestContext",
298
+ description: "Request-scoped context with execution metadata.",
299
+ isOptional: true,
300
+ },
301
+ ]}
302
+ />
303
+
304
+ #### ProcessInputStepResult
305
+
306
+ The method can return any combination of these properties:
307
+
308
+ <PropertiesTable
309
+ content={[
310
+ {
311
+ name: "model",
312
+ type: "LanguageModelV2 | string",
313
+ description: "Change the model for this step. Can be a model instance or router ID like 'openai/gpt-4o'.",
314
+ isOptional: true,
315
+ },
316
+ {
317
+ name: "toolChoice",
318
+ type: "ToolChoice",
319
+ description: "Change tool selection behavior for this step.",
320
+ isOptional: true,
321
+ },
322
+ {
323
+ name: "activeTools",
324
+ type: "string[]",
325
+ description: "Filter which tools are available for this step.",
326
+ isOptional: true,
327
+ },
328
+ {
329
+ name: "tools",
330
+ type: "ToolSet",
331
+ description: "Replace or modify tools for this step. Use spread to merge: { tools: { ...tools, newTool } }.",
332
+ isOptional: true,
333
+ },
334
+ {
335
+ name: "messages",
336
+ type: "MastraDBMessage[]",
337
+ description: "Replace all messages. Cannot be used with messageList.",
338
+ isOptional: true,
339
+ },
340
+ {
341
+ name: "messageList",
342
+ type: "MessageList",
343
+ description: "Return the same messageList instance (indicates you mutated it). Cannot be used with messages.",
344
+ isOptional: true,
345
+ },
346
+ {
347
+ name: "systemMessages",
348
+ type: "CoreMessage[]",
349
+ description: "Replace all system messages for this step only.",
350
+ isOptional: true,
351
+ },
352
+ {
353
+ name: "providerOptions",
354
+ type: "SharedV2ProviderOptions",
355
+ description: "Change provider-specific options for this step.",
356
+ isOptional: true,
357
+ },
358
+ {
359
+ name: "modelSettings",
360
+ type: "CallSettings",
361
+ description: "Change model settings for this step.",
362
+ isOptional: true,
363
+ },
364
+ {
365
+ name: "structuredOutput",
366
+ type: "StructuredOutputOptions",
367
+ description: "Change structured output configuration for this step.",
368
+ isOptional: true,
369
+ },
370
+ ]}
371
+ />
372
+
373
+ #### Processor chaining
374
+
375
+ When multiple processors implement `processInputStep`, they run in order and changes chain through:
376
+
377
+ ```
378
+ Processor 1: receives { model: 'gpt-4o' } → returns { model: 'gpt-4o-mini' }
379
+ Processor 2: receives { model: 'gpt-4o-mini' } → returns { toolChoice: 'none' }
380
+ Final: model = 'gpt-4o-mini', toolChoice = 'none'
381
+ ```
382
+
383
+ #### System message isolation
384
+
385
+ System messages are **reset to their original values** at the start of each step. Modifications made in `processInputStep` only affect the current step, not subsequent steps.
386
+
387
+ #### Use cases
388
+
389
+ - Dynamic model switching based on step number or context
390
+ - Disabling tools after a certain number of steps
391
+ - Dynamically adding or replacing tools based on conversation context
392
+ - Transforming message part types between providers (e.g., `reasoning` → `thinking` for Anthropic)
393
+ - Modifying messages based on step number or accumulated context
394
+ - Adding step-specific system instructions
395
+ - Adjusting provider options per step (e.g., cache control)
396
+ - Modifying structured output schema based on step context
397
+
398
+ ---
399
+
400
+ ### processOutputStream
401
+
402
+ Processes streaming output chunks with built-in state management. Allows processors to accumulate chunks and make decisions based on larger context.
403
+
404
+ ```typescript copy
405
+ processOutputStream?(args: ProcessOutputStreamArgs): Promise<ChunkType | null | undefined>;
406
+ ```
407
+
408
+ #### ProcessOutputStreamArgs
409
+
410
+ <PropertiesTable
411
+ content={[
412
+ {
413
+ name: "part",
414
+ type: "ChunkType",
415
+ description: "The current stream chunk being processed.",
416
+ isOptional: false,
417
+ },
418
+ {
419
+ name: "streamParts",
420
+ type: "ChunkType[]",
421
+ description: "All chunks seen so far in the stream.",
422
+ isOptional: false,
423
+ },
424
+ {
425
+ name: "state",
426
+ type: "Record<string, unknown>",
427
+ description: "Mutable state object that persists across chunks within a single stream.",
428
+ isOptional: false,
429
+ },
430
+ {
431
+ name: "abort",
432
+ type: "(reason?: string) => never",
433
+ description: "Function to abort the stream.",
434
+ isOptional: false,
435
+ },
436
+ {
437
+ name: "messageList",
438
+ type: "MessageList",
439
+ description: "MessageList instance for accessing conversation history.",
440
+ isOptional: true,
441
+ },
442
+ {
443
+ name: "tracingContext",
444
+ type: "TracingContext",
445
+ description: "Tracing context for observability.",
446
+ isOptional: true,
447
+ },
448
+ {
449
+ name: "requestContext",
450
+ type: "RequestContext",
451
+ description: "Request-scoped context with execution metadata.",
452
+ isOptional: true,
453
+ },
454
+ ]}
455
+ />
456
+
457
+ #### Return value
458
+
459
+ - Return the `ChunkType` to emit it (possibly modified)
460
+ - Return `null` or `undefined` to skip emitting the chunk
461
+
462
+ ---
463
+
464
+ ### processOutputResult
465
+
466
+ Processes the complete output result after streaming or generation is finished.
467
+
468
+ ```typescript copy
469
+ processOutputResult?(args: ProcessOutputResultArgs): ProcessorMessageResult;
470
+ ```
471
+
472
+ #### ProcessOutputResultArgs
473
+
474
+ <PropertiesTable
475
+ content={[
476
+ {
477
+ name: "messages",
478
+ type: "MastraDBMessage[]",
479
+ description: "The generated response messages.",
480
+ isOptional: false,
481
+ },
482
+ {
483
+ name: "messageList",
484
+ type: "MessageList",
485
+ description: "MessageList instance for managing messages.",
486
+ isOptional: false,
487
+ },
488
+ {
489
+ name: "abort",
490
+ type: "(reason?: string) => never",
491
+ description: "Function to abort processing.",
492
+ isOptional: false,
493
+ },
494
+ {
495
+ name: "tracingContext",
496
+ type: "TracingContext",
497
+ description: "Tracing context for observability.",
498
+ isOptional: true,
499
+ },
500
+ {
501
+ name: "requestContext",
502
+ type: "RequestContext",
503
+ description: "Request-scoped context with execution metadata.",
504
+ isOptional: true,
505
+ },
506
+ ]}
507
+ />
508
+
509
+ ---
510
+
511
+ ### processOutputStep
512
+
513
+ Processes output after each LLM response in the agentic loop, before tool execution. Unlike `processOutputResult` which runs once at the end, this runs at every step. This is the ideal method for implementing guardrails that can trigger retries.
514
+
515
+ ```typescript copy
516
+ processOutputStep?(args: ProcessOutputStepArgs): ProcessorMessageResult;
517
+ ```
518
+
519
+ #### ProcessOutputStepArgs
520
+
521
+ <PropertiesTable
522
+ content={[
523
+ {
524
+ name: "messages",
525
+ type: "MastraDBMessage[]",
526
+ description: "All messages including the latest LLM response.",
527
+ isOptional: false,
528
+ },
529
+ {
530
+ name: "messageList",
531
+ type: "MessageList",
532
+ description: "MessageList instance for managing messages.",
533
+ isOptional: false,
534
+ },
535
+ {
536
+ name: "stepNumber",
537
+ type: "number",
538
+ description: "Current step number (0-indexed).",
539
+ isOptional: false,
540
+ },
541
+ {
542
+ name: "finishReason",
543
+ type: "string",
544
+ description: "The finish reason from the LLM (stop, tool-use, length, etc.).",
545
+ isOptional: true,
546
+ },
547
+ {
548
+ name: "toolCalls",
549
+ type: "ToolCallInfo[]",
550
+ description: "Tool calls made in this step (if any).",
551
+ isOptional: true,
552
+ },
553
+ {
554
+ name: "text",
555
+ type: "string",
556
+ description: "Generated text from this step.",
557
+ isOptional: true,
558
+ },
559
+ {
560
+ name: "systemMessages",
561
+ type: "CoreMessage[]",
562
+ description: "All system messages for read/modify access.",
563
+ isOptional: true,
564
+ },
565
+ {
566
+ name: "abort",
567
+ type: "(reason?: string, options?: { retry?: boolean; metadata?: unknown }) => never",
568
+ description: "Function to abort processing. Pass `retry: true` to request the LLM retry the step.",
569
+ isOptional: false,
570
+ },
571
+ {
572
+ name: "retryCount",
573
+ type: "number",
574
+ description: "Number of times processors have triggered retry. Use this to limit retry attempts.",
575
+ isOptional: true,
576
+ },
577
+ {
578
+ name: "tracingContext",
579
+ type: "TracingContext",
580
+ description: "Tracing context for observability.",
581
+ isOptional: true,
582
+ },
583
+ {
584
+ name: "requestContext",
585
+ type: "RequestContext",
586
+ description: "Request-scoped context with execution metadata.",
587
+ isOptional: true,
588
+ },
589
+ ]}
590
+ />
591
+
592
+ #### Use cases
593
+
594
+ - Implementing quality guardrails that can request retries
595
+ - Validating LLM output before tool execution
596
+ - Adding per-step logging or metrics
597
+ - Implementing output moderation with retry capability
598
+
599
+ #### Example: Quality guardrail with retry
600
+
601
+ ```typescript title="src/mastra/processors/quality-guardrail.ts" showLineNumbers copy
602
+ import type { Processor } from "@mastra/core";
603
+
604
+ export class QualityGuardrail implements Processor {
605
+ id = "quality-guardrail";
606
+
607
+ async processOutputStep({ text, abort, retryCount }) {
608
+ const score = await evaluateResponseQuality(text);
609
+
610
+ if (score < 0.7) {
611
+ if (retryCount < 3) {
612
+ // Request retry with feedback for the LLM
613
+ abort("Response quality too low. Please provide more detail.", {
614
+ retry: true,
615
+ metadata: { qualityScore: score },
616
+ });
617
+ } else {
618
+ // Max retries reached, block the response
619
+ abort("Response quality too low after multiple attempts.");
620
+ }
621
+ }
622
+
623
+ return [];
624
+ }
625
+ }
626
+ ```
627
+
628
+ ## Processor types
629
+
630
+ Mastra provides type aliases to ensure processors implement the required methods:
631
+
632
+ ```typescript copy
633
+ // Must implement processInput OR processInputStep (or both)
634
+ type InputProcessor = Processor & (
635
+ | { processInput: required }
636
+ | { processInputStep: required }
637
+ );
638
+
639
+ // Must implement processOutputStream, processOutputStep, OR processOutputResult (or any combination)
640
+ type OutputProcessor = Processor & (
641
+ | { processOutputStream: required }
642
+ | { processOutputStep: required }
643
+ | { processOutputResult: required }
644
+ );
645
+ ```
646
+
647
+ ## Usage examples
648
+
649
+ ### Basic input processor
650
+
651
+ ```typescript title="src/mastra/processors/lowercase.ts" showLineNumbers copy
652
+ import type { Processor, MastraDBMessage } from "@mastra/core";
653
+
654
+ export class LowercaseProcessor implements Processor {
655
+ id = "lowercase";
656
+
657
+ async processInput({ messages }): Promise<MastraDBMessage[]> {
658
+ return messages.map((msg) => ({
659
+ ...msg,
660
+ content: {
661
+ ...msg.content,
662
+ parts: msg.content.parts?.map((part) =>
663
+ part.type === "text"
664
+ ? { ...part, text: part.text.toLowerCase() }
665
+ : part
666
+ ),
667
+ },
668
+ }));
669
+ }
670
+ }
671
+ ```
672
+
673
+ ### Per-step processor with processInputStep
674
+
675
+ ```typescript title="src/mastra/processors/dynamic-model.ts" showLineNumbers copy
676
+ import type { Processor, ProcessInputStepArgs, ProcessInputStepResult } from "@mastra/core";
677
+
678
+ export class DynamicModelProcessor implements Processor {
679
+ id = "dynamic-model";
680
+
681
+ async processInputStep({
682
+ stepNumber,
683
+ steps,
684
+ toolChoice,
685
+ }: ProcessInputStepArgs): Promise<ProcessInputStepResult> {
686
+ // Use a fast model for initial response
687
+ if (stepNumber === 0) {
688
+ return { model: "openai/gpt-4o-mini" };
689
+ }
690
+
691
+ // Switch to powerful model after tool calls
692
+ if (steps.length > 0 && steps[steps.length - 1].toolCalls?.length) {
693
+ return { model: "openai/gpt-4o" };
694
+ }
695
+
696
+ // Disable tools after 5 steps to force completion
697
+ if (stepNumber > 5) {
698
+ return { toolChoice: "none" };
699
+ }
700
+
701
+ return {};
702
+ }
703
+ }
704
+ ```
705
+
706
+ ### Message transformer with processInputStep
707
+
708
+ ```typescript title="src/mastra/processors/reasoning-transformer.ts" showLineNumbers copy
709
+ import type { Processor, MastraDBMessage } from "@mastra/core";
710
+
711
+ export class ReasoningTransformer implements Processor {
712
+ id = "reasoning-transformer";
713
+
714
+ async processInputStep({ messages, messageList }) {
715
+ // Transform reasoning parts to thinking parts at each step
716
+ // This is useful when switching between model providers
717
+ for (const msg of messages) {
718
+ if (msg.role === "assistant" && msg.content.parts) {
719
+ for (const part of msg.content.parts) {
720
+ if (part.type === "reasoning") {
721
+ (part as any).type = "thinking";
722
+ }
723
+ }
724
+ }
725
+ }
726
+ return messageList;
727
+ }
728
+ }
729
+ ```
730
+
731
+ ### Hybrid processor (input and output)
732
+
733
+ ```typescript title="src/mastra/processors/content-filter.ts" showLineNumbers copy
734
+ import type { Processor, MastraDBMessage, ChunkType } from "@mastra/core";
735
+
736
+ export class ContentFilter implements Processor {
737
+ id = "content-filter";
738
+ private blockedWords: string[];
739
+
740
+ constructor(blockedWords: string[]) {
741
+ this.blockedWords = blockedWords;
742
+ }
743
+
744
+ async processInput({ messages, abort }): Promise<MastraDBMessage[]> {
745
+ for (const msg of messages) {
746
+ const text = msg.content.parts
747
+ ?.filter((p) => p.type === "text")
748
+ .map((p) => p.text)
749
+ .join(" ");
750
+
751
+ if (this.blockedWords.some((word) => text?.includes(word))) {
752
+ abort("Blocked content detected in input");
753
+ }
754
+ }
755
+ return messages;
756
+ }
757
+
758
+ async processOutputStream({ part, abort }): Promise<ChunkType | null> {
759
+ if (part.type === "text-delta") {
760
+ if (this.blockedWords.some((word) => part.textDelta.includes(word))) {
761
+ abort("Blocked content detected in output");
762
+ }
763
+ }
764
+ return part;
765
+ }
766
+ }
767
+ ```
768
+
769
+ ### Stream accumulator with state
770
+
771
+ ```typescript title="src/mastra/processors/word-counter.ts" showLineNumbers copy
772
+ import type { Processor, ChunkType } from "@mastra/core";
773
+
774
+ export class WordCounter implements Processor {
775
+ id = "word-counter";
776
+
777
+ async processOutputStream({ part, state }): Promise<ChunkType> {
778
+ // Initialize state on first chunk
779
+ if (!state.wordCount) {
780
+ state.wordCount = 0;
781
+ }
782
+
783
+ // Count words in text chunks
784
+ if (part.type === "text-delta") {
785
+ const words = part.textDelta.split(/\s+/).filter(Boolean);
786
+ state.wordCount += words.length;
787
+ }
788
+
789
+ // Log word count on finish
790
+ if (part.type === "finish") {
791
+ console.log(`Total words: ${state.wordCount}`);
792
+ }
793
+
794
+ return part;
795
+ }
796
+ }
797
+ ```
798
+
799
+ ## Related
800
+
801
+ - [Processors overview](/docs/v1/agents/processors) - Conceptual guide to processors
802
+ - [Guardrails](/docs/v1/agents/guardrails) - Security and validation processors
803
+ - [Memory Processors](/docs/v1/memory/memory-processors) - Memory-specific processors