Common use cases
- Customer journey mapping and personalization: stream events to a CRM or Customer Data Platform (CDP) to build comprehensive customer profiles and tailor campaigns across various touchpoints.
- Analysis and reporting: send message events (e.g., sends, opens, clicks) to a data warehouse to analyze engagement patterns or long-term trends across channels.
- Compliance and regulatory reporting: stream all message-sent data to a data warehouse for auditing and compliance purposes.
- AI and predictive models: send message event data to in-house AI or predictive models to create comprehensive customer cohorts and understand churn risks—such as email unsubscribes or message dismissals, which may indicate potential churn.
- Marketing automation: send engagement events (like message opens or clicks) to other tools to automatically trigger the next steps in the user journey or update customer profiles and recent activity.
- Data fragmentation: valuable customer data often resides in separate tools (such as customer engagement platforms, CRMs, analytics tools, and data warehouses). Event streaming helps centralize this data, increasing visibility into valuable first-party data and allowing for faster revenue outcomes.
- Slow communication between systems: by sending live engagement events to other systems, you can trigger actions immediately after an event occurs, rather than waiting hours or days for batched updates. This eliminates reliance on manual imports or data syncs.
- Spend bloat and technical debt: instead of managing multiple intermediary tools, you can directly connect OneSignal with your data warehouse. This reduces the costly overhead of managing multiple integrations or custom data pipelines, lessens technical debt, and preserves valuable technical resources for product and marketing.
How to partner with your technical team
Setting up Event Streams requires collaboration with your technical team. Here are some tips to facilitate the conversation:- Explain the benefits: share your strategy for using this data and how it can enhance marketing campaigns, personalize user experiences, consolidate data, and reduce technical debt.
- Define the scope: identify where you want the data to be sent, which events you want to track, and the estimated data volume. This will aid in configuring the proper endpoint setup.
- Provide technical documentation: share OneSignal’s technical documentation and setup instructions. Your development team will need to configure the recipient endpoints and the event stream in OneSignal, ensuring data is routed correctly.
- Discuss data volume and management: confirm that your systems can handle real-time data flows. It’s recommended that the API handler records events without additional online processing to maintain low response times.
- Test and troubleshoot: conduct tests to ensure everything is functioning smoothly before going live.
Setup
You can configure a new event stream for your OneSignal application under Data > Event Streams.Requirements
Events can’t be sent unless the following requirements are met:- A valid URL or IP address pointing to your server HTTP(S) server
- URLs and IP addresses must be publicly routable
- Domains must include a recognized top-level domain (e.g., “.com”, “.net”)
Event Selection
Click “Select Events” to select your choice of events to trigger an event stream.
Trigger Webhook

Event Selection
Event stream filters
You can optionally further refine events by specifying the identifiers of one or more messages or templates, enabling you to receive only events related to specific messages within your app. Refer to the instructions below to enable event stream filtering.
Filtering events by template

Copying the Template ID of a template
- Template – https://dashboard.onesignal.com/apps/{APP_ID}/templates/{TEMPLATE_ID}
- Push – https://dashboard.onesignal.com/apps/{APP_ID}/notifications/{MESSAGE_ID}
- Email – https://dashboard.onesignal.com/apps/{APP_ID}/email/{MESSAGE_ID}
- SMS – https://dashboard.onesignal.com/apps/{APP_ID}/sms/{MESSAGE_ID}
Configure the Event Stream
Select the HTTP method, the URL, and add headers for the event stream. This is where authentication should be configured to ensure secure communication between OneSignal and your systems. The URI and Headers can contain liquid syntax which will come from both the user properties and properties of the event stream.Authentication Headers
You can add authentication headers to validate that requests to your endpoint are genuinely from OneSignal. Common authentication methods include:- Authorization Header: Add an Authorizationheader, whereYOUR_TOKENis provided by your system or 3rd party like:- Basic {{YOUR_TOKEN}}
- Bearer {{YOUR_TOKEN}}
- ApiKey {{YOUR_API_KEY}}
 
- Custom Headers: You can also add custom headers like:
- X-API-Key: {{YOUR_API_KEY}}
 
Testing Your Configuration
If you are looking for an easy way to test, use webhook.site. Find “Your unique URL” in the center of the page. Copy that URL and use it in the URL field of your event stream configuration.
Configure Webhook
Disallowed headers
The following headers are restricted and can’t be set.- content-length
- referer
- metadata-flavor
- x-google-metadata-request
- host
- x-onesignal*
Body
The body for an event stream will be JSON. The body JSON can be defined either as individual key/value pairs or as an editable code block. To change the input method use the first dropdown under the body heading and select the custom body.
Event Stream Body Options

