Notification Failed

The Notification Failed event is triggered when an attempt to send a notification to a device fails.


Table Schema

Notification Failed events are stored in BigQuery in the notification_failed table. The following is a detailed description of each column in the table grouped by data model.

Event

Properties of the Notification Failed event.

Column Description
event.timestamp A UNIX timestamp (seconds since January 1st, 1970 at UTC) indicating the time the event occurred.
event.triggered_event_id Deprecated No longer in use.
event.errors A string indicating the reason the notification failed to send. The value of this column will be the error returned from APNS/FCM. Some possible values are: InvalidRegistration, NotRegistered and Unregistered

Message

The individual message/notification that attempted to send.

Column Description
message.id The messages’s ID.
message.message_template_id The ID of the message template the message was generated from.
message.notification_text The copy used for the body of the push notification. See the Apple documentation and Android documentation for more detail on how push notifications are constructed.
message.ios_title The copy used for the title of the push notification on iOS devices. See the Apple documentation for more detail on how push notifications are constructed.
message.android_title The copy used for the title of the push notification on Android devices. See the Android documentation for more detail on how push notifications are constructed.
message.read A boolean value indicating whether the user has read the message.
message.viewed Deprecated Use message.read instead.
message.saved_to_inbox A boolean indicating whether the message is saved to the user’s inbox.
message.content_type The type of content this message drive’s the user to when the notification is swiped/tapped or the message is launched from the user’s inbox. There are five possible values: landing-page, experience, deep-link, website or custom
message.deeplink_url If the content type a deep-link, the value of this column will be the deep-link URL that is opened when the message’s notification is swiped/tapped or the message is launched from the inbox.
message.website_url If the content type is website, the value of this column will be the website URL that is opened when the message’s notification is swiped/tapped or the message is launched from the inbox.

Message Template

The message “template” is the message that was authored in the Messages app to which the individual message/notification was generated from.

Column Description
message_template.id The message template’s ID.
message_tempalte.type Indicates whether the message is a Proximity message or a Scheduled message. The possible values are ProximityMessageTemplate or ScheduledMessageTemplate.
message_template.title The message template’s title.
message_template.save_to_inbox A boolean indicating whether the “Save to Inbox” option is enabled.
message_template.notification_text The copy used for the body of the push notification. See the Apple documentation and Android documentation for more detail on how push notifications are constructed.
message_template.schedule_monday For proximity messages only – a boolean value indicating whether this message can be triggered on Mondays.
message_template.schedule_tuesday For proximity messages only – a boolean value indicating whether this message can be triggered on Tuesdays.
message_template.schedule_wednesday For proximity messages only – a boolean value indicating whether this message can be triggered on Wednesdays.
message_template.schedule_thursday For proximity messages only – a boolean value indicating whether this message can be triggered on Thursdays.
message_template.schedule_friday For proximity messages only – a boolean value indicating whether this message can be triggered on Fridays.
message_template.schedule_saturday For proximity messages only – a boolean value indicating whether this message can be triggered on Saturdays.
message_template.schedule_sunday For proximity messages only – a boolean value indicating whether this message can be triggered on Sundays.
message_template.content_type The type of content this message drive’s the user to when the notification is swiped/tapped or the message is launched from the user’s inbox. There are five possible values: landing-page, experience, deep-link, website or custom
message_template.scheduled_at For scheduled messages only – a timestamp indicating the date and time the message should be delivered. The timestamp is in UTC although the timezone information is ignored. The timezone in which the message is sent is determined from the message_template.scheduled_local_time and message_template.scheduled_time_zone columns.
message_template.scheduled_local_time For scheduled messages only – a boolean indicating whether the message should be sent to users in their own time zone. E.g. if the message is scheduled to be delivered at 3:00 PM on Jan 1. and message_template. scheduled_local_time is true, then the message will be sent to each user when it is 3:00 PM in their timezone.
message_template.scheduled_time_zone For scheduled messages only – the time zone in which the message should be sent. E.g. if this column has a value of America/Toronto (which is EST) – and the message_template.scheduled_at column has a value of Jan 1. at 3:00 PM UTC – the message will be delivered on Jan 1. at 3:00 PM EST.
message_template.time_schedule.start For proximity messages only – the time in minutes since 12:00 AM at which point the message is eligible to be delivered. I.e. if a user trigger’s a valid proximity event before this time, the message will not be delivered. A value of 0 means there is no minimum start time before the message becomes eligible to be sent. A value of 480, for example, means the message is not eligible to be sent before 8:00 AM (8 hours * 60 minutes = 480).
message_template.time_schedule.end For proximity messages only – the time in minutes since 12:00 AM at which point the message is no longer eligible to be delivered. I.e. if a user trigger’s a valid proximity event after this time, the message will not be delivered. A value of 1,440 is equivalent to the end of day and means there is no time limit on when a message is eligible to be sent. A value of 1,020, for example, means that after 5:00 PM the message is no longer eligible to be sent (17 hours * 60 minutes = 1,020).

