Aller au contenu

Notifications Custom FORM

Aperçu

  • Prise en charge des images: Oui
  • Prise en charge des pièces jointes: Oui
  • Limites de caractères des messages:
    • Corps: 32768
  • Créer votre URL Apprise

Il s’agit simplement d’une notification personnalisee permettant a cet outil de publier vers un serveur web sous la forme d’un simple FORM, application/x-www-form-urlencoded. C’est utile pour les personnes qui souhaitent etre notifiees via leurs propres methodes personnalisees.

La charge utile inclura body, title, version et type dans la requete. Vous pouvez en ajouter d’autres, voir les details ci-dessous.

Le type prendra l’une des valeurs suivantes :

  • info : message de type informatif
  • success : rapport de succes
  • failure : rapport d’echec
  • warning : avertissement

La syntaxe valide est la suivante :

  • form://{hostname}
  • form://{hostname}:{port}
  • form://{user}:@{hostname}
  • form://{user}:@{hostname}:{port}
  • form://{user}:{password}@{hostname}
  • form://{user}:{password}@{hostname}:{port}

L’ajout d’un s au schema, c’est-a-dire forms://, bascule vers une connexion HTTPS securisee :

  • forms://{hostname}
  • forms://{hostname}:{port}
  • forms://{user}:@{hostname}
  • forms://{user}:@{hostname}:{port}
  • forms://{user}:{password}@{hostname}
  • forms://{user}:{password}@{hostname}:{port}
VariableObligatoireDescription
hostnameOuiNom d’hote du serveur web.
portNonPort sur lequel votre serveur web ecoute. La valeur par defaut est 80 pour form:// et 443 pour toutes les references forms://.
userNonSi votre systeme est configure pour utiliser HTTP-AUTH, vous pouvez fournir le username pour vous authentifier.
passwordNonSi votre systeme est configure pour utiliser HTTP-AUTH, vous pouvez fournir le password pour vous authentifier.
methodNonPermet facultativement de preciser la methode HTTP du serveur ; les options possibles sont post, put, get, delete, patch, head, update et options. Si aucune methode n’est precisee, post est utilise par defaut.
attach-asNonPermet facultativement de remplacer le nom meta du fichier lorsqu’il y a des pieces jointes. Par defaut, chaque piece jointe est publiee sous file01, file02, etc. Il existe des cas d’usage ou le point de terminaison distant attend un nom meta precis, c’est-a-dire le champ sous lequel le fichier apparait dans la requete HTTP, comme document. Utilisez cette surcharge pour obtenir ce comportement. Utilisez aussi le caractere * pour autoriser la numerotation. Ainsi ?attach-as=meta* donnera meta01, meta02, etc.

Remarque : si vous incluez des pieces jointes, elles sont toutes concatenees dans une seule publication vers le serveur amont. Dans ce cas, l’en-tete Content-Type passe aussi de application/x-www-form-urlencoded a multipart/form-data.

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 requete web FORM a notre serveur web a l’ecoute sur le port 80 :

Fenêtre de terminal
# Supposons que notre {hostname} soit my.server.local
apprise form://my.server.local

Par defaut, toutes les notifications sont envoyees en POST. Remplacez ce comportement avec le parametre d’URL method :

Fenêtre de terminal
# Envoyer comme requete PUT
apprise -vv -t "Titre du Message de Test" -b "Corps du Message de Test" \
"form://localhost/?method=put"
# Envoyer comme requete DELETE
apprise -vv -t "Titre du Message de Test" -b "Corps du Message de Test" \
"form://localhost/?method=delete"
# Envoyer comme requete PATCH
apprise -vv -t "Titre du Message de Test" -b "Corps du Message de Test" \
"form://localhost/?method=patch"

La liste complete des methodes prises en charge est : post, par defaut, get, put, delete, patch, head, update et options.

Remarque : lorsque method=get est utilise, les champs de charge utile du formulaire, version, title, message, type, sont ajoutes comme parametres de requete dans l’URL au lieu d’etre envoyes dans le corps de la requete. L’en-tete Content-Type n’est pas defini pour les requetes GET. Les pieces jointes ne sont pas compatibles avec GET.

L’utilisation de : dans l’URL Apprise vous permet de modifier et d’ajouter des champs au formulaire publie en amont vers un serveur distant.

Fenêtre de terminal
# Ajouter a la charge utile envoyee au serveur distant comme si cela
# faisait partie du message qu'Apprise aurait autrement prepare
#
# Supposons que notre {hostname} soit localhost
# Supposons que nous voulions inclure "sound=oceanwave" dans la charge utile existante :
apprise -vv -t "Titre du Message de Test" -b "Corps du Message de Test" \
"form://localhost/?:sound=oceanwave"

L’exemple ci-dessus effectuerait un POST avec les champs de formulaire suivants :

version=1.0
title=Titre du Message de Test
message=Corps du Message de Test
type=info
sound=oceanwave

Vous pouvez aussi supprimer les champs integres en definissant leur valeur comme vide :

Fenêtre de terminal
# Supprimer version et type de la charge utile :
# Supposons que notre {hostname} soit localhost
apprise -vv -t "Titre du Message de Test" -b "Corps du Message de Test" \
"form://localhost/?:version&:type"

L’exemple ci-dessus publierait :

title=Titre du Message de Test
message=Corps du Message de Test

Enfin, vous pouvez remapper un champ integre vers un nom de cle different :

Fenêtre de terminal
# Remapper le champ "message" vers "body" :
# Supposons que notre {hostname} soit localhost
apprise -vv -t "Titre du Message de Test" -b "Corps du Message de Test" \
"form://localhost/?:message=body"

L’exemple ci-dessus publierait :

version=1.0
title=Titre du Message de Test
body=Corps du Message de Test
type=info

Certains utilisateurs peuvent avoir besoin d’en-tetes HTTP speciaux lors de l’envoi de leurs donnees vers leur serveur. Pour cela, il suffit d’ajouter un symbole plus, +, devant n’importe quel parametre precise dans votre URL.

Fenêtre de terminal
# L'exemple ci-dessous definirait l'en-tete :
# X-Token: abcdefg
#
# Supposons que notre {hostname} soit localhost
# Supposons que notre {port} soit 8080
apprise -vv -t "Titre du Message de Test" -b "Corps du Message de Test" \
"form://localhost:8080/path/?+X-Token=abcdefg"
# Pour plusieurs en-tetes, il suffit d'ajouter plus d'entrees :
# L'exemple ci-dessous definirait les en-tetes :
# X-Token: abcdefg
# X-Apprise: is great
#
# Supposons que notre {hostname} soit localhost
# Supposons que notre {port} soit 8080
apprise -vv -t "Titre du Message de Test" -b "Corps du Message de Test" \
"form://localhost:8080/path/?+X-Token=abcdefg&+X-Apprise=is%20great"

Certains utilisateurs peuvent avoir besoin que des parametres GET fassent partie de leur POST. Tous les parametres que vous passez a la ligne de commande Apprise sont interpretes par Apprise lui-meme comme des options ou actions a executer, comme method=update ou cto=3. Pour qu’Apprise ignore ce qui a ete precise et transmette le contenu tel quel en amont, il suffit de prefixer vos entrees avec un symbole moins, -.

Fenêtre de terminal
# L'exemple ci-dessous publierait vers http://localhost:8000?token=abcdefg
#
# Le symbole `-` sera retire lors de l'envoi en amont
# Apprise sait qu'il ne doit pas traiter cet argument et qu'il doit le transmettre tel quel.
apprise -vv -t "Titre du Message de Test" -b "Corps du Message de Test" \
"form://localhost:8080/?-token=abcdefg"
# Si vous voulez transmettre plus d'un element, il suffit de les enchainer :
# L'exemple ci-dessous enverrait un POST vers :
# https://example.ca/my/path?key1=value1&key2=value2
#
apprise -vv -t "Titre du Message de Test" -b "Corps du Message de Test" \
"forms://example.ca/my/path?-key1=value1&-key2=value2"

Cette section detaille davantage l’option de surcharge ?attach-as=.

Ajoutez-la simplement a l’URL, par exemple :

Fenêtre de terminal
# appliquer la surcharge de `file{:02d}` vers `document`
bin/apprise -vvvv 'forms://webhook.site/<webhook>?attach-as=document' \
--attach test/var/apprise-test.png -b test

Pour prendre en charge d’autres variantes, vous pouvez faire :

Fenêtre de terminal
# Definir l'objet tableau de fichiers dans la requete comme `{:02d}meta`
bin/apprise -vvvv 'forms://webhook.site/<webhook>?attach-as=*meta' \
--attach test/var/apprise-test.png -b test
# Definir l'objet tableau de fichiers dans la requete comme `meta{:02d}`
bin/apprise -vvvv 'forms://webhook.site/<webhook>?attach-as=meta*' \
--attach test/var/apprise-test.png -b test
# Definir l'objet tableau de fichiers dans la requete comme `meta{:02d}file`
bin/apprise -vvvv 'forms://webhook.site/<webhook>?attach-as=meta*file' \
--attach test/var/apprise-test.png -b test
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