Voice Assistant
Control your AI coding agent with voice using the built-in voice assistant powered by ElevenLabs Conversational AI.
Overview
The voice assistant lets you:
- Talk to your agent - Ask questions, give instructions, and request code changes hands-free
- Approve permissions by voice - Say "yes" or "no" to approve or deny permission requests
- Monitor progress - Receive spoken updates when tasks complete or errors occur
The assistant bridges voice communication with your active coding agent (Claude Code, Codex, Gemini, or OpenCode), relaying your requests and summarizing responses in natural speech.
Prerequisites
An ElevenLabs account with API access
Setup
1. Get an API Key
- Sign up or log in at elevenlabs.io
- Go to API Keys in your account settings
- Create a new API key and copy it
2. Configure the Hub
Set the environment variable before starting the hub:
export ELEVENLABS_API_KEY="your-api-key"
hapi hub --relayThe hub automatically creates a "Hapi Voice Assistant" agent in your ElevenLabs account on first use.
3. (Optional) Custom Agent
If you want to use your own ElevenLabs agent instead of the auto-created one:
export ELEVENLABS_AGENT_ID="your-agent-id"Usage
Starting a Voice Session
- Open a session in the web app
- Click the microphone button in the composer (or the send button when empty)
- Grant microphone permission when prompted
- Start speaking
Voice Commands
| Say this | What happens |
|---|---|
| "Ask Claude to..." / "Have it..." | Sends your request to the coding agent |
| "Refactor the auth module" | Coding requests are forwarded automatically |
| "Yes" / "Allow" / "Go ahead" | Approves pending permission requests |
| "No" / "Deny" / "Cancel" | Denies pending permission requests |
| Direct questions | The voice assistant answers itself if it can |
How It Works
Context Synchronization
The voice assistant automatically receives updates when:
- You focus on a session (full history is loaded)
- The agent sends messages or uses tools
- Permission requests arrive
- Tasks complete
You don't need to ask for status updates - the assistant proactively summarizes relevant changes.
Tools
The voice assistant has two tools to interact with your coding agent:
- messageCodingAgent - Forwards your requests to the active agent
- processPermissionRequest - Handles permission approvals and denials
Architecture
Browser → WebRTC → ElevenLabs ConvAI → Voice Assistant → HAPI Hub → Coding AgentThe voice connection uses WebRTC for low-latency audio streaming. The HAPI hub provides conversation tokens and handles authentication.
Tips
- Be specific - Clear, complete requests get better results
- Wait for completion - The assistant stays silent while the agent works, then summarizes results
- Use natural language - No special command syntax needed
- Keep sessions focused - One active session at a time for clearest context
Troubleshooting
"ElevenLabs API key not configured"
Set ELEVENLABS_API_KEY in your environment and restart the hub.
"Failed to get microphone permission"
- Check browser permissions for microphone access
- Ensure no other app is using the microphone
- Try refreshing the page
Voice not responding
- Verify the session is connected (green dot in status bar)
- Check that voice status shows "connecting" or connected state
- Ensure you have a stable internet connection
"Failed to create ElevenLabs agent automatically"
- Verify your API key is valid
- Check your ElevenLabs account has available quota
- Try setting a custom
ELEVENLABS_AGENT_ID
Poor audio quality
- Use a headset to avoid echo
- Reduce background noise
- Check your internet connection stability