@mastra/core 1.6.0 → 1.7.0-alpha.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 (452) hide show
  1. package/CHANGELOG.md +117 -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-IHDE4CJV.js → chunk-6NRSTTAS.js} +80 -11
  7. package/dist/chunk-6NRSTTAS.js.map +1 -0
  8. package/dist/{chunk-4WG5K4CK.js → chunk-6RTFK6XW.js} +7 -7
  9. package/dist/{chunk-4WG5K4CK.js.map → chunk-6RTFK6XW.js.map} +1 -1
  10. package/dist/{chunk-AYHSPIT6.cjs → chunk-7UAJ6LMR.cjs} +820 -259
  11. package/dist/chunk-7UAJ6LMR.cjs.map +1 -0
  12. package/dist/{chunk-EEU5NHHU.js → chunk-DFCRXDVK.js} +3 -3
  13. package/dist/{chunk-EEU5NHHU.js.map → chunk-DFCRXDVK.js.map} +1 -1
  14. package/dist/{chunk-5K45E5VE.js → chunk-GPJGPARM.js} +3 -2
  15. package/dist/chunk-GPJGPARM.js.map +1 -0
  16. package/dist/{chunk-VJWRJWSC.cjs → chunk-HYU6AULN.cjs} +85 -15
  17. package/dist/chunk-HYU6AULN.cjs.map +1 -0
  18. package/dist/{chunk-DGS2KGDI.js → chunk-HZ33YLNC.js} +6 -5
  19. package/dist/chunk-HZ33YLNC.js.map +1 -0
  20. package/dist/{chunk-3U3XFMGJ.cjs → chunk-N435UBEN.cjs} +13 -8
  21. package/dist/chunk-N435UBEN.cjs.map +1 -0
  22. package/dist/{chunk-5VQPSWPG.cjs → chunk-NAUBU4SI.cjs} +48 -48
  23. package/dist/{chunk-5VQPSWPG.cjs.map → chunk-NAUBU4SI.cjs.map} +1 -1
  24. package/dist/{chunk-MWGGSA5Q.js → chunk-NHYSIYTD.js} +10 -5
  25. package/dist/chunk-NHYSIYTD.js.map +1 -0
  26. package/dist/{chunk-RZNHRIM7.cjs → chunk-OL4P6TXG.cjs} +5 -5
  27. package/dist/{chunk-RZNHRIM7.cjs.map → chunk-OL4P6TXG.cjs.map} +1 -1
  28. package/dist/{chunk-XWZAKKFT.cjs → chunk-S3JIVN4S.cjs} +14 -14
  29. package/dist/{chunk-XWZAKKFT.cjs.map → chunk-S3JIVN4S.cjs.map} +1 -1
  30. package/dist/{chunk-TVPANHLE.cjs → chunk-SBOHDNIZ.cjs} +3 -2
  31. package/dist/chunk-SBOHDNIZ.cjs.map +1 -0
  32. package/dist/{chunk-LNKS4TJ6.cjs → chunk-T4KRCLC3.cjs} +8 -7
  33. package/dist/chunk-T4KRCLC3.cjs.map +1 -0
  34. package/dist/{chunk-RHKNKJNM.js → chunk-WBVBORCZ.js} +4 -4
  35. package/dist/{chunk-RHKNKJNM.js.map → chunk-WBVBORCZ.js.map} +1 -1
  36. package/dist/{chunk-YM6245EM.js → chunk-WR5RUKVK.js} +3 -3
  37. package/dist/{chunk-YM6245EM.js.map → chunk-WR5RUKVK.js.map} +1 -1
  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/index.cjs +8 -8
  92. package/dist/stream/index.js +1 -1
  93. package/dist/tool-loop-agent/index.cjs +4 -4
  94. package/dist/tool-loop-agent/index.js +1 -1
  95. package/dist/vector/index.cjs +7 -7
  96. package/dist/vector/index.js +1 -1
  97. package/dist/workflows/evented/index.cjs +10 -10
  98. package/dist/workflows/evented/index.js +1 -1
  99. package/dist/workflows/index.cjs +25 -25
  100. package/dist/workflows/index.js +1 -1
  101. package/dist/workspace/constants/index.d.ts +2 -0
  102. package/dist/workspace/constants/index.d.ts.map +1 -1
  103. package/dist/workspace/errors.d.ts +1 -1
  104. package/dist/workspace/errors.d.ts.map +1 -1
  105. package/dist/workspace/filesystem/composite-filesystem.d.ts +4 -1
  106. package/dist/workspace/filesystem/composite-filesystem.d.ts.map +1 -1
  107. package/dist/workspace/filesystem/file-write-lock.d.ts +35 -0
  108. package/dist/workspace/filesystem/file-write-lock.d.ts.map +1 -0
  109. package/dist/workspace/filesystem/filesystem.d.ts +5 -1
  110. package/dist/workspace/filesystem/filesystem.d.ts.map +1 -1
  111. package/dist/workspace/filesystem/index.d.ts +1 -0
  112. package/dist/workspace/filesystem/index.d.ts.map +1 -1
  113. package/dist/workspace/filesystem/local-filesystem.d.ts +17 -1
  114. package/dist/workspace/filesystem/local-filesystem.d.ts.map +1 -1
  115. package/dist/workspace/index.cjs +72 -64
  116. package/dist/workspace/index.d.ts +3 -2
  117. package/dist/workspace/index.d.ts.map +1 -1
  118. package/dist/workspace/index.js +1 -1
  119. package/dist/workspace/lifecycle.d.ts +1 -9
  120. package/dist/workspace/lifecycle.d.ts.map +1 -1
  121. package/dist/workspace/sandbox/index.d.ts +2 -0
  122. package/dist/workspace/sandbox/index.d.ts.map +1 -1
  123. package/dist/workspace/sandbox/local-process-manager.d.ts +18 -0
  124. package/dist/workspace/sandbox/local-process-manager.d.ts.map +1 -0
  125. package/dist/workspace/sandbox/local-sandbox.d.ts +49 -35
  126. package/dist/workspace/sandbox/local-sandbox.d.ts.map +1 -1
  127. package/dist/workspace/sandbox/mastra-sandbox.d.ts +45 -11
  128. package/dist/workspace/sandbox/mastra-sandbox.d.ts.map +1 -1
  129. package/dist/workspace/sandbox/native-sandbox/bubblewrap.d.ts +2 -3
  130. package/dist/workspace/sandbox/native-sandbox/bubblewrap.d.ts.map +1 -1
  131. package/dist/workspace/sandbox/native-sandbox/seatbelt.d.ts +2 -3
  132. package/dist/workspace/sandbox/native-sandbox/seatbelt.d.ts.map +1 -1
  133. package/dist/workspace/sandbox/native-sandbox/wrapper.d.ts +4 -5
  134. package/dist/workspace/sandbox/native-sandbox/wrapper.d.ts.map +1 -1
  135. package/dist/workspace/sandbox/process-manager/index.d.ts +4 -0
  136. package/dist/workspace/sandbox/process-manager/index.d.ts.map +1 -0
  137. package/dist/workspace/sandbox/process-manager/process-handle.d.ts +107 -0
  138. package/dist/workspace/sandbox/process-manager/process-handle.d.ts.map +1 -0
  139. package/dist/workspace/sandbox/process-manager/process-manager.d.ts +59 -0
  140. package/dist/workspace/sandbox/process-manager/process-manager.d.ts.map +1 -0
  141. package/dist/workspace/sandbox/process-manager/types.d.ts +24 -0
  142. package/dist/workspace/sandbox/process-manager/types.d.ts.map +1 -0
  143. package/dist/workspace/sandbox/sandbox.d.ts +38 -2
  144. package/dist/workspace/sandbox/sandbox.d.ts.map +1 -1
  145. package/dist/workspace/sandbox/types.d.ts +9 -2
  146. package/dist/workspace/sandbox/types.d.ts.map +1 -1
  147. package/dist/workspace/sandbox/utils.d.ts +7 -0
  148. package/dist/workspace/sandbox/utils.d.ts.map +1 -0
  149. package/dist/workspace/tools/execute-command.d.ts +53 -2
  150. package/dist/workspace/tools/execute-command.d.ts.map +1 -1
  151. package/dist/workspace/tools/get-process-output.d.ts +6 -0
  152. package/dist/workspace/tools/get-process-output.d.ts.map +1 -0
  153. package/dist/workspace/tools/index.d.ts +4 -1
  154. package/dist/workspace/tools/index.d.ts.map +1 -1
  155. package/dist/workspace/tools/kill-process.d.ts +4 -0
  156. package/dist/workspace/tools/kill-process.d.ts.map +1 -0
  157. package/dist/workspace/tools/output-helpers.d.ts +21 -0
  158. package/dist/workspace/tools/output-helpers.d.ts.map +1 -0
  159. package/dist/workspace/tools/tools.d.ts.map +1 -1
  160. package/dist/workspace/types.d.ts +31 -0
  161. package/dist/workspace/types.d.ts.map +1 -1
  162. package/dist/workspace/utils.d.ts +11 -0
  163. package/dist/workspace/utils.d.ts.map +1 -0
  164. package/dist/workspace/workspace.d.ts +36 -0
  165. package/dist/workspace/workspace.d.ts.map +1 -1
  166. package/package.json +2 -2
  167. package/dist/chunk-3U3XFMGJ.cjs.map +0 -1
  168. package/dist/chunk-5K45E5VE.js.map +0 -1
  169. package/dist/chunk-AYHSPIT6.cjs.map +0 -1
  170. package/dist/chunk-DGS2KGDI.js.map +0 -1
  171. package/dist/chunk-IHDE4CJV.js.map +0 -1
  172. package/dist/chunk-LNKS4TJ6.cjs.map +0 -1
  173. package/dist/chunk-MWGGSA5Q.js.map +0 -1
  174. package/dist/chunk-TVPANHLE.cjs.map +0 -1
  175. package/dist/chunk-VJWRJWSC.cjs.map +0 -1
  176. package/dist/chunk-XB3DA67Q.js.map +0 -1
  177. package/dist/docs/SKILL.md +0 -301
  178. package/dist/docs/assets/SOURCE_MAP.json +0 -1413
  179. package/dist/docs/references/docs-agents-adding-voice.md +0 -353
  180. package/dist/docs/references/docs-agents-agent-approval.md +0 -377
  181. package/dist/docs/references/docs-agents-agent-memory.md +0 -212
  182. package/dist/docs/references/docs-agents-guardrails.md +0 -382
  183. package/dist/docs/references/docs-agents-network-approval.md +0 -275
  184. package/dist/docs/references/docs-agents-networks.md +0 -290
  185. package/dist/docs/references/docs-agents-overview.md +0 -309
  186. package/dist/docs/references/docs-agents-processors.md +0 -632
  187. package/dist/docs/references/docs-agents-structured-output.md +0 -271
  188. package/dist/docs/references/docs-agents-using-tools.md +0 -214
  189. package/dist/docs/references/docs-evals-custom-scorers.md +0 -519
  190. package/dist/docs/references/docs-evals-overview.md +0 -146
  191. package/dist/docs/references/docs-evals-running-in-ci.md +0 -106
  192. package/dist/docs/references/docs-mcp-overview.md +0 -370
  193. package/dist/docs/references/docs-mcp-publishing-mcp-server.md +0 -95
  194. package/dist/docs/references/docs-memory-memory-processors.md +0 -316
  195. package/dist/docs/references/docs-memory-observational-memory.md +0 -246
  196. package/dist/docs/references/docs-memory-overview.md +0 -45
  197. package/dist/docs/references/docs-memory-semantic-recall.md +0 -272
  198. package/dist/docs/references/docs-memory-storage.md +0 -261
  199. package/dist/docs/references/docs-memory-working-memory.md +0 -400
  200. package/dist/docs/references/docs-observability-datasets-overview.md +0 -188
  201. package/dist/docs/references/docs-observability-datasets-running-experiments.md +0 -266
  202. package/dist/docs/references/docs-observability-logging.md +0 -99
  203. package/dist/docs/references/docs-observability-overview.md +0 -70
  204. package/dist/docs/references/docs-observability-tracing-bridges-otel.md +0 -209
  205. package/dist/docs/references/docs-observability-tracing-exporters-arize.md +0 -274
  206. package/dist/docs/references/docs-observability-tracing-exporters-braintrust.md +0 -111
  207. package/dist/docs/references/docs-observability-tracing-exporters-cloud.md +0 -129
  208. package/dist/docs/references/docs-observability-tracing-exporters-datadog.md +0 -187
  209. package/dist/docs/references/docs-observability-tracing-exporters-default.md +0 -211
  210. package/dist/docs/references/docs-observability-tracing-exporters-laminar.md +0 -100
  211. package/dist/docs/references/docs-observability-tracing-exporters-langfuse.md +0 -217
  212. package/dist/docs/references/docs-observability-tracing-exporters-langsmith.md +0 -202
  213. package/dist/docs/references/docs-observability-tracing-exporters-otel.md +0 -479
  214. package/dist/docs/references/docs-observability-tracing-exporters-posthog.md +0 -148
  215. package/dist/docs/references/docs-observability-tracing-overview.md +0 -1114
  216. package/dist/docs/references/docs-rag-chunking-and-embedding.md +0 -183
  217. package/dist/docs/references/docs-rag-graph-rag.md +0 -215
  218. package/dist/docs/references/docs-rag-overview.md +0 -72
  219. package/dist/docs/references/docs-rag-retrieval.md +0 -521
  220. package/dist/docs/references/docs-rag-vector-databases.md +0 -648
  221. package/dist/docs/references/docs-server-auth-auth0.md +0 -222
  222. package/dist/docs/references/docs-server-auth-clerk.md +0 -132
  223. package/dist/docs/references/docs-server-auth-composite-auth.md +0 -234
  224. package/dist/docs/references/docs-server-auth-custom-auth-provider.md +0 -513
  225. package/dist/docs/references/docs-server-auth-firebase.md +0 -272
  226. package/dist/docs/references/docs-server-auth-jwt.md +0 -110
  227. package/dist/docs/references/docs-server-auth-simple-auth.md +0 -178
  228. package/dist/docs/references/docs-server-auth-supabase.md +0 -117
  229. package/dist/docs/references/docs-server-auth-workos.md +0 -190
  230. package/dist/docs/references/docs-server-custom-adapters.md +0 -374
  231. package/dist/docs/references/docs-server-custom-api-routes.md +0 -267
  232. package/dist/docs/references/docs-server-mastra-client.md +0 -243
  233. package/dist/docs/references/docs-server-mastra-server.md +0 -71
  234. package/dist/docs/references/docs-server-middleware.md +0 -228
  235. package/dist/docs/references/docs-server-request-context.md +0 -478
  236. package/dist/docs/references/docs-streaming-events.md +0 -247
  237. package/dist/docs/references/docs-streaming-tool-streaming.md +0 -178
  238. package/dist/docs/references/docs-streaming-workflow-streaming.md +0 -109
  239. package/dist/docs/references/docs-voice-overview.md +0 -979
  240. package/dist/docs/references/docs-voice-speech-to-speech.md +0 -103
  241. package/dist/docs/references/docs-voice-speech-to-text.md +0 -80
  242. package/dist/docs/references/docs-voice-text-to-speech.md +0 -84
  243. package/dist/docs/references/docs-workflows-agents-and-tools.md +0 -170
  244. package/dist/docs/references/docs-workflows-control-flow.md +0 -823
  245. package/dist/docs/references/docs-workflows-error-handling.md +0 -360
  246. package/dist/docs/references/docs-workflows-human-in-the-loop.md +0 -213
  247. package/dist/docs/references/docs-workflows-overview.md +0 -372
  248. package/dist/docs/references/docs-workflows-snapshots.md +0 -238
  249. package/dist/docs/references/docs-workflows-suspend-and-resume.md +0 -205
  250. package/dist/docs/references/docs-workflows-time-travel.md +0 -309
  251. package/dist/docs/references/docs-workflows-workflow-state.md +0 -181
  252. package/dist/docs/references/docs-workspace-filesystem.md +0 -162
  253. package/dist/docs/references/docs-workspace-overview.md +0 -239
  254. package/dist/docs/references/docs-workspace-sandbox.md +0 -63
  255. package/dist/docs/references/docs-workspace-search.md +0 -219
  256. package/dist/docs/references/docs-workspace-skills.md +0 -126
  257. package/dist/docs/references/guides-agent-frameworks-ai-sdk.md +0 -140
  258. package/dist/docs/references/reference-agents-agent.md +0 -142
  259. package/dist/docs/references/reference-agents-generate.md +0 -174
  260. package/dist/docs/references/reference-agents-generateLegacy.md +0 -176
  261. package/dist/docs/references/reference-agents-getDefaultGenerateOptions.md +0 -36
  262. package/dist/docs/references/reference-agents-getDefaultOptions.md +0 -34
  263. package/dist/docs/references/reference-agents-getDefaultStreamOptions.md +0 -36
  264. package/dist/docs/references/reference-agents-getDescription.md +0 -21
  265. package/dist/docs/references/reference-agents-getInstructions.md +0 -34
  266. package/dist/docs/references/reference-agents-getLLM.md +0 -37
  267. package/dist/docs/references/reference-agents-getMemory.md +0 -34
  268. package/dist/docs/references/reference-agents-getModel.md +0 -34
  269. package/dist/docs/references/reference-agents-getTools.md +0 -29
  270. package/dist/docs/references/reference-agents-getVoice.md +0 -34
  271. package/dist/docs/references/reference-agents-listAgents.md +0 -35
  272. package/dist/docs/references/reference-agents-listScorers.md +0 -34
  273. package/dist/docs/references/reference-agents-listTools.md +0 -34
  274. package/dist/docs/references/reference-agents-listWorkflows.md +0 -34
  275. package/dist/docs/references/reference-agents-network.md +0 -134
  276. package/dist/docs/references/reference-ai-sdk-chat-route.md +0 -82
  277. package/dist/docs/references/reference-ai-sdk-network-route.md +0 -74
  278. package/dist/docs/references/reference-ai-sdk-to-ai-sdk-stream.md +0 -232
  279. package/dist/docs/references/reference-ai-sdk-with-mastra.md +0 -59
  280. package/dist/docs/references/reference-ai-sdk-workflow-route.md +0 -79
  281. package/dist/docs/references/reference-auth-auth0.md +0 -73
  282. package/dist/docs/references/reference-auth-clerk.md +0 -36
  283. package/dist/docs/references/reference-auth-firebase.md +0 -80
  284. package/dist/docs/references/reference-auth-jwt.md +0 -26
  285. package/dist/docs/references/reference-auth-supabase.md +0 -33
  286. package/dist/docs/references/reference-auth-workos.md +0 -84
  287. package/dist/docs/references/reference-client-js-agents.md +0 -438
  288. package/dist/docs/references/reference-configuration.md +0 -749
  289. package/dist/docs/references/reference-core-addGateway.md +0 -42
  290. package/dist/docs/references/reference-core-getAgent.md +0 -21
  291. package/dist/docs/references/reference-core-getAgentById.md +0 -21
  292. package/dist/docs/references/reference-core-getDeployer.md +0 -22
  293. package/dist/docs/references/reference-core-getGateway.md +0 -38
  294. package/dist/docs/references/reference-core-getGatewayById.md +0 -41
  295. package/dist/docs/references/reference-core-getLogger.md +0 -22
  296. package/dist/docs/references/reference-core-getMCPServer.md +0 -45
  297. package/dist/docs/references/reference-core-getMCPServerById.md +0 -53
  298. package/dist/docs/references/reference-core-getMemory.md +0 -50
  299. package/dist/docs/references/reference-core-getScorer.md +0 -54
  300. package/dist/docs/references/reference-core-getScorerById.md +0 -54
  301. package/dist/docs/references/reference-core-getServer.md +0 -22
  302. package/dist/docs/references/reference-core-getStorage.md +0 -22
  303. package/dist/docs/references/reference-core-getStoredAgentById.md +0 -89
  304. package/dist/docs/references/reference-core-getTelemetry.md +0 -22
  305. package/dist/docs/references/reference-core-getVector.md +0 -22
  306. package/dist/docs/references/reference-core-getWorkflow.md +0 -40
  307. package/dist/docs/references/reference-core-listAgents.md +0 -21
  308. package/dist/docs/references/reference-core-listGateways.md +0 -40
  309. package/dist/docs/references/reference-core-listLogs.md +0 -38
  310. package/dist/docs/references/reference-core-listLogsByRunId.md +0 -36
  311. package/dist/docs/references/reference-core-listMCPServers.md +0 -51
  312. package/dist/docs/references/reference-core-listMemory.md +0 -56
  313. package/dist/docs/references/reference-core-listScorers.md +0 -29
  314. package/dist/docs/references/reference-core-listStoredAgents.md +0 -93
  315. package/dist/docs/references/reference-core-listVectors.md +0 -22
  316. package/dist/docs/references/reference-core-listWorkflows.md +0 -21
  317. package/dist/docs/references/reference-core-mastra-class.md +0 -66
  318. package/dist/docs/references/reference-core-mastra-model-gateway.md +0 -153
  319. package/dist/docs/references/reference-core-setLogger.md +0 -26
  320. package/dist/docs/references/reference-core-setStorage.md +0 -27
  321. package/dist/docs/references/reference-datasets-addItem.md +0 -35
  322. package/dist/docs/references/reference-datasets-addItems.md +0 -33
  323. package/dist/docs/references/reference-datasets-compareExperiments.md +0 -48
  324. package/dist/docs/references/reference-datasets-create.md +0 -49
  325. package/dist/docs/references/reference-datasets-dataset.md +0 -78
  326. package/dist/docs/references/reference-datasets-datasets-manager.md +0 -84
  327. package/dist/docs/references/reference-datasets-delete.md +0 -23
  328. package/dist/docs/references/reference-datasets-deleteExperiment.md +0 -25
  329. package/dist/docs/references/reference-datasets-deleteItem.md +0 -25
  330. package/dist/docs/references/reference-datasets-deleteItems.md +0 -27
  331. package/dist/docs/references/reference-datasets-get.md +0 -29
  332. package/dist/docs/references/reference-datasets-getDetails.md +0 -45
  333. package/dist/docs/references/reference-datasets-getExperiment.md +0 -28
  334. package/dist/docs/references/reference-datasets-getItem.md +0 -31
  335. package/dist/docs/references/reference-datasets-getItemHistory.md +0 -29
  336. package/dist/docs/references/reference-datasets-list.md +0 -29
  337. package/dist/docs/references/reference-datasets-listExperimentResults.md +0 -37
  338. package/dist/docs/references/reference-datasets-listExperiments.md +0 -31
  339. package/dist/docs/references/reference-datasets-listItems.md +0 -44
  340. package/dist/docs/references/reference-datasets-listVersions.md +0 -31
  341. package/dist/docs/references/reference-datasets-startExperiment.md +0 -60
  342. package/dist/docs/references/reference-datasets-startExperimentAsync.md +0 -41
  343. package/dist/docs/references/reference-datasets-update.md +0 -46
  344. package/dist/docs/references/reference-datasets-updateItem.md +0 -36
  345. package/dist/docs/references/reference-evals-answer-relevancy.md +0 -105
  346. package/dist/docs/references/reference-evals-answer-similarity.md +0 -99
  347. package/dist/docs/references/reference-evals-bias.md +0 -120
  348. package/dist/docs/references/reference-evals-completeness.md +0 -137
  349. package/dist/docs/references/reference-evals-content-similarity.md +0 -101
  350. package/dist/docs/references/reference-evals-context-precision.md +0 -196
  351. package/dist/docs/references/reference-evals-create-scorer.md +0 -270
  352. package/dist/docs/references/reference-evals-faithfulness.md +0 -114
  353. package/dist/docs/references/reference-evals-hallucination.md +0 -220
  354. package/dist/docs/references/reference-evals-keyword-coverage.md +0 -128
  355. package/dist/docs/references/reference-evals-mastra-scorer.md +0 -123
  356. package/dist/docs/references/reference-evals-run-evals.md +0 -138
  357. package/dist/docs/references/reference-evals-scorer-utils.md +0 -330
  358. package/dist/docs/references/reference-evals-textual-difference.md +0 -113
  359. package/dist/docs/references/reference-evals-tone-consistency.md +0 -119
  360. package/dist/docs/references/reference-evals-toxicity.md +0 -123
  361. package/dist/docs/references/reference-harness-harness-class.md +0 -645
  362. package/dist/docs/references/reference-logging-pino-logger.md +0 -117
  363. package/dist/docs/references/reference-memory-deleteMessages.md +0 -40
  364. package/dist/docs/references/reference-memory-memory-class.md +0 -147
  365. package/dist/docs/references/reference-memory-observational-memory.md +0 -565
  366. package/dist/docs/references/reference-observability-tracing-bridges-otel.md +0 -131
  367. package/dist/docs/references/reference-observability-tracing-configuration.md +0 -178
  368. package/dist/docs/references/reference-observability-tracing-exporters-console-exporter.md +0 -138
  369. package/dist/docs/references/reference-observability-tracing-exporters-datadog.md +0 -116
  370. package/dist/docs/references/reference-observability-tracing-instances.md +0 -109
  371. package/dist/docs/references/reference-observability-tracing-interfaces.md +0 -749
  372. package/dist/docs/references/reference-observability-tracing-processors-sensitive-data-filter.md +0 -144
  373. package/dist/docs/references/reference-observability-tracing-spans.md +0 -224
  374. package/dist/docs/references/reference-processors-batch-parts-processor.md +0 -61
  375. package/dist/docs/references/reference-processors-language-detector.md +0 -81
  376. package/dist/docs/references/reference-processors-message-history-processor.md +0 -85
  377. package/dist/docs/references/reference-processors-moderation-processor.md +0 -104
  378. package/dist/docs/references/reference-processors-pii-detector.md +0 -107
  379. package/dist/docs/references/reference-processors-processor-interface.md +0 -525
  380. package/dist/docs/references/reference-processors-prompt-injection-detector.md +0 -71
  381. package/dist/docs/references/reference-processors-semantic-recall-processor.md +0 -123
  382. package/dist/docs/references/reference-processors-system-prompt-scrubber.md +0 -80
  383. package/dist/docs/references/reference-processors-token-limiter-processor.md +0 -113
  384. package/dist/docs/references/reference-processors-tool-call-filter.md +0 -85
  385. package/dist/docs/references/reference-processors-tool-search-processor.md +0 -113
  386. package/dist/docs/references/reference-processors-unicode-normalizer.md +0 -62
  387. package/dist/docs/references/reference-processors-working-memory-processor.md +0 -154
  388. package/dist/docs/references/reference-rag-database-config.md +0 -264
  389. package/dist/docs/references/reference-rag-embeddings.md +0 -92
  390. package/dist/docs/references/reference-server-mastra-server.md +0 -298
  391. package/dist/docs/references/reference-server-register-api-route.md +0 -249
  392. package/dist/docs/references/reference-storage-cloudflare-d1.md +0 -218
  393. package/dist/docs/references/reference-storage-composite.md +0 -235
  394. package/dist/docs/references/reference-storage-lance.md +0 -131
  395. package/dist/docs/references/reference-storage-libsql.md +0 -135
  396. package/dist/docs/references/reference-storage-mongodb.md +0 -262
  397. package/dist/docs/references/reference-storage-mssql.md +0 -155
  398. package/dist/docs/references/reference-storage-overview.md +0 -121
  399. package/dist/docs/references/reference-storage-postgresql.md +0 -529
  400. package/dist/docs/references/reference-storage-upstash.md +0 -160
  401. package/dist/docs/references/reference-streaming-ChunkType.md +0 -292
  402. package/dist/docs/references/reference-streaming-agents-MastraModelOutput.md +0 -182
  403. package/dist/docs/references/reference-streaming-agents-streamLegacy.md +0 -142
  404. package/dist/docs/references/reference-streaming-workflows-observeStream.md +0 -42
  405. package/dist/docs/references/reference-streaming-workflows-resumeStream.md +0 -61
  406. package/dist/docs/references/reference-streaming-workflows-stream.md +0 -88
  407. package/dist/docs/references/reference-streaming-workflows-timeTravelStream.md +0 -142
  408. package/dist/docs/references/reference-templates-overview.md +0 -194
  409. package/dist/docs/references/reference-tools-create-tool.md +0 -237
  410. package/dist/docs/references/reference-tools-graph-rag-tool.md +0 -185
  411. package/dist/docs/references/reference-tools-mcp-client.md +0 -962
  412. package/dist/docs/references/reference-tools-mcp-server.md +0 -1275
  413. package/dist/docs/references/reference-tools-vector-query-tool.md +0 -459
  414. package/dist/docs/references/reference-vectors-libsql.md +0 -305
  415. package/dist/docs/references/reference-vectors-mongodb.md +0 -295
  416. package/dist/docs/references/reference-vectors-pg.md +0 -408
  417. package/dist/docs/references/reference-vectors-upstash.md +0 -294
  418. package/dist/docs/references/reference-voice-composite-voice.md +0 -121
  419. package/dist/docs/references/reference-voice-mastra-voice.md +0 -313
  420. package/dist/docs/references/reference-voice-voice.addInstructions.md +0 -56
  421. package/dist/docs/references/reference-voice-voice.addTools.md +0 -67
  422. package/dist/docs/references/reference-voice-voice.connect.md +0 -94
  423. package/dist/docs/references/reference-voice-voice.events.md +0 -37
  424. package/dist/docs/references/reference-voice-voice.listen.md +0 -164
  425. package/dist/docs/references/reference-voice-voice.on.md +0 -111
  426. package/dist/docs/references/reference-voice-voice.speak.md +0 -157
  427. package/dist/docs/references/reference-workflows-run-methods-cancel.md +0 -86
  428. package/dist/docs/references/reference-workflows-run-methods-restart.md +0 -33
  429. package/dist/docs/references/reference-workflows-run-methods-resume.md +0 -59
  430. package/dist/docs/references/reference-workflows-run-methods-start.md +0 -58
  431. package/dist/docs/references/reference-workflows-run-methods-startAsync.md +0 -67
  432. package/dist/docs/references/reference-workflows-run-methods-timeTravel.md +0 -142
  433. package/dist/docs/references/reference-workflows-run.md +0 -59
  434. package/dist/docs/references/reference-workflows-step.md +0 -119
  435. package/dist/docs/references/reference-workflows-workflow-methods-branch.md +0 -25
  436. package/dist/docs/references/reference-workflows-workflow-methods-commit.md +0 -17
  437. package/dist/docs/references/reference-workflows-workflow-methods-create-run.md +0 -63
  438. package/dist/docs/references/reference-workflows-workflow-methods-dountil.md +0 -25
  439. package/dist/docs/references/reference-workflows-workflow-methods-dowhile.md +0 -25
  440. package/dist/docs/references/reference-workflows-workflow-methods-foreach.md +0 -118
  441. package/dist/docs/references/reference-workflows-workflow-methods-map.md +0 -93
  442. package/dist/docs/references/reference-workflows-workflow-methods-parallel.md +0 -21
  443. package/dist/docs/references/reference-workflows-workflow-methods-sleep.md +0 -35
  444. package/dist/docs/references/reference-workflows-workflow-methods-sleepUntil.md +0 -35
  445. package/dist/docs/references/reference-workflows-workflow-methods-then.md +0 -21
  446. package/dist/docs/references/reference-workflows-workflow.md +0 -157
  447. package/dist/docs/references/reference-workspace-filesystem.md +0 -202
  448. package/dist/docs/references/reference-workspace-local-filesystem.md +0 -327
  449. package/dist/docs/references/reference-workspace-local-sandbox.md +0 -285
  450. package/dist/docs/references/reference-workspace-sandbox.md +0 -81
  451. package/dist/docs/references/reference-workspace-workspace-class.md +0 -226
  452. package/dist/docs/references/reference.md +0 -276
