Activity Feeds V3 is in closed alpha — do not use it in production (just yet).

Event Handling

You can configure your Stream app to receive webhook events as well as AWS SNS and AWS SQS. Webhooks are usually the simplest way to receive events from your app and to perform additional action based on what happens to your application.

The configuration can be done using the API or from the Dashboard. By default, all events are sent to your webhook/sqs/sns endpoint, you can also configure the events you want to receive in the dashboard.

await serverAuthClient.updateAppSettings({
  event_hooks: [
    {
      hook_type: "webhook",
      enabled: true,
      // Pass an empty array to subscribe to all events
      event_types: [],
      webhook_url: "<webhook url>",
    },
    {
      hook_type: "webhook",
      enabled: true,
      // Subscribe only to specific events
      event_types: ["feeds.activity.added" /* ... */],
      webhook_url: "<webhook url>",
    },
  ],
});

Some important points to consider:

  • The selection of events you want to receive applies to all the endpoints you have configured.
  • You can configure multiple endpoints for the same app (eg. AWS SNS and HTTP Webhook).
  • If your app is configured to receive all events, you can still filter the events you want to receive in your webhook handler.
  • If your app is configured to receive all events, newly introduced event types will be sent to your webhook handler by default.
  • If you pick specific events, newly introduced event types will not be sent to your webhook handler by default (you can still manually add them later on).

How to implement a webhook handler

Your webhook handler needs to follow these rules:

  • accept HTTP POST requests with JSON payload
  • be reachable from the public internet. Tunneling services like Ngrok are supported
  • respond with response codes from 200 to 299 as fast as possible

Your webhook handler can use the type field to handle events based correctly based on their type and payload.

All webhook requests contain these headers:

NameDescription
X-WEBHOOK-IDUnique ID of the webhook call. This value is consistent between retries and could be used to deduplicate retry calls
X-WEBHOOK-ATTEMPTNumber of webhook request attempt starting from 1
X-API-KEYYour application’s API key. Should be used to validate request signature
X-SIGNATUREHMAC signature of the request body. See Signature section

Best Practices

We highly recommend following common security guidelines to make your webhook integration safe and fast:

  • Use HTTPS with a certificate from a trusted authority
  • Verify the “X-Signature” header to ensure the request is coming from Stream
  • Support HTTP Keep-Alive
  • Use a highly available infrastructure such as AWS Elastic Load Balancer, Google Cloud Load Balancer, or similar
  • Offload the processing of the message if possible (read, store, and forget)
  • When decoding JSON into objects, ensure that your webhook can handle new fields being added to the JSON payload as well as new event types (eg. log unknown fields and event types instead of failing)

Error Handling

In case of the request failure Stream Chat attempts to retry a request. The amount of maximum attempts depends on the kind of the error it receives:

  • Response code is 408, 429 or >=500: 3 attempts
  • Network error: 2 attempts
  • Request timeout: 3 attempts

The timeout of one request is 6 seconds, and the request with all retries cannot exceed the duration of 15 seconds.

Available Event Types

Below is a comprehensive table of all available event types and their descriptions:

Event NameDescription
Activity Events
feeds.activity.addedFired when a new activity is added to a feed
feeds.activity.updatedFired when an activity is modified
feeds.activity.deletedFired when an activity is removed
feeds.activity.removed_from_feedFired when an activity is removed from a specific feed
feeds.activity.pinnedFired when an activity is pinned to the top
feeds.activity.unpinnedFired when an activity is unpinned
Notification Events
feeds.notification_feed.updatedFired when the notification status, or notification groups (aggregated activities) are updated
Comment Events
feeds.comment.addedFired when a new comment is added to an activity
feeds.comment.updatedFired when a comment is modified
feeds.comment.deletedFired when a comment is removed
Reaction Events
feeds.activity.reaction.addedFired when a reaction is added to an activity
feeds.activity.reaction.deletedFired when a reaction is removed from an activity
feeds.comment.reaction.addedFired when a reaction is added to a comment
feeds.comment.reaction.deletedFired when a reaction is removed from a comment
Poll Events
feeds.poll.closedFired when a poll is closed
feeds.poll.deletedFired when a poll is deleted
feeds.poll.updatedFired when a poll is modified
feeds.poll.vote_castedFired when a vote is cast
feeds.poll.vote_changedFired when a vote is changed
feeds.poll.vote_removedFired when a vote is removed
Feed Events
feeds.feed.createdFired when a new feed is created
feeds.feed.updatedFired when a feed is modified
feeds.feed.deletedFired when a feed is deleted
Member Events
feeds.feed_member.addedFired when a member is added to a feed
feeds.feed_member.removedFired when a member is removed from a feed
feeds.feed_member.updatedFired when a member’s role/permissions change
Follow Events
feeds.follow.createdFired when a follow relationship is created
feeds.follow.deletedFired when a follow relationship is removed
feeds.follow.updatedFired when follow settings are modified
Bookmark Events
feeds.bookmark.addedFired when an activity is bookmarked
feeds.bookmark.deletedFired when a bookmark is removed
feeds.bookmark.updatedFired when bookmark metadata is modified
feeds.bookmark_folder.deletedFired when bookmark folder is deleted
feeds.bookmark_folder.updatedFired when bookmark folder is updated

© Getstream.io, Inc. All Rights Reserved.