Skip to main content

Notification webhooks

You can configure Supaglue to fire webhooks to your application for important events. These webhooks don't contain Provider data but are used to notify your application or trigger related workflows.

Supaglue uses Svix as its webhooks platform. They provide some nice characteristics for building production-grade webhooks in the following areas:

Use cases

Your integration can listen for these webhooks to do the following:

  • Notify customers when initial syncs complete
  • Alert on sync errors
  • Transform synced data for your application
  • Cleanup old data after a customer deletes their account or disconnects their integration
  • Backfill data after a customer changes configuration settings

Setup

Configure webhook notifications via the Management Portal by navigating to Settings --> Webhooks.

webhook-config

Event types

  • sync.complete (its result field indicates SUCCESS or ERROR)
  • connection.created
  • connection.deleted

You can retrieve the event type in the request payload from the key webhook_event_type.

Timeout

You must process Webhook events within 15 seconds.

Webhook security

Because of the way webhooks work, attackers can impersonate services by simply sending a fake webhook to an endpoint. Think about it: it's just an HTTP POST from an unknown source. This is a potential security hole for many applications, or at the very least, a source of problems.

To prevent it, Supaglue signs every webhook and its metadata with a unique key for each endpoint. This signature can then be used to verify the webhook indeed comes from Supaglue, and only process it if it is.

Another potential security hole is what's called replay attacks. A replay attack is when an attacker intercepts a valid payload (including the signature), and re-transmits it to your endpoint. This payload will pass signature validation, and will therefore be acted upon.

To mitigate this attack, Supaglue includes a timestamp for when the webhook attempt occurred. Our libraries automatically reject webhooks with a timestamp more than five minutes away (past or future) from the current time. This requires your server's clock to be synchronized and accurate, and it's recommended that you use NTP to achieve this.

Supaglue uses an underlying webhook framework called Svix. Look more about how to validate the signature of webhook events in their docs here.

Reliable processing of webhook events

In some situations, after consuming notification webhooks, you will want to ensure the reliability and eventual consistency of processing webhook events, e.g. for transformations that involve multiple steps. Refer to our Recipes section for more details.

More information

You can read our Listening for Webhooks tutorial for a more in-depth guide on consuming webhook notifications.