Module default_api

Source

Enums§

BeginLiveActivityError
struct for typed errors of method begin_live_activity
CancelNotificationError
struct for typed errors of method cancel_notification
CreateAppError
struct for typed errors of method create_app
CreateNotificationError
struct for typed errors of method create_notification
CreatePlayerError
struct for typed errors of method create_player
CreateSegmentsError
struct for typed errors of method create_segments
CreateSubscriptionError
struct for typed errors of method create_subscription
CreateUserError
struct for typed errors of method create_user
DeleteAliasError
struct for typed errors of method delete_alias
DeletePlayerError
struct for typed errors of method delete_player
DeleteSegmentsError
struct for typed errors of method delete_segments
DeleteSubscriptionError
struct for typed errors of method delete_subscription
DeleteUserError
struct for typed errors of method delete_user
EndLiveActivityError
struct for typed errors of method end_live_activity
ExportEventsError
struct for typed errors of method export_events
ExportPlayersError
struct for typed errors of method export_players
FetchAliasesError
struct for typed errors of method fetch_aliases
FetchUserError
struct for typed errors of method fetch_user
FetchUserIdentityError
struct for typed errors of method fetch_user_identity
GetAppError
struct for typed errors of method get_app
GetAppsError
struct for typed errors of method get_apps
GetEligibleIamsError
struct for typed errors of method get_eligible_iams
GetNotificationError
struct for typed errors of method get_notification
GetNotificationHistoryError
struct for typed errors of method get_notification_history
GetNotificationsError
struct for typed errors of method get_notifications
GetOutcomesError
struct for typed errors of method get_outcomes
GetPlayerError
struct for typed errors of method get_player
GetPlayersError
struct for typed errors of method get_players
IdentifyUserByAliasError
struct for typed errors of method identify_user_by_alias
IdentifyUserBySubscriptionIdError
struct for typed errors of method identify_user_by_subscription_id
TransferSubscriptionError
struct for typed errors of method transfer_subscription
UpdateAppError
struct for typed errors of method update_app
UpdateLiveActivityError
struct for typed errors of method update_live_activity
UpdatePlayerError
struct for typed errors of method update_player
UpdatePlayerTagsError
struct for typed errors of method update_player_tags
UpdateSubscriptionError
struct for typed errors of method update_subscription
UpdateUserError
struct for typed errors of method update_user

Functions§

