Introduction
Webhooks are HTTPS POST requests sent from Cyberdesk to your service when events happen (e.g., a workflow run completes). They eliminate polling and let you react in real-time. The high-level steps:- Activate Webhooks in the Dashboard (creates a Svix Application for your org).
- Add an endpoint URL and subscribe to
run_complete
. - Implement your endpoint to verify signatures and process events.
- Test and monitor via the embedded Webhooks portal.
Events and Event Types
Cyberdesk webhooks are organized by event types (e.g.,run_complete
). You can browse the full, always-up-to-date list and their schemas in the Event Catalog inside the Webhooks portal. As of today, run_complete
is the most commonly used type and fires when a workflow run reaches a terminal state (success, error, or cancelled). Its payload includes the full Run object (see API reference for RunResponse
).
Adding an Endpoint
- Go to Dashboard → Webhooks.
- Click “Add Endpoint” and enter your publicly reachable HTTPS URL.
- Select the
run_complete
event type (or accept all for initial testing). - Copy the generated endpoint signing secret (
whsec_...
).
Keep separate endpoints/secrets for each environment (dev, staging, prod).
Testing Endpoints
Use the “Testing” tools in the Webhooks portal to send example events to your endpoint. Inspect payloads, responses, and message attempts under Logs/Activity. You can replay messages individually or recover all failed messages since a timestamp.We’re building a managed Webhooks SDK with built‑in verification and typing. If you want this prioritized, please let the team know.
Verifying Signatures
Always verify signatures to ensure messages originate from Cyberdesk. We use Svix headers and signing format. Headers sent with every webhook:svix-id
– unique message id (use for idempotency)svix-timestamp
– Unix timestampsvix-signature
– signature over the raw request body
Install dependencies
- TypeScript / Node
- Python
Endpoint handlers
- TypeScript / Node
- Python
Verify against the exact raw request body. Do not re-stringify JSON before verification.
Retry Mechanism
Cyberdesk (via Svix) retries failed deliveries using exponential backoff:- Immediately
- 5 seconds
- 5 minutes
- 30 minutes
- 2 hours
- 5 hours
- 10 hours
- 10 hours
Troubleshooting & Failure Recovery
Common pitfalls:- Not using raw body for signature verification
- Using the wrong endpoint secret (each endpoint has its own secret)
- Returning non-2xx status for successful processing
- Handler timeouts (do heavy work asynchronously)
- Re-enable disabled endpoints in the portal
- Replay failed messages individually or recover all since a timestamp
Using run_complete Data
run_complete
includes the full RunResponse
. Useful patterns:
- Trigger the next workflow in your pipeline
- Update your job table with
run.status
andoutput_data
- Persist
output_attachment_ids
and fetch/download files as needed - Correlate
input_values
to your original request (e.g., patient_id) - Understand sensitive inputs: plaintext secrets are never included in the payload. Use
run.sensitive_input_aliases
(keys only, e.g.,password
) to audit which sensitive variables were used; actual values are not exposed.
Example: TypeScript handler
Example: Python handler
Idempotency
Deduplicate usingsvix-id
(header) or event_id
(payload). Store processed ids and ignore duplicates.
Security Checklist
- Verify signatures and timestamp
- Use HTTPS only
- Rotate secrets when needed
- Return 2xx promptly; process work asynchronously
See Also
- Webhooks Quickstart
- API Reference → Event types and Run schema