Integrates with Git repositories to analyze recent changes, commit statistics, and diffs for automated code review workflows through Claude Desktop.
MCP Claude Desktop
A Model Context Protocol (MCP) server that enables Claude Code to communicate with Claude Desktop. This server allows Claude Code to send prompts to Claude Desktop and poll for responses.
Inspired by claude-chatgpt-mcp, this project adapts the concept for Apple's ecosystem using native macOS automation.
Features
Send prompts from Claude Code to Claude Desktop
Automatic polling for responses with configurable timeout
List available conversations in Claude Desktop
Error handling and retry logic
Comprehensive logging
Installation
You can install and use this MCP server in two ways:
Option 1: Using npx (Recommended)
The simplest way to use this server is directly with npx, without any installation:
Option 2: Local Installation
Clone this repository:
Install dependencies:
Build the project:
Configure MCP:
System Requirements
macOS 11.0+ (Big Sur or later)
Node.js 18+
Claude Desktop app installed
Accessibility permissions granted for AppleScript
Granting Accessibility Permissions
Open System Preferences > Security & Privacy > Privacy
Select "Accessibility" from the left sidebar
Click the lock to make changes
Add Terminal (or your terminal app) to the allowed apps
Restart your terminal
MCP Tools
This MCP server provides two tools:
ask
Purpose: Send a prompt to Claude Desktop and get a response
Parameters:
prompt: The text to send to Claude Desktop (required)conversationId: Optional ID to continue a specific conversationtimeout: Response timeout in seconds (optional, default: 30, max: 300)pollingInterval: How often to check for response in seconds (optional, default: 1.5, min: 0.5)
get_conversations
Purpose: Get a list of available conversations in Claude Desktop
Parameters: None
Usage
Once configured, Claude Code can use the MCP in various ways:
General Purpose Usage
When Claude uses these tools, it will call them with parameters like:
Basic usage:
Tool:
askParameters:
{ "prompt": "What is dependency injection?" }
With custom timeout:
Tool:
askParameters:
{ "prompt": "Explain quantum computing", "timeout": 120 }
With both timeout and polling interval:
Tool:
askParameters:
{ "prompt": "Quick question", "timeout": 10, "pollingInterval": 0.5 }
Get conversations:
Tool:
get_conversationsParameters:
{}
How to Use in Claude
Once the MCP server is configured and running, you can use these tools directly in Claude:
Basic usage:
"Use the ask tool to ask Claude Desktop: What are the best practices for error handling in Python?"
"Use get_conversations to list all my Claude Desktop conversations"
With custom timeout:
"Use the ask tool with timeout 60 to ask Claude Desktop: Explain B+ tree implementation"
"Use ask with timeout 10 and pollingInterval 0.5 to ask Claude Desktop: What is 2+2?"
Important: The MCP server configuration (shown above) only tells Claude how to start the server. The timeout and pollingInterval parameters are specified when you use the tool in Claude, not in the server configuration file.
Known Limitations
Response Reading
Due to Claude Desktop's Electron-based architecture, this MCP integration cannot read Claude's responses programmatically. The tool can successfully:
✅ Send prompts to Claude Desktop
✅ Create new conversations
✅ Activate and focus the Claude window
❌ Read Claude's responses back
This is a limitation of how Electron apps expose UI elements through accessibility APIs. When you use the ask tool, you'll receive a confirmation that the message was sent, but you'll need to check the Claude Desktop window directly to see the response.
Workarounds
Use Claude's API: For programmatic access to responses, consider using Claude's API directly instead of desktop automation
Manual verification: After sending a prompt, manually check the Claude Desktop window for the response
One-way automation: Use this tool for scenarios where you only need to send prompts without reading responses
Claude Commands Integration
Claude Commands allow you to create reusable workflows that combine MCP tools. This project works seamlessly with Claude Commands to enable powerful automation.
Example: Code Peer Review Command
We've included an example Claude Command that demonstrates how to use MCP Claude Desktop for automated code reviews. The command uses git to analyze recent changes and sends them to Claude Desktop for peer review feedback.
Setup
Copy the example command to your Claude Commands directory:
cp examples/claude-peer-review.md ~/.claude/commands/The command will be available in Claude Code as
/claude-peer-review
Usage
The peer review command accepts up to 3 arguments:
description: What changes to review (e.g., "authentication fix")
polling_interval: How often to check for response (default: 1.5s)
timeout: Maximum wait time for response (default: 30s)
Examples:
How It Works
Git Integration: The command automatically fetches:
Current git status
Recent commit statistics
Full diff of changes
Current branch name
Claude Desktop Review: Sends the changes to Claude Desktop with specific review questions:
Code appropriateness and implementation quality
Security concerns or potential bugs
Code quality and best practices
Suggestions for improvements
Response Handling: Uses the MCP server's polling mechanism to wait for Claude's response
Summary Generation: Provides a structured summary of:
Changes reviewed
Claude's feedback
Actions taken based on feedback
Final review status
Creating Your Own Commands
You can create custom Claude Commands that leverage MCP Claude Desktop. Commands should:
Include the tools in the frontmatter:
--- allowed-tools: mcp__claude-desktop__ask, mcp__claude-desktop__get_conversations ---Use the MCP tools with appropriate parameters:
mcp__claude-desktop__ask prompt: "Your prompt here" timeout: 60 pollingInterval: 2Handle timeouts gracefully and suggest longer timeouts for complex queries
See the example command for a complete implementation.
Development
Running in Development Mode
Running Tests
Linting
Type Checking
API
Tools
ask
Send a prompt to Claude Desktop and get a response.
Parameters:
prompt(string, required): The prompt to sendconversationId(string, optional): Continue a specific conversationtimeout(number, optional): Response timeout in secondsDefault: 30 seconds
Minimum: 1 second
Maximum: 300 seconds (5 minutes)
pollingInterval(number, optional): How often to check for response in secondsDefault: 1.5 seconds
Minimum: 0.5 seconds
Maximum: 10 seconds
Response:
get_conversations
Get a list of available conversations in Claude Desktop.
Parameters: None
Response:
Architecture
The MCP server uses AppleScript to communicate with Claude Desktop:
Claude Code sends a prompt via MCP
AppleScript activates Claude Desktop and creates a new conversation
The prompt is typed into Claude Desktop
The server polls Claude Desktop for the response
Once a response is detected, it's parsed and returned to Claude Code
Troubleshooting
Common Issues
"AppleScript execution failed"
Ensure Claude Desktop is installed and running
Check accessibility permissions
Try running the server with higher log level:
LOG_LEVEL=3
"Response timed out"
Increase the timeout parameter:
timeout: 60(60 seconds)For complex queries, use longer timeouts:
timeout: 120(2 minutes)Reduce polling interval for faster detection:
pollingInterval: 0.5Check if Claude Desktop is responding normally
Ensure the system isn't under heavy load
"Permission denied"
Grant accessibility permissions to your terminal
Run the build command with proper permissions
MCP Server Crashes After Sending Requests If the MCP server crashes after handling requests, you can:
Disable response polling (recommended for stability):
export SKIP_CLAUDE_POLLING=trueThis will send the message to Claude Desktop but won't try to read the response.
Enable debug logging to see what's happening:
export LOG_LEVEL=3Check stderr output - All logs are now written to stderr to avoid interfering with the MCP protocol on stdout.
Known Limitations with Response Polling
Response polling can occasionally cause instability due to:
Extended polling duration (30 seconds default)
Complex UI element reading from Electron apps
Timing issues with Claude's response generation
Consider using SKIP_CLAUDE_POLLING=true for more reliable operation if you don't need response reading.
Contributing
We welcome contributions to MCP Claude Desktop! Whether you're fixing bugs, adding features, or improving documentation, your help is appreciated.
Getting Started
Fork the repository
Clone your fork:
git clone https://github.com/YOUR_USERNAME/mcp-claude-desktop cd mcp-claude-desktopInstall dependencies:
npm installCreate a new branch:
git checkout -b feature/your-feature-name
Development Workflow
Make your changes
Run tests to ensure everything works:
npm testRun linting to maintain code quality:
npm run lintRun type checking:
npm run typecheckBuild the project:
npm run build
Code Style Guidelines
Use TypeScript for all source code
Follow the existing code style (enforced by ESLint)
Write meaningful commit messages
Add tests for new features
Update documentation as needed
Submitting Changes
Commit your changes with a descriptive message:
git commit -m "feat: add support for conversation history"Push to your fork:
git push origin feature/your-feature-nameCreate a Pull Request on GitHub
Pull Request Guidelines
Provide a clear description of the changes
Reference any related issues
Ensure all tests pass
Update README if adding new features
Be responsive to code review feedback
Reporting Issues
Use GitHub Issues to report bugs
Include macOS version and Node.js version
Provide steps to reproduce the issue
Include relevant error messages or logs
Feature Requests
Open an issue to discuss new features
Explain the use case and benefits
Be open to feedback and alternative approaches
License
MIT