Skip to content

Activités en direct pour Swift

Découvrez comment implémenter les activités en direct pour le SDK Swift de Braze. Les activités en direct sont des notifications persistantes et interactives qui s’affichent directement sur l’écran de verrouillage, permettant aux utilisateurs d’obtenir des mises à jour dynamiques en temps réel—sans déverrouiller leur appareil.

Fonctionnement

Un suivi de livraison d'activité en direct sur l'écran de verrouillage d'un iPhone. Une barre d'état avec une voiture est presque à moitié remplie. Le texte indique « 2 min until pickup ».

Les activités en direct présentent une combinaison d’informations statiques et dynamiques que vous mettez à jour. Par exemple, vous pouvez créer une activité en direct qui fournit un suivi de statut pour une livraison. Cette activité en direct comporterait le nom de votre entreprise comme information statique, ainsi qu’un « délai de livraison » dynamique qui serait mis à jour à mesure que le livreur approche de sa destination.

En tant que développeur, vous pouvez utiliser Braze pour gérer les cycles de vie de vos activités en direct, effectuer des appels à la REST API de Braze pour mettre à jour les activités en direct, et faire en sorte que tous les appareils abonnés reçoivent la mise à jour dès que possible. De plus, comme vous gérez les activités en direct via Braze, vous pouvez les utiliser en tandem avec vos autres canaux de communication—notifications push, messages in-app, Content Cards—pour favoriser l’adoption.

Diagramme de séquence

Afficher le diagramme
---
config:
  theme: mc
---
sequenceDiagram
  participant Server as Client Server
  participant Device as User Device
  participant App as iOS App / Braze SDK
  participant BrazeAPI as Braze API
  participant APNS as Apple Push Notification Service
  Note over Server, APNS: Launch Option 1<br/>Locally Start Activities
  App ->> App: Register a Live Activity using <br>`launchActivity(pushTokenTag:activity:)`
  App ->> App: Get push token from iOS
  App ->> BrazeAPI: Activity ID & Push token<br>automatically sent to Braze
  Note over Server, APNS: Launch Option 2<br/>Remotely Start Activities
  Device ->> App: Call `registerPushToStart`<br>to collect push tokens early
  App ->> BrazeAPI: Push-to-start tokens sent to Braze
  Server ->> BrazeAPI: POST /messages/live_activity/start
  Note right of BrazeAPI: Payload includes:<br>- push_token<br>- activity_id<br>- external_id<br>- event_name<br>- content_state (optional)
  BrazeAPI ->> APNS: Live activity start request
  APNS ->> Device: APNS sends activity to device
  App ->> App: Get push token from iOS
  App ->> BrazeAPI: Activity ID & Push token<br>automatically sent to Braze
  Note over Server, APNS: Resuming activities upon app launch
  App ->> App: Call `resumeActivities(ofType:)` on each app launch
  Note over Server, APNS: Updating a Live Activity
  loop update a live activity
  Server ->> BrazeAPI: POST /messages/live_activity/update
  Note right of BrazeAPI: Payload includes changes<br>to ContentState (dynamic variables)
  BrazeAPI ->> APNS: Update sent to APNS
  APNS ->> Device: APNS sends update to device
  end
  Note over Server, APNS: Ending a Live Activity
  Server ->> BrazeAPI: POST /messages/live_activity/update
  Note right of BrazeAPI: Activity can be ended via:<br> - User manually dismisses<br>- Times out after 12 hours<br>- Setting `end_activity: true` on `/messages/live_activity/update`
  APNS ->> Device: Live activity is dismissed

Implémenter une activité en direct

Conditions préalables

Avant de pouvoir utiliser cette fonctionnalité, vous devrez intégrer le SDK Swift Braze. Vous devrez également remplir les conditions suivantes :

  • Assurez-vous que votre projet cible iOS 16.1 ou une version ultérieure.
  • Ajoutez le droit Push Notification sous Signing & Capabilities dans votre projet Xcode.
  • Assurez-vous que les clés .p8 sont utilisées pour envoyer des notifications. Les fichiers plus anciens tels que .p12 ou .pem ne sont pas pris en charge.
  • À partir de la version 8.2.0 du SDK Swift de Braze, vous pouvez enregistrer à distance une activité en direct. Pour utiliser cette fonctionnalité, iOS 17.2 ou une version ultérieure est requis.

