Notifications Microsoft Teams
Configuration du compte
Section intitulée « Configuration du compte »Créez un compte gratuit sur https://teams.microsoft.com.
Vous devrez créer un Incoming Webhook pour relier Apprise. Cela peut se faire via le magasin d’applications en bas à gauche de l’interface de type Slack ; ne vous inquiétez pas, c’est gratuit. Depuis ce magasin, recherchez Incoming Webhook. Une fois sélectionné, vous pourrez l’associer à votre équipe, lui attribuer un nom et un avatar, puis le rattacher à un canal.
Vous pouvez aussi ouvrir le canal où vous souhaitez ajouter le webhook, cliquer sur l’icône ••• (More options) dans la barre de navigation supérieure, rechercher Incoming Webhook, puis sélectionner Add.
Une fois cette étape terminée, une URL ressemblant à ceci sera générée :
https://team-name.office.com/webhook/ \ abcdefgf8-2f4b-4eca-8f61-225c83db1967@abcdefg2-5a99-4849-8efc-\ c9e78d28e57d/IncomingWebhook/291289f63a8abd3593e834af4d79f9fe/\ a2329f43-0ffb-46ab-948b-c9abdad9d643Oui, l’URL est effectivement aussi longue… mais au final cela correspond à :
https://{team}.office.com/webhook/{tokenA}/IncomingWebhook/{tokenB}/{tokenC}
Ainsi, le nom de l’équipe se trouve dans le webhook généré, qui ressemble à ceci :
# https://TEAM-NAME.office.com/webhook/ABCD/IncomingWebhook/DEFG/HIJK# ^ ^ ^ ^# | | | |# Ces éléments sont importants <--------^--------------------^----^Par comparaison, l’ancienne URL ressemblait à ceci, avec outlook comme nom d’équipe fixe :
# https://outlook.office.com/webhook/ABCD/IncomingWebhook/DEFG/HIJK# ^ ^ ^ ^# | | | |# ancienne reference d'equipe : 'outlook' | | |# | | |# Ces éléments sont importants <------^--------------------^----^Comme vous pouvez le voir, nous avons 3 jetons distincts. Ce sont eux qui vous servent à construire votre URL Apprise. Dans l’exemple ci-dessus, les jetons sont les suivants :
- TokenA est
ABCD@WXYZ - TokenB est
DEFG - TokenC est
HIJK
Remarque : Apprise prend en charge cette URL telle quelle (depuis la version 0.7.7). Vous n’avez donc plus besoin de la reparser davantage. Il y a toutefois un léger surcoût interne si vous l’utilisez de cette manière.
La syntaxe valide est la suivante :
https://team-name.office.com/webhook/{tokenA}/IncomingWebhook/{tokenB}/{tokenC}msteams://{team}/{tokenA}/{tokenB}/{tokenC}/
L’ancien format est lui aussi toujours pris en charge. L’URL ci-dessous définirait automatiquement le nom d’équipe à outlook :
msteams://{tokenA}/{tokenB}/{tokenC}/
Détail des Paramètres
Section intitulée « Détail des Paramètres »| Variable | Requis | Description |
|---|---|---|
| team | Oui | Extrait de l’incoming-webhook. |
| tokenA | Oui | La première partie des 3 jetons fournis après la création d’un incoming-webhook. |
| tokenB | Oui | La deuxième partie des 3 jetons fournis après la création d’un incoming-webhook. |
| tokenC | Oui | La dernière partie des 3 jetons fournis après la création d’un incoming-webhook. |
| template | Non | Permet de pointer vers votre propre MessageCard Microsoft Teams au format JSON ; voir ici les détails du format. |
Paramètres Globaux
Section intitulée « Paramètres Globaux »| Variable | Description |
|---|---|
| overflow | Ce 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. |
| format | Ce 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é. |
| verify | Les 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. |
| cto | Signifie 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. |
| rto | Signifie 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. |
| emojis | Active 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. |
| tz | Identifie 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. |
Exemples
Section intitulée « Exemples »Envoyer une notification Microsoft Teams :
# Supposons que notre {team} soit Apprise# Supposons que notre {tokenA} soit T1JJ3T3L2@DEFK543# Supposons que notre {tokenB} soit A1BRTD4JD# Supposons que notre {tokenC} soit TIiajkdnlazkcOXrIdevi7Fapprise -vv -t "Titre du Message de Test" -b "Corps du Message de Test" \ msteams:///Apprise/T1JJ3T3L2@DEFK543/A1BRTD4JD/TIiajkdnlazkcOXrIdevi7F/L’Argument d’URL template
Section intitulée « L’Argument d’URL template »Définissez un argument ?template= pointant vers une MessageCard prédéfinie que vous avez déjà préparée pour Microsoft Teams. Le paramètre template peut viser un fichier local ou une URL web. Son contenu doit être du JSON, faute de quoi une erreur sera levée lors du traitement. Au minimum, il doit respecter la structure suivante :
{ "@type": "MessageCard", "@context": "https://schema.org/extensions"}Les Jetons de Modèle
Section intitulée « Les Jetons de Modèle »Le template= vers lequel vous pointez peut soit être déjà entièrement rempli et prêt à être envoyé au serveur de discussion MSTeams, soit être alimenté dynamiquement à chaque appel Apprise. Pour cela, utilisez des doubles accolades {{ et }} autour d’un mot-clé de votre choix, comme dans l’exemple ci-dessous :
{ "@type": "MessageCard", "@context": "https://schema.org/extensions", "summary": "{{app_id}}", "sections": [ { "activityImage": "{{app_image_url}}", "activityTitle": "{{app_title}}", "text": "Hello {{ target }}, how are you {{ whence }}?" } ]}Dans l’exemple ci-dessus, nous introduisons plusieurs jetons : app_id, app_title, target et whence. Certaines entrées seront TOUJOURS définies et ne peuvent pas être surchargées :
- app_id : l’identifiant de l’application, généralement défini à
Apprise, même si un développeur peut le surcharger. - app_desc : la description de l’application, souvent une variante un peu plus explicite de
app_id. Elle vaut en généralApprise Notificationsauf surcharge. - app_color : un code hexadécimal représentant la couleur associée au message. Par exemple, les messages
infosont généralement bleus tandis que les messageswarningsont orange. - app_type : le type du message lui-même, par exemple
info,warning,success, etc. - app_title : le titre réel transmis à la notification Apprise (
--titleou-ten ligne de commande). - app_body : le corps réel transmis à la notification Apprise (
--bodyou-ben ligne de commande). - app_image_url : l’URL d’image associée au type de message (
info,warning, etc.) si elle existe et si elle n’a pas été désactivée dans l’URL (image=no). - app_url : l’URL associée à l’instance Apprise, trouvée dans l’objet AppriseAsset(). Sauf surcharge explicite, sa valeur est
https://github.com/caronc/apprise.
Tout ce que vous inventez en dehors de cela vous appartient. Revenons donc à target et whence. Les jetons de template peuvent être définis dynamiquement en utilisant l’opérateur : devant tout argument d’URL que vous choisissez. Par exemple :
msteams://credentials/?template=/path/to/template.json&:target=Chris&:whence=this%20afternoonmsteams://credentials/?template=http://host/to/template.json&:target=Chris&:whence=this%20afternoon
Une notification comme celle-ci :
# En utilisant des deux-points, nous pouvons definir dynamiquement# target et whence depuis la ligne de commande :apprise -t "Mon Titre" -b "Ceci est Ignore" \ "msteams://credentials/?template=http://host/to/template.json&:target=Chris&:whence=this%20afternoon"Publierait dans MSTeams, sur la base du template ci-dessus :
{ "@type": "MessageCard", "@context": "https://schema.org/extensions", "summary": "Apprise", "sections": [ { "activityImage": null, "activityTitle": "Mon Titre", "text": "Bonjour Chris, comment allez-vous cet apres-midi ?" } ]}Le template Apprise par défaut à ce jour ressemble à ceci :
# Prepare our payloadpayload = { "@type": "MessageCard", "@context": "https://schema.org/extensions", "summary": "{{app_desc}}", "themeColor": "{{app_color}}", "sections": [ { "activityImage": null, "activityTitle": "{{app_title}}", "text": "{{app_body}}" } ]}Autres Exemples de Modèle
Section intitulée « Autres Exemples de Modèle »{ "@type": "MessageCard", "@context": "https://schema.org/extensions", "summary": "{{app_desc}}", "themeColor": "{{app_color}}", "sections": [ { "activityImage": null, "activityTitle": "{{app_title}}", "text": "{{app_body}}" } ], "potentialAction": [ { "@type": "ActionCard", "name": "Add a comment", "inputs": [ { "@type": "TextInput", "id": "comment", "isMultiline": false, "title": "Add a comment here for this task" } ], "actions": [ { "@type": "HttpPOST", "name": "Add comment", "target": "{{ target }}" } ] } ]}Remarques Supplémentaires sur les Modèles
Section intitulée « Remarques Supplémentaires sur les Modèles »- Les jetons peuvent contenir des espaces autour d’eux pour améliorer la lisibilité. Ainsi,
{{ token }}n’est pas différent de{{token}}. - Tous les jetons sont correctement échappés ; ne vous inquiétez donc pas si une valeur contient un guillemet double (
"), il sera correctement échappé avant l’envoi en amont. - Les jetons sont sensibles à la casse. Ainsi,
{{Token}}doit être alimenté par une valeur:Token=dans votre URL. - Les jetons qui ne correspondent à rien ne sont tout simplement pas remplacés, et
{{keyword}}restera tel quel dans le message. - Apprise exige toujours au minimum un
--body(-b), qui peut éventuellement être référencé en tant que{{app_body}}dans votre template. Même si vous ne l’utilisez pas, vous devez quand même fournir quelque chose pour satisfaire cette exigence et tirer parti des appels de template.
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 :