
Ghost MCP Server
Manage your Ghost blog content directly from Claude, Cursor, or any MCP-compatible client, allowing you to create, edit, search, and delete posts with support for tag management and analytics.
README
Ghost MCP Server
A Model Context Protocol (MCP) server for Ghost CMS. Manage your Ghost blog content directly from Claude, Cursor, or any MCP-compatible client.
Features
- 📝 Create & Edit Posts - Draft and publish blog posts
- 🔍 Search Posts - Find posts by status, tags, or query
- 🏷️ Tag Management - List and organize your tags
- 📊 Analytics - Basic analytics integration support
- 🗑️ Delete Posts - Remove unwanted content
- 📚 Resource Access - Browse posts as MCP resources
Installation
NPM (recommended)
npm install -g ghost-mcp
From Source
git clone https://github.com/mcpanvil/ghost-mcp.git
cd ghost-mcp
npm install
npm run build
npm link
Configuration
-
Get your Ghost API keys:
- Log into your Ghost Admin
- Go to Settings > Integrations
- Create a new Custom Integration
- Copy the Admin API Key and Content API Key
-
Set up environment variables:
# Create a .env file or set these in your environment
GHOST_URL=https://your-site.ghost.io
GHOST_ADMIN_API_KEY=your-admin-api-key
GHOST_CONTENT_API_KEY=your-content-api-key
Usage
With Claude Desktop
Add to your claude_desktop_config.json
:
{
"mcpServers": {
"ghost": {
"command": "npx",
"args": ["ghost-mcp"],
"env": {
"GHOST_URL": "https://your-site.ghost.io",
"GHOST_ADMIN_API_KEY": "your-admin-key",
"GHOST_CONTENT_API_KEY": "your-content-key"
}
}
}
}
With Claude Code
# Add to Claude Code with your Ghost credentials
claude mcp add ghost \
-e GHOST_URL=https://your-site.ghost.io \
-e GHOST_ADMIN_API_KEY=your-admin-key \
-e GHOST_CONTENT_API_KEY=your-content-key \
-- npx ghost-mcp
Get your API keys from Ghost Admin → Settings → Integrations.
With Cursor
Add to Cursor's MCP settings:
{
"ghost": {
"command": "npx",
"args": ["@mcpanvil/ghost-mcp"],
"env": {
"GHOST_URL": "https://your-site.ghost.io",
"GHOST_ADMIN_API_KEY": "your-admin-key",
"GHOST_CONTENT_API_KEY": "your-content-key"
}
}
}
Available Tools
create_post
Create a new blog post.
{
title: string; // Required
content: string; // Required (HTML or Markdown)
status?: 'draft' | 'published'; // Default: 'draft' - set to 'published' to make live
tags?: string[];
excerpt?: string;
featured?: boolean;
}
⚠️ Important Notes:
- Posts are created as drafts by default. To publish immediately, set
status: 'published'
- Ghost v5 uses Lexical format internally, but this MCP handles HTML/Markdown conversion automatically
- When viewing draft posts in Ghost admin, they may appear empty due to format conversion - this is normal
update_post
Update an existing post.
{
id: string; // Required (post ID)
title?: string;
content?: string;
status?: 'draft' | 'published';
tags?: string[];
excerpt?: string;
featured?: boolean;
}
search_posts
Search and list posts.
{
query?: string;
status?: 'draft' | 'published' | 'all';
limit?: number; // 1-100, default 10
tags?: string[];
}
get_post
Get a specific post by ID or slug.
{
id: string; // Post ID or slug
}
delete_post
Delete a post.
{
id: string; // Post ID
}
list_tags
List all available tags.
{
limit?: number; // 1-100, default 20
}
get_analytics
Get analytics information (requires additional setup).
{
days?: number; // 1-365, default 30
}
Troubleshooting
Updates Not Working
If post updates don't seem to be applying:
- Check browser cache - Ghost aggressively caches content
- Verify the post status - drafts may not show updates immediately
- Ensure you're using ghost-mcp v0.1.6 or later (earlier versions had an update bug)
Empty Content in Ghost Admin
When viewing posts in Ghost admin, content may appear empty. This is because:
- Ghost v5 uses Lexical format internally
- The MCP creates posts in HTML format
- The admin panel may not display HTML content in the editor
- Your published posts will display correctly on your site
Common Issues
- "Validation error, cannot save post": Usually means required fields are missing
- "Cannot read post": The post ID may be incorrect or the post was deleted
- Draft posts not visible: Check your Ghost admin's post filter settings
Example Workflows
Writing a New Blog Post
Human: Create a published blog post about building MCP servers
推荐服务器

Baidu Map
百度地图核心API现已全面兼容MCP协议,是国内首家兼容MCP协议的地图服务商。
Playwright MCP Server
一个模型上下文协议服务器,它使大型语言模型能够通过结构化的可访问性快照与网页进行交互,而无需视觉模型或屏幕截图。
Magic Component Platform (MCP)
一个由人工智能驱动的工具,可以从自然语言描述生成现代化的用户界面组件,并与流行的集成开发环境(IDE)集成,从而简化用户界面开发流程。
Audiense Insights MCP Server
通过模型上下文协议启用与 Audiense Insights 账户的交互,从而促进营销洞察和受众数据的提取和分析,包括人口统计信息、行为和影响者互动。

VeyraX
一个单一的 MCP 工具,连接你所有喜爱的工具:Gmail、日历以及其他 40 多个工具。
graphlit-mcp-server
模型上下文协议 (MCP) 服务器实现了 MCP 客户端与 Graphlit 服务之间的集成。 除了网络爬取之外,还可以将任何内容(从 Slack 到 Gmail 再到播客订阅源)导入到 Graphlit 项目中,然后从 MCP 客户端检索相关内容。
Kagi MCP Server
一个 MCP 服务器,集成了 Kagi 搜索功能和 Claude AI,使 Claude 能够在回答需要最新信息的问题时执行实时网络搜索。

e2b-mcp-server
使用 MCP 通过 e2b 运行代码。
Neon MCP Server
用于与 Neon 管理 API 和数据库交互的 MCP 服务器
Exa MCP Server
模型上下文协议(MCP)服务器允许像 Claude 这样的 AI 助手使用 Exa AI 搜索 API 进行网络搜索。这种设置允许 AI 模型以安全和受控的方式获取实时的网络信息。