Aller au contenu

Notifications Fluxer

Aperçu

Fluxer utilise des webhooks pour publier des notifications.

Une URL de webhook ressemble à ceci :

https://api.fluxer.app/webhooks/417429632418316298/JHZ7lQml277CDHmQKMHI8qBe7bk2ZwO5UKjCiOAF7711o33MyqU344Qpgv7YTpadV

Ce qui correspond effectivement à : https://api.fluxer.app/webhooks/{WebhookID}/{WebhookToken}

La dernière partie de l’URL qui vous est fournie constitue les 2 jetons nécessaires pour envoyer des notifications. Pour l’exemple ci-dessus, les jetons sont les suivants :

  1. WebhookID est 417429632418316298
  2. WebhookToken est JHZ7lQml277CDHmQKMHI8qBe7bk2ZwO5UKjCiOAF7711o33MyqU344Qpgv7YTpadV

Fluxer prend en charge les mentions de style Discord. Vous pouvez les placer directement dans le corps du message :

  • user : <@123>
  • role : <@&456>
  • tag : @everyone ou @here

Vous pouvez également forcer des pings via le paramètre URL ping= (voir ci-dessous).

La syntaxe valide est la suivante :

  • https://api.fluxer.app/webhooks/{WebhookID}/{WebhookToken}
  • https://api.fluxer.app/v1/webhooks/{WebhookID}/{WebhookToken}
  • fluxer://{WebhookID}/{WebhookToken}/
  • fluxer://{botname}@{WebhookID}/{WebhookToken}/

