WSLSnapit-MCP

WSLSnapit-MCP

Enables AI assistants to capture screenshots and read clipboard content from Windows applications while operating within a WSL environment. It supports monitor or window-specific targeting and features intelligent image optimization for efficient data transfer.

Category
Visit Server

README

WSLSnapit-MCP 📸

WSLSnapit-MCP is a powerful Model Context Protocol (MCP) server that provides advanced screenshot capture and clipboard reading capabilities for Windows applications from within WSL environments. It enables AI assistants to capture screens, windows, and monitors with intelligent image processing and optimization, as well as read text and images from the Windows clipboard.

License MCP Node

✨ Features

📸 Screenshot Capture

  • Monitor Selection: Capture all monitors, primary monitor, or specific monitor by number
  • Window Targeting: Capture specific windows by title (partial match) or process name
  • Smart Compression: Automatic image optimization to stay under 1MB with progressive quality adjustment
  • Direct Return: Images can be returned directly to AI assistants or saved to disk
  • DPI-Aware: Handles multi-monitor setups with different scaling factors correctly

📋 Clipboard Reading

  • Auto-Detection: Automatically detects whether clipboard contains text or image
  • Text Support: Read text content from Windows clipboard
  • Image Support: Capture images from clipboard with automatic compression
  • Format Control: Force specific format (text/image) or use auto mode

🚀 Performance

  • Efficient Processing: Memory-conscious handling of high-resolution captures
  • Progressive Compression: Dynamic quality adjustment (1920px → 1280px → 800px if needed)
  • Optimized Communication: Base64 encoding for reliable binary data transfer

📦 Installation

Prerequisites

  • Windows 10/11 with WSL2 installed
  • Node.js 18.0.0 or higher
  • npm, yarn, or bun package manager
  • PowerShell (comes with Windows)

Quick Install

# Clone the repository
git clone https://github.com/yourusername/WSLSnapit-MCP.git
cd WSLSnapit-MCP

# Install dependencies
npm install
# or
yarn install
# or
bun install

Claude Desktop Configuration

Add the following to your Claude Desktop configuration file:

Windows: %APPDATA%\Claude\claude_desktop_config.json macOS: ~/Library/Application Support/Claude/claude_desktop_config.json Linux: ~/.config/Claude/claude_desktop_config.json

{
  "mcpServers": {
    "wslsnapit": {
      "command": "wsl",
      "args": [
        "--cd",
        "/mnt/h/dev/mcp/wslsnapit-mcp",
        "node",
        "index.js"
      ]
    }
  }
}

Note: Adjust the path /mnt/h/dev/mcp/wslsnapit-mcp to match your installation location.

🎯 Usage

Screenshot Capture

The take_screenshot tool supports various capture modes:

Basic Usage

// Capture all monitors (default)
take_screenshot()

// Capture primary monitor only
take_screenshot({ monitor: "primary" })

// Capture specific monitor (1, 2, 3, etc.)
take_screenshot({ monitor: 2 })

Window Capture

// Capture window by title (partial match)
take_screenshot({ windowTitle: "Visual Studio" })

// Capture window by process name
take_screenshot({ processName: "notepad" })

// Handle multiple matching windows
take_screenshot({ windowTitle: "Chrome", windowIndex: 2 })

Output Options

// Return image directly (default)
take_screenshot({ returnDirect: true })

// Save to file
take_screenshot({ 
  returnDirect: false, 
  filename: "myshot.png",
  folder: "/home/user/screenshots" 
})

// Control JPEG quality (for direct return)
take_screenshot({ 
  returnDirect: true, 
  quality: 90 
})

Clipboard Reading

The read_clipboard tool supports both text and image content:

// Auto-detect clipboard content (default)
read_clipboard()

// Force text reading
read_clipboard({ format: "text" })

// Force image reading
read_clipboard({ format: "image" })

🔧 Parameters Reference

take_screenshot

Parameter Type Default Description
filename string "screenshot.png" Filename when saving to disk
monitor string|number "all" Monitor selection: "all", "primary", or monitor number
windowTitle string - Capture window by title (partial match)
windowIndex number 1 Which window to capture when multiple match
processName string - Capture window by process name
folder string - Custom folder path (supports WSL and Windows paths)
returnDirect boolean true Return image to AI or save to disk
quality number 80 JPEG quality (1-100) for direct return

read_clipboard

Parameter Type Default Description
format string "auto" Format: "auto", "text", or "image"

🛡️ Security Considerations

WSLSnapit-MCP is designed with security in mind:

  • Minimal Permissions: Windows executable runs with minimal permissions, only accessing screen capture and clipboard APIs
  • Local Processing: All clipboard data is processed locally without any network transmission
  • Process Isolation: PowerShell runs as a separate Windows process, preventing access to sensitive WSL environment
  • Input Validation: All user inputs are properly escaped to prevent injection attacks
  • Resource Limits: Memory limits and progressive compression prevent resource exhaustion

🏗️ Architecture

Core Components

  • MCP Server: Implements the Model Context Protocol for AI assistant integration
  • PowerShell Bridge: Executes Windows-specific operations from WSL
  • Image Processor: Uses Sharp library for efficient image compression
  • Path Handler: Seamlessly converts between WSL and Windows paths

Technology Stack

  • Node.js with ES modules
  • @modelcontextprotocol/sdk for MCP implementation
  • Sharp for image processing
  • PowerShell for Windows API integration

🐛 Troubleshooting

Common Issues

  1. "No windows found" error

    • Ensure the target window is visible and not minimized
    • Try using a shorter or different part of the window title
    • Use process name instead of window title
  2. Large screenshots fail to return

    • The tool automatically compresses images to stay under 1MB
    • If issues persist, try lowering the quality parameter
  3. Clipboard reading returns empty

    • Ensure content is properly copied to clipboard
    • Try specifying the format explicitly instead of using auto-detect
  4. Path not found errors

    • Verify the folder path exists
    • Remember WSL paths start with /mnt/c/ for C: drive

Debug Mode

To run with debug output:

DEBUG=* node index.js

🤝 Contributing

Contributions are welcome! Please feel free to submit a Pull Request. For major changes, please open an issue first to discuss what you would like to change.

  1. Fork the repository
  2. Create your feature branch (git checkout -b feature/AmazingFeature)
  3. Commit your changes (git commit -m 'Add some AmazingFeature')
  4. Push to the branch (git push origin feature/AmazingFeature)
  5. Open a Pull Request

📄 License

This project is licensed under the MIT License - see the LICENSE file for details.

🙏 Acknowledgments

📞 Support


Made with ❤️ for the WSL and MCP community

Recommended Servers

playwright-mcp

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.

Official
Featured
TypeScript
Magic Component Platform (MCP)

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.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

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.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
Kagi MCP Server

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.

Official
Featured
Python
graphlit-mcp-server

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.

Official
Featured
TypeScript
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

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.

Official
Featured
E2B

E2B

Using MCP to run code via e2b.

Official
Featured