Make updates and terminate running Live Activities.
How to Use this API
To use this API, ensure your iOS application is configured correctly to support Live Activities by following the Live Activities Setup guide. Once you've successfully launched your Live Activity on the device using our SDK, you may begin updating Live Activities started from the device or remotely using a pushToStartToken
token.
Pick a Live Activity to update
Select which Live Activity to update by specifying its Activity ID in the URL. This is simple if your application only has one Live Activity or when the Live Activity is started remotely using Start Live Activity, It's either the identifier you passed to the LiveActivities.enter
SDK method or the activity_id
specified in your request. Otherwise, determine which Live Activity to update via its associated Activity ID.
For example, given the following code to launch an Activity:
OneSignal.LiveActivities.enter("bos_vs_dal_2024_09_05", withToken: token)
The Activity ID is bos_vs_dal_2024_09_05
.
Provide new state
Use the event_updates
parameter to specify a JSON object that matches the structure of the ActivityAttributes.ContentState
struct defined in your Live Activity widget extension.
For example, given the following ActivityAttributes.ContentState
struct:
public struct ContentState: Codable, Hashable {
var homeScore: Int
var awayScore: Int
var quarter: Int
}
Update the state of a Live Activity by setting the event_updates
to:
{
"homeScore": 0,
"homeScore": 3,
"quarter": 1
}
The event_updates
and ActivityAttributes.ContentState
must match, or the Live Activity will silently fail to launch.
Examples
Update active Live Activity
curl --request POST \
--url https://api.onesignal.com/apps/app_id/live_activities/<EXAMPLE_ACTIVITY_ID>/notifications \
--header 'Authorization: Basic <YOUR_REST_API_KEY>' \
--header 'Content-Type: application/json' \
--header 'accept: application/json' \
--data '
{
"included_segments": ["Celtics fans"],
"event": "update",
"event_updates": {
"homeScore": 0,
"awayScore": 0,
"quarter": 1,
},
"name": "Celtics vs. Mavericks Game 1",
"contents": {
"en": "Boston takes on Dallas at home."
},
"headings": {
"en": "BOS vs DAL"
},
"sound": "beep.wav",
"stale_date": 1695760785,
"dismissal_date": 1703505600,
"priority": 10
}
Path Parameters
activity_id
activity_id
Description
A self-generated identifier is used to uniquely identify your Live Activity.
Guidance
- Generate a unique
activity_id
to track and manage your Live Activity. This value is crucial for maintaining a consistent reference to the Live Activity across different devices and sessions. Consider using a UUID, CUID, or NanoID for this parameter. - Provide this
activity_id
when calling the iOS SDK methodenterLiveActivity
. This linkage is necessary for the iOS SDK to correctly handle and update the Live Activity. - Ensure that the
activity_id
is unique and consistently used for each Live Activity to avoid conflicts and ensure accurate tracking.
Refer to this guide to learn more about starting and updating Live Activities.
Body Parameters
event
event
Required
Type: string
Description
The action to perform on the Live Activity.
Guidance
Set to one of the following values:
-
"update"
—Updates the content of an existing Live Activity without ending it. -
"end"
—Ends the Live Activity and removes it from the user's view.
Example
Update an existing Live Activity:
{
"event": "update"
}
Refer to Apple's official documentation on Live Activities for comprehensive guidance on managing Live Activities.
event_updates
event_updates
Type: object
Description
The content to update a running Live Activity with. The object must conform to the ContentState
interface defined within your app's Live Activity.
Guidance
Ensure that the event_updates
object matches the ContentState
interface exactly as defined in your Live Activity implementation. Inconsistencies can cause Live Activities to fail to display.
Example
In this example, the object includes fields such as quarter
, homeScore
, and awayScore
, which should correspond to the fields defined in the iOS app's ContentState
interface.
{
"event_updates": {
"quarter": 1,
"homeScore": 70,
"awayScore": 78,
"inTimeout": false
}
}
name
name
Required
Type: string
Description
An internal identifier used to assist with your campaign's organization and management. This value is not displayed to the end user and serves solely for tracking purposes within your campaign tracking and analytics.
Guidance
The name should be meaningful and indicate the campaign's purpose or target audience.
Example
{
"name": "Spring Sale Campaign"
}
contents
contents
Required
Type object
Description
The notification content is displayed in the main body of the notification.
Guidance
Equivalent to the contents
parameter for Push Notifcations.
headings
headings
Type object
Description
The notification's title.
Guidance
Equivalent to the headings
parameter for Push Notifcations.
sound
sound
Type string
Specify a custom sound file to play when the notification is received instead of the default sound.
Guidance
Equivalent to the ios_sound
for Push Notifications.
stale_date
stale_date
Type: number
Description
A Unix timestamp (in seconds) that indicates when the Live Activity is considered outdated. Once this time is reached, the system updates the Live Activity to ActivityState.stale
.
Guidance
Use this parameter to set an expiration time for the Live Activity, ensuring users do not see outdated information.
The Unix timestamp should be provided in seconds, representing the exact time the Live Activity should transition to a stale state.
Example
To set a stale date for January 1, 2025, at 00:00:00 UTC.
{
"stale_date": 1735689600
}
Refer to Apple's documentation to learn more about this paramater.
dismissal_date
dismissal_date
Type: number
Description
The Unix timestamp (in seconds) at which the Live Activity will be terminated and removed from users' lock screens.
Guidance
This parameter lets you control when the Live Activity should be automatically removed from the lock screen, ensuring timely updates and removing irrelevant information.
- By default, the Live Activity is dismissed after 4 hours.
- Provide the Unix timestamp in seconds.
- This parameter is only effective when
event
is set to"end"
.
Example:
To set a dismissal date for January 1, 2025, at 12:00:00 UTC.
{
"dismissal_date": 1735723200
}
Refer to Apple's documentation to learn more about this paramater.
priority
priority
Type: number
Description
The priority level affects how quickly a notification is delivered and processed, particularly in power-saving modes.
Guidance
The priority
parameter determines the urgency and delivery behavior of the notification.
10
—Send the notification immediately. We recommend using this option while under development.5
—Send the notification based on the device's current power considerations, balancing timely delivery with power efficiency. We recommend using this option for the majority of your notifications, reserving10
for only the most critical messages.1
—Prioritize the device's power savings over immediate delivery. Notifications will not wake the device and get delivered when it is more power-efficient.- If the
priority
is omitted, APNS defaults to a priority of 10.
Example:
Send a notification with a balanced priority.
{
"priority": 5
}
For more detailed information, refer to Apple's official documentation on APNs Priority Levels.