ClipSnap
Enables reliable image paste from clipboard into Claude Code running in iTerm2, bypassing terminal paste limitations.
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., "@ClipSnapcheck the screenshot I just took"
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.
An MCP server that gives Claude Code reliable access to clipboard images and screenshots. A background Swift daemon watches the clipboard in real time, so screenshots from any app — including clipboard-only tools like Shottr — are captured automatically and available instantly.
Built to fix the broken Ctrl+V image paste in iTerm2 and Terminal.app when using Claude Code. Should also work with any MCP-compatible client (Cursor, Claude Desktop, etc.).
The Problem
Pasting images into Claude Code viaCtrl+V in iTerm2 is unreliable and often fails completely.
These are real, open issues:
Issue | What happens |
| |
| |
| |
"Can't paste image from clipboard" (various causes) |
Similar problems exist in other terminal AI tools: Codex CLI, Gemini CLI. The root cause is that terminals have no reliable protocol for transferring binary image data from the macOS clipboard.
Related MCP server: MCP Windows Screenshots
The Solution
Real-Time Capture
A lightweight Swift daemon polls NSPasteboard every 500ms. Clipboard-only screenshots (Shottr Esc, Cmd+C on any image) are captured automatically as PNG files.
Multi-Source Discovery
Parallel search across clipboard watcher dir, native macOS screenshots dir, and Spotlight. Three sources — the newest image wins.
Sandbox Bypass
MCP servers run outside sandbox-exec. No more denied clipboard access. No more silent failures.
Smart Processing
Auto-resize to optimal AI vision dimensions (1568px). Saves tokens without losing detail. PNG or JPEG output.
Quick Start
Install
git clone https://github.com/zelentsov-dev/clipsnap-mcp.git ~/.clipsnap-mcp
cd ~/.clipsnap-mcp
npm install
npm run build # TypeScript + Swift clipboard watcher
npm install -g . # install globally (symlinks to this directory)Important:
npm install -g .creates a symlink to the cloned directory — do not delete it.npm install -g git+https://...does not work because the package requires a build step.
Add to Claude Code
claude mcp add --scope user --transport stdio clipsnap -- clipsnap-mcpThis registers ClipSnap globally across all your projects. Verify with:
claude mcp listThen restart Claude Code. Now when you say "look at my screenshot" or "check what I just captured", Claude Code will use ClipSnap to find your images.
Update
cd ~/.clipsnap-mcp
git pull
npm install # if dependencies changed
npm run buildThe global clipsnap-mcp binary is a symlink to ~/.clipsnap-mcp, so it picks up changes automatically. Restart Claude Code after updating.
Uninstall
claude mcp remove clipsnap --scope user
npm uninstall -g clipsnap-mcp
rm -rf ~/.clipsnap-mcpHow It Works
1. Claude Code starts
└── MCP server starts
└── Swift clipboard watcher spawns as background daemon
2. User takes screenshot (any app: native, Shottr, CleanShot X, browser, etc.)
└── Clipboard gets image
└── Watcher detects NSPasteboard change within ~500ms
└── Saves PNG to ~/.clipsnap/clipboard-captures/
3. User: "look at my screenshot"
└── Claude Code calls paste_recent tool
└── Parallel search:
├── Watcher captures dir (clipboard images, instant)
├── Native screenshots dir (file-saved screenshots, instant)
└── Spotlight mdfind (broad coverage, all apps)
└── Merge, dedup, sort by time → return newest N as base64 images
4. Claude Code exits
└── SIGTERM → watcher stops → session files cleaned upgraph TD
A["Claude Code"] -->|MCP stdio| B["ClipSnap MCP Server<br/>(Node.js)"]
B -->|spawns on start| C["Swift Clipboard Watcher"]
C -->|polls NSPasteboard<br/>every 500ms| D["~/.clipsnap/clipboard-captures/"]
B -->|scans| D
B -->|scans| E["Native Screenshots Dir"]
B -->|queries| F["Spotlight mdfind"]
D & E & F -->|merge + dedup<br/>sort by time| G["Return newest N images"]
A -->|SIGTERM on exit| CTools Reference
paste_recent
Returns the most recent N screenshot images. Combines clipboard watcher captures, native macOS screenshots directory, and Spotlight. Sorted by time, newest first.
Parameter | Type | Default | Description |
|
|
| Number of images to return |
|
| — | Scan a specific folder instead |
|
|
| Max long edge in pixels |
Example prompts: "Look at my screenshot", "Compare the last 4 screenshots", "Check what I just captured"
cleanup_images
Deletes temporary ClipSnap session images. Auto-cleanup runs on TTL/size limits, so this is rarely needed.
Parameter | Type | Default | Description |
|
|
| Delete ALL sessions, not just current |
|
| — | Delete files older than N minutes |
Configuration
All settings via environment variables:
Variable | Default | Description |
|
| Max image long edge (px) |
|
| Output format ( |
|
| JPEG quality (1–100) |
| auto | Native screenshots dir (auto-detected via |
|
| Max files per session |
|
| File time-to-live |
|
| Max total session size |
|
| Detect passwords before reading clipboard |
|
| Delete session files on exit |
Token Cost
Claude calculates image tokens as (width x height) / 750:
Image Size | Tokens | Cost (Sonnet, $3/1M input) |
1568x882 (16:9) | ~1,841 | $0.006 |
1568x1024 | ~2,141 | $0.006 |
800x600 (snippet) | ~640 | $0.002 |
Security
Password detection — checks
ConcealedType/TransientTypebefore reading (1Password, Bitwarden, macOS Keychain)Symlink protection —
lstatprevents following symlinks to sensitive filesFile permissions —
0600files,0700directoriesSession isolation — UUID-based subdirs per process (
$TMPDIR/clipsnap-<uuid>/)No content logging — clipboard data is never logged
No network calls — fully offline, zero telemetry
Compatibility
Built and tested with Claude Code on iTerm2 on macOS.
Since ClipSnap is a standard MCP server (stdio transport), it should work with any MCP-compatible client — Cursor, Claude Desktop, Windsurf, etc. — but these haven't been tested yet. If you try it, let us know.
Requirements:
macOS 15+ (Sequoia or later)
Node.js 20+
Swift 6.2+ (for building the clipboard watcher; optional)
Troubleshooting
The Swift watcher binary must be built:
npm run build # or: cd watcher && swift build -c releaseIf the binary is missing, ClipSnap still works via Spotlight and native dir scanning — just without real-time clipboard capture.
Take a screenshot or copy an image first:
Cmd+Shift+4(region) orCmd+Shift+3(full screen)Cmd+Con an image in Preview, Figma, browserShottr, CleanShot X, or any screenshot tool
Your clipboard contains a password (1Password, Bitwarden, etc.). ClipSnap refuses to read it for security. Copy a screenshot instead.
ClipSnap auto-detects from defaults read com.apple.screencapture location, falling back to ~/Screenshots or ~/Desktop. Override with CLIPSNAP_SCREENSHOTS_DIR.
Contributing
Contributions welcome! Please open an issue before starting work on large changes.
Built by Aleksei Zelentsov
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Tools
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/zelentsov-dev/clipsnap-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server