@mastra/mcp-docs-server 1.1.5 → 1.1.6

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 (556) hide show
  1. package/.docs/docs/agents/adding-voice.md +349 -0
  2. package/.docs/docs/agents/agent-approval.md +558 -0
  3. package/.docs/docs/agents/agent-memory.md +209 -0
  4. package/.docs/docs/agents/guardrails.md +374 -0
  5. package/.docs/docs/agents/network-approval.md +275 -0
  6. package/.docs/docs/agents/networks.md +299 -0
  7. package/.docs/docs/agents/overview.md +304 -0
  8. package/.docs/docs/agents/processors.md +622 -0
  9. package/.docs/docs/agents/structured-output.md +273 -0
  10. package/.docs/docs/agents/supervisor-agents.md +304 -0
  11. package/.docs/docs/agents/using-tools.md +214 -0
  12. package/.docs/docs/build-with-ai/mcp-docs-server.md +238 -0
  13. package/.docs/docs/build-with-ai/skills.md +35 -0
  14. package/.docs/docs/community/contributing-templates.md +3 -0
  15. package/.docs/docs/community/discord.md +9 -0
  16. package/.docs/docs/community/licensing.md +66 -0
  17. package/.docs/docs/deployment/cloud-providers.md +15 -0
  18. package/.docs/docs/deployment/mastra-server.md +122 -0
  19. package/.docs/docs/deployment/monorepo.md +142 -0
  20. package/.docs/docs/deployment/overview.md +62 -0
  21. package/.docs/docs/deployment/studio.md +239 -0
  22. package/.docs/docs/deployment/web-framework.md +52 -0
  23. package/.docs/docs/deployment/workflow-runners.md +9 -0
  24. package/.docs/docs/evals/built-in-scorers.md +47 -0
  25. package/.docs/docs/evals/custom-scorers.md +519 -0
  26. package/.docs/docs/evals/overview.md +141 -0
  27. package/.docs/docs/evals/running-in-ci.md +124 -0
  28. package/.docs/docs/getting-started/build-with-ai.md +68 -0
  29. package/.docs/docs/getting-started/manual-install.md +226 -0
  30. package/.docs/docs/getting-started/project-structure.md +60 -0
  31. package/.docs/docs/getting-started/start.md +28 -0
  32. package/.docs/docs/getting-started/studio.md +101 -0
  33. package/.docs/docs/index.md +43 -0
  34. package/.docs/docs/mastra-cloud/deployment.md +77 -0
  35. package/.docs/docs/mastra-cloud/observability.md +38 -0
  36. package/.docs/docs/mastra-cloud/overview.md +23 -0
  37. package/.docs/docs/mastra-cloud/setup.md +42 -0
  38. package/.docs/docs/mastra-cloud/studio.md +24 -0
  39. package/.docs/docs/mastra-code/configuration.md +299 -0
  40. package/.docs/docs/mastra-code/customization.md +228 -0
  41. package/.docs/docs/mastra-code/modes.md +104 -0
  42. package/.docs/docs/mastra-code/overview.md +135 -0
  43. package/.docs/docs/mastra-code/tools.md +229 -0
  44. package/.docs/docs/mcp/overview.md +373 -0
  45. package/.docs/docs/mcp/publishing-mcp-server.md +95 -0
  46. package/.docs/docs/memory/memory-processors.md +314 -0
  47. package/.docs/docs/memory/message-history.md +260 -0
  48. package/.docs/docs/memory/observational-memory.md +248 -0
  49. package/.docs/docs/memory/overview.md +45 -0
  50. package/.docs/docs/memory/semantic-recall.md +272 -0
  51. package/.docs/docs/memory/storage.md +261 -0
  52. package/.docs/docs/memory/working-memory.md +400 -0
  53. package/.docs/docs/observability/datasets/overview.md +198 -0
  54. package/.docs/docs/observability/datasets/running-experiments.md +274 -0
  55. package/.docs/docs/observability/logging.md +99 -0
  56. package/.docs/docs/observability/overview.md +70 -0
  57. package/.docs/docs/observability/tracing/bridges/otel.md +209 -0
  58. package/.docs/docs/observability/tracing/exporters/arize.md +272 -0
  59. package/.docs/docs/observability/tracing/exporters/braintrust.md +111 -0
  60. package/.docs/docs/observability/tracing/exporters/cloud.md +127 -0
  61. package/.docs/docs/observability/tracing/exporters/datadog.md +187 -0
  62. package/.docs/docs/observability/tracing/exporters/default.md +209 -0
  63. package/.docs/docs/observability/tracing/exporters/laminar.md +100 -0
  64. package/.docs/docs/observability/tracing/exporters/langfuse.md +213 -0
  65. package/.docs/docs/observability/tracing/exporters/langsmith.md +198 -0
  66. package/.docs/docs/observability/tracing/exporters/otel.md +476 -0
  67. package/.docs/docs/observability/tracing/exporters/posthog.md +148 -0
  68. package/.docs/docs/observability/tracing/exporters/sentry.md +208 -0
  69. package/.docs/docs/observability/tracing/overview.md +1112 -0
  70. package/.docs/docs/observability/tracing/processors/sensitive-data-filter.md +300 -0
  71. package/.docs/docs/rag/chunking-and-embedding.md +183 -0
  72. package/.docs/docs/rag/graph-rag.md +215 -0
  73. package/.docs/docs/rag/overview.md +72 -0
  74. package/.docs/docs/rag/retrieval.md +515 -0
  75. package/.docs/docs/rag/vector-databases.md +645 -0
  76. package/.docs/docs/server/auth/auth0.md +220 -0
  77. package/.docs/docs/server/auth/better-auth.md +203 -0
  78. package/.docs/docs/server/auth/clerk.md +132 -0
  79. package/.docs/docs/server/auth/composite-auth.md +234 -0
  80. package/.docs/docs/server/auth/custom-auth-provider.md +513 -0
  81. package/.docs/docs/server/auth/firebase.md +272 -0
  82. package/.docs/docs/server/auth/jwt.md +110 -0
  83. package/.docs/docs/server/auth/simple-auth.md +180 -0
  84. package/.docs/docs/server/auth/supabase.md +117 -0
  85. package/.docs/docs/server/auth/workos.md +186 -0
  86. package/.docs/docs/server/auth.md +38 -0
  87. package/.docs/docs/server/custom-adapters.md +378 -0
  88. package/.docs/docs/server/custom-api-routes.md +267 -0
  89. package/.docs/docs/server/mastra-client.md +243 -0
  90. package/.docs/docs/server/mastra-server.md +71 -0
  91. package/.docs/docs/server/middleware.md +225 -0
  92. package/.docs/docs/server/request-context.md +471 -0
  93. package/.docs/docs/server/server-adapters.md +547 -0
  94. package/.docs/docs/streaming/events.md +237 -0
  95. package/.docs/docs/streaming/overview.md +175 -0
  96. package/.docs/docs/streaming/tool-streaming.md +175 -0
  97. package/.docs/docs/streaming/workflow-streaming.md +109 -0
  98. package/.docs/docs/voice/overview.md +959 -0
  99. package/.docs/docs/voice/speech-to-speech.md +102 -0
  100. package/.docs/docs/voice/speech-to-text.md +79 -0
  101. package/.docs/docs/voice/text-to-speech.md +83 -0
  102. package/.docs/docs/workflows/agents-and-tools.md +166 -0
  103. package/.docs/docs/workflows/control-flow.md +822 -0
  104. package/.docs/docs/workflows/error-handling.md +360 -0
  105. package/.docs/docs/workflows/human-in-the-loop.md +215 -0
  106. package/.docs/docs/workflows/overview.md +370 -0
  107. package/.docs/docs/workflows/snapshots.md +238 -0
  108. package/.docs/docs/workflows/suspend-and-resume.md +205 -0
  109. package/.docs/docs/workflows/time-travel.md +309 -0
  110. package/.docs/docs/workflows/workflow-state.md +181 -0
  111. package/.docs/docs/workspace/filesystem.md +164 -0
  112. package/.docs/docs/workspace/overview.md +239 -0
  113. package/.docs/docs/workspace/sandbox.md +63 -0
  114. package/.docs/docs/workspace/search.md +243 -0
  115. package/.docs/docs/workspace/skills.md +169 -0
  116. package/.docs/guides/agent-frameworks/ai-sdk.md +140 -0
  117. package/.docs/guides/build-your-ui/ai-sdk-ui.md +1499 -0
  118. package/.docs/guides/build-your-ui/assistant-ui.md +156 -0
  119. package/.docs/guides/build-your-ui/copilotkit.md +289 -0
  120. package/.docs/guides/deployment/amazon-ec2.md +130 -0
  121. package/.docs/guides/deployment/aws-lambda.md +248 -0
  122. package/.docs/guides/deployment/azure-app-services.md +114 -0
  123. package/.docs/guides/deployment/cloudflare.md +99 -0
  124. package/.docs/guides/deployment/digital-ocean.md +168 -0
  125. package/.docs/guides/deployment/inngest.md +682 -0
  126. package/.docs/guides/deployment/netlify.md +77 -0
  127. package/.docs/guides/deployment/vercel.md +101 -0
  128. package/.docs/guides/getting-started/astro.md +398 -0
  129. package/.docs/guides/getting-started/electron.md +504 -0
  130. package/.docs/guides/getting-started/express.md +251 -0
  131. package/.docs/guides/getting-started/hono.md +190 -0
  132. package/.docs/guides/getting-started/next-js.md +347 -0
  133. package/.docs/guides/getting-started/nuxt.md +497 -0
  134. package/.docs/guides/getting-started/quickstart.md +67 -0
  135. package/.docs/guides/getting-started/sveltekit.md +296 -0
  136. package/.docs/guides/getting-started/vite-react.md +425 -0
  137. package/.docs/guides/guide/ai-recruiter.md +226 -0
  138. package/.docs/guides/guide/chef-michel.md +211 -0
  139. package/.docs/guides/guide/code-review-bot.md +226 -0
  140. package/.docs/guides/guide/dev-assistant.md +307 -0
  141. package/.docs/guides/guide/docs-manager.md +238 -0
  142. package/.docs/guides/guide/github-actions-pr-description.md +236 -0
  143. package/.docs/guides/guide/notes-mcp-server.md +416 -0
  144. package/.docs/guides/guide/research-assistant.md +348 -0
  145. package/.docs/guides/guide/research-coordinator.md +416 -0
  146. package/.docs/guides/guide/stock-agent.md +132 -0
  147. package/.docs/guides/guide/web-search.md +320 -0
  148. package/.docs/guides/guide/whatsapp-chat-bot.md +405 -0
  149. package/.docs/guides/index.md +3 -0
  150. package/.docs/guides/migrations/agentnetwork.md +97 -0
  151. package/.docs/guides/migrations/ai-sdk-v4-to-v5.md +112 -0
  152. package/.docs/guides/migrations/network-to-supervisor.md +261 -0
  153. package/.docs/guides/migrations/upgrade-to-v1/agent.md +404 -0
  154. package/.docs/guides/migrations/upgrade-to-v1/cli.md +57 -0
  155. package/.docs/guides/migrations/upgrade-to-v1/client.md +337 -0
  156. package/.docs/guides/migrations/upgrade-to-v1/deployment.md +37 -0
  157. package/.docs/guides/migrations/upgrade-to-v1/evals.md +239 -0
  158. package/.docs/guides/migrations/upgrade-to-v1/mastra.md +143 -0
  159. package/.docs/guides/migrations/upgrade-to-v1/mcp.md +97 -0
  160. package/.docs/guides/migrations/upgrade-to-v1/memory.md +285 -0
  161. package/.docs/guides/migrations/upgrade-to-v1/overview.md +119 -0
  162. package/.docs/guides/migrations/upgrade-to-v1/processors.md +68 -0
  163. package/.docs/guides/migrations/upgrade-to-v1/rag.md +42 -0
  164. package/.docs/guides/migrations/upgrade-to-v1/storage.md +553 -0
  165. package/.docs/guides/migrations/upgrade-to-v1/tools.md +180 -0
  166. package/.docs/guides/migrations/upgrade-to-v1/tracing.md +412 -0
  167. package/.docs/guides/migrations/upgrade-to-v1/vectors.md +87 -0
  168. package/.docs/guides/migrations/upgrade-to-v1/voice.md +30 -0
  169. package/.docs/guides/migrations/upgrade-to-v1/workflows.md +341 -0
  170. package/.docs/guides/migrations/vnext-to-standard-apis.md +362 -0
  171. package/.docs/models/embeddings.md +161 -0
  172. package/.docs/models/gateways/azure-openai.md +128 -0
  173. package/.docs/models/gateways/custom-gateways.md +545 -0
  174. package/.docs/models/gateways/netlify.md +88 -0
  175. package/.docs/models/gateways/openrouter.md +219 -0
  176. package/.docs/models/gateways/vercel.md +225 -0
  177. package/.docs/models/gateways.md +14 -0
  178. package/.docs/models/index.md +286 -0
  179. package/.docs/models/providers/302ai.md +134 -0
  180. package/.docs/models/providers/abacus.md +125 -0
  181. package/.docs/models/providers/agentrouter.md +90 -0
  182. package/.docs/models/providers/aihubmix.md +107 -0
  183. package/.docs/models/providers/alibaba-cn.md +135 -0
  184. package/.docs/models/providers/alibaba.md +111 -0
  185. package/.docs/models/providers/amazon-bedrock.md +33 -0
  186. package/.docs/models/providers/anthropic.md +153 -0
  187. package/.docs/models/providers/azure.md +33 -0
  188. package/.docs/models/providers/bailing.md +72 -0
  189. package/.docs/models/providers/baseten.md +77 -0
  190. package/.docs/models/providers/berget.md +78 -0
  191. package/.docs/models/providers/cerebras.md +101 -0
  192. package/.docs/models/providers/chutes.md +136 -0
  193. package/.docs/models/providers/cloudflare-ai-gateway.md +33 -0
  194. package/.docs/models/providers/cloudflare-workers-ai.md +109 -0
  195. package/.docs/models/providers/cohere.md +33 -0
  196. package/.docs/models/providers/cortecs.md +91 -0
  197. package/.docs/models/providers/deepinfra.md +112 -0
  198. package/.docs/models/providers/deepseek.md +88 -0
  199. package/.docs/models/providers/fastrouter.md +84 -0
  200. package/.docs/models/providers/fireworks-ai.md +89 -0
  201. package/.docs/models/providers/firmware.md +85 -0
  202. package/.docs/models/providers/friendli.md +78 -0
  203. package/.docs/models/providers/github-models.md +125 -0
  204. package/.docs/models/providers/google-vertex.md +33 -0
  205. package/.docs/models/providers/google.md +159 -0
  206. package/.docs/models/providers/groq.md +107 -0
  207. package/.docs/models/providers/helicone.md +161 -0
  208. package/.docs/models/providers/huggingface.md +90 -0
  209. package/.docs/models/providers/iflowcn.md +84 -0
  210. package/.docs/models/providers/inception.md +72 -0
  211. package/.docs/models/providers/inference.md +79 -0
  212. package/.docs/models/providers/io-intelligence.md +87 -0
  213. package/.docs/models/providers/io-net.md +87 -0
  214. package/.docs/models/providers/jiekou.md +131 -0
  215. package/.docs/models/providers/kilo.md +333 -0
  216. package/.docs/models/providers/kimi-for-coding.md +100 -0
  217. package/.docs/models/providers/kuae-cloud-coding-plan.md +71 -0
  218. package/.docs/models/providers/llama.md +77 -0
  219. package/.docs/models/providers/lmstudio.md +73 -0
  220. package/.docs/models/providers/lucidquery.md +72 -0
  221. package/.docs/models/providers/minimax-cn-coding-plan.md +102 -0
  222. package/.docs/models/providers/minimax-cn.md +102 -0
  223. package/.docs/models/providers/minimax-coding-plan.md +102 -0
  224. package/.docs/models/providers/minimax.md +104 -0
  225. package/.docs/models/providers/mistral.md +124 -0
  226. package/.docs/models/providers/moark.md +72 -0
  227. package/.docs/models/providers/modelscope.md +77 -0
  228. package/.docs/models/providers/moonshotai-cn.md +76 -0
  229. package/.docs/models/providers/moonshotai.md +76 -0
  230. package/.docs/models/providers/morph.md +73 -0
  231. package/.docs/models/providers/nano-gpt.md +103 -0
  232. package/.docs/models/providers/nebius.md +116 -0
  233. package/.docs/models/providers/nova.md +72 -0
  234. package/.docs/models/providers/novita-ai.md +154 -0
  235. package/.docs/models/providers/nvidia.md +141 -0
  236. package/.docs/models/providers/ollama-cloud.md +103 -0
  237. package/.docs/models/providers/ollama.md +33 -0
  238. package/.docs/models/providers/openai.md +193 -0
  239. package/.docs/models/providers/opencode.md +100 -0
  240. package/.docs/models/providers/ovhcloud.md +83 -0
  241. package/.docs/models/providers/perplexity.md +100 -0
  242. package/.docs/models/providers/poe.md +183 -0
  243. package/.docs/models/providers/privatemode-ai.md +75 -0
  244. package/.docs/models/providers/requesty.md +90 -0
  245. package/.docs/models/providers/scaleway.md +84 -0
  246. package/.docs/models/providers/siliconflow-cn.md +138 -0
  247. package/.docs/models/providers/siliconflow.md +140 -0
  248. package/.docs/models/providers/stackit.md +78 -0
  249. package/.docs/models/providers/stepfun.md +73 -0
  250. package/.docs/models/providers/submodel.md +79 -0
  251. package/.docs/models/providers/synthetic.md +96 -0
  252. package/.docs/models/providers/togetherai.md +115 -0
  253. package/.docs/models/providers/upstage.md +73 -0
  254. package/.docs/models/providers/venice.md +95 -0
  255. package/.docs/models/providers/vivgrid.md +106 -0
  256. package/.docs/models/providers/vultr.md +75 -0
  257. package/.docs/models/providers/wandb.md +80 -0
  258. package/.docs/models/providers/xai.md +141 -0
  259. package/.docs/models/providers/xiaomi.md +71 -0
  260. package/.docs/models/providers/zai-coding-plan.md +80 -0
  261. package/.docs/models/providers/zai.md +79 -0
  262. package/.docs/models/providers/zenmux.md +161 -0
  263. package/.docs/models/providers/zhipuai-coding-plan.md +79 -0
  264. package/.docs/models/providers/zhipuai.md +79 -0
  265. package/.docs/models/providers.md +81 -0
  266. package/.docs/reference/agents/agent.md +141 -0
  267. package/.docs/reference/agents/generate.md +186 -0
  268. package/.docs/reference/agents/generateLegacy.md +173 -0
  269. package/.docs/reference/agents/getDefaultGenerateOptions.md +36 -0
  270. package/.docs/reference/agents/getDefaultOptions.md +34 -0
  271. package/.docs/reference/agents/getDefaultStreamOptions.md +36 -0
  272. package/.docs/reference/agents/getDescription.md +21 -0
  273. package/.docs/reference/agents/getInstructions.md +34 -0
  274. package/.docs/reference/agents/getLLM.md +37 -0
  275. package/.docs/reference/agents/getMemory.md +34 -0
  276. package/.docs/reference/agents/getModel.md +34 -0
  277. package/.docs/reference/agents/getTools.md +29 -0
  278. package/.docs/reference/agents/getVoice.md +34 -0
  279. package/.docs/reference/agents/listAgents.md +35 -0
  280. package/.docs/reference/agents/listScorers.md +34 -0
  281. package/.docs/reference/agents/listTools.md +34 -0
  282. package/.docs/reference/agents/listWorkflows.md +34 -0
  283. package/.docs/reference/agents/network.md +133 -0
  284. package/.docs/reference/ai-sdk/chat-route.md +82 -0
  285. package/.docs/reference/ai-sdk/handle-chat-stream.md +53 -0
  286. package/.docs/reference/ai-sdk/handle-network-stream.md +37 -0
  287. package/.docs/reference/ai-sdk/handle-workflow-stream.md +55 -0
  288. package/.docs/reference/ai-sdk/network-route.md +74 -0
  289. package/.docs/reference/ai-sdk/to-ai-sdk-stream.md +231 -0
  290. package/.docs/reference/ai-sdk/to-ai-sdk-v4-messages.md +79 -0
  291. package/.docs/reference/ai-sdk/to-ai-sdk-v5-messages.md +76 -0
  292. package/.docs/reference/ai-sdk/with-mastra.md +59 -0
  293. package/.docs/reference/ai-sdk/workflow-route.md +79 -0
  294. package/.docs/reference/auth/auth0.md +73 -0
  295. package/.docs/reference/auth/better-auth.md +71 -0
  296. package/.docs/reference/auth/clerk.md +36 -0
  297. package/.docs/reference/auth/firebase.md +80 -0
  298. package/.docs/reference/auth/jwt.md +26 -0
  299. package/.docs/reference/auth/supabase.md +33 -0
  300. package/.docs/reference/auth/workos.md +84 -0
  301. package/.docs/reference/cli/create-mastra.md +137 -0
  302. package/.docs/reference/cli/mastra.md +336 -0
  303. package/.docs/reference/client-js/agents.md +437 -0
  304. package/.docs/reference/client-js/error-handling.md +16 -0
  305. package/.docs/reference/client-js/logs.md +24 -0
  306. package/.docs/reference/client-js/mastra-client.md +63 -0
  307. package/.docs/reference/client-js/memory.md +221 -0
  308. package/.docs/reference/client-js/observability.md +72 -0
  309. package/.docs/reference/client-js/telemetry.md +20 -0
  310. package/.docs/reference/client-js/tools.md +44 -0
  311. package/.docs/reference/client-js/vectors.md +79 -0
  312. package/.docs/reference/client-js/workflows.md +199 -0
  313. package/.docs/reference/configuration.md +752 -0
  314. package/.docs/reference/core/addGateway.md +42 -0
  315. package/.docs/reference/core/getAgent.md +21 -0
  316. package/.docs/reference/core/getAgentById.md +21 -0
  317. package/.docs/reference/core/getDeployer.md +22 -0
  318. package/.docs/reference/core/getGateway.md +38 -0
  319. package/.docs/reference/core/getGatewayById.md +41 -0
  320. package/.docs/reference/core/getLogger.md +22 -0
  321. package/.docs/reference/core/getMCPServer.md +47 -0
  322. package/.docs/reference/core/getMCPServerById.md +55 -0
  323. package/.docs/reference/core/getMemory.md +50 -0
  324. package/.docs/reference/core/getScorer.md +54 -0
  325. package/.docs/reference/core/getScorerById.md +54 -0
  326. package/.docs/reference/core/getServer.md +22 -0
  327. package/.docs/reference/core/getStorage.md +22 -0
  328. package/.docs/reference/core/getStoredAgentById.md +89 -0
  329. package/.docs/reference/core/getTelemetry.md +22 -0
  330. package/.docs/reference/core/getVector.md +22 -0
  331. package/.docs/reference/core/getWorkflow.md +42 -0
  332. package/.docs/reference/core/listAgents.md +21 -0
  333. package/.docs/reference/core/listGateways.md +40 -0
  334. package/.docs/reference/core/listLogs.md +38 -0
  335. package/.docs/reference/core/listLogsByRunId.md +36 -0
  336. package/.docs/reference/core/listMCPServers.md +55 -0
  337. package/.docs/reference/core/listMemory.md +56 -0
  338. package/.docs/reference/core/listScorers.md +29 -0
  339. package/.docs/reference/core/listStoredAgents.md +93 -0
  340. package/.docs/reference/core/listVectors.md +22 -0
  341. package/.docs/reference/core/listWorkflows.md +21 -0
  342. package/.docs/reference/core/mastra-class.md +66 -0
  343. package/.docs/reference/core/mastra-model-gateway.md +153 -0
  344. package/.docs/reference/core/setLogger.md +26 -0
  345. package/.docs/reference/core/setStorage.md +27 -0
  346. package/.docs/reference/datasets/addItem.md +37 -0
  347. package/.docs/reference/datasets/addItems.md +35 -0
  348. package/.docs/reference/datasets/compareExperiments.md +52 -0
  349. package/.docs/reference/datasets/create.md +51 -0
  350. package/.docs/reference/datasets/dataset.md +82 -0
  351. package/.docs/reference/datasets/datasets-manager.md +94 -0
  352. package/.docs/reference/datasets/delete.md +25 -0
  353. package/.docs/reference/datasets/deleteExperiment.md +27 -0
  354. package/.docs/reference/datasets/deleteItem.md +27 -0
  355. package/.docs/reference/datasets/deleteItems.md +29 -0
  356. package/.docs/reference/datasets/get.md +31 -0
  357. package/.docs/reference/datasets/getDetails.md +47 -0
  358. package/.docs/reference/datasets/getExperiment.md +30 -0
  359. package/.docs/reference/datasets/getItem.md +33 -0
  360. package/.docs/reference/datasets/getItemHistory.md +31 -0
  361. package/.docs/reference/datasets/list.md +31 -0
  362. package/.docs/reference/datasets/listExperimentResults.md +39 -0
  363. package/.docs/reference/datasets/listExperiments.md +33 -0
  364. package/.docs/reference/datasets/listItems.md +46 -0
  365. package/.docs/reference/datasets/listVersions.md +33 -0
  366. package/.docs/reference/datasets/startExperiment.md +62 -0
  367. package/.docs/reference/datasets/startExperimentAsync.md +43 -0
  368. package/.docs/reference/datasets/update.md +48 -0
  369. package/.docs/reference/datasets/updateItem.md +38 -0
  370. package/.docs/reference/deployer/cloudflare.md +79 -0
  371. package/.docs/reference/deployer/netlify.md +80 -0
  372. package/.docs/reference/deployer/vercel.md +91 -0
  373. package/.docs/reference/deployer.md +100 -0
  374. package/.docs/reference/evals/answer-relevancy.md +105 -0
  375. package/.docs/reference/evals/answer-similarity.md +99 -0
  376. package/.docs/reference/evals/bias.md +120 -0
  377. package/.docs/reference/evals/completeness.md +136 -0
  378. package/.docs/reference/evals/content-similarity.md +101 -0
  379. package/.docs/reference/evals/context-precision.md +196 -0
  380. package/.docs/reference/evals/context-relevance.md +531 -0
  381. package/.docs/reference/evals/create-scorer.md +270 -0
  382. package/.docs/reference/evals/faithfulness.md +114 -0
  383. package/.docs/reference/evals/hallucination.md +213 -0
  384. package/.docs/reference/evals/keyword-coverage.md +128 -0
  385. package/.docs/reference/evals/mastra-scorer.md +123 -0
  386. package/.docs/reference/evals/noise-sensitivity.md +675 -0
  387. package/.docs/reference/evals/prompt-alignment.md +614 -0
  388. package/.docs/reference/evals/run-evals.md +179 -0
  389. package/.docs/reference/evals/scorer-utils.md +326 -0
  390. package/.docs/reference/evals/textual-difference.md +113 -0
  391. package/.docs/reference/evals/tone-consistency.md +119 -0
  392. package/.docs/reference/evals/tool-call-accuracy.md +533 -0
  393. package/.docs/reference/evals/toxicity.md +123 -0
  394. package/.docs/reference/harness/harness-class.md +708 -0
  395. package/.docs/reference/index.md +277 -0
  396. package/.docs/reference/logging/pino-logger.md +117 -0
  397. package/.docs/reference/mastra-code/createMastraCode.md +108 -0
  398. package/.docs/reference/memory/clone-utilities.md +199 -0
  399. package/.docs/reference/memory/cloneThread.md +130 -0
  400. package/.docs/reference/memory/createThread.md +68 -0
  401. package/.docs/reference/memory/deleteMessages.md +38 -0
  402. package/.docs/reference/memory/getThreadById.md +24 -0
  403. package/.docs/reference/memory/listThreads.md +145 -0
  404. package/.docs/reference/memory/memory-class.md +147 -0
  405. package/.docs/reference/memory/observational-memory.md +565 -0
  406. package/.docs/reference/memory/recall.md +91 -0
  407. package/.docs/reference/observability/tracing/bridges/otel.md +131 -0
  408. package/.docs/reference/observability/tracing/configuration.md +178 -0
  409. package/.docs/reference/observability/tracing/exporters/arize.md +141 -0
  410. package/.docs/reference/observability/tracing/exporters/braintrust.md +93 -0
  411. package/.docs/reference/observability/tracing/exporters/cloud-exporter.md +163 -0
  412. package/.docs/reference/observability/tracing/exporters/console-exporter.md +138 -0
  413. package/.docs/reference/observability/tracing/exporters/datadog.md +116 -0
  414. package/.docs/reference/observability/tracing/exporters/default-exporter.md +174 -0
  415. package/.docs/reference/observability/tracing/exporters/laminar.md +78 -0
  416. package/.docs/reference/observability/tracing/exporters/langfuse.md +134 -0
  417. package/.docs/reference/observability/tracing/exporters/langsmith.md +108 -0
  418. package/.docs/reference/observability/tracing/exporters/otel.md +199 -0
  419. package/.docs/reference/observability/tracing/exporters/posthog.md +92 -0
  420. package/.docs/reference/observability/tracing/exporters/sentry.md +184 -0
  421. package/.docs/reference/observability/tracing/instances.md +107 -0
  422. package/.docs/reference/observability/tracing/interfaces.md +743 -0
  423. package/.docs/reference/observability/tracing/processors/sensitive-data-filter.md +144 -0
  424. package/.docs/reference/observability/tracing/spans.md +224 -0
  425. package/.docs/reference/processors/batch-parts-processor.md +61 -0
  426. package/.docs/reference/processors/language-detector.md +82 -0
  427. package/.docs/reference/processors/message-history-processor.md +85 -0
  428. package/.docs/reference/processors/moderation-processor.md +104 -0
  429. package/.docs/reference/processors/pii-detector.md +108 -0
  430. package/.docs/reference/processors/processor-interface.md +521 -0
  431. package/.docs/reference/processors/prompt-injection-detector.md +72 -0
  432. package/.docs/reference/processors/semantic-recall-processor.md +117 -0
  433. package/.docs/reference/processors/system-prompt-scrubber.md +80 -0
  434. package/.docs/reference/processors/token-limiter-processor.md +115 -0
  435. package/.docs/reference/processors/tool-call-filter.md +85 -0
  436. package/.docs/reference/processors/tool-search-processor.md +111 -0
  437. package/.docs/reference/processors/unicode-normalizer.md +62 -0
  438. package/.docs/reference/processors/working-memory-processor.md +152 -0
  439. package/.docs/reference/rag/chunk.md +221 -0
  440. package/.docs/reference/rag/database-config.md +261 -0
  441. package/.docs/reference/rag/document.md +114 -0
  442. package/.docs/reference/rag/embeddings.md +92 -0
  443. package/.docs/reference/rag/extract-params.md +168 -0
  444. package/.docs/reference/rag/graph-rag.md +111 -0
  445. package/.docs/reference/rag/metadata-filters.md +216 -0
  446. package/.docs/reference/rag/rerank.md +75 -0
  447. package/.docs/reference/rag/rerankWithScorer.md +80 -0
  448. package/.docs/reference/server/create-route.md +262 -0
  449. package/.docs/reference/server/express-adapter.md +176 -0
  450. package/.docs/reference/server/fastify-adapter.md +90 -0
  451. package/.docs/reference/server/hono-adapter.md +162 -0
  452. package/.docs/reference/server/koa-adapter.md +127 -0
  453. package/.docs/reference/server/mastra-server.md +298 -0
  454. package/.docs/reference/server/register-api-route.md +249 -0
  455. package/.docs/reference/server/routes.md +306 -0
  456. package/.docs/reference/storage/cloudflare-d1.md +218 -0
  457. package/.docs/reference/storage/cloudflare.md +88 -0
  458. package/.docs/reference/storage/composite.md +235 -0
  459. package/.docs/reference/storage/convex.md +161 -0
  460. package/.docs/reference/storage/dynamodb.md +282 -0
  461. package/.docs/reference/storage/lance.md +131 -0
  462. package/.docs/reference/storage/libsql.md +135 -0
  463. package/.docs/reference/storage/mongodb.md +262 -0
  464. package/.docs/reference/storage/mssql.md +157 -0
  465. package/.docs/reference/storage/overview.md +121 -0
  466. package/.docs/reference/storage/postgresql.md +526 -0
  467. package/.docs/reference/storage/upstash.md +160 -0
  468. package/.docs/reference/streaming/ChunkType.md +292 -0
  469. package/.docs/reference/streaming/agents/MastraModelOutput.md +182 -0
  470. package/.docs/reference/streaming/agents/stream.md +221 -0
  471. package/.docs/reference/streaming/agents/streamLegacy.md +142 -0
  472. package/.docs/reference/streaming/workflows/observeStream.md +42 -0
  473. package/.docs/reference/streaming/workflows/resumeStream.md +61 -0
  474. package/.docs/reference/streaming/workflows/stream.md +88 -0
  475. package/.docs/reference/streaming/workflows/timeTravelStream.md +142 -0
  476. package/.docs/reference/templates/overview.md +194 -0
  477. package/.docs/reference/tools/create-tool.md +237 -0
  478. package/.docs/reference/tools/document-chunker-tool.md +89 -0
  479. package/.docs/reference/tools/graph-rag-tool.md +182 -0
  480. package/.docs/reference/tools/mcp-client.md +954 -0
  481. package/.docs/reference/tools/mcp-server.md +1271 -0
  482. package/.docs/reference/tools/vector-query-tool.md +459 -0
  483. package/.docs/reference/vectors/astra.md +121 -0
  484. package/.docs/reference/vectors/chroma.md +264 -0
  485. package/.docs/reference/vectors/convex.md +300 -0
  486. package/.docs/reference/vectors/couchbase.md +226 -0
  487. package/.docs/reference/vectors/duckdb.md +318 -0
  488. package/.docs/reference/vectors/elasticsearch.md +189 -0
  489. package/.docs/reference/vectors/lance.md +220 -0
  490. package/.docs/reference/vectors/libsql.md +305 -0
  491. package/.docs/reference/vectors/mongodb.md +295 -0
  492. package/.docs/reference/vectors/opensearch.md +99 -0
  493. package/.docs/reference/vectors/pg.md +408 -0
  494. package/.docs/reference/vectors/pinecone.md +168 -0
  495. package/.docs/reference/vectors/qdrant.md +222 -0
  496. package/.docs/reference/vectors/s3vectors.md +277 -0
  497. package/.docs/reference/vectors/turbopuffer.md +157 -0
  498. package/.docs/reference/vectors/upstash.md +294 -0
  499. package/.docs/reference/vectors/vectorize.md +147 -0
  500. package/.docs/reference/voice/azure.md +148 -0
  501. package/.docs/reference/voice/cloudflare.md +83 -0
  502. package/.docs/reference/voice/composite-voice.md +121 -0
  503. package/.docs/reference/voice/deepgram.md +79 -0
  504. package/.docs/reference/voice/elevenlabs.md +98 -0
  505. package/.docs/reference/voice/google-gemini-live.md +378 -0
  506. package/.docs/reference/voice/google.md +228 -0
  507. package/.docs/reference/voice/mastra-voice.md +311 -0
  508. package/.docs/reference/voice/murf.md +122 -0
  509. package/.docs/reference/voice/openai-realtime.md +203 -0
  510. package/.docs/reference/voice/openai.md +88 -0
  511. package/.docs/reference/voice/playai.md +80 -0
  512. package/.docs/reference/voice/sarvam.md +126 -0
  513. package/.docs/reference/voice/speechify.md +75 -0
  514. package/.docs/reference/voice/voice.addInstructions.md +55 -0
  515. package/.docs/reference/voice/voice.addTools.md +67 -0
  516. package/.docs/reference/voice/voice.answer.md +54 -0
  517. package/.docs/reference/voice/voice.close.md +51 -0
  518. package/.docs/reference/voice/voice.connect.md +94 -0
  519. package/.docs/reference/voice/voice.events.md +37 -0
  520. package/.docs/reference/voice/voice.getSpeakers.md +129 -0
  521. package/.docs/reference/voice/voice.listen.md +164 -0
  522. package/.docs/reference/voice/voice.off.md +54 -0
  523. package/.docs/reference/voice/voice.on.md +111 -0
  524. package/.docs/reference/voice/voice.send.md +65 -0
  525. package/.docs/reference/voice/voice.speak.md +157 -0
  526. package/.docs/reference/voice/voice.updateConfig.md +60 -0
  527. package/.docs/reference/workflows/run-methods/cancel.md +86 -0
  528. package/.docs/reference/workflows/run-methods/restart.md +33 -0
  529. package/.docs/reference/workflows/run-methods/resume.md +59 -0
  530. package/.docs/reference/workflows/run-methods/start.md +58 -0
  531. package/.docs/reference/workflows/run-methods/startAsync.md +67 -0
  532. package/.docs/reference/workflows/run-methods/timeTravel.md +142 -0
  533. package/.docs/reference/workflows/run.md +59 -0
  534. package/.docs/reference/workflows/step.md +119 -0
  535. package/.docs/reference/workflows/workflow-methods/branch.md +25 -0
  536. package/.docs/reference/workflows/workflow-methods/commit.md +17 -0
  537. package/.docs/reference/workflows/workflow-methods/create-run.md +63 -0
  538. package/.docs/reference/workflows/workflow-methods/dountil.md +25 -0
  539. package/.docs/reference/workflows/workflow-methods/dowhile.md +25 -0
  540. package/.docs/reference/workflows/workflow-methods/foreach.md +118 -0
  541. package/.docs/reference/workflows/workflow-methods/map.md +93 -0
  542. package/.docs/reference/workflows/workflow-methods/parallel.md +21 -0
  543. package/.docs/reference/workflows/workflow-methods/sleep.md +35 -0
  544. package/.docs/reference/workflows/workflow-methods/sleepUntil.md +35 -0
  545. package/.docs/reference/workflows/workflow-methods/then.md +21 -0
  546. package/.docs/reference/workflows/workflow.md +157 -0
  547. package/.docs/reference/workspace/e2b-sandbox.md +289 -0
  548. package/.docs/reference/workspace/filesystem.md +255 -0
  549. package/.docs/reference/workspace/gcs-filesystem.md +174 -0
  550. package/.docs/reference/workspace/local-filesystem.md +343 -0
  551. package/.docs/reference/workspace/local-sandbox.md +301 -0
  552. package/.docs/reference/workspace/s3-filesystem.md +175 -0
  553. package/.docs/reference/workspace/sandbox.md +87 -0
  554. package/.docs/reference/workspace/workspace-class.md +244 -0
  555. package/CHANGELOG.md +16 -0
  556. package/package.json +6 -6
