clipboard-vision-mcp
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., "@clipboard-vision-mcpdescribe the image in 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.
clipboard-vision-mcp
Add vision to text-only models in Opencode (DeepSeek V4, GLM 5.1) β see the image in your clipboard directly, no manual file saving.
Tested on Windows 11 + Opencode + DeepSeek V4 Pro. Multi-OS clipboard support (Windows / macOS / Linux X11 / Linux Wayland).
Forked from itcomgroup/vision-mcp-server β rewritten around clipboard-first tools, security hardening, cross-platform clipboard extraction, and one-prompt AI install.
The problem
Cheap/fast text-only models like DeepSeek V4 and GLM 5.1 are great for code, but they cannot read images. Every time you paste a screenshot, the model asks you to save it to disk and provide a path.
The fix
This MCP server exposes *_from_clipboard tools. When the LLM needs to see your screenshot, it calls analyze_clipboard β the server reads the clipboard image, sends it to a real vision model (Groq + Llama-4 Scout, free tier), and returns a text description the text model can reason about.
Result: paste β ask β done. No file shuffling.
π€ One-prompt install via AI (recommended)
Instead of running the steps below manually, paste one of these prompts into any coding assistant (DeepSeek, GLM, Claude, GPT, ...) and it will set everything up for you end-to-end β clone, venv, deps, MCP config, keybindings:
π¬π§ docs/INSTALL_PROMPT_EN.md
π«π· docs/INSTALL_PROMPT_FR.md
Prefer doing it yourself? Keep reading.
Features
πΌοΈ Clipboard-first β
analyze_clipboard,extract_text_from_clipboard,diagnose_error_from_clipboard,describe_ui_from_clipboard,code_from_clipboard.π File path fallback β same tools available for images already on disk.
π Free vision backend β Groq's free tier with Llama-4 Scout (17B, multimodal).
π₯οΈ Multi-OS β Windows, macOS, Linux (X11 + Wayland).
π Security hardened β extension/size/magic-byte validation, auto-delete of clipboard temp files after analysis.
π MCP standard β works with Opencode, Claude Code, Cursor, Cline, Continue, or any MCP-capable client.
Requirements
Python 3.10+
Groq API key (free, 30 seconds sign-up): https://console.groq.com/keys
An MCP-capable client (Opencode, Claude Code, Cursor, Cline, Continue, ...)
Python dependencies (installed automatically via pip install -e .)
Package | Purpose |
| MCP protocol server |
| Groq API client (Llama-4 Scout vision) |
| Async file I/O |
| Clipboard image extraction (Windows/macOS), PNG encoding |
OS-specific clipboard dependencies
OS | Command | Why |
Windows | nothing extra | Pillow + pywin32 handle the clipboard natively. |
macOS |
| Pillow works in most cases; pngpaste as backup. |
Linux β Wayland |
| Provides |
Linux β X11 |
| Or your distro equivalent. |
Quick start
1. Get a free Groq API key
2. Install
git clone https://github.com/Capetlevrai/clipboard-vision-mcp.git
cd clipboard-vision-mcp
python -m venv .venv
# Windows:
.venv\Scripts\activate
# macOS/Linux:
source .venv/bin/activate
pip install -e .3. Smoke test (no Groq needed)
Copy any screenshot, then:
python examples/smoke_test.pyExpected: OK: clipboard image saved to <path>.
4. Wire to your MCP client
See docs/OPENCODE.md for Opencode (Windows-tested) or docs/CLIENTS.md for Claude Code / Cursor / Cline / Continue.
Opencode (%APPDATA%\opencode\opencode.json on Windows, ~/.config/opencode/opencode.json on Linux/macOS):
{
"mcp": {
"clipboard-vision": {
"type": "local",
"command": [
"C:\\path\\to\\clipboard-vision-mcp\\.venv\\Scripts\\python.exe",
"-m",
"clipboard_vision_mcp"
],
"enabled": true,
"environment": {
"GROQ_API_KEY": "gsk_your_key_here"
}
}
}
}π‘ Use the absolute path to the venv's Python. This guarantees the MCP starts with the right dependencies regardless of shell, cwd, or active venv.
5. β οΈ Opencode keybindings for pasting images
Opencode does not bind image-paste to Ctrl+V / Alt+V by default. Without this step, copying a screenshot and hitting paste will insert nothing (or plain text).
Edit your Opencode keybinds.json or the keybinds section of opencode.json:
{
"keybinds": {
"input_paste": "ctrl+v",
"input_paste_image": "alt+v"
}
}Restart Opencode after editing.
6. Does it auto-start after a Windows reboot?
Yes. Opencode re-reads opencode.json at every launch and auto-spawns any MCP server with "type": "local" and "enabled": true. Because the command uses the absolute path to the venv's Python, it doesn't matter which shell or working directory Opencode is launched from.
Reboot β open Opencode β clipboard-vision tools are listed. No manual step.
Usage
You: (copy a screenshot to clipboard, then type)
"Look at what I just copied and tell me what's wrong with this error."
LLM (DeepSeek, GLM, Claude, ...): [calls diagnose_error_from_clipboard]
β "The error says `ECONNREFUSED 127.0.0.1:5432`. Postgres isn't
running on port 5432. Start it with: ..."The text-only model never sees pixels β it reads the description returned by Llama-4 Scout and reasons over it.
Tool reference
Tool | Input | Use when |
| optional | Generic description, Q&A on the clipboard image. |
| β | Pure OCR. |
| β | UI/UX review, component inventory. |
| β | Error screenshot β cause + fix. |
| β | Extract code from a screenshot. |
|
| Image already on disk. |
|
| Same as above for files. |
Security
This server runs as a local stdio process β it does not open any network port and only talks to the MCP client over stdin/stdout and to the Groq API over HTTPS.
Hardening in place:
File type allow-list.
analyze_imageand the other file-path tools only accept.png .jpg .jpeg .gif .webp .bmp. This prevents a prompt-injected LLM from asking the server to read arbitrary local files (~/.ssh/id_rsa,.env, ...) and exfiltrate them as base64 to Groq.Magic-byte check. File content is validated against known image headers before upload.
Size cap. 20 MB max per image.
Auto-delete clipboard temp files after each analysis. Screenshots may contain secrets (tokens, chats, credentials) β the server writes them to
$TMPDIR/clipboard_vision_mcp/and unlinks them on completion.No telemetry. No analytics, no phone-home.
What this project cannot protect you from
Your API key lives in your MCP client config in plain text. That is how MCP clients work today. Keep that config file non-world-readable and never commit it. If you accidentally expose a key (chat, screenshot, git push), rotate it at https://console.groq.com/keys.
Groq receives the images you analyze. Check their privacy policy before sending anything sensitive.
Any MCP tool is executed at the direction of the LLM. If you connect a prompt-injected model to this server and feed it untrusted input, the model can choose what to analyze. The allow-list above reduces blast radius but cannot eliminate it.
Found an issue?
Please open a private security advisory rather than a public issue.
How it works
ββββββββββββββββ MCP βββββββββββββββββββ HTTPS βββββββββββββββββββ
β Opencode β βββββββΆ β clipboard- β βββββββββΆ β Groq API β
β (DeepSeek) β β vision-mcp β β Llama-4 Scout β
ββββββββββββββββ βββββββββββββββββββ βββββββββββββββββββ
β
βΌ
reads system clipboard
(PIL / wl-paste / xclip)
β validate β base64 β send β deleteTroubleshooting
"Clipboard does not contain an image." β Copy an actual image, not a file icon or text. On Linux, verify
wl-paste --type image/pngorxclip -selection clipboard -t image/png -o | file -works outside the MCP."GROQ_API_KEY is not set." β Check the
environmentblock in your client config, then fully restart the client.Tools don't appear in Opencode. β Check Opencode's MCP logs. Run
python -m clipboard_vision_mcpmanually β it should start and wait silently on stdin."Refusing to read '' β only image files are allowed." β You (or the LLM) passed a non-image path. This is the security guard doing its job.
Credits
Forked from itcomgroup/vision-mcp-server β original Groq + Llama-4 Scout MCP integration.
Vision model: Llama-4 Scout 17B served by Groq.
License
MIT β see LICENSE.
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/Capetlevrai/clipboard-vision-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server