Aller au contenu

Notifications SimplePush

Aperçu

SimplePush est un systeme de messagerie plutot simple que vous pouvez utiliser sur votre appareil Android via leur application disponible ici.

Vous pouvez facultativement ajouter un chiffrement supplementaire aux notifications dans les parametres. Le service vous fournit alors une valeur {salt} et vous permet de definir votre propre {password} de chiffrement.

L’equipe Apprise reconnait que le chiffrement utilise par ce plugin est l’AES-CBC-128, un mode dont certaines faiblesses sont connues, notamment sa vulnerabilite potentielle aux attaques de type padding oracle (reference).

Si ce niveau de chiffrement ne vous convient pas, plusieurs options s’offrent a vous :

  1. contacter SimplePush pour leur demander d’ameliorer leur securite, ce qu’Apprise prendra volontiers en charge ensuite ;
  2. ne pas utiliser SimplePush et choisir plutot l’un des nombreux autres services disponibles.

Il est important de noter que ce chiffrement plus faible n’est utilise par Apprise que pour rester compatible avec SimplePush. Cela n’a aucun effet de bord et n’impacte aucun autre service de notification securise pris en charge par Apprise.

Vous trouverez ci-dessous une capture d’ecran de https://simplepush.io/features presentant le reglage de chiffrement tel qu’il est defini par le service d’origine :
Screenshot from 2024-10-03 21-52-46

La syntaxe valide est la suivante :

  • spush://{apikey}/
  • spush://{salt}:{password}@{apikey}/
VariableObligatoireDescription
apikeyOuiCle requise pour faire fonctionner votre compte. Elle vous est fournie par votre compte SimplePush.
eventNonPermet facultativement de preciser un evenement dans l’URL.
passwordNonSimplePush permet de chiffrer davantage le message et le titre pendant leur transmission, en plus du canal securise deja utilise. Il s’agit ici du mot de passe de chiffrement. Vous devez fournir aussi la valeur salt pour que cela fonctionne.
saltNonLa valeur salt vous est fournie par SimplePush et constitue la seconde partie du chiffrement additionnel disponible avec ce service. Vous devez fournir egalement un password pour que cela fonctionne.
VariableDescription
overflowCe paramètre peut être défini sur split, truncate ou upstream. Il détermine la manière dont Apprise remet le message que vous lui transmettez. Par défaut, il vaut upstream.
👉 upstream : ne fait aucune modification et transmet le message exactement tel qu’il a été reçu au service.
👉 truncate : veille à ce que le message tienne dans la limite amont documentée par le service. Si plus d’informations sont fournies que la limite définie, l’excédent est tronqué.
👉 split : similaire à truncate, sauf que si le message dépasse la limite amont documentée par le service, il est découpé en plusieurs morceaux plus petits puis envoyés séquentiellement.
formatCe paramètre peut être défini sur text, html ou markdown. Certains services prennent en charge plusieurs formats de publication du contenu. La valeur par défaut varie selon le service choisi et peut correspondre à l’un de ces trois formats. Vous pouvez facultativement forcer cette option pour vous écarter du comportement par défaut. Si le service ne prend pas en charge plusieurs formats de transmission, ce champ est ignoré.
verifyLes requêtes externes vers des emplacements sécurisés, par exemple via https, utilisent des certificats. Par défaut, Apprise vérifie la validité de ces certificats ; si ce n’est pas le cas, aucune notification n’est envoyée à la source. Dans certains cas, un utilisateur ne dispose pas d’une autorité de certification pour valider la clé ou fait simplement confiance à la source ; dans ce cas, vous pouvez définir ce drapeau sur no. Par défaut, il vaut yes.
ctoSignifie Socket Connect Timeout. Il s’agit du nombre de secondes pendant lesquelles Requests attend que votre client établisse une connexion avec une machine distante, ce qui correspond à l’appel connect() sur la socket. La valeur par défaut est de 4.0 secondes.
rtoSignifie Socket Read Timeout. Il s’agit du nombre de secondes pendant lesquelles le client attend que le serveur envoie une réponse. La valeur par défaut est de 4.0 secondes.
emojisActive la prise en charge des emojis, par exemple :+1: qui sera traduit en 👍. Par défaut, cette option vaut no.
Remarque : selon la configuration côté serveur, l’administrateur peut désactiver globalement la prise en charge des emojis ; mais par défaut, ce n’est pas le cas.
tzIdentifie le fuseau horaire de la base IANA que vous souhaitez utiliser. Par défaut, celui-ci est détecté à partir de la configuration du serveur qui exécute Apprise. Vous pouvez le définir sur des valeurs comme America/Toronto, ou sur tout autre fuseau correctement formaté correspondant à votre région.

Envoyer une notification SimplePush :

Fenêtre de terminal
# Supposons que :
# - notre {apikey} soit ABC123
apprise -vv -t "Titre du Message de Test" -b "Corps du Message de Test" \
spush://ABC123
Questions ou commentaires ?

Documentation

Vous avez repéré une faute de frappe ou une erreur ? Signalez-la ou proposez une correction .

Problèmes Techniques

Vous rencontrez un problème avec le code ? Ouvrez un ticket sur GitHub :

Conçu avec amour depuis le Canada