mcp-clipboardify
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@mcp-clipboardifywhat's on my clipboard?"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
MCP Clipboard Server
A Model Context Protocol (MCP) server that provides clipboard access tools for AI assistants and automation workflows. Seamlessly integrate clipboard operations into your AI-powered applications.
๐ Quick Navigation
๐ Quick Start - Get up and running in minutes
โจ Features - Full feature overview
๐ Tools - Available clipboard operations
๐ง Usage Examples - JSON-RPC protocol examples
๐๏ธ Installation & Setup - Platform-specific instructions
๐ Troubleshooting - Platform support and common issues
๐ Technical Reference - Protocol details
๐ค Contributing - Development and contribution guidelines
๐ Quick Start
Install the server:
pip install mcp-clipboardifyStart the server:
mcp-clipboardify
# or alternatively:
python -m mcp_clipboard_serverโจ Features
Cross-platform clipboard access - Works on Windows, macOS, and Linux with platform-specific fallback handling
MCP protocol compliance - Full JSON-RPC 2.0 over STDIO implementation with batch request support
JSON Schema validation - Comprehensive parameter validation with detailed error messages
Two core tools:
get_clipboard- Retrieve current clipboard contentset_clipboard- Set clipboard to provided text
Enhanced error handling - Platform-specific guidance for troubleshooting clipboard issues
Graceful degradation - Fails safely with empty string on read errors, detailed error messages on write failures
Size limits - 1MB text limit to prevent memory issues
Unicode support - Full UTF-8 support for international text and emoji
Type safety - Built with TypedDict for reliable protocol compliance
Production ready - Comprehensive testing across platforms with CI/CD pipeline
๐ Tools
get_clipboard
Retrieves the current text content from the system clipboard.
Parameters: None
Returns: Current clipboard content as a string
set_clipboard
Sets the system clipboard to the provided text content.
Parameters:
text(string, required): The text content to copy to the clipboardMaximum size: 1MB (1,048,576 bytes)
Supports Unicode text and emoji
Returns: Success confirmation
๐ง Usage Examples
Basic MCP Client Communication
The server uses JSON-RPC 2.0 over STDIO. Here are example request/response patterns:
# Initialize the connection:
{
"jsonrpc": "2.0",
"id": 1,
"method": "initialize",
"params": {
"protocolVersion": "2024-11-05",
"capabilities": {},
"clientInfo": {
"name": "example-client",
"version": "1.0.0"
}
}
}# List available tools:
{
"jsonrpc": "2.0",
"id": 2,
"method": "tools/list",
"params": {}
}# Get clipboard content:
{
"jsonrpc": "2.0",
"id": 3,
"method": "tools/call",
"params": {
"name": "get_clipboard",
"arguments": {}
}
}# Set clipboard content:
{
"jsonrpc": "2.0",
"id": 4,
"method": "tools/call",
"params": {
"name": "set_clipboard",
"arguments": {
"text": "Hello, World! ๐"
}
}
}# Batch Requests (JSON-RPC 2.0)
The server supports batch requests for processing multiple operations in a single call:
[
{
"jsonrpc": "2.0",
"id": 1,
"method": "tools/call",
"params": {
"name": "get_clipboard",
"arguments": {}
}
},
{
"jsonrpc": "2.0",
"id": 2,
"method": "tools/call",
"params": {
"name": "set_clipboard",
"arguments": {
"text": "Batch operation result"
}
}
}
]๐ง JSON-RPC 2.0 Compliance
This server implements full JSON-RPC 2.0 specification with the following features:
Supported Features
โ Single requests - Standard request/response pattern
โ Batch requests - Process multiple requests in one call
โ Notifications - Fire-and-forget messages (e.g.,
$/ping)โ Error handling - Comprehensive error codes and messages
โ Parameter validation - JSON Schema-based validation with detailed error reports
Schema Validation
All tool parameters are validated against JSON schemas with helpful error messages:
Type validation - Ensures parameters are correct types
Required fields - Validates all required parameters are present
Size limits - Enforces 1MB text size limit for clipboard operations
Additional properties - Rejects unexpected parameters
Error Codes
The server uses standard JSON-RPC 2.0 error codes plus MCP-specific extensions:
-32700Parse error (invalid JSON)-32600Invalid Request (malformed JSON-RPC)-32601Method not found-32602Invalid params (schema validation failures)-32603Internal error-32000Server error (MCP-specific errors)
Integration with MCP Clients
This server works with any MCP-compatible client. Example integration:
import subprocess
import json
# Start the server
process = subprocess.Popen(
["mcp-clipboardify"],
stdin=subprocess.PIPE,
stdout=subprocess.PIPE,
text=True
)
# Send initialize request
init_request = {
"jsonrpc": "2.0",
"id": 1,
"method": "initialize",
"params": {
"protocolVersion": "2024-11-05",
"capabilities": {},
"clientInfo": {"name": "my-client", "version": "1.0.0"}
}
}
process.stdin.write(json.dumps(init_request) + '\n')
process.stdin.flush()
# Read response
response = json.loads(process.stdout.readline())
print(response)๐๏ธ Installation & Setup
System Requirements
Python: 3.8 or higher
Operating System: Windows, macOS, or Linux
Dependencies: pyperclip for cross-platform clipboard access
Platform-Specific Setup
# Linux
You may need to install additional packages for clipboard support:
# Ubuntu/Debian
sudo apt-get install xclip
# or
sudo apt-get install xsel
# Fedora/RHEL
sudo dnf install xclip# Windows & macOS
No additional setup required - clipboard access works out of the box.
Install from PyPI
pip install mcp-clipboardifyInstall from Source
git clone https://github.com/fluffypony/mcp-clipboardify.git
cd mcp-clipboardify
poetry install๐งช Development
Setup Development Environment
Clone the repository:
git clone https://github.com/fluffypony/mcp-clipboardify.git cd mcp-clipboardifyInstall Poetry (if not already installed):
curl -sSL https://install.python-poetry.org | python3 -Install dependencies:
poetry installRun the server in development:
poetry run python -m mcp_clipboard_server
Testing
Run the test suite:
# Run all tests
poetry run pytest
# Run with coverage
poetry run pytest --cov=mcp_clipboard_server
# Run specific test categories
poetry run pytest tests/test_unit.py
poetry run pytest tests/test_integration.pyCode Quality
# Type checking
poetry run mypy src/
# Linting
poetry run flake8 src/
# Formatting
poetry run black src/ tests/๐ Troubleshooting
Platform Support
The MCP Clipboard Server provides comprehensive cross-platform support with intelligent fallback handling:
# โ Windows
Requirements: No additional dependencies
Supported: Windows 10/11, Windows Server 2019+
Features: Full Unicode support, CRLF line ending handling
Notes: May require clipboard access permissions in some enterprise environments
# โ macOS
Requirements: macOS 10.15+ recommended
Supported: Intel and Apple Silicon Macs
Features: Full Unicode support, RTF content fallback to plain text
Notes: Security permissions may be required (System Preferences > Privacy & Security)
# โ Linux
Requirements: X11 display server and clipboard utilities
Installation:
# Ubuntu/Debian sudo apt-get install xclip xsel # RHEL/CentOS/Fedora sudo yum install xclip xsel # Arch Linux sudo pacman -S xclip xselSupported Distributions: Ubuntu, Debian, RHEL, CentOS, Fedora, Arch Linux
Features: Full Unicode support, headless environment detection
Notes: Requires DISPLAY environment variable for GUI clipboard access
# ๐ง WSL (Windows Subsystem for Linux)
Requirements: WSL2 with Windows 10 build 19041+
Installation:
sudo apt-get install wslu # For clip.exe integrationFeatures: Clipboard sharing with Windows host
Notes: Use Windows Terminal or enable clipboard sharing in WSL configuration
# ๐ซ Headless/Server Environments
Behavior: Graceful degradation - read operations return empty string
Use Case: Automated testing, CI/CD environments
Notes: Write operations will fail with descriptive error messages
Platform-Specific Guidance
The server automatically detects your platform and provides specific guidance when clipboard operations fail:
# Linux Troubleshooting
# Missing utilities error
sudo apt-get install xclip xsel
# No display error
export DISPLAY=:0 # or run in desktop environment
# Headless system
# Read operations return empty string (graceful)
# Write operations fail with clear error message# WSL Troubleshooting
# Install Windows integration
sudo apt-get install wslu
# Enable clipboard sharing in ~/.wslconfig
[wsl2]
guiApplications=true# macOS Troubleshooting
# Security permissions
# Go to System Preferences > Privacy & Security > Input Monitoring
# Add Terminal or your application
# Sandboxed applications
# May have limited clipboard access# Windows Troubleshooting
REM Antivirus blocking
REM Add exception for clipboard access
REM Enterprise policies
REM Check with IT administrator for clipboard permissionsCommon Issues
# Platform Detection Issues
Symptoms: Unexpected platform-specific errors
Solution: The server automatically detects your environment. Check logs with MCP_LOG_LEVEL=DEBUG for detailed platform information.
# Unicode Content Problems
Symptoms: International text or emoji not displaying correctly Solution: Ensure your terminal/application supports UTF-8 encoding. The server handles Unicode correctly on all platforms.
# Large Content Handling
Solution: The server enforces a 1MB limit. Split large content into smaller chunks.
# Server Not Responding
Solution: Check that the client is sending proper JSON-RPC 2.0 formatted messages.
Debugging
Enable debug logging:
# Set environment variable for detailed logs
export MCP_LOG_LEVEL=DEBUG
export MCP_LOG_JSON=true
mcp-clipboardifyGetting Help
Platform Guide: Platform-specific setup instructions
Troubleshooting: Common issues and solutions
Issues: GitHub Issues
Discussions: GitHub Discussions
MCP Specification: Model Context Protocol
Installation Verification
After installation, verify everything works:
# Quick verification
mcp-clipboardify --help
# Comprehensive verification (requires download)
curl -sSL https://raw.githubusercontent.com/fluffypony/mcp-clipboardify/main/scripts/verify_installation.sh | bash
# Or with Python script
python -c "from scripts.verify_installation import InstallationVerifier; InstallationVerifier().run_all_tests()"๐ Protocol Details & Technical Reference
MCP Compliance
This server implements the Model Context Protocol specification:
Transport: JSON-RPC 2.0 over STDIO
Required methods:
initialize,tools/list,tools/callOptional methods: Ping notifications for keep-alive
Error handling: Standard JSON-RPC error codes
Message Format
All messages are line-delimited JSON objects:
{"jsonrpc":"2.0","id":1,"method":"initialize","params":{...}}
{"jsonrpc":"2.0","id":2,"method":"tools/list","params":{}}Error Codes
The server returns standard JSON-RPC 2.0 error codes:
-32700: Parse error (invalid JSON)-32600: Invalid request (malformed JSON-RPC)-32601: Method not found-32602: Invalid params-32603: Internal error
๐ค Contributing
We welcome contributions! Please see our Development Guide for contributing guidelines and workflow details.
Development Workflow
Fork the repository
Create a feature branch:
git checkout -b feature/my-featureMake your changes
Add tests for new functionality
Run the test suite:
poetry run pytestCommit your changes:
git commit -am 'Add my feature'Push to the branch:
git push origin feature/my-featureCreate a Pull Request
๐ License
This project is licensed under the MIT License - see the LICENSE file for details.
๐ Acknowledgments
Model Context Protocol specification
pyperclip for cross-platform clipboard access
The Python community for excellent tooling and libraries
Made with โค๏ธ for the AI and automation community
This server cannot be installed
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/fluffypony/mcp-clipboardify'
If you have feedback or need assistance with the MCP directory API, please join our Discord server