Étape 1 : Créer une activité

Tout d’abord, assurez-vous d’avoir suivi Displaying live data with Live Activities dans la documentation d’Apple pour configurer les activités en direct dans votre application iOS. Dans le cadre de cette tâche, assurez-vous d’inclure NSSupportsLiveActivities défini sur YES dans votre Info.plist.

Comme la nature exacte de votre activité en direct est spécifique à votre cas d’usage, configurez et initialisez les objets Activity. Vous définirez notamment :

  • ActivityAttributes : Ce protocole définit le contenu statique (immuable) et dynamique (variable) qui apparaît dans votre activité en direct.
  • ActivityAttributes.ContentState : Ce type définit les données dynamiques qui sont mises à jour au cours de l’activité.

Vous utiliserez également SwiftUI pour créer la présentation de l’interface utilisateur sur l’écran de verrouillage et Dynamic Island sur les appareils pris en charge.

Assurez-vous de bien connaître les conditions préalables et les limites d’Apple pour les activités en direct, car ces contraintes sont indépendantes de Braze.

Exemple

Imaginons que nous voulions créer une activité en direct pour donner à nos utilisateurs des mises à jour sur le spectacle Superb Owl, où deux équipes concurrentes de sauvetage d’animaux sauvages reçoivent des points pour les hiboux dont ils s’occupent. Dans cet exemple, nous avons créé une structure appelée SportsActivityAttributes, mais vous pouvez utiliser votre propre implémentation d’ActivityAttributes.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
#if canImport(ActivityKit)
  import ActivityKit
#endif

@available(iOS 16.1, *)
struct SportsActivityAttributes: ActivityAttributes {
  public struct ContentState: Codable, Hashable {
    var teamOneScore: Int
    var teamTwoScore: Int
  }

  var gameName: String
  var gameNumber: String
}

Étape 2 : Démarrer l’activité

Tout d’abord, choisissez le mode d’enregistrement de votre activité :

  • À distance : Utilisez la méthode registerPushToStart au début du cycle de vie de l’utilisateur et avant que le jeton push-to-start ne soit nécessaire, puis démarrez une activité à l’aide de l’endpoint /messages/live_activity/start.
  • Localement : Créez une instance de votre activité en direct, puis utilisez la méthode launchActivity pour créer des jetons de notification push que Braze pourra gérer.

Étape 2.1 : Ajouter BrazeKit à votre extension de widget

Dans votre projet Xcode, sélectionnez le nom de votre application, puis General. Sous Frameworks and Libraries, vérifiez que BrazeKit est inclus dans la liste.

Le framework BrazeKit sous Frameworks and Libraries dans un exemple de projet Xcode.

Étape 2.2 : Ajouter le protocole BrazeLiveActivityAttributes

Dans votre implémentation d’ActivityAttributes, ajoutez la conformité au protocole BrazeLiveActivityAttributes, puis ajoutez la propriété brazeActivityId à votre modèle d’attributs.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
import BrazeKit

#if canImport(ActivityKit)
  import ActivityKit
#endif

@available(iOS 16.1, *)
// 1. Add the `BrazeLiveActivityAttributes` conformance to your `ActivityAttributes` struct.
struct SportsActivityAttributes: ActivityAttributes, BrazeLiveActivityAttributes {
  public struct ContentState: Codable, Hashable {
    var teamOneScore: Int
    var teamTwoScore: Int
  }

  var gameName: String
  var gameNumber: String

  // 2. Add the `String?` property to represent the activity ID.
  var brazeActivityId: String?
}

Étape 2.3 : S’inscrire au push-to-start

Ensuite, enregistrez le type d’activité en direct afin que Braze puisse suivre tous les jetons push-to-start et les instances d’activité en direct associés à ce type.

Exemple