@@ -1,529 +0,0 @@
1
- # PostgreSQL Storage
2
-
3
- The PostgreSQL storage implementation provides a production-ready storage solution using PostgreSQL databases.
4
-
5
- ## Installation
6
-
7
- **npm**:
8
-
9
- ```bash
10
- npm install @mastra/pg@latest
11
- ```
12
-
13
- **pnpm**:
14
-
15
- ```bash
16
- pnpm add @mastra/pg@latest
17
- ```
18
-
19
- **Yarn**:
20
-
21
- ```bash
22
- yarn add @mastra/pg@latest
23
- ```
24
-
25
- **Bun**:
26
-
27
- ```bash
28
- bun add @mastra/pg@latest
29
- ```
30
-
31
- ## Usage
32
-
33
- ```typescript
34
- import { PostgresStore } from "@mastra/pg";
35
-
36
- const storage = new PostgresStore({
37
- id: 'pg-storage',
38
- connectionString: process.env.DATABASE_URL,
39
- });
40
- ```
41
-
42
- ## Parameters
43
-
44
- **id:** (`string`): Unique identifier for this storage instance.
45
-
46
- **connectionString?:** (`string`): PostgreSQL connection string (e.g., postgresql://user:pass\@host:5432/dbname). Required unless using \`pool\` or individual host-based parameters (\`host\`, \`port\`, \`database\`, \`user\`, \`password\`).
47
-
48
- **host?:** (`string`): Database server hostname or IP address. Used with other host-based parameters as an alternative to connectionString.
49
-
50
- **port?:** (`number`): Database server port number. Defaults to 5432 if not specified.
51
-
52
- **database?:** (`string`): Name of the database to connect to.
53
-
54
- **user?:** (`string`): Database user for authentication.
55
-
56
- **password?:** (`string`): Password for the database user.
57
-
58
- **pool?:** (`pg.Pool`): Pre-configured pg.Pool instance. Use this to reuse an existing connection pool. When provided, Mastra will not create its own pool and will not close it when \`store.close()\` is called.
59
-
60
- **schemaName?:** (`string`): The name of the schema you want the storage to use. Defaults to 'public'.
61
-
62
- **ssl?:** (`boolean | ConnectionOptions`): SSL configuration for the connection; set to true to use default SSL or provide a ConnectionOptions object for custom SSL settings.
63
-
64
- **max?:** (`number`): Maximum number of connections in the pool. Defaults to 20.
65
-
66
- **idleTimeoutMillis?:** (`number`): How long a connection can sit idle before being closed. Defaults to 30000 (30 seconds).
67
-
68
- **disableInit?:** (`boolean`): When true, automatic table creation/migrations are disabled. Useful for CI/CD pipelines where migrations are run separately.
69
-
70
- **skipDefaultIndexes?:** (`boolean`): When true, default indexes will not be created during initialization.
71
-
72
- **indexes?:** (`CreateIndexOptions[]`): Custom indexes to create during initialization.
73
-
74
- ## Constructor Examples
75
-
76
- You can instantiate `PostgresStore` in the following ways:
77
-
78
- ```ts
79
- import { PostgresStore } from "@mastra/pg";
80
- import { Pool } from "pg";
81
-
82
- // Using a connection string
83
- const store1 = new PostgresStore({
84
- id: 'pg-storage-1',
85
- connectionString: "postgresql://user:password@localhost:5432/mydb",
86
- });
87
-
88
- // Using a connection string with pool options
89
- const store2 = new PostgresStore({
90
- id: 'pg-storage-2',
91
- connectionString: "postgresql://user:password@localhost:5432/mydb",
92
- schemaName: "custom_schema",
93
- max: 30, // Max pool connections
94
- idleTimeoutMillis: 60000, // Idle timeout
95
- ssl: { rejectUnauthorized: false },
96
- });
97
-
98
- // Using individual connection parameters
99
- const store3 = new PostgresStore({
100
- id: 'pg-storage-3',
101
- host: "localhost",
102
- port: 5432,
103
- database: "mydb",
104
- user: "user",
105
- password: "password",
106
- });
107
-
108
- // Using a pre-configured pg.Pool (recommended for pool reuse)
109
- const existingPool = new Pool({
110
- connectionString: "postgresql://user:password@localhost:5432/mydb",
111
- max: 20,
112
- // ... your custom pool configuration
113
- });
114
-
115
- const store4 = new PostgresStore({
116
- id: 'pg-storage-4',
117
- pool: existingPool,
118
- schemaName: "custom_schema", // optional
119
- });
120
- ```
121
-
122
- ## Additional Notes
123
-
124
- ### Schema Management
125
-
126
- The storage implementation handles schema creation and updates automatically. It creates the following tables:
127
-
128
- - `mastra_workflow_snapshot`: Stores workflow state and execution data
129
- - `mastra_evals`: Stores evaluation results and metadata
130
- - `mastra_threads`: Stores conversation threads
131
- - `mastra_messages`: Stores individual messages
132
- - `mastra_traces`: Stores telemetry and tracing data
133
- - `mastra_scorers`: Stores scoring and evaluation data
134
- - `mastra_resources`: Stores resource working memory data
135
-
136
- ### Observability
137
-
138
- PostgreSQL supports observability and can handle low trace volumes. Throughput capacity depends on deployment factors such as hardware, schema design, indexing, and retention policies, and should be validated for your specific environment. For high-volume production environments, consider:
139
-
140
- - Using the `insert-only` [tracing strategy](https://mastra.ai/docs/observability/tracing/exporters/default) to reduce database write operations
141
- - Setting up table partitioning for efficient data retention
142
- - Migrating observability to [ClickHouse via composite storage](https://mastra.ai/reference/storage/composite) if you need to scale further
143
-
144
- ### Initialization
145
-
146
- When you pass storage to the Mastra class, `init()` is called automatically before any storage operation:
147
-
148
- ```typescript
149
- import { Mastra } from "@mastra/core";
150
- import { PostgresStore } from "@mastra/pg";
151
-
152
- const storage = new PostgresStore({
153
- id: 'pg-storage',
154
- connectionString: process.env.DATABASE_URL,
155
- });
156
-
157
- const mastra = new Mastra({
158
- storage, // init() is called automatically
159
- });
160
- ```
161
-
162
- If you're using storage directly without Mastra, you must call `init()` explicitly to create the tables:
163
-
164
- ```typescript
165
- import { PostgresStore } from "@mastra/pg";
166
-
167
- const storage = new PostgresStore({
168
- id: 'pg-storage',
169
- connectionString: process.env.DATABASE_URL,
170
- });
171
-
172
- // Required when using storage directly
173
- await storage.init();
174
-
175
- // Access domain-specific stores via getStore()
176
- const memoryStore = await storage.getStore('memory');
177
- const thread = await memoryStore?.getThreadById({ threadId: "..." });
178
- ```
179
-
180
- > **Warning:** If `init()` is not called, tables won't be created and storage operations will fail silently or throw errors.
181
-
182
- ### Using an Existing Pool
183
-
184
- If you already have a `pg.Pool` in your application (e.g., shared with an ORM or for Row Level Security), you can pass it directly to `PostgresStore`:
185
-
186
- ```typescript
187
- import { Pool } from "pg";
188
- import { PostgresStore } from "@mastra/pg";
189
-
190
- // Your existing pool (shared across your application)
191
- const pool = new Pool({
192
- connectionString: process.env.DATABASE_URL,
193
- max: 20,
194
- });
195
-
196
- const storage = new PostgresStore({
197
- id: "shared-storage",
198
- pool: pool,
199
- });
200
- ```
201
-
202
- **Pool lifecycle behavior:**
203
-
204
- - When you **provide a pool**: Mastra uses your pool but does **not** close it when `store.close()` is called. You manage the pool lifecycle.
205
- - When Mastra **creates a pool**: Mastra owns the pool and will close it when `store.close()` is called.
206
-
207
- ### Direct Database and Pool Access
208
-
209
- `PostgresStore` exposes the underlying database client and pool for advanced use cases:
210
-
211
- ```typescript
212
- store.db; // DbClient - query interface with helpers (any, one, tx, etc.)
213
- store.pool; // pg.Pool - the underlying connection pool
214
- ```
215
-
216
- **Using `store.db` for queries:**
217
-
218
- ```typescript
219
- // Execute queries with helper methods
220
- const users = await store.db.any("SELECT * FROM users WHERE active = $1", [true]);
221
- const user = await store.db.one("SELECT * FROM users WHERE id = $1", [userId]);
222
- const maybeUser = await store.db.oneOrNone("SELECT * FROM users WHERE email = $1", [email]);
223
-
224
- // Use transactions
225
- const result = await store.db.tx(async (t) => {
226
- await t.none("INSERT INTO logs (message) VALUES ($1)", ["Started"]);
227
- const data = await t.any("SELECT * FROM items");
228
- return data;
229
- });
230
- ```
231
-
232
- **Using `store.pool` directly:**
233
-
234
- ```typescript
235
- // Get a client for manual connection management
236
- const client = await store.pool.connect();
237
- try {
238
- await client.query("SET LOCAL app.user_id = $1", [userId]);
239
- const result = await client.query("SELECT * FROM protected_table");
240
- return result.rows;
241
- } finally {
242
- client.release();
243
- }
244
- ```
245
-
246
- When using these fields:
247
-
248
- - You are responsible for proper connection and transaction handling.
249
- - Closing the store (`store.close()`) will destroy the pool only if Mastra created it.
250
- - Direct access bypasses any additional logic or validation provided by PostgresStore methods.
251
-
252
- This approach is intended for advanced scenarios where low-level access is required.
253
-
254
- ### Using with Next.js
255
-
256
- When using `PostgresStore` in Next.js applications, [Hot Module Replacement (HMR)](https://nextjs.org/docs/architecture/fast-refresh) during development can cause multiple storage instances to be created, resulting in this warning:
257
-
258
- ```text
259
- WARNING: Creating a duplicate database object for the same connection.
260
- ```
261
-
262
- To prevent this, store the `PostgresStore` instance on the global object so it persists across HMR reloads:
263
-
264
- ```typescript
265
- import { PostgresStore } from "@mastra/pg";
266
- import { Memory } from "@mastra/memory";
267
-
268
- // Extend the global type to include our instances
269
- declare global {
270
- var pgStore: PostgresStore | undefined;
271
- var memory: Memory | undefined;
272
- }
273
-
274
- // Get or create the PostgresStore instance
275
- function getPgStore(): PostgresStore {
276
- if (!global.pgStore) {
277
- if (!process.env.DATABASE_URL) {
278
- throw new Error("DATABASE_URL is not defined in environment variables");
279
- }
280
- global.pgStore = new PostgresStore({
281
- id: "pg-storage",
282
- connectionString: process.env.DATABASE_URL,
283
- ssl:
284
- process.env.DATABASE_SSL === "true"
285
- ? { rejectUnauthorized: false }
286
- : false,
287
- });
288
- }
289
- return global.pgStore;
290
- }
291
-
292
- // Get or create the Memory instance
293
- function getMemory(): Memory {
294
- if (!global.memory) {
295
- global.memory = new Memory({
296
- storage: getPgStore(),
297
- });
298
- }
299
- return global.memory;
300
- }
301
-
302
- export const storage = getPgStore();
303
- export const memory = getMemory();
304
- ```
305
-
306
- Then use the exported instances in your Mastra configuration:
307
-
308
- ```typescript
309
- import { Mastra } from "@mastra/core/mastra";
310
- import { storage } from "./storage";
311
-
312
- export const mastra = new Mastra({
313
- storage,
314
- // ...other config
315
- });
316
- ```
317
-
318
- This pattern ensures only one `PostgresStore` instance is created regardless of how many times the module is reloaded during development. The same pattern can be applied to other storage providers like `LibSQLStore`.
319
-
320
- > **Tip:** This singleton pattern is only necessary during local development with HMR. In production builds, modules are only loaded once.
321
-
322
- ## Usage Example
323
-
324
- ### Adding memory to an agent
325
-
326
- To add PostgreSQL memory to an agent use the `Memory` class and create a new `storage` key using `PostgresStore`. The `connectionString` can either be a remote location, or a local database connection.
327
-
328
- ```typescript
329
- import { Memory } from "@mastra/memory";
330
- import { Agent } from "@mastra/core/agent";
331
- import { PostgresStore } from "@mastra/pg";
332
-
333
- export const pgAgent = new Agent({
334
- id: "pg-agent",
335
- name: "PG Agent",
336
- instructions:
337
- "You are an AI agent with the ability to automatically recall memories from previous interactions.",
338
- model: "openai/gpt-5.1",
339
- memory: new Memory({
340
- storage: new PostgresStore({
341
- id: 'pg-agent-storage',
342
- connectionString: process.env.DATABASE_URL!,
343
- }),
344
- options: {
345
- generateTitle: true, // Explicitly enable automatic title generation
346
- },
347
- }),
348
- });
349
- ```
350
-
351
- ### Using the agent
352
-
353
- Use `memoryOptions` to scope recall for this request. Set `lastMessages: 5` to limit recency-based recall, and use `semanticRecall` to fetch the `topK: 3` most relevant messages, including `messageRange: 2` neighboring messages for context around each match.
354
-
355
- ```typescript
356
- import "dotenv/config";
357
-
358
- import { mastra } from "./mastra";
359
-
360
- const threadId = "123";
361
- const resourceId = "user-456";
362
-
363
- const agent = mastra.getAgent("pg-agent");
364
-
365
- const message = await agent.stream("My name is Mastra", {
366
- memory: {
367
- thread: threadId,
368
- resource: resourceId,
369
- },
370
- });
371
-
372
- await message.textStream.pipeTo(new WritableStream());
373
-
374
- const stream = await agent.stream("What's my name?", {
375
- memory: {
376
- thread: threadId,
377
- resource: resourceId,
378
- },
379
- memoryOptions: {
380
- lastMessages: 5,
381
- semanticRecall: {
382
- topK: 3,
383
- messageRange: 2,
384
- },
385
- },
386
- });
387
-
388
- for await (const chunk of stream.textStream) {
389
- process.stdout.write(chunk);
390
- }
391
- ```
392
-
393
- ## Index Management
394
-
395
- PostgreSQL storage provides index management to optimize query performance.
396
-
397
- ### Default Indexes
398
-
399
- PostgreSQL storage creates composite indexes during initialization for common query patterns:
400
-
401
- - `mastra_threads_resourceid_createdat_idx`: (resourceId, createdAt DESC)
402
- - `mastra_messages_thread_id_createdat_idx`: (thread\_id, createdAt DESC)
403
- - `mastra_ai_spans_traceid_startedat_idx`: (traceId, startedAt DESC)
404
- - `mastra_ai_spans_parentspanid_startedat_idx`: (parentSpanId, startedAt DESC)
405
- - `mastra_ai_spans_name_startedat_idx`: (name, startedAt DESC)
406
- - `mastra_ai_spans_scope_startedat_idx`: (scope, startedAt DESC)
407
- - `mastra_scores_trace_id_span_id_created_at_idx`: (traceId, spanId, createdAt DESC)
408
-
409
- These indexes improve performance for filtered queries with sorting, including `dateRange` filters on message queries.
410
-
411
- ### Configuring Indexes
412
-
413
- You can control index creation via constructor options:
414
-
415
- ```typescript
416
- import { PostgresStore } from "@mastra/pg";
417
-
418
- // Skip default indexes (manage indexes separately)
419
- const store = new PostgresStore({
420
- id: 'pg-storage',
421
- connectionString: process.env.DATABASE_URL,
422
- skipDefaultIndexes: true,
423
- });
424
-
425
- // Add custom indexes during initialization
426
- const storeWithCustomIndexes = new PostgresStore({
427
- id: 'pg-storage',
428
- connectionString: process.env.DATABASE_URL,
429
- indexes: [
430
- {
431
- name: "idx_threads_metadata_type",
432
- table: "mastra_threads",
433
- columns: ["metadata->>'type'"],
434
- },
435
- {
436
- name: "idx_messages_status",
437
- table: "mastra_messages",
438
- columns: ["metadata->>'status'"],
439
- },
440
- ],
441
- });
442
- ```
443
-
444
- For advanced index types, you can specify additional options:
445
-
446
- - `unique: true` for unique constraints
447
- - `where: 'condition'` for partial indexes
448
- - `method: 'brin'` for time-series data
449
- - `storage: { fillfactor: 90 }` for update-heavy tables
450
- - `concurrent: true` for non-blocking creation (default)
451
-
452
- ### Index Options
453
-
454
- **name:** (`string`): Unique name for the index
455
-
456
- **table:** (`string`): Table name (e.g., 'mastra\_threads')
457
-
458
- **columns:** (`string[]`): Array of column names with optional sort order (e.g., \['id', 'createdAt DESC'])
459
-
460
- **unique?:** (`boolean`): Creates a unique constraint index
461
-
462
- **concurrent?:** (`boolean`): Creates index without locking table (default: true)
463
-
464
- **where?:** (`string`): Partial index condition (PostgreSQL specific)
465
-
466
- **method?:** (`'btree' | 'hash' | 'gin' | 'gist' | 'spgist' | 'brin'`): Index method (default: 'btree')
467
-
468
- **opclass?:** (`string`): Operator class for GIN/GIST indexes
469
-
470
- **storage?:** (`Record<string, any>`): Storage parameters (e.g., { fillfactor: 90 })
471
-
472
- **tablespace?:** (`string`): Tablespace name for index placement
473
-
474
- ### Schema-Specific Indexes
475
-
476
- When using custom schemas, index names are prefixed with the schema name:
477
-
478
- ```typescript
479
- const storage = new PostgresStore({
480
- id: 'pg-storage',
481
- connectionString: process.env.DATABASE_URL,
482
- schemaName: "custom_schema",
483
- indexes: [
484
- {
485
- name: "idx_threads_status",
486
- table: "mastra_threads",
487
- columns: ["status"],
488
- },
489
- ],
490
- });
491
-
492
- // Creates index as: custom_schema_idx_threads_status
493
- ```
494
-
495
- ### Managing Indexes via SQL
496
-
497
- For advanced index management (listing, dropping, analyzing), use direct SQL queries via the `db` accessor:
498
-
499
- ```typescript
500
- // List indexes for a table
501
- const indexes = await storage.db.any(`
502
- SELECT indexname, indexdef
503
- FROM pg_indexes
504
- WHERE tablename = 'mastra_messages'
505
- `);
506
-
507
- // Drop an index
508
- await storage.db.none('DROP INDEX IF EXISTS idx_my_custom_index');
509
-
510
- // Analyze index usage
511
- const stats = await storage.db.one(`
512
- SELECT idx_scan, idx_tup_read
513
- FROM pg_stat_user_indexes
514
- WHERE indexrelname = 'mastra_messages_thread_id_createdat_idx'
515
- `);
516
- ```
517
-
518
- ### Index Types and Use Cases
519
-
520
- PostgreSQL offers different index types optimized for specific scenarios:
521
-
522
- | Index Type | Best For | Storage | Speed |
523
- | ------------------- | --------------------------------------- | ---------- | -------------------------- |
524
- | **btree** (default) | Range queries, sorting, general purpose | Moderate | Fast |
525
- | **hash** | Equality comparisons only | Small | Very fast for `=` |
526
- | **gin** | JSONB, arrays, full-text search | Large | Fast for contains |
527
- | **gist** | Geometric data, full-text search | Moderate | Fast for nearest-neighbor |
528
- | **spgist** | Non-balanced data, text patterns | Small | Fast for specific patterns |
529
- | **brin** | Large tables with natural ordering | Very small | Fast for ranges |
@@ -1,160 +0,0 @@
1
- # Upstash Storage
2
-
3
- The Upstash storage implementation provides a serverless-friendly storage solution using Upstash's Redis-compatible key-value store.
4
-
5
- > **Pricing:** When using Mastra with Upstash, the pay-as-you-go model can result in unexpectedly high costs due to the high volume of Redis commands generated during agent conversations. We strongly recommend using a **fixed pricing plan** for predictable costs. See [Upstash pricing](https://upstash.com/pricing/redis) for details and [GitHub issue #5850](https://github.com/mastra-ai/mastra/issues/5850) for context.
6
-
7
- > **Observability Not Supported:** Upstash storage **does not support the observability domain**. Traces from the `DefaultExporter` cannot be persisted to Upstash, and Mastra Studio's observability features won't work with Upstash as your only storage provider. To enable observability, use [composite storage](https://mastra.ai/reference/storage/composite) to route observability data to a supported provider like ClickHouse or PostgreSQL.
8
-
9
- ## Installation
10
-
11
- **npm**:
12
-
13
- ```bash
14
- npm install @mastra/upstash@latest
15
- ```
16
-
17
- **pnpm**:
18
-
19
- ```bash
20
- pnpm add @mastra/upstash@latest
21
- ```
22
-
23
- **Yarn**:
24
-
25
- ```bash
26
- yarn add @mastra/upstash@latest
27
- ```
28
-
29
- **Bun**:
30
-
31
- ```bash
32
- bun add @mastra/upstash@latest
33
- ```
34
-
35
- ## Usage
36
-
37
- ```typescript
38
- import { UpstashStore } from "@mastra/upstash";
39
-
40
- const storage = new UpstashStore({
41
- id: 'upstash-storage',
42
- url: process.env.UPSTASH_URL,
43
- token: process.env.UPSTASH_TOKEN,
44
- });
45
- ```
46
-
47
- ## Parameters
48
-
49
- **url:** (`string`): Upstash Redis URL
50
-
51
- **token:** (`string`): Upstash Redis authentication token
52
-
53
- **prefix?:** (`string`): Key prefix for all stored items (Default: `mastra:`)
54
-
55
- ## Additional Notes
56
-
57
- ### Key Structure
58
-
59
- The Upstash storage implementation uses a key-value structure:
60
-
61
- - Thread keys: `{prefix}thread:{threadId}`
62
- - Message keys: `{prefix}message:{messageId}`
63
- - Metadata keys: `{prefix}metadata:{entityId}`
64
-
65
- ### Serverless Benefits
66
-
67
- Upstash storage is particularly well-suited for serverless deployments:
68
-
69
- - No connection management needed
70
- - Pay-per-request pricing
71
- - Global replication options
72
- - Edge-compatible
73
-
74
- ### Data Persistence
75
-
76
- Upstash provides:
77
-
78
- - Automatic data persistence
79
- - Point-in-time recovery
80
- - Cross-region replication options
81
-
82
- ### Performance Considerations
83
-
84
- For optimal performance:
85
-
86
- - Use appropriate key prefixes to organize data
87
- - Monitor Redis memory usage
88
- - Consider data expiration policies if needed
89
-
90
- ## Usage Example
91
-
92
- ### Adding memory to an agent
93
-
94
- To add Upstash memory to an agent use the `Memory` class and create a new `storage` key using `UpstashStore` and a new `vector` key using `UpstashVector`. The configuration can point to either a remote service or a local setup.
95
-
96
- ```typescript
97
- import { Memory } from "@mastra/memory";
98
- import { Agent } from "@mastra/core/agent";
99
- import { UpstashStore } from "@mastra/upstash";
100
-
101
- export const upstashAgent = new Agent({
102
- id: "upstash-agent",
103
- name: "Upstash Agent",
104
- instructions:
105
- "You are an AI agent with the ability to automatically recall memories from previous interactions.",
106
- model: "openai/gpt-5.1",
107
- memory: new Memory({
108
- storage: new UpstashStore({
109
- id: 'upstash-agent-storage',
110
- url: process.env.UPSTASH_REDIS_REST_URL!,
111
- token: process.env.UPSTASH_REDIS_REST_TOKEN!,
112
- }),
113
- options: {
114
- generateTitle: true, // Explicitly enable automatic title generation
115
- },
116
- }),
117
- });
118
- ```
119
-
120
- ### Using the agent
121
-
122
- Use `memoryOptions` to scope recall for this request. Set `lastMessages: 5` to limit recency-based recall, and use `semanticRecall` to fetch the `topK: 3` most relevant messages, including `messageRange: 2` neighboring messages for context around each match.
123
-
124
- ```typescript
125
- import "dotenv/config";
126
-
127
- import { mastra } from "./mastra";
128
-
129
- const threadId = "123";
130
- const resourceId = "user-456";
131
-
132
- const agent = mastra.getAgent("upstashAgent");
133
-
134
- const message = await agent.stream("My name is Mastra", {
135
- memory: {
136
- thread: threadId,
137
- resource: resourceId,
138
- },
139
- });
140
-
141
- await message.textStream.pipeTo(new WritableStream());
142
-
143
- const stream = await agent.stream("What's my name?", {
144
- memory: {
145
- thread: threadId,
146
- resource: resourceId,
147
- },
148
- memoryOptions: {
149
- lastMessages: 5,
150
- semanticRecall: {
151
- topK: 3,
152
- messageRange: 2,
153
- },
154
- },
155
- });
156
-
157
- for await (const chunk of stream.textStream) {
158
- process.stdout.write(chunk);
159
- }
160
- ```