Carrier
The carrier delivers the phone call to Patter. Patter supports Twilio and Telnyx. Both share DTMF, call transfer, AMD, status callbacks, and cost tracking; recording is Twilio-only. You configure one carrier perPatter instance by passing an instance to the carrier= keyword argument. Each carrier class falls back to environment variables when constructor arguments are omitted.
Each carrier ships as both a flat alias (from getpatter import Twilio) and a namespaced class (from getpatter.carriers import twilio → twilio.Carrier()). They are equivalent.
Twilio
| Parameter | Type | Default | Description |
|---|---|---|---|
account_sid | str | "" | Twilio Account SID (starts with AC). Reads from TWILIO_ACCOUNT_SID when empty. |
auth_token | str | "" | Twilio Auth Token. Reads from TWILIO_AUTH_TOKEN when empty. |
serve(), Patter automatically sets the voice_url on the Twilio number to https://<webhook_url>/webhooks/twilio/voice via the Twilio REST API — no manual Console configuration needed.
Twilio trial account limitations
Twilio trial accounts apply a few platform-level restrictions that affect first-time testing. None of these are Patter limitations — they’re Twilio platform rules:- Verified Caller IDs required for outbound — trial accounts can only call numbers you’ve added under Phone Numbers › Verified Caller IDs in the Twilio Console. Verifying via the CLI is also restricted; do it from the Console.
- Trial announcement prepended on outbound calls — Twilio plays an English trial-account message before connecting the call to your agent; the callee has to press a key to continue.
- Trial caller-ID restrictions — the caller-ID shown to the recipient may be masked or labelled differently than your purchased number until the account is upgraded.
Signature verification
The Auth Token is also used to verify every Twilio webhook with HMAC-SHA1 against theX-Twilio-Signature header. Requests with invalid signatures are rejected with HTTP 403.
Telnyx
| Parameter | Type | Default | Description |
|---|---|---|---|
api_key | str | "" | Telnyx API v2 key. Reads from TELNYX_API_KEY when empty. |
connection_id | str | "" | Call Control Application ID. Reads from TELNYX_CONNECTION_ID when empty. |
public_key | str | "" | Optional. Ed25519 public key for webhook signature verification. Reads from TELNYX_PUBLIC_KEY when empty. |
Signature verification
Whenpublic_key is set (or TELNYX_PUBLIC_KEY is present), every Telnyx webhook is verified with Ed25519. Requests older than 5 minutes are rejected (replay protection).
Webhook Endpoints
The embedded server exposes these endpoints regardless of carrier choice:| Endpoint | Purpose |
|---|---|
POST /webhooks/twilio/voice | Incoming Twilio call → returns TwiML to start streaming. |
POST /webhooks/twilio/status | Call lifecycle status callbacks (initiated, ringing, answered, completed). |
POST /webhooks/twilio/recording | Recording completion callbacks. |
POST /webhooks/twilio/amd | Async AMD (answering machine detection) results. |
POST /webhooks/telnyx/voice | Incoming Telnyx call → returns Call Control commands. |
Outbound calls
Usephone.call(...) to place an outbound call on either carrier. Every keyword argument is snake_case:
machine_detectiondefaults toTrue. On Twilio Patter sendsMachineDetection=DetectMessageEnd+ Async AMD so there is no answer-latency penalty on human pickups. PassFalseto skip per-call AMD billing.ring_timeoutdefaults to25seconds. Pass60for legacy carrier-default parity, orNoneto omit the parameter entirely.- The AMD callback was renamed
on_machine→on_machine_detectionand now receives aMachineDetectionResult(not a raw dict).
What’s Next
STT
Speech-to-text providers.
LLM
Language model providers.
TTS
Text-to-speech providers.
Tunneling
Expose your local server publicly.

