Webhooks¶
This page shows provider‑specific webhook endpoints, sample payloads, and signature verification examples.
Outbound Status — Phaxio¶
- Endpoint: POST /phaxio-callback?job_id=<faxbot_job_id>
- Signature: header X-Phaxio-Signature(HMAC‑SHA256 of the raw body usingPHAXIO_API_SECRET)
Example form payload (Phaxio):
fax[id]=123456&fax[status]=success&fax[num_pages]=2
Verification (Python):
import hmac, hashlib
secret = PHAXIO_API_SECRET.encode()
digest = hmac.new(secret, raw_body_bytes, hashlib.sha256).hexdigest()
assert hmac.compare_digest(digest, header_value.strip().lower())
Inbound — Phaxio¶
- Endpoint: POST /phaxio-inbound
- Signature: header X-Phaxio-Signature(HMAC‑SHA256)
Example JSON payload:
{
  "fax": {
    "id": 98765,
    "from": "+15551230000",
    "to": "+15559870000",
    "num_pages": 3,
    "status": "received",
    "file_url": "https://files.phaxio.com/..."
  }
}
Verification (Python): same HMAC pattern as above on the raw request body.
Inbound — Sinch Fax API v3¶
- Endpoint: POST /sinch-inbound
- Basic auth (optional): set SINCH_INBOUND_BASIC_USER/PASS
- HMAC (optional): header X-Sinch-Signaturewith secretSINCH_INBOUND_HMAC_SECRET
Example JSON payload (simplified):
{
  "id": "abcd-1234",
  "from": "+15551230000",
  "to": "+15559870000",
  "num_pages": 2,
  "status": "received",
  "file_url": "https://fax.api.sinch.com/v3/..."
}
HMAC verification (Python):
import hmac, hashlib
secret = SINCH_INBOUND_HMAC_SECRET.encode()
digest = hmac.new(secret, raw_body_bytes, hashlib.sha256).hexdigest()
assert hmac.compare_digest(digest, header_value.strip().lower())
Inbound — SIP/Asterisk (Self‑Hosted)¶
- Endpoint: POST /_internal/asterisk/inbound
- Header: X-Internal-Secret: <ASTERISK_INBOUND_SECRET>
- Body (JSON):
{ "tiff_path": "/faxdata/in.tiff", "to_number": "+15559870000", "from_number": "+15551230000", "faxstatus": "received", "faxpages": 2, "uniqueid": "1603261234.89" }
Example curl (internal network):
curl -X POST -H 'X-Internal-Secret: <secret>' -H 'Content-Type: application/json' \
  http://api:8080/_internal/asterisk/inbound \
  -d '{"tiff_path":"/faxdata/in.tiff","to_number":"+1555..."}'
Security Tips¶
- Use HTTPS for all public callbacks.
- Keep secrets out of logs; audit only metadata (job ids, event types).
- Rotate webhook secrets periodically and validate signatures strictly.