@mastra/mcp-docs-server 1.1.4 → 1.1.5-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.
- package/CHANGELOG.md +7 -0
- package/package.json +3 -3
- package/.docs/docs/agents/adding-voice.md +0 -353
- package/.docs/docs/agents/agent-approval.md +0 -377
- package/.docs/docs/agents/agent-memory.md +0 -212
- package/.docs/docs/agents/guardrails.md +0 -382
- package/.docs/docs/agents/network-approval.md +0 -275
- package/.docs/docs/agents/networks.md +0 -290
- package/.docs/docs/agents/overview.md +0 -309
- package/.docs/docs/agents/processors.md +0 -632
- package/.docs/docs/agents/structured-output.md +0 -271
- package/.docs/docs/agents/using-tools.md +0 -214
- package/.docs/docs/build-with-ai/mcp-docs-server.md +0 -241
- package/.docs/docs/build-with-ai/skills.md +0 -35
- package/.docs/docs/community/contributing-templates.md +0 -3
- package/.docs/docs/community/discord.md +0 -9
- package/.docs/docs/community/licensing.md +0 -66
- package/.docs/docs/deployment/cloud-providers.md +0 -15
- package/.docs/docs/deployment/mastra-server.md +0 -122
- package/.docs/docs/deployment/monorepo.md +0 -142
- package/.docs/docs/deployment/overview.md +0 -62
- package/.docs/docs/deployment/studio.md +0 -234
- package/.docs/docs/deployment/web-framework.md +0 -52
- package/.docs/docs/deployment/workflow-runners.md +0 -9
- package/.docs/docs/evals/built-in-scorers.md +0 -47
- package/.docs/docs/evals/custom-scorers.md +0 -519
- package/.docs/docs/evals/overview.md +0 -146
- package/.docs/docs/evals/running-in-ci.md +0 -106
- package/.docs/docs/getting-started/build-with-ai.md +0 -68
- package/.docs/docs/getting-started/manual-install.md +0 -226
- package/.docs/docs/getting-started/project-structure.md +0 -60
- package/.docs/docs/getting-started/start.md +0 -28
- package/.docs/docs/getting-started/studio.md +0 -101
- package/.docs/docs/index.md +0 -43
- package/.docs/docs/mastra-cloud/deployment.md +0 -77
- package/.docs/docs/mastra-cloud/observability.md +0 -38
- package/.docs/docs/mastra-cloud/overview.md +0 -23
- package/.docs/docs/mastra-cloud/setup.md +0 -42
- package/.docs/docs/mastra-cloud/studio.md +0 -24
- package/.docs/docs/mcp/overview.md +0 -370
- package/.docs/docs/mcp/publishing-mcp-server.md +0 -95
- package/.docs/docs/memory/memory-processors.md +0 -316
- package/.docs/docs/memory/message-history.md +0 -260
- package/.docs/docs/memory/observational-memory.md +0 -246
- package/.docs/docs/memory/overview.md +0 -45
- package/.docs/docs/memory/semantic-recall.md +0 -272
- package/.docs/docs/memory/storage.md +0 -261
- package/.docs/docs/memory/working-memory.md +0 -400
- package/.docs/docs/observability/datasets/overview.md +0 -188
- package/.docs/docs/observability/datasets/running-experiments.md +0 -266
- package/.docs/docs/observability/logging.md +0 -99
- package/.docs/docs/observability/overview.md +0 -70
- package/.docs/docs/observability/tracing/bridges/otel.md +0 -209
- package/.docs/docs/observability/tracing/exporters/arize.md +0 -274
- package/.docs/docs/observability/tracing/exporters/braintrust.md +0 -111
- package/.docs/docs/observability/tracing/exporters/cloud.md +0 -129
- package/.docs/docs/observability/tracing/exporters/datadog.md +0 -187
- package/.docs/docs/observability/tracing/exporters/default.md +0 -211
- package/.docs/docs/observability/tracing/exporters/laminar.md +0 -100
- package/.docs/docs/observability/tracing/exporters/langfuse.md +0 -217
- package/.docs/docs/observability/tracing/exporters/langsmith.md +0 -202
- package/.docs/docs/observability/tracing/exporters/otel.md +0 -479
- package/.docs/docs/observability/tracing/exporters/posthog.md +0 -148
- package/.docs/docs/observability/tracing/exporters/sentry.md +0 -208
- package/.docs/docs/observability/tracing/overview.md +0 -1114
- package/.docs/docs/observability/tracing/processors/sensitive-data-filter.md +0 -303
- package/.docs/docs/rag/chunking-and-embedding.md +0 -183
- package/.docs/docs/rag/graph-rag.md +0 -215
- package/.docs/docs/rag/overview.md +0 -72
- package/.docs/docs/rag/retrieval.md +0 -521
- package/.docs/docs/rag/vector-databases.md +0 -648
- package/.docs/docs/server/auth/auth0.md +0 -222
- package/.docs/docs/server/auth/better-auth.md +0 -203
- package/.docs/docs/server/auth/clerk.md +0 -132
- package/.docs/docs/server/auth/composite-auth.md +0 -234
- package/.docs/docs/server/auth/custom-auth-provider.md +0 -513
- package/.docs/docs/server/auth/firebase.md +0 -272
- package/.docs/docs/server/auth/jwt.md +0 -110
- package/.docs/docs/server/auth/simple-auth.md +0 -178
- package/.docs/docs/server/auth/supabase.md +0 -117
- package/.docs/docs/server/auth/workos.md +0 -190
- package/.docs/docs/server/auth.md +0 -38
- package/.docs/docs/server/custom-adapters.md +0 -374
- package/.docs/docs/server/custom-api-routes.md +0 -267
- package/.docs/docs/server/mastra-client.md +0 -243
- package/.docs/docs/server/mastra-server.md +0 -71
- package/.docs/docs/server/middleware.md +0 -228
- package/.docs/docs/server/request-context.md +0 -478
- package/.docs/docs/server/server-adapters.md +0 -547
- package/.docs/docs/streaming/events.md +0 -247
- package/.docs/docs/streaming/overview.md +0 -181
- package/.docs/docs/streaming/tool-streaming.md +0 -178
- package/.docs/docs/streaming/workflow-streaming.md +0 -109
- package/.docs/docs/voice/overview.md +0 -979
- package/.docs/docs/voice/speech-to-speech.md +0 -103
- package/.docs/docs/voice/speech-to-text.md +0 -80
- package/.docs/docs/voice/text-to-speech.md +0 -84
- package/.docs/docs/workflows/agents-and-tools.md +0 -170
- package/.docs/docs/workflows/control-flow.md +0 -823
- package/.docs/docs/workflows/error-handling.md +0 -360
- package/.docs/docs/workflows/human-in-the-loop.md +0 -213
- package/.docs/docs/workflows/overview.md +0 -372
- package/.docs/docs/workflows/snapshots.md +0 -238
- package/.docs/docs/workflows/suspend-and-resume.md +0 -205
- package/.docs/docs/workflows/time-travel.md +0 -309
- package/.docs/docs/workflows/workflow-state.md +0 -181
- package/.docs/docs/workspace/filesystem.md +0 -162
- package/.docs/docs/workspace/overview.md +0 -239
- package/.docs/docs/workspace/sandbox.md +0 -63
- package/.docs/docs/workspace/search.md +0 -219
- package/.docs/docs/workspace/skills.md +0 -126
- package/.docs/guides/agent-frameworks/ai-sdk.md +0 -140
- package/.docs/guides/build-your-ui/ai-sdk-ui.md +0 -1463
- package/.docs/guides/build-your-ui/assistant-ui.md +0 -156
- package/.docs/guides/build-your-ui/copilotkit.md +0 -292
- package/.docs/guides/deployment/amazon-ec2.md +0 -130
- package/.docs/guides/deployment/aws-lambda.md +0 -248
- package/.docs/guides/deployment/azure-app-services.md +0 -114
- package/.docs/guides/deployment/cloudflare.md +0 -99
- package/.docs/guides/deployment/digital-ocean.md +0 -168
- package/.docs/guides/deployment/inngest.md +0 -685
- package/.docs/guides/deployment/netlify.md +0 -77
- package/.docs/guides/deployment/vercel.md +0 -101
- package/.docs/guides/getting-started/astro.md +0 -408
- package/.docs/guides/getting-started/electron.md +0 -504
- package/.docs/guides/getting-started/express.md +0 -251
- package/.docs/guides/getting-started/hono.md +0 -191
- package/.docs/guides/getting-started/next-js.md +0 -355
- package/.docs/guides/getting-started/nuxt.md +0 -476
- package/.docs/guides/getting-started/quickstart.md +0 -67
- package/.docs/guides/getting-started/sveltekit.md +0 -300
- package/.docs/guides/getting-started/vite-react.md +0 -439
- package/.docs/guides/guide/ai-recruiter.md +0 -227
- package/.docs/guides/guide/chef-michel.md +0 -215
- package/.docs/guides/guide/code-review-bot.md +0 -221
- package/.docs/guides/guide/dev-assistant.md +0 -304
- package/.docs/guides/guide/docs-manager.md +0 -238
- package/.docs/guides/guide/github-actions-pr-description.md +0 -236
- package/.docs/guides/guide/notes-mcp-server.md +0 -425
- package/.docs/guides/guide/research-assistant.md +0 -349
- package/.docs/guides/guide/stock-agent.md +0 -134
- package/.docs/guides/guide/web-search.md +0 -326
- package/.docs/guides/guide/whatsapp-chat-bot.md +0 -416
- package/.docs/guides/index.md +0 -3
- package/.docs/guides/migrations/agentnetwork.md +0 -101
- package/.docs/guides/migrations/ai-sdk-v4-to-v5.md +0 -112
- package/.docs/guides/migrations/upgrade-to-v1/agent.md +0 -404
- package/.docs/guides/migrations/upgrade-to-v1/cli.md +0 -57
- package/.docs/guides/migrations/upgrade-to-v1/client.md +0 -337
- package/.docs/guides/migrations/upgrade-to-v1/deployment.md +0 -37
- package/.docs/guides/migrations/upgrade-to-v1/evals.md +0 -239
- package/.docs/guides/migrations/upgrade-to-v1/mastra.md +0 -143
- package/.docs/guides/migrations/upgrade-to-v1/mcp.md +0 -97
- package/.docs/guides/migrations/upgrade-to-v1/memory.md +0 -285
- package/.docs/guides/migrations/upgrade-to-v1/overview.md +0 -119
- package/.docs/guides/migrations/upgrade-to-v1/processors.md +0 -68
- package/.docs/guides/migrations/upgrade-to-v1/rag.md +0 -42
- package/.docs/guides/migrations/upgrade-to-v1/storage.md +0 -553
- package/.docs/guides/migrations/upgrade-to-v1/tools.md +0 -180
- package/.docs/guides/migrations/upgrade-to-v1/tracing.md +0 -417
- package/.docs/guides/migrations/upgrade-to-v1/vectors.md +0 -87
- package/.docs/guides/migrations/upgrade-to-v1/voice.md +0 -30
- package/.docs/guides/migrations/upgrade-to-v1/workflows.md +0 -341
- package/.docs/guides/migrations/vnext-to-standard-apis.md +0 -364
- package/.docs/models/embeddings.md +0 -161
- package/.docs/models/gateways/azure-openai.md +0 -128
- package/.docs/models/gateways/custom-gateways.md +0 -545
- package/.docs/models/gateways/netlify.md +0 -88
- package/.docs/models/gateways/openrouter.md +0 -219
- package/.docs/models/gateways/vercel.md +0 -225
- package/.docs/models/gateways.md +0 -14
- package/.docs/models/index.md +0 -286
- package/.docs/models/providers/302ai.md +0 -134
- package/.docs/models/providers/abacus.md +0 -125
- package/.docs/models/providers/agentrouter.md +0 -90
- package/.docs/models/providers/aihubmix.md +0 -107
- package/.docs/models/providers/alibaba-cn.md +0 -135
- package/.docs/models/providers/alibaba.md +0 -111
- package/.docs/models/providers/amazon-bedrock.md +0 -33
- package/.docs/models/providers/anthropic.md +0 -153
- package/.docs/models/providers/azure.md +0 -33
- package/.docs/models/providers/bailing.md +0 -72
- package/.docs/models/providers/baseten.md +0 -77
- package/.docs/models/providers/berget.md +0 -78
- package/.docs/models/providers/cerebras.md +0 -101
- package/.docs/models/providers/chutes.md +0 -136
- package/.docs/models/providers/cloudflare-ai-gateway.md +0 -33
- package/.docs/models/providers/cloudflare-workers-ai.md +0 -109
- package/.docs/models/providers/cohere.md +0 -33
- package/.docs/models/providers/cortecs.md +0 -91
- package/.docs/models/providers/deepinfra.md +0 -112
- package/.docs/models/providers/deepseek.md +0 -88
- package/.docs/models/providers/fastrouter.md +0 -84
- package/.docs/models/providers/fireworks-ai.md +0 -89
- package/.docs/models/providers/firmware.md +0 -85
- package/.docs/models/providers/friendli.md +0 -78
- package/.docs/models/providers/github-models.md +0 -125
- package/.docs/models/providers/google-vertex.md +0 -33
- package/.docs/models/providers/google.md +0 -159
- package/.docs/models/providers/groq.md +0 -107
- package/.docs/models/providers/helicone.md +0 -161
- package/.docs/models/providers/huggingface.md +0 -90
- package/.docs/models/providers/iflowcn.md +0 -84
- package/.docs/models/providers/inception.md +0 -72
- package/.docs/models/providers/inference.md +0 -79
- package/.docs/models/providers/io-intelligence.md +0 -87
- package/.docs/models/providers/io-net.md +0 -87
- package/.docs/models/providers/jiekou.md +0 -131
- package/.docs/models/providers/kilo.md +0 -333
- package/.docs/models/providers/kimi-for-coding.md +0 -100
- package/.docs/models/providers/kuae-cloud-coding-plan.md +0 -71
- package/.docs/models/providers/llama.md +0 -77
- package/.docs/models/providers/lmstudio.md +0 -73
- package/.docs/models/providers/lucidquery.md +0 -72
- package/.docs/models/providers/minimax-cn-coding-plan.md +0 -102
- package/.docs/models/providers/minimax-cn.md +0 -102
- package/.docs/models/providers/minimax-coding-plan.md +0 -102
- package/.docs/models/providers/minimax.md +0 -104
- package/.docs/models/providers/mistral.md +0 -124
- package/.docs/models/providers/moark.md +0 -72
- package/.docs/models/providers/modelscope.md +0 -77
- package/.docs/models/providers/moonshotai-cn.md +0 -76
- package/.docs/models/providers/moonshotai.md +0 -76
- package/.docs/models/providers/morph.md +0 -73
- package/.docs/models/providers/nano-gpt.md +0 -103
- package/.docs/models/providers/nebius.md +0 -116
- package/.docs/models/providers/nova.md +0 -72
- package/.docs/models/providers/novita-ai.md +0 -154
- package/.docs/models/providers/nvidia.md +0 -141
- package/.docs/models/providers/ollama-cloud.md +0 -103
- package/.docs/models/providers/ollama.md +0 -33
- package/.docs/models/providers/openai.md +0 -193
- package/.docs/models/providers/opencode.md +0 -100
- package/.docs/models/providers/ovhcloud.md +0 -83
- package/.docs/models/providers/perplexity.md +0 -100
- package/.docs/models/providers/poe.md +0 -183
- package/.docs/models/providers/privatemode-ai.md +0 -75
- package/.docs/models/providers/requesty.md +0 -90
- package/.docs/models/providers/scaleway.md +0 -84
- package/.docs/models/providers/siliconflow-cn.md +0 -138
- package/.docs/models/providers/siliconflow.md +0 -140
- package/.docs/models/providers/stackit.md +0 -78
- package/.docs/models/providers/stepfun.md +0 -73
- package/.docs/models/providers/submodel.md +0 -79
- package/.docs/models/providers/synthetic.md +0 -96
- package/.docs/models/providers/togetherai.md +0 -115
- package/.docs/models/providers/upstage.md +0 -73
- package/.docs/models/providers/venice.md +0 -95
- package/.docs/models/providers/vivgrid.md +0 -106
- package/.docs/models/providers/vultr.md +0 -75
- package/.docs/models/providers/wandb.md +0 -80
- package/.docs/models/providers/xai.md +0 -141
- package/.docs/models/providers/xiaomi.md +0 -71
- package/.docs/models/providers/zai-coding-plan.md +0 -80
- package/.docs/models/providers/zai.md +0 -79
- package/.docs/models/providers/zenmux.md +0 -161
- package/.docs/models/providers/zhipuai-coding-plan.md +0 -79
- package/.docs/models/providers/zhipuai.md +0 -79
- package/.docs/models/providers.md +0 -81
- package/.docs/reference/agents/agent.md +0 -142
- package/.docs/reference/agents/generate.md +0 -174
- package/.docs/reference/agents/generateLegacy.md +0 -176
- package/.docs/reference/agents/getDefaultGenerateOptions.md +0 -36
- package/.docs/reference/agents/getDefaultOptions.md +0 -34
- package/.docs/reference/agents/getDefaultStreamOptions.md +0 -36
- package/.docs/reference/agents/getDescription.md +0 -21
- package/.docs/reference/agents/getInstructions.md +0 -34
- package/.docs/reference/agents/getLLM.md +0 -37
- package/.docs/reference/agents/getMemory.md +0 -34
- package/.docs/reference/agents/getModel.md +0 -34
- package/.docs/reference/agents/getTools.md +0 -29
- package/.docs/reference/agents/getVoice.md +0 -34
- package/.docs/reference/agents/listAgents.md +0 -35
- package/.docs/reference/agents/listScorers.md +0 -34
- package/.docs/reference/agents/listTools.md +0 -34
- package/.docs/reference/agents/listWorkflows.md +0 -34
- package/.docs/reference/agents/network.md +0 -134
- package/.docs/reference/ai-sdk/chat-route.md +0 -82
- package/.docs/reference/ai-sdk/handle-chat-stream.md +0 -53
- package/.docs/reference/ai-sdk/handle-network-stream.md +0 -37
- package/.docs/reference/ai-sdk/handle-workflow-stream.md +0 -55
- package/.docs/reference/ai-sdk/network-route.md +0 -74
- package/.docs/reference/ai-sdk/to-ai-sdk-stream.md +0 -232
- package/.docs/reference/ai-sdk/to-ai-sdk-v4-messages.md +0 -79
- package/.docs/reference/ai-sdk/to-ai-sdk-v5-messages.md +0 -73
- package/.docs/reference/ai-sdk/with-mastra.md +0 -59
- package/.docs/reference/ai-sdk/workflow-route.md +0 -79
- package/.docs/reference/auth/auth0.md +0 -73
- package/.docs/reference/auth/better-auth.md +0 -71
- package/.docs/reference/auth/clerk.md +0 -36
- package/.docs/reference/auth/firebase.md +0 -80
- package/.docs/reference/auth/jwt.md +0 -26
- package/.docs/reference/auth/supabase.md +0 -33
- package/.docs/reference/auth/workos.md +0 -84
- package/.docs/reference/cli/create-mastra.md +0 -137
- package/.docs/reference/cli/mastra.md +0 -336
- package/.docs/reference/client-js/agents.md +0 -438
- package/.docs/reference/client-js/error-handling.md +0 -16
- package/.docs/reference/client-js/logs.md +0 -24
- package/.docs/reference/client-js/mastra-client.md +0 -63
- package/.docs/reference/client-js/memory.md +0 -225
- package/.docs/reference/client-js/observability.md +0 -72
- package/.docs/reference/client-js/telemetry.md +0 -20
- package/.docs/reference/client-js/tools.md +0 -44
- package/.docs/reference/client-js/vectors.md +0 -79
- package/.docs/reference/client-js/workflows.md +0 -199
- package/.docs/reference/configuration.md +0 -749
- package/.docs/reference/core/addGateway.md +0 -42
- package/.docs/reference/core/getAgent.md +0 -21
- package/.docs/reference/core/getAgentById.md +0 -21
- package/.docs/reference/core/getDeployer.md +0 -22
- package/.docs/reference/core/getGateway.md +0 -38
- package/.docs/reference/core/getGatewayById.md +0 -41
- package/.docs/reference/core/getLogger.md +0 -22
- package/.docs/reference/core/getMCPServer.md +0 -45
- package/.docs/reference/core/getMCPServerById.md +0 -53
- package/.docs/reference/core/getMemory.md +0 -50
- package/.docs/reference/core/getScorer.md +0 -54
- package/.docs/reference/core/getScorerById.md +0 -54
- package/.docs/reference/core/getServer.md +0 -22
- package/.docs/reference/core/getStorage.md +0 -22
- package/.docs/reference/core/getStoredAgentById.md +0 -89
- package/.docs/reference/core/getTelemetry.md +0 -22
- package/.docs/reference/core/getVector.md +0 -22
- package/.docs/reference/core/getWorkflow.md +0 -40
- package/.docs/reference/core/listAgents.md +0 -21
- package/.docs/reference/core/listGateways.md +0 -40
- package/.docs/reference/core/listLogs.md +0 -38
- package/.docs/reference/core/listLogsByRunId.md +0 -36
- package/.docs/reference/core/listMCPServers.md +0 -51
- package/.docs/reference/core/listMemory.md +0 -56
- package/.docs/reference/core/listScorers.md +0 -29
- package/.docs/reference/core/listStoredAgents.md +0 -93
- package/.docs/reference/core/listVectors.md +0 -22
- package/.docs/reference/core/listWorkflows.md +0 -21
- package/.docs/reference/core/mastra-class.md +0 -66
- package/.docs/reference/core/mastra-model-gateway.md +0 -153
- package/.docs/reference/core/setLogger.md +0 -26
- package/.docs/reference/core/setStorage.md +0 -27
- package/.docs/reference/datasets/addItem.md +0 -35
- package/.docs/reference/datasets/addItems.md +0 -33
- package/.docs/reference/datasets/compareExperiments.md +0 -48
- package/.docs/reference/datasets/create.md +0 -49
- package/.docs/reference/datasets/dataset.md +0 -78
- package/.docs/reference/datasets/datasets-manager.md +0 -84
- package/.docs/reference/datasets/delete.md +0 -23
- package/.docs/reference/datasets/deleteExperiment.md +0 -25
- package/.docs/reference/datasets/deleteItem.md +0 -25
- package/.docs/reference/datasets/deleteItems.md +0 -27
- package/.docs/reference/datasets/get.md +0 -29
- package/.docs/reference/datasets/getDetails.md +0 -45
- package/.docs/reference/datasets/getExperiment.md +0 -28
- package/.docs/reference/datasets/getItem.md +0 -31
- package/.docs/reference/datasets/getItemHistory.md +0 -29
- package/.docs/reference/datasets/list.md +0 -29
- package/.docs/reference/datasets/listExperimentResults.md +0 -37
- package/.docs/reference/datasets/listExperiments.md +0 -31
- package/.docs/reference/datasets/listItems.md +0 -44
- package/.docs/reference/datasets/listVersions.md +0 -31
- package/.docs/reference/datasets/startExperiment.md +0 -60
- package/.docs/reference/datasets/startExperimentAsync.md +0 -41
- package/.docs/reference/datasets/update.md +0 -46
- package/.docs/reference/datasets/updateItem.md +0 -36
- package/.docs/reference/deployer/cloudflare.md +0 -79
- package/.docs/reference/deployer/netlify.md +0 -82
- package/.docs/reference/deployer/vercel.md +0 -91
- package/.docs/reference/deployer.md +0 -100
- package/.docs/reference/evals/answer-relevancy.md +0 -105
- package/.docs/reference/evals/answer-similarity.md +0 -99
- package/.docs/reference/evals/bias.md +0 -120
- package/.docs/reference/evals/completeness.md +0 -137
- package/.docs/reference/evals/content-similarity.md +0 -101
- package/.docs/reference/evals/context-precision.md +0 -196
- package/.docs/reference/evals/context-relevance.md +0 -536
- package/.docs/reference/evals/create-scorer.md +0 -270
- package/.docs/reference/evals/faithfulness.md +0 -114
- package/.docs/reference/evals/hallucination.md +0 -220
- package/.docs/reference/evals/keyword-coverage.md +0 -128
- package/.docs/reference/evals/mastra-scorer.md +0 -123
- package/.docs/reference/evals/noise-sensitivity.md +0 -685
- package/.docs/reference/evals/prompt-alignment.md +0 -619
- package/.docs/reference/evals/run-evals.md +0 -138
- package/.docs/reference/evals/scorer-utils.md +0 -330
- package/.docs/reference/evals/textual-difference.md +0 -113
- package/.docs/reference/evals/tone-consistency.md +0 -119
- package/.docs/reference/evals/tool-call-accuracy.md +0 -533
- package/.docs/reference/evals/toxicity.md +0 -123
- package/.docs/reference/harness/harness-class.md +0 -645
- package/.docs/reference/index.md +0 -276
- package/.docs/reference/logging/pino-logger.md +0 -117
- package/.docs/reference/memory/clone-utilities.md +0 -199
- package/.docs/reference/memory/cloneThread.md +0 -130
- package/.docs/reference/memory/createThread.md +0 -68
- package/.docs/reference/memory/deleteMessages.md +0 -40
- package/.docs/reference/memory/getThreadById.md +0 -24
- package/.docs/reference/memory/listThreads.md +0 -145
- package/.docs/reference/memory/memory-class.md +0 -147
- package/.docs/reference/memory/observational-memory.md +0 -565
- package/.docs/reference/memory/recall.md +0 -91
- package/.docs/reference/observability/tracing/bridges/otel.md +0 -131
- package/.docs/reference/observability/tracing/configuration.md +0 -178
- package/.docs/reference/observability/tracing/exporters/arize.md +0 -141
- package/.docs/reference/observability/tracing/exporters/braintrust.md +0 -93
- package/.docs/reference/observability/tracing/exporters/cloud-exporter.md +0 -163
- package/.docs/reference/observability/tracing/exporters/console-exporter.md +0 -138
- package/.docs/reference/observability/tracing/exporters/datadog.md +0 -116
- package/.docs/reference/observability/tracing/exporters/default-exporter.md +0 -174
- package/.docs/reference/observability/tracing/exporters/laminar.md +0 -78
- package/.docs/reference/observability/tracing/exporters/langfuse.md +0 -134
- package/.docs/reference/observability/tracing/exporters/langsmith.md +0 -110
- package/.docs/reference/observability/tracing/exporters/otel.md +0 -199
- package/.docs/reference/observability/tracing/exporters/posthog.md +0 -92
- package/.docs/reference/observability/tracing/exporters/sentry.md +0 -184
- package/.docs/reference/observability/tracing/instances.md +0 -109
- package/.docs/reference/observability/tracing/interfaces.md +0 -749
- package/.docs/reference/observability/tracing/processors/sensitive-data-filter.md +0 -144
- package/.docs/reference/observability/tracing/spans.md +0 -224
- package/.docs/reference/processors/batch-parts-processor.md +0 -61
- package/.docs/reference/processors/language-detector.md +0 -81
- package/.docs/reference/processors/message-history-processor.md +0 -85
- package/.docs/reference/processors/moderation-processor.md +0 -104
- package/.docs/reference/processors/pii-detector.md +0 -107
- package/.docs/reference/processors/processor-interface.md +0 -525
- package/.docs/reference/processors/prompt-injection-detector.md +0 -71
- package/.docs/reference/processors/semantic-recall-processor.md +0 -123
- package/.docs/reference/processors/system-prompt-scrubber.md +0 -80
- package/.docs/reference/processors/token-limiter-processor.md +0 -113
- package/.docs/reference/processors/tool-call-filter.md +0 -85
- package/.docs/reference/processors/tool-search-processor.md +0 -113
- package/.docs/reference/processors/unicode-normalizer.md +0 -62
- package/.docs/reference/processors/working-memory-processor.md +0 -154
- package/.docs/reference/rag/chunk.md +0 -221
- package/.docs/reference/rag/database-config.md +0 -264
- package/.docs/reference/rag/document.md +0 -114
- package/.docs/reference/rag/embeddings.md +0 -92
- package/.docs/reference/rag/extract-params.md +0 -168
- package/.docs/reference/rag/graph-rag.md +0 -111
- package/.docs/reference/rag/metadata-filters.md +0 -216
- package/.docs/reference/rag/rerank.md +0 -80
- package/.docs/reference/rag/rerankWithScorer.md +0 -80
- package/.docs/reference/server/create-route.md +0 -260
- package/.docs/reference/server/express-adapter.md +0 -176
- package/.docs/reference/server/fastify-adapter.md +0 -90
- package/.docs/reference/server/hono-adapter.md +0 -162
- package/.docs/reference/server/koa-adapter.md +0 -127
- package/.docs/reference/server/mastra-server.md +0 -298
- package/.docs/reference/server/register-api-route.md +0 -249
- package/.docs/reference/server/routes.md +0 -306
- package/.docs/reference/storage/cloudflare-d1.md +0 -218
- package/.docs/reference/storage/cloudflare.md +0 -88
- package/.docs/reference/storage/composite.md +0 -235
- package/.docs/reference/storage/convex.md +0 -161
- package/.docs/reference/storage/dynamodb.md +0 -282
- package/.docs/reference/storage/lance.md +0 -131
- package/.docs/reference/storage/libsql.md +0 -135
- package/.docs/reference/storage/mongodb.md +0 -262
- package/.docs/reference/storage/mssql.md +0 -155
- package/.docs/reference/storage/overview.md +0 -121
- package/.docs/reference/storage/postgresql.md +0 -529
- package/.docs/reference/storage/upstash.md +0 -160
- package/.docs/reference/streaming/ChunkType.md +0 -292
- package/.docs/reference/streaming/agents/MastraModelOutput.md +0 -182
- package/.docs/reference/streaming/agents/stream.md +0 -212
- package/.docs/reference/streaming/agents/streamLegacy.md +0 -142
- package/.docs/reference/streaming/workflows/observeStream.md +0 -42
- package/.docs/reference/streaming/workflows/resumeStream.md +0 -61
- package/.docs/reference/streaming/workflows/stream.md +0 -88
- package/.docs/reference/streaming/workflows/timeTravelStream.md +0 -142
- package/.docs/reference/templates/overview.md +0 -194
- package/.docs/reference/tools/create-tool.md +0 -237
- package/.docs/reference/tools/document-chunker-tool.md +0 -89
- package/.docs/reference/tools/graph-rag-tool.md +0 -185
- package/.docs/reference/tools/mcp-client.md +0 -962
- package/.docs/reference/tools/mcp-server.md +0 -1275
- package/.docs/reference/tools/vector-query-tool.md +0 -459
- package/.docs/reference/vectors/astra.md +0 -121
- package/.docs/reference/vectors/chroma.md +0 -267
- package/.docs/reference/vectors/convex.md +0 -303
- package/.docs/reference/vectors/couchbase.md +0 -226
- package/.docs/reference/vectors/duckdb.md +0 -318
- package/.docs/reference/vectors/elasticsearch.md +0 -189
- package/.docs/reference/vectors/lance.md +0 -220
- package/.docs/reference/vectors/libsql.md +0 -305
- package/.docs/reference/vectors/mongodb.md +0 -295
- package/.docs/reference/vectors/opensearch.md +0 -99
- package/.docs/reference/vectors/pg.md +0 -408
- package/.docs/reference/vectors/pinecone.md +0 -168
- package/.docs/reference/vectors/qdrant.md +0 -222
- package/.docs/reference/vectors/s3vectors.md +0 -277
- package/.docs/reference/vectors/turbopuffer.md +0 -157
- package/.docs/reference/vectors/upstash.md +0 -294
- package/.docs/reference/vectors/vectorize.md +0 -147
- package/.docs/reference/voice/azure.md +0 -148
- package/.docs/reference/voice/cloudflare.md +0 -83
- package/.docs/reference/voice/composite-voice.md +0 -121
- package/.docs/reference/voice/deepgram.md +0 -79
- package/.docs/reference/voice/elevenlabs.md +0 -98
- package/.docs/reference/voice/google-gemini-live.md +0 -378
- package/.docs/reference/voice/google.md +0 -228
- package/.docs/reference/voice/mastra-voice.md +0 -313
- package/.docs/reference/voice/murf.md +0 -122
- package/.docs/reference/voice/openai-realtime.md +0 -203
- package/.docs/reference/voice/openai.md +0 -88
- package/.docs/reference/voice/playai.md +0 -80
- package/.docs/reference/voice/sarvam.md +0 -126
- package/.docs/reference/voice/speechify.md +0 -75
- package/.docs/reference/voice/voice.addInstructions.md +0 -56
- package/.docs/reference/voice/voice.addTools.md +0 -67
- package/.docs/reference/voice/voice.answer.md +0 -54
- package/.docs/reference/voice/voice.close.md +0 -51
- package/.docs/reference/voice/voice.connect.md +0 -94
- package/.docs/reference/voice/voice.events.md +0 -37
- package/.docs/reference/voice/voice.getSpeakers.md +0 -129
- package/.docs/reference/voice/voice.listen.md +0 -164
- package/.docs/reference/voice/voice.off.md +0 -54
- package/.docs/reference/voice/voice.on.md +0 -111
- package/.docs/reference/voice/voice.send.md +0 -65
- package/.docs/reference/voice/voice.speak.md +0 -157
- package/.docs/reference/voice/voice.updateConfig.md +0 -60
- package/.docs/reference/workflows/run-methods/cancel.md +0 -86
- package/.docs/reference/workflows/run-methods/restart.md +0 -33
- package/.docs/reference/workflows/run-methods/resume.md +0 -59
- package/.docs/reference/workflows/run-methods/start.md +0 -58
- package/.docs/reference/workflows/run-methods/startAsync.md +0 -67
- package/.docs/reference/workflows/run-methods/timeTravel.md +0 -142
- package/.docs/reference/workflows/run.md +0 -59
- package/.docs/reference/workflows/step.md +0 -119
- package/.docs/reference/workflows/workflow-methods/branch.md +0 -25
- package/.docs/reference/workflows/workflow-methods/commit.md +0 -17
- package/.docs/reference/workflows/workflow-methods/create-run.md +0 -63
- package/.docs/reference/workflows/workflow-methods/dountil.md +0 -25
- package/.docs/reference/workflows/workflow-methods/dowhile.md +0 -25
- package/.docs/reference/workflows/workflow-methods/foreach.md +0 -118
- package/.docs/reference/workflows/workflow-methods/map.md +0 -93
- package/.docs/reference/workflows/workflow-methods/parallel.md +0 -21
- package/.docs/reference/workflows/workflow-methods/sleep.md +0 -35
- package/.docs/reference/workflows/workflow-methods/sleepUntil.md +0 -35
- package/.docs/reference/workflows/workflow-methods/then.md +0 -21
- package/.docs/reference/workflows/workflow.md +0 -157
- package/.docs/reference/workspace/e2b-sandbox.md +0 -288
- package/.docs/reference/workspace/filesystem.md +0 -202
- package/.docs/reference/workspace/gcs-filesystem.md +0 -170
- package/.docs/reference/workspace/local-filesystem.md +0 -327
- package/.docs/reference/workspace/local-sandbox.md +0 -285
- package/.docs/reference/workspace/s3-filesystem.md +0 -169
- package/.docs/reference/workspace/sandbox.md +0 -81
- package/.docs/reference/workspace/workspace-class.md +0 -226
|
@@ -1,202 +0,0 @@
|
|
|
1
|
-
# WorkspaceFilesystem
|
|
2
|
-
|
|
3
|
-
**Added in:** `@mastra/core@1.1.0`
|
|
4
|
-
|
|
5
|
-
The `WorkspaceFilesystem` interface defines how workspaces interact with file storage.
|
|
6
|
-
|
|
7
|
-
## Methods
|
|
8
|
-
|
|
9
|
-
### `readFile(path, options?)`
|
|
10
|
-
|
|
11
|
-
Read file contents.
|
|
12
|
-
|
|
13
|
-
```typescript
|
|
14
|
-
const content = await filesystem.readFile('/docs/guide.md');
|
|
15
|
-
const buffer = await filesystem.readFile('/image.png', { encoding: 'binary' });
|
|
16
|
-
```
|
|
17
|
-
|
|
18
|
-
**Parameters:**
|
|
19
|
-
|
|
20
|
-
**path:** (`string`): File path relative to basePath
|
|
21
|
-
|
|
22
|
-
**options.encoding?:** (`'utf-8' | 'binary'`): Text or binary encoding (Default: `'utf-8'`)
|
|
23
|
-
|
|
24
|
-
**Returns:** `Promise<string | Buffer>`
|
|
25
|
-
|
|
26
|
-
### `writeFile(path, content, options?)`
|
|
27
|
-
|
|
28
|
-
Write file contents.
|
|
29
|
-
|
|
30
|
-
```typescript
|
|
31
|
-
await filesystem.writeFile('/docs/new.md', '# New Document');
|
|
32
|
-
await filesystem.writeFile('/nested/path/file.md', content, { recursive: true });
|
|
33
|
-
```
|
|
34
|
-
|
|
35
|
-
**Parameters:**
|
|
36
|
-
|
|
37
|
-
**path:** (`string`): File path relative to basePath
|
|
38
|
-
|
|
39
|
-
**content:** (`string | Buffer`): File content
|
|
40
|
-
|
|
41
|
-
**options.recursive?:** (`boolean`): Create parent directories if they don't exist (Default: `false`)
|
|
42
|
-
|
|
43
|
-
**options.overwrite?:** (`boolean`): Overwrite existing file (Default: `true`)
|
|
44
|
-
|
|
45
|
-
### `deleteFile(path, options?)`
|
|
46
|
-
|
|
47
|
-
Delete a file.
|
|
48
|
-
|
|
49
|
-
```typescript
|
|
50
|
-
await filesystem.deleteFile('/docs/old.md');
|
|
51
|
-
await filesystem.deleteFile('/docs/maybe.md', { force: true }); // Don't throw if missing
|
|
52
|
-
```
|
|
53
|
-
|
|
54
|
-
**Parameters:**
|
|
55
|
-
|
|
56
|
-
**path:** (`string`): File path
|
|
57
|
-
|
|
58
|
-
**options.force?:** (`boolean`): Don't throw error if file doesn't exist (Default: `false`)
|
|
59
|
-
|
|
60
|
-
### `readdir(path, options?)`
|
|
61
|
-
|
|
62
|
-
List directory contents.
|
|
63
|
-
|
|
64
|
-
```typescript
|
|
65
|
-
const entries = await filesystem.readdir('/docs');
|
|
66
|
-
// [{ name: 'guide.md', type: 'file' }, { name: 'api', type: 'directory' }]
|
|
67
|
-
```
|
|
68
|
-
|
|
69
|
-
**Returns:** `Promise<FileEntry[]>`
|
|
70
|
-
|
|
71
|
-
```typescript
|
|
72
|
-
interface FileEntry {
|
|
73
|
-
name: string;
|
|
74
|
-
type: 'file' | 'directory';
|
|
75
|
-
size?: number;
|
|
76
|
-
modifiedAt?: Date;
|
|
77
|
-
}
|
|
78
|
-
```
|
|
79
|
-
|
|
80
|
-
### `mkdir(path, options?)`
|
|
81
|
-
|
|
82
|
-
Create a directory.
|
|
83
|
-
|
|
84
|
-
```typescript
|
|
85
|
-
await filesystem.mkdir('/docs/api');
|
|
86
|
-
await filesystem.mkdir('/deeply/nested/path', { recursive: true });
|
|
87
|
-
```
|
|
88
|
-
|
|
89
|
-
**Parameters:**
|
|
90
|
-
|
|
91
|
-
**path:** (`string`): Directory path
|
|
92
|
-
|
|
93
|
-
**options.recursive?:** (`boolean`): Create parent directories (Default: `false`)
|
|
94
|
-
|
|
95
|
-
### `rmdir(path, options?)`
|
|
96
|
-
|
|
97
|
-
Remove a directory.
|
|
98
|
-
|
|
99
|
-
```typescript
|
|
100
|
-
await filesystem.rmdir('/docs/old');
|
|
101
|
-
await filesystem.rmdir('/docs/nested', { recursive: true });
|
|
102
|
-
```
|
|
103
|
-
|
|
104
|
-
**Parameters:**
|
|
105
|
-
|
|
106
|
-
**path:** (`string`): Directory path
|
|
107
|
-
|
|
108
|
-
**options.recursive?:** (`boolean`): Remove contents recursively (Default: `false`)
|
|
109
|
-
|
|
110
|
-
**options.force?:** (`boolean`): Don't throw if directory doesn't exist (Default: `false`)
|
|
111
|
-
|
|
112
|
-
### `exists(path)`
|
|
113
|
-
|
|
114
|
-
Check if a path exists.
|
|
115
|
-
|
|
116
|
-
```typescript
|
|
117
|
-
const exists = await filesystem.exists('/docs/guide.md');
|
|
118
|
-
```
|
|
119
|
-
|
|
120
|
-
**Returns:** `Promise<boolean>`
|
|
121
|
-
|
|
122
|
-
### `stat(path)`
|
|
123
|
-
|
|
124
|
-
Get file or directory metadata.
|
|
125
|
-
|
|
126
|
-
```typescript
|
|
127
|
-
const stat = await filesystem.stat('/docs/guide.md');
|
|
128
|
-
// { type: 'file', size: 1234, modifiedAt: Date, createdAt: Date, path: '/docs/guide.md' }
|
|
129
|
-
```
|
|
130
|
-
|
|
131
|
-
**Returns:** `Promise<FileStat>`
|
|
132
|
-
|
|
133
|
-
```typescript
|
|
134
|
-
interface FileStat {
|
|
135
|
-
type: 'file' | 'directory';
|
|
136
|
-
size: number;
|
|
137
|
-
modifiedAt: Date;
|
|
138
|
-
createdAt: Date;
|
|
139
|
-
path: string;
|
|
140
|
-
}
|
|
141
|
-
```
|
|
142
|
-
|
|
143
|
-
## Optional Methods
|
|
144
|
-
|
|
145
|
-
### `init()`
|
|
146
|
-
|
|
147
|
-
Initialize the filesystem. Called by `workspace.init()`.
|
|
148
|
-
|
|
149
|
-
```typescript
|
|
150
|
-
await filesystem.init?.();
|
|
151
|
-
```
|
|
152
|
-
|
|
153
|
-
### `destroy()`
|
|
154
|
-
|
|
155
|
-
Clean up resources. Called by `workspace.destroy()`.
|
|
156
|
-
|
|
157
|
-
```typescript
|
|
158
|
-
await filesystem.destroy?.();
|
|
159
|
-
```
|
|
160
|
-
|
|
161
|
-
### `getInfo()`
|
|
162
|
-
|
|
163
|
-
Get filesystem metadata.
|
|
164
|
-
|
|
165
|
-
```typescript
|
|
166
|
-
const info = await filesystem.getInfo?.();
|
|
167
|
-
// { id, name, provider, basePath, readOnly, status, storage? }
|
|
168
|
-
```
|
|
169
|
-
|
|
170
|
-
**Returns:** `Promise<FilesystemInfo>`
|
|
171
|
-
|
|
172
|
-
```typescript
|
|
173
|
-
interface FilesystemInfo {
|
|
174
|
-
id: string;
|
|
175
|
-
name: string;
|
|
176
|
-
provider: string;
|
|
177
|
-
basePath?: string;
|
|
178
|
-
readOnly?: boolean;
|
|
179
|
-
status?: string;
|
|
180
|
-
storage?: {
|
|
181
|
-
totalBytes?: number;
|
|
182
|
-
usedBytes?: number;
|
|
183
|
-
availableBytes?: number;
|
|
184
|
-
};
|
|
185
|
-
}
|
|
186
|
-
```
|
|
187
|
-
|
|
188
|
-
### `getInstructions()`
|
|
189
|
-
|
|
190
|
-
Get a description of how this filesystem works. Used in tool descriptions to help agents understand path semantics.
|
|
191
|
-
|
|
192
|
-
```typescript
|
|
193
|
-
const instructions = filesystem.getInstructions?.();
|
|
194
|
-
// 'Local filesystem at "/workspace". Files at workspace path "/foo" are stored at "/workspace/foo" on disk.'
|
|
195
|
-
```
|
|
196
|
-
|
|
197
|
-
**Returns:** `string`
|
|
198
|
-
|
|
199
|
-
## Related
|
|
200
|
-
|
|
201
|
-
- [Workspace Class](https://mastra.ai/reference/workspace/workspace-class)
|
|
202
|
-
- [Sandbox Interface](https://mastra.ai/reference/workspace/sandbox)
|
|
@@ -1,170 +0,0 @@
|
|
|
1
|
-
# GCSFilesystem
|
|
2
|
-
|
|
3
|
-
Stores files in Google Cloud Storage.
|
|
4
|
-
|
|
5
|
-
> **Info:** For interface details, see [WorkspaceFilesystem Interface](https://mastra.ai/reference/workspace/filesystem).
|
|
6
|
-
|
|
7
|
-
## Installation
|
|
8
|
-
|
|
9
|
-
```bash
|
|
10
|
-
npm install @mastra/gcs
|
|
11
|
-
```
|
|
12
|
-
|
|
13
|
-
## Usage
|
|
14
|
-
|
|
15
|
-
Add a `GCSFilesystem` to a workspace and assign it to an agent:
|
|
16
|
-
|
|
17
|
-
```typescript
|
|
18
|
-
import { Agent } from '@mastra/core/agent';
|
|
19
|
-
import { Workspace } from '@mastra/core/workspace';
|
|
20
|
-
import { GCSFilesystem } from '@mastra/gcs';
|
|
21
|
-
|
|
22
|
-
const workspace = new Workspace({
|
|
23
|
-
filesystem: new GCSFilesystem({
|
|
24
|
-
bucket: 'my-gcs-bucket',
|
|
25
|
-
projectId: 'my-project-id',
|
|
26
|
-
credentials: JSON.parse(process.env.GCS_SERVICE_ACCOUNT_KEY),
|
|
27
|
-
}),
|
|
28
|
-
});
|
|
29
|
-
|
|
30
|
-
const agent = new Agent({
|
|
31
|
-
name: 'file-agent',
|
|
32
|
-
model: 'anthropic/claude-opus-4-5',
|
|
33
|
-
workspace,
|
|
34
|
-
});
|
|
35
|
-
```
|
|
36
|
-
|
|
37
|
-
### Using Application Default Credentials
|
|
38
|
-
|
|
39
|
-
If running on Google Cloud or with `gcloud` CLI configured, you can omit credentials:
|
|
40
|
-
|
|
41
|
-
```typescript
|
|
42
|
-
import { GCSFilesystem } from '@mastra/gcs';
|
|
43
|
-
|
|
44
|
-
const filesystem = new GCSFilesystem({
|
|
45
|
-
bucket: 'my-gcs-bucket',
|
|
46
|
-
// Uses Application Default Credentials automatically
|
|
47
|
-
});
|
|
48
|
-
```
|
|
49
|
-
|
|
50
|
-
[Application Default Credentials (ADC)](https://cloud.google.com/docs/authentication/application-default-credentials) automatically discovers credentials in this order:
|
|
51
|
-
|
|
52
|
-
1. `GOOGLE_APPLICATION_CREDENTIALS` environment variable (path to a service account key file)
|
|
53
|
-
2. Default service account when running on GCP (Compute Engine, Cloud Run, GKE, etc.)
|
|
54
|
-
3. User credentials from `gcloud auth application-default login` (for local development)
|
|
55
|
-
|
|
56
|
-
### Using a Key File Path
|
|
57
|
-
|
|
58
|
-
You can also pass a path to a service account key file:
|
|
59
|
-
|
|
60
|
-
```typescript
|
|
61
|
-
import { GCSFilesystem } from '@mastra/gcs';
|
|
62
|
-
|
|
63
|
-
const filesystem = new GCSFilesystem({
|
|
64
|
-
bucket: 'my-gcs-bucket',
|
|
65
|
-
projectId: 'my-project-id',
|
|
66
|
-
credentials: '/path/to/service-account-key.json',
|
|
67
|
-
});
|
|
68
|
-
```
|
|
69
|
-
|
|
70
|
-
## Constructor parameters
|
|
71
|
-
|
|
72
|
-
**bucket:** (`string`): GCS bucket name
|
|
73
|
-
|
|
74
|
-
**projectId?:** (`string`): GCS project ID. Required when using service account credentials.
|
|
75
|
-
|
|
76
|
-
**credentials?:** (`object | string`): Service account key JSON object or path to key file. If not provided, uses Application Default Credentials.
|
|
77
|
-
|
|
78
|
-
**prefix?:** (`string`): Optional prefix for all keys (acts like a subdirectory)
|
|
79
|
-
|
|
80
|
-
**id?:** (`string`): Unique identifier for this filesystem instance (Default: `Auto-generated`)
|
|
81
|
-
|
|
82
|
-
**displayName?:** (`string`): Human-friendly display name for the UI
|
|
83
|
-
|
|
84
|
-
**readOnly?:** (`boolean`): When true, all write operations are blocked (Default: `false`)
|
|
85
|
-
|
|
86
|
-
**endpoint?:** (`string`): Custom API endpoint URL. Used for local development with emulators.
|
|
87
|
-
|
|
88
|
-
## Properties
|
|
89
|
-
|
|
90
|
-
**id:** (`string`): Filesystem instance identifier
|
|
91
|
-
|
|
92
|
-
**name:** (`string`): Provider name ('GCSFilesystem')
|
|
93
|
-
|
|
94
|
-
**provider:** (`string`): Provider identifier ('gcs')
|
|
95
|
-
|
|
96
|
-
**bucket:** (`string`): The GCS bucket name
|
|
97
|
-
|
|
98
|
-
**readOnly:** (`boolean | undefined`): Whether the filesystem is in read-only mode
|
|
99
|
-
|
|
100
|
-
## Methods
|
|
101
|
-
|
|
102
|
-
GCSFilesystem implements the [WorkspaceFilesystem interface](https://mastra.ai/reference/workspace/filesystem), providing all standard filesystem methods:
|
|
103
|
-
|
|
104
|
-
- `readFile(path, options?)` - Read file contents
|
|
105
|
-
- `writeFile(path, content, options?)` - Write content to a file
|
|
106
|
-
- `appendFile(path, content)` - Append content to a file
|
|
107
|
-
- `deleteFile(path, options?)` - Delete a file
|
|
108
|
-
- `copyFile(src, dest, options?)` - Copy a file
|
|
109
|
-
- `moveFile(src, dest, options?)` - Move or rename a file
|
|
110
|
-
- `mkdir(path, options?)` - Create a directory
|
|
111
|
-
- `rmdir(path, options?)` - Remove a directory
|
|
112
|
-
- `readdir(path, options?)` - List directory contents
|
|
113
|
-
- `exists(path)` - Check if a path exists
|
|
114
|
-
- `stat(path)` - Get file or directory metadata
|
|
115
|
-
|
|
116
|
-
### `init()`
|
|
117
|
-
|
|
118
|
-
Initialize the filesystem. Verifies bucket access and credentials.
|
|
119
|
-
|
|
120
|
-
```typescript
|
|
121
|
-
await filesystem.init();
|
|
122
|
-
```
|
|
123
|
-
|
|
124
|
-
### `getInfo()`
|
|
125
|
-
|
|
126
|
-
Returns metadata about this filesystem instance.
|
|
127
|
-
|
|
128
|
-
```typescript
|
|
129
|
-
const info = filesystem.getInfo();
|
|
130
|
-
// { id: '...', name: 'GCSFilesystem', provider: 'gcs', status: 'ready' }
|
|
131
|
-
```
|
|
132
|
-
|
|
133
|
-
### `getMountConfig()`
|
|
134
|
-
|
|
135
|
-
Returns the mount configuration for sandboxes that support mounting this filesystem type.
|
|
136
|
-
|
|
137
|
-
```typescript
|
|
138
|
-
const config = filesystem.getMountConfig();
|
|
139
|
-
// { type: 'gcs', bucket: 'my-bucket', ... }
|
|
140
|
-
```
|
|
141
|
-
|
|
142
|
-
## Mounting in E2B Sandboxes
|
|
143
|
-
|
|
144
|
-
GCSFilesystem can be mounted into E2B sandboxes, making the bucket accessible as a local directory:
|
|
145
|
-
|
|
146
|
-
```typescript
|
|
147
|
-
import { Workspace } from '@mastra/core/workspace';
|
|
148
|
-
import { GCSFilesystem } from '@mastra/gcs';
|
|
149
|
-
import { E2BSandbox } from '@mastra/e2b';
|
|
150
|
-
|
|
151
|
-
const workspace = new Workspace({
|
|
152
|
-
mounts: {
|
|
153
|
-
'/data': new GCSFilesystem({
|
|
154
|
-
bucket: 'my-gcs-bucket',
|
|
155
|
-
projectId: 'my-project-id',
|
|
156
|
-
credentials: JSON.parse(process.env.GCS_SERVICE_ACCOUNT_KEY),
|
|
157
|
-
}),
|
|
158
|
-
},
|
|
159
|
-
sandbox: new E2BSandbox({ id: 'dev-sandbox' }),
|
|
160
|
-
});
|
|
161
|
-
```
|
|
162
|
-
|
|
163
|
-
See [E2BSandbox reference](https://mastra.ai/reference/workspace/e2b-sandbox) for more details on mounting.
|
|
164
|
-
|
|
165
|
-
## Related
|
|
166
|
-
|
|
167
|
-
- [WorkspaceFilesystem interface](https://mastra.ai/reference/workspace/filesystem)
|
|
168
|
-
- [S3Filesystem reference](https://mastra.ai/reference/workspace/s3-filesystem)
|
|
169
|
-
- [E2BSandbox reference](https://mastra.ai/reference/workspace/e2b-sandbox)
|
|
170
|
-
- [Workspace overview](https://mastra.ai/docs/workspace/overview)
|
|
@@ -1,327 +0,0 @@
|
|
|
1
|
-
# LocalFilesystem
|
|
2
|
-
|
|
3
|
-
**Added in:** `@mastra/core@1.1.0`
|
|
4
|
-
|
|
5
|
-
Stores files in a directory on the local filesystem.
|
|
6
|
-
|
|
7
|
-
> **Info:** For interface details, see [WorkspaceFilesystem Interface](https://mastra.ai/reference/workspace/filesystem).
|
|
8
|
-
|
|
9
|
-
## Usage
|
|
10
|
-
|
|
11
|
-
Add a `LocalFilesystem` to a workspace and assign it to an agent. The agent can then read, write, and manage files as part of its tasks:
|
|
12
|
-
|
|
13
|
-
```typescript
|
|
14
|
-
import { Agent } from '@mastra/core/agent';
|
|
15
|
-
import { Workspace, LocalFilesystem } from '@mastra/core/workspace';
|
|
16
|
-
|
|
17
|
-
const workspace = new Workspace({
|
|
18
|
-
filesystem: new LocalFilesystem({
|
|
19
|
-
basePath: './workspace',
|
|
20
|
-
}),
|
|
21
|
-
});
|
|
22
|
-
|
|
23
|
-
const agent = new Agent({
|
|
24
|
-
id: 'file-agent',
|
|
25
|
-
model: 'openai/gpt-4o',
|
|
26
|
-
workspace,
|
|
27
|
-
});
|
|
28
|
-
|
|
29
|
-
// The agent now has filesystem tools available
|
|
30
|
-
const response = await agent.generate('List all files in the workspace');
|
|
31
|
-
```
|
|
32
|
-
|
|
33
|
-
## Constructor parameters
|
|
34
|
-
|
|
35
|
-
**basePath:** (`string`): Base directory path on disk. All file paths are resolved relative to this directory.
|
|
36
|
-
|
|
37
|
-
**id?:** (`string`): Unique identifier for this filesystem instance (Default: `Auto-generated`)
|
|
38
|
-
|
|
39
|
-
**contained?:** (`boolean`): When true, all file operations are restricted to stay within basePath. Prevents path traversal attacks and symlink escapes. See \[containment]\(/docs/workspace/filesystem#containment). (Default: `true`)
|
|
40
|
-
|
|
41
|
-
**allowedPaths?:** (`string[]`): Additional absolute paths that are allowed beyond basePath. Useful with \`contained: true\` to grant access to specific directories without disabling containment entirely. Paths are resolved to absolute paths. (Default: `[]`)
|
|
42
|
-
|
|
43
|
-
**readOnly?:** (`boolean`): When true, all write operations are blocked. Read operations are still allowed. (Default: `false`)
|
|
44
|
-
|
|
45
|
-
## Properties
|
|
46
|
-
|
|
47
|
-
**id:** (`string`): Filesystem instance identifier
|
|
48
|
-
|
|
49
|
-
**name:** (`string`): Provider name ('LocalFilesystem')
|
|
50
|
-
|
|
51
|
-
**provider:** (`string`): Provider identifier ('local')
|
|
52
|
-
|
|
53
|
-
**basePath:** (`string`): The absolute base path on disk
|
|
54
|
-
|
|
55
|
-
**readOnly:** (`boolean | undefined`): Whether the filesystem is in read-only mode
|
|
56
|
-
|
|
57
|
-
**allowedPaths:** (`readonly string[]`): Current set of additional allowed paths (absolute, resolved). These paths are permitted beyond basePath when containment is enabled.
|
|
58
|
-
|
|
59
|
-
## Methods
|
|
60
|
-
|
|
61
|
-
### `init()`
|
|
62
|
-
|
|
63
|
-
Initialize the filesystem. Creates the base directory if it doesn't exist.
|
|
64
|
-
|
|
65
|
-
```typescript
|
|
66
|
-
await filesystem.init();
|
|
67
|
-
```
|
|
68
|
-
|
|
69
|
-
Called by `workspace.init()`.
|
|
70
|
-
|
|
71
|
-
### Lazy initialization
|
|
72
|
-
|
|
73
|
-
LocalFilesystem initializes on first operation if not already initialized, creating the base directory automatically. Calling `init()` explicitly is optional but can be useful to pre-create directories before the first operation.
|
|
74
|
-
|
|
75
|
-
### `destroy()`
|
|
76
|
-
|
|
77
|
-
Clean up filesystem resources.
|
|
78
|
-
|
|
79
|
-
```typescript
|
|
80
|
-
await filesystem.destroy();
|
|
81
|
-
```
|
|
82
|
-
|
|
83
|
-
Called by `workspace.destroy()`.
|
|
84
|
-
|
|
85
|
-
### `setAllowedPaths(pathsOrUpdater)`
|
|
86
|
-
|
|
87
|
-
Update the allowed paths at runtime. Accepts a new paths array (replaces current) or an updater callback that receives the current paths and returns the new set.
|
|
88
|
-
|
|
89
|
-
```typescript
|
|
90
|
-
// Set directly
|
|
91
|
-
filesystem.setAllowedPaths(['/home/user/.config']);
|
|
92
|
-
|
|
93
|
-
// Update with callback
|
|
94
|
-
filesystem.setAllowedPaths(prev => [...prev, '/home/user/documents']);
|
|
95
|
-
|
|
96
|
-
// Clear all allowed paths
|
|
97
|
-
filesystem.setAllowedPaths([]);
|
|
98
|
-
```
|
|
99
|
-
|
|
100
|
-
**Parameters:**
|
|
101
|
-
|
|
102
|
-
**pathsOrUpdater:** (`string[] | ((current: readonly string[]) => string[])`): New allowed paths array or updater function receiving current paths
|
|
103
|
-
|
|
104
|
-
### `readFile(path, options?)`
|
|
105
|
-
|
|
106
|
-
Read file contents.
|
|
107
|
-
|
|
108
|
-
```typescript
|
|
109
|
-
const content = await filesystem.readFile('/docs/guide.md');
|
|
110
|
-
const buffer = await filesystem.readFile('/image.png', { encoding: 'binary' });
|
|
111
|
-
```
|
|
112
|
-
|
|
113
|
-
**Parameters:**
|
|
114
|
-
|
|
115
|
-
**path:** (`string`): File path relative to basePath
|
|
116
|
-
|
|
117
|
-
**options.encoding?:** (`'utf-8' | 'binary'`): Text or binary encoding (Default: `'utf-8'`)
|
|
118
|
-
|
|
119
|
-
### `writeFile(path, content, options?)`
|
|
120
|
-
|
|
121
|
-
Write content to a file.
|
|
122
|
-
|
|
123
|
-
```typescript
|
|
124
|
-
await filesystem.writeFile('/docs/new.md', '# New Document');
|
|
125
|
-
await filesystem.writeFile('/nested/path/file.md', content, { recursive: true });
|
|
126
|
-
```
|
|
127
|
-
|
|
128
|
-
**Parameters:**
|
|
129
|
-
|
|
130
|
-
**path:** (`string`): File path relative to basePath
|
|
131
|
-
|
|
132
|
-
**content:** (`string | Buffer`): File content
|
|
133
|
-
|
|
134
|
-
**options.recursive?:** (`boolean`): Create parent directories if they don't exist (Default: `false`)
|
|
135
|
-
|
|
136
|
-
**options.overwrite?:** (`boolean`): Overwrite existing file (Default: `true`)
|
|
137
|
-
|
|
138
|
-
### `appendFile(path, content)`
|
|
139
|
-
|
|
140
|
-
Append content to an existing file.
|
|
141
|
-
|
|
142
|
-
```typescript
|
|
143
|
-
await filesystem.appendFile('/logs/app.log', 'New log entry\n');
|
|
144
|
-
```
|
|
145
|
-
|
|
146
|
-
**Parameters:**
|
|
147
|
-
|
|
148
|
-
**path:** (`string`): File path relative to basePath
|
|
149
|
-
|
|
150
|
-
**content:** (`string | Buffer`): Content to append
|
|
151
|
-
|
|
152
|
-
### `deleteFile(path, options?)`
|
|
153
|
-
|
|
154
|
-
Delete a file.
|
|
155
|
-
|
|
156
|
-
```typescript
|
|
157
|
-
await filesystem.deleteFile('/docs/old.md');
|
|
158
|
-
await filesystem.deleteFile('/docs/maybe.md', { force: true }); // Don't throw if missing
|
|
159
|
-
```
|
|
160
|
-
|
|
161
|
-
**Parameters:**
|
|
162
|
-
|
|
163
|
-
**path:** (`string`): File path
|
|
164
|
-
|
|
165
|
-
**options.force?:** (`boolean`): Don't throw error if file doesn't exist (Default: `false`)
|
|
166
|
-
|
|
167
|
-
### `copyFile(src, dest, options?)`
|
|
168
|
-
|
|
169
|
-
Copy a file to a new location.
|
|
170
|
-
|
|
171
|
-
```typescript
|
|
172
|
-
await filesystem.copyFile('/docs/template.md', '/docs/new-doc.md');
|
|
173
|
-
await filesystem.copyFile('/src/config.json', '/backup/config.json', { overwrite: false });
|
|
174
|
-
```
|
|
175
|
-
|
|
176
|
-
**Parameters:**
|
|
177
|
-
|
|
178
|
-
**src:** (`string`): Source file path
|
|
179
|
-
|
|
180
|
-
**dest:** (`string`): Destination file path
|
|
181
|
-
|
|
182
|
-
**options.overwrite?:** (`boolean`): Overwrite destination if it exists (Default: `true`)
|
|
183
|
-
|
|
184
|
-
### `moveFile(src, dest, options?)`
|
|
185
|
-
|
|
186
|
-
Move or rename a file.
|
|
187
|
-
|
|
188
|
-
```typescript
|
|
189
|
-
await filesystem.moveFile('/docs/draft.md', '/docs/final.md');
|
|
190
|
-
await filesystem.moveFile('/temp/upload.txt', '/files/document.txt');
|
|
191
|
-
```
|
|
192
|
-
|
|
193
|
-
**Parameters:**
|
|
194
|
-
|
|
195
|
-
**src:** (`string`): Source file path
|
|
196
|
-
|
|
197
|
-
**dest:** (`string`): Destination file path
|
|
198
|
-
|
|
199
|
-
**options.overwrite?:** (`boolean`): Overwrite destination if it exists (Default: `true`)
|
|
200
|
-
|
|
201
|
-
### `mkdir(path, options?)`
|
|
202
|
-
|
|
203
|
-
Create a directory.
|
|
204
|
-
|
|
205
|
-
```typescript
|
|
206
|
-
await filesystem.mkdir('/docs/api');
|
|
207
|
-
await filesystem.mkdir('/deeply/nested/path', { recursive: true });
|
|
208
|
-
```
|
|
209
|
-
|
|
210
|
-
**Parameters:**
|
|
211
|
-
|
|
212
|
-
**path:** (`string`): Directory path
|
|
213
|
-
|
|
214
|
-
**options.recursive?:** (`boolean`): Create parent directories (Default: `false`)
|
|
215
|
-
|
|
216
|
-
### `rmdir(path, options?)`
|
|
217
|
-
|
|
218
|
-
Remove a directory.
|
|
219
|
-
|
|
220
|
-
```typescript
|
|
221
|
-
await filesystem.rmdir('/docs/old');
|
|
222
|
-
await filesystem.rmdir('/docs/nested', { recursive: true });
|
|
223
|
-
```
|
|
224
|
-
|
|
225
|
-
**Parameters:**
|
|
226
|
-
|
|
227
|
-
**path:** (`string`): Directory path
|
|
228
|
-
|
|
229
|
-
**options.recursive?:** (`boolean`): Remove contents recursively (Default: `false`)
|
|
230
|
-
|
|
231
|
-
**options.force?:** (`boolean`): Don't throw if directory doesn't exist (Default: `false`)
|
|
232
|
-
|
|
233
|
-
### `readdir(path, options?)`
|
|
234
|
-
|
|
235
|
-
List directory contents.
|
|
236
|
-
|
|
237
|
-
```typescript
|
|
238
|
-
const entries = await filesystem.readdir('/docs');
|
|
239
|
-
// [{ name: 'guide.md', type: 'file' }, { name: 'api', type: 'directory' }]
|
|
240
|
-
```
|
|
241
|
-
|
|
242
|
-
### `exists(path)`
|
|
243
|
-
|
|
244
|
-
Check if a path exists.
|
|
245
|
-
|
|
246
|
-
```typescript
|
|
247
|
-
const exists = await filesystem.exists('/docs/guide.md');
|
|
248
|
-
```
|
|
249
|
-
|
|
250
|
-
### `stat(path)`
|
|
251
|
-
|
|
252
|
-
Get file or directory metadata.
|
|
253
|
-
|
|
254
|
-
```typescript
|
|
255
|
-
const stat = await filesystem.stat('/docs/guide.md');
|
|
256
|
-
// { type: 'file', size: 1234, modifiedAt: Date, createdAt: Date, path: '/docs/guide.md' }
|
|
257
|
-
```
|
|
258
|
-
|
|
259
|
-
### `getInfo()`
|
|
260
|
-
|
|
261
|
-
Returns metadata about this filesystem instance.
|
|
262
|
-
|
|
263
|
-
```typescript
|
|
264
|
-
const info = filesystem.getInfo();
|
|
265
|
-
// { id: '...', name: 'LocalFilesystem', provider: 'local', basePath: '/workspace', readOnly: false }
|
|
266
|
-
```
|
|
267
|
-
|
|
268
|
-
### `getInstructions()`
|
|
269
|
-
|
|
270
|
-
Returns a description of how paths work in this filesystem. Used in tool descriptions.
|
|
271
|
-
|
|
272
|
-
```typescript
|
|
273
|
-
const instructions = filesystem.getInstructions();
|
|
274
|
-
// 'Local filesystem at "/workspace". Files at workspace path "/foo" are stored at "/workspace/foo" on disk.'
|
|
275
|
-
```
|
|
276
|
-
|
|
277
|
-
## Path resolution
|
|
278
|
-
|
|
279
|
-
### How basePath works
|
|
280
|
-
|
|
281
|
-
The `basePath` option sets the root directory for all file operations. File paths passed to methods like `readFile()` are resolved relative to this base:
|
|
282
|
-
|
|
283
|
-
- Leading slashes are stripped: `/docs/guide.md` → `docs/guide.md`
|
|
284
|
-
- The path is normalized and joined with basePath
|
|
285
|
-
- Result: `./workspace` + `docs/guide.md` → `./workspace/docs/guide.md`
|
|
286
|
-
|
|
287
|
-
```typescript
|
|
288
|
-
const filesystem = new LocalFilesystem({
|
|
289
|
-
basePath: './workspace',
|
|
290
|
-
});
|
|
291
|
-
|
|
292
|
-
// These all resolve to ./workspace/docs/guide.md
|
|
293
|
-
await filesystem.readFile('/docs/guide.md');
|
|
294
|
-
await filesystem.readFile('docs/guide.md');
|
|
295
|
-
```
|
|
296
|
-
|
|
297
|
-
### Relative paths and execution context
|
|
298
|
-
|
|
299
|
-
When you use a relative path for `basePath`, it resolves from `process.cwd()`. In Mastra projects, cwd varies depending on how you run your code:
|
|
300
|
-
|
|
301
|
-
| Context | Working directory | `./workspace` resolves to |
|
|
302
|
-
| -------------- | ------------------------- | ------------------------------- |
|
|
303
|
-
| `mastra dev` | `./src/mastra/public/` | `./src/mastra/public/workspace` |
|
|
304
|
-
| `mastra start` | `./.mastra/output/` | `./.mastra/output/workspace` |
|
|
305
|
-
| Direct script | Where you ran the command | Relative to that location |
|
|
306
|
-
|
|
307
|
-
This can cause confusion when the same relative path resolves to different locations.
|
|
308
|
-
|
|
309
|
-
### Recommended: Use absolute paths
|
|
310
|
-
|
|
311
|
-
For consistent paths across all execution contexts, use an environment variable with an absolute path:
|
|
312
|
-
|
|
313
|
-
```typescript
|
|
314
|
-
import { LocalFilesystem } from '@mastra/core/workspace';
|
|
315
|
-
|
|
316
|
-
const filesystem = new LocalFilesystem({
|
|
317
|
-
basePath: process.env.WORKSPACE_PATH!,
|
|
318
|
-
});
|
|
319
|
-
```
|
|
320
|
-
|
|
321
|
-
Set `WORKSPACE_PATH` in your environment to an absolute path like `/home/user/my-project/workspace`. This ensures the workspace path is consistent regardless of how you run your code.
|
|
322
|
-
|
|
323
|
-
## Related
|
|
324
|
-
|
|
325
|
-
- [WorkspaceFilesystem interface](https://mastra.ai/reference/workspace/filesystem)
|
|
326
|
-
- [Workspace class](https://mastra.ai/reference/workspace/workspace-class)
|
|
327
|
-
- [Workspace overview](https://mastra.ai/docs/workspace/overview)
|