Dans l’exemple suivant, la classe LiveActivityManager gère des objets d’activité en direct. Ensuite, la méthode registerPushToStart enregistre SportsActivityAttributes :

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
import BrazeKit

#if canImport(ActivityKit)
  import ActivityKit
#endif

class LiveActivityManager {

  @available(iOS 17.2, *)
  func registerActivityType() {
    // This method returns a Swift background task.
    // You may keep a reference to this task if you need to cancel it wherever appropriate, or ignore the return value if you wish.
    let pushToStartObserver: Task = Self.braze?.liveActivities.registerPushToStart(
      forType: Activity<SportsActivityAttributes>.self,
      name: SportsActivityAttributes.name
    )
  }

}

Étape 2.4 : Envoyer une notification push-to-start

Envoyez une notification push-to-start à distance à l’aide de l’endpoint /messages/live_activity/start.

Vous pouvez utiliser le framework ActivityKit d’Apple pour obtenir un jeton de notification push que le SDK Braze peut gérer pour vous. Cela vous permet de mettre à jour les activités en direct via l’API Braze, car Braze enverra le jeton de notification push au service de notification push d’Apple (APNs) côté serveur.

  1. Créez une instance de votre implémentation d’activité en direct à l’aide des API ActivityKit d’Apple.
  2. Définissez le paramètre pushType sur .token.
  3. Transmettez les ActivitiesAttributes et le ContentState des activités en direct que vous avez définis.
  4. Enregistrez votre activité auprès de votre instance Braze en la passant dans launchActivity(pushTokenTag:activity:). Le paramètre pushTokenTag est une chaîne de caractères personnalisée que vous définissez. Elle doit être unique pour chaque activité en direct que vous créez.

Une fois l’activité en direct enregistrée, le SDK Braze extrait et observe les changements dans les jetons de notification push.

Exemple

Pour notre exemple, nous allons créer une classe appelée LiveActivityManager qui servira d’interface pour nos objets d’activité en direct. Ensuite, nous définirons le pushTokenTag sur "sports-game-2024-03-15".

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
import BrazeKit

#if canImport(ActivityKit)
  import ActivityKit
#endif

class LiveActivityManager {

  @available(iOS 16.2, *)
  func createActivity() {
    let activityAttributes = SportsActivityAttributes(gameName: "Superb Owl", gameNumber: "Game 1")
    let contentState = SportsActivityAttributes.ContentState(teamOneScore: "0", teamTwoScore: "0")
    let activityContent = ActivityContent(state: contentState, staleDate: nil)
    if let activity = try? Activity.request(attributes: activityAttributes,
                                            content: activityContent,
      // Setting your pushType as .token allows the Activity to generate push tokens for the server to watch.
                                            pushType: .token) {
      // Register your Live Activity with Braze using the pushTokenTag.
      // This method returns a Swift background task.
      // You may keep a reference to this task if you need to cancel it wherever appropriate, or ignore the return value if you wish.
      let liveActivityObserver: Task = AppDelegate.braze?.liveActivities.launchActivity(pushTokenTag: "sports-game-2024-03-15",
                                                                                        activity: activity)
    }
  }

}

Votre widget d’activité en direct affichera ce contenu initial à vos utilisateurs.

Une activité en direct sur l'écran de verrouillage d'un iPhone avec les scores de deux équipes. Les équipes Wild Bird Fund et Owl Rehab ont toutes deux un score de 0.

Étape 3 : Reprendre le suivi de l’activité

Pour que Braze suive votre activité en direct dès le lancement de l’application :

  1. Ouvrez votre fichier AppDelegate.
  2. Importez le module ActivityKit s’il est disponible.
  3. Appelez resumeActivities(ofType:) dans application(_:didFinishLaunchingWithOptions:) pour tous les types d’ActivityAttributes que vous avez enregistrés dans votre application.

Cela permet à Braze de reprendre les tâches de suivi des mises à jour des jetons de notification push pour toutes les activités en direct actives. Notez que si un utilisateur a explicitement fermé l’activité en direct sur son appareil, elle est considérée comme supprimée et Braze ne la suivra plus.

Exemple
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
import UIKit
import BrazeKit

