Avant de nous intéresser à l'API, examinons le push de manière globale, du début à la fin. Ensuite, lorsque nous aborderons des sujets ou des API spécifiques plus tard, vous aurez une idée de la façon dont et pourquoi cela est important.
Voici les trois étapes clés pour implémenter le push:
- Ajouter la logique côté client pour abonner un utilisateur aux notifications push (c'est-à-dire le code JavaScript et l'UI de votre application Web qui enregistre un utilisateur pour les notifications push)
- Appel d'API à partir de votre backend / application qui déclenche l'envoi d'un message push sur l'appareil d'un utilisateur.
- Fichier JavaScript du service worker qui recevra un "événement push" lorsque le push arrivera sur l'appareil. C'est dans ce code JavaScript que vous pourrez afficher une notification.
Examinons en détail chacune de ces étapes.
Étape 1: Côté client
La première étape consiste à "abonner" un utilisateur aux messages push.
Pour abonner un utilisateur, vous devez remplir deux conditions. Tout d'abord, obtenez l'autorisation de l'utilisateur pour lui envoyer des notifications push. Deuxièmement, obtenir un PushSubscription
à partir du navigateur.
Un PushSubscription
contient toutes les informations dont nous avons besoin pour envoyer un message push à cet utilisateur.
Vous pouvez considérer cela comme un identifiant de l'appareil de cet utilisateur.
Tout cela se fait en JavaScript avec l'API Push.
Avant d'abonner un utilisateur, vous devez générer un ensemble de "clés de serveur d'application", que nous verrons plus tard.
Les clés du serveur d'application, également appelées clés VAPID, sont propres à votre serveur. Ils permettent à un service de transfert de données par poussée de savoir quel serveur d'application a souscrit un utilisateur et de s'assurer qu'il s'agit du même serveur qui déclenche les messages de transfert de données par poussée vers cet utilisateur.
Une fois que vous avez souscrit l'utilisateur et que vous disposez d'un PushSubscription
, vous devez envoyer les informations PushSubscription
à votre backend / serveur. Sur votre serveur, vous allez enregistrer cet abonnement dans une base de données et l'utiliser pour envoyer un message push à cet utilisateur.
Étape 2: Envoyer un message push
Lorsque vous souhaitez envoyer un message push à vos utilisateurs, vous devez effectuer un appel d'API à un service push. Cet appel d'API inclut les données à envoyer, à qui envoyer le message et les critères d'envoi du message. Normalement, cet appel d'API est effectué à partir de votre serveur.
Voici quelques questions que vous pourriez vous poser:
- Qui est le service push et en quoi consiste-t-il ?
- À quoi ressemble l'API ? S'agit-il de JSON, de XML ou d'un autre format ?
- Que peut faire l'API ?
Qui est le service push et en quoi consiste-t-il ?
Un service push reçoit une requête réseau, la valide et envoie un message push au navigateur approprié. Si le navigateur est hors connexion, le message est mis en file d'attente jusqu'à ce qu'il soit en ligne.
Chaque navigateur peut utiliser n'importe quel service push, ce sur quoi les développeurs n'ont aucun contrôle. Ce n'est pas un problème, car chaque service de transfert par poussée attend le même appel d'API. Cela signifie que vous n'avez pas à vous soucier de l'identité du service de transfert. Vous devez simplement vous assurer que votre appel d'API est valide.
Pour obtenir l'URL appropriée pour déclencher un message push (c'est-à-dire l'URL du service push), il vous suffit de consulter la valeur endpoint
dans un PushSubscription
.
Vous trouverez ci-dessous un exemple des valeurs que vous obtiendrez à partir d'un PushSubscription:
{
"endpoint": "https://random-push-service.com/some-kind-of-unique-id-1234/v2/",
"keys": {
"p256dh": "BNcRdreALRFXTkOOUHK1EtK2wtaz5Ry4YfYCA_0QTpQtUbVlUls0VJXg7A8u-Ts1XbjhazAkj7I99e8QcYP7DkM=",
"auth": "tBHItJI5svbpez7KI4CCXg=="
}
}
Le point de terminaison dans ce cas est [https://random-push-service.com/some-kind-of-unique-id-1234/v2/]. Le service de transfert par poussée serait "random-push-service.com", et chaque point de terminaison est propre à un utilisateur, indiqué par "un-type-d-identifiant-unique-1234". Lorsque vous commencerez à travailler avec le push, vous remarquerez ce schéma.
Les clés de l'abonnement seront abordées plus tard.
À quoi ressemble l'API ?
J'ai mentionné que chaque service de push Web s'attend au même appel d'API. Cette API est le protocole Web Push. Il s'agit d'une norme IETF qui définit comment effectuer un appel d'API à un service push.
L'appel d'API nécessite que certains en-têtes soient définis et que les données soient un flux d'octets. Nous allons examiner les bibliothèques pouvant effectuer cet appel d'API pour nous, ainsi que la façon de le faire nous-mêmes.
Que peut faire l'API ?
L'API permet d'envoyer un message à un utilisateur, avec ou sans données, et fournit des instructions sur la manière d'envoyer le message.
Les données que vous envoyez avec un message push doivent être chiffrées. En effet, cela empêche les services push, qui peuvent être n'importe qui, de voir les données envoyées avec le message push. Cela est important, car c'est le navigateur qui décide du service de push à utiliser, ce qui pourrait ouvrir la porte aux navigateurs qui utilisent un service de push non sécurisé.
Lorsque vous déclenchez un message push, le service push reçoit l'appel d'API et met le message en file d'attente. Ce message restera en file d'attente jusqu'à ce que l'appareil de l'utilisateur soit en ligne et que le service de push puisse distribuer les messages. Les instructions que vous pouvez donner au service de push définissent la mise en file d'attente du message push.
Les instructions incluent des informations telles que:
Durée de vie d'un message push. Ce paramètre définit la durée pendant laquelle un message doit être mis en file d'attente avant d'être supprimé et non distribué.
Définissez l'urgence du message. Cela est utile si le service push préserve l'autonomie de la batterie des utilisateurs en ne transmettant que des messages à priorité élevée.
Attribuez un nom de "sujet" à un message push. Ce nouveau message remplacera tous les messages en attente.
Étape 3: Envoyer un événement push sur l'appareil de l'utilisateur
Une fois que nous avons envoyé un message push, le service de push conserve votre message sur son serveur jusqu'à ce qu'un des événements suivants se produise:
- L'appareil se connecte et le service de messages push envoie le message.
- Le message expire. Dans ce cas, le service de transfert de données supprime le message de sa file d'attente et il ne sera jamais distribué.
Lorsque le service push envoie un message, le navigateur le reçoit, déchiffre les données et distribue un événement push
dans votre service worker.
Un service worker est un fichier JavaScript "spécial". Le navigateur peut exécuter ce code JavaScript sans que votre page soit ouverte. Il peut même exécuter ce code JavaScript lorsque le navigateur est fermé. Un service worker dispose également d'API, comme le push, qui ne sont pas disponibles sur la page Web (c'est-à-dire des API qui ne sont pas disponibles en dehors d'un script de service worker).
C'est dans l'événement "push" du service worker que vous pouvez effectuer des tâches en arrière-plan. Vous pouvez effectuer des appels d'analyse, mettre en cache des pages hors connexion et afficher des notifications.
C'est l'ensemble du flux de la messagerie push.
Étapes suivantes
- Présentation des notifications push Web
- Fonctionnement de la méthode push
- Inscription d'un utilisateur
- Expérience utilisateur des autorisations
- Envoyer des messages avec des bibliothèques Web Push
- Protocole Web Push
- Gérer les événements push
- Afficher une notification
- Comportement des notifications
- Modèles de notification courants
- Questions fréquentes sur les notifications push
- Problèmes courants et signalement de bugs