Skip to main content

What is a Webhook?

A webhook is an automated message that is sent from one application to another application when certain events occur. Webhooks let applications notify one another in real-time when something has changed in one system and can be used to trigger an instance's flow so the change is reflected in the other system.

A webhook consists of two main parts:

  • The event that causes the webhook to fire. The event is usually a change to a record in an application. For example, you may have a contact.changed or report.created event.
  • The endpoint where information about the event is sent. The endpoint is a URL that you provide to the application that will receive the webhook.

Webhook request payloads

When a webhook fires, the application where the event occurred will send a POST request to the endpoint you provided. Most applications will send a JSON payload in the request body that contains information about the event that occurred (though some, notably Salesforce, send XML payloads).

Some payloads contain the entire record that changed, while others contain only the record's ID and you are expected to fetch the record yourself.

Webhook security

Webhooks are often secured using Hashed Message Authentication Codes (or HMAC) to ensure that the request is coming from the application that you expect.

For More Information: Secure Webhook Endpoints with HMAC.

Responses to webhooks

Some applications expect a particular response to the webhook request to ensure that your application understood the request. Most application expect an HTTP 200 response with a special message in the response body that is usually derived from the webhook's payload or request header. Other apps simply expect an HTTP 200 response.

Webhooks in Prismatic

In Prismatic, the endpoint of a webhook is generally an instance's flow's trigger URL.

Your integration configures webhooks in the third-party app when the instance is deployed either using an onInstanceDeploy function in a custom trigger, or by creating a "setup" flow that is triggered on instance deploy. Some built-in components will subscribe to webhooks automatically when the instance is deployed. If you configure webhooks on instance deploy, you should also remove webhooks on instance delete using a similar process.

If the third-party app expects a specific response to the webhook request, you can build a custom trigger that validates HMAC signatures and responds to the webhook request appropriately. Many build-in components already have triggers that handle this for you.

Ensuring webhook ordering with a FIFO queue

Prismatic's integration runner is designed to process requests in parallel. If you invoke an integration with multiple requests in quick succession, the runner will scale and process all of the requests at the same time.

If you have a workflow that requires requests to be processed in a specific order, or a workflow that requires you to process only one record at a time, you'll need to take some extra steps to ensure that the requests are processed sequentially. Check out our FIFO Queue tutorial for more information.