The Storyblok MCP Server enables users to manage Storyblok CMS content seamlessly using natural language interactions with AI tools. Capabilities include:
- Content Management: Create, read, update, and delete stories; manage publish status; access and restore versions; search with advanced filters
- Tag Management: Create, list, delete tags and assign them to stories
- Release Management: Create, publish, add stories to, and delete releases
- Asset Handling: Upload, fetch, and delete assets; manage asset folders
- Component Management: Create, update, and delete components (content types)
- Data & Configuration: Manage folders, datasources, and datasource entries; access space information
- AI-Powered Features: Generate alt text and meta tags; auto-tag stories; translate content
- Workflow Management: Handle workflows, stages, and stage changes
- Development Flow: Control pipeline branches and deployments
- System Utility: Check connectivity between server and Storyblok API
Provides comprehensive tools for managing Storyblok CMS content through natural language, including story management (create, update, delete, publish), tag management, release management, asset handling, component management, and AI-powered content features like generating alt text, translations, meta tags, and content summaries.
Storyblok MCP Server
Connect AI tools to Storyblok instantly - use natural language to manage your CMS like magic.
Demo
Table of Contents
- Demo
- Why This Project?
- What is Storyblok?
- What's an MCP Server?
- Challenges I Faced
- How to Set Up (For Contributors)
- How to Use (For Users)
- Tools
- How to Contribute
- Useful Links
- Thanks
- License
Why This Project?
Built for the Storyblok Headless CMS Challenge on DEV.to.
The goal: push AI and Storyblok's power together, make something fresh and useful.
What is Storyblok?
Storyblok is a powerful headless CMS. API-first. Easy for devs and content creators to work together.
It's modular, super flexible, and fits with any frontend or workflow you want.
What's an MCP Server?
MCP = a protocol that connects AI, tools, and data.
The MCP server acts as a middleman, showing AI what it can do and what data it has.
This enables AI clients, such as Cursor or Claude Desktop, to interact with Storyblok through natural language and manage content smoothly.
Challenges I Faced
- Built for myself (lol): Never made or installed an MCP before. Took way longer than I thought.
- API stress: Kept checking Storyblok's API docs again and again. Scared I'd miss something.
- AI stuff pressure: Trying to get AI features right without breaking things was a headache.
- Security: Had to make sure no sensitive info leaks while exposing Storyblok management.
- Developer experience: Made the server easy to run, extend, and plug into AI tools. No shortcuts.
How to Set Up (For Contributors)
- Clone the repo:
- Install dependencies:
- Run the server:
How to Use (For Users)
Clone the repo:
Connect with Cursor
https://github.com/user-attachments/assets/98b77544-81c4-49b3-8dc2-14849e6ba7e5
- Open Cursor in the same directory.
- Right click on
build/index.js
file and click Copy Path. - Now, go to Settings → MCP Tools.
- Click on New MCP Server
- Inside the opened
mcp.json
file. Paste this and replace PATH_YOU_COPIED with the path copied in the second step:
Tools
- fetch_stories
Retrieve a list of stories (pages, folders, or content entries) from Storyblok. Supports filtering, pagination, and search. - get_story
Fetch a single story by its ID. - create_story
Create a new story (page, folder, or content entry) in Storyblok. - update_story
Update an existing story's content, name, slug, or tags. - delete_story
Delete a story by its ID. - publish_story
Publish a story, making it live. - unpublish_story
Unpublish a story, removing it from the live site. - get_story_versions
Retrieve all previous versions of a story for version history and rollback. - restore_story
Restore a story to a previous version. - import_story
Import a story, optionally specifying language code and whether to import language settings.
- fetch_tags
List all tags used in the space. - create_tag
Create a new tag. - create_tag_and_add_to_story
Create a tag and immediately assign it to a story. - delete_tag
Delete a tag by its ID.
- fetch_webhooks
List all webhooks registered in the space. - get_webhook
Fetch a single webhook by its ID. - create_webhook
Create a new webhook that will trigger on specified Storyblok events. - update_webhook
Update an existing webhook's endpoint, events, or other properties. - delete_webhook
Delete a webhook by its ID.
- fetch_releases
List all releases (content batches for scheduled publishing). - create_release
Create a new release. - update_release
Update an existing release's properties including name, release time and notification settings. - add_story_to_release
Add a story to a release. - publish_release
Publish all stories in a release. - delete_release
Delete a release.
- fetch_presets
List all component presets in the space. Supports pagination. - get_preset
Fetch a single preset by its ID. - create_preset
Create a new preset with default values for a component. - update_preset
Update an existing preset's content, name, or appearance settings. - delete_preset
Delete a preset by its ID.
- fetch_story_schedulings
Retrieve a list of story scheduling objects (scheduled publishings) for stories. Supports filtering, pagination, and search. - get_story_scheduling
Fetch a single story scheduling object by its ID. - create_story_scheduling
Schedule a story to be published at a specific date and time. - update_story_scheduling
Update an existing story scheduling (e.g., change publish time or language). - delete_story_scheduling
Delete a story scheduling by its ID.
- fetch_access_tokens
Retrieve all access tokens (API keys) for the current space. - get_access_token
Fetch a single access token by its ID. - create_access_token
Create a new access token (API key) for the space. Supports public/private, name, min_cache, story_ids, and branch_id. - update_access_token
Update an existing access token's properties (type, name, min_cache, story_ids, branch_id). - delete_access_token
Delete an access token by its ID.
- fetch_assets
List all assets (images, files, etc.) in the space. - get_asset
Fetch a single asset by its ID. - delete_asset
Delete an asset. - init_asset_upload
Start uploading a new asset. - complete_asset_upload
Complete the asset upload process.
- fetch_asset_folders
List all asset folders. - create_asset_folder
Create a new asset folder. - update_asset_folder
Rename an asset folder. - delete_asset_folder
Delete an asset folder.
- fetch_components
List all components (content types) in the space. - get_component
Fetch a single component by its ID. - create_component
Create a new component. - update_component
Update a component's schema or settings. - delete_component
Delete a component.
- search_stories
Search for stories using advanced filters (by slug, tag, etc.). - get_story_by_slug
Fetch a story by its slug.
- fetch_folders
List all story folders.
- fetch_datasources
List all datasources (for dynamic select fields, etc.). - get_datasource
Get a single datasource by its ID. - create_datasource
Create a new datasource with optional dimensions. - update_datasource
Update an existing datasource (name, slug, dimensions). - delete_datasource
Delete a datasource by its ID.
- fetch_datasource_entries
List all entries (key-value pairs) for a datasource. - get_datasource_entry
Fetch a single datasource entry. - create_datasource_entry
Create a new entry in a datasource with optional dimension values. - update_datasource_entry
Update an existing datasource entry. - delete_datasource_entry
Delete a datasource entry by its ID.
- ping
Check if the server and Storyblok API are reachable.
- fetch_component_folders
List all component folders in the space. - get_component_folder
Fetch a single component folder by its ID. - create_component_folder
Create a new component folder with optional parent ID. - update_component_folder
Update an existing component folder's name or parent ID. - delete_component_folder
Delete a component folder by its ID.
- fetch_space_roles
List all space roles in your Storyblok space. - get_space_role
Fetch a single space role by its ID. - create_space_role
Create a new space role with custom permissions settings. - update_space_role
Update an existing space role's permissions and settings. - delete_space_role
Delete a space role by its ID.
- fetch_spaces
List all spaces accessible to your account. Supports pagination. - get_space
Get information about the current Storyblok space. - create_space
Create a new space with optional configuration for billing, environments, and custom options. - update_space
Update an existing space's settings including name, domain, hooks, and configuration options. - delete_space
Delete a space by its ID. - duplicate_space
Create a copy of an existing space with options to duplicate content and components. - backup_space
Trigger a backup for a space.
- generate_alt_text
Automatically create alt text for images based on content or context. - translate_story
Translate the content of a story into different languages using AI. - generate_meta_tags
Generate SEO-friendly meta titles and descriptions for any story. - summarize_story
Get a brief AI-generated summary of a story's content. - tag_story_with_ai
Auto-generate relevant tags for a story using natural language processing.
- fetch_workflows
List all workflows in the space with optional pagination. - get_workflow
Fetch a single workflow by its ID. - create_workflow
Create a new workflow with name and associated content types. - update_workflow
Update an existing workflow's name or content types. - duplicate_workflow
Create a duplicate of an existing workflow with a new name and content types. - delete_workflow
Delete a workflow by its ID.
- fetch_workflow_stages
List all workflow stages defined in the space. - get_workflow_stage
Fetch a single workflow stage by its ID. - create_workflow_stage
Create a new workflow stage with permissions and settings. - update_workflow_stage
Update an existing workflow stage's permissions, name, color, or position. - delete_workflow_stage
Delete a workflow stage by its ID.
- fetch_workflow_stage_changes
List all workflow stage changes with option to filter by story ID. - get_workflow_stage_change
Fetch a single workflow stage change by its ID. - create_workflow_stage_change
Create a new workflow stage change by assigning a story to a specific workflow stage.
- fetch_branches
List all pipeline branches in the space. Supports pagination. - get_branch
Fetch a single branch by its ID. - create_branch
Create a new branch with options for name, source branch, URL, and position. - update_branch
Update an existing branch's properties like name, source, URL, or position. - delete_branch
Delete a branch by its ID. - deploy_branch
Manually trigger a deployment of a branch. - get_branch_stories
List all stories within a specific branch. Supports filtering and pagination. - compare_branches
Compare content between two branches to see differences. - copy_stories_between_branches
Copy stories from one branch to another.
- fetch_branch_deployments
List all branch deployments in the space. Supports pagination. - create_branch_deployment
Create a new branch deployment with required branch ID and optional release UUIDs. Requires the Pipelines application to be installed. - get_branch_deployment
Fetch a single branch deployment by its ID.
How to Contribute
Fork, make changes, open PRs. Found bugs or want features? Open an issue.
Useful Links
Thanks
Made with ❤️ for the DEV.to Storyblok Challenge.
License
MIT
remote-capable server
The server can be hosted and run remotely because it primarily relies on remote services or has no dependency on the local environment.
Connects AI tools to Storyblok CMS, allowing users to manage content through natural language commands for tasks like story management, asset handling, and AI-powered content operations.
Related MCP Servers
- -securityAlicense-qualityEnables management of Payload CMS projects through natural language commands, allowing developers to create, configure, and deploy content models with conversational AI.Last updated -8221MIT License
- TypeScriptMIT License
- -securityFlicense-qualityA comprehensive server enabling natural language interaction with Storyblok CMS for managing stories, assets, components, releases, and other content through a modular architecture.Last updated -0TypeScript
- AsecurityAlicenseAqualityEnables AI assistants to interact with Emlog blog systems through a standardized Model Context Protocol interface, supporting content management operations like creating/updating articles, managing comments, uploading files, and accessing blog resources.Last updated -101082JavaScriptMIT License