Skip to main content
POST
/
v1
/
webhooks
Create a webhook subscription
curl --request POST \
  --url https://api.topcalls.ai/v1/webhooks \
  --header 'Authorization: Bearer <token>' \
  --header 'Content-Type: application/json' \
  --data '
{
  "event": "call.completed.booked_callback",
  "url": "https://hooks.your-app.com/topcalls",
  "filters": {
    "is_conversion": true,
    "phone_number": "+1555%"
  }
}
'
{
  "id": "3c90c3cc-0d44-4b50-8888-8dd25736052a",
  "account_id": "3c90c3cc-0d44-4b50-8888-8dd25736052a",
  "event": "call.completed.booked_callback",
  "url": "<string>",
  "filters": {},
  "deleted_at": "2023-11-07T05:31:56Z",
  "created_by_api_key_id": "3c90c3cc-0d44-4b50-8888-8dd25736052a",
  "created_at": "2023-11-07T05:31:56Z"
}

Documentation Index

Fetch the complete documentation index at: https://docs.topcalls.ai/llms.txt

Use this file to discover all available pages before exploring further.

Authorizations

Authorization
string
header
required

Use Authorization: Bearer tc_live_xxxxx

Headers

Idempotency-Key
string

Optional client-supplied idempotency key. When present, the gateway caches the response for 24 hours and returns the same response on retried requests with the same key (account-scoped). Safe for retries on network blips. Format: 8-255 ASCII characters from [A-Za-z0-9_-].

Required string length: 8 - 255
Pattern: ^[A-Za-z0-9_-]+$
Example:

"a1b2c3d4-e5f6-7890-abcd-ef0123456789"

Body

application/json
event
string
required
Pattern: ^call\.completed(?:\.[a-z0-9_]+)?$|^lead\.status_changed$|^campaign\.(?:activated|paused)$
Example:

"call.completed.booked_callback"

url
string<uri>
required
Example:

"https://hooks.your-app.com/topcalls"

filters
object

Optional equality / array-OR / SQL-LIKE filters applied to the call-completed payload before fan-out. Top-level keys are payload field names. The special key is_conversion is matched against the derived boolean (true if the call's disposition is in the campaign's conversion_outcomes list).

Example:
{
"is_conversion": true,
"phone_number": "+1555%"
}

Response

Webhook subscription created

id
string<uuid>
account_id
string<uuid>
event
string
Example:

"call.completed.booked_callback"

url
string<uri>
filters
object
deleted_at
string<date-time> | null
created_by_api_key_id
string<uuid> | null
created_at
string<date-time>