Place

For proximity messages only – the place associated with the geofence that triggered the message/notification attempt, or the place associated with the beacon that triggered the message/notification attempt.

Column Description
place.id The place’s ID
place.title The place’s title.
place.address The place’s street name and number.
place.city The place’s city.
place.province The place’s province or state.
place.country The place’s country.
place.postal_code The place’s postal code or zip code.
place.latitude The latitude used for the geofence region associated with this place.
place.longitude The longitude used for the geofence region associated with this place.
place.radius The radius used for the geofence region associated with this place.
place.tags Tags associated with this place as setup in the Proximity App.
place.google_place_id A Google Place ID associated with this place. A Google Place will automatically be associated if you select one of the Google suggestions when creating a place in the Proximity App.
place.enabled Deprecated No longer in use.
place.shared Deprecated No longer in use.
beacon_configurations_count The number of beacons associated with the place.

Configuration

For proximity messages only – the beacon configuration associated with the beacon that triggered the message/notification attempt.

Column Description
configuration.id The configuration’s ID.
configuration.place_id The ID of the Place associated with the configuration. This will be null if the configuration was not associated with a Place.
configuration.title The configuration’s title.
configuration.uuid The configuration’s UUID.
configuration.major_number The configuration’s major number.
configuration.minor_number The configuration’s minor number.
configuration.tags Tags that were added to the configuration in the Proximity App.
configuration.enabled Deprecated No longer in use.
configuration.shared Deprecated No longer in use.

Device

The device that triggered the event.

Column Description
device.id A unique device identifier. On iOS this is the value returned from UIDevice.identifierForVendor. On Android this is a UUID generated by the Rover SDK.
device.token The token used by APNS or FCM/GCM to sent notifications to the device.
device.locale_lang The language portion of device’s current locale as set in the device’s system settings. E.g. “en”.
device.locale_region The region dialect portion of device’s current locale as set in the device’s system settings. E.g. “US”.
device.time_zone The device’s current time zone. E.g. “America/Toronto”
device.sdk_version The version of the Rover SDK the device has installed. E.g. 1.6.2
device.platform A value of “iOS” or “Android” indicates this event was created by a device through the Rover SDK in a native app. A value of “Web” means the event was triggered by a device through a web browser. Currently the only events that can be triggered through a web browser are experience events when viewing a mobile-web version of an experience.
device.os_name The name of the operating system the device is running. E.g. “iOS”
device.os_version The version of the operating system the device is running. E.g. 11.1.2
device.model The name of the device model. E.g. “iPhone 6 Plus”
device.manufacturer The manufacturer of the device. E.g. “Samsung”
device.carrier The mobile carrier the device is currently connected to. E.g. “T-Mobile”
device.app_identifier The unique identifier of the app the device is running. E.g. “com.example.MyApp”
device.background_enabled Deprecated No longer in use.
device.notifications_enabled Deprecated Use device.notification_authorization instead.
device.bluetooth_enabled Indicates whether the device currently has Bluetooth enabled.
device.location_monitoring_enabled Indicates whether location monitoring is enabled. This could be turned off permanently in the system settings or by switching on airplane mode.
device.aid The advertising identifier associated with the device. On iOS this is the value returned from advertisingIdentifier.
device.location.latitude The latitude of the device’s last known location obtained from a location update.
device.location.longitude The longitude of the device’s last known location obtained from a location update.
device.location.accuracy The accuracy of the device’s last known location obtained from a location update, measured in metres.
device.ip The last known IP address of the device.
device.notification_authorization Indicates whether the device has authorized the app to display notifications.

Customer

Deprecated The customer model and all of its columns are deprecated and no longer in use.