Skip to content

Event Subscriptions with Webhooks

Alex Reichert edited this page Aug 25, 2020 · 2 revisions

If you want to build your own integrations, you can quickly subscribe to Papercups events (e.g. message:created) via webhooks.

Setting up a webhook

Step 1: Go to the Integrations page

After logging in, navigate to the Integrations page to get started: https://app.papercups.io/integrations

Screen Shot 2020-08-23 at 10 23 53 PM

Step 2: Click "Add webhook URL"

Click the "Add webhook URL" to open the modal which will guide you through setting up your first webhook.

Screen Shot 2020-08-23 at 10 24 00 PM

Step 3: Enter your webhook URL

Enter the URL that you would like Papercups to notify of new events. After you enter a URL, we will attempt to verify it by sending it a POST request with a request body that looks like:

{
  "event": "webhook:verify",
  "payload": "_SOME_RANDOMLY_GENERATED_STRING_"
}

In order to get your URL verified, it will need to respond with the randomly generated string. In a Node backend, this might look something like:

api.post('/webhook', (req, res) => {
  const {event, payload} = req.body;

  switch (event) {
    case 'webhook:verify':
      // Just respond with random string in the payload
      return res.send(payload);
    case 'message:created':
      // Not implemented yet
  }
});

NB: In development, you may need to use a service like ngrok to test your webhook. URLs like https://localhost:3000/api/webhook or 127.0.0.1/api/webhook will not work.

Step 4: Respond to events

The following events will be sent to your webhook URL once it's verified:

  • message:created - sent when a message is created
  • conversation:created (coming soon!) - sent when a conversation is created
  • conversation:updated (coming soon!) - sent when a conversation is updated (e.g. closed, assigned, etc)

As an example, the message:created event request body would look something like this:

{
  "event": "message:created",
  "payload": {
    "body": "Hello world!",
    "created_at": "2020-09-01T23:00:00",
    "conversation_id": "xxx-xxxx-xxx",
    "customer_id": "xxx-xxxx-xxx",
  }
}

To see some examples of webhook integrations, check out this demo: (coming soon!)

Clone this wiki locally