Drupal MCP Server
Enables AI models to interact with Drupal 10+ sites via JSON:API for querying, searching, and retrieving content. It supports listing content types, searching by title across all types, and fetching detailed node information including relationships.
README
Drupal MCP Server
A Model Context Protocol (MCP) server that enables Claude to interact with Drupal 10+ sites via JSON:API. This server allows Claude to query, search, and retrieve content from your Drupal installation.
Features
- Query Content: Search and filter nodes by content type with flexible options
- Get Node Details: Retrieve complete node information including relationships
- List Content Types: Discover all available content types on your site
- Search Across Types: Search for content across all content types by title
Prerequisites
- Node.js 18+ and npm
- TypeScript 5+
- A Drupal 10+ site with JSON:API enabled (enabled by default)
- Valid Drupal credentials (username/password or OAuth token)
Installation
# Clone or create the project directory
mkdir drupal-mcp-server
cd drupal-mcp-server
# Initialize and install dependencies
npm init -y
npm install @modelcontextprotocol/sdk axios
npm install -D typescript @types/node
Project Structure
drupal-mcp-server/
├── src/
│ ├── index.ts # Main MCP server
│ ├── drupal-client.ts # Drupal API client
│ └── types.ts # TypeScript type definitions
├── dist/ # Compiled JavaScript (generated)
├── package.json
└── tsconfig.json
Building
# Compile TypeScript
npm run build
# Watch mode (optional)
npm run watch
The compiled JavaScript files will be output to the dist/ directory.
Configuration
For Claude Desktop
Edit your Claude Desktop configuration file:
macOS: ~/Library/Application Support/Claude/claude_desktop_config.json
Windows: %APPDATA%\Claude\claude_desktop_config.json
Linux: ~/.config/Claude/claude_desktop_config.json
Add the following configuration:
{
"mcpServers": {
"drupal": {
"command": "node",
"args": ["/absolute/path/to/drupal-mcp-server/dist/index.js"],
"env": {
"DRUPAL_BASE_URL": "https://your-drupal-site.com",
"DRUPAL_USERNAME": "your-username",
"DRUPAL_PASSWORD": "your-password"
}
}
}
}
Note: Replace /absolute/path/to/drupal-mcp-server with the actual path on your system. Use pwd in the project directory to get the full path.
For Cline (VS Code)
Add to your VS Code settings.json:
{
"cline.mcpServers": {
"drupal": {
"command": "node",
"args": ["/absolute/path/to/drupal-mcp-server/dist/index.js"],
"env": {
"DRUPAL_BASE_URL": "https://your-drupal-site.com",
"DRUPAL_USERNAME": "your-username",
"DRUPAL_PASSWORD": "your-password"
}
}
}
}
Environment Variables
DRUPAL_BASE_URL(required): Your Drupal site URLDRUPAL_USERNAME(optional): Basic auth usernameDRUPAL_PASSWORD(optional): Basic auth passwordDRUPAL_ACCESS_TOKEN(optional): OAuth access token (alternative to username/password)
Testing
Manual Server Test
Test the server directly from the command line:
cd /path/to/drupal-mcp-server
DRUPAL_BASE_URL="https://your-site.com" \
DRUPAL_USERNAME="admin" \
DRUPAL_PASSWORD="password" \
node dist/index.js
You should see:
Drupal MCP Server running
Connected to: https://your-site.com
Press Ctrl+C to stop.
Test Connection to Drupal
Verify your Drupal site is accessible:
curl -I https://your-site.com/jsonapi
Should return a 200 OK status.
Testing in Claude Desktop
- Restart Claude Desktop after updating the configuration
- Look for the 🔌 icon at the bottom of the interface
- Click it to see connected MCP servers
- Start a new conversation and try:
What tools do you have available?
Example Queries
List content types:
List all available content types on my Drupal site
Query content:
Show me 5 published articles
Search content:
Search for content with "tutorial" in the title
Get node details:
Get the full details of node [UUID]
Complex query:
1. List all content types
2. Find 3 articles
3. Show me the complete details of the first article
Available Tools
query_content
Search and filter Drupal content by type.
Parameters:
contentType(required): Machine name of the content type (e.g., "article", "page")limit(optional): Maximum results to return (default: 10)title(optional): Filter by title (partial match)status(optional): Filter by publication status (true/false)
get_node
Retrieve complete details of a specific node.
Parameters:
nodeId(required): UUID or numeric ID of the nodeinclude(optional): Array of related entities to include (e.g., ["field_image", "uid"])
list_content_types
List all available content types on the site.
Parameters: None
search_content
Search across all content types by title.
Parameters:
searchTerm(required): Text to search for in titleslimit(optional): Maximum results (default: 10)
Troubleshooting
"Server disconnected" error
- Check that the server starts manually
- Verify the path in the configuration is absolute
- Check Claude Desktop logs:
# macOS tail -f ~/Library/Logs/Claude/mcp*.log
SSL Certificate errors (DDEV/local development)
If using self-signed certificates, the server automatically disables certificate verification for local development.
Permission errors
Ensure your Drupal user has permission to access JSON:API endpoints. The "View published content" permission is usually sufficient for read operations.
JSON:API not enabled
JSON:API is enabled by default in Drupal 10+. If you get 404 errors, verify it's enabled at:
/admin/modules → Search for "JSON:API"
Development
Adding new tools
- Define the tool schema in
TOOLSarray insrc/index.ts - Implement the handler in the
CallToolRequestSchemaswitch statement - Add any new methods to
DrupalClientclass as needed - Rebuild:
npm run build
Extending functionality
Potential enhancements:
- Create/update content (POST/PATCH requests)
- Manage taxonomy terms
- Query users
- Execute Views
- Upload media/files
- Manage menus
License
MIT
Contributing
Contributions are welcome! Please feel free to submit issues or pull requests.
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.