begin_live_activity
Starts a Live Activity
cancel_notification
Used to stop a scheduled or currently outgoing notification
create_app
Creates a new OneSignal app
create_notification
Sends notifications to your users
create_player
Register a new device to one of your OneSignal apps 🚧 Don’t use this This API endpoint is designed to be used from our open source Mobile and Web Push SDKs. It is not designed for developers to use it directly, unless instructed to do so by OneSignal support. If you use this method instead of our SDKs, many OneSignal features such as conversion tracking, timezone tracking, language detection, and rich-push won’t work out of the box. It will also make it harder to identify possible setup issues. This method is used to register a new device with OneSignal. If a device is already registered with the specified identifier, then this will update the existing device record instead of creating a new one. The returned player is a player / user ID. Use the returned ID to send push notifications to this specific user later, or to include this player when sending to a set of users. 🚧 iOS Must set test_type to 1 when building your iOS app as development. Omit this field in your production app builds.
create_segments
Create segments visible and usable in the dashboard and API - Required: OneSignal Paid Plan The Create Segment method is used when you want your server to programmatically create a segment instead of using the OneSignal Dashboard UI. Just like creating Segments from the dashboard you can pass in filters with multiple "AND" or "OR" operator’s. 🚧 Does Not Update Segments This endpoint will only create segments, it does not edit or update currently created Segments. You will need to use the Delete Segments endpoint and re-create it with this endpoint to edit.
create_subscription
Creates a new Subscription under the User provided. Useful to add email addresses and SMS numbers to the User.
create_user
Creates a User, optionally Subscriptions owned by the User as well as Aliases. Aliases provided in the payload will be used to look up an existing User.
delete_alias
Deletes an alias by alias label
delete_player
Delete player - Required: Used to delete a single, specific Player ID record from a specific OneSignal app.
delete_segments
Delete segments (not user devices) - Required: OneSignal Paid Plan You can delete a segment under your app by calling this API. You must provide an API key in the Authorization header that has admin access on the app. The segment_id can be found in the URL of the segment when viewing it in the dashboard.
delete_subscription
Deletes the Subscription.
delete_user
Removes the User identified by (:alias_label, :alias_id), and all Subscriptions and Aliases
end_live_activity
Stops a Live Activity
export_events
Generate a compressed CSV report of all of the events data for a notification. This will return a URL immediately upon success but it may take several minutes for the CSV to become available at that URL depending on the volume of data. Only one export can be in-progress per OneSignal account at any given time.
export_players
Generate a compressed CSV export of all of your current user data This method can be used to generate a compressed CSV export of all of your current user data. It is a much faster alternative than retrieving this data using the /players API endpoint. The file will be compressed using GZip. The file may take several minutes to generate depending on the number of users in your app. The URL generated will be available for 3 days and includes random v4 uuid as part of the resource name to be unguessable. 🚧 403 Error Responses You can test if it is complete by making a GET request to the csv_file_url value. This file may take time to generate depending on how many device records are being pulled. If the file is not ready, a 403 error will be returned. Otherwise the file itself will be returned. 🚧 Requires Authentication Key Requires your OneSignal App’s REST API Key, available in Keys & IDs. 🚧 Concurrent Exports Only one concurrent export is allowed per OneSignal account. Please ensure you have successfully downloaded the .csv.gz file before exporting another app. CSV File Format: - Default Columns: | Field | Details | | — | — | | id | OneSignal Player Id | | identifier | Push Token | | session_count | Number of times they visited the app or site | language | Device language code | | timezone | Number of seconds away from UTC. Example: -28800 | | game_version | Version of your mobile app gathered from Android Studio versionCode in your App/build.gradle and iOS uses kCFBundleVersionKey in Xcode. | | device_os | Device Operating System Version. Example: 80 = Chrome 80, 9 = Android 9 | | device_type | Device Operating System Type | | device_model | Device Hardware String Code. Example: Mobile Web Subscribers will have Linux armv | | ad_id | Based on the Google Advertising Id for Android, identifierForVendor for iOS. OptedOut means user turned off Advertising tracking on the device. | | tags | Current OneSignal Data Tags on the device. | | last_active | Date and time the user last opened the mobile app or visited the site. | | playtime | Total amount of time in seconds the user had the mobile app open. | | amount_spent | Mobile only - amount spent in USD on In-App Purchases. | | created_at | Date and time the device record was created in OneSignal. Mobile - first time they opened the app with OneSignal SDK. Web - first time the user subscribed to the site. | | invalid_identifier | t = unsubscribed, f = subscibed | | badge_count | Current number of badges on the device | - Extra Columns: | Field | Details | | — | — | | external_user_id | Your User Id set on the device | | notification_types | Notification types | | location | Location points (Latitude and Longitude) set on the device. | | country | Country code | | rooted | Android device rooted or not | | ip | IP Address of the device if being tracked. See Handling Personal Data. | | web_auth | Web Only authorization key. | | web_p256 | Web Only p256 key. |
fetch_aliases
Lists all Aliases for the User identified by :subscription_id.
fetch_user
Returns the User’s properties, Aliases, and Subscriptions.
fetch_user_identity
Lists all Aliases for the User identified by (:alias_label, :alias_id).
get_app
View the details of a single OneSignal app
get_apps
View the details of all of your current OneSignal apps
get_eligible_iams
Manifest of In-App Messages the Subscription is eligible to display by the SDK.
get_notification
View the details of a single notification and outcomes associated with it
get_notification_history
-> View the devices sent a message - OneSignal Paid Plan Required This method will return all devices that were sent the given notification_id of an Email or Push Notification if used within 7 days of the date sent. After 7 days of the sending date, the message history data will be unavailable. After a successful response is received, the destination url may be polled until the file becomes available. Most exports are done in ~1-3 minutes, so setting a poll interval of 10 seconds should be adequate. For use cases that are not meant to be consumed by a script, an email will be sent to the supplied email address. 🚧 Requirements A OneSignal Paid Plan. Turn on Send History via OneSignal API in Settings -> Analytics. Cannot get data before this was turned on. Must be called within 7 days after sending the message. Messages targeting under 1000 recipients will not have "sent" events recorded, but will show "clicked" events. Requires your OneSignal App’s REST API Key, available in Keys & IDs.
get_notifications
View the details of multiple notifications
get_outcomes
View the details of all the outcomes associated with your app 🚧 Requires Authentication Key Requires your OneSignal App’s REST API Key, available in Keys & IDs. 🚧 Outcome Data Limitations Outcomes are only accessible for around 30 days before deleted from our servers. You will need to export this data every month if you want to keep it.
get_player
View the details of an existing device in one of your OneSignal apps
get_players
View the details of multiple devices in one of your OneSignal apps Unavailable for Apps Over 80,000 Users For performance reasons, this method is not available for larger apps. Larger apps should use the CSV export API endpoint, which is much more performant.
identify_user_by_alias
Upserts one or more Aliases to an existing User identified by (:alias_label, :alias_id).
identify_user_by_subscription_id
Upserts one or more Aliases for the User identified by :subscription_id.
transfer_subscription
Transfers this Subscription to the User identified by the identity in the payload.
update_app
Updates the name or configuration settings of an existing OneSignal app
update_live_activity
Updates a specified live activity.
update_player
Update an existing device in one of your OneSignal apps
update_player_tags
Update an existing device’s tags in one of your OneSignal apps using the External User ID. Warning - Android SDK Data Synchronization Tags added through the Android SDK tagging methods may not update if using the API to change or update the same tag. For example, if you use SDK method sendTag("key", "value1") then update the tag value to "value2" with this API endpoint. You will not be able to set the value back to "value1" through the SDK, you will need to change it to something different through the SDK to be reset. Recommendations if using this Endpoint on Android Mobile Apps: 1 - Do not use the same tag keys for SDK and API updates 2 - If you want to use the same key for both SDK and API updates, call the SDK getTags method first to update the device’s tags. This is only applicable on the Android Mobile App SDKs. 📘 Deleting Tags To delete a tag, include its key and set its value to blank. Omitting a key/value will not delete it. For example, if I wanted to delete two existing tags rank and category while simultaneously adding a new tag class, the tags JSON would look like the following: "tags": { "rank": "", "category": "", "class": "my_new_value" }
update_subscription
Updates an existing Subscription’s properties.
update_user
Updates an existing User’s properties.