Fluxer peut être utilisé dans deux modes :

  • mode=cloud (par défaut) : publie vers l’API Fluxer Cloud (https://api.fluxer.app)
  • mode=private : publie vers l’hôte que vous spécifiez dans l’URL

Lorsque mode=private est utilisé, un hôte est requis :

  • fluxer://{host}/{WebhookID}/{WebhookToken}/?mode=private
  • fluxer://{host}:{port}/{WebhookID}/{WebhookToken}/?mode=private

Si mode=private est sélectionné mais que l’hôte contient fluxer.app, Apprise repassera automatiquement en mode=cloud.

VariableRequisDescription
WebhookIDOuiLa première partie des 2 jetons fournis lors de la création d’un webhook entrant
WebhookTokenOuiLa seconde partie des 2 jetons fournis lors de la création d’un webhook entrant
botnameNonIndique le nom du robot qui doit émettre le message
hostNonNom d’hôte de votre serveur Fluxer privé (utilisé avec mode=private)
portNonPort de votre serveur Fluxer privé (utilisé avec mode=private)
modeNonL’une des valeurs suivantes : cloud (par défaut) ou private
ttsNonActiver la synthèse vocale (Text-To-Speech) (par défaut Non)
avatarNonRemplacer l’icône d’avatar par défaut par une icône identifiant le type de notification (par défaut Oui)
avatar_urlNonRemplacer l’URL de l’icône d’avatar. Si non défini, Apprise choisit dynamiquement une URL en fonction du type de message
footerNonInclure une section pied de page dans l’intégration (par défaut Non)
footer_logoNonInclure le logo de pied de page Fluxer lorsque footer=yes (par défaut Oui)
imageNonInclure une image en ligne avec le message décrivant le type de notification (par défaut Non)
fieldsNonUtiliser des champs intégrés lors de la publication au format markdown (par défaut Oui)
formatNonLa valeur par défaut est text. Définir sur markdown pour activer l’analyse markdown vers intégration (les en-têtes sont convertis en intégrations)
hrefNonIdentifier une URL vers laquelle le titre doit pointer lors de la publication. Vous pouvez également utiliser url= comme alias
threadNonDéfinir éventuellement le thread_id auquel vous souhaitez que votre message soit appliqué
thread_nameNonDéfinir éventuellement le nom du fil de discussion lors de l’utilisation de thread=
pingNonUne liste séparée par des virgules d’utilisateurs, de rôles ou de jetons tels que everyone qui doivent toujours être mentionnés
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.
redirectPar défaut, Apprise suit les redirections HTTP (réponses 3xx) émises par le serveur distant, conformément au comportement de la bibliothèque requests sous-jacente. Si vous souhaitez empêcher la transmission des en-têtes personnalisés et des identifiants vers des destinations différentes de l’URL d’origine, définissez cette option sur no. Par défaut, elle 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.
retryNombre de tentatives de remise supplémentaires après le premier échec, avant d’abandonner. Accepte un entier compris entre 0 et 10. La valeur par défaut est 0 (aucune nouvelle tentative — une seule tentative est effectuée). Lorsqu’il est combiné avec wait, Apprise marque une pause du nombre de secondes spécifié entre chaque tentative.
waitNombre de secondes à attendre entre les nouvelles tentatives. Accepte une valeur décimale comprise entre 0.0 et 20.0 ; les entiers sont automatiquement convertis en virgule flottante. La valeur par défaut est 0.5. Ce paramètre n’est utile que si retry est supérieur à zéro — un service avec retry=0 effectue exactement une tentative, quelle que soit la valeur de wait.
optionalLorsqu’il est défini sur yes, un échec de remise pour ce service est silencieusement absorbé. L’appel global notify() retourne quand même True même si ce point de terminaison était injoignable, à condition que tous les services requis (non optionnels) du même lot aient réussi. Ce drapeau ne saute pas la remise ni ne contourne la logique de nouvelles tentatives — toutes les tentatives configurées sont effectuées avant que l’échec soit absorbé. Par défaut, il vaut no, ce qui signifie que chaque échec est propagé à l’appelant.

Envoyer une notification Fluxer :

Fenêtre de terminal
# Assuming our {WebhookID} is 417429632418316298
# Assuming our {WebhookToken} is JHZ7lQml277CDHmQKMHI8qBe7bk2ZwO5UKjCiOAF7711o33MyqU344Qpgv7YTpadV
apprise -vv -t "Titre du Message de Test" -b "Corps du Message de Test" \
"fluxer://417429632418316298/JHZ7lQml277CDHmQKMHI8qBe7bk2ZwO5UKjCiOAF7711o33MyqU344Qpgv7YTpadV"

Envoyer une notification en utilisant le formatage markdown vers intégration :

Fenêtre de terminal
# Assuming our {WebhookID} is 417429632418316298
# Assuming our {WebhookToken} is JHZ7lQml277CDHmQKMHI8qBe7bk2ZwO5UKjCiOAF7711o33MyqU344Qpgv7YTpadV
cat << _EOF | apprise -vv \
"fluxer://417429632418316298/JHZ7lQml277CDHmQKMHI8qBe7bk2ZwO5UKjCiOAF7711o33MyqU344Qpgv7YTpadV?format=markdown"
# Title
- Bullet 1
- Bullet 2
- Bullet 3
_EOF

Envoyer une pièce jointe :

Fenêtre de terminal
# Assuming our {WebhookID} is 417429632418316298
# Assuming our {WebhookToken} is JHZ7lQml277CDHmQKMHI8qBe7bk2ZwO5UKjCiOAF7711o3dV_js
apprise -vv -b "Here is a file" \
--attach=/path/to/file.png \
"fluxer://417429632418316298/JHZ7lQml277CDHmQKMHI8qBe7bk2ZwO5UKjCiOAF7711o33MyqU344Qpgv7YTpadV"

Publier vers un serveur Fluxer privé :

Fenêtre de terminal
# Assuming your private server is https://fluxer.example.com
# Assuming our {WebhookID} is 417429632418316298
# Assuming our {WebhookToken} is JHZ7lQml277CDHmQKMHI8qBe7bk2ZwO5UKjCiOAF7711o33MyqU344Qpgv7YTpadV
apprise -vv -b "Private server test" \
"fluxer://fluxer.example.com/417429632418316298/JHZ7lQml277CDHmQKMHI8qBe7bk2ZwO5UKjCiOAF7711o33MyqU344Qpgv7YTpadV?mode=private"
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