Open-source WebRTC voice chat. Ephemeral rooms. No auth. Pure P2P.
| Package | Description |
|---|---|
| @treyorr/voca-client | Core TypeScript SDK |
| @treyorr/voca-react | React hooks |
| @treyorr/voca-svelte | Svelte 5 runes wrapper |
bun install @treyorr/voca-client
# or for frameworks:
bun install @treyorr/voca-react # React
bun install @treyorr/voca-svelte # Svelte 5
import { useVocaRoom } from '@treyorr/voca-react';
function VoiceRoom({ roomId }) {
const { status, peers, toggleMute, isMuted } = useVocaRoom(roomId, {
password: 'secret123' // Optional: protect room with password
});
return (
<button onClick={toggleMute}>{isMuted ? 'Unmute' : 'Mute'}</button>
);
}
Voca is designed for easy self-hosting with Docker. No database or external dependencies required.
mise run dev
# Terminal 1: Signaling server
cd services/signaling && RUST_LOG=info cargo run
# Terminal 2: Web frontend
cd apps/web && bun install && bun run dev
| Endpoint | Auth | Description |
|---|---|---|
POST /api/room?password=<pwd> |
- | Create room (optional password) ā {"room": "abc123", "password": "pwd"} |
GET /api/room/{id} |
- | Check if room exists ā {"exists": true, "password_required": false} |
GET /ws/{id}?password=<pwd> |
- | WebSocket signaling (password required if room protected) |
GET /api/admin/rooms |
Bearer | List all rooms |
GET /api/admin/metrics |
Bearer | Usage metrics |
git checkout -b my-featuremise run lintPlease read our Code of Conduct first.