Homebrew MCP Python Server
Expose Homebrew management as MCP tools for integration with AI clients.
Key Features
Use Cases
README
Homebrew MCP Python Server
A Model Context Protocol (MCP) server for Homebrew package management on macOS, designed for seamless integration with Claude Desktop and other MCP-compatible clients.
- Language: Python 3.13
- MCP: Model Context Protocol
- Package Manager: Homebrew (macOS)
- Venv/Dependency Manager: uv
Features
- Exposes Homebrew commands as MCP tools. The supported commands are grouped by function:
- Package Management:
install,uninstall,upgrade,cleanup - Information & Discovery:
list,search,info,outdated,deps - System Health & Updates:
doctor,update - Tap & Source Management:
tap,untap - Version Management:
pin,unpin - Service Management:
services
- Package Management:
- Runs real
brewcommands via subprocess (requires Homebrew on macOS). - Fully MCP spec-compliant (stdio, JSON-RPC 2.0, MCP spec 2025-06-18).
- Designed for Claude Desktop and other LLM clients.
- Functional, declarative Python (no classes).
- Logs all requests/results to
homebrew_mcp.log. - Includes an interactive test script (
test_claude_homebrew_mcp.py) that:- Dynamically fetches available tools from the MCP server.
- Allows Claude to make multiple tool calls for a single user prompt.
- Demonstrates advanced interaction patterns with the Anthropic API.
Installation
-
Clone this repository:
shgit clone https://github.com/jeannier/homebrew-mcp cd homebrew-mcp -
Install uv (if not already):
shbrew install uv -
Create a virtual environment and install dependencies:
shuv venv source .venv/bin/activate # Activate the virtual environment uv pip install -r requirements.txt -
Run the MCP Server (for Local Testing): To test the server locally or during development, you can run it directly:
shuv run python homebrew_mcp.pyThe server will then start. If successful, there will be no immediate output; it will silently listen for MCP requests over stdio. You can confirm it's running by checking the
homebrew_mcp.logfile.Note: If you are integrating with Claude Desktop, you do not need to run this command manually. Claude Desktop will start the server automatically based on the configuration provided in the "Claude Desktop Integration" section. This command is for direct testing or development purposes.
Cursor Integration
Prerequisite: Before adding the tool, please complete the steps in the Installation section to set up the project and its dependencies. The "Add to Cursor" button assumes the project is located at ~/Documents/GitHub/homebrew-mcp.
-
Install Cursor via Homebrew (macOS):
shbrew install --cask cursor -
Add the Tool to Cursor:
- Click the "Add to Cursor" button above. This will open Cursor and automatically install the tool.
- If your project is not at the location assumed by the button, you will need to edit the generated configuration. On macOS, this file is located at
~/.cursor/mcp.json. Open it and update the path inside thecommandstring for thehomebrew-mcpentry. Themcp.jsonfile in this repository can be used as a reference.
-
Restart Cursor:
- For the tool to become active, restart Cursor after installation.
Claude Desktop Integration
-
Install Claude Desktop via Homebrew (macOS):
shbrew install --cask claude -
Ensure
uvis in your PATH and the project is accessible. -
Configure Claude Desktop to use this MCP server:
- On macOS, edit or create your user-level MCP configuration file at:
~/Library/Application Support/Claude/claude_desktop.json. - Add the following server definition, replacing
/path/to/your/project/with the absolute path to the directory where you cloned this project. You can refer to theclaude_desktop_config.jsonfile in this repository for an example.
- On macOS, edit or create your user-level MCP configuration file at:
{
"mcpServers": {
"homebrew-mcp": {
"command": "uv",
"args": [
"run",
"--directory",
"/path/to/your/project/",
"homebrew_mcp.py"
],
"type": "stdio"
}
}
}
The --directory argument tells uv where to find the homebrew_mcp.py script and its context (like the .venv).
- Restart Claude Desktop.
Project Structure
- Python Scripts
homebrew_mcp.py— Main MCP server script.test_claude_homebrew_mcp.py— Interactive Claude integration test script.
- Configuration
claude_desktop_config.json— Example configuration for Claude Desktop.mcp.json— Example configuration for Cursor.requirements.txt— Python project dependencies.
- Documentation & Metadata
README.md— This file.LICENSE— The project's MIT license..gitignore— Specifies files for Git to ignore.
- Generated Files (Not in Git)
.venv/— Python virtual environment managed byuv.homebrew_mcp.log— Log file for the MCP server.
Monitoring Logs
To watch the server log in real time and pretty-print each JSON line:
tail -f homebrew_mcp.log | jq .
Tested Environment
This MCP server and its integration with Claude have been primarily tested on the following environment:
- macOS: Sonoma 14.7.5
- Homebrew: 4.5.8
- Python: 3.13 (managed via
uv)- mcp module: 1.9.4 (installed using
uv pip)
- mcp module: 1.9.4 (installed using
- anthropic module: 0.55.0 (installed using
uv pip) - Claude Desktop: 0.10.38 (installed via Homebrew Cask on macOS).
- Cursor: 1.1.4
Example Prompts
Here are some example prompts you can use with Claude (or another MCP client) when interacting with this Homebrew MCP server:
- provide a summary of all installed packages
- check which packages are installed, and provide suggestions for other packages to install
- are there any problems with my homebrew setup? and how can I fix them ?
- show me information about the python 3.13 package
- install the wget package
Interactive Claude Test Script
To run the Claude integration test (test_claude_homebrew_mcp.py), you need an Anthropic Claude API key. Set your API key in the ANTHROPIC_API_KEY variable at the top of the test script. This script allows you to interact with Claude, which in turn uses the homebrew_mcp.py server. It demonstrates dynamic tool discovery and Claude's ability to make multiple tool calls.
uv run python test_claude_homebrew_mcp.py
Example Test Run Output
This section shows an example of the output when running the test_claude_homebrew_mcp.py script.
It demonstrates the interaction between Claude and the Homebrew MCP server, including dynamic tool discovery, multiple tool calls, and final responses.
$ uv run python test_claude_homebrew_mcp.py
============================== Claude Prompt 1/7 ===============================
install wget if not installed, or uninstall if already installed
================================================================================
============================= Claude's Answer 1/7 ==============================
I've successfully installed wget on your system. Now that wget is installed, if you'd like me to uninstall it instead (as per your request to either install if not present or uninstall if already installed), I can do that for you.
Would you like me to proceed with uninstalling wget now? Please let me know.
================================================================================
============================== Claude Prompt 2/7 ===============================
restore initial state of wget
================================================================================
============================= Claude's Answer 2/7 ==============================
I've successfully uninstalled wget, returning your system to its initial state before our conversation. The wget package has been completely removed from your system.
================================================================================
============================== Claude Prompt 3/7 ===============================
check for outdated packages
================================================================================
============================= Claude's Answer 3/7 ==============================
You have 3 outdated packages:
1. libnghttp2
2. uv
3. yt-dlp
These packages have newer versions available and can be upgraded if you wish.
================================================================================
============================== Claude Prompt 4/7 ===============================
provide a summary of all installed packages
================================================================================
============================= Claude's Answer 4/7 ==============================
Here's a summary of all installed packages on your system:
1. **Command Line Tools & Utilities**: bash, coreutils, curl, git, jq, nmap, grep, watch, etc.
2. **Programming Languages & Tools**: python (multiple versions), node, go, lua
3. **Media Tools & Libraries**: ffmpeg and its dependencies (x264, x265, etc.), yt-dlp
4. **Development Tools**: neovim, tree-sitter, shellcheck
5. **Applications (Casks)**:
- Browsers: google-chrome, firefox
- Development: visual-studio-code, iterm2, cursor, github
- Communication: discord, whatsapp
- Media: vlc, spotify, stremio
- Utilities: docker-desktop, keepassxc, alt-tab, disk-inventory-x
- AI/ML tools: chatgpt, claude, ollama, superwhisper
You have 3 outdated packages (libnghttp2, uv, and yt-dlp) that could be updated.
================================================================================
============================== Claude Prompt 5/7 ===============================
provide 5 suggestions of other packages to install
================================================================================
============================= Claude's Answer 5/7 ==============================
Based on your installed packages and common developer tools, here are 5 suggested packages that would complement your setup:
1. **tmux** - A terminal multiplexer that allows you to manage multiple terminal sessions within a single window. Great companion to your iterm2 and neovim setup.
2. **htop** - An interactive process viewer and system monitor, much more feature-rich than the standard top command.
3. **ripgrep** - A faster alternative to grep, designed for searching code. Works well with your development tools.
4. **fzf** - A command-line fuzzy finder that can dramatically improve your terminal workflow for searching files, command history, and more.
5. **tldr** - Simplified and community-driven man pages with practical examples. Perfect for quickly finding common command usage patterns.
These tools would enhance your command-line productivity and integrate well with your existing development environment. Would you like more information about any of these packages?
================================================================================
============================== Claude Prompt 6/7 ===============================
use brew doctor to see if there are any issues, try to find a fix for all of these issues
================================================================================
============================= Claude's Answer 6/7 ==============================
Based on the complete analysis, here's my recommendation to fix the one minor warning:
Since this is just a warning about having both the core and tap version of nextdns available, and you're actually using the core version (as shown by the info command), this isn't causing any functional problems with your system. The warning is simply informing you that if you want to specifically use the tap version, you need to use the full name.
If you want to fully resolve this warning, you have two options:
1. Continue using the core version of nextdns (which you are currently using) and untap the nextdns tap to remove the ambiguity. This would require identifying the exact tap name and then using the untap command.
2. Keep both versions available and just be aware that you need to use the full name when referring to the tap version.
Since the warning isn't causing any actual issues with your Homebrew installation and everything is functioning correctly, I would recommend option 2 - simply being aware of the naming convention when you need to use the tap version.
The brew doctor results suggest your Homebrew installation is actually in good shape with no critical issues that need fixing!
================================================================================
============================== Claude Prompt 7/7 ===============================
provide a summary of what was done
================================================================================
============================= Claude's Answer 7/7 ==============================
# Homebrew Session Summary
Here's a summary of what was done during our session:
1. **Checked and installed wget**:
- Initially verified that wget was not installed on your system
- Installed wget version 1.25.0
2. **Restored initial state**:
- Uninstalled wget to return to the original system state
3. **Checked for outdated packages**:
- Found 3 outdated packages: libnghttp2, uv, and yt-dlp
4. **Listed all installed packages**:
- Displayed a complete list of installed formulae and casks
- Your system has numerous development tools, utilities, and applications installed
5. **Suggested 5 additional packages**:
- tmux: Terminal multiplexer
- htop: Interactive process viewer
- ripgrep: Fast alternative to grep
- fzf: Command-line fuzzy finder
- tldr: Simplified man pages
6. **Ran system diagnostics**:
- Executed brew doctor to check for issues
- Found only one minor warning related to the nextdns package having the same name in both core formulae and a custom tap
- This warning is informational only and doesn't require action unless you experience issues with nextdns
7. **Examined package versions**:
- Listed all installed packages with their versions to get a better understanding of your system configuration
Overall, your Homebrew installation appears to be in good health with only a minor naming conflict that doesn't impact functionality.
================================================================================
License
MIT License
Star History
Repository Owner
User
Repository Details
Programming Languages
Tags
Join Our Newsletter
Stay updated with the latest AI tools, news, and offers by subscribing to our weekly newsletter.
Related MCPs
Discover similar Model Context Protocol servers
mcp-get
A command-line tool for discovering, installing, and managing Model Context Protocol servers.
mcp-get is a CLI tool designed to help users discover, install, and manage Model Context Protocol (MCP) servers. It enables seamless integration of Large Language Models (LLMs) with various external data sources and tools by utilizing a standardized protocol. The tool provides access to a curated registry of MCP servers and supports installation and management across multiple programming languages and environments. Although now archived, mcp-get simplifies environment variable management, package versioning, and server updates to enhance the LLM ecosystem.
- ⭐ 497
- MCP
- michaellatman/mcp-get
mcp-server-home-assistant
A Model Context Protocol Server integration for Home Assistant.
Provides an MCP server interface for Home Assistant, enabling context sharing between Home Assistant and AI models through the Model Context Protocol. Allows users to connect Claude Desktop and similar tools to Home Assistant via a WebSocket API and secure API token. Facilitates seamless integration by leveraging a custom Home Assistant component that is migrating into Home Assistant Core. Enables access and manipulation of smart home context data in standardized ways.
- ⭐ 64
- MCP
- allenporter/mcp-server-home-assistant
MCP Server for TheHive
Connect AI-powered automation tools to TheHive incident response platform via MCP.
MCP Server for TheHive enables AI models and automation clients to interact with TheHive incident response platform using the Model Context Protocol. It provides tools to retrieve and analyze security alerts, manage cases, and automate incident response operations. The server facilitates seamless integration by exposing these functionalities over the standardized MCP protocol through stdio communication. It offers both pre-compiled binaries and a source build option with flexible configuration for connecting to TheHive instances.
- ⭐ 11
- MCP
- gbrigandi/mcp-server-thehive
Intruder MCP
Enable AI agents to control Intruder.io via the Model Context Protocol.
Intruder MCP allows AI model clients such as Claude and Cursor to interactively control the Intruder vulnerability scanner through the Model Context Protocol. It can be deployed using smithery, locally with Python, or in a Docker container, requiring only an Intruder API key for secure access. The tool provides integration instructions tailored for MCP-compatible clients, streamlining vulnerability management automation for AI-driven workflows.
- ⭐ 21
- MCP
- intruder-io/intruder-mcp
Model Context Protocol Server for Home Assistant
Seamlessly connect Home Assistant to LLMs for natural language smart home control via MCP.
Enables integration between a local Home Assistant instance and language models using the Model Context Protocol (MCP). Facilitates natural language monitoring and control of smart home devices, with robust API support for state management, automation, real-time updates, and system administration. Features secure, token-based access, and supports mobile and HTTP clients. Designed to bridge Home Assistant environments with modern AI-driven automation.
- ⭐ 468
- MCP
- tevonsb/homeassistant-mcp
Apple Books MCP
Model Context Protocol server for integrating and managing Apple Books data with AI assistants.
Apple Books MCP is a server implementation of the Model Context Protocol (MCP) that enables AI assistants to access, organize, and interact with Apple Books data such as collections, books, highlights, notes, and annotations. It provides standardized tools for retrieving and searching book-related data, supporting integration with platforms like Claude Desktop. Designed for easy setup with Python or uv, it facilitates context-aware AI capabilities for reading and annotation workflows.
- ⭐ 33
- MCP
- vgnshiyer/apple-books-mcp
Didn't find tool you were looking for?