@@ -0,0 +1,72 @@
1
+ # RAG (Retrieval-Augmented Generation) in Mastra
2
+
3
+ RAG in Mastra helps you enhance LLM outputs by incorporating relevant context from your own data sources, improving accuracy and grounding responses in real information.
4
+
5
+ Mastra's RAG system provides:
6
+
7
+ - Standardized APIs to process and embed documents
8
+ - Support for multiple vector stores
9
+ - Chunking and embedding strategies for optimal retrieval
10
+ - Observability for tracking embedding and retrieval performance
11
+
12
+ ## Example
13
+
14
+ To implement RAG, you process your documents into chunks, create embeddings, store them in a vector database, and then retrieve relevant context at query time.
15
+
16
+ ```ts
17
+ import { embedMany } from 'ai'
18
+ import { PgVector } from '@mastra/pg'
19
+ import { MDocument } from '@mastra/rag'
20
+ import { z } from 'zod'
21
+
22
+ // 1. Initialize document
23
+ const doc = MDocument.fromText(`Your document text here...`)
24
+
25
+ // 2. Create chunks
26
+ const chunks = await doc.chunk({
27
+ strategy: 'recursive',
28
+ size: 512,
29
+ overlap: 50,
30
+ })
31
+
32
+ // 3. Generate embeddings; we need to pass the text of each chunk
33
+ import { ModelRouterEmbeddingModel } from '@mastra/core/llm'
34
+
35
+ const { embeddings } = await embedMany({
36
+ values: chunks.map(chunk => chunk.text),
37
+ model: new ModelRouterEmbeddingModel('openai/text-embedding-3-small'),
38
+ })
39
+
40
+ // 4. Store in vector database
41
+ const pgVector = new PgVector({
42
+ id: 'pg-vector',
43
+ connectionString: process.env.POSTGRES_CONNECTION_STRING,
44
+ })
45
+ await pgVector.upsert({
46
+ indexName: 'embeddings',
47
+ vectors: embeddings,
48
+ }) // using an index name of 'embeddings'
49
+
50
+ // 5. Query similar chunks
51
+ const results = await pgVector.query({
52
+ indexName: 'embeddings',
53
+ queryVector: queryVector,
54
+ topK: 3,
55
+ }) // queryVector is the embedding of the query
56
+
57
+ console.log('Similar chunks:', results)
58
+ ```
59
+
60
+ This example shows the essentials: initialize a document, create chunks, generate embeddings, store them, and query for similar content.
61
+
62
+ ## Document Processing
63
+
64
+ The basic building block of RAG is document processing. Documents can be chunked using various strategies (recursive, sliding window, etc.) and enriched with metadata. See the [chunking and embedding doc](https://mastra.ai/docs/rag/chunking-and-embedding).
65
+
66
+ ## Vector Storage
67
+
68
+ Mastra supports multiple vector stores for embedding persistence and similarity search, including pgvector, Pinecone, Qdrant, and MongoDB. See the [vector database doc](https://mastra.ai/docs/rag/vector-databases).
69
+
70
+ ## More resources
71
+
72
+ - [Chain of Thought RAG Example](https://github.com/mastra-ai/mastra/tree/main/examples/basics/rag/cot-rag)
@@ -0,0 +1,515 @@
1
+ # Retrieval in RAG Systems
2
+
3
+ After storing embeddings, you need to retrieve relevant chunks to answer user queries.
4
+
5
+ Mastra provides flexible retrieval options with support for semantic search, filtering, and re-ranking.
6
+
7
+ ## How Retrieval Works
8
+
9
+ 1. The user's query is converted to an embedding using the same model used for document embeddings
10
+ 2. This embedding is compared to stored embeddings using vector similarity
11
+ 3. The most similar chunks are retrieved and can be optionally:
12
+
13
+ - Filtered by metadata
14
+ - Re-ranked for better relevance
15
+ - Processed through a knowledge graph
16
+
17
+ ## Basic Retrieval
18
+
19
+ The simplest approach is direct semantic search. This method uses vector similarity to find chunks that are semantically similar to the query:
20
+
21
+ ```ts
22
+ import { embed } from 'ai'
23
+ import { PgVector } from '@mastra/pg'
24
+ import { ModelRouterEmbeddingModel } from '@mastra/core/llm'
25
+
26
+ // Convert query to embedding
27
+ const { embedding } = await embed({
28
+ value: 'What are the main points in the article?',
29
+ model: new ModelRouterEmbeddingModel('openai/text-embedding-3-small'),
30
+ })
31
+
32
+ // Query vector store
33
+ const pgVector = new PgVector({
34
+ id: 'pg-vector',
35
+ connectionString: process.env.POSTGRES_CONNECTION_STRING,
36
+ })
37
+ const results = await pgVector.query({
38
+ indexName: 'embeddings',
39
+ queryVector: embedding,
40
+ topK: 10,
41
+ })
42
+
43
+ // Display results
44
+ console.log(results)
45
+ ```
46
+
47
+ The `topK` parameter specifies the maximum number of most similar results to return from the vector search.
48
+
49
+ Results include both the text content and a similarity score:
50
+
51
+ ```ts
52
+ [
53
+ {
54
+ text: 'Climate change poses significant challenges...',
55
+ score: 0.89,
56
+ metadata: { source: 'article1.txt' },
57
+ },
58
+ {
59
+ text: 'Rising temperatures affect crop yields...',
60
+ score: 0.82,
61
+ metadata: { source: 'article1.txt' },
62
+ },
63
+ ]
64
+ ```
65
+
66
+ ## Advanced Retrieval options
67
+
68
+ ### Metadata Filtering
69
+
70
+ Filter results based on metadata fields to narrow down the search space. This approach - combining vector similarity search with metadata filters - is sometimes called hybrid vector search, as it merges semantic search with structured filtering criteria.
71
+
72
+ This is useful when you have documents from different sources, time periods, or with specific attributes. Mastra provides a unified MongoDB-style query syntax that works across all supported vector stores.
73
+
74
+ For detailed information about available operators and syntax, see the [Metadata Filters Reference](https://mastra.ai/reference/rag/metadata-filters).
75
+
76
+ Basic filtering examples:
77
+
78
+ ```ts
79
+ // Simple equality filter
80
+ const results = await pgVector.query({
81
+ indexName: 'embeddings',
82
+ queryVector: embedding,
83
+ topK: 10,
84
+ filter: {
85
+ source: 'article1.txt',
86
+ },
87
+ })
88
+
89
+ // Numeric comparison
90
+ const results = await pgVector.query({
91
+ indexName: 'embeddings',
92
+ queryVector: embedding,
93
+ topK: 10,
94
+ filter: {
95
+ price: { $gt: 100 },
96
+ },
97
+ })
98
+
99
+ // Multiple conditions
100
+ const results = await pgVector.query({
101
+ indexName: 'embeddings',
102
+ queryVector: embedding,
103
+ topK: 10,
104
+ filter: {
105
+ category: 'electronics',
106
+ price: { $lt: 1000 },
107
+ inStock: true,
108
+ },
109
+ })
110
+
111
+ // Array operations
112
+ const results = await pgVector.query({
113
+ indexName: 'embeddings',
114
+ queryVector: embedding,
115
+ topK: 10,
116
+ filter: {
117
+ tags: { $in: ['sale', 'new'] },
118
+ },
119
+ })
120
+
121
+ // Logical operators
122
+ const results = await pgVector.query({
123
+ indexName: 'embeddings',
124
+ queryVector: embedding,
125
+ topK: 10,
126
+ filter: {
127
+ $or: [{ category: 'electronics' }, { category: 'accessories' }],
128
+ $and: [{ price: { $gt: 50 } }, { price: { $lt: 200 } }],
129
+ },
130
+ })
131
+ ```
132
+
133
+ Common use cases for metadata filtering:
134
+
135
+ - Filter by document source or type
136
+ - Filter by date ranges
137
+ - Filter by specific categories or tags
138
+ - Filter by numerical ranges (e.g., price, rating)
139
+ - Combine multiple conditions for precise querying
140
+ - Filter by document attributes (e.g., language, author)
141
+
142
+ ### Vector Query Tool
143
+
144
+ Sometimes you want to give your agent the ability to query a vector database directly. The Vector Query Tool allows your agent to be in charge of retrieval decisions, combining semantic search with optional filtering and reranking based on the agent's understanding of the user's needs.
145
+
146
+ ```ts
147
+ import { createVectorQueryTool } from '@mastra/rag'
148
+ import { ModelRouterEmbeddingModel } from '@mastra/core/llm'
149
+
150
+ const vectorQueryTool = createVectorQueryTool({
151
+ vectorStoreName: 'pgVector',
152
+ indexName: 'embeddings',
153
+ model: new ModelRouterEmbeddingModel('openai/text-embedding-3-small'),
154
+ })
155
+ ```
156
+
157
+ When creating the tool, pay special attention to the tool's name and description - these help the agent understand when and how to use the retrieval capabilities. For example, you might name it "SearchKnowledgeBase" and describe it as "Search through our documentation to find relevant information about X topic."
158
+
159
+ This is particularly useful when:
160
+
161
+ - Your agent needs to dynamically decide what information to retrieve
162
+ - The retrieval process requires complex decision-making
163
+ - You want the agent to combine multiple retrieval strategies based on context
164
+
165
+ #### Database-Specific Configurations
166
+
167
+ The Vector Query Tool supports database-specific configurations that enable you to leverage unique features and optimizations of different vector stores.
168
+
169
+ > **Note:** These configurations are for **query-time options** like namespaces, performance tuning, and filtering—not for database connection setup.
170
+ >
171
+ > Connection credentials (URLs, auth tokens) are configured when you instantiate the vector store class (e.g., `new LibSQLVector({ url: '...' })`).
172
+
173
+ ```ts
174
+ import { createVectorQueryTool } from '@mastra/rag'
175
+ import { ModelRouterEmbeddingModel } from '@mastra/core/llm'
176
+
177
+ // Pinecone with namespace
178
+ const pineconeQueryTool = createVectorQueryTool({
179
+ vectorStoreName: 'pinecone',
180
+ indexName: 'docs',
181
+ model: new ModelRouterEmbeddingModel('openai/text-embedding-3-small'),
182
+ databaseConfig: {
183
+ pinecone: {
184
+ namespace: 'production', // Isolate data by environment
185
+ },
186
+ },
187
+ })
188
+
189
+ // pgVector with performance tuning
190
+ const pgVectorQueryTool = createVectorQueryTool({
191
+ vectorStoreName: 'postgres',
192
+ indexName: 'embeddings',
193
+ model: new ModelRouterEmbeddingModel('openai/text-embedding-3-small'),
194
+ databaseConfig: {
195
+ pgvector: {
196
+ minScore: 0.7, // Filter low-quality results
197
+ ef: 200, // HNSW search parameter
198
+ probes: 10, // IVFFlat probe parameter
199
+ },
200
+ },
201
+ })
202
+
203
+ // Chroma with advanced filtering
204
+ const chromaQueryTool = createVectorQueryTool({
205
+ vectorStoreName: 'chroma',
206
+ indexName: 'documents',
207
+ model: new ModelRouterEmbeddingModel('openai/text-embedding-3-small'),
208
+ databaseConfig: {
209
+ chroma: {
210
+ where: { category: 'technical' },
211
+ whereDocument: { $contains: 'API' },
212
+ },
213
+ },
214
+ })
215
+
216
+ // LanceDB with table specificity
217
+ const lanceQueryTool = createVectorQueryTool({
218
+ vectorStoreName: 'lance',
219
+ indexName: 'documents',
220
+ model: new ModelRouterEmbeddingModel('openai/text-embedding-3-small'),
221
+ databaseConfig: {
222
+ lance: {
223
+ tableName: 'myVectors', // Specify which table to query
224
+ includeAllColumns: true, // Include all metadata columns in results
225
+ },
226
+ },
227
+ })
228
+ ```
229
+
230
+ **Key Benefits:**
231
+
232
+ - **Pinecone namespaces**: Organize vectors by tenant, environment, or data type
233
+ - **pgVector optimization**: Control search accuracy and speed with ef/probes parameters
234
+ - **Quality filtering**: Set minimum similarity thresholds to improve result relevance
235
+ - **LanceDB tables**: Separate data into tables for better organization and performance
236
+ - **Runtime flexibility**: Override configurations dynamically based on context
237
+
238
+ **Common Use Cases:**
239
+
240
+ - Multi-tenant applications using Pinecone namespaces
241
+ - Performance optimization in high-load scenarios
242
+ - Environment-specific configurations (dev/staging/prod)
243
+ - Quality-gated search results
244
+ - Embedded, file-based vector storage with LanceDB for edge deployment scenarios
245
+
246
+ You can also override these configurations at runtime using the request context:
247
+
248
+ ```ts
249
+ import { RequestContext } from '@mastra/core/request-context'
250
+
251
+ const requestContext = new RequestContext()
252
+ requestContext.set('databaseConfig', {
253
+ pinecone: {
254
+ namespace: 'runtime-namespace',
255
+ },
256
+ })
257
+
258
+ await pineconeQueryTool.execute({ queryText: 'search query' }, { mastra, requestContext })
259
+ ```
260
+
261
+ For detailed configuration options and advanced usage, see the [Vector Query Tool Reference](https://mastra.ai/reference/tools/vector-query-tool).
262
+
263
+ ### Vector Store Prompts
264
+
265
+ Vector store prompts define query patterns and filtering capabilities for each vector database implementation. When implementing filtering, these prompts are required in the agent's instructions to specify valid operators and syntax for each vector store implementation.
266
+
267
+ **pgVector**:
268
+
269
+ ```ts
270
+ import { PGVECTOR_PROMPT } from '@mastra/pg'
271
+
272
+ export const ragAgent = new Agent({
273
+ id: 'rag-agent',
274
+ name: 'RAG Agent',
275
+ model: 'openai/gpt-5.1',
276
+ instructions: `
277
+ Process queries using the provided context. Structure responses to be concise and relevant.
278
+ ${PGVECTOR_PROMPT}
279
+ `,
280
+ tools: { vectorQueryTool },
281
+ })
282
+ ```
283
+
284
+ **Pinecone**:
285
+
286
+ ```ts
287
+ import { PINECONE_PROMPT } from '@mastra/pinecone'
288
+
289
+ export const ragAgent = new Agent({
290
+ id: 'rag-agent',
291
+ name: 'RAG Agent',
292
+ model: 'openai/gpt-5.1',
293
+ instructions: `
294
+ Process queries using the provided context. Structure responses to be concise and relevant.
295
+ ${PINECONE_PROMPT}
296
+ `,
297
+ tools: { vectorQueryTool },
298
+ })
299
+ ```
300
+
301
+ **Qdrant**:
302
+
303
+ ```ts
304
+ import { QDRANT_PROMPT } from '@mastra/qdrant'
305
+
306
+ export const ragAgent = new Agent({
307
+ id: 'rag-agent',
308
+ name: 'RAG Agent',
309
+ model: 'openai/gpt-5.1',
310
+ instructions: `
311
+ Process queries using the provided context. Structure responses to be concise and relevant.
312
+ ${QDRANT_PROMPT}
313
+ `,
314
+ tools: { vectorQueryTool },
315
+ })
316
+ ```
317
+
318
+ **Chroma**:
319
+
320
+ ```ts
321
+ import { CHROMA_PROMPT } from '@mastra/chroma'
322
+
323
+ export const ragAgent = new Agent({
324
+ id: 'rag-agent',
325
+ name: 'RAG Agent',
326
+ model: 'openai/gpt-5.1',
327
+ instructions: `
328
+ Process queries using the provided context. Structure responses to be concise and relevant.
329
+ ${CHROMA_PROMPT}
330
+ `,
331
+ tools: { vectorQueryTool },
332
+ })
333
+ ```
334
+
335
+ **Astra**:
336
+
337
+ ```ts
338
+ import { ASTRA_PROMPT } from '@mastra/astra'
339
+
340
+ export const ragAgent = new Agent({
341
+ id: 'rag-agent',
342
+ name: 'RAG Agent',
343
+ model: 'openai/gpt-5.1',
344
+ instructions: `
345
+ Process queries using the provided context. Structure responses to be concise and relevant.
346
+ ${ASTRA_PROMPT}
347
+ `,
348
+ tools: { vectorQueryTool },
349
+ })
350
+ ```
351
+
352
+ **libSQL**:
353
+
354
+ ```ts
355
+ import { LIBSQL_PROMPT } from '@mastra/libsql'
356
+
357
+ export const ragAgent = new Agent({
358
+ id: 'rag-agent',
359
+ name: 'RAG Agent',
360
+ model: 'openai/gpt-5.1',
361
+ instructions: `
362
+ Process queries using the provided context. Structure responses to be concise and relevant.
363
+ ${LIBSQL_PROMPT}
364
+ `,
365
+ tools: { vectorQueryTool },
366
+ })
367
+ ```
368
+
369
+ **Upstash**:
370
+
371
+ ```ts
372
+ import { UPSTASH_PROMPT } from '@mastra/upstash'
373
+
374
+ export const ragAgent = new Agent({
375
+ id: 'rag-agent',
376
+ name: 'RAG Agent',
377
+ model: 'openai/gpt-5.1',
378
+ instructions: `
379
+ Process queries using the provided context. Structure responses to be concise and relevant.
380
+ ${UPSTASH_PROMPT}
381
+ `,
382
+ tools: { vectorQueryTool },
383
+ })
384
+ ```
385
+
386
+ **Vectorize**:
387
+
388
+ ```ts
389
+ import { VECTORIZE_PROMPT } from '@mastra/vectorize'
390
+
391
+ export const ragAgent = new Agent({
392
+ id: 'rag-agent',
393
+ name: 'RAG Agent',
394
+ model: 'openai/gpt-5.1',
395
+ instructions: `
396
+ Process queries using the provided context. Structure responses to be concise and relevant.
397
+ ${VECTORIZE_PROMPT}
398
+ `,
399
+ tools: { vectorQueryTool },
400
+ })
401
+ ```
402
+
403
+ **MongoDB**:
404
+
405
+ ```ts
406
+ import { MONGODB_PROMPT } from '@mastra/mongodb'
407
+
408
+ export const ragAgent = new Agent({
409
+ id: 'rag-agent',
410
+ name: 'RAG Agent',
411
+ model: 'openai/gpt-5.1',
412
+ instructions: `
413
+ Process queries using the provided context. Structure responses to be concise and relevant.
414
+ ${MONGODB_PROMPT}
415
+ `,
416
+ tools: { vectorQueryTool },
417
+ })
418
+ ```
419
+
420
+ **OpenSearch**:
421
+
422
+ ```ts
423
+ import { OPENSEARCH_PROMPT } from '@mastra/opensearch'
424
+
425
+ export const ragAgent = new Agent({
426
+ id: 'rag-agent',
427
+ name: 'RAG Agent',
428
+ model: 'openai/gpt-5.1',
429
+ instructions: `
430
+ Process queries using the provided context. Structure responses to be concise and relevant.
431
+ ${OPENSEARCH_PROMPT}
432
+ `,
433
+ tools: { vectorQueryTool },
434
+ })
435
+ ```
436
+
437
+ **S3Vectors**:
438
+
439
+ ```ts
440
+ import { S3VECTORS_PROMPT } from '@mastra/s3vectors'
441
+
442
+ export const ragAgent = new Agent({
443
+ id: 'rag-agent',
444
+ name: 'RAG Agent',
445
+ model: 'openai/gpt-5.1',
446
+ instructions: `
447
+ Process queries using the provided context. Structure responses to be concise and relevant.
448
+ ${S3VECTORS_PROMPT}
449
+ `,
450
+ tools: { vectorQueryTool },
451
+ })
452
+ ```
453
+
454
+ ### Re-ranking
455
+
456
+ Initial vector similarity search can sometimes miss nuanced relevance. Re-ranking is a more computationally expensive process, but more accurate algorithm that improves results by:
457
+
458
+ - Considering word order and exact matches
459
+ - Applying more sophisticated relevance scoring
460
+ - Using a method called cross-attention between query and documents
461
+
462
+ Here's how to use re-ranking:
463
+
464
+ ```ts
465
+ import { rerankWithScorer as rerank, MastraAgentRelevanceScorer } from '@mastra/rag'
466
+
467
+ // Get initial results from vector search
468
+ const initialResults = await pgVector.query({
469
+ indexName: 'embeddings',
470
+ queryVector: queryEmbedding,
471
+ topK: 10,
472
+ })
473
+
474
+ // Create a relevance scorer
475
+ const relevanceProvider = new MastraAgentRelevanceScorer('relevance-scorer', 'openai/gpt-5.1')
476
+
477
+ // Re-rank the results
478
+ const rerankedResults = await rerank({
479
+ results: initialResults,
480
+ query,
481
+ scorer: relevanceProvider,
482
+ options: {
483
+ weights: {
484
+ semantic: 0.5, // How well the content matches the query semantically
485
+ vector: 0.3, // Original vector similarity score
486
+ position: 0.2, // Preserves original result ordering
487
+ },
488
+ topK: 10,
489
+ },
490
+ })
491
+ ```
492
+
493
+ The weights control how different factors influence the final ranking:
494
+
495
+ - `semantic`: Higher values prioritize semantic understanding and relevance to the query
496
+ - `vector`: Higher values favor the original vector similarity scores
497
+ - `position`: Higher values help maintain the original ordering of results
498
+
499
+ > **Note:** For semantic scoring to work properly during re-ranking, each result must include the text content in its `metadata.text` field.
500
+
501
+ You can also use other relevance score providers like Cohere or ZeroEntropy:
502
+
503
+ ```ts
504
+ const relevanceProvider = new CohereRelevanceScorer('rerank-v3.5')
505
+ ```
506
+
507
+ ```ts
508
+ const relevanceProvider = new ZeroEntropyRelevanceScorer('zerank-1')
509
+ ```
510
+
511
+ The re-ranked results combine vector similarity with semantic understanding to improve retrieval quality.
512
+
513
+ For more details about re-ranking, see the [rerank()](https://mastra.ai/reference/rag/rerankWithScorer) method.
514
+
515
+ For graph-based retrieval that follows connections between chunks, see the [GraphRAG](https://mastra.ai/docs/rag/graph-rag) documentation.