clvoice-mcp
Provides integration with Google Gemini for speech-to-text transcription as an alternative to Groq.
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., "@clvoice-mcplisten to me"
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.
Hold Ctrl + `, talk, release. The audio is recorded (ffmpeg) → transcribed (Groq Whisper, ~1s) → filler words cleaned up (Groq LLM) → pasted into the focused input for you to edit before sending. Nothing runs automatically — you stay in control.
TypeScript. Windows (microphone via DirectShow/
dshow). Runs as an MCP server that Claude Code keeps alive for the whole session.
How it works
HOLD Ctrl+` ──► ffmpeg records mic ──► release
│ │
▼ ▼
🔴 recording Groq Whisper (STT) ─► ✨ clean fillers (Groq LLM)
│
▼
paste into focused input ─► you edit ─► EnterTwo ways to trigger:
Push-to-talk hotkey (recommended, hands-free). The MCP server hosts a global hotkey watcher for the whole session.
MCP tool
voice_listen— Claude calls it when you ask (e.g. "listen to me").
Important: the transcript is not returned to Claude and is never auto-executed — it only lands in your input box. You edit, then press Enter to send.
Related MCP server: Claude Voice Commands
Features
🎙️ Push-to-talk dictation (hold to talk, release to send)
⚡ Fast STT via Groq Whisper (~1s); Gemini as an alternative
✨ Filler-word cleanup ("à, ừm, ờ...") + punctuation via a Groq LLM (context-aware, never executes your text)
📋 Clipboard + auto-paste into whatever window is focused
🔊 Audio beeps (start / stop / done) + on-terminal status line
🧩 Self-hosted in the MCP server — no separate window, single-instance lock + takeover across multiple Claude Code windows
🪟 One-command setup (
setup.ps1)
Requirements
Node.js ≥ 18
ffmpeg on
PATH(ffmpeg -version) — https://ffmpeg.org/download.htmlA working microphone
Groq API key (default, free): https://console.groq.com/keys — or a Gemini API key: https://aistudio.google.com/apikey
Quick setup (Windows)
cd clvoice-mcp
powershell -ExecutionPolicy Bypass -File setup.ps1The script installs deps, builds, detects your mic, asks for a Groq key, registers the MCP server (user scope), and adds the status line. Hotkey + cleanup are on by default, so nothing else to configure. Then restart Claude Code.
Non-interactive:
powershell -ExecutionPolicy Bypass -File setup.ps1 -GroqKey "<key>" -MicDevice "<mic>"
# add -NoStatusLine to skip the status lineManual setup
npm install
npm run build # produces dist/index.js
ffmpeg -list_devices true -f dshow -i dummy # find your mic name
claude mcp add clvoice --scope user ^
--env GROQ_API_KEY=<KEY> ^
--env "CLVOICE_MIC_DEVICE=<MIC>" ^
-- node <ABSOLUTE-PATH>\dist\index.jsGroq STT, hotkey, and cleanup are all default-on, so they don't need env vars. To use Gemini instead: add --env CLVOICE_STT=gemini --env GEMINI_API_KEY=....
Configuration (environment variables)
Variable | Required | Default | Description |
| ❌ |
| STT engine: |
| ❌ |
| Spoken language: |
| ✅ (for groq) | — | Groq API key — https://console.groq.com/keys |
| ❌ |
| Groq Whisper model. |
| ✅ (for gemini) | — | Gemini API key. |
| ❌ |
| Gemini model (switch if a model 404s). |
| ❌ | (first input) | Exact dshow mic name. |
| ❌ |
| Path to the ffmpeg binary. |
| ❌ |
| Host the push-to-talk watcher in the server. |
| ❌ |
| Clean filler words via Groq LLM (+~0.4s, needs |
| ❌ |
| Groq chat model for cleanup. |
| ❌ |
| Auto-paste (Ctrl+V) into the focused window. |
| ❌ |
| Default record duration (MCP tool path). |
| ❌ |
| Hard cap on record duration. |
Usage
Hotkey (push-to-talk)
**Hold Ctrl + **, speak, release. You'll hear a high beep (recording), a low beep (processing), then a short beep (done) as the text is pasted. Change the key in scripts/clvoice-hotkey.ps1 (-Key, -NoCtrl, -Alt, -Shift`).
MCP tools
voice_listen({ seconds?, language? })— record, transcribe, paste into the input. Does not return the transcript.list_audio_devices()— list mic names forCLVOICE_MIC_DEVICE.
Status line (on the Claude Code terminal)
setup.ps1 adds this automatically. Manual:
// ~/.claude/settings.json
"statusLine": {
"type": "command",
"command": "node \"<ABS>\\scripts\\clvoice-statusline.cjs\"",
"padding": 0,
"refreshInterval": 1
}Shows 🔴 recording → ⏳ transcribing → ✨ processing, hidden when idle. The wrapper preserves any existing status line. ~1s refresh (Claude Code limit); beeps are instant.
Privacy
Audio is sent to the cloud STT provider (Groq or Google) to be transcribed. Don't use it for sensitive content. A local/offline STT is out of scope for v1.
Troubleshooting
Symptom | Fix |
| Install ffmpeg and add to PATH, or set |
No mic / wrong mic | Run |
No beep / no status on first use | Server warms up a few seconds after Claude Code starts — wait, then try. |
Hotkey stops after closing a window | Close all old Claude Code windows after changing env (server env is captured at spawn). |
Empty transcription | Audio was silent/too short — speak clearly, increase duration. |
Status shows stale state | Check |
Limitations (v1)
Windows-only · cloud STT (needs internet) · status line capped at ~1s refresh · the recording status is shared across all Claude Code windows (cosmetic).
License
MIT
This server cannot be installed
Maintenance
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/tvtdev94/clvoice-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server