go_computer_use_mcp_server
MCP (Model Context Protocol) server in Go for computer automation. Uses robotgo library for desktop automation. Features Mouse control: movement, clicks, dragging, scrolling Keyboard control: key presses, text input, hotkeys Screen operations: screenshots, pixel color, display information Window management: move, resize, minimize/maximize Process management: list processes, search, terminate
README
go_computer_use_mcp_server
[!WARNING] This server is intended to run as a trusted local MCP tool.
It currently provides broad local desktop control and is not sandboxed by default.
Do not expose it to untrusted networks, users, or agents without additional security controls.
MCP (Model Context Protocol) server in Go for computer automation. Uses robotgo library for desktop automation.
Features
- Mouse control: movement, clicks, dragging, scrolling
- Keyboard control: key presses, text input, hotkeys
- Screen operations: screenshots, pixel color, display information
- Window management: move, resize, minimize/maximize
- Process management: list processes, search, terminate
- System utilities: system info, dialogs, delays
Quick Start with npx
The easiest way to run the server is via npx (requires Node.js 18+):
# Run with stdio transport (for MCP clients)
npx go-computer-use-mcp-server -t stdio
# Run with SSE transport
npx go-computer-use-mcp-server -t sse -h 0.0.0.0 -p 8080
Integration with AI Tools
Claude Desktop
Add to 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
{
"mcpServers": {
"computer-use": {
"command": "npx",
"args": ["-y", "go-computer-use-mcp-server", "-t", "stdio"]
}
}
}
Claude Code
Using CLI command:
claude mcp add computer-use -- npx -y go-computer-use-mcp-server -t stdio
claude mcp add --transport stdio \
--env DISPLAY="$DISPLAY" \
--env XAUTHORITY="${XAUTHORITY:-$HOME/.Xauthority}" \
computer-use -- \
npx -y go-computer-use-mcp-server -t stdio
Or add manually to your project's .mcp.json file:
{
"mcpServers": {
"computer-use": {
"command": "npx",
"args": ["-y", "go-computer-use-mcp-server", "-t", "stdio"]
}
}
}
OpenCode
Add to your opencode.jsonc configuration file:
{
"$schema": "https://opencode.ai/config.json",
"mcp": {
"computer-use": {
"type": "local",
"command": ["npx", "-y", "go-computer-use-mcp-server", "-t", "stdio"],
"enabled": true
}
}
}
Codex (OpenAI)
Using CLI command:
codex mcp add computer-use -- npx -y go-computer-use-mcp-server -t stdio
Or add to ~/.codex/config.toml:
[mcp_servers.computer-use]
command = "npx"
args = ["-y", "go-computer-use-mcp-server", "-t", "stdio"]
env_vars = ["DISPLAY", "XAUTHORITY"]
Cursor
Add to your Cursor MCP configuration. Go to Cursor Settings > Features > MCP Servers and add:
{
"mcpServers": {
"computer-use": {
"command": "npx",
"args": ["-y", "go-computer-use-mcp-server", "-t", "stdio"]
}
}
}
Windsurf
Add to ~/.codeium/mcp_config.json or via Settings > Cascade > MCP Servers > Add Server:
{
"mcpServers": {
"computer-use": {
"command": "npx",
"args": ["-y", "go-computer-use-mcp-server", "-t", "stdio"]
}
}
}
Cline (VS Code Extension)
Click the MCP Servers icon in Cline panel, select "Configure" tab, then "Configure MCP Servers" to edit cline_mcp_settings.json:
{
"mcpServers": {
"computer-use": {
"command": "npx",
"args": ["-y", "go-computer-use-mcp-server", "-t", "stdio"],
"disabled": false
}
}
}
Generic MCP Client
For any MCP-compatible client, use:
npx -y go-computer-use-mcp-server -t stdio
Installation from Source
Requirements
- Go 1.21+
- GCC compiler
- X11 libraries (Linux)
Ubuntu/Debian
# Go (if not installed)
sudo snap install go --classic
# GCC
sudo apt install gcc libc6-dev
# X11
sudo apt install libx11-dev xorg-dev libxtst-dev
# Clipboard support
sudo apt install xsel xclip
# Bitmap support (for image operations)
sudo apt install libpng++-dev
# Event hook support
sudo apt install xcb libxcb-xkb-dev x11-xkb-utils libx11-xcb-dev libxkbcommon-x11-dev libxkbcommon-dev
One-liner:
sudo apt install gcc libc6-dev libx11-dev xorg-dev libxtst-dev xsel xclip libpng++-dev xcb libxcb-xkb-dev x11-xkb-utils libx11-xcb-dev libxkbcommon-x11-dev libxkbcommon-dev
Fedora
# GCC (if not installed)
sudo dnf install gcc
# X11
sudo dnf install libX11-devel libXtst-devel
# Clipboard support
sudo dnf install xsel xclip
# Bitmap support
sudo dnf install libpng-devel
# Event hook support
sudo dnf install libxkbcommon-devel libxkbcommon-x11-devel xorg-x11-xkb-utils-devel
One-liner:
sudo dnf install gcc libX11-devel libXtst-devel xsel xclip libpng-devel libxkbcommon-devel libxkbcommon-x11-devel xorg-x11-xkb-utils-devel
Build
# Download dependencies
make deps
# Build for current platform
make build
# Build for all platforms
make build-all
Running (from source)
SSE transport (default)
./go_computer_use_mcp_server -t sse -h 0.0.0.0 -p 8080
Stdio transport
./go_computer_use_mcp_server -t stdio
Command line arguments
| Argument | Description | Default |
|---|---|---|
-t |
Transport: sse or stdio |
sse |
-h |
Host for SSE server | 0.0.0.0 |
-p |
Port for SSE server | 8080 |
Available Tools
Mouse Control (12 tools)
| Tool | Description |
|---|---|
mouse_move |
Move cursor to absolute coordinates |
mouse_move_smooth |
Smooth cursor movement (human-like) |
mouse_move_relative |
Relative cursor movement |
mouse_get_position |
Get current cursor position |
mouse_click |
Mouse click |
mouse_click_at |
Move and click |
mouse_toggle |
Press/release mouse button |
mouse_drag |
Drag operation |
mouse_drag_smooth |
Smooth drag operation |
mouse_scroll |
Scroll |
mouse_scroll_direction |
Scroll in direction |
mouse_scroll_smooth |
Smooth scroll |
Keyboard Control (7 tools)
| Tool | Description |
|---|---|
key_tap |
Key press (with modifiers) |
key_toggle |
Press/release key |
type_text |
Type text (UTF-8) |
type_text_delayed |
Type text with delay |
clipboard_read |
Read clipboard |
clipboard_write |
Write to clipboard |
clipboard_paste |
Paste via clipboard |
Screen Operations (7 tools)
| Tool | Description |
|---|---|
screen_get_size |
Get screen size |
screen_get_displays_num |
Number of monitors |
screen_get_display_bounds |
Monitor bounds |
screen_capture |
Screen capture (returns MCP ImageContent) |
screen_capture_save |
Capture and save to file |
screen_get_pixel_color |
Pixel color at coordinates |
screen_get_mouse_color |
Pixel color under cursor |
Window Management (9 tools)
| Tool | Description |
|---|---|
window_get_active |
Active window information |
window_get_title |
Window title |
window_get_bounds |
Window bounds |
window_set_active |
Activate window |
window_move |
Move window |
window_resize |
Resize window |
window_minimize |
Minimize window |
window_maximize |
Maximize window |
window_close |
Close window |
Process Management (6 tools)
| Tool | Description |
|---|---|
process_list |
List all processes |
process_find_by_name |
Find processes by name |
process_get_name |
Get process name by PID |
process_exists |
Check if process exists |
process_kill |
Kill process |
process_run |
Run command |
System Utilities (3 tools)
| Tool | Description |
|---|---|
system_get_info |
System information |
util_sleep |
Sleep/delay |
alert_show |
Show dialog |
Usage Examples
Move mouse and click
{
"tool": "mouse_click_at",
"arguments": {
"x": 100,
"y": 200,
"button": "left",
"double": false
}
}
Type text
{
"tool": "type_text",
"arguments": {
"text": "Hello, World!",
"delay": 50
}
}
Hotkeys
{
"tool": "key_tap",
"arguments": {
"key": "c",
"modifiers": ["ctrl"]
}
}
Screen capture
{
"tool": "screen_capture",
"arguments": {
"x": 0,
"y": 0,
"width": 800,
"height": 600
}
}
Supported Keys
Letters and numbers
a-z, A-Z, 0-9
Function keys
f1-f24
Navigation
up, down, left, right, home, end, pageup, pagedown
Special keys
backspace, delete, enter, tab, escape, space, insert, capslock
Modifiers
alt, ctrl, shift, cmd (or command)
Multimedia
audio_mute, audio_vol_down, audio_vol_up, audio_play, audio_stop, audio_pause
License
MIT
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.