Beta - Data Export - Databricks
This Integration is in Private Beta
If you are interested in participating in this beta, please contact your OneSignal Account Representative.

Overview
We understand that gaining deeper insights into engagement is essential for our customers to drive successful messaging strategies. By integrating with OneSignal’s Databricks Data Export functionality, you can automatically sync your messaging event data directly to your Databricks project—eliminating the need for manual exports and giving you immediate access to a centralized data source for advanced analysis
This integration empowers you to perform in-depth analyses of your engagement data across key channels, including email, push notifications, in-app messages, and SMS. You can leverage this data to build custom dashboards, uncover trends, and generate actionable reports for leadership and cross-functional teams.
Currently, the integration supports data exports for events tied to sent messages and related engagement actions (such as clicks, opens, and more). We are continuously expanding our export capabilities and plan to offer additional event types in the near future to provide an even more comprehensive view of your users' journeys.
Requirements
Your Databricks account can be set up on Amazon Web Services (AWS), Microsoft Azure, Google Cloud Platform (GCP).
Databicks Account
- Needs to be on a Premium plan or above Premium plan or above
- Unity Catalog enabled on your Databricks Workspace
- Unity Catalog is a unified governance solution for all data and AI assets including files, tables, machine learning models and dashboards in your lakehouse on any cloud. Legacy deployments can continue to use Databricks without Unity Catalog
- SQL warehouses
- SQL warehouses are optimized for data ingestion and analytics workloads, start and shut down rapidly, and are automatically upgraded with Databricks' latest enhancements.
OneSignal Account & Annual Plan
- This integration is only accessible to OneSignal customers on an annual plan.
Setup
Step 1- Configure Databricks
-
Gather information from your SQL Warehouse
- Navigate to SQL Warehouses, select your warehouse, and switch to the Connection Details tab
- Make note of the Server Hostname, Port, and HTTP Path
-
Create a Service Principal
- Navigate to the workspace Settings
- Go to Identity and Access, then Service Principals'
- Click “Add Service Principal”, then “Add New”
-
Generate a Secret for your Service Principal
- Click your service principal
- Go to the “Secrets” tab
- Generate a secret
-
Add Permissions to your Service Principal
- Navigate to your Catalog, and go to the Permissions tab
- Click the “Grant” button, and enter the name of the service principal you’ve created
- Add the following permissions:
CREATE SCHEMA, CREATE TABLE, SELECT, MODIFY, CREATE SCHEMA, CREATE TABLE
Step 2 - Set up Databricks Integration in OneSignal
- Navigate to the Databricks integrations page in OneSignal
- Dashboard > Integrations > Databricks
- Copy the configuration details that you gathered from your Cluster and your SQL Warehouse in your Databricks account and paste them into the relevant fields in OneSignal

Step 3 - Send a Message
The hard part is over.
Now, we move on to the fun part: generating Message Events. You can send messages to any number of subscriptions using the channel of your choice (as long as you’ve subscribed to receive those events in your integration settings on OneSignal).
Step 4 - Find Message Event Data In Databricks
- Navigate to your catalog
- Once syncing has succeeded, you should see a new Schema appear within your Catalog, with the name you gave it when setting up the integration in OneSignal

- You should be able to click the table and view Sample Data:

If your Databricks set up is not covered by this documentation or if you run into issues with connecting your Onesignal to Databricks, please reach out to [email protected].
Events and Properties
Below is an overview of the data available for the Databricks Data Export Integration. We will offer Message Event data in the beta, and will plan to offer more categories of event data and summary reports in the future.
For this integration, any event data generated by a user for the given OneSignal application will be exported to a customer's Databricks project. Customers will not be able to select specific event kinds or filter the events they receive.
Message Event Kinds
See Event Streams for more details.
The events that be:
sent
- The push, email, or sms was sent to the Subscriptionreceived
- The push or email was received by the Subscription. See Confirmed Delivery.clicked
- The in-app, push, or email link was clicked by the user.failed
- The push, email, or sms failed to send. See message results for details.unsubscribed
- The push, email, or sms Subscription became unsubscribed.opened
- The email was opened. See Email Message Reports for details.spam
- The user reported email as spam. See Email deliverability for details.bounce
- The email address bounced. See Email Message Reports for details.suppressed
- The email was not sent because the email address is on the Suppression list .page_displayed
- A card on the in-app carousel displayed to the user.impression
- The in-app displayed to the user.
Message Events Properties
See Event Streams for more details.
For each message event generated by a user, the following metadata will be attached to the record.
Column Name | Type | Description | Example |
---|---|---|---|
event_id | UUID | A unique ID that represents the event | dc76df03-287c-403a-aabd-b2d4fe44e5c6 |
app_id | UUID | A unique ID that represents the OneSignal App ID events were generated in | bc76df03-287c-403a-aabd-b2d4fe44e5c6\ |
event_kind | string | The type of event that occurred. The list of event kinds can be found here. | message.email.opened |
event_impression_timestamp | unix_timestamp | The time that Onesignal processes the event | 1684951205 |
subscription_id | UUID | A unique ID that represents the device/subscription | 6e8b6978-75a4-4882-878c-2d15a78c2409 |
subscription_language | string | The language of this subscription | en |
subscription_timezone | integer | The specified timezone of this subscription | -25200 |
subscription_device_type | string | The type of device this subscription uses. | SMS |
onesignal_id | UUID | The onesignal_id of the user that made the impression | dc76df03-287c-403a-aabd-b2d4fe44e5c6 |
external_id | string | The external_id of the user that made the impression | MyExternalId |
message_id | UUID | A unique ID that represents the message | dc76df03-287c-403a-aabd-b2d4fe44e5c6 |
message_name | string | The human-readable id of the Notification/Message | Campaign 1 |
message_title | string | The Title of the Notification/Message. English only at this time | Bonus 50 coins when you play! |
message_body | string | The Body of the message. (Truncated) English only at this time. | Play against your friends and earn an additional... |
Updated 1 day ago