tools/integrations/sanity.md
Headless CMS with real-time collaboration, GROQ query language, and schema-as-code.
| Integration | Available | Notes |
|---|---|---|
| API | ✓ | GROQ queries, Mutations API, Assets API |
| MCP | - | No official MCP server |
| CLI | ✓ | sanity CLI for studio, datasets, deployment |
| SDK | ✓ | @sanity/client, next-sanity, @sanity/image-url |
Authorization: Bearer skXXXXXXURL-encode the query parameter value in practice.
GET https://{projectId}.api.sanity.io/v2024-01-01/data/query/{dataset}?query=*[_type == "post"]{title, slug, publishedAt}
GET https://{projectId}.api.sanity.io/v2024-01-01/data/query/{dataset}?query=*[_type == "post" && slug.current == $slug][0]&$slug="my-post"
GET https://{projectId}.api.sanity.io/v2024-01-01/data/doc/{dataset}/{documentId}
POST https://{projectId}.api.sanity.io/v2024-01-01/data/mutate/{dataset}
{
"mutations": [
{
"create": {
"_type": "post",
"title": "New Post",
"slug": {"_type": "slug", "current": "new-post"},
"body": [{"_type": "block", "children": [{"_type": "span", "text": "Hello"}]}]
}
}
]
}
Use createOrReplace instead if you want to upsert (requires _id field).
POST https://{projectId}.api.sanity.io/v2024-01-01/data/mutate/{dataset}
{
"mutations": [
{"delete": {"id": "document-id"}}
]
}
POST https://{projectId}.api.sanity.io/v2024-01-01/data/mutate/{dataset}
{
"mutations": [
{
"patch": {
"id": "document-id",
"set": {"title": "Updated Title"}
}
}
]
}
# Create a new Sanity project
sanity init
# Start the studio locally
sanity dev
# Deploy studio to Sanity hosting
sanity deploy
# Export dataset
sanity dataset export production ./backup.tar.gz
# Import dataset
sanity dataset import ./data.ndjson production
# List datasets
sanity dataset list
# Run a GROQ query
sanity documents query '*[_type == "post"][0..9]{title, slug}'
_id, _type, _rev{_type: "reference", _ref: "doc-id"})production, staging){_type: "slug", current: "my-slug"})Rate limits vary by plan. Documented defaults: