Documentation Index
Fetch the complete documentation index at: https://docs.getpatter.com/llms.txt
Use this file to discover all available pages before exploring further.
Python Quickstart
Patter connects an AI agent to a real phone number in four lines of Python. This page walks you end-to-end: install, credentials, the four lines, and your first call.Prerequisites
- Python 3.11+
- A Twilio or Telnyx account with a phone number you own
- An AI provider key — OpenAI for the default Realtime engine, or any supported STT/TTS pair for pipeline mode
Step 1 — Install
Step 2 — Set environment variables
Each carrier and engine reads its credentials from the environment by default. The four-line quickstart below works as-is once these are set.| Variable | Purpose |
|---|---|
TWILIO_ACCOUNT_SID | Account SID from the Twilio console. Starts with AC. |
TWILIO_AUTH_TOKEN | Auth token paired with the SID. Keep it secret. |
OPENAI_API_KEY | Used by OpenAIRealtime, WhisperSTT, and OpenAITTS. |
TELNYX_API_KEY and TELNYX_CONNECTION_ID (plus optional TELNYX_PUBLIC_KEY for webhook signature verification) and use Telnyx() in place of Twilio(). See the Carrier page for all supported env vars.
Step 3 — The four-line quickstart
Createmain.py:
main.py
first_message="...":
- Import — the three primitives you need: the client, a carrier, and an engine. All three read credentials from environment variables by default, so no keys appear in source.
Patter(...)— build the client and bind it to your phone number.Twilio()(orTelnyx()) carries the carrier credentials; swap it to change providers.phone.agent(...)— describe the agent: the engine (OpenAI Realtime by default), the system prompt, and the first message it speaks on answer.await phone.serve(agent, tunnel=True)— start the embedded server.tunnel=Truespawns a Cloudflare tunnel and points your Twilio number at it automatically, so the agent is reachable from the PSTN without any additional DNS or firewall work.
tunnel=True is the dev shorthand. In production replace it with a stable webhook URL via the constructor:Patter(..., tunnel=Static(hostname="agent.example.com")). See Tunneling.Step 4 — Run it
Step 5 — Call the number
Pick up your phone, dial your Twilio number, and the agent will answer with"Hello! How can I help?". Start talking.
Since 0.6.2,
Patter(...) persists per-call records (metadata.json, transcript.jsonl, events.jsonl) to the platform default data directory by default so the local dashboard’s call history survives process restarts. Pass persist=False to keep the old ephemeral-RAM-only behaviour, or persist="/custom/path" to choose a different location. See Call logging for the full layout.Using a different engine
OpenAI Realtime is the default. To switch engines, pass a different instance:ElevenLabsConvAI() reads ELEVENLABS_API_KEY and ELEVENLABS_AGENT_ID from the environment.
For the STT + LLM + TTS pipeline mode, pick each stage independently:
AnthropicLLM() for OpenAILLM(), GroqLLM(), CerebrasLLM(), or GoogleLLM() — tool calling works across all five. Need fully custom LLM logic? Drop llm= and pass on_message=handler to serve() instead.
Non-English agents
OpenAI Realtime auto-detects the spoken language from the inbound audio and matches the language of yoursystem_prompt. Writing the prompt in the target language is the primary control:
language="ja" parameter on OpenAIRealtime only seeds the auto-generated fallback prompt ("Respond in {language}") when you don’t supply your own system_prompt. It does not configure the Realtime API session itself.
For pipeline mode the STT needs the language code so it can pick the right acoustic model:
to= values must be E.164. Many regions drop the trunk-zero — Japanese numbers like 090-xxxx-xxxx are dialled as +81XXXXXXXXX (drop the leading 0).
What’s next
Configuration
Every constructor option in one place.
Agents
Customize voice, model, tools, and guardrails.
STT providers
Deepgram, Whisper, Cartesia, Soniox, Speechmatics, AssemblyAI.
TTS providers
ElevenLabs, OpenAI, Cartesia, Rime, LMNT.
Tools
Give your agent function-calling superpowers.

