Auth
Every one-shot call needs a bearer API key. Mint one in Settings → API keys in the dashboard.Transcribe
- Audio body is binary. Wrap PCM/MP3/WAV/etc. in the request body — no base64.
- Intent goes in the
x-speko-intentheader (JSON), not the body. Constraints inx-speko-constraints.
Synthesize
audio/pcm;rate=24000 for Cartesia, audio/mpeg for ElevenLabs). Routing headers (X-Speko-Provider, etc.) tell you which provider ran.
Complete
With an SDK
Both SDKs wrap all three endpoints with matching shapes. See@spekoai/sdk and spekoai (Python).