@mastra/core 1.6.0 → 1.7.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 (453) hide show
  1. package/CHANGELOG.md +236 -0
  2. package/dist/agent/agent.d.ts +6 -0
  3. package/dist/agent/agent.d.ts.map +1 -1
  4. package/dist/agent/index.cjs +8 -8
  5. package/dist/agent/index.js +1 -1
  6. package/dist/{chunk-VJWRJWSC.cjs → chunk-2X66GWF5.cjs} +94 -16
  7. package/dist/chunk-2X66GWF5.cjs.map +1 -0
  8. package/dist/{chunk-YM6245EM.js → chunk-6OXW5E2O.js} +3 -3
  9. package/dist/{chunk-YM6245EM.js.map → chunk-6OXW5E2O.js.map} +1 -1
  10. package/dist/{chunk-XWZAKKFT.cjs → chunk-6QBN6MZY.cjs} +14 -14
  11. package/dist/{chunk-XWZAKKFT.cjs.map → chunk-6QBN6MZY.cjs.map} +1 -1
  12. package/dist/{chunk-AYHSPIT6.cjs → chunk-7UAJ6LMR.cjs} +820 -259
  13. package/dist/chunk-7UAJ6LMR.cjs.map +1 -0
  14. package/dist/{chunk-RZNHRIM7.cjs → chunk-A72NTLFT.cjs} +5 -5
  15. package/dist/{chunk-RZNHRIM7.cjs.map → chunk-A72NTLFT.cjs.map} +1 -1
  16. package/dist/{chunk-EEU5NHHU.js → chunk-DFCRXDVK.js} +3 -3
  17. package/dist/{chunk-EEU5NHHU.js.map → chunk-DFCRXDVK.js.map} +1 -1
  18. package/dist/{chunk-5K45E5VE.js → chunk-GPJGPARM.js} +3 -2
  19. package/dist/chunk-GPJGPARM.js.map +1 -0
  20. package/dist/{chunk-LNKS4TJ6.cjs → chunk-HB6T4554.cjs} +8 -7
  21. package/dist/chunk-HB6T4554.cjs.map +1 -0
  22. package/dist/{chunk-DGS2KGDI.js → chunk-KUXNBWN7.js} +6 -5
  23. package/dist/chunk-KUXNBWN7.js.map +1 -0
  24. package/dist/{chunk-IHDE4CJV.js → chunk-QSHV7GPT.js} +89 -12
  25. package/dist/chunk-QSHV7GPT.js.map +1 -0
  26. package/dist/{chunk-3U3XFMGJ.cjs → chunk-QTAS3HND.cjs} +13 -8
  27. package/dist/chunk-QTAS3HND.cjs.map +1 -0
  28. package/dist/{chunk-RHKNKJNM.js → chunk-QWTB53GS.js} +4 -4
  29. package/dist/{chunk-RHKNKJNM.js.map → chunk-QWTB53GS.js.map} +1 -1
  30. package/dist/{chunk-4WG5K4CK.js → chunk-R4N65TLG.js} +7 -7
  31. package/dist/{chunk-4WG5K4CK.js.map → chunk-R4N65TLG.js.map} +1 -1
  32. package/dist/{chunk-5VQPSWPG.cjs → chunk-RABITNTG.cjs} +48 -48
  33. package/dist/{chunk-5VQPSWPG.cjs.map → chunk-RABITNTG.cjs.map} +1 -1
  34. package/dist/{chunk-TVPANHLE.cjs → chunk-SBOHDNIZ.cjs} +3 -2
  35. package/dist/chunk-SBOHDNIZ.cjs.map +1 -0
  36. package/dist/{chunk-MWGGSA5Q.js → chunk-T6GAM3SQ.js} +10 -5
  37. package/dist/chunk-T6GAM3SQ.js.map +1 -0
  38. package/dist/{chunk-TL2TTA4X.cjs → chunk-YQG7NBPR.cjs} +9 -9
  39. package/dist/{chunk-TL2TTA4X.cjs.map → chunk-YQG7NBPR.cjs.map} +1 -1
  40. package/dist/{chunk-XB3DA67Q.js → chunk-ZSBM2SVU.js} +818 -259
  41. package/dist/chunk-ZSBM2SVU.js.map +1 -0
  42. package/dist/datasets/experiment/scorer.d.ts.map +1 -1
  43. package/dist/datasets/index.cjs +17 -17
  44. package/dist/datasets/index.js +2 -2
  45. package/dist/evals/index.cjs +20 -20
  46. package/dist/evals/index.js +3 -3
  47. package/dist/evals/scoreTraces/index.cjs +7 -6
  48. package/dist/evals/scoreTraces/index.cjs.map +1 -1
  49. package/dist/evals/scoreTraces/index.js +4 -3
  50. package/dist/evals/scoreTraces/index.js.map +1 -1
  51. package/dist/evals/scoreTraces/scoreTracesWorkflow.d.ts.map +1 -1
  52. package/dist/harness/harness.d.ts +21 -1
  53. package/dist/harness/harness.d.ts.map +1 -1
  54. package/dist/harness/index.cjs +422 -5
  55. package/dist/harness/index.cjs.map +1 -1
  56. package/dist/harness/index.d.ts +2 -1
  57. package/dist/harness/index.d.ts.map +1 -1
  58. package/dist/harness/index.js +418 -3
  59. package/dist/harness/index.js.map +1 -1
  60. package/dist/harness/types.d.ts +151 -0
  61. package/dist/harness/types.d.ts.map +1 -1
  62. package/dist/index.cjs +2 -2
  63. package/dist/index.js +1 -1
  64. package/dist/loop/index.cjs +12 -12
  65. package/dist/loop/index.js +1 -1
  66. package/dist/loop/test-utils/tools.d.ts.map +1 -1
  67. package/dist/loop/workflows/agentic-loop/index.d.ts.map +1 -1
  68. package/dist/mastra/hooks.d.ts.map +1 -1
  69. package/dist/mastra/index.cjs +2 -2
  70. package/dist/mastra/index.js +1 -1
  71. package/dist/memory/index.cjs +14 -14
  72. package/dist/memory/index.js +1 -1
  73. package/dist/processor-provider/index.cjs +10 -10
  74. package/dist/processor-provider/index.js +1 -1
  75. package/dist/processors/index.cjs +45 -41
  76. package/dist/processors/index.js +1 -1
  77. package/dist/processors/processors/index.d.ts +1 -0
  78. package/dist/processors/processors/index.d.ts.map +1 -1
  79. package/dist/processors/processors/workspace-instructions.d.ts +50 -0
  80. package/dist/processors/processors/workspace-instructions.d.ts.map +1 -0
  81. package/dist/relevance/index.cjs +3 -3
  82. package/dist/relevance/index.js +1 -1
  83. package/dist/storage/constants.cjs +56 -56
  84. package/dist/storage/constants.d.ts.map +1 -1
  85. package/dist/storage/constants.js +1 -1
  86. package/dist/storage/index.cjs +160 -160
  87. package/dist/storage/index.js +2 -2
  88. package/dist/storage/types.d.ts +2 -0
  89. package/dist/storage/types.d.ts.map +1 -1
  90. package/dist/stream/aisdk/v5/compat/prepare-tools.d.ts.map +1 -1
  91. package/dist/stream/base/output.d.ts.map +1 -1
  92. package/dist/stream/index.cjs +8 -8
  93. package/dist/stream/index.js +1 -1
  94. package/dist/tool-loop-agent/index.cjs +4 -4
  95. package/dist/tool-loop-agent/index.js +1 -1
  96. package/dist/vector/index.cjs +7 -7
  97. package/dist/vector/index.js +1 -1
  98. package/dist/workflows/evented/index.cjs +10 -10
  99. package/dist/workflows/evented/index.js +1 -1
  100. package/dist/workflows/index.cjs +25 -25
  101. package/dist/workflows/index.js +1 -1
  102. package/dist/workspace/constants/index.d.ts +2 -0
  103. package/dist/workspace/constants/index.d.ts.map +1 -1
  104. package/dist/workspace/errors.d.ts +1 -1
  105. package/dist/workspace/errors.d.ts.map +1 -1
  106. package/dist/workspace/filesystem/composite-filesystem.d.ts +4 -1
  107. package/dist/workspace/filesystem/composite-filesystem.d.ts.map +1 -1
  108. package/dist/workspace/filesystem/file-write-lock.d.ts +35 -0
  109. package/dist/workspace/filesystem/file-write-lock.d.ts.map +1 -0
  110. package/dist/workspace/filesystem/filesystem.d.ts +5 -1
  111. package/dist/workspace/filesystem/filesystem.d.ts.map +1 -1
  112. package/dist/workspace/filesystem/index.d.ts +1 -0
  113. package/dist/workspace/filesystem/index.d.ts.map +1 -1
  114. package/dist/workspace/filesystem/local-filesystem.d.ts +17 -1
  115. package/dist/workspace/filesystem/local-filesystem.d.ts.map +1 -1
  116. package/dist/workspace/index.cjs +72 -64
  117. package/dist/workspace/index.d.ts +3 -2
  118. package/dist/workspace/index.d.ts.map +1 -1
  119. package/dist/workspace/index.js +1 -1
  120. package/dist/workspace/lifecycle.d.ts +1 -9
  121. package/dist/workspace/lifecycle.d.ts.map +1 -1
  122. package/dist/workspace/sandbox/index.d.ts +2 -0
  123. package/dist/workspace/sandbox/index.d.ts.map +1 -1
  124. package/dist/workspace/sandbox/local-process-manager.d.ts +18 -0
  125. package/dist/workspace/sandbox/local-process-manager.d.ts.map +1 -0
  126. package/dist/workspace/sandbox/local-sandbox.d.ts +49 -35
  127. package/dist/workspace/sandbox/local-sandbox.d.ts.map +1 -1
  128. package/dist/workspace/sandbox/mastra-sandbox.d.ts +45 -11
  129. package/dist/workspace/sandbox/mastra-sandbox.d.ts.map +1 -1
  130. package/dist/workspace/sandbox/native-sandbox/bubblewrap.d.ts +2 -3
  131. package/dist/workspace/sandbox/native-sandbox/bubblewrap.d.ts.map +1 -1
  132. package/dist/workspace/sandbox/native-sandbox/seatbelt.d.ts +2 -3
  133. package/dist/workspace/sandbox/native-sandbox/seatbelt.d.ts.map +1 -1
  134. package/dist/workspace/sandbox/native-sandbox/wrapper.d.ts +4 -5
  135. package/dist/workspace/sandbox/native-sandbox/wrapper.d.ts.map +1 -1
  136. package/dist/workspace/sandbox/process-manager/index.d.ts +4 -0
  137. package/dist/workspace/sandbox/process-manager/index.d.ts.map +1 -0
  138. package/dist/workspace/sandbox/process-manager/process-handle.d.ts +107 -0
  139. package/dist/workspace/sandbox/process-manager/process-handle.d.ts.map +1 -0
  140. package/dist/workspace/sandbox/process-manager/process-manager.d.ts +59 -0
  141. package/dist/workspace/sandbox/process-manager/process-manager.d.ts.map +1 -0
  142. package/dist/workspace/sandbox/process-manager/types.d.ts +24 -0
  143. package/dist/workspace/sandbox/process-manager/types.d.ts.map +1 -0
  144. package/dist/workspace/sandbox/sandbox.d.ts +38 -2
  145. package/dist/workspace/sandbox/sandbox.d.ts.map +1 -1
  146. package/dist/workspace/sandbox/types.d.ts +9 -2
  147. package/dist/workspace/sandbox/types.d.ts.map +1 -1
  148. package/dist/workspace/sandbox/utils.d.ts +7 -0
  149. package/dist/workspace/sandbox/utils.d.ts.map +1 -0
  150. package/dist/workspace/tools/execute-command.d.ts +53 -2
  151. package/dist/workspace/tools/execute-command.d.ts.map +1 -1
  152. package/dist/workspace/tools/get-process-output.d.ts +6 -0
  153. package/dist/workspace/tools/get-process-output.d.ts.map +1 -0
  154. package/dist/workspace/tools/index.d.ts +4 -1
  155. package/dist/workspace/tools/index.d.ts.map +1 -1
  156. package/dist/workspace/tools/kill-process.d.ts +4 -0
  157. package/dist/workspace/tools/kill-process.d.ts.map +1 -0
  158. package/dist/workspace/tools/output-helpers.d.ts +21 -0
  159. package/dist/workspace/tools/output-helpers.d.ts.map +1 -0
  160. package/dist/workspace/tools/tools.d.ts.map +1 -1
  161. package/dist/workspace/types.d.ts +31 -0
  162. package/dist/workspace/types.d.ts.map +1 -1
  163. package/dist/workspace/utils.d.ts +11 -0
  164. package/dist/workspace/utils.d.ts.map +1 -0
  165. package/dist/workspace/workspace.d.ts +36 -0
  166. package/dist/workspace/workspace.d.ts.map +1 -1
  167. package/package.json +7 -7
  168. package/dist/chunk-3U3XFMGJ.cjs.map +0 -1
  169. package/dist/chunk-5K45E5VE.js.map +0 -1
  170. package/dist/chunk-AYHSPIT6.cjs.map +0 -1
  171. package/dist/chunk-DGS2KGDI.js.map +0 -1
  172. package/dist/chunk-IHDE4CJV.js.map +0 -1
  173. package/dist/chunk-LNKS4TJ6.cjs.map +0 -1
  174. package/dist/chunk-MWGGSA5Q.js.map +0 -1
  175. package/dist/chunk-TVPANHLE.cjs.map +0 -1
  176. package/dist/chunk-VJWRJWSC.cjs.map +0 -1
  177. package/dist/chunk-XB3DA67Q.js.map +0 -1
  178. package/dist/docs/SKILL.md +0 -301
  179. package/dist/docs/assets/SOURCE_MAP.json +0 -1413
  180. package/dist/docs/references/docs-agents-adding-voice.md +0 -353
  181. package/dist/docs/references/docs-agents-agent-approval.md +0 -377
  182. package/dist/docs/references/docs-agents-agent-memory.md +0 -212
  183. package/dist/docs/references/docs-agents-guardrails.md +0 -382
  184. package/dist/docs/references/docs-agents-network-approval.md +0 -275
  185. package/dist/docs/references/docs-agents-networks.md +0 -290
  186. package/dist/docs/references/docs-agents-overview.md +0 -309
  187. package/dist/docs/references/docs-agents-processors.md +0 -632
  188. package/dist/docs/references/docs-agents-structured-output.md +0 -271
  189. package/dist/docs/references/docs-agents-using-tools.md +0 -214
  190. package/dist/docs/references/docs-evals-custom-scorers.md +0 -519
  191. package/dist/docs/references/docs-evals-overview.md +0 -146
  192. package/dist/docs/references/docs-evals-running-in-ci.md +0 -106
  193. package/dist/docs/references/docs-mcp-overview.md +0 -370
  194. package/dist/docs/references/docs-mcp-publishing-mcp-server.md +0 -95
  195. package/dist/docs/references/docs-memory-memory-processors.md +0 -316
  196. package/dist/docs/references/docs-memory-observational-memory.md +0 -246
  197. package/dist/docs/references/docs-memory-overview.md +0 -45
  198. package/dist/docs/references/docs-memory-semantic-recall.md +0 -272
  199. package/dist/docs/references/docs-memory-storage.md +0 -261
  200. package/dist/docs/references/docs-memory-working-memory.md +0 -400
  201. package/dist/docs/references/docs-observability-datasets-overview.md +0 -188
  202. package/dist/docs/references/docs-observability-datasets-running-experiments.md +0 -266
  203. package/dist/docs/references/docs-observability-logging.md +0 -99
  204. package/dist/docs/references/docs-observability-overview.md +0 -70
  205. package/dist/docs/references/docs-observability-tracing-bridges-otel.md +0 -209
  206. package/dist/docs/references/docs-observability-tracing-exporters-arize.md +0 -274
  207. package/dist/docs/references/docs-observability-tracing-exporters-braintrust.md +0 -111
  208. package/dist/docs/references/docs-observability-tracing-exporters-cloud.md +0 -129
  209. package/dist/docs/references/docs-observability-tracing-exporters-datadog.md +0 -187
  210. package/dist/docs/references/docs-observability-tracing-exporters-default.md +0 -211
  211. package/dist/docs/references/docs-observability-tracing-exporters-laminar.md +0 -100
  212. package/dist/docs/references/docs-observability-tracing-exporters-langfuse.md +0 -217
  213. package/dist/docs/references/docs-observability-tracing-exporters-langsmith.md +0 -202
  214. package/dist/docs/references/docs-observability-tracing-exporters-otel.md +0 -479
  215. package/dist/docs/references/docs-observability-tracing-exporters-posthog.md +0 -148
  216. package/dist/docs/references/docs-observability-tracing-overview.md +0 -1114
  217. package/dist/docs/references/docs-rag-chunking-and-embedding.md +0 -183
  218. package/dist/docs/references/docs-rag-graph-rag.md +0 -215
  219. package/dist/docs/references/docs-rag-overview.md +0 -72
  220. package/dist/docs/references/docs-rag-retrieval.md +0 -521
  221. package/dist/docs/references/docs-rag-vector-databases.md +0 -648
  222. package/dist/docs/references/docs-server-auth-auth0.md +0 -222
  223. package/dist/docs/references/docs-server-auth-clerk.md +0 -132
  224. package/dist/docs/references/docs-server-auth-composite-auth.md +0 -234
  225. package/dist/docs/references/docs-server-auth-custom-auth-provider.md +0 -513
  226. package/dist/docs/references/docs-server-auth-firebase.md +0 -272
  227. package/dist/docs/references/docs-server-auth-jwt.md +0 -110
  228. package/dist/docs/references/docs-server-auth-simple-auth.md +0 -178
  229. package/dist/docs/references/docs-server-auth-supabase.md +0 -117
  230. package/dist/docs/references/docs-server-auth-workos.md +0 -190
  231. package/dist/docs/references/docs-server-custom-adapters.md +0 -374
  232. package/dist/docs/references/docs-server-custom-api-routes.md +0 -267
  233. package/dist/docs/references/docs-server-mastra-client.md +0 -243
  234. package/dist/docs/references/docs-server-mastra-server.md +0 -71
  235. package/dist/docs/references/docs-server-middleware.md +0 -228
  236. package/dist/docs/references/docs-server-request-context.md +0 -478
  237. package/dist/docs/references/docs-streaming-events.md +0 -247
  238. package/dist/docs/references/docs-streaming-tool-streaming.md +0 -178
  239. package/dist/docs/references/docs-streaming-workflow-streaming.md +0 -109
  240. package/dist/docs/references/docs-voice-overview.md +0 -979
  241. package/dist/docs/references/docs-voice-speech-to-speech.md +0 -103
  242. package/dist/docs/references/docs-voice-speech-to-text.md +0 -80
  243. package/dist/docs/references/docs-voice-text-to-speech.md +0 -84
  244. package/dist/docs/references/docs-workflows-agents-and-tools.md +0 -170
  245. package/dist/docs/references/docs-workflows-control-flow.md +0 -823
  246. package/dist/docs/references/docs-workflows-error-handling.md +0 -360
  247. package/dist/docs/references/docs-workflows-human-in-the-loop.md +0 -213
  248. package/dist/docs/references/docs-workflows-overview.md +0 -372
  249. package/dist/docs/references/docs-workflows-snapshots.md +0 -238
  250. package/dist/docs/references/docs-workflows-suspend-and-resume.md +0 -205
  251. package/dist/docs/references/docs-workflows-time-travel.md +0 -309
  252. package/dist/docs/references/docs-workflows-workflow-state.md +0 -181
  253. package/dist/docs/references/docs-workspace-filesystem.md +0 -162
  254. package/dist/docs/references/docs-workspace-overview.md +0 -239
  255. package/dist/docs/references/docs-workspace-sandbox.md +0 -63
  256. package/dist/docs/references/docs-workspace-search.md +0 -219
  257. package/dist/docs/references/docs-workspace-skills.md +0 -126
  258. package/dist/docs/references/guides-agent-frameworks-ai-sdk.md +0 -140
  259. package/dist/docs/references/reference-agents-agent.md +0 -142
  260. package/dist/docs/references/reference-agents-generate.md +0 -174
  261. package/dist/docs/references/reference-agents-generateLegacy.md +0 -176
  262. package/dist/docs/references/reference-agents-getDefaultGenerateOptions.md +0 -36
  263. package/dist/docs/references/reference-agents-getDefaultOptions.md +0 -34
  264. package/dist/docs/references/reference-agents-getDefaultStreamOptions.md +0 -36
  265. package/dist/docs/references/reference-agents-getDescription.md +0 -21
  266. package/dist/docs/references/reference-agents-getInstructions.md +0 -34
  267. package/dist/docs/references/reference-agents-getLLM.md +0 -37
  268. package/dist/docs/references/reference-agents-getMemory.md +0 -34
  269. package/dist/docs/references/reference-agents-getModel.md +0 -34
  270. package/dist/docs/references/reference-agents-getTools.md +0 -29
  271. package/dist/docs/references/reference-agents-getVoice.md +0 -34
  272. package/dist/docs/references/reference-agents-listAgents.md +0 -35
  273. package/dist/docs/references/reference-agents-listScorers.md +0 -34
  274. package/dist/docs/references/reference-agents-listTools.md +0 -34
  275. package/dist/docs/references/reference-agents-listWorkflows.md +0 -34
  276. package/dist/docs/references/reference-agents-network.md +0 -134
  277. package/dist/docs/references/reference-ai-sdk-chat-route.md +0 -82
  278. package/dist/docs/references/reference-ai-sdk-network-route.md +0 -74
  279. package/dist/docs/references/reference-ai-sdk-to-ai-sdk-stream.md +0 -232
  280. package/dist/docs/references/reference-ai-sdk-with-mastra.md +0 -59
  281. package/dist/docs/references/reference-ai-sdk-workflow-route.md +0 -79
  282. package/dist/docs/references/reference-auth-auth0.md +0 -73
  283. package/dist/docs/references/reference-auth-clerk.md +0 -36
  284. package/dist/docs/references/reference-auth-firebase.md +0 -80
  285. package/dist/docs/references/reference-auth-jwt.md +0 -26
  286. package/dist/docs/references/reference-auth-supabase.md +0 -33
  287. package/dist/docs/references/reference-auth-workos.md +0 -84
  288. package/dist/docs/references/reference-client-js-agents.md +0 -438
  289. package/dist/docs/references/reference-configuration.md +0 -749
  290. package/dist/docs/references/reference-core-addGateway.md +0 -42
  291. package/dist/docs/references/reference-core-getAgent.md +0 -21
  292. package/dist/docs/references/reference-core-getAgentById.md +0 -21
  293. package/dist/docs/references/reference-core-getDeployer.md +0 -22
  294. package/dist/docs/references/reference-core-getGateway.md +0 -38
  295. package/dist/docs/references/reference-core-getGatewayById.md +0 -41
  296. package/dist/docs/references/reference-core-getLogger.md +0 -22
  297. package/dist/docs/references/reference-core-getMCPServer.md +0 -45
  298. package/dist/docs/references/reference-core-getMCPServerById.md +0 -53
  299. package/dist/docs/references/reference-core-getMemory.md +0 -50
  300. package/dist/docs/references/reference-core-getScorer.md +0 -54
  301. package/dist/docs/references/reference-core-getScorerById.md +0 -54
  302. package/dist/docs/references/reference-core-getServer.md +0 -22
  303. package/dist/docs/references/reference-core-getStorage.md +0 -22
  304. package/dist/docs/references/reference-core-getStoredAgentById.md +0 -89
  305. package/dist/docs/references/reference-core-getTelemetry.md +0 -22
  306. package/dist/docs/references/reference-core-getVector.md +0 -22
  307. package/dist/docs/references/reference-core-getWorkflow.md +0 -40
  308. package/dist/docs/references/reference-core-listAgents.md +0 -21
  309. package/dist/docs/references/reference-core-listGateways.md +0 -40
  310. package/dist/docs/references/reference-core-listLogs.md +0 -38
  311. package/dist/docs/references/reference-core-listLogsByRunId.md +0 -36
  312. package/dist/docs/references/reference-core-listMCPServers.md +0 -51
  313. package/dist/docs/references/reference-core-listMemory.md +0 -56
  314. package/dist/docs/references/reference-core-listScorers.md +0 -29
  315. package/dist/docs/references/reference-core-listStoredAgents.md +0 -93
  316. package/dist/docs/references/reference-core-listVectors.md +0 -22
  317. package/dist/docs/references/reference-core-listWorkflows.md +0 -21
  318. package/dist/docs/references/reference-core-mastra-class.md +0 -66
  319. package/dist/docs/references/reference-core-mastra-model-gateway.md +0 -153
  320. package/dist/docs/references/reference-core-setLogger.md +0 -26
  321. package/dist/docs/references/reference-core-setStorage.md +0 -27
  322. package/dist/docs/references/reference-datasets-addItem.md +0 -35
  323. package/dist/docs/references/reference-datasets-addItems.md +0 -33
  324. package/dist/docs/references/reference-datasets-compareExperiments.md +0 -48
  325. package/dist/docs/references/reference-datasets-create.md +0 -49
  326. package/dist/docs/references/reference-datasets-dataset.md +0 -78
  327. package/dist/docs/references/reference-datasets-datasets-manager.md +0 -84
  328. package/dist/docs/references/reference-datasets-delete.md +0 -23
  329. package/dist/docs/references/reference-datasets-deleteExperiment.md +0 -25
  330. package/dist/docs/references/reference-datasets-deleteItem.md +0 -25
  331. package/dist/docs/references/reference-datasets-deleteItems.md +0 -27
  332. package/dist/docs/references/reference-datasets-get.md +0 -29
  333. package/dist/docs/references/reference-datasets-getDetails.md +0 -45
  334. package/dist/docs/references/reference-datasets-getExperiment.md +0 -28
  335. package/dist/docs/references/reference-datasets-getItem.md +0 -31
  336. package/dist/docs/references/reference-datasets-getItemHistory.md +0 -29
  337. package/dist/docs/references/reference-datasets-list.md +0 -29
  338. package/dist/docs/references/reference-datasets-listExperimentResults.md +0 -37
  339. package/dist/docs/references/reference-datasets-listExperiments.md +0 -31
  340. package/dist/docs/references/reference-datasets-listItems.md +0 -44
  341. package/dist/docs/references/reference-datasets-listVersions.md +0 -31
  342. package/dist/docs/references/reference-datasets-startExperiment.md +0 -60
  343. package/dist/docs/references/reference-datasets-startExperimentAsync.md +0 -41
  344. package/dist/docs/references/reference-datasets-update.md +0 -46
  345. package/dist/docs/references/reference-datasets-updateItem.md +0 -36
  346. package/dist/docs/references/reference-evals-answer-relevancy.md +0 -105
  347. package/dist/docs/references/reference-evals-answer-similarity.md +0 -99
  348. package/dist/docs/references/reference-evals-bias.md +0 -120
  349. package/dist/docs/references/reference-evals-completeness.md +0 -137
  350. package/dist/docs/references/reference-evals-content-similarity.md +0 -101
  351. package/dist/docs/references/reference-evals-context-precision.md +0 -196
  352. package/dist/docs/references/reference-evals-create-scorer.md +0 -270
  353. package/dist/docs/references/reference-evals-faithfulness.md +0 -114
  354. package/dist/docs/references/reference-evals-hallucination.md +0 -220
  355. package/dist/docs/references/reference-evals-keyword-coverage.md +0 -128
  356. package/dist/docs/references/reference-evals-mastra-scorer.md +0 -123
  357. package/dist/docs/references/reference-evals-run-evals.md +0 -138
  358. package/dist/docs/references/reference-evals-scorer-utils.md +0 -330
  359. package/dist/docs/references/reference-evals-textual-difference.md +0 -113
  360. package/dist/docs/references/reference-evals-tone-consistency.md +0 -119
  361. package/dist/docs/references/reference-evals-toxicity.md +0 -123
  362. package/dist/docs/references/reference-harness-harness-class.md +0 -645
  363. package/dist/docs/references/reference-logging-pino-logger.md +0 -117
  364. package/dist/docs/references/reference-memory-deleteMessages.md +0 -40
  365. package/dist/docs/references/reference-memory-memory-class.md +0 -147
  366. package/dist/docs/references/reference-memory-observational-memory.md +0 -565
  367. package/dist/docs/references/reference-observability-tracing-bridges-otel.md +0 -131
  368. package/dist/docs/references/reference-observability-tracing-configuration.md +0 -178
  369. package/dist/docs/references/reference-observability-tracing-exporters-console-exporter.md +0 -138
  370. package/dist/docs/references/reference-observability-tracing-exporters-datadog.md +0 -116
  371. package/dist/docs/references/reference-observability-tracing-instances.md +0 -109
  372. package/dist/docs/references/reference-observability-tracing-interfaces.md +0 -749
  373. package/dist/docs/references/reference-observability-tracing-processors-sensitive-data-filter.md +0 -144
  374. package/dist/docs/references/reference-observability-tracing-spans.md +0 -224
  375. package/dist/docs/references/reference-processors-batch-parts-processor.md +0 -61
  376. package/dist/docs/references/reference-processors-language-detector.md +0 -81
  377. package/dist/docs/references/reference-processors-message-history-processor.md +0 -85
  378. package/dist/docs/references/reference-processors-moderation-processor.md +0 -104
  379. package/dist/docs/references/reference-processors-pii-detector.md +0 -107
  380. package/dist/docs/references/reference-processors-processor-interface.md +0 -525
  381. package/dist/docs/references/reference-processors-prompt-injection-detector.md +0 -71
  382. package/dist/docs/references/reference-processors-semantic-recall-processor.md +0 -123
  383. package/dist/docs/references/reference-processors-system-prompt-scrubber.md +0 -80
  384. package/dist/docs/references/reference-processors-token-limiter-processor.md +0 -113
  385. package/dist/docs/references/reference-processors-tool-call-filter.md +0 -85
  386. package/dist/docs/references/reference-processors-tool-search-processor.md +0 -113
  387. package/dist/docs/references/reference-processors-unicode-normalizer.md +0 -62
  388. package/dist/docs/references/reference-processors-working-memory-processor.md +0 -154
  389. package/dist/docs/references/reference-rag-database-config.md +0 -264
  390. package/dist/docs/references/reference-rag-embeddings.md +0 -92
  391. package/dist/docs/references/reference-server-mastra-server.md +0 -298
  392. package/dist/docs/references/reference-server-register-api-route.md +0 -249
  393. package/dist/docs/references/reference-storage-cloudflare-d1.md +0 -218
  394. package/dist/docs/references/reference-storage-composite.md +0 -235
  395. package/dist/docs/references/reference-storage-lance.md +0 -131
  396. package/dist/docs/references/reference-storage-libsql.md +0 -135
  397. package/dist/docs/references/reference-storage-mongodb.md +0 -262
  398. package/dist/docs/references/reference-storage-mssql.md +0 -155
  399. package/dist/docs/references/reference-storage-overview.md +0 -121
  400. package/dist/docs/references/reference-storage-postgresql.md +0 -529
  401. package/dist/docs/references/reference-storage-upstash.md +0 -160
  402. package/dist/docs/references/reference-streaming-ChunkType.md +0 -292
  403. package/dist/docs/references/reference-streaming-agents-MastraModelOutput.md +0 -182
  404. package/dist/docs/references/reference-streaming-agents-streamLegacy.md +0 -142
  405. package/dist/docs/references/reference-streaming-workflows-observeStream.md +0 -42
  406. package/dist/docs/references/reference-streaming-workflows-resumeStream.md +0 -61
  407. package/dist/docs/references/reference-streaming-workflows-stream.md +0 -88
  408. package/dist/docs/references/reference-streaming-workflows-timeTravelStream.md +0 -142
  409. package/dist/docs/references/reference-templates-overview.md +0 -194
  410. package/dist/docs/references/reference-tools-create-tool.md +0 -237
  411. package/dist/docs/references/reference-tools-graph-rag-tool.md +0 -185
  412. package/dist/docs/references/reference-tools-mcp-client.md +0 -962
  413. package/dist/docs/references/reference-tools-mcp-server.md +0 -1275
  414. package/dist/docs/references/reference-tools-vector-query-tool.md +0 -459
  415. package/dist/docs/references/reference-vectors-libsql.md +0 -305
  416. package/dist/docs/references/reference-vectors-mongodb.md +0 -295
  417. package/dist/docs/references/reference-vectors-pg.md +0 -408
  418. package/dist/docs/references/reference-vectors-upstash.md +0 -294
  419. package/dist/docs/references/reference-voice-composite-voice.md +0 -121
  420. package/dist/docs/references/reference-voice-mastra-voice.md +0 -313
  421. package/dist/docs/references/reference-voice-voice.addInstructions.md +0 -56
  422. package/dist/docs/references/reference-voice-voice.addTools.md +0 -67
  423. package/dist/docs/references/reference-voice-voice.connect.md +0 -94
  424. package/dist/docs/references/reference-voice-voice.events.md +0 -37
  425. package/dist/docs/references/reference-voice-voice.listen.md +0 -164
  426. package/dist/docs/references/reference-voice-voice.on.md +0 -111
  427. package/dist/docs/references/reference-voice-voice.speak.md +0 -157
  428. package/dist/docs/references/reference-workflows-run-methods-cancel.md +0 -86
  429. package/dist/docs/references/reference-workflows-run-methods-restart.md +0 -33
  430. package/dist/docs/references/reference-workflows-run-methods-resume.md +0 -59
  431. package/dist/docs/references/reference-workflows-run-methods-start.md +0 -58
  432. package/dist/docs/references/reference-workflows-run-methods-startAsync.md +0 -67
  433. package/dist/docs/references/reference-workflows-run-methods-timeTravel.md +0 -142
  434. package/dist/docs/references/reference-workflows-run.md +0 -59
  435. package/dist/docs/references/reference-workflows-step.md +0 -119
  436. package/dist/docs/references/reference-workflows-workflow-methods-branch.md +0 -25
  437. package/dist/docs/references/reference-workflows-workflow-methods-commit.md +0 -17
  438. package/dist/docs/references/reference-workflows-workflow-methods-create-run.md +0 -63
  439. package/dist/docs/references/reference-workflows-workflow-methods-dountil.md +0 -25
  440. package/dist/docs/references/reference-workflows-workflow-methods-dowhile.md +0 -25
  441. package/dist/docs/references/reference-workflows-workflow-methods-foreach.md +0 -118
  442. package/dist/docs/references/reference-workflows-workflow-methods-map.md +0 -93
  443. package/dist/docs/references/reference-workflows-workflow-methods-parallel.md +0 -21
  444. package/dist/docs/references/reference-workflows-workflow-methods-sleep.md +0 -35
  445. package/dist/docs/references/reference-workflows-workflow-methods-sleepUntil.md +0 -35
  446. package/dist/docs/references/reference-workflows-workflow-methods-then.md +0 -21
  447. package/dist/docs/references/reference-workflows-workflow.md +0 -157
  448. package/dist/docs/references/reference-workspace-filesystem.md +0 -202
  449. package/dist/docs/references/reference-workspace-local-filesystem.md +0 -327
  450. package/dist/docs/references/reference-workspace-local-sandbox.md +0 -285
  451. package/dist/docs/references/reference-workspace-sandbox.md +0 -81
  452. package/dist/docs/references/reference-workspace-workspace-class.md +0 -226
  453. package/dist/docs/references/reference.md +0 -276
