Tauri MCP Server
A server for testing and interacting with Tauri v2 applications, providing tools for process management, window manipulation, and debugging.
Tauri MCP Server
A Model Context Protocol (MCP) server for testing and interacting with Tauri v2 applications. This tool enables AI assistants to better understand, debug, and interact with Tauri apps during development.
The MCP protocol provides a standardized way for AI assistants to interact with external tools and systems. This server implements the MCP specification to expose Tauri application testing and debugging capabilities.
MCP Compliance
This server is fully compliant with the Model Context Protocol specification. It implements:
- ✅ JSON-RPC 2.0 transport over stdio
- ✅ Initialize/shutdown handshake
- ✅ Tools capability with 12 specialized Tauri testing tools
- ✅ Proper error handling with descriptive messages
- ✅ Tool schemas using JSON Schema format
- ✅ Protocol version compatibility - Supports both "1.0" and date-based versions (e.g., "2024-11-05")
For more details about MCP:
Features
Core Tools
-
Process Management
launch_app- Launch Tauri applications with argumentsstop_app- Gracefully stop running appsget_app_logs- Capture stdout/stderr outputmonitor_resources- Track CPU, memory, and disk usage
-
Window Manipulation
take_screenshot- Capture app window screenshotsget_window_info- Get window dimensions, position, and state
-
Input Simulation
send_keyboard_input- Simulate keyboard inputsend_mouse_click- Simulate mouse clicks- Mouse movement, dragging, and scrolling support
-
Debugging Tools
execute_js- Execute JavaScript in the webviewget_devtools_info- Get DevTools connection info- WebDriver integration for advanced testing
- Console log capture
-
IPC Interaction
list_ipc_handlers- List registered Tauri commandscall_ipc_command- Call Tauri IPC commands- Event emission and listening
Installation
Using DXT (Recommended for Claude Desktop)
The easiest way to install tauri-mcp for use with Claude Desktop is via DXT (Desktop Extension):
- Download the latest
tauri-mcp-node-*.dxtfile from the releases page - Double-click the
.dxtfile to install (or drag it onto Claude Desktop) - The server will be automatically configured and ready to use
Note: Due to a known issue with Claude Desktop's DXT extraction, we provide a Node.js wrapper version (tauri-mcp-node-*.dxt) that works around this limitation.
Using Cargo
cargo install tauri-mcp
Important Note for Rust-based MCP Servers: Claude Desktop currently has compatibility issues with Rust-based MCP servers, causing immediate disconnections after initialization. This is a known issue affecting all non-Node.js MCP servers. The cargo installation is suitable for:
- Direct CLI usage
- Integration with other tools
- Development and testing
For use with Claude Desktop, please use the DXT package which includes a Node.js wrapper.
From Source
# Clone the repository
git clone https://github.com/dirvine/tauri-mcp.git
cd tauri-mcp
# Build and install
cargo install --path .
Usage
As a Standalone Server
# Start the MCP server
tauri-mcp serve
# With custom host and port
tauri-mcp serve --host 127.0.0.1 --port 3000
# With a specific Tauri app
tauri-mcp --app-path ./my-tauri-app
Configuration
Create a tauri-mcp.toml file for configuration:
auto_discover = true
session_management = true
event_streaming = false
performance_profiling = false
network_interception = false
Environment Variables
TAURI_MCP_LOG_LEVEL- Set log level (trace, debug, info, warn, error)TAURI_MCP_CONFIG- Path to config file (default: tauri-mcp.toml)
MCP Integration
Claude Desktop Configuration
Option 1: Using DXT Package (Recommended)
Install the tauri-mcp-node-*.dxt package by double-clicking it. The server will be automatically configured.
Option 2: Manual Configuration
If you need to configure manually or use the development version, add to your Claude Desktop configuration:
{
"mcpServers": {
"tauri-mcp": {
"command": "node",
"args": ["/path/to/tauri-mcp/server/index.js"],
"env": {
"TAURI_MCP_LOG_LEVEL": "info"
}
}
}
}
Note: Direct Rust binary configuration ("command": "tauri-mcp") will not work with Claude Desktop due to compatibility issues. Use the Node.js wrapper approach shown above.
Available MCP Tools
All tools are exposed through the MCP protocol and can be called by AI assistants:
// Launch a Tauri app
await use_mcp_tool("tauri-mcp", "launch_app", {
app_path: "/path/to/tauri-app",
args: ["--debug"]
});
// Take a screenshot
await use_mcp_tool("tauri-mcp", "take_screenshot", {
process_id: "uuid-here",
output_path: "./screenshot.png"
});
// Execute JavaScript
await use_mcp_tool("tauri-mcp", "execute_js", {
process_id: "uuid-here",
javascript_code: "window.location.href"
});
// Send keyboard input
await use_mcp_tool("tauri-mcp", "send_keyboard_input", {
process_id: "uuid-here",
keys: "cmd+a"
});
Platform Support
- macOS - Full support including window management
- Windows - Full support with native window APIs
- Linux - X11 support (Wayland in progress)
Development
Building
# Debug build
cargo build
# Release build
cargo build --release
# Run tests
cargo test
Building DXT Packages
The project includes build scripts for creating DXT (Desktop Extension) packages for different platforms.
Prerequisites
- Rust toolchain installed
- Node.js 18+ (for the Node.js wrapper)
zipcommand available in PATH
Building on macOS/Linux
# Build the Node.js wrapper version (recommended)
./build-dxt-node.sh
# The DXT package will be created as tauri-mcp-node-*.dxt
Building on Windows
# Create a Windows build script or use WSL
# Ensure you have zip.exe available or use PowerShell's Compress-Archive
# Build release binary
cargo build --release
# Create package directory structure
mkdir dxt-package-node
mkdir dxt-package-node\server
# Copy files
copy target\release\tauri-mcp.exe dxt-package-node\
copy server\*.* dxt-package-node\server\
copy manifest-node.json dxt-package-node\manifest.json
# Install Node dependencies
cd dxt-package-node\server
npm install --production
cd ..\..
# Create DXT archive (using PowerShell)
Compress-Archive -Path dxt-package-node\* -DestinationPath tauri-mcp-node.zip
Rename-Item tauri-mcp-node.zip tauri-mcp-node-0.1.8.dxt
DXT Package Structure
The DXT package includes:
manifest.json- Extension metadata and configurationtauri-mcp- The compiled Rust binaryserver/- Node.js wrapper and dependenciesindex.js- Node.js MCP server that spawns the Rust binarypackage.json- Node.js dependenciesnode_modules/- MCP SDK and dependencies
Important Notes
-
Use
--no-dir-entriesflag: When creating the zip file, use the--no-dir-entriesflag to avoid extraction issues:zip -r package.dxt . --no-dir-entries -
Binary permissions: Ensure the Rust binary has executable permissions before packaging:
chmod +x tauri-mcp -
Cross-platform builds: For distributing to other platforms, you'll need to build the Rust binary on each target platform or use cross-compilation.
Project Structure
tauri-mcp/
├── src/
│ ├── main.rs # Entry point
│ ├── server.rs # MCP server implementation
│ ├── tools/ # Tool implementations
│ │ ├── process.rs # Process management
│ │ ├── window.rs # Window manipulation
│ │ ├── input.rs # Input simulation
│ │ ├── debug.rs # Debugging tools
│ │ └── ipc.rs # IPC interaction
│ └── utils/ # Utility modules
├── examples/ # Example Tauri apps
└── tests/ # Integration tests
Examples
Testing a Tauri App
# Launch the server
tauri-mcp serve
# In your AI assistant:
# 1. Launch the app
# 2. Take a screenshot
# 3. Send some input
# 4. Check the logs
# 5. Stop the app
Automated Testing Script
import asyncio
from mcp import Client
async def test_tauri_app():
client = Client("tauri-mcp")
# Launch app
result = await client.call_tool("launch_app", {
"app_path": "./my-app",
"args": ["--test-mode"]
})
process_id = result["process_id"]
# Wait for app to start
await asyncio.sleep(2)
# Take screenshot
await client.call_tool("take_screenshot", {
"process_id": process_id,
"output_path": "./test-screenshot.png"
})
# Send input
await client.call_tool("send_keyboard_input", {
"process_id": process_id,
"keys": "Hello, Tauri!"
})
# Get logs
logs = await client.call_tool("get_app_logs", {
"process_id": process_id,
"lines": 50
})
print("App logs:", logs)
# Stop app
await client.call_tool("stop_app", {
"process_id": process_id
})
asyncio.run(test_tauri_app())
Troubleshooting
Common Issues
-
Permission Denied on macOS
- Grant accessibility permissions in System Preferences
- Required for input simulation
-
Screenshot Fails
- Ensure screen recording permissions are granted
- Check if the app window is visible
-
WebDriver Connection Failed
- Ensure the Tauri app has DevTools enabled
- Check if ChromeDriver is installed for WebDriver support
Debug Mode
Enable debug logging:
TAURI_MCP_LOG_LEVEL=debug tauri-mcp serve
Contributing
Contributions are welcome! Please feel free to submit a Pull Request.
- Fork the repository
- Create your feature branch (
git checkout -b feature/amazing-feature) - Commit your changes (
git commit -m 'Add some amazing feature') - Push to the branch (
git push origin feature/amazing-feature) - Open a Pull Request
License
This project is licensed under the MIT License - see the LICENSE file for details.
Acknowledgments
- Implements the Model Context Protocol specification
- Designed for Tauri v2 applications
- Input simulation powered by enigo
- Screenshot functionality via screenshots-rs
Related Servers
Odoo XML-RPC MCP Server
Interact with Odoo instances using the XML-RPC API. Requires configuration via environment variables or config files.
E2B
Run code in secure sandboxes hosted by E2B
Hostname MCP Server
A lightweight server for hostname detection and system context.
VibeShift
An intelligent security agent that analyzes AI-generated code for vulnerabilities and assists with remediation.
Markdown Sidecar MCP Server
An MCP server to access markdown documentation for locally installed NPM, Go, and PyPi packages.
Node.js API Docs
An MCP server for accessing and searching Node.js API documentation.
Open MCP Server
A service framework supporting the Model Context Protocol (MCP) to integrate enterprise systems and AI platforms via RESTful, gRPC, and Dubbo protocols.
MCP Stdio-HTTP Proxy
A TypeScript proxy that connects stdio MCP clients to HTTP SSE MCP servers, handling OAuth authentication.
MCP Server with Google OAuth & Analytics
A remote MCP server with built-in Google OAuth authentication and analytics tracking.
cellrank-MCP
A natural language interface for single-cell RNA sequencing (scRNA-Seq) analysis using the CellRank toolkit.