#if canImport(ActivityKit)
  import ActivityKit
#endif

@main
class AppDelegate: UIResponder, UIApplicationDelegate {

  static var braze: Braze? = nil

  func application(
    _ application: UIApplication,
    didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?
  ) -> Bool {

    if #available(iOS 16.1, *) {
      Self.braze?.liveActivities.resumeActivities(
        ofType: Activity<SportsActivityAttributes>.self
      )
    }

    return true
  }
}

Étape 4 : Mettre à jour l’activité

Une activité en direct sur l'écran de verrouillage d'un iPhone avec les scores de deux équipes. Le Wild Bird Fund a 2 points et l'Owl Rehab en a 4.

L’endpoint /messages/live_activity/update vous permet de mettre à jour une activité en direct via des notifications push transmises par la REST API de Braze. Utilisez cet endpoint pour mettre à jour le ContentState de votre activité en direct.

Lorsque vous mettez à jour votre ContentState, votre widget d’activité en direct affiche les nouvelles informations. Voici à quoi pourrait ressembler le spectacle Superb Owl à la fin de la première mi-temps.

Pour plus de détails, consultez notre article sur l’endpoint /messages/live_activity/update.

Étape 5 : Terminer l’activité

Lorsqu’une activité en direct est active, elle s’affiche à la fois sur l’écran de verrouillage de l’utilisateur et sur Dynamic Island. Pour la terminer via Braze, utilisez l’endpoint /messages/live_activity/update avec end_activity défini sur true.

Pour améliorer la fiabilité lors de la fin d’une activité en direct, suivez ces étapes facultatives :

  1. Incluez éventuellement dismissal_date dans la même requête update pour indiquer à iOS quand supprimer l’interface de l’activité en direct.
  2. Vérifiez les résultats de distribution dans le Journal d’activité des messages.

Planifier la fermeture automatique

Pour planifier une fermeture automatique, programmez une requête de suivi vers l’endpoint de mise à jour après avoir démarré l’activité en direct.

  1. Envoyez une requête /messages/live_activity/start avec un activity_id que vous pouvez suivre.
  2. Stockez cet activity_id et votre heure de fin cible dans votre planificateur backend.
  3. À l’heure de fin cible, envoyez une requête /messages/live_activity/update avec end_activity défini sur true.
  4. Configurez la date de fermeture dans la même requête de mise à jour. Pour plus de détails, consultez l’endpoint /messages/live_activity/update.

Notez que le moment de la fermeture est contrôlé par iOS. Même après l’envoi d’une requête de fin valide, la suppression de l’écran de verrouillage ou de Dynamic Island peut être retardée ou se comporter différemment selon les conditions du système d’exploitation.

Une activité en direct peut également se terminer en dehors de Braze :

  • Fermeture par l’utilisateur : Un utilisateur peut fermer manuellement une activité en direct.
  • Expiration : Après une durée par défaut de huit heures, iOS supprime l’activité en direct de Dynamic Island. Après une durée par défaut de 12 heures, iOS supprime l’activité en direct de l’écran de verrouillage.

Pour plus de détails, consultez notre article sur l’endpoint /messages/live_activity/update.

Suivi des activités en direct

Les événements d’activité en direct sont disponibles dans Currents, Snowflake Data Sharing et le Générateur de requêtes. Les événements suivants peuvent vous aider à comprendre et à surveiller le cycle de vie de vos activités en direct, à suivre la disponibilité des jetons et à diagnostiquer de manière indépendante les problèmes ou à vérifier les statuts de distribution.

  • Live Activity Push To Start Token Change : Enregistre lorsqu’un jeton push-to-start (PTS) est ajouté ou mis à jour dans Braze, vous permettant de suivre les enregistrements et la disponibilité des jetons par utilisateur.
  • Live Activity Update Token Change : Suit l’ajout, la mise à jour ou la suppression des jetons Live Activity Update (LAU).
  • Live Activity Send : Enregistre chaque fois qu’une activité en direct est démarrée, mise à jour ou terminée par Braze.
  • Live Activity Outcome : Indique l’état final de la distribution au service de notification push d’Apple (APNs) pour chaque activité en direct envoyée depuis Braze.

