Skip to main content
Glama

Ghost MCP Server

This is a fork of MFYDev/ghost-mcp, now maintained and improved by @hithereiamaliff.

This Model Context Protocol (MCP) server provides a powerful and flexible way to manage your Ghost CMS instance using Large Language Model (LLM) interfaces. It offers comprehensive and secure access to your blog's administrative functions, allowing you to automate and streamline your content management workflows.

Features

  • Robust API Integration: Utilizes direct, authenticated axios calls for all Admin API operations, ensuring a stable and reliable connection that is not dependent on external libraries.

  • Comprehensive Entity Access: Manages posts, users, members, tiers, offers, and newsletters.

  • Enhanced Error Handling: Provides detailed status codes and response bodies.

  • Modern Transport: Exclusively uses the Streamable HTTP transport, with all deprecated STDIO logic removed.

  • Diagnostic Tools: Includes tools for troubleshooting API connectivity and configuration.

  • Multi-Tenant Support: Accepts Ghost API credentials via URL query parameters for public/shared deployments.

  • Firebase Analytics: Cloud-based analytics storage with Firebase Realtime Database and local file backup.

  • VPS Deployment Ready: Docker, Nginx, and GitHub Actions auto-deployment support.

Installation & Usage

This MCP server is available through two deployment methods:

Install directly from npm:

npm install -g mcp-ghostcms

Or use with npx (no installation required):

npx mcp-ghostcms

Using with Claude Desktop

To use with MCP clients like Claude Desktop, add the following to your claude_desktop_config.json:

{ "mcpServers": { "mcp-ghostcms": { "command": "npx", "args": ["-y", "mcp-ghostcms"], "env": { "GHOST_API_URL": "https://yourghostbloginstance.com", "GHOST_ADMIN_API_KEY": "your_admin_api_key", "GHOST_API_VERSION": "v6.0" } } } }

Method 2: Smithery Cloud Platform

Deploy and run on Smithery's cloud platform:

Or for local development with Smithery:

git clone <this-repo> cd ghost-mcp npm install npm run dev

This will start the server on port 8080 and open the Smithery Playground in your browser.

Method 3: Self-Hosted VPS with URL Query Parameters

For public/shared deployments, this MCP server can be self-hosted on a VPS and accepts Ghost API credentials via URL query parameters. This allows multiple users to connect their own Ghost instances without server-side configuration.

MCP URL Format

https://your-domain.com/ghostcms/mcp?url=YOUR_GHOST_URL&key=YOUR_ADMIN_API_KEY&version=v5.0

Query Parameters:

Parameter

Required

Description

Example

url

Yes

