Details on all properties available for Event Streams and Webhooks.
{{ }}
to capture that data in the Event Stream. See Examples.
event
propertiesevent
object includes the following properties:
String
The message type (push
, email
, sms
, iam
) and event (e.g. received
, sent
, clicked
, failed
, unsubscribed
, displayed
, pagedisplayed
, opened
, clicked
, unsubscribed
, reported_as_spam
, hardbounced
, failed
, supressed
).
Usage: {{ event.kind }}
Message Event Kind (OneSignal) | Event name (in data set) | Event Description |
---|---|---|
Push Sent | message.push.sent | Push notification successfully sent to the push services (FCM, APNS, etc). |
Push Received | message.push.received | Push notification received by recipient. Not available on all platforms. See Confirmed Delivery for more details. |
Push Clicked | message.push.clicked | User tapped the push notification to open the app on device. |
Push Failed | message.push.failed | Push failed to be sent. See the Push Message Reports for details. |
Push Unsubscribed | message.push.unsubscribed | User unsubscribed on push subscription. See When do push subscription statuses update?. |
In-App Impression | message.iam.displayed | In-App Message successfully displayed on device. |
In-App Clicked | message.iam.clicked | User tapped an element on the In-App Message. |
In-App Page Displayed | message.iam.pagedisplayed | In-App Message page was displayed. Helpful for tracking carousels. |
Email Sent | message.email.sent | Email successfully sent. |
Email Received | message.email.received | Email received by recipient. |
Email Opened | message.email.opened | Email was opened by recipient. See Email Message Reports for details. |
Email Link Clicked | message.email.clicked | User tapped a link in the email. |
Email Unsubscribed | message.email.unsubscribed | User unsubscribed from email via the unsubscribe link. |
Email Reported As Spam | message.email.reported_as_spam | User reported the email as spam. Gmail requires Google Postmaster Tools to track. See Email deliverability for more details. |
Email Bounced | message.email.hardbounced | Email returned to sender due to permanent error. See Email Message Reports for details. |
Email Failed | message.email.failed | Email could not be delivered. See Email Message Reports for details. |
Email Suppressed | message.email.supressed | Email could not be sent because the email address is on the Suppression list. |
SMS Sent | message.sms.sent | SMS sent to recipient |
SMS Failed | message.sms.failed | SMS failed to send. See SMS Message Reports for details. |
SMS Delivered | message.sms.delivered | SMS successfully delivered |
SMS Undelivered | message.sms.undelivered | SMS could not be sent. See SMS Message Reports for details. |
UUID
A unique, OneSignal-generated identifier for each individual event in UUID v4 format. Use this ID for idempotent delivery tracking. If you are looking for the specific message or template identifier, use message.id
or message.template_id
.
Usage: {{ event.id }}
Integer
The UNIX timestamp of the event.
Usage: {{ event.timestamp }}
String
A human-readable time of the event in UTC (specifically an ISO string like “2024-02-21T23:45:15.228Z”).
Usage: {{ event.datetime }}
UUID
The OneSignal App ID.
Usage: {{ event.app_id }}
String
The subscription type (e.g. iOS
, Android
, Chrome
, Email
, SMS
, etc).
Usage: {{ event.subscription_device_type }}
UUID
The OneSignal Subscription ID.
Usage: {{ event.subscription_id }}
UUID
The OneSignal created User ID.
Usage: {{ event.onesignal_id }}
String
Your User ID set as the OneSignal External ID alias. Can be empty if not set in OneSignal.
Usage: {{ event.external_id }}
String
The name of the page or card that is displayed for certain in-app message events. See In-app message Event Streams for details.
Usage: {{ event.data.page_name }}
String
A unique identifier for the page or card that is displayed for certain in-app message events. See In-app message Event Streams for details.
Usage: {{ event.data.page_id }}
String
The name of the button or image block element clicked. Must contain a In-app click action. See In-app message Event Streams for details.
Usage: {{ event.data.target_name }}
String
A unique identifier for the button or image block element clicked. Must contain a In-app click action. See In-app message Event Streams for details.
Usage: {{ event.data.target_id }}
message
object is designed to keep you informed of the messages sent to the end-user. It includes properties like id
, template_id
, and content
, which contains the actual text of the message.
UUID
The message ID generated by OneSignal.
Usage: {{ message.id }}
String
The name of the message as set in the dashboard or using the API name
property.
Usage: {{ message.name }}
Object
The title of the push message or email subject as set in the dashboard or using the API headings
or email_subject
properties.
Usage: {{ message.title }}
Object
The contents of the push or SMS message as set in the dashboard or using the API contents
property (clipped at 50 characters). Email contents (email_body
) are not provided.
Usage: {{ message.contents }}
UUID
The template ID for a message sent via Journeys or the API template_id
property.
Usage: {{ message.template_id }}
String
The message’s launch URL (when using only one URL that is web and app agnostic). See URLs, Links and Deep Links for details.
Usage: {{ message.url }}
String
The message’s launch URL when using both a web and app-specific URL. See URLs, Links and Deep Links for details.
Usage: {{ message.app_url }}
String
The message’s launch URL when using both a web and app-specific URL. See URLs, Links and Deep Links for details.
Usage: {{ message.web_url }}
String
The user’s OneSignal ID.
Usage {{ user.onesignal_id }}
String
The user’s External ID.
Usage: {{ user.external_id }}
Object
The user’s tags.
Usage:
{{ user.tags }}
{{ user.tags.your_tag }}
{{ user.tags}}
."{{ user.tags.your_tag | default: '' }}"
.String
The user’s language.
Usage: {{ user.language }}
String
The ID of the subscription the message was sent to.
Usage: {{ user.subscription.id }}
String
The ID of the app.
Usage: {{ user.subscription.app_id }}
String
The token for the subscription the message was sent to.
{{ user.subscription.subscription_token }}
Number
The session count for the subscription the message was sent to.
Usage: {{ user.subscription.session_count }}
String
The language set on the subscription the message was sent to.
Usage: {{ user.subscription.language }}
String
The game version set on the subscription the message was sent to.
Usage: {{ user.subscription.game_version }}
Number
The last active time set on the subscription the message was sent to.
Usage: {{ user.subscription.last_active }}
Number
The play time set on the subscription the message was sent to.
Usage: {{ user.subscription.play_time }}
Number
The amount spent on the subscription the message was sent to.
Usage: {{ user.subscription.amount_spent }}
Number
The creation time of the subscription the message was sent to.
Usage: {{ user.subscription.created_at }}
Boolean
Indicates whether the subscription the message was sent to is currently subscribed.
Usage: {{ user.subscription.subscribed }}
String
The SDK version set on the subscription the message was sent to.
Usage: {{ user.subscription.sdk }}
String
The device model set on the subscription the message was sent to.
Usage: {{ user.subscription.device_model }}
String
The device operating system set on the subscription the message was sent to.
Usage: {{ user.subscription.device_os }}
Object
The user’s tags. You can access the entire object or specific tags.
Usage:
{{ user.tags }}
{{ user.tags.your_tag }}