@@ -1,107 +0,0 @@
1
- # PIIDetector
2
-
3
- The `PIIDetector` is a **hybrid processor** that can be used for both input and output processing to detect and redact personally identifiable information (PII) for privacy compliance. This processor helps maintain privacy by identifying various types of PII and providing flexible strategies for handling them, including multiple redaction methods to ensure compliance with GDPR, CCPA, HIPAA, and other privacy regulations.
4
-
5
- ## Usage example
6
-
7
- ```typescript
8
- import { PIIDetector } from "@mastra/core/processors";
9
-
10
- const processor = new PIIDetector({
11
- model: "openrouter/openai/gpt-oss-safeguard-20b",
12
- threshold: 0.6,
13
- strategy: "redact",
14
- detectionTypes: ["email", "phone", "credit-card", "ssn"]
15
- });
16
- ```
17
-
18
- ## Constructor parameters
19
-
20
- **options:** (`Options`): Configuration options for PII detection and redaction
21
-
22
- ### Options
23
-
24
- **model:** (`MastraModelConfig`): Model configuration for the detection agent
25
-
26
- **detectionTypes?:** (`string[]`): PII types to detect. If not specified, uses default types
27
-
28
- **threshold?:** (`number`): Confidence threshold for flagging (0-1). PII is flagged if any category score exceeds this threshold
29
-
30
- **strategy?:** (`'block' | 'warn' | 'filter' | 'redact'`): Strategy when PII is detected: 'block' rejects with error, 'warn' logs warning but allows through, 'filter' removes flagged messages, 'redact' replaces PII with redacted versions
31
-
32
- **redactionMethod?:** (`'mask' | 'hash' | 'remove' | 'placeholder'`): Redaction method for PII: 'mask' replaces with asterisks, 'hash' replaces with SHA256 hash, 'remove' removes entirely, 'placeholder' replaces with type placeholder
33
-
34
- **instructions?:** (`string`): Custom detection instructions for the agent. If not provided, uses default instructions based on detection types
35
-
36
- **includeDetections?:** (`boolean`): Whether to include detection details in logs. Useful for compliance auditing and debugging
37
-
38
- **preserveFormat?:** (`boolean`): Whether to preserve PII format during redaction. When true, maintains structure like \*\*\*-\*\*-1234 for phone numbers
39
-
40
- **providerOptions?:** (`ProviderOptions`): Provider-specific options passed to the internal detection agent. Use this to control model behavior like reasoning effort for thinking models (e.g., \`{ openai: { reasoningEffort: 'low' } }\`)
41
-
42
- ## Returns
43
-
44
- **id:** (`string`): Processor identifier set to 'pii-detector'
45
-
46
- **name?:** (`string`): Optional processor display name
47
-
48
- **processInput:** (`(args: { messages: MastraDBMessage[]; abort: (reason?: string) => never; tracingContext?: TracingContext }) => Promise<MastraDBMessage[]>`): Processes input messages to detect and redact PII before sending to LLM
49
-
50
- **processOutputStream:** (`(args: { part: ChunkType; streamParts: ChunkType[]; state: Record<string, any>; abort: (reason?: string) => never; tracingContext?: TracingContext }) => Promise<ChunkType | null | undefined>`): Processes streaming output parts to detect and redact PII during streaming
51
-
52
- ## Extended usage example
53
-
54
- ### Input processing
55
-
56
- ```typescript
57
- import { Agent } from "@mastra/core/agent";
58
- import { PIIDetector } from "@mastra/core/processors";
59
-
60
- export const agent = new Agent({
61
- name: "private-agent",
62
- instructions: "You are a helpful assistant",
63
- model: "openai/gpt-5.1",
64
- inputProcessors: [
65
- new PIIDetector({
66
- model: "openrouter/openai/gpt-oss-safeguard-20b",
67
- detectionTypes: ["email", "phone", "credit-card", "ssn"],
68
- threshold: 0.6,
69
- strategy: "redact",
70
- redactionMethod: "mask",
71
- instructions: "Detect and redact personally identifiable information while preserving message intent",
72
- includeDetections: true,
73
- preserveFormat: true
74
- })
75
- ]
76
- });
77
- ```
78
-
79
- ### Output processing with batching
80
-
81
- When using `PIIDetector` as an output processor, it's recommended to combine it with `BatchPartsProcessor` to optimize performance. The `BatchPartsProcessor` batches stream chunks together before passing them to the PII detector, reducing the number of LLM calls required for detection.
82
-
83
- ```typescript
84
- import { Agent } from "@mastra/core/agent";
85
- import { BatchPartsProcessor, PIIDetector } from "@mastra/core/processors";
86
-
87
- export const agent = new Agent({
88
- name: "output-pii-agent",
89
- instructions: "You are a helpful assistant",
90
- model: "openai/gpt-5.1",
91
- outputProcessors: [
92
- // Batch stream parts first to reduce LLM calls
93
- new BatchPartsProcessor({
94
- batchSize: 10,
95
- }),
96
- // Then apply PII detection on batched content
97
- new PIIDetector({
98
- model: "openrouter/openai/gpt-oss-safeguard-20b",
99
- strategy: "redact",
100
- })
101
- ]
102
- });
103
- ```
104
-
105
- ## Related
106
-
107
- - [Guardrails](https://mastra.ai/docs/agents/guardrails)
@@ -1,525 +0,0 @@
1
- # Processor Interface
2
-
3
- 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.
4
-
5
- ## When processor methods run
6
-
7
- The five processor methods run at different points in the agent execution lifecycle:
8
-
9
- ```text
10
- ┌─────────────────────────────────────────────────────────────────┐
11
- │ Agent Execution Flow │
12
- ├─────────────────────────────────────────────────────────────────┤
13
- │ │
14
- │ User Input │
15
- │ │ │
16
- │ ▼ │
17
- │ ┌─────────────────┐ │
18
- │ │ processInput │ ← Runs ONCE at start │
19
- │ └────────┬────────┘ │
20
- │ │ │
21
- │ ▼ │
22
- │ ┌─────────────────────────────────────────────────────────┐ │
23
- │ │ Agentic Loop │ │
24
- │ │ ┌─────────────────────┐ │ │
25
- │ │ │ processInputStep │ ← Runs at EACH step │ │
26
- │ │ └──────────┬──────────┘ │ │
27
- │ │ │ │ │
28
- │ │ ▼ │ │
29
- │ │ LLM Execution │ │
30
- │ │ │ │ │
31
- │ │ ▼ │ │
32
- │ │ ┌──────────────────────┐ │ │
33
- │ │ │ processOutputStream │ ← Runs on EACH stream chunk │ │
34
- │ │ └──────────┬───────────┘ │ │
35
- │ │ │ │ │
36
- │ │ ▼ │ │
37
- │ │ ┌──────────────────────┐ │ │
38
- │ │ │ processOutputStep │ ← Runs after EACH LLM step │ │
39
- │ │ └──────────┬───────────┘ │ │
40
- │ │ │ │ │
41
- │ │ ▼ │ │
42
- │ │ Tool Execution (if needed) │ │
43
- │ │ │ │ │
44
- │ │ └──────── Loop back if tools called ────────│ │
45
- │ └─────────────────────────────────────────────────────────┘ │
46
- │ │ │
47
- │ ▼ │
48
- │ ┌─────────────────────┐ │
49
- │ │ processOutputResult │ ← Runs ONCE after completion │
50
- │ └─────────────────────┘ │
51
- │ │ │
52
- │ ▼ │
53
- │ Final Response │
54
- │ │
55
- └─────────────────────────────────────────────────────────────────┘
56
- ```
57
-
58
- | Method | When it runs | Use case |
59
- | --------------------- | ------------------------------------------------------ | ------------------------------------------------------------- |
60
- | `processInput` | Once at the start, before the agentic loop | Validate/transform initial user input, add context |
61
- | `processInputStep` | At each step of the agentic loop, before each LLM call | Transform messages between steps, handle tool results |
62
- | `processOutputStream` | On each streaming chunk during LLM response | Filter/modify streaming content, detect patterns in real-time |
63
- | `processOutputStep` | After each LLM response, before tool execution | Validate output quality, implement guardrails with retry |
64
- | `processOutputResult` | Once after generation completes | Post-process final response, log results |
65
-
66
- ## Interface definition
67
-
68
- ```typescript
69
- interface Processor<TId extends string = string> {
70
- readonly id: TId;
71
- readonly name?: string;
72
-
73
- processInput?(args: ProcessInputArgs): Promise<ProcessInputResult> | ProcessInputResult;
74
- processInputStep?(args: ProcessInputStepArgs): ProcessorMessageResult;
75
- processOutputStream?(args: ProcessOutputStreamArgs): Promise<ChunkType | null | undefined>;
76
- processOutputStep?(args: ProcessOutputStepArgs): ProcessorMessageResult;
77
- processOutputResult?(args: ProcessOutputResultArgs): ProcessorMessageResult;
78
- }
79
- ```
80
-
81
- ## Properties
82
-
83
- **id:** (`string`): Unique identifier for the processor. Used for tracing and debugging.
84
-
85
- **name?:** (`string`): Optional display name for the processor. Falls back to id if not provided.
86
-
87
- ## Methods
88
-
89
- ### processInput
90
-
91
- Processes input messages before they are sent to the LLM. Runs once at the start of agent execution.
92
-
93
- ```typescript
94
- processInput?(args: ProcessInputArgs): Promise<ProcessInputResult> | ProcessInputResult;
95
- ```
96
-
97
- #### ProcessInputArgs
98
-
99
- **messages:** (`MastraDBMessage[]`): User and assistant messages to process (excludes system messages).
100
-
101
- **systemMessages:** (`CoreMessage[]`): All system messages (agent instructions, memory context, user-provided). Can be modified and returned.
102
-
103
- **messageList:** (`MessageList`): Full MessageList instance for advanced message management.
104
-
105
- **abort:** (`(reason?: string, options?: { retry?: boolean; metadata?: unknown }) => never`): Function to abort processing. Throws a TripWire error that stops execution. Pass \`retry: true\` to request the LLM retry the step with feedback.
106
-
107
- **retryCount?:** (`number`): Number of times processors have triggered retry for this generation. Use this to limit retry attempts.
108
-
109
- **tracingContext?:** (`TracingContext`): Tracing context for observability.
110
-
111
- **requestContext?:** (`RequestContext`): Request-scoped context with execution metadata like threadId and resourceId.
112
-
113
- #### ProcessInputResult
114
-
115
- The method can return one of three types:
116
-
117
- **MastraDBMessage\[]:** (`array`): Transformed messages array. System messages remain unchanged.
118
-
119
- **MessageList:** (`MessageList`): The same messageList instance passed in. Indicates you've mutated it directly.
120
-
121
- **{ messages, systemMessages }:** (`object`): Object with both transformed messages and modified system messages.
122
-
123
- ***
124
-
125
- ### processInputStep
126
-
127
- 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.
128
-
129
- ```typescript
130
- processInputStep?(args: ProcessInputStepArgs): ProcessorMessageResult;
131
- ```
132
-
133
- #### Execution order in the agentic loop
134
-
135
- 1. `processInput` (once at start)
136
- 2. `processInputStep` from inputProcessors (at each step, before LLM call)
137
- 3. `prepareStep` callback (runs as part of the processInputStep pipeline, after inputProcessors)
138
- 4. LLM execution
139
- 5. Tool execution (if needed)
140
- 6. Repeat from step 2 if tools were called
141
-
142
- #### ProcessInputStepArgs
143
-
144
- **messages:** (`MastraDBMessage[]`): All messages including tool calls and results from previous steps (read-only snapshot).
145
-
146
- **messageList:** (`MessageList`): MessageList instance for managing messages. Can mutate directly or return in result.
147
-
148
- **stepNumber:** (`number`): Current step number (0-indexed). Step 0 is the initial LLM call.
149
-
150
- **steps:** (`StepResult[]`): Results from previous steps, including text, toolCalls, and toolResults.
151
-
152
- **systemMessages:** (`CoreMessage[]`): All system messages (read-only snapshot). Return in result to replace.
153
-
154
- **model:** (`MastraLanguageModelV2`): Current model being used. Return a different model in result to switch.
155
-
156
- **toolChoice?:** (`ToolChoice`): Current tool choice setting ('auto', 'none', 'required', or specific tool).
157
-
158
- **activeTools?:** (`string[]`): Currently active tool names. Return filtered array to limit tools.
159
-
160
- **tools?:** (`ToolSet`): Current tools available for this step. Return in result to add/replace tools.
161
-
162
- **providerOptions?:** (`SharedV2ProviderOptions`): Provider-specific options (e.g., Anthropic cacheControl, OpenAI reasoningEffort).
163
-
164
- **modelSettings?:** (`CallSettings`): Model settings like temperature, maxTokens, topP.
165
-
166
- **structuredOutput?:** (`StructuredOutputOptions`): Structured output configuration (schema, output mode). Return in result to modify.
167
-
168
- **abort:** (`(reason?: string) => never`): Function to abort processing.
169
-
170
- **tracingContext?:** (`TracingContext`): Tracing context for observability.
171
-
172
- **requestContext?:** (`RequestContext`): Request-scoped context with execution metadata.
173
-
174
- #### ProcessInputStepResult
175
-
176
- The method can return any combination of these properties:
177
-
178
- **model?:** (`LanguageModelV2 | string`): Change the model for this step. Can be a model instance or router ID like 'openai/gpt-4o'.
179
-
180
- **toolChoice?:** (`ToolChoice`): Change tool selection behavior for this step.
181
-
182
- **activeTools?:** (`string[]`): Filter which tools are available for this step.
183
-
184
- **tools?:** (`ToolSet`): Replace or modify tools for this step. Use spread to merge: { tools: { ...tools, newTool } }.
185
-
186
- **messages?:** (`MastraDBMessage[]`): Replace all messages. Cannot be used with messageList.
187
-
188
- **messageList?:** (`MessageList`): Return the same messageList instance (indicates you mutated it). Cannot be used with messages.
189
-
190
- **systemMessages?:** (`CoreMessage[]`): Replace all system messages for this step only.
191
-
192
- **providerOptions?:** (`SharedV2ProviderOptions`): Change provider-specific options for this step.
193
-
194
- **modelSettings?:** (`CallSettings`): Change model settings for this step.
195
-
196
- **structuredOutput?:** (`StructuredOutputOptions`): Change structured output configuration for this step.
197
-
198
- #### Processor chaining
199
-
200
- When multiple processors implement `processInputStep`, they run in order and changes chain through:
201
-
202
- ```text
203
- Processor 1: receives { model: 'gpt-4o' } → returns { model: 'gpt-4o-mini' }
204
- Processor 2: receives { model: 'gpt-4o-mini' } → returns { toolChoice: 'none' }
205
- Final: model = 'gpt-4o-mini', toolChoice = 'none'
206
- ```
207
-
208
- #### System message isolation
209
-
210
- 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.
211
-
212
- #### Use cases
213
-
214
- - Dynamic model switching based on step number or context
215
- - Disabling tools after a certain number of steps
216
- - Dynamically adding or replacing tools based on conversation context
217
- - Transforming message part types between providers (e.g., `reasoning` → `thinking` for Anthropic)
218
- - Modifying messages based on step number or accumulated context
219
- - Adding step-specific system instructions
220
- - Adjusting provider options per step (e.g., cache control)
221
- - Modifying structured output schema based on step context
222
-
223
- ***
224
-
225
- ### processOutputStream
226
-
227
- Processes streaming output chunks with built-in state management. Allows processors to accumulate chunks and make decisions based on larger context.
228
-
229
- ```typescript
230
- processOutputStream?(args: ProcessOutputStreamArgs): Promise<ChunkType | null | undefined>;
231
- ```
232
-
233
- #### ProcessOutputStreamArgs
234
-
235
- **part:** (`ChunkType`): The current stream chunk being processed.
236
-
237
- **streamParts:** (`ChunkType[]`): All chunks seen so far in the stream.
238
-
239
- **state:** (`Record<string, unknown>`): Mutable state object that persists across chunks within a single stream.
240
-
241
- **abort:** (`(reason?: string) => never`): Function to abort the stream.
242
-
243
- **messageList?:** (`MessageList`): MessageList instance for accessing conversation history.
244
-
245
- **tracingContext?:** (`TracingContext`): Tracing context for observability.
246
-
247
- **requestContext?:** (`RequestContext`): Request-scoped context with execution metadata.
248
-
249
- **writer?:** (`ProcessorStreamWriter`): Stream writer for emitting custom data chunks back to the client. Call writer.custom() to emit data-\* typed chunks. Available during streaming.
250
-
251
- #### Return value
252
-
253
- - Return the `ChunkType` to emit it (possibly modified)
254
- - Return `null` or `undefined` to skip emitting the chunk
255
-
256
- ***
257
-
258
- ### processOutputResult
259
-
260
- Processes the complete output result after streaming or generation is finished.
261
-
262
- ```typescript
263
- processOutputResult?(args: ProcessOutputResultArgs): ProcessorMessageResult;
264
- ```
265
-
266
- #### ProcessOutputResultArgs
267
-
268
- **messages:** (`MastraDBMessage[]`): The generated response messages.
269
-
270
- **messageList:** (`MessageList`): MessageList instance for managing messages.
271
-
272
- **abort:** (`(reason?: string) => never`): Function to abort processing.
273
-
274
- **tracingContext?:** (`TracingContext`): Tracing context for observability.
275
-
276
- **requestContext?:** (`RequestContext`): Request-scoped context with execution metadata.
277
-
278
- **writer?:** (`ProcessorStreamWriter`): Stream writer for emitting custom data chunks back to the client. Call writer.custom() to emit data-\* typed chunks. Available during streaming.
279
-
280
- ***
281
-
282
- ### processOutputStep
283
-
284
- 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.
285
-
286
- ```typescript
287
- processOutputStep?(args: ProcessOutputStepArgs): ProcessorMessageResult;
288
- ```
289
-
290
- #### ProcessOutputStepArgs
291
-
292
- **messages:** (`MastraDBMessage[]`): All messages including the latest LLM response.
293
-
294
- **messageList:** (`MessageList`): MessageList instance for managing messages.
295
-
296
- **stepNumber:** (`number`): Current step number (0-indexed).
297
-
298
- **finishReason?:** (`string`): The finish reason from the LLM (stop, tool-use, length, etc.).
299
-
300
- **toolCalls?:** (`ToolCallInfo[]`): Tool calls made in this step (if any).
301
-
302
- **text?:** (`string`): Generated text from this step.
303
-
304
- **systemMessages?:** (`CoreMessage[]`): All system messages for read/modify access.
305
-
306
- **abort:** (`(reason?: string, options?: { retry?: boolean; metadata?: unknown }) => never`): Function to abort processing. Pass \`retry: true\` to request the LLM retry the step.
307
-
308
- **retryCount?:** (`number`): Number of times processors have triggered retry. Use this to limit retry attempts.
309
-
310
- **tracingContext?:** (`TracingContext`): Tracing context for observability.
311
-
312
- **requestContext?:** (`RequestContext`): Request-scoped context with execution metadata.
313
-
314
- #### Use cases
315
-
316
- - Implementing quality guardrails that can request retries
317
- - Validating LLM output before tool execution
318
- - Adding per-step logging or metrics
319
- - Implementing output moderation with retry capability
320
-
321
- #### Example: Quality guardrail with retry
322
-
323
- ```typescript
324
- import type { Processor } from "@mastra/core";
325
-
326
- export class QualityGuardrail implements Processor {
327
- id = "quality-guardrail";
328
-
329
- async processOutputStep({ text, abort, retryCount }) {
330
- const score = await evaluateResponseQuality(text);
331
-
332
- if (score < 0.7) {
333
- if (retryCount < 3) {
334
- // Request retry with feedback for the LLM
335
- abort("Response quality too low. Please provide more detail.", {
336
- retry: true,
337
- metadata: { qualityScore: score },
338
- });
339
- } else {
340
- // Max retries reached, block the response
341
- abort("Response quality too low after multiple attempts.");
342
- }
343
- }
344
-
345
- return [];
346
- }
347
- }
348
- ```
349
-
350
- ## Processor types
351
-
352
- Mastra provides type aliases to ensure processors implement the required methods:
353
-
354
- ```typescript
355
- // Must implement processInput OR processInputStep (or both)
356
- type InputProcessor = Processor & (
357
- | { processInput: required }
358
- | { processInputStep: required }
359
- );
360
-
361
- // Must implement processOutputStream, processOutputStep, OR processOutputResult (or any combination)
362
- type OutputProcessor = Processor & (
363
- | { processOutputStream: required }
364
- | { processOutputStep: required }
365
- | { processOutputResult: required }
366
- );
367
- ```
368
-
369
- ## Usage examples
370
-
371
- ### Basic input processor
372
-
373
- ```typescript
374
- import type { Processor, MastraDBMessage } from "@mastra/core";
375
-
376
- export class LowercaseProcessor implements Processor {
377
- id = "lowercase";
378
-
379
- async processInput({ messages }): Promise<MastraDBMessage[]> {
380
- return messages.map((msg) => ({
381
- ...msg,
382
- content: {
383
- ...msg.content,
384
- parts: msg.content.parts?.map((part) =>
385
- part.type === "text"
386
- ? { ...part, text: part.text.toLowerCase() }
387
- : part
388
- ),
389
- },
390
- }));
391
- }
392
- }
393
- ```
394
-
395
- ### Per-step processor with processInputStep
396
-
397
- ```typescript
398
- import type { Processor, ProcessInputStepArgs, ProcessInputStepResult } from "@mastra/core";
399
-
400
- export class DynamicModelProcessor implements Processor {
401
- id = "dynamic-model";
402
-
403
- async processInputStep({
404
- stepNumber,
405
- steps,
406
- toolChoice,
407
- }: ProcessInputStepArgs): Promise<ProcessInputStepResult> {
408
- // Use a fast model for initial response
409
- if (stepNumber === 0) {
410
- return { model: "openai/gpt-4o-mini" };
411
- }
412
-
413
- // Switch to powerful model after tool calls
414
- if (steps.length > 0 && steps[steps.length - 1].toolCalls?.length) {
415
- return { model: "openai/gpt-4o" };
416
- }
417
-
418
- // Disable tools after 5 steps to force completion
419
- if (stepNumber > 5) {
420
- return { toolChoice: "none" };
421
- }
422
-
423
- return {};
424
- }
425
- }
426
- ```
427
-
428
- ### Message transformer with processInputStep
429
-
430
- ```typescript
431
- import type { Processor, MastraDBMessage } from "@mastra/core";
432
-
433
- export class ReasoningTransformer implements Processor {
434
- id = "reasoning-transformer";
435
-
436
- async processInputStep({ messages, messageList }) {
437
- // Transform reasoning parts to thinking parts at each step
438
- // This is useful when switching between model providers
439
- for (const msg of messages) {
440
- if (msg.role === "assistant" && msg.content.parts) {
441
- for (const part of msg.content.parts) {
442
- if (part.type === "reasoning") {
443
- (part as any).type = "thinking";
444
- }
445
- }
446
- }
447
- }
448
- return messageList;
449
- }
450
- }
451
- ```
452
-
453
- ### Hybrid processor (input and output)
454
-
455
- ```typescript
456
- import type { Processor, MastraDBMessage, ChunkType } from "@mastra/core";
457
-
458
- export class ContentFilter implements Processor {
459
- id = "content-filter";
460
- private blockedWords: string[];
461
-
462
- constructor(blockedWords: string[]) {
463
- this.blockedWords = blockedWords;
464
- }
465
-
466
- async processInput({ messages, abort }): Promise<MastraDBMessage[]> {
467
- for (const msg of messages) {
468
- const text = msg.content.parts
469
- ?.filter((p) => p.type === "text")
470
- .map((p) => p.text)
471
- .join(" ");
472
-
473
- if (this.blockedWords.some((word) => text?.includes(word))) {
474
- abort("Blocked content detected in input");
475
- }
476
- }
477
- return messages;
478
- }
479
-
480
- async processOutputStream({ part, abort }): Promise<ChunkType | null> {
481
- if (part.type === "text-delta") {
482
- if (this.blockedWords.some((word) => part.textDelta.includes(word))) {
483
- abort("Blocked content detected in output");
484
- }
485
- }
486
- return part;
487
- }
488
- }
489
- ```
490
-
491
- ### Stream accumulator with state
492
-
493
- ```typescript
494
- import type { Processor, ChunkType } from "@mastra/core";
495
-
496
- export class WordCounter implements Processor {
497
- id = "word-counter";
498
-
499
- async processOutputStream({ part, state }): Promise<ChunkType> {
500
- // Initialize state on first chunk
501
- if (!state.wordCount) {
502
- state.wordCount = 0;
503
- }
504
-
505
- // Count words in text chunks
506
- if (part.type === "text-delta") {
507
- const words = part.textDelta.split(/\s+/).filter(Boolean);
508
- state.wordCount += words.length;
509
- }
510
-
511
- // Log word count on finish
512
- if (part.type === "finish") {
513
- console.log(`Total words: ${state.wordCount}`);
514
- }
515
-
516
- return part;
517
- }
518
- }
519
- ```
520
-
521
- ## Related
522
-
523
- - [Processors overview](https://mastra.ai/docs/agents/processors) - Conceptual guide to processors
524
- - [Guardrails](https://mastra.ai/docs/agents/guardrails) - Security and validation processors
525
- - [Memory Processors](https://mastra.ai/docs/memory/memory-processors) - Memory-specific processors