Your Ghost site URL (with https://)

https://myblog.ghost.io

key

Yes

Ghost Admin API Key (id:secret format)

abc123:def456...

version

No

Ghost API version (default: v5.0)

v5.0 or v6.0

Example Usage with Claude Desktop

Add to your claude_desktop_config.json:

{ "mcpServers": { "ghost-myblog": { "type": "streamable-http", "url": "https://mcp.yourdomain.com/ghostcms/mcp?url=https://myblog.ghost.io&key=YOUR_ADMIN_API_KEY" } } }

Live Demo

A public instance is available at:

https://mcp.techmavie.digital/ghostcms/mcp?url=YOUR_GHOST_URL&key=YOUR_ADMIN_API_KEY

Note: The https:// prefix is automatically added if missing from the URL parameter.

Configuration

This MCP server requires the following configuration:

  • GHOST_API_URL: Your Ghost site URL (domain only, no path), e.g., https://yourghostbloginstance.com

  • GHOST_ADMIN_API_KEY: Your Ghost Admin API key in id:secret format (from Ghost Admin → Settings → Integrations).

  • GHOST_API_VERSION: Ghost API version (v5.0 for Ghost 5.x, v6.0 for Ghost 6.x).

  • GHOST_CONTENT_API_KEY (optional): Your Ghost Content API key for read-only operations.

Available Resources

The following Ghost CMS resources are available through this MCP server:

  • Posts: Articles and content published on your Ghost site.

  • Members: Registered users and subscribers of your site.

  • Newsletters: Email newsletters managed and sent via Ghost.

  • Offers: Promotional offers and discounts for members.

  • Invites: Invitations for new users or staff to join your Ghost site.

  • Roles: User roles and permissions within the Ghost admin.

  • Tags: Organizational tags for posts and content.

  • Tiers: Subscription tiers and plans for members.

  • Users: Admin users and staff accounts.

  • Webhooks: Automated event notifications to external services.

Available Tools

This MCP server provides a wide array of tools to manage your Ghost CMS. These tools are exposed via the Model Context Protocol and allow for a full range of CRUD (Create, Read, Update, Delete) operations on your blog's resources. Below is an overview of the available toolset:

Posts

  • Browse Posts: List posts with optional filters, pagination, and ordering.

  • Read Post: Retrieve a post by ID or slug.

  • Add Post: Create a new post with title, content, and status.

  • Edit Post: Update an existing post by ID.

  • Delete Post: Remove a post by ID.

Members

  • Browse Members: List members with filters and pagination.

  • Read Member: Retrieve a member by ID or email.

  • Add Member: Create a new member.

  • Edit Member: Update member details.

  • Delete Member: Remove a member.

Newsletters

  • Browse Newsletters: List newsletters.

  • Read Newsletter: Retrieve a newsletter by ID.

  • Add Newsletter: Create a new newsletter.

  • Edit Newsletter: Update newsletter details.

  • Delete Newsletter: Remove a newsletter.

Offers

  • Browse Offers: List offers.

  • Read Offer: Retrieve an offer by ID.

  • Add Offer: Create a new offer.

  • Edit Offer: Update offer details.

  • Delete Offer: Remove an offer.

Invites

  • Browse Invites: List invites.

  • Add Invite: Create a new invite.

  • Delete Invite: Remove an invite.

Roles

  • Browse Roles: List roles.

  • Read Role: Retrieve a role by ID.

Tags

  • Browse Tags: List tags.

  • Read Tag: Retrieve a tag by ID or slug.

  • Add Tag: Create a new tag.

  • Edit Tag: Update tag details.

  • Delete Tag: Remove a tag.

Tiers

  • Browse Tiers: List tiers.

  • Read Tier: Retrieve a tier by ID.

  • Add Tier: Create a new tier.

  • Edit Tier: Update tier details.

  • Delete Tier: Remove a tier.

Users

  • Browse Users: List users.

  • Read User: Retrieve a user by ID or slug.

  • Edit User: Update user details.

  • Delete User: Remove a user.

Webhooks

  • Browse Webhooks: List webhooks.

  • Add Webhook: Create a new webhook.

  • Delete Webhook: Remove a webhook.

Each tool is accessible via the MCP protocol and can be invoked from compatible clients. For detailed parameter schemas and usage, see the source code in src/tools/.

Error Handling & Diagnostics

This fork includes enhanced error handling that provides detailed information about API failures:

  • HTTP status codes are captured and reported

  • Full response bodies are included in error messages

  • Runtime configuration is logged at startup

  • Diagnostic tools are available to troubleshoot connectivity issues:

    • admin_site_ping: Tests if the Ghost Admin API endpoint is reachable

    • config_echo: Shows the current Ghost API configuration (with masked key)

These improvements make it much easier to diagnose common issues like:

  • Incorrect API URL format

  • Missing or malformed Admin API keys

  • API version mismatches

  • Network/proxy configuration problems

Development

Setup

  1. Clone the repository

  2. Install dependencies: npm install

  3. Create a .env file with your Ghost configuration:

    GHOST_API_URL=https://yourghostbloginstance.com GHOST_ADMIN_API_KEY=your_admin_api_key GHOST_API_VERSION=v6.0
  4. Build the project: npm run build

  5. Start the dev server: npm run dev

Troubleshooting

If you encounter authentication or "Resource not found" errors:

  1. Verify your Ghost Admin API key is in the correct id:secret format.

  2. Ensure your GHOST_API_URL is the correct domain for your Ghost instance.

  3. Use the admin_site_ping tool to verify that the Admin API endpoint is reachable.

  4. Check the server logs for the actual configuration being used.

MCP Streamable HTTP Requirements

This server implements the MCP Streamable HTTP transport with proper session management and Accept header handling. The server automatically injects text/event-stream into Accept headers and creates isolated transport instances per request to prevent session conflicts.

Testing the endpoint with proper MCP initialization:

# Test MCP initialization (proper way to test) curl -s -X POST \ -H "Content-Type: application/json" \ -H "Accept: application/json, text/event-stream" \ -d '{"jsonrpc":"2.0","id":1,"method":"initialize","params":{"protocolVersion":"2024-11-05","capabilities":{},"clientInfo":{"name":"test","version":"1.0"}}}' \ "https://mcp.techmavie.digital/ghostcms/mcp?url=https://your-site.com&key=YOUR_KEY" # Expected response (SSE format): # event: message # data: {"result":{"protocolVersion":"2024-11-05","capabilities":{...},"serverInfo":{...}},"jsonrpc":"2.0","id":1}

Note: Simple GET/POST requests without MCP initialization will return protocol errors like "Bad Request: Server not initialized" - this is expected behavior. The endpoint requires proper MCP protocol handshake.

For MCP Clients (Claude Desktop, Claude iOS, Claude Code):

  • MCP clients automatically handle the initialization protocol and session management

  • Ensure your MCP URL is correctly formatted in your client configuration

  • For Claude iOS, use the Connectors feature with the full MCP URL including query parameters

  • For Claude Code, add the server to your MCP settings with type streamable-http

Session Management:

  • The server creates a new transport instance for each HTTP request (stateless pattern)

  • Each client connection gets a unique session ID automatically

  • Multiple clients can connect simultaneously without session conflicts

  • Sessions are automatically cleaned up after responses are sent

Common Errors and Solutions:

Error

Cause

Solution

"Not Acceptable: Client must accept text/event-stream"

Old server version

Update to latest version - this is fixed

"Bad Request: Server not initialized"

Testing without MCP protocol

Use proper MCP initialization (see example above)

"Mcp-Session-Id header is required"

Old server version with session conflicts

Update to latest version - this is fixed

"Server already initialized"

Old server version reusing transports

Update to latest version - this is fixed

VPS Deployment

This MCP server includes full support for self-hosted VPS deployment with Docker, Nginx, and GitHub Actions auto-deployment.

Architecture

┌─────────────────┐ ┌─────────────────┐ ┌─────────────────┐ │ Claude/MCP │────▶│ Nginx Proxy │────▶│ Docker │ │ Client │ │ /ghostcms/ │ │ Container │ └─────────────────┘ └─────────────────┘ └─────────────────┘ │ ▼ ┌─────────────────┐ │ Ghost CMS │ │ Admin API │ └─────────────────┘

Deployment Files

The repository includes:

  • Dockerfile - Container configuration with Node.js 20-alpine

  • docker-compose.yml - Docker orchestration with volumes for analytics and Firebase credentials

  • deploy/nginx-mcp.conf - Nginx reverse proxy configuration

  • .github/workflows/deploy-vps.yml - GitHub Actions auto-deployment workflow

Quick Deploy

# On your VPS cd /opt/mcp-servers git clone https://github.com/hithereiamaliff/mcp-ghostcms.git ghostcms cd ghostcms # Build and start docker compose up -d --build # Check logs docker compose logs -f

Endpoints

Endpoint

Description

/health

Health check

/mcp

MCP endpoint (with query params)

/analytics

Analytics JSON data

/analytics/dashboard

Visual analytics dashboard

/analytics/tools

Tool usage statistics

Firebase Analytics

This MCP server uses Firebase Realtime Database for cloud-based analytics storage with local file backup as fallback.

Features

  • Dual Storage: Firebase (primary) + local file (backup)

  • Persistent: Data survives container rebuilds and deployments

  • Real-time: Updates every 60 seconds

  • Dashboard: Visual analytics at /analytics/dashboard

Data Tracked

  • Total requests and tool calls

  • Requests by method (GET, POST, etc.)

  • Requests by endpoint

  • Tool usage statistics

  • Client IPs and user agents

  • Hourly request trends

  • Recent tool call activity

Firebase Setup

  1. Create a Firebase project at Firebase Console

  2. Enable Realtime Database

  3. Generate service account credentials (Project Settings → Service Accounts)

  4. Copy credentials to your VPS:

# On VPS mkdir -p /opt/mcp-servers/ghostcms/.credentials # Copy firebase-service-account.json to this directory # Create Docker volume docker volume create ghostcms_firebase-credentials # Copy to volume with correct permissions docker run --rm \ -v ghostcms_firebase-credentials:/credentials \ -v /opt/mcp-servers/ghostcms/.credentials:/source:ro \ alpine sh -c "cp /source/firebase-service-account.json /credentials/ && chown -R 1001:1001 /credentials/" # Restart container docker compose down docker compose up -d

Firebase Data Structure

mcp-analytics/ └── mcp-ghostcms/ ├── serverStartTime ├── totalRequests ├── totalToolCalls ├── requestsByMethod ├── requestsByEndpoint ├── toolCalls ├── recentToolCalls ├── clientsByIp ├── clientsByUserAgent ├── hourlyRequests └── lastUpdated

For detailed Firebase setup instructions, see FIREBASE_SETUP.md.

Contributing

  1. Fork repository

  2. Create feature branch

  3. Commit changes

  4. Create pull request

License

MIT

-
security - not tested
A
license - permissive license
-
quality - not tested

Latest Blog Posts

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/hithereiamaliff/mcp-ghostcms'

If you have feedback or need assistance with the MCP directory API, please join our Discord server