Eduard Ruzga/DesktopCommanderMCP
Built by Metorial, the integration platform for agentic AI.
Eduard Ruzga/DesktopCommanderMCP
Server Summary
Execute terminal commands
Manage processes
Perform text replacements
Rewrite files
Automate tasks
Edit files
Work with code and text, run processes, and automate tasks, going far beyond other AI editors - without API token costs.
All of your AI development tools in one place. Desktop Commander puts all dev tools in one chat. Execute long-running terminal commands on your computer and manage processes through Model Context Protocol (MCP). Built on top of MCP Filesystem Server to provide additional search and replace file editing capabilities.
First, ensure you've downloaded and installed the Claude Desktop app and you have npm installed.
π Update & Uninstall Information: Before choosing an installation option, note that only Options 1 and 3 have automatic updates. Options 2, 4, and 5 require manual updates. See the sections below for update and uninstall instructions for each option.
Just run this in terminal:
npx @wonderwhy-er/desktop-commander@latest setup
For debugging mode (allows Node.js inspector connection):
npx @wonderwhy-er/desktop-commander@latest setup --debug
Restart Claude if running.
β
Auto-Updates: Yes - automatically updates when you restart Claude
π Manual Update: Run the setup command again
ποΈ Uninstall: Run npx @wonderwhy-er/desktop-commander@latest setup --uninstall
For macOS users, you can use our automated bash installer which will check your Node.js version, install it if needed, and automatically configure Desktop Commander:
curl -fsSL https://raw.githubusercontent.com/wonderwhy-er/DesktopCommanderMCP/refs/heads/main/install.sh | bash
This script handles all dependencies and configuration automatically for a seamless setup experience.
β
Auto-Updates: Yes - requires manual updates
π Manual Update: Re-run the bash installer command above
ποΈ Uninstall: Remove the MCP server entry from your Claude config file and delete the cloned repository if it exists
To install Desktop Commander for Claude Desktop automatically via Smithery:
npx -y @smithery/cli install @wonderwhy-er/desktop-commander --client claude
β
Auto-Updates: Yes - automatically updates when you restart Claude
π Manual Update: Re-run the Smithery install command
ποΈ Uninstall: npx -y @smithery/cli uninstall @wonderwhy-er/desktop-commander --client claude
Add this entry to your claude_desktop_config.json:
~/Library/Application\ Support/Claude/claude_desktop_config.json
%APPDATA%\Claude\claude_desktop_config.json
~/.config/Claude/claude_desktop_config.json
{
"mcpServers": {
"desktop-commander": {
"command": "npx",
"args": [
"-y",
"@wonderwhy-er/desktop-commander"
]
}
}
}
Restart Claude if running.
β Auto-Updates: No - uses npx but config might not update automatically
π Manual Update: Usually automatic via npx, but if issues occur, update your config file or re-add the entry
ποΈ Uninstall: Remove the "desktop-commander" entry from your claude_desktop_config.json file
git clone https://github.com/wonderwhy-er/DesktopCommanderMCP.git
cd DesktopCommanderMCP
npm run setup
Restart Claude if running.
The setup command will:
β Auto-Updates: No - requires manual git updates
π Manual Update: cd DesktopCommanderMCP && git pull && npm run setup
ποΈ Uninstall: Remove the cloned directory and remove MCP server entry from Claude config
Options 1 (npx) and 3 (Smithery) automatically update to the latest version whenever you restart Claude. No manual intervention needed.
cd DesktopCommanderMCP && git pull && npm run setup
npx @wonderwhy-er/desktop-commander@latest setup --uninstall
npx -y @smithery/cli uninstall @wonderwhy-er/desktop-commander --client claude
After uninstalling, restart Claude Desktop to complete the removal.
The server provides a comprehensive set of tools organized into several categories:
Category | Tool | Description |
---|---|---|
Configuration | get_config | Get the complete server configuration as JSON (includes blockedCommands, defaultShell, allowedDirectories, fileReadLineLimit, fileWriteLineLimit, telemetryEnabled) |
set_config_value | Set a specific configuration value by key. Available settings: β’ blockedCommands : Array of shell commands that cannot be executedβ’ defaultShell : Shell to use for commands (e.g., bash, zsh, powershell)β’ allowedDirectories : Array of filesystem paths the server can access for file operations (β οΈ terminal commands can still access files outside these directories)β’ fileReadLineLimit : Maximum lines to read at once (default: 1000)β’ fileWriteLineLimit : Maximum lines to write at once (default: 50)β’ telemetryEnabled : Enable/disable telemetry (boolean) | |
Terminal | start_process | Start programs with smart detection of when they're ready for input |
interact_with_process | Send commands to running programs and get responses | |
read_process_output | Read output from running processes | |
force_terminate | Force terminate a running terminal session | |
list_sessions | List all active terminal sessions | |
list_processes | List all running processes with detailed information | |
kill_process | Terminate a running process by PID | |
Filesystem | read_file | Read contents from local filesystem or URLs with line-based pagination (supports positive/negative offset and length parameters) |
read_multiple_files | Read multiple files simultaneously | |
write_file | Write file contents with options for rewrite or append mode (uses configurable line limits) | |
create_directory | Create a new directory or ensure it exists | |
list_directory | Get detailed listing of files and directories | |
move_file | Move or rename files and directories | |
search_files | Find files by name using case-insensitive substring matching | |
search_code | Search for text/code patterns within file contents using ripgrep | |
get_file_info | Retrieve detailed metadata about a file or directory | |
Text Editing | edit_block | Apply targeted text replacements with enhanced prompting for smaller edits (includes character-level diff feedback) |
Analytics | get_usage_stats | Get usage statistics for your own insight |
give_feedback_to_desktop_commander | Open feedback form in browser to provide feedback to Desktop Commander Team |
Data Analysis:
"Analyze sales.csv and show top customers" β Claude runs Python code in memory
Remote Access:
"SSH to my server and check disk space" β Claude maintains SSH session
Development:
"Start Node.js and test this API" β Claude runs interactive Node session
Search/Replace Block Format:
filepath.ext
< SEARCH
content to find
=======
new content
>>>>>>> REPLACE
Example:
src/main.js
< SEARCH
console.log("old message");
=======
console.log("new message");
>>>>>>> REPLACE
The edit_block
tool includes several enhancements for better reliability:
{-removed-}{+added+}
formatexpected_replacements
parameterWhen a search fails, you'll see detailed information about the closest match found, including similarity percentage, execution time, and character differences. All these details are automatically logged for later analysis using the fuzzy search log tools.
Desktop Commander can be run in Docker containers for complete isolation from your host system, providing zero risk to your computer. This is perfect for testing, development, or when you want complete sandboxing.
Install Docker for Windows/Mac
Get Desktop Commander Docker Configuration
Mount Your Machine Folders (Coming Soon)
read_file
can now fetch content from both local files and URLsread_file
with isUrl: true
parameter to read from web resourcesThe fuzzy search logging system includes convenient npm scripts for analyzing logs outside of the MCP environment:
# View recent fuzzy search logs
npm run logs:view -- --count 20
# Analyze patterns and performance
npm run logs:analyze -- --threshold 0.8
# Export logs to CSV or JSON
npm run logs:export -- --format json --output analysis.json
# Clear all logs (with confirmation)
npm run logs:clear
For detailed documentation on these scripts, see scripts/README.md.
Desktop Commander includes comprehensive logging for fuzzy search operations in the edit_block
tool. When an exact match isn't found, the system performs a fuzzy search and logs detailed information for analysis.
Every fuzzy search operation logs:
Logs are automatically saved to:
~/.claude-server-commander-logs/fuzzy-search.log
%USERPROFILE%\.claude-server-commander-logs\fuzzy-search.log
The fuzzy search logs help you understand:
Desktop Commander now includes comprehensive logging for all tool calls:
Logs are saved to:
~/.claude-server-commander/claude_tool_call.log
%USERPROFILE%\.claude-server-commander\claude_tool_call.log
This audit trail helps with debugging, security monitoring, and understanding how Claude is interacting with your system.
For commands that may take a while:
Always change configuration in a separate chat window from where you're doing your actual work. Claude may sometimes attempt to modify configuration settings (like allowedDirectories
) if it encounters filesystem access restrictions.
The allowedDirectories
setting currently only restricts filesystem operations, not terminal commands. Terminal commands can still access files outside allowed directories. Full terminal sandboxing is on the roadmap.
You can manage server configuration using the provided tools:
// Get the entire config
get_config({})
// Set a specific config value
set_config_value({ "key": "defaultShell", "value": "/bin/zsh" })
// Set multiple config values using separate calls
set_config_value({ "key": "defaultShell", "value": "/bin/bash" })
set_config_value({ "key": "allowedDirectories", "value": ["/Users/username/projects"] })
The configuration is saved to config.json
in the server's working directory and persists between server restarts.
The fileWriteLineLimit
setting controls how many lines can be written in a single write_file
operation (default: 50 lines). This limit exists for several important reasons:
Why the limit exists:
Setting the limit:
// You can set it to thousands if you want
set_config_value({ "key": "fileWriteLineLimit", "value": 1000 })
// Or keep it smaller to force more efficient behavior
set_config_value({ "key": "fileWriteLineLimit", "value": 25 })
Maximum value: You can set it to thousands if you want - there's no technical restriction.
Best practices:
Create a dedicated chat for configuration changes: Make all your config changes in one chat, then start a new chat for your actual work.
Be careful with empty allowedDirectories
: Setting this to an empty array ([]
) grants access to your entire filesystem for file operations.
Use specific paths: Instead of using broad paths like /
, specify exact directories you want to access.
Always verify configuration after changes: Use get_config({})
to confirm your changes were applied correctly.
You can specify which shell to use for command execution:
// Using default shell (bash or system default)
execute_command({ "command": "echo $SHELL" })
// Using zsh specifically
execute_command({ "command": "echo $SHELL", "shell": "/bin/zsh" })
// Using bash specifically
execute_command({ "command": "echo $SHELL", "shell": "/bin/bash" })
This allows you to use shell-specific features or maintain consistent environments across commands.
execute_command
returns after timeout with initial outputread_output
with PID to get new outputforce_terminate
to stop if neededIf you need to debug the server, you can install it in debug mode:
# Using npx
npx @wonderwhy-er/desktop-commander@latest setup --debug
# Or if installed locally
npm run setup:debug
This will:
--inspect-brk=9229
flagTo connect a debugger:
chrome://inspect
and look for the Node.js instanceImportant debugging notes:
--inspect-brk
flag)Troubleshooting:
This project extends the MCP Filesystem Server to enable:
Created as part of exploring Claude MCPs: https://youtube.com/live/TlbjFDbl5Us
read_file
command can now fetch content from URLsThe following features are currently being explored: