plugins/mastra/skills/use-mastra/SKILL.md
Answer questions about the Mastra AI framework and help build agents, workflows, tools, memory, and RAG features. Use when developers: (1) ask about Mastra APIs like `Mastra`, `Agent`, `createWorkflow`, `createTool`, `createStep`, `Memory`, or run the `mastra` CLI; (2) wire up agents, workflows, or step-based orchestration; (3) integrate `@mastra/*` packages (`@mastra/core`, `@mastra/memory`, `@mastra/rag`, `@mastra/evals`, `@mastra/deployer`, `@mastra/server`, `@mastra/pg`, `@mastra/libsql`, `@mastra/mcp`); (4) debug TypeScript errors from Mastra APIs or model-router strings. Triggers on: "Mastra", "@mastra/core", "mastra agent", "mastra workflow", "createWorkflow", "createTool", "createStep", "mastra memory", "semantic recall", "mastra rag", "mastra deployer", "mastra evals", "mastra studio", "provider/model".
npx skillsauth add pleaseai/claude-code-plugins use-mastraInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
Before writing Mastra code, verify the relevant package is installed in the current project:
ls node_modules/mastra 2>/dev/null # CLI + project scaffolding + platform API
ls node_modules/@mastra/ 2>/dev/null # scoped packages (core, memory, rag, ...)
If the needed package is missing, install only what the task requires using the project's package manager (detect via lockfile):
# root CLI / platform (only when invoking `mastra dev`, `mastra build`, etc.)
pnpm add mastra # or: bun add mastra / npm i mastra / yarn add mastra
# scoped packages — add what you actually use
pnpm add @mastra/core @mastra/memory @mastra/rag
Do not install packages you do not yet need. Mastra is opinionated about module format — confirm TypeScript target before writing: target: ES2022, module: ES2022, moduleResolution: bundler.
Mastra evolves rapidly. Constructor signatures, exported symbol names, workflow step APIs, memory option shapes, and model-router providers shift between minor versions. Training-data recollection of Mastra APIs is likely wrong.
When working with Mastra:
node_modules/<pkg>/package.json).node_modules/<pkg>/dist/docs/SKILL.md before coding.dist/docs/references/*.md or dist/docs/assets/SOURCE_MAP.json.If documentation cannot be found locally or remotely to back an answer, say so explicitly.
node_modules/Every Mastra package that ships documentation places it at <pkg>/dist/docs/:
node_modules/<pkg>/dist/docs/
├── SKILL.md # package overview + links
├── assets/SOURCE_MAP.json # export → source file mapping
└── references/ # one .md per topic or exported symbol
├── docs-<topic>.md # concept guides
└── reference-<symbol>.md # API reference
Packages confirmed to ship dist/docs/ (v1.6.2 / core 1.27.0 as of 2026-04):
| Package | What it covers |
| --- | --- |
| mastra | CLI commands (mastra dev, mastra build), platform REST API |
| @mastra/core | Mastra, Agent, createTool, createWorkflow, createStep, processors, guardrails, browser/editor |
| @mastra/memory | Memory, threads, working memory, semantic recall, storage |
| @mastra/rag | MDocument, chunking, embeddings, retrieval, GraphRAG, rerankers |
| @mastra/evals | Scorers, datasets, experiments, CI harness |
| @mastra/deployer, @mastra/server | Build / deploy / serve Mastra projects |
| @mastra/pg, @mastra/libsql, @mastra/mcp | Storage adapters, MCP server integration |
See references/packages.md for purpose + SKILL path per package, plus which packages currently lack bundled docs (remote-only).
# 1. Start from the overview shipped with the installed version
cat node_modules/@mastra/core/dist/docs/SKILL.md
# 2. Grep references/ for the topic or symbol
grep -rli "Agent" node_modules/@mastra/core/dist/docs/references/
grep -rli "createWorkflow" node_modules/@mastra/core/dist/docs/references/
# 3. Resolve an exported symbol back to its type definition
cat node_modules/@mastra/core/dist/docs/assets/SOURCE_MAP.json | jq '."Agent"'
cat node_modules/@mastra/core/dist/<path-from-source-map>
If the package is not installed, or a doc is missing from dist/docs/:
https://mastra.ai/llms.txt — index of current docs (fetch and grep).https://mastra.ai/docs/ — full documentation site.@mastra/mcp-docs-server MCP server (configured by this plugin in plugin.json) — returns the same docs over MCP tool calls.Remote docs track main and may be ahead of the installed version; always prefer bundled docs when both are available.
Concise map of what each package exports and where its docs live. Full table with docs paths and verification notes: references/packages.md.
| Need | Package | Typical import |
| --- | --- | --- |
| Mastra, Agent, createTool, createWorkflow, createStep | @mastra/core | @mastra/core, @mastra/core/agent, @mastra/core/workflows, @mastra/core/tools |
| Threads, working memory, semantic recall | @mastra/memory | @mastra/memory |
| RAG pipeline — chunk, embed, retrieve, rerank | @mastra/rag | @mastra/rag |
| Scorers, datasets, experiments | @mastra/evals | @mastra/evals |
| Postgres / LibSQL storage + vectors | @mastra/pg, @mastra/libsql | @mastra/pg, @mastra/libsql |
| MCP server integration | @mastra/mcp | @mastra/mcp |
| CLI + Studio + platform API | mastra | mastra (dev dependency for CLI; runtime for platform clients) |
| Build & deploy | @mastra/deployer, @mastra/server | usually only invoked via CLI |
Concise recipes — each one ends with "verify against dist/docs/ before shipping": references/agents-and-workflows.md.
Rules of thumb:
Agent for open-ended tasks (research, chat, triage). Use createWorkflow + createStep for deterministic pipelines with a fixed shape and explicit state.Mastra. Tools, agents, workflows, storage, and logger all hang off a single Mastra instance. Passing tools to an agent without also registering them on Mastra is a common bug.provider/model (e.g. openai/gpt-5.4, anthropic/claude-sonnet-4-5). Never bare model IDs. The provider-registry script shipped with the existing mastra skill (plugins/mastra/.agents/skills/mastra/scripts/provider-registry.mjs) enumerates valid provider keys and current model names — run it before generating code that references a model..commit() is required on workflows. Forgetting it is the #1 cause of Cannot read property 'then' of undefined.threadId + resourceId must be stable across turns for memory to persist.pnpm tsc --noEmit (or bun tsc --noEmit, npm run typecheck).Before searching source code, grep references/common-errors.md for the failing symptom. It indexes the most frequent Mastra failure modes (ESM/CJS mismatch, tools registered but not called, memory without storage, semantic recall without a vector store, workflow missing .commit(), invalid model string, wrong threadId) against the canonical fix.
If the symptom is not listed:
# resolve the error string inside installed source
rg -n "error string fragment" node_modules/@mastra/core/dist
rg -n "error string fragment" node_modules/@mastra/<subpkg>/dist
mastra skillThis plugin ships a separate, richer primer at plugins/mastra/.agents/skills/mastra/SKILL.md (v2.0.0, sourced from mastra-ai/skills). That skill is a framework primer — concepts, doc-lookup strategy, upgrade guides, migration notes, extensive common-errors coverage.
use-mastra is the task-triggered workflow skill — concise, trigger-heavy, focused on redirecting agents to version-accurate dist/docs/ and stopping training-data hallucinations. The two are complementary; Claude Code will auto-activate whichever matches the task framing.
When in doubt, read the primer first (plugins/mastra/.agents/skills/mastra/SKILL.md) and use this skill's references for quick per-package lookup paths and concise recipes.
references/packages.md — every Mastra package, its purpose, and the exact dist/docs/ path to readreferences/agents-and-workflows.md — canonical recipes: agent with tools + memory, workflow with steps, Mastra-instance registrationreferences/common-errors.md — symptom → cause → fix for the most frequent Mastra failuresdevelopment
RTK (Rust Token Killer) reduces LLM token consumption by 60-90% by filtering and compressing command outputs. Use when user asks about token savings, token optimization, RTK usage, `rtk gain`, `rtk discover`, or `rtk proxy`. Triggers on mentions of token reduction, RTK commands, or checking command cost.
tools
Semantic code search using the Semble MCP server. Use when exploring an unfamiliar codebase, finding code by what it does rather than exact text, locating an implementation, understanding how a feature works, or discovering related code. Triggers on requests like "where is X handled", "find the code that does Y", "how does Z work", "search the codebase for", or any semantic/exploratory code question where grep's literal matching is a poor fit.
development
Get best practices for developing applications with Spring Boot.
development
Get best practices for JUnit 5 unit testing, including data-driven tests