Observer les événements d’activité en direct (facultatif)

Le SDK Braze fournit deux méthodes d’abonnement sur braze.liveActivities pour observer l’ensemble du cycle de vie des activités en direct. Pour un guide pas à pas complet, consultez le tutoriel sur les activités en direct.

  • subscribeToStateUpdates(_:) : Fournit les événements du cycle de vie pour l’enregistrement des jetons push-to-start et les instances d’activité en cours d’exécution.
  • subscribeToErrors(_:) : Fournit les erreurs côté SDK et côté serveur rencontrées lors du suivi des activités en direct.

Configurer les abonnements

Configurez les abonnements une seule fois dans application(_:didFinishLaunchingWithOptions:) et conservez-les pendant toute la durée de vie de votre application :

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
class AppDelegate: UIResponder, UIApplicationDelegate {
  static var braze: Braze?

  var stateSubscription: Braze.Cancellable?
  var errorSubscription: Braze.Cancellable?

  func application(
    _ application: UIApplication,
    didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?
  ) -> Bool {
    let braze = Braze(configuration: config)
    Self.braze = braze

    if #available(iOS 16.1, *) {
      stateSubscription = Self.braze?.liveActivities.subscribeToStateUpdates { event in
        self.handleStateUpdate(event)
      }
      errorSubscription = Self.braze?.liveActivities.subscribeToErrors { error in
        self.handleLiveActivityError(error)
      }
    }

    return true
  }
}

subscribeToStateUpdates

subscribeToStateUpdates(_:) fournit des valeurs UpdateEvent qui couvrent l’ensemble du cycle de vie des activités en direct. Les événements sont répartis en deux portées :

  • .activityType(ActivityType) : Événements au niveau du type pour l’enregistrement des jetons push-to-start (iOS 17.2+). Aucune instance d’activité n’existe encore.
  • .activityInstance(ActivityInstance) : Événements au niveau de l’instance pour une activité en cours d’exécution spécifique.

Plusieurs abonnés sont pris en charge — chaque abonnement actif reçoit chaque émission de manière indépendante.

Événements au niveau du type

Événement Quand il se déclenche
.pushToStartTokenRead(activityType:) Un jeton push-to-start a été lu depuis le système d’exploitation. Braze peut désormais démarrer à distance une nouvelle activité de ce type.
.pushToStartTokenFlushed(activityType:) Le jeton a été envoyé au serveur Braze. Braze peut envoyer des notifications push-to-start pour ce type.
.pushToStartOptedOut(activityType:) L’utilisateur a été désabonné du push-to-start pour ce type d’activité via optOutPushToStart(type:).
.pushToStartOptOutFlushed(activityType:) La désinscription a été envoyée au serveur Braze.

Événements au niveau de l’instance