cURL Preview of Event Stream
Personalization
You can personalize all fields in your Event Stream with predefined Event Streams Data. This data can be added using Liquid Syntax. This gives you the flexibility to use event streams for nearly any use case.See Event Streams Data for a list of all event, message, and user event data available for personalization.
Example body
Select the “Custom Body” in the drop-down:
Custom Body
Using Liquid Syntax in JSON
When using Liquid syntax within JSON, proper quoting depends on the data type: Guidelines for JSON Formatting- Strings → Must wrap in quotes.
- Numbers → Don’t wrap in quotes.
- Objects → Must not be wrapped in quotes.
Strings
✅ CorrectNumbers & Booleans
✅ CorrectObjects
✅ Correct- Use Direct Language Checks: Always check user.languagedirectly in conditionals, not in variables likeuserLang, for better compatibility.
- Start Simple: Begin with basic phrases, then gradually add complexity.
- Avoid Over-Nesting: Keep conditionals flat to prevent parsing issues.
- Test Basic Punctuation First: Start with simple sentences and punctuation before using special characters.
- Use Fallbacks: Ensure a default language (e.g., English) in case of missing translations.
- Stick to Standard Keys: Use standard OneSignal keys like content/title/enfor reliability.
For details and options on how to personalize your messages using Liquid syntax, check out our Using Liquid Syntax Guide.
Results & Debugging
You can see how your event stream performs over a period of time on the event stream report page under the Report tab. This will include all-time numbers, the current status of your event stream, and time series data showing what kind of responses the hook has been receiving. Any HTTP response in the 200 range indicates an event was successfully received, while responses in the 400s and 500s indicate errors. A timeout means the server on the other side didn’t manage to respond within a reasonable amount of time so OneSignal closed the connection and assumed it failed. You can see a sampling of recent requests under the Logs tab for even more detail. This will show actual requests and the responses from the other side (if applicable). If your event stream has issues, this is a great place to look first. If you need to change/update your event stream, you can edit it on the form page and send test requests to see the full details you need until you can get it right.
Event Stream Logs and Metrics
Retries / Disabling
When an Event Stream request fails for any recoverable reason (for example, status code 429), OneSignal will retry sending the event again after a short delay. This will happen a few times with increasing delays between requests. If enough retries fail in a row, the hook will be marked as ‘failed permanently’ and will no longer be retried. If too many separate requests fail in a row, this is probably because of an issue on the receiving end; the receiving end could have errors or have changed/disabled something. OneSignal will continue to send requests to a certain point, but if the requests continue to fail, the event stream might be disabled by OneSignal. If this happens, make sure to spend some time troubleshooting, fixing and then testing the event stream before re-enabling it. A poorly performing API could lead to event stream disablement. It is important that the API which ingests an event stream is able to handle the volume of events which is produced by message sends. Reviewing the volume of message sends that are produced by your app will reflect the performance required of your API. We recommend that the API receiving the event stream record an event without any other online processing. This will keep response times low and prevent any latency related issues. Slow response time or status code 429 responses from your API can cause a backlog of events. A consistent backlog of events will lead OneSignal to disable the event stream so you can update your API to handle the required throughput. OneSignal will send out emails to app admins and org admins when an event stream starts to experience a significant volume of failed events (but has not yet been disabled) as well as an email when the event stream is disabled when too many events have failed to send. There will also be a banner on the event streams index page notifying a OneSignal user of issues with one of their event streams. Each Event Stream has a uniqueevent.id for each event. This can be used as a header or in the body of the message as a way to check and potentially deduplicate requests if you see the same ones coming through.
Tips for Success
- You typically will want to have event streams connect to your own servers, not third party services.
- While there is nothing wrong with connecting directly to a third party the following can be harder to manage: It will be more challenging to configure/debug
 
- The volume of requests will not be managed in OneSignal.
- Event stream events will be sent out as fast as users hit the steps in your journey and this might overwhelm other services, hit rate limits, or run up YOUR bill unexpectedly. This is especially common when trying to use another messaging channel for something like SMS. The flexibility of event streams means OneSignal does not know what you’re trying to accomplish with them, so you may want to create a simple service of your own that accepts the event stream requests and then correctly handles your third-party connection limits, rate limits, and queue.
 
- Many services have public HTTP APIs which means you can connect to them with an event stream; look for their API docs and examples of how to make an HTTP request to find the right place to get started.
Message event data limitations
Data for messages sent via our Journeys or API are only available in our system for 30 days. This means that any message events (like clicks, opens, unsubscribes, etc.) that happen 30+ days after the Journey or API message was sent, will not be available in the event stream. This may appear as blank or missing data in your analytics. To work around this limitation, you can correlate themessage_id of these clicked/opened/unsubscribed events with the original sent event that has the same message_id. The original sent event should have the relevant message data (title, template etc).
Testing
Use a tool like https://webhook.site/ and set the Your unique URL provided into the URL parameter in the Event Stream with the POST method.
The URL matches the "Your unique URL" from webhook.site

Push message events selected, but any can be used for testing.

Example using webhook.site
- Host: the IP address where the request came from. See REST API overview for a list of possible IPs.
- Request Content the data sent within the body of the event stream.