MCP Desktop Automation
Automate desktop actions like mouse control, keyboard input, and taking screenshots.
MCP Desktop Automation
A Model Context Protocol server that provides desktop automation capabilities using RobotJS and screenshot capabilities. This server enables LLMs to control mouse movements, keyboard inputs, and capture screenshots of the desktop environment.
Configuration to use Desktop Automation Server
Here's how to configure Claude Desktop to use the MCP Desktop Automation server:
NPX
{
"mcpServers": {
"desktop-automation": {
"command": "npx",
"args": ["-y", "mcp-desktop-automation"]
}
}
}
Permissions
This server requires system-level permissions to:
- Capture screenshots of your screen
- Control mouse movement and clicks
- Simulate keyboard input
When first running Claude Desktop with this server, you may need to grant these permissions in your operating system's security settings.
Limitations
While this server works with various MCP clients, it has been primarily tested with Claude Desktop.
Important: The current implementation has a 1MB response size limit. For screen captures, this means:
- High-resolution screenshots may exceed this limit and fail
- Testing has shown 800x600 resolution works reliably
- Consider reducing screen resolution or capturing specific screen areas if you encounter issues
Requirements
- Node.js (>=14.x)
Components
Tools
-
get_screen_size
- Gets the screen dimensions
- No input parameters required
-
screen_capture
- Captures the current screen content
- No input parameters required
-
keyboard_press
- Presses a keyboard key or key combination
- Inputs:
key(string, required): Key to press (e.g., 'enter', 'a', 'control')modifiers(array of strings, optional): Modifier keys to hold while pressing the key. Possible values: "control", "shift", "alt", "command"
-
keyboard_type
- Types text at the current cursor position
- Input:
text(string, required): Text to type
-
mouse_click
- Performs a mouse click
- Inputs:
button(string, optional, default: "left"): Mouse button to click. Possible values: "left", "right", "middle"double(boolean, optional, default: false): Whether to perform a double click
-
mouse_move
- Moves the mouse to specified coordinates
- Inputs:
x(number, required): X coordinatey(number, required): Y coordinate
Resources
The server provides access to screenshots:
-
Screenshot List (
screenshot://list)- Lists all available screenshots by name
-
Screenshot Content (
screenshot://{id})- PNG images of captured screenshots
- Accessible via the screenshot ID (timestamp-based naming)
Key Features
- Desktop mouse control
- Keyboard input simulation
- Screen size detection
- Screenshot capabilities
- Simple JSON response format
License
This MCP server is licensed under the MIT License. This means you are free to use, modify, and distribute the software, subject to the terms and conditions of the MIT License. For more details, please see the LICENSE file in the project repository.
Related Servers
FluentLab Funding Assistant
An assistant API to help find and apply for funding opportunities.
Jira MCP Server
An MCP server for accessing JIRA issue data stored in Snowflake.
Yuga Planner
AI Task schedule planning with LLamaIndex and Timefold: breaks down a task description and schedules it around an existing calendar
MCP Atlassian
Interact with Atlassian products like Confluence and Jira, supporting both Cloud and Server/Data Center deployments.
Actual Budget
Integrate Actual Budget with LLM assistants to manage your personal finances.
Mesh Scanner
A simple, self-contained notes system with resources, tools, and prompts, implemented as an MCP server.
Phabricator
Interact with Phabricator for task management and code review workflows.
NPX-MCP
A TypeScript server for automation and integration, featuring Microsoft OAuth, browser control, and basic utilities.
Computer Control MCP
Control your computer's mouse, keyboard, and perform OCR using PyAutoGUI and RapidOCR. Works on Windows, with potential support for other platforms.
Taskade
Connect to the Taskade platform via MCP. Access tasks, projects, workflows, and AI agents in real-time through a unified workspace and API.