@mastra/mcp-docs-server 1.1.5 → 1.1.6-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/.docs/docs/agents/adding-voice.md +349 -0
- package/.docs/docs/agents/agent-approval.md +558 -0
- package/.docs/docs/agents/agent-memory.md +209 -0
- package/.docs/docs/agents/guardrails.md +374 -0
- package/.docs/docs/agents/network-approval.md +275 -0
- package/.docs/docs/agents/networks.md +299 -0
- package/.docs/docs/agents/overview.md +304 -0
- package/.docs/docs/agents/processors.md +622 -0
- package/.docs/docs/agents/structured-output.md +273 -0
- package/.docs/docs/agents/supervisor-agents.md +304 -0
- package/.docs/docs/agents/using-tools.md +214 -0
- package/.docs/docs/build-with-ai/mcp-docs-server.md +238 -0
- package/.docs/docs/build-with-ai/skills.md +35 -0
- package/.docs/docs/community/contributing-templates.md +3 -0
- package/.docs/docs/community/discord.md +9 -0
- package/.docs/docs/community/licensing.md +66 -0
- package/.docs/docs/deployment/cloud-providers.md +15 -0
- package/.docs/docs/deployment/mastra-server.md +122 -0
- package/.docs/docs/deployment/monorepo.md +142 -0
- package/.docs/docs/deployment/overview.md +62 -0
- package/.docs/docs/deployment/studio.md +239 -0
- package/.docs/docs/deployment/web-framework.md +52 -0
- package/.docs/docs/deployment/workflow-runners.md +9 -0
- package/.docs/docs/evals/built-in-scorers.md +47 -0
- package/.docs/docs/evals/custom-scorers.md +519 -0
- package/.docs/docs/evals/overview.md +141 -0
- package/.docs/docs/evals/running-in-ci.md +124 -0
- package/.docs/docs/getting-started/build-with-ai.md +68 -0
- package/.docs/docs/getting-started/manual-install.md +226 -0
- package/.docs/docs/getting-started/project-structure.md +60 -0
- package/.docs/docs/getting-started/start.md +28 -0
- package/.docs/docs/getting-started/studio.md +101 -0
- package/.docs/docs/index.md +43 -0
- package/.docs/docs/mastra-cloud/deployment.md +77 -0
- package/.docs/docs/mastra-cloud/observability.md +38 -0
- package/.docs/docs/mastra-cloud/overview.md +23 -0
- package/.docs/docs/mastra-cloud/setup.md +42 -0
- package/.docs/docs/mastra-cloud/studio.md +24 -0
- package/.docs/docs/mastra-code/configuration.md +299 -0
- package/.docs/docs/mastra-code/customization.md +228 -0
- package/.docs/docs/mastra-code/modes.md +104 -0
- package/.docs/docs/mastra-code/overview.md +135 -0
- package/.docs/docs/mastra-code/tools.md +229 -0
- package/.docs/docs/mcp/overview.md +373 -0
- package/.docs/docs/mcp/publishing-mcp-server.md +95 -0
- package/.docs/docs/memory/memory-processors.md +314 -0
- package/.docs/docs/memory/message-history.md +260 -0
- package/.docs/docs/memory/observational-memory.md +248 -0
- package/.docs/docs/memory/overview.md +45 -0
- package/.docs/docs/memory/semantic-recall.md +272 -0
- package/.docs/docs/memory/storage.md +261 -0
- package/.docs/docs/memory/working-memory.md +400 -0
- package/.docs/docs/observability/datasets/overview.md +198 -0
- package/.docs/docs/observability/datasets/running-experiments.md +274 -0
- package/.docs/docs/observability/logging.md +99 -0
- package/.docs/docs/observability/overview.md +70 -0
- package/.docs/docs/observability/tracing/bridges/otel.md +209 -0
- package/.docs/docs/observability/tracing/exporters/arize.md +272 -0
- package/.docs/docs/observability/tracing/exporters/braintrust.md +111 -0
- package/.docs/docs/observability/tracing/exporters/cloud.md +127 -0
- package/.docs/docs/observability/tracing/exporters/datadog.md +187 -0
- package/.docs/docs/observability/tracing/exporters/default.md +209 -0
- package/.docs/docs/observability/tracing/exporters/laminar.md +100 -0
- package/.docs/docs/observability/tracing/exporters/langfuse.md +213 -0
- package/.docs/docs/observability/tracing/exporters/langsmith.md +198 -0
- package/.docs/docs/observability/tracing/exporters/otel.md +476 -0
- package/.docs/docs/observability/tracing/exporters/posthog.md +148 -0
- package/.docs/docs/observability/tracing/exporters/sentry.md +208 -0
- package/.docs/docs/observability/tracing/overview.md +1112 -0
- package/.docs/docs/observability/tracing/processors/sensitive-data-filter.md +300 -0
- package/.docs/docs/rag/chunking-and-embedding.md +183 -0
- package/.docs/docs/rag/graph-rag.md +215 -0
- package/.docs/docs/rag/overview.md +72 -0
- package/.docs/docs/rag/retrieval.md +515 -0
- package/.docs/docs/rag/vector-databases.md +645 -0
- package/.docs/docs/server/auth/auth0.md +220 -0
- package/.docs/docs/server/auth/better-auth.md +203 -0
- package/.docs/docs/server/auth/clerk.md +132 -0
- package/.docs/docs/server/auth/composite-auth.md +234 -0
- package/.docs/docs/server/auth/custom-auth-provider.md +513 -0
- package/.docs/docs/server/auth/firebase.md +272 -0
- package/.docs/docs/server/auth/jwt.md +110 -0
- package/.docs/docs/server/auth/simple-auth.md +180 -0
- package/.docs/docs/server/auth/supabase.md +117 -0
- package/.docs/docs/server/auth/workos.md +186 -0
- package/.docs/docs/server/auth.md +38 -0
- package/.docs/docs/server/custom-adapters.md +378 -0
- package/.docs/docs/server/custom-api-routes.md +267 -0
- package/.docs/docs/server/mastra-client.md +243 -0
- package/.docs/docs/server/mastra-server.md +71 -0
- package/.docs/docs/server/middleware.md +225 -0
- package/.docs/docs/server/request-context.md +471 -0
- package/.docs/docs/server/server-adapters.md +547 -0
- package/.docs/docs/streaming/events.md +237 -0
- package/.docs/docs/streaming/overview.md +175 -0
- package/.docs/docs/streaming/tool-streaming.md +175 -0
- package/.docs/docs/streaming/workflow-streaming.md +109 -0
- package/.docs/docs/voice/overview.md +959 -0
- package/.docs/docs/voice/speech-to-speech.md +102 -0
- package/.docs/docs/voice/speech-to-text.md +79 -0
- package/.docs/docs/voice/text-to-speech.md +83 -0
- package/.docs/docs/workflows/agents-and-tools.md +166 -0
- package/.docs/docs/workflows/control-flow.md +822 -0
- package/.docs/docs/workflows/error-handling.md +360 -0
- package/.docs/docs/workflows/human-in-the-loop.md +215 -0
- package/.docs/docs/workflows/overview.md +370 -0
- package/.docs/docs/workflows/snapshots.md +238 -0
- package/.docs/docs/workflows/suspend-and-resume.md +205 -0
- package/.docs/docs/workflows/time-travel.md +309 -0
- package/.docs/docs/workflows/workflow-state.md +181 -0
- package/.docs/docs/workspace/filesystem.md +164 -0
- package/.docs/docs/workspace/overview.md +239 -0
- package/.docs/docs/workspace/sandbox.md +63 -0
- package/.docs/docs/workspace/search.md +243 -0
- package/.docs/docs/workspace/skills.md +169 -0
- package/.docs/guides/agent-frameworks/ai-sdk.md +140 -0
- package/.docs/guides/build-your-ui/ai-sdk-ui.md +1499 -0
- package/.docs/guides/build-your-ui/assistant-ui.md +156 -0
- package/.docs/guides/build-your-ui/copilotkit.md +289 -0
- package/.docs/guides/deployment/amazon-ec2.md +130 -0
- package/.docs/guides/deployment/aws-lambda.md +248 -0
- package/.docs/guides/deployment/azure-app-services.md +114 -0
- package/.docs/guides/deployment/cloudflare.md +99 -0
- package/.docs/guides/deployment/digital-ocean.md +168 -0
- package/.docs/guides/deployment/inngest.md +682 -0
- package/.docs/guides/deployment/netlify.md +77 -0
- package/.docs/guides/deployment/vercel.md +101 -0
- package/.docs/guides/getting-started/astro.md +398 -0
- package/.docs/guides/getting-started/electron.md +504 -0
- package/.docs/guides/getting-started/express.md +251 -0
- package/.docs/guides/getting-started/hono.md +190 -0
- package/.docs/guides/getting-started/next-js.md +347 -0
- package/.docs/guides/getting-started/nuxt.md +497 -0
- package/.docs/guides/getting-started/quickstart.md +67 -0
- package/.docs/guides/getting-started/sveltekit.md +296 -0
- package/.docs/guides/getting-started/vite-react.md +425 -0
- package/.docs/guides/guide/ai-recruiter.md +226 -0
- package/.docs/guides/guide/chef-michel.md +211 -0
- package/.docs/guides/guide/code-review-bot.md +226 -0
- package/.docs/guides/guide/dev-assistant.md +307 -0
- package/.docs/guides/guide/docs-manager.md +238 -0
- package/.docs/guides/guide/github-actions-pr-description.md +236 -0
- package/.docs/guides/guide/notes-mcp-server.md +416 -0
- package/.docs/guides/guide/research-assistant.md +348 -0
- package/.docs/guides/guide/research-coordinator.md +416 -0
- package/.docs/guides/guide/stock-agent.md +132 -0
- package/.docs/guides/guide/web-search.md +320 -0
- package/.docs/guides/guide/whatsapp-chat-bot.md +405 -0
- package/.docs/guides/index.md +3 -0
- package/.docs/guides/migrations/agentnetwork.md +97 -0
- package/.docs/guides/migrations/ai-sdk-v4-to-v5.md +112 -0
- package/.docs/guides/migrations/network-to-supervisor.md +261 -0
- package/.docs/guides/migrations/upgrade-to-v1/agent.md +404 -0
- package/.docs/guides/migrations/upgrade-to-v1/cli.md +57 -0
- package/.docs/guides/migrations/upgrade-to-v1/client.md +337 -0
- package/.docs/guides/migrations/upgrade-to-v1/deployment.md +37 -0
- package/.docs/guides/migrations/upgrade-to-v1/evals.md +239 -0
- package/.docs/guides/migrations/upgrade-to-v1/mastra.md +143 -0
- package/.docs/guides/migrations/upgrade-to-v1/mcp.md +97 -0
- package/.docs/guides/migrations/upgrade-to-v1/memory.md +285 -0
- package/.docs/guides/migrations/upgrade-to-v1/overview.md +119 -0
- package/.docs/guides/migrations/upgrade-to-v1/processors.md +68 -0
- package/.docs/guides/migrations/upgrade-to-v1/rag.md +42 -0
- package/.docs/guides/migrations/upgrade-to-v1/storage.md +553 -0
- package/.docs/guides/migrations/upgrade-to-v1/tools.md +180 -0
- package/.docs/guides/migrations/upgrade-to-v1/tracing.md +412 -0
- package/.docs/guides/migrations/upgrade-to-v1/vectors.md +87 -0
- package/.docs/guides/migrations/upgrade-to-v1/voice.md +30 -0
- package/.docs/guides/migrations/upgrade-to-v1/workflows.md +341 -0
- package/.docs/guides/migrations/vnext-to-standard-apis.md +362 -0
- package/.docs/models/embeddings.md +161 -0
- package/.docs/models/gateways/azure-openai.md +128 -0
- package/.docs/models/gateways/custom-gateways.md +545 -0
- package/.docs/models/gateways/netlify.md +88 -0
- package/.docs/models/gateways/openrouter.md +219 -0
- package/.docs/models/gateways/vercel.md +225 -0
- package/.docs/models/gateways.md +14 -0
- package/.docs/models/index.md +286 -0
- package/.docs/models/providers/302ai.md +134 -0
- package/.docs/models/providers/abacus.md +125 -0
- package/.docs/models/providers/agentrouter.md +90 -0
- package/.docs/models/providers/aihubmix.md +107 -0
- package/.docs/models/providers/alibaba-cn.md +135 -0
- package/.docs/models/providers/alibaba.md +111 -0
- package/.docs/models/providers/amazon-bedrock.md +33 -0
- package/.docs/models/providers/anthropic.md +153 -0
- package/.docs/models/providers/azure.md +33 -0
- package/.docs/models/providers/bailing.md +72 -0
- package/.docs/models/providers/baseten.md +77 -0
- package/.docs/models/providers/berget.md +78 -0
- package/.docs/models/providers/cerebras.md +101 -0
- package/.docs/models/providers/chutes.md +136 -0
- package/.docs/models/providers/cloudflare-ai-gateway.md +33 -0
- package/.docs/models/providers/cloudflare-workers-ai.md +109 -0
- package/.docs/models/providers/cohere.md +33 -0
- package/.docs/models/providers/cortecs.md +91 -0
- package/.docs/models/providers/deepinfra.md +112 -0
- package/.docs/models/providers/deepseek.md +88 -0
- package/.docs/models/providers/fastrouter.md +84 -0
- package/.docs/models/providers/fireworks-ai.md +89 -0
- package/.docs/models/providers/firmware.md +85 -0
- package/.docs/models/providers/friendli.md +78 -0
- package/.docs/models/providers/github-models.md +125 -0
- package/.docs/models/providers/google-vertex.md +33 -0
- package/.docs/models/providers/google.md +159 -0
- package/.docs/models/providers/groq.md +107 -0
- package/.docs/models/providers/helicone.md +161 -0
- package/.docs/models/providers/huggingface.md +90 -0
- package/.docs/models/providers/iflowcn.md +84 -0
- package/.docs/models/providers/inception.md +72 -0
- package/.docs/models/providers/inference.md +79 -0
- package/.docs/models/providers/io-intelligence.md +87 -0
- package/.docs/models/providers/io-net.md +87 -0
- package/.docs/models/providers/jiekou.md +131 -0
- package/.docs/models/providers/kilo.md +333 -0
- package/.docs/models/providers/kimi-for-coding.md +100 -0
- package/.docs/models/providers/kuae-cloud-coding-plan.md +71 -0
- package/.docs/models/providers/llama.md +77 -0
- package/.docs/models/providers/lmstudio.md +73 -0
- package/.docs/models/providers/lucidquery.md +72 -0
- package/.docs/models/providers/minimax-cn-coding-plan.md +102 -0
- package/.docs/models/providers/minimax-cn.md +102 -0
- package/.docs/models/providers/minimax-coding-plan.md +102 -0
- package/.docs/models/providers/minimax.md +104 -0
- package/.docs/models/providers/mistral.md +124 -0
- package/.docs/models/providers/moark.md +72 -0
- package/.docs/models/providers/modelscope.md +77 -0
- package/.docs/models/providers/moonshotai-cn.md +76 -0
- package/.docs/models/providers/moonshotai.md +76 -0
- package/.docs/models/providers/morph.md +73 -0
- package/.docs/models/providers/nano-gpt.md +103 -0
- package/.docs/models/providers/nebius.md +116 -0
- package/.docs/models/providers/nova.md +72 -0
- package/.docs/models/providers/novita-ai.md +154 -0
- package/.docs/models/providers/nvidia.md +141 -0
- package/.docs/models/providers/ollama-cloud.md +103 -0
- package/.docs/models/providers/ollama.md +33 -0
- package/.docs/models/providers/openai.md +193 -0
- package/.docs/models/providers/opencode.md +100 -0
- package/.docs/models/providers/ovhcloud.md +83 -0
- package/.docs/models/providers/perplexity.md +100 -0
- package/.docs/models/providers/poe.md +183 -0
- package/.docs/models/providers/privatemode-ai.md +75 -0
- package/.docs/models/providers/requesty.md +90 -0
- package/.docs/models/providers/scaleway.md +84 -0
- package/.docs/models/providers/siliconflow-cn.md +138 -0
- package/.docs/models/providers/siliconflow.md +140 -0
- package/.docs/models/providers/stackit.md +78 -0
- package/.docs/models/providers/stepfun.md +73 -0
- package/.docs/models/providers/submodel.md +79 -0
- package/.docs/models/providers/synthetic.md +96 -0
- package/.docs/models/providers/togetherai.md +115 -0
- package/.docs/models/providers/upstage.md +73 -0
- package/.docs/models/providers/venice.md +95 -0
- package/.docs/models/providers/vivgrid.md +106 -0
- package/.docs/models/providers/vultr.md +75 -0
- package/.docs/models/providers/wandb.md +80 -0
- package/.docs/models/providers/xai.md +141 -0
- package/.docs/models/providers/xiaomi.md +71 -0
- package/.docs/models/providers/zai-coding-plan.md +80 -0
- package/.docs/models/providers/zai.md +79 -0
- package/.docs/models/providers/zenmux.md +161 -0
- package/.docs/models/providers/zhipuai-coding-plan.md +79 -0
- package/.docs/models/providers/zhipuai.md +79 -0
- package/.docs/models/providers.md +81 -0
- package/.docs/reference/agents/agent.md +141 -0
- package/.docs/reference/agents/generate.md +186 -0
- package/.docs/reference/agents/generateLegacy.md +173 -0
- package/.docs/reference/agents/getDefaultGenerateOptions.md +36 -0
- package/.docs/reference/agents/getDefaultOptions.md +34 -0
- package/.docs/reference/agents/getDefaultStreamOptions.md +36 -0
- package/.docs/reference/agents/getDescription.md +21 -0
- package/.docs/reference/agents/getInstructions.md +34 -0
- package/.docs/reference/agents/getLLM.md +37 -0
- package/.docs/reference/agents/getMemory.md +34 -0
- package/.docs/reference/agents/getModel.md +34 -0
- package/.docs/reference/agents/getTools.md +29 -0
- package/.docs/reference/agents/getVoice.md +34 -0
- package/.docs/reference/agents/listAgents.md +35 -0
- package/.docs/reference/agents/listScorers.md +34 -0
- package/.docs/reference/agents/listTools.md +34 -0
- package/.docs/reference/agents/listWorkflows.md +34 -0
- package/.docs/reference/agents/network.md +133 -0
- package/.docs/reference/ai-sdk/chat-route.md +82 -0
- package/.docs/reference/ai-sdk/handle-chat-stream.md +53 -0
- package/.docs/reference/ai-sdk/handle-network-stream.md +37 -0
- package/.docs/reference/ai-sdk/handle-workflow-stream.md +55 -0
- package/.docs/reference/ai-sdk/network-route.md +74 -0
- package/.docs/reference/ai-sdk/to-ai-sdk-stream.md +231 -0
- package/.docs/reference/ai-sdk/to-ai-sdk-v4-messages.md +79 -0
- package/.docs/reference/ai-sdk/to-ai-sdk-v5-messages.md +76 -0
- package/.docs/reference/ai-sdk/with-mastra.md +59 -0
- package/.docs/reference/ai-sdk/workflow-route.md +79 -0
- package/.docs/reference/auth/auth0.md +73 -0
- package/.docs/reference/auth/better-auth.md +71 -0
- package/.docs/reference/auth/clerk.md +36 -0
- package/.docs/reference/auth/firebase.md +80 -0
- package/.docs/reference/auth/jwt.md +26 -0
- package/.docs/reference/auth/supabase.md +33 -0
- package/.docs/reference/auth/workos.md +84 -0
- package/.docs/reference/cli/create-mastra.md +137 -0
- package/.docs/reference/cli/mastra.md +336 -0
- package/.docs/reference/client-js/agents.md +437 -0
- package/.docs/reference/client-js/error-handling.md +16 -0
- package/.docs/reference/client-js/logs.md +24 -0
- package/.docs/reference/client-js/mastra-client.md +63 -0
- package/.docs/reference/client-js/memory.md +221 -0
- package/.docs/reference/client-js/observability.md +72 -0
- package/.docs/reference/client-js/telemetry.md +20 -0
- package/.docs/reference/client-js/tools.md +44 -0
- package/.docs/reference/client-js/vectors.md +79 -0
- package/.docs/reference/client-js/workflows.md +199 -0
- package/.docs/reference/configuration.md +752 -0
- package/.docs/reference/core/addGateway.md +42 -0
- package/.docs/reference/core/getAgent.md +21 -0
- package/.docs/reference/core/getAgentById.md +21 -0
- package/.docs/reference/core/getDeployer.md +22 -0
- package/.docs/reference/core/getGateway.md +38 -0
- package/.docs/reference/core/getGatewayById.md +41 -0
- package/.docs/reference/core/getLogger.md +22 -0
- package/.docs/reference/core/getMCPServer.md +47 -0
- package/.docs/reference/core/getMCPServerById.md +55 -0
- package/.docs/reference/core/getMemory.md +50 -0
- package/.docs/reference/core/getScorer.md +54 -0
- package/.docs/reference/core/getScorerById.md +54 -0
- package/.docs/reference/core/getServer.md +22 -0
- package/.docs/reference/core/getStorage.md +22 -0
- package/.docs/reference/core/getStoredAgentById.md +89 -0
- package/.docs/reference/core/getTelemetry.md +22 -0
- package/.docs/reference/core/getVector.md +22 -0
- package/.docs/reference/core/getWorkflow.md +42 -0
- package/.docs/reference/core/listAgents.md +21 -0
- package/.docs/reference/core/listGateways.md +40 -0
- package/.docs/reference/core/listLogs.md +38 -0
- package/.docs/reference/core/listLogsByRunId.md +36 -0
- package/.docs/reference/core/listMCPServers.md +55 -0
- package/.docs/reference/core/listMemory.md +56 -0
- package/.docs/reference/core/listScorers.md +29 -0
- package/.docs/reference/core/listStoredAgents.md +93 -0
- package/.docs/reference/core/listVectors.md +22 -0
- package/.docs/reference/core/listWorkflows.md +21 -0
- package/.docs/reference/core/mastra-class.md +66 -0
- package/.docs/reference/core/mastra-model-gateway.md +153 -0
- package/.docs/reference/core/setLogger.md +26 -0
- package/.docs/reference/core/setStorage.md +27 -0
- package/.docs/reference/datasets/addItem.md +37 -0
- package/.docs/reference/datasets/addItems.md +35 -0
- package/.docs/reference/datasets/compareExperiments.md +52 -0
- package/.docs/reference/datasets/create.md +51 -0
- package/.docs/reference/datasets/dataset.md +82 -0
- package/.docs/reference/datasets/datasets-manager.md +94 -0
- package/.docs/reference/datasets/delete.md +25 -0
- package/.docs/reference/datasets/deleteExperiment.md +27 -0
- package/.docs/reference/datasets/deleteItem.md +27 -0
- package/.docs/reference/datasets/deleteItems.md +29 -0
- package/.docs/reference/datasets/get.md +31 -0
- package/.docs/reference/datasets/getDetails.md +47 -0
- package/.docs/reference/datasets/getExperiment.md +30 -0
- package/.docs/reference/datasets/getItem.md +33 -0
- package/.docs/reference/datasets/getItemHistory.md +31 -0
- package/.docs/reference/datasets/list.md +31 -0
- package/.docs/reference/datasets/listExperimentResults.md +39 -0
- package/.docs/reference/datasets/listExperiments.md +33 -0
- package/.docs/reference/datasets/listItems.md +46 -0
- package/.docs/reference/datasets/listVersions.md +33 -0
- package/.docs/reference/datasets/startExperiment.md +62 -0
- package/.docs/reference/datasets/startExperimentAsync.md +43 -0
- package/.docs/reference/datasets/update.md +48 -0
- package/.docs/reference/datasets/updateItem.md +38 -0
- package/.docs/reference/deployer/cloudflare.md +79 -0
- package/.docs/reference/deployer/netlify.md +80 -0
- package/.docs/reference/deployer/vercel.md +91 -0
- package/.docs/reference/deployer.md +100 -0
- package/.docs/reference/evals/answer-relevancy.md +105 -0
- package/.docs/reference/evals/answer-similarity.md +99 -0
- package/.docs/reference/evals/bias.md +120 -0
- package/.docs/reference/evals/completeness.md +136 -0
- package/.docs/reference/evals/content-similarity.md +101 -0
- package/.docs/reference/evals/context-precision.md +196 -0
- package/.docs/reference/evals/context-relevance.md +531 -0
- package/.docs/reference/evals/create-scorer.md +270 -0
- package/.docs/reference/evals/faithfulness.md +114 -0
- package/.docs/reference/evals/hallucination.md +213 -0
- package/.docs/reference/evals/keyword-coverage.md +128 -0
- package/.docs/reference/evals/mastra-scorer.md +123 -0
- package/.docs/reference/evals/noise-sensitivity.md +675 -0
- package/.docs/reference/evals/prompt-alignment.md +614 -0
- package/.docs/reference/evals/run-evals.md +179 -0
- package/.docs/reference/evals/scorer-utils.md +326 -0
- package/.docs/reference/evals/textual-difference.md +113 -0
- package/.docs/reference/evals/tone-consistency.md +119 -0
- package/.docs/reference/evals/tool-call-accuracy.md +533 -0
- package/.docs/reference/evals/toxicity.md +123 -0
- package/.docs/reference/harness/harness-class.md +708 -0
- package/.docs/reference/index.md +277 -0
- package/.docs/reference/logging/pino-logger.md +117 -0
- package/.docs/reference/mastra-code/createMastraCode.md +108 -0
- package/.docs/reference/memory/clone-utilities.md +199 -0
- package/.docs/reference/memory/cloneThread.md +130 -0
- package/.docs/reference/memory/createThread.md +68 -0
- package/.docs/reference/memory/deleteMessages.md +38 -0
- package/.docs/reference/memory/getThreadById.md +24 -0
- package/.docs/reference/memory/listThreads.md +145 -0
- package/.docs/reference/memory/memory-class.md +147 -0
- package/.docs/reference/memory/observational-memory.md +565 -0
- package/.docs/reference/memory/recall.md +91 -0
- package/.docs/reference/observability/tracing/bridges/otel.md +131 -0
- package/.docs/reference/observability/tracing/configuration.md +178 -0
- package/.docs/reference/observability/tracing/exporters/arize.md +141 -0
- package/.docs/reference/observability/tracing/exporters/braintrust.md +93 -0
- package/.docs/reference/observability/tracing/exporters/cloud-exporter.md +163 -0
- package/.docs/reference/observability/tracing/exporters/console-exporter.md +138 -0
- package/.docs/reference/observability/tracing/exporters/datadog.md +116 -0
- package/.docs/reference/observability/tracing/exporters/default-exporter.md +174 -0
- package/.docs/reference/observability/tracing/exporters/laminar.md +78 -0
- package/.docs/reference/observability/tracing/exporters/langfuse.md +134 -0
- package/.docs/reference/observability/tracing/exporters/langsmith.md +108 -0
- package/.docs/reference/observability/tracing/exporters/otel.md +199 -0
- package/.docs/reference/observability/tracing/exporters/posthog.md +92 -0
- package/.docs/reference/observability/tracing/exporters/sentry.md +184 -0
- package/.docs/reference/observability/tracing/instances.md +107 -0
- package/.docs/reference/observability/tracing/interfaces.md +743 -0
- package/.docs/reference/observability/tracing/processors/sensitive-data-filter.md +144 -0
- package/.docs/reference/observability/tracing/spans.md +224 -0
- package/.docs/reference/processors/batch-parts-processor.md +61 -0
- package/.docs/reference/processors/language-detector.md +82 -0
- package/.docs/reference/processors/message-history-processor.md +85 -0
- package/.docs/reference/processors/moderation-processor.md +104 -0
- package/.docs/reference/processors/pii-detector.md +108 -0
- package/.docs/reference/processors/processor-interface.md +521 -0
- package/.docs/reference/processors/prompt-injection-detector.md +72 -0
- package/.docs/reference/processors/semantic-recall-processor.md +117 -0
- package/.docs/reference/processors/system-prompt-scrubber.md +80 -0
- package/.docs/reference/processors/token-limiter-processor.md +115 -0
- package/.docs/reference/processors/tool-call-filter.md +85 -0
- package/.docs/reference/processors/tool-search-processor.md +111 -0
- package/.docs/reference/processors/unicode-normalizer.md +62 -0
- package/.docs/reference/processors/working-memory-processor.md +152 -0
- package/.docs/reference/rag/chunk.md +221 -0
- package/.docs/reference/rag/database-config.md +261 -0
- package/.docs/reference/rag/document.md +114 -0
- package/.docs/reference/rag/embeddings.md +92 -0
- package/.docs/reference/rag/extract-params.md +168 -0
- package/.docs/reference/rag/graph-rag.md +111 -0
- package/.docs/reference/rag/metadata-filters.md +216 -0
- package/.docs/reference/rag/rerank.md +75 -0
- package/.docs/reference/rag/rerankWithScorer.md +80 -0
- package/.docs/reference/server/create-route.md +262 -0
- package/.docs/reference/server/express-adapter.md +176 -0
- package/.docs/reference/server/fastify-adapter.md +90 -0
- package/.docs/reference/server/hono-adapter.md +162 -0
- package/.docs/reference/server/koa-adapter.md +127 -0
- package/.docs/reference/server/mastra-server.md +298 -0
- package/.docs/reference/server/register-api-route.md +249 -0
- package/.docs/reference/server/routes.md +306 -0
- package/.docs/reference/storage/cloudflare-d1.md +218 -0
- package/.docs/reference/storage/cloudflare.md +88 -0
- package/.docs/reference/storage/composite.md +235 -0
- package/.docs/reference/storage/convex.md +161 -0
- package/.docs/reference/storage/dynamodb.md +282 -0
- package/.docs/reference/storage/lance.md +131 -0
- package/.docs/reference/storage/libsql.md +135 -0
- package/.docs/reference/storage/mongodb.md +262 -0
- package/.docs/reference/storage/mssql.md +157 -0
- package/.docs/reference/storage/overview.md +121 -0
- package/.docs/reference/storage/postgresql.md +526 -0
- package/.docs/reference/storage/upstash.md +160 -0
- package/.docs/reference/streaming/ChunkType.md +292 -0
- package/.docs/reference/streaming/agents/MastraModelOutput.md +182 -0
- package/.docs/reference/streaming/agents/stream.md +221 -0
- package/.docs/reference/streaming/agents/streamLegacy.md +142 -0
- package/.docs/reference/streaming/workflows/observeStream.md +42 -0
- package/.docs/reference/streaming/workflows/resumeStream.md +61 -0
- package/.docs/reference/streaming/workflows/stream.md +88 -0
- package/.docs/reference/streaming/workflows/timeTravelStream.md +142 -0
- package/.docs/reference/templates/overview.md +194 -0
- package/.docs/reference/tools/create-tool.md +237 -0
- package/.docs/reference/tools/document-chunker-tool.md +89 -0
- package/.docs/reference/tools/graph-rag-tool.md +182 -0
- package/.docs/reference/tools/mcp-client.md +954 -0
- package/.docs/reference/tools/mcp-server.md +1271 -0
- package/.docs/reference/tools/vector-query-tool.md +459 -0
- package/.docs/reference/vectors/astra.md +121 -0
- package/.docs/reference/vectors/chroma.md +264 -0
- package/.docs/reference/vectors/convex.md +300 -0
- package/.docs/reference/vectors/couchbase.md +226 -0
- package/.docs/reference/vectors/duckdb.md +318 -0
- package/.docs/reference/vectors/elasticsearch.md +189 -0
- package/.docs/reference/vectors/lance.md +220 -0
- package/.docs/reference/vectors/libsql.md +305 -0
- package/.docs/reference/vectors/mongodb.md +295 -0
- package/.docs/reference/vectors/opensearch.md +99 -0
- package/.docs/reference/vectors/pg.md +408 -0
- package/.docs/reference/vectors/pinecone.md +168 -0
- package/.docs/reference/vectors/qdrant.md +222 -0
- package/.docs/reference/vectors/s3vectors.md +277 -0
- package/.docs/reference/vectors/turbopuffer.md +157 -0
- package/.docs/reference/vectors/upstash.md +294 -0
- package/.docs/reference/vectors/vectorize.md +147 -0
- package/.docs/reference/voice/azure.md +148 -0
- package/.docs/reference/voice/cloudflare.md +83 -0
- package/.docs/reference/voice/composite-voice.md +121 -0
- package/.docs/reference/voice/deepgram.md +79 -0
- package/.docs/reference/voice/elevenlabs.md +98 -0
- package/.docs/reference/voice/google-gemini-live.md +378 -0
- package/.docs/reference/voice/google.md +228 -0
- package/.docs/reference/voice/mastra-voice.md +311 -0
- package/.docs/reference/voice/murf.md +122 -0
- package/.docs/reference/voice/openai-realtime.md +203 -0
- package/.docs/reference/voice/openai.md +88 -0
- package/.docs/reference/voice/playai.md +80 -0
- package/.docs/reference/voice/sarvam.md +126 -0
- package/.docs/reference/voice/speechify.md +75 -0
- package/.docs/reference/voice/voice.addInstructions.md +55 -0
- package/.docs/reference/voice/voice.addTools.md +67 -0
- package/.docs/reference/voice/voice.answer.md +54 -0
- package/.docs/reference/voice/voice.close.md +51 -0
- package/.docs/reference/voice/voice.connect.md +94 -0
- package/.docs/reference/voice/voice.events.md +37 -0
- package/.docs/reference/voice/voice.getSpeakers.md +129 -0
- package/.docs/reference/voice/voice.listen.md +164 -0
- package/.docs/reference/voice/voice.off.md +54 -0
- package/.docs/reference/voice/voice.on.md +111 -0
- package/.docs/reference/voice/voice.send.md +65 -0
- package/.docs/reference/voice/voice.speak.md +157 -0
- package/.docs/reference/voice/voice.updateConfig.md +60 -0
- package/.docs/reference/workflows/run-methods/cancel.md +86 -0
- package/.docs/reference/workflows/run-methods/restart.md +33 -0
- package/.docs/reference/workflows/run-methods/resume.md +59 -0
- package/.docs/reference/workflows/run-methods/start.md +58 -0
- package/.docs/reference/workflows/run-methods/startAsync.md +67 -0
- package/.docs/reference/workflows/run-methods/timeTravel.md +142 -0
- package/.docs/reference/workflows/run.md +59 -0
- package/.docs/reference/workflows/step.md +119 -0
- package/.docs/reference/workflows/workflow-methods/branch.md +25 -0
- package/.docs/reference/workflows/workflow-methods/commit.md +17 -0
- package/.docs/reference/workflows/workflow-methods/create-run.md +63 -0
- package/.docs/reference/workflows/workflow-methods/dountil.md +25 -0
- package/.docs/reference/workflows/workflow-methods/dowhile.md +25 -0
- package/.docs/reference/workflows/workflow-methods/foreach.md +118 -0
- package/.docs/reference/workflows/workflow-methods/map.md +93 -0
- package/.docs/reference/workflows/workflow-methods/parallel.md +21 -0
- package/.docs/reference/workflows/workflow-methods/sleep.md +35 -0
- package/.docs/reference/workflows/workflow-methods/sleepUntil.md +35 -0
- package/.docs/reference/workflows/workflow-methods/then.md +21 -0
- package/.docs/reference/workflows/workflow.md +157 -0
- package/.docs/reference/workspace/e2b-sandbox.md +289 -0
- package/.docs/reference/workspace/filesystem.md +255 -0
- package/.docs/reference/workspace/gcs-filesystem.md +174 -0
- package/.docs/reference/workspace/local-filesystem.md +343 -0
- package/.docs/reference/workspace/local-sandbox.md +301 -0
- package/.docs/reference/workspace/s3-filesystem.md +175 -0
- package/.docs/reference/workspace/sandbox.md +87 -0
- package/.docs/reference/workspace/workspace-class.md +244 -0
- package/CHANGELOG.md +8 -0
- package/package.json +5 -5
|
@@ -0,0 +1,497 @@
|
|
|
1
|
+
# Integrate Mastra in your Nuxt project
|
|
2
|
+
|
|
3
|
+
In this guide, you'll build a tool-calling AI agent using Mastra, then connect it to Nuxt by importing and calling the agent directly from your server routes.
|
|
4
|
+
|
|
5
|
+
You'll use [AI SDK UI](https://ai-sdk.dev/docs/ai-sdk-ui/overview) to create a beautiful, interactive chat experience with Vue.
|
|
6
|
+
|
|
7
|
+
## Before you begin
|
|
8
|
+
|
|
9
|
+
- You'll need an API key from a supported [model provider](https://mastra.ai/models). If you don't have a preference, use [OpenAI](https://mastra.ai/models/providers/openai).
|
|
10
|
+
- Install Node.js `v22.13.0` or later
|
|
11
|
+
|
|
12
|
+
## Create a new Nuxt app (optional)
|
|
13
|
+
|
|
14
|
+
If you already have a Nuxt app, skip to the next step.
|
|
15
|
+
|
|
16
|
+
Run the following command to [create a new Nuxt app](https://nuxt.com/docs/getting-started/installation):
|
|
17
|
+
|
|
18
|
+
**npm**:
|
|
19
|
+
|
|
20
|
+
```bash
|
|
21
|
+
npm create nuxt@latest mastra-nuxt -- --template minimal --packageManager npm --gitInit --modules
|
|
22
|
+
```
|
|
23
|
+
|
|
24
|
+
**pnpm**:
|
|
25
|
+
|
|
26
|
+
```bash
|
|
27
|
+
pnpm create nuxt mastra-nuxt --template minimal --packageManager npm --gitInit --modules
|
|
28
|
+
```
|
|
29
|
+
|
|
30
|
+
**Yarn**:
|
|
31
|
+
|
|
32
|
+
```bash
|
|
33
|
+
yarn create nuxt mastra-nuxt --template minimal --packageManager npm --gitInit --modules
|
|
34
|
+
```
|
|
35
|
+
|
|
36
|
+
**Bun**:
|
|
37
|
+
|
|
38
|
+
```bash
|
|
39
|
+
bunx create-nuxt mastra-nuxt --template minimal --packageManager npm --gitInit --modules
|
|
40
|
+
```
|
|
41
|
+
|
|
42
|
+
This creates a project called `mastra-nuxt`, but you can replace it with any name you want.
|
|
43
|
+
|
|
44
|
+
## Initialize Mastra
|
|
45
|
+
|
|
46
|
+
Navigate to your Nuxt project:
|
|
47
|
+
|
|
48
|
+
```bash
|
|
49
|
+
cd mastra-nuxt
|
|
50
|
+
```
|
|
51
|
+
|
|
52
|
+
Run [`mastra init`](https://mastra.ai/reference/cli/mastra). When prompted, choose a provider (e.g. OpenAI) and enter your key:
|
|
53
|
+
|
|
54
|
+
**npm**:
|
|
55
|
+
|
|
56
|
+
```bash
|
|
57
|
+
npx mastra@latest init
|
|
58
|
+
```
|
|
59
|
+
|
|
60
|
+
**pnpm**:
|
|
61
|
+
|
|
62
|
+
```bash
|
|
63
|
+
pnpm dlx mastra@latest init
|
|
64
|
+
```
|
|
65
|
+
|
|
66
|
+
**Yarn**:
|
|
67
|
+
|
|
68
|
+
```bash
|
|
69
|
+
yarn dlx mastra@latest init
|
|
70
|
+
```
|
|
71
|
+
|
|
72
|
+
**Bun**:
|
|
73
|
+
|
|
74
|
+
```bash
|
|
75
|
+
bun x mastra@latest init
|
|
76
|
+
```
|
|
77
|
+
|
|
78
|
+
This creates a `mastra` folder with an example weather agent and the following files:
|
|
79
|
+
|
|
80
|
+
- `index.ts` - Mastra config, including memory
|
|
81
|
+
- `tools/weather-tool.ts` - a tool to fetch weather for a given location
|
|
82
|
+
- `agents/weather-agent.ts`- a weather agent with a prompt that uses the tool
|
|
83
|
+
|
|
84
|
+
You'll call `weather-agent.ts` from your Nuxt server routes in the next steps.
|
|
85
|
+
|
|
86
|
+
## Install AI SDK UI
|
|
87
|
+
|
|
88
|
+
Install AI SDK UI along with the Mastra adapter:
|
|
89
|
+
|
|
90
|
+
**npm**:
|
|
91
|
+
|
|
92
|
+
```bash
|
|
93
|
+
npm install @mastra/ai-sdk@latest @ai-sdk/vue ai
|
|
94
|
+
```
|
|
95
|
+
|
|
96
|
+
**pnpm**:
|
|
97
|
+
|
|
98
|
+
```bash
|
|
99
|
+
pnpm add @mastra/ai-sdk@latest @ai-sdk/vue ai
|
|
100
|
+
```
|
|
101
|
+
|
|
102
|
+
**Yarn**:
|
|
103
|
+
|
|
104
|
+
```bash
|
|
105
|
+
yarn add @mastra/ai-sdk@latest @ai-sdk/vue ai
|
|
106
|
+
```
|
|
107
|
+
|
|
108
|
+
**Bun**:
|
|
109
|
+
|
|
110
|
+
```bash
|
|
111
|
+
bun add @mastra/ai-sdk@latest @ai-sdk/vue ai
|
|
112
|
+
```
|
|
113
|
+
|
|
114
|
+
## Create a chat route
|
|
115
|
+
|
|
116
|
+
Create `server/api/chat.ts`:
|
|
117
|
+
|
|
118
|
+
```ts
|
|
119
|
+
import { handleChatStream } from '@mastra/ai-sdk'
|
|
120
|
+
import { toAISdkV5Messages } from '@mastra/ai-sdk/ui'
|
|
121
|
+
import { createUIMessageStreamResponse } from 'ai'
|
|
122
|
+
import { mastra } from '../../src/mastra'
|
|
123
|
+
|
|
124
|
+
const THREAD_ID = 'example-user-id'
|
|
125
|
+
const RESOURCE_ID = 'weather-chat'
|
|
126
|
+
|
|
127
|
+
export default defineEventHandler(async event => {
|
|
128
|
+
const method = event.method
|
|
129
|
+
|
|
130
|
+
if (method === 'POST') {
|
|
131
|
+
const params = await readBody(event)
|
|
132
|
+
const stream = await handleChatStream({
|
|
133
|
+
mastra,
|
|
134
|
+
agentId: 'weather-agent',
|
|
135
|
+
params: {
|
|
136
|
+
...params,
|
|
137
|
+
memory: {
|
|
138
|
+
...params.memory,
|
|
139
|
+
thread: THREAD_ID,
|
|
140
|
+
resource: RESOURCE_ID,
|
|
141
|
+
},
|
|
142
|
+
},
|
|
143
|
+
})
|
|
144
|
+
|
|
145
|
+
return createUIMessageStreamResponse({ stream })
|
|
146
|
+
}
|
|
147
|
+
|
|
148
|
+
if (method === 'GET') {
|
|
149
|
+
const memory = await mastra.getAgentById('weather-agent').getMemory()
|
|
150
|
+
let response = null
|
|
151
|
+
|
|
152
|
+
try {
|
|
153
|
+
response = await memory?.recall({
|
|
154
|
+
threadId: THREAD_ID,
|
|
155
|
+
resourceId: RESOURCE_ID,
|
|
156
|
+
})
|
|
157
|
+
} catch {
|
|
158
|
+
console.log('No previous messages found.')
|
|
159
|
+
}
|
|
160
|
+
|
|
161
|
+
const uiMessages = toAISdkV5Messages(response?.messages || [])
|
|
162
|
+
|
|
163
|
+
return uiMessages
|
|
164
|
+
}
|
|
165
|
+
})
|
|
166
|
+
```
|
|
167
|
+
|
|
168
|
+
The `POST` handler accepts a prompt and streams the agent's response back in AI SDK format, while the `GET` handler fetches message history from memory so the UI can be hydrated when the client reloads.
|
|
169
|
+
|
|
170
|
+
## Add the chat UI
|
|
171
|
+
|
|
172
|
+
Replace the contents of `app/app.vue` with the following:
|
|
173
|
+
|
|
174
|
+
```html
|
|
175
|
+
<script setup lang="ts">
|
|
176
|
+
import { ref, onMounted } from 'vue'
|
|
177
|
+
import { Chat } from '@ai-sdk/vue'
|
|
178
|
+
import { DefaultChatTransport, type ToolUIPart } from 'ai'
|
|
179
|
+
|
|
180
|
+
const chat = new Chat({
|
|
181
|
+
transport: new DefaultChatTransport({
|
|
182
|
+
api: '/api/chat',
|
|
183
|
+
}),
|
|
184
|
+
})
|
|
185
|
+
|
|
186
|
+
const STATE_TO_LABEL_MAP: Record<string, string> = {
|
|
187
|
+
'input-streaming': 'Pending',
|
|
188
|
+
'input-available': 'Running',
|
|
189
|
+
'output-available': 'Completed',
|
|
190
|
+
'output-error': 'Error',
|
|
191
|
+
'output-denied': 'Denied',
|
|
192
|
+
}
|
|
193
|
+
|
|
194
|
+
const input = ref('')
|
|
195
|
+
|
|
196
|
+
onMounted(async () => {
|
|
197
|
+
const res = await fetch('/api/chat')
|
|
198
|
+
const data = await res.json()
|
|
199
|
+
chat.messages = [...data]
|
|
200
|
+
})
|
|
201
|
+
|
|
202
|
+
function handleSubmit() {
|
|
203
|
+
if (!input.value.trim()) return
|
|
204
|
+
|
|
205
|
+
chat.sendMessage({ text: input.value })
|
|
206
|
+
input.value = ''
|
|
207
|
+
}
|
|
208
|
+
</script>
|
|
209
|
+
|
|
210
|
+
<template>
|
|
211
|
+
<div class="chat-container">
|
|
212
|
+
<div class="messages">
|
|
213
|
+
<div v-for="message in chat.messages" :key="message.id" class="message-wrapper">
|
|
214
|
+
<div v-for="(part, i) in message.parts" :key="`${message.id}-${i}`">
|
|
215
|
+
<div v-if="part.type === 'text'" :class="['message', message.role]">
|
|
216
|
+
<div class="message-content">{{ part.text }}</div>
|
|
217
|
+
</div>
|
|
218
|
+
|
|
219
|
+
<details v-else-if="part.type?.startsWith('tool-')" class="tool">
|
|
220
|
+
<summary class="tool-header">
|
|
221
|
+
{{ (part as ToolUIPart).type?.split('-').slice(1).join('-') }} - {{
|
|
222
|
+
STATE_TO_LABEL_MAP[(part as ToolUIPart).state ?? 'output-available'] }}
|
|
223
|
+
</summary>
|
|
224
|
+
<div class="tool-content">
|
|
225
|
+
<div class="tool-section">
|
|
226
|
+
<div class="tool-label">Parameters</div>
|
|
227
|
+
<pre><code>{{ JSON.stringify((part as ToolUIPart).input, null, 2) }}</code></pre>
|
|
228
|
+
</div>
|
|
229
|
+
<div class="tool-section">
|
|
230
|
+
<div class="tool-label">
|
|
231
|
+
{{ (part as ToolUIPart).errorText ? 'Error' : 'Result' }}
|
|
232
|
+
</div>
|
|
233
|
+
<pre><code>{{ JSON.stringify((part as ToolUIPart).output, null, 2) }}</code></pre>
|
|
234
|
+
<div v-if="(part as ToolUIPart).errorText" class="tool-error">
|
|
235
|
+
{{ (part as ToolUIPart).errorText }}
|
|
236
|
+
</div>
|
|
237
|
+
</div>
|
|
238
|
+
</div>
|
|
239
|
+
</details>
|
|
240
|
+
</div>
|
|
241
|
+
</div>
|
|
242
|
+
</div>
|
|
243
|
+
|
|
244
|
+
<form class="input-form" @submit.prevent="handleSubmit">
|
|
245
|
+
<input
|
|
246
|
+
v-model="input"
|
|
247
|
+
type="text"
|
|
248
|
+
placeholder="Ask about the weather..."
|
|
249
|
+
:disabled="chat.status !== 'ready'"
|
|
250
|
+
class="chat-input"
|
|
251
|
+
/>
|
|
252
|
+
<button type="submit" class="submit-button" :disabled="chat.status !== 'ready'">Send</button>
|
|
253
|
+
</form>
|
|
254
|
+
</div>
|
|
255
|
+
</template>
|
|
256
|
+
|
|
257
|
+
<style>
|
|
258
|
+
*,
|
|
259
|
+
*::before,
|
|
260
|
+
*::after {
|
|
261
|
+
box-sizing: border-box;
|
|
262
|
+
}
|
|
263
|
+
|
|
264
|
+
*:not(dialog) {
|
|
265
|
+
margin: 0;
|
|
266
|
+
}
|
|
267
|
+
|
|
268
|
+
@media (prefers-reduced-motion: no-preference) {
|
|
269
|
+
html {
|
|
270
|
+
interpolate-size: allow-keywords;
|
|
271
|
+
}
|
|
272
|
+
}
|
|
273
|
+
|
|
274
|
+
html {
|
|
275
|
+
font-family:
|
|
276
|
+
-apple-system,
|
|
277
|
+
BlinkMacSystemFont,
|
|
278
|
+
avenir next,
|
|
279
|
+
avenir,
|
|
280
|
+
segoe ui,
|
|
281
|
+
helvetica neue,
|
|
282
|
+
Adwaita Sans,
|
|
283
|
+
Cantarell,
|
|
284
|
+
Ubuntu,
|
|
285
|
+
roboto,
|
|
286
|
+
noto,
|
|
287
|
+
helvetica,
|
|
288
|
+
arial,
|
|
289
|
+
sans-serif;
|
|
290
|
+
}
|
|
291
|
+
|
|
292
|
+
body {
|
|
293
|
+
line-height: 1.5;
|
|
294
|
+
-webkit-font-smoothing: antialiased;
|
|
295
|
+
}
|
|
296
|
+
|
|
297
|
+
img,
|
|
298
|
+
picture,
|
|
299
|
+
video,
|
|
300
|
+
canvas,
|
|
301
|
+
svg {
|
|
302
|
+
display: block;
|
|
303
|
+
max-width: 100%;
|
|
304
|
+
}
|
|
305
|
+
|
|
306
|
+
input,
|
|
307
|
+
button,
|
|
308
|
+
textarea,
|
|
309
|
+
select {
|
|
310
|
+
font: inherit;
|
|
311
|
+
}
|
|
312
|
+
|
|
313
|
+
p,
|
|
314
|
+
h1,
|
|
315
|
+
h2,
|
|
316
|
+
h3,
|
|
317
|
+
h4,
|
|
318
|
+
h5,
|
|
319
|
+
h6 {
|
|
320
|
+
overflow-wrap: break-word;
|
|
321
|
+
}
|
|
322
|
+
|
|
323
|
+
p {
|
|
324
|
+
text-wrap: pretty;
|
|
325
|
+
}
|
|
326
|
+
h1,
|
|
327
|
+
h2,
|
|
328
|
+
h3,
|
|
329
|
+
h4,
|
|
330
|
+
h5,
|
|
331
|
+
h6 {
|
|
332
|
+
text-wrap: balance;
|
|
333
|
+
}
|
|
334
|
+
|
|
335
|
+
.chat-container {
|
|
336
|
+
max-width: 48rem;
|
|
337
|
+
margin: 0 auto;
|
|
338
|
+
padding: 1.5rem;
|
|
339
|
+
height: 100vh;
|
|
340
|
+
display: flex;
|
|
341
|
+
flex-direction: column;
|
|
342
|
+
}
|
|
343
|
+
|
|
344
|
+
.messages {
|
|
345
|
+
flex: 1;
|
|
346
|
+
overflow-y: auto;
|
|
347
|
+
display: flex;
|
|
348
|
+
flex-direction: column;
|
|
349
|
+
gap: 1rem;
|
|
350
|
+
}
|
|
351
|
+
|
|
352
|
+
.message-wrapper {
|
|
353
|
+
display: flex;
|
|
354
|
+
flex-direction: column;
|
|
355
|
+
gap: 0.5rem;
|
|
356
|
+
}
|
|
357
|
+
|
|
358
|
+
.message {
|
|
359
|
+
padding: 0.75rem 1rem;
|
|
360
|
+
border-radius: 0.5rem;
|
|
361
|
+
}
|
|
362
|
+
|
|
363
|
+
.message.user {
|
|
364
|
+
background-color: #3b82f6;
|
|
365
|
+
color: white;
|
|
366
|
+
margin-left: auto;
|
|
367
|
+
max-width: 60%;
|
|
368
|
+
}
|
|
369
|
+
|
|
370
|
+
.message.assistant {
|
|
371
|
+
background-color: #f3f4f6;
|
|
372
|
+
color: #1f2937;
|
|
373
|
+
max-width: 80%;
|
|
374
|
+
}
|
|
375
|
+
|
|
376
|
+
.tool {
|
|
377
|
+
border: 1px solid #d1d5db;
|
|
378
|
+
border-radius: 0.5rem;
|
|
379
|
+
margin: 0.5rem 0;
|
|
380
|
+
overflow: hidden;
|
|
381
|
+
}
|
|
382
|
+
|
|
383
|
+
.tool-header {
|
|
384
|
+
padding: 0.75rem 1rem;
|
|
385
|
+
background-color: #f9fafb;
|
|
386
|
+
cursor: pointer;
|
|
387
|
+
font-weight: 500;
|
|
388
|
+
font-size: 0.875rem;
|
|
389
|
+
}
|
|
390
|
+
|
|
391
|
+
.tool-content {
|
|
392
|
+
padding: 1rem;
|
|
393
|
+
border-top: 1px solid #d1d5db;
|
|
394
|
+
}
|
|
395
|
+
|
|
396
|
+
.tool-section {
|
|
397
|
+
margin-bottom: 1rem;
|
|
398
|
+
}
|
|
399
|
+
|
|
400
|
+
.tool-section:last-child {
|
|
401
|
+
margin-bottom: 0;
|
|
402
|
+
}
|
|
403
|
+
|
|
404
|
+
.tool-label {
|
|
405
|
+
font-size: 0.75rem;
|
|
406
|
+
font-weight: 500;
|
|
407
|
+
text-transform: uppercase;
|
|
408
|
+
color: #6b7280;
|
|
409
|
+
margin-bottom: 0.5rem;
|
|
410
|
+
}
|
|
411
|
+
|
|
412
|
+
.tool pre {
|
|
413
|
+
background-color: #f3f4f6;
|
|
414
|
+
padding: 0.75rem;
|
|
415
|
+
border-radius: 0.375rem;
|
|
416
|
+
overflow-x: auto;
|
|
417
|
+
font-size: 0.875rem;
|
|
418
|
+
}
|
|
419
|
+
|
|
420
|
+
.tool-error {
|
|
421
|
+
color: #dc2626;
|
|
422
|
+
margin-top: 0.5rem;
|
|
423
|
+
}
|
|
424
|
+
|
|
425
|
+
.input-form {
|
|
426
|
+
display: grid;
|
|
427
|
+
grid-template-columns: 1fr auto;
|
|
428
|
+
gap: 0.75rem;
|
|
429
|
+
padding-top: 1rem;
|
|
430
|
+
border-top: 1px solid #e5e7eb;
|
|
431
|
+
margin-top: 1rem;
|
|
432
|
+
}
|
|
433
|
+
|
|
434
|
+
.chat-input {
|
|
435
|
+
padding: 0.75rem 1rem;
|
|
436
|
+
border: 1px solid #d1d5db;
|
|
437
|
+
border-radius: 0.5rem;
|
|
438
|
+
font-size: 1rem;
|
|
439
|
+
}
|
|
440
|
+
|
|
441
|
+
.chat-input:focus {
|
|
442
|
+
outline: none;
|
|
443
|
+
border-color: #3b82f6;
|
|
444
|
+
box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
|
|
445
|
+
}
|
|
446
|
+
|
|
447
|
+
.chat-input:disabled {
|
|
448
|
+
background-color: #f3f4f6;
|
|
449
|
+
cursor: not-allowed;
|
|
450
|
+
}
|
|
451
|
+
|
|
452
|
+
.submit-button {
|
|
453
|
+
padding: 0.75rem 1.5rem;
|
|
454
|
+
background-color: #3b82f6;
|
|
455
|
+
color: white;
|
|
456
|
+
border: none;
|
|
457
|
+
border-radius: 0.5rem;
|
|
458
|
+
font-weight: 500;
|
|
459
|
+
cursor: pointer;
|
|
460
|
+
transition: background-color 0.2s;
|
|
461
|
+
}
|
|
462
|
+
|
|
463
|
+
.submit-button:hover:not(:disabled) {
|
|
464
|
+
background-color: #2563eb;
|
|
465
|
+
}
|
|
466
|
+
|
|
467
|
+
.submit-button:disabled {
|
|
468
|
+
background-color: #9ca3af;
|
|
469
|
+
cursor: not-allowed;
|
|
470
|
+
}
|
|
471
|
+
</style>
|
|
472
|
+
```
|
|
473
|
+
|
|
474
|
+
This component connects [`Chat()`](https://ai-sdk.dev/docs/reference/ai-sdk-ui/use-chat) to the `/api/chat` endpoint, sending prompts there and streaming the response back in chunks.
|
|
475
|
+
|
|
476
|
+
It renders the response text using custom message styling and shows any tool invocations in a collapsible details element.
|
|
477
|
+
|
|
478
|
+
## Test your agent
|
|
479
|
+
|
|
480
|
+
1. Run your Nuxt app with `npm run dev`
|
|
481
|
+
2. Open the chat at <http://localhost:3000>
|
|
482
|
+
3. Try asking about the weather. If your API key is set up correctly, you'll get a response
|
|
483
|
+
|
|
484
|
+
## Next steps
|
|
485
|
+
|
|
486
|
+
Congratulations on building your Mastra agent with Nuxt! 🎉
|
|
487
|
+
|
|
488
|
+
From here, you can extend the project with your own tools and logic:
|
|
489
|
+
|
|
490
|
+
- Learn more about [agents](https://mastra.ai/docs/agents/overview)
|
|
491
|
+
- Give your agent its own [tools](https://mastra.ai/docs/agents/using-tools)
|
|
492
|
+
- Add human-like [memory](https://mastra.ai/docs/agents/agent-memory) to your agent
|
|
493
|
+
|
|
494
|
+
When you're ready, read more about how Mastra integrates with AI SDK UI and Nuxt, and how to deploy your agent anywhere:
|
|
495
|
+
|
|
496
|
+
- Integrate Mastra with [AI SDK UI](https://mastra.ai/guides/build-your-ui/ai-sdk-ui)
|
|
497
|
+
- Deploy your agent [anywhere](https://mastra.ai/docs/deployment/overview)
|
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
# Mastra Quickstart
|
|
2
|
+
|
|
3
|
+
The `create mastra` CLI command is the quickest way to get started. It walks you through setup and creates example agents, workflows, and tools for you to run locally or adapt.
|
|
4
|
+
|
|
5
|
+
If you need more control over the setup, see the [manual installation guide](https://mastra.ai/docs/getting-started/manual-install). You can also use [`mastra init`](https://mastra.ai/reference/cli/mastra) for existing projects.
|
|
6
|
+
|
|
7
|
+
## Before you begin
|
|
8
|
+
|
|
9
|
+
- You'll need an API key from a supported [model provider](https://mastra.ai/models). If you don't have a preference, use [OpenAI](https://mastra.ai/models/providers/openai).
|
|
10
|
+
|
|
11
|
+
## Initialize Mastra
|
|
12
|
+
|
|
13
|
+
You can run `create mastra` anywhere on your machine.
|
|
14
|
+
|
|
15
|
+
When prompted, choose a provider (e.g. OpenAI) and enter your key:
|
|
16
|
+
|
|
17
|
+
**npm**:
|
|
18
|
+
|
|
19
|
+
```bash
|
|
20
|
+
npm create mastra@latest
|
|
21
|
+
```
|
|
22
|
+
|
|
23
|
+
**pnpm**:
|
|
24
|
+
|
|
25
|
+
```bash
|
|
26
|
+
pnpm create mastra
|
|
27
|
+
```
|
|
28
|
+
|
|
29
|
+
**Yarn**:
|
|
30
|
+
|
|
31
|
+
```bash
|
|
32
|
+
yarn create mastra
|
|
33
|
+
```
|
|
34
|
+
|
|
35
|
+
**Bun**:
|
|
36
|
+
|
|
37
|
+
```bash
|
|
38
|
+
bunx create-mastra
|
|
39
|
+
```
|
|
40
|
+
|
|
41
|
+
This creates a new directory for your project with a `src/mastra` folder containing an example weather agent and the following files:
|
|
42
|
+
|
|
43
|
+
- `index.ts`: Entry point for all Mastra-related code and configuration
|
|
44
|
+
- `agents/weather-agent.ts`: A weather agent with a prompt that uses the tool
|
|
45
|
+
- `tools/weather-tool.ts`: A tool to fetch weather for a given location
|
|
46
|
+
- `workflows/weather-workflow.ts`: A workflow that runs the weather agent
|
|
47
|
+
- `scorers/weather-scorer.ts`: A scorer to evaluate the weather agent's responses
|
|
48
|
+
|
|
49
|
+
Depending on your choices, you'll also end up with [Mastra Skills](https://mastra.ai/docs/build-with-ai/skills) or the [MCP Docs Server](https://mastra.ai/docs/build-with-ai/mcp-docs-server) installed.
|
|
50
|
+
|
|
51
|
+
> **Tip:** You can use [flags](https://mastra.ai/reference/cli/create-mastra) with `create mastra` like `--no-example` to skip the example weather agent or `--template` to start from a specific [template](https://mastra.ai/templates).
|
|
52
|
+
|
|
53
|
+
## Test your agent
|
|
54
|
+
|
|
55
|
+
Once setup is complete, follow the instructions in your terminal to start the Mastra dev server, then open Studio at [localhost:4111](http://localhost:4111).
|
|
56
|
+
|
|
57
|
+
Try asking about the weather. If your API key is set up correctly, you'll get a response:
|
|
58
|
+
|
|
59
|
+
[Studio](https://mastra.ai/docs/getting-started/studio) lets you rapidly build and prototype agents without needing to build a UI. Once you're ready, you can integrate your Mastra agent into your app using the guides below.
|
|
60
|
+
|
|
61
|
+
## Next steps
|
|
62
|
+
|
|
63
|
+
- Integrate Mastra with your frontend framework: [Next.js](https://mastra.ai/guides/getting-started/next-js), [React](https://mastra.ai/guides/getting-started/vite-react), or [Astro](https://mastra.ai/guides/getting-started/astro)
|
|
64
|
+
- Read more about [Mastra's features](https://mastra.ai/docs)
|
|
65
|
+
- Learn how you can [build Mastra with AI](https://mastra.ai/docs/getting-started/build-with-ai)
|
|
66
|
+
- Build an agent from scratch following one of our [guides](https://mastra.ai/guides)
|
|
67
|
+
- Watch conceptual guides on our [YouTube channel](https://www.youtube.com/@mastra-ai) and [subscribe](https://www.youtube.com/@mastra-ai?sub_confirmation=1)
|