1000 FAQ, 500 Anleitungen und Lernvideos. Hier gibt es nur Lösungen!
Externe Anwendungen mit kChat verbinden
Dieser Leitfaden zeigt Ihnen, wie Sie externe Anwendungen mit kChat mithilfe von Webhooks verwalten.
Vorwort
- Ein Webhook ist eine Methode, die es einer Anwendung ermöglicht, sofort benachrichtigt zu werden, wenn ein bestimmtes Ereignis in einer anderen Anwendung auftritt, anstatt diese Anwendung ständig zu fragen, ob etwas Neues passiert ist (was als "Polling" bezeichnet wird).
- Ausgehender Webhook: kChat ĂĽbermittelt Informationen an andere Apps, wenn ein Ereignis in kChat auftritt.
- Eingehender Webhook: kChat empfängt Informationen von anderen Apps, um Aktionen in kChat auszulösen.
- Es ist nicht möglich, den Chatverlauf aus einer anderen Anwendung (Slack, Teams, Jabber usw.) oder aus einer anderen Organisation zu importieren.
Auf die kChat-Webhook-Schnittstelle zugreifen
Voraussetzungen
- Kein externer Benutzer sein (dieser sieht das MenĂĽ nicht Integrationen).
Um einen Webhook zu konfigurieren, finden Sie Anwendungen und selbstgehostete oder Drittanbieter-Integrationen:
- Hier klicken‍ um auf die Web-App kChat (Online-Dienst ksuite.infomaniak.com/kchat) zuzugreifen, oder öffnen Sie die Desktop-App kChat (Desktop-Anwendung auf macOS / Windows / Linux).
- Klicken Sie auf das Symbol Neu ‍ neben dem Namen Ihrer kChat-Organisation.
- Klicken Sie auf Integrationen.
- Navigieren Sie zu den Kategorien:
Beispiel fĂĽr eine Integration
Einen einfachen eingehenden Webhook erstellen
DafĂĽr:
- Klicken Sie auf die Kategorie Eingehende Webhooks.
- Klicken Sie auf die blaue Schaltfläche Eingehende Webhooks hinzufügen:
- FĂĽgen Sie einen Namen und eine Beschreibung (max. 500 Zeichen) fĂĽr den Webhook hinzu.
- Wählen Sie den Kanal aus, der die Nachrichten erhält.
- Speichern Sie, um die URL (nicht öffentlich weitergeben) zu erhalten; Beispiel: „
https://your-server-kchat.xyz/hooks/xxx-key-generated-xxx
“.
Verwendung des Webhooks
In der Anwendung, die auf kChat posten soll:
Passen Sie den folgenden Code entsprechend der erhaltenen URL an:
POST /hooks/xxx-key-generated-xxx HTTP/1.1 Host: your-server-kchat.xyz Content-Type: application/json Content-Length: 63 { "text": "Hello, text1 Text2." }
Verwenden Sie gegebenenfalls dieselbe Anfrage, aber mit
curl
(zum Testen aus einer Anwendung vom TypTerminal
(Kommandoschnittstelle,CLI / Command Line Interface
) auf Ihrem Gerät):curl -i -X POST -H 'Content-Type: application/json' -d '{"text": "Hello, text1 Text2."}' https://your-server-kchat.xyz/hooks/xxx-key-generated-xxx
Wenn kein Header Content-Type
definiert ist, muss der Anfragekörper mit payload=
beginnen, wie folgt:
payload={"text": "Hello, text1
Text2."}
Eine erfolgreiche Anfrage erhält die folgende Antwort:
HTTP/1.1 200 OK
Content-Type: application/json
X-Version-Id: 4.7.1.dev.12799dvd77e172e8a2eba0f4041ec1471.false
Date: Sun, 01 Jun 2023 17:00:00 GMT
Content-Length: 58
{
"id":"x",
"create_at":1713198308869,
"update_at":1713198308869,
"delete_at":0,
"user_id":"x",
"channel_id":"x",
"root_id":"",
"original_id":"",
"participants":null,
"message":"test",
"type":"",
"props":{
"override_username":"webhook",
"override_icon_url":null,
"override_icon_emoji":null,
"webhook_display_name":"test",
"attachments":[
],
"card":null,
"from_webhook":"true"
},
"hashtags":null,
"metadata":{
"embeds":[
{
"type":"message_attachment"
}
],
"files":[
],
"reactions":[
]
},
"file_ids":null,
"has_reactions":false,
"edit_at":0,
"is_pinned":false,
"remote_id":null,
"reply_count":0,
"pending_post_id":null,
"is_following":false
}
Wenn Sie dasselbe Antwortformat wie Slack haben möchten:
HTTP/1.1 200 OK
Content-Type: text/plain
X-Request-Id: hoan69ws7rp5xj7wu9rmystry
X-Version-Id: 4.7.1.dev.12799dvd77e172e8a2eba0f4041ec1471.false
Date: Sun, 01 Jun 2023 17:00:00 GMT
Content-Length: 2
ok
mĂĽssen Sie ?slack_return_format=true
zur Webhook-URL hinzufĂĽgen.
Der Hinweis BOT wird aus SicherheitsgrĂĽnden neben dem Benutzernamen in kChat hinzugefĂĽgt.
Einstellungen
Neben dem Feld text
finden Sie hier die vollständige Liste der unterstützten Parameter:
Parameter | Beschreibung | Erforderlich |
---|---|---|
text | Nachricht im Markdown-Format, die im Beitrag angezeigt werden soll. Um Benachrichtigungen auszulösen, verwenden Sie „@<Benutzername>“, „@Kanal“ und „@hier“ wie in anderen kChat-Nachrichten. | Wenn attachments nicht definiert ist, ja |
channel | Ersetzt den Kanal, in dem die Nachricht gepostet wird. Verwenden Sie den Kanalnamen, nicht den Anzeigenamen, verwenden Sie z. B. „town-square“, nicht „Place de la ville“. Verwenden Sie „@“ gefolgt von einem Benutzernamen, um eine Direktnachricht zu senden. Standardmäßig wird der beim Erstellen des Webhooks festgelegte Kanal verwendet. Der Webhook kann in jedem öffentlichen und privaten Kanal posten, in dem sich der Ersteller des Webhooks befindet. Beiträge in Direktnachrichten erscheinen in der Direktnachricht zwischen dem Zielbenutzer und dem Ersteller des Webhooks. | Nein |
username | Ersetze den Benutzernamen, unter dem die Nachricht gepostet wird. Standardmäßig wird der beim Erstellen des Webhooks festgelegte Benutzername verwendet; wenn beim Erstellen kein Benutzername festgelegt wurde, wird webhook . | Nein |
icon_url | Ersetze das Profilbild, mit dem die Nachricht gepostet wird. Standardmäßig wird die beim Erstellen des Webhooks festgelegte URL verwendet; wenn beim Erstellen kein Icon festgelegt wurde, wird das Standard-Webhook-Icon (‍) angezeigt. Der Konfigurationsparameter Erlaube Integrationen, Profilbild-Icons zu ersetzen muss aktiviert sein, damit das Ersetzen des Icons wirksam wird. | Nein |
icon_emoji | Ersetze das Profilbild und den Parameter icon_url .Standardmäßig wird beim Erstellen des Webhooks nichts festgelegt. Der erwartete Wert ist der Name eines Emojis, wie er in einer Nachricht eingegeben wird, mit oder ohne Doppelpunkte ( : ).Der Konfigurationsparameter Erlaube Integrationen, Profilbild-Icons zu ersetzen muss aktiviert sein, damit das Ersetzen wirksam wird. | Nein |
attachments | Anlagen im Nachricht verwendet fĂĽr reichhaltigere Formatierungsoptionen. | Wenn text nicht definiert ist, ja |
type | Definiert das type Veröffentlichungsdatum, hauptsächlich für die Verwendung durch Plugins.Wenn es nicht leer ist, muss es mit " beginnen custom_ ". | Nein |
Codebeispiel mit Parametern
Hier ist, wie Sie eine umfassendere Nachricht mit Parametern generieren, einige können bereits beim Erstellen des Webhooks festgelegte Parameter (Benutzername, bevorzugter Kanal, Avatar ...) ersetzen, wie in der obigen Tabelle angegeben:
POST /hooks/xxx-clé-générée-xxx HTTP/1.1
Host: votre-serveur-kchat.xyz
Content-Type: application/json
Content-Length: 630
{
"channel": "kchatemp",
"username": "test-automation",
"icon_url": "https://domain.xyz/wp-content/uploads/2023/06/icon.png",
"text": "#### Résultats des tests pour le 27 juillet 2023
@channel veuillez vérifier les tests échoués.
| Composant | Tests effectués | Tests échoués |
|:-----------|:-----------:|:-----------------------------------------------|
| Serveur | 948 | 0 |
| Client Web | 123 | 2 [(voir détails)](https://linktologs) |
| Client iOS | 78 | 3 [(voir détails)](https://linktologs) |"
}
Dies fĂĽhrt dazu, dass diese Nachricht im Kanal kchatemp der Organisation angezeigt wird: