Skip to main content
How to use Webhooks
Kevin avatar
Written by Kevin
Updated over 2 weeks ago

Webhooks allow interaction between web-based applications through the use of custom callbacks. In addition, Webhooks allow web applications to communicate with other web apps automatically.

Configuration

You can configure webhooks by going to Studio > Webhooks. Once you enter the calling endpoint and select the events you wish to receive, you're all set up on our end.

Return a 2xx response

Your endpoint must quickly return a successful status code (2xx) before any complex logic that could cause a timeout. For example, you must return a 200 response before adding a customer's transaction to your accounting system.

Soundee attempts to deliver your webhooks for up to three days with exponential backoff. If your endpoint has been disabled or deleted when we attempt a retry, future retries of that event will be prevented. However, if you disable and then re-enable a webhook endpoint before we're able to retry, you should still expect to see future retry attempts.

Signature verification (optional)

Soundee signs the webhook events to your endpoints by including a signature in each event's Soundee-Signature header. This allows you to verify that the events were sent by Soundee and not by a third party.

Before you can verify signatures, you need to retrieve your endpoint's application key from your Dashboard's Webhooks settings. First, go to your settings, then click the Reveal key button.

To verify the call, you first need to hash the payload through encryption with your application key as the secret. For example, in PHP, it would look like this:

$hash = base64_encode(hash_hmac('sha256', $payloadJSON, $yourApplicationKey));

Now you can check if the Soundee-Signature is equal to your hash.

if($hash === $_SERVER['HTTP_SOUNDEE_VERIFICATION']){
// ok
} else {
// not by soundee..
}

Logs

In Studio > Dashboard, you can see an overview of all webhook calls made. As soon as the call is successful, you will see the status code "success." As soon as the call is unsuccessful, you will see "failed."

For each call, you can view it's payload by clicking on it:


Did this answer your question?