Événement Quand il se déclenche
.started(activityId:activityType:pushTokenTag:launchSource:) Le SDK a commencé à suivre cette activité via launchActivity(pushTokenTag:activity:). La valeur launchSource est .local pour les activités initiées par l’application ou .pushToStart pour les activités démarrées à distance.
.resumed(activityId:activityType:pushTokenTag:) Le SDK a repris le suivi de cette activité via resumeActivities(ofType:).
.pushTokenFlushed(activityId:activityType:pushTokenTag:) Le jeton de notification push de l’activité a été accepté par le serveur Braze — l’activité peut désormais recevoir des mises à jour à distance.
.active(activityId:activityType:) L’activité est actuellement active et visible pour l’utilisateur.
.stale(activityId:activityType:staleDate:) Le contenu de l’activité est devenu obsolète. Émis uniquement sur iOS 16.2 et versions ultérieures.
.dismissed(activityId:activityType:) L’utilisateur a fermé manuellement l’activité.
.ended(activityId:activityType:) L’activité s’est terminée.
.contentUpdated(activityId:activityType:) L’état du contenu de l’activité a été mis à jour (iOS 16.2+). Utilisez une logique personnalisée pour rechercher l’Activity<T> par ID depuis Activity.activities et accéder à l’état typé via activity.content.state.
.pushTokenUpdated(activityId:activityType:) ActivityKit a effectué une rotation du jeton de notification push de l’activité.
Exemple
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
func handleStateUpdate(_ event: Braze.LiveActivities.UpdateEvent) {
  switch event {

  // Type-scoped: push-to-start token lifecycle (iOS 17.2+)
  case .activityType(.pushToStartTokenRead(let activityType)):
    print("[\(activityType)] Push-to-start token read by SDK")

  // ...

  // Instance-scoped: SDK tracking
  case .activityInstance(.started(let id, let type, let tag, let source)):
    print("[\(type)] Activity \(id) started via \(source), tag: \(tag)")

  // ...

  // Instance-scoped: ActivityKit lifecycle
  case .activityInstance(.active(let id, let type)):
    print("[\(type)] Activity \(id) is active")

  // ...

  case .activityInstance(.ended(let id, let type)):
    print("[\(type)] Activity \(id) ended")

  // Instance-scoped: content updates (iOS 16.2+)
  case .activityInstance(.contentUpdated(let id, let type)):
    // For more advanced use cases of `contentUpdated`, see the section below
    print("[\(type)] Content updated for activity \(id)")

  case .activityInstance(.pushTokenUpdated(let id, let type)):
    print("[\(type)] Activity \(id) push token rotated")
  }
}

subscribeToErrors

subscribeToErrors(_:) fournit des valeurs ErrorEvent en utilisant les deux mêmes portées que UpdateEvent :

  • .activityType(ActivityType) : Erreurs au niveau du type pour les échecs d’enregistrement push-to-start.
  • .activityInstance(ActivityInstance) : Erreurs au niveau de l’instance pour une activité en cours d’exécution.

Utilisez le drapeau isTransient pour déterminer si une nouvelle tentative est appropriée. Le SDK réessaie automatiquement les échecs transitoires.

Erreurs au niveau du type

Erreur Quand elle se déclenche
.pushToStartRegistrationFailed(activityType:isTransient:reason:) Le jeton push-to-start n’a pas pu atteindre le serveur Braze.

Erreurs au niveau de l’instance

Erreur Quand elle se déclenche
.registrationFailed(activityId:activityType:pushTokenTag:isTransient:reason:) Le jeton de notification push de l’activité n’a pas pu être enregistré auprès de Braze.
.activityNotFound(activityId:activityType:) resumeActivities(ofType:) a trouvé un mappage stocké pour une activité qui n’est plus en cours d’exécution — elle s’est probablement terminée alors que l’application était fermée.
.invalidPushTokenTag(activityId:activityType:tag:) launchActivity(pushTokenTag:activity:) a été appelé avec une étiquette invalide. Les étiquettes doivent être non vides et inférieures à 256 octets.
Exemple
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
func handleLiveActivityError(_ error: Braze.LiveActivities.ErrorEvent) {
  switch error {

  // Type-scoped errors
  case .activityType(.pushToStartRegistrationFailed(let type, let isTransient, let reason)):
    if isTransient {
      print("[\(type)] Push-to-start registration failed (transient, will retry): \(reason)")
    } else {
      print("[\(type)] Push-to-start registration failed (permanent): \(reason)")
    }

  // Instance-scoped errors
  case .activityInstance(.registrationFailed(let id, let type, _, let isTransient, let reason)):
    if isTransient {
      print("[\(type)] Activity \(id) registration failed (transient, retrying): \(reason)")
    } else {
      print("[\(type)] Activity \(id) registration failed (permanent): \(reason)")
    }

  case .activityInstance(.activityNotFound(let id, let type)):
    print("[\(type)] Stored activity \(id) not found on resume")

  case .activityInstance(.invalidPushTokenTag(let id, let type, let tag)):
    print("[\(type)] Activity \(id) has invalid push token tag '\(tag)'")
  }
}

Gérer les mises à jour de l’état du contenu (facultatif)

Si vous souhaitez utiliser l’état du contenu de l’instance réelle de l’activité en direct, suivez cette section.

Lorsqu’un événement .contentUpdated se déclenche, utilisez une logique personnalisée pour rechercher l’Activity<T> en cours d’exécution par son ID depuis Activity.activities, puis accédez au ContentState typé via activity.content.state.

Type d’attributs unique

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
case .activityInstance(.contentUpdated(let id, let type)):
  #if canImport(ActivityKit)
    // Add custom logic look up the Activity<T> by ID and access your app's typed ContentState.
    // In this example, `SportsActivityAttributes` is the app's custom type.
    if #available(iOS 16.2, *),
      let activity = findActivityInstance(id: id, as: SportsActivityAttributes.self)
    {
      // `activityContent` is now strongly typed as a `SportsActivityAttributes`
      let activityContent = activity.content.state
      print("[\(type)] Game \(id) — score: \(activityContent.teamOneScore)\(activityContent.teamTwoScore)")
      return
    }
  #endif
  print("[\(type)] Content updated for activity \(id)")

// ...

// - MARK: Helper methods

@available(iOS 16.2, *)
func findActivityInstance<Attributes: ActivityAttributes>(
  id: String,
  as type: Attributes.Type
) -> Activity<Attributes>? {
  // Use Apple's API to find the matching Live Activity instance:
  // - https://developer.apple.com/documentation/activitykit/activity/activities
  Activity<Attributes>.activities.first(where: { $0.id == id })
}

Types d’attributs multiples

Si votre application utilise plusieurs types d’ActivityAttributes, vérifiez la chaîne type pour rechercher l’Activity<T> approprié :

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
case .activityInstance(.contentUpdated(let id, let type)):
  #if canImport(ActivityKit)
    if #available(iOS 16.2, *) {
      if type == SportsActivityAttributes.name,
        let activity = findActivityInstance(id: id, as: SportsActivityAttributes.self)
      {
        let activityContent = activity.content.state
        print("[\(type)] Game \(id) — score: \(activityContent.teamOneScore)\(activityContent.teamTwoScore)")
        return

      } else if type == OrderActivityAttributes.name,
        let activity = findActivityInstance(id: id, as: OrderActivityAttributes.self)
      {
        let activityContent = activity.content.state
        print("[\(type)] Order \(id) — status: \(activityContent.status), ETA: \(activityContent.eta)")
        return
      }
    }
  #endif
  print("[\(type)] Content updated for activity \(id)")

// ...

// - MARK: Helper methods

@available(iOS 16.2, *)
func findActivityInstance<Attributes: ActivityAttributes>(
  id: String,
  as type: Attributes.Type
) -> Activity<Attributes>? {
  // Use Apple's API to find the matching Live Activity instance:
  // - https://developer.apple.com/documentation/activitykit/activity/activities
  Activity<Attributes>.activities.first(where: { $0.id == id })
}

Foire aux questions (FAQ)

Fonctionnalité et support

Quelles plateformes prennent en charge les activités en direct ?

Actuellement, les activités en direct sont une fonctionnalité spécifique à iOS et iPadOS. Par défaut, les activités lancées sur un iPhone ou un iPad sont également affichées sur tout appareil watchOS 11+ ou macOS 26+ appairé.

Capture d'écran d'une barre de menus macOS affichant une activité en direct sous forme d'alerte.

L’article sur les activités en direct couvre les conditions préalables à la gestion des activités en direct via le SDK Swift de Braze.

Les applications React Native prennent-elles en charge les activités en direct ?

Oui, le SDK React Native 3.0.0+ prend en charge les activités en direct via le SDK Swift de Braze. Autrement dit, vous devez écrire du code iOS React Native directement au-dessus du SDK Swift de Braze.

Il n’existe pas d’API JavaScript spécifique à React Native pour les activités en direct, car les fonctionnalités des activités en direct fournies par Apple utilisent des langages non transposables en JavaScript (par exemple, la concurrence Swift, les génériques, SwiftUI).

Braze prend-il en charge les activités en direct en tant que campagne ou étape Canvas ?

Non, cela n’est pas pris en charge actuellement.

Notifications push et activités en direct

Que se passe-t-il si une notification push est envoyée alors qu’une activité en direct est active ?

Écran de téléphone avec une activité sportive en direct « Bulls vs Bears » vers le milieu de l'écran et un texte de notification push lorem ipsum en bas de l'écran.

Les activités en direct et les notifications push occupent des zones d’écran différentes et n’entrent pas en conflit sur l’écran de l’utilisateur.

Si les activités en direct exploitent la fonctionnalité de notification push, les notifications push doivent-elles être activées pour recevoir les activités en direct ?

Bien que les activités en direct reposent sur les notifications push pour les mises à jour, elles sont contrôlées par des paramètres utilisateur différents. Un utilisateur peut s’abonner aux activités en direct mais pas aux notifications push, et inversement.

Les jetons de mise à jour de l’activité en direct expirent au bout de huit heures.

Les activités en direct nécessitent-elles des amorces de notification push ?

Les amorces de notification push constituent une bonne pratique pour inviter vos utilisateurs à s’abonner aux notifications push de votre application. Cependant, il n’y a pas d’invite système pour s’abonner aux activités en direct. Par défaut, les utilisateurs sont abonnés aux activités en direct pour une application individuelle lorsqu’ils installent cette application sur iOS 16.1 ou une version ultérieure. Cette autorisation peut être désactivée ou réactivée dans les paramètres de l’appareil, application par application.

Sujets techniques et résolution des problèmes

Comment savoir si les activités en direct comportent des erreurs ?

Toute erreur d’activité en direct est consignée dans le tableau de bord de Braze dans le Journal d’activité des messages, où vous pouvez filtrer par « LiveActivity Errors ».

Après avoir envoyé une notification push-to-start, pourquoi n’ai-je pas reçu mon activité en direct ?

Tout d’abord, vérifiez que votre payload comprend tous les champs obligatoires décrits dans l’endpoint messages/live_activity/start. Les champs activity_attributes et content_state doivent correspondre aux propriétés définies dans le code de votre projet. Si vous êtes certain que le payload est correct, il est possible que votre débit soit limité par les APNs. Cette limite est imposée par Apple et non par Braze.

Pour vérifier que votre notification push-to-start est bien arrivée sur l’appareil mais n’a pas été affichée en raison des limites de débit, vous pouvez déboguer votre projet à l’aide de l’application Console sur votre Mac. Attachez le processus d’enregistrement pour l’appareil souhaité, puis filtrez les journaux par process:liveactivitiesd dans la barre de recherche.

Après avoir démarré mon activité en direct avec push-to-start, pourquoi ne reçoit-elle pas de nouvelles mises à jour ?

Vérifiez que vous avez correctement implémenté les instructions décrites ci-dessus. Votre ActivityAttributes doit contenir à la fois la conformité au protocole BrazeLiveActivityAttributes et la propriété brazeActivityId.

Après avoir reçu une notification push-to-start d’activité en direct, vérifiez que vous pouvez voir une requête réseau sortante vers l’endpoint /push_token_tag de votre URL Braze et qu’elle contient le bon ID d’activité dans le champ "tag".

Enfin, assurez-vous que le type d’attribut d’activité en direct dans votre payload de mise à jour correspond exactement à la chaîne de caractères et à la classe utilisées dans votre appel de méthode SDK vers registerPushToStart. Utilisez des constantes pour éviter les erreurs de frappe.

Je reçois une réponse « Accès refusé » lorsque j’essaie d’utiliser l’endpoint live_activity/update. Pourquoi ?

Les clés API que vous utilisez doivent disposer des autorisations appropriées pour accéder aux différents endpoints de l’API Braze. Si vous utilisez une clé API que vous avez précédemment créée, il est possible que vous ayez omis de mettre à jour ses autorisations. Consultez notre aperçu de la sécurité des clés API pour en savoir plus.

L’endpoint messages/send partage-t-il les limites de débit avec l’endpoint messages/live_activity/update ?

Par défaut, la limite de débit pour l’endpoint messages/live_activity/update est de 250 000 requêtes par heure, par espace de travail et sur plusieurs endpoints. Pour plus d’informations, consultez les limites de débit de l’API.

New Stuff!