1000 FAQs, 500 tutorials and explanatory videos. Here, there are only solutions!
Connect external applications to kChat
This guide allows you to manage external applications with kChat using webhooks.
Preamble
- A webhook is a method that allows an application to be immediately informed when a particular event occurs in another application, rather than constantly asking this application if something new has happened ("polling").
- Outgoing webhook: kChat communicates information to other apps when an event occurs in kChat.
- Incoming webhook: kChat receives information from other apps to trigger actions in kChat.
- It is not possible to import the chat history from another application (Slack, Teams, Jabber, etc.) or from another Organization.
âš Max. number of incoming/outgoing webhooks:
| kSuite | free | 1 / 1 |
| Standard | 20 / 20 | |
| Business | unlimited | |
| Enterprise | unlimited | |
Access the kChat webhooks interface
Prerequisites
- Not being an external user (this user will not see the menu Integrations).
To configure a webhook, find self-hosted or third-party applications and integrations:
- Click here‍‍ to access the Web app kChat (online service ksuite.infomaniak.com/kchat) or open the desktop app kChat (desktop application on macOS / Windows / Linux).
- Click on the New icon ‍ next to your kChat organization's name.
- Click on Integrations:

- Access the categories:

Specific guides
Integration examples on kChat:
- Calendar Infomaniak: display an event reminder on kChat
- application n8n: trigger sending a message on kChat
Guides for any other use
To create an incoming webhook (to display an external event on kChat):
- Click on the Incoming Webhooks category.
- Click on the blue button Add incoming webhooks:

- Add a name and description for the webhook.
- Select the channel that will receive the messages.
- Click on the button to Save:

- The URL to keep for your developments is displayed (do not disclose it publicly); example “
https://your-server-kchat.xyz/hooks/xxx-key-generated-xxx”:
Webhook usage
Quick example
- A specific
curlcommand (detailed below) is entered in a terminal. - The command contains the URL obtained in point 6 above.
- The command will result in posting a message in the channel specified in point 4 above:

Details
On the application that needs to post on kChat:
Adjust the code below according to the URL obtained on kChat:
POST /hooks/xxx-key-generated-xxx HTTP/1.1 Host: your-server-kchat.xyz Content-Type: application/json Content-Length: 63 { "text": "Hello, text1\nText2." }Optionally, use the same request but in
curl(to test from aTerminaltype application (command line interface,CLI / Command Line Interface) on your device) as in the image example above:curl -i -X POST -H 'Content-Type: application/json' -d '{"text": "Hello, text1\nText2."}' https://your-server-kchat.xyz/hooks/xxx-key-generated-xxx
The BOT indication is added next to the username on kChat for security reasons.
If no Content-Type header is defined, the request body must be preceded by payload= as follows:
payload={"text": "Hello, text1\nText2."}A successful request will receive the following response:
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
}If you want to have the same response format as Slack:
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
okyou must add ?slack_return_format=true to the webhook URL.
Parameters
In addition to the text field, here is the complete list of supported parameters:
| Parameter | Description | Required |
|---|---|---|
text | Markdown-formatted message to display in the post. To trigger notifications, use “@<username>”, “@channel” and “@here” as you would in other kChat messages. | If attachments is not defined, yes |
channel | Replaces the channel in which the message is posted. Use the channel name, not the display name, for example “town-square”, not “Place de la ville”. Use “@” followed by a username to send a direct message. By default, uses the channel defined when the webhook was created. The webhook can post in any public and private channel where the webhook creator is present. Posts in direct messages will appear in the direct message between the targeted user and the webhook creator. | No |
username | Replaces the username under which the message is posted. By default, uses the username defined when the webhook was created; if no username was defined during creation, uses webhook. | No |
icon_url | Replaces the profile picture with which the message is posted. By default, uses the URL defined when the webhook was created; if no icon was defined during creation, the standard webhook icon (‍) is displayed. The configuration parameter Allow integrations to replace profile picture icons must be enabled for the icon replacement to take effect. | No |
icon_emoji | Replaces the profile picture and the parameter icon_url.By default, nothing is defined when creating the webhook. The expected value is the name of an emoji as it is typed in a message, with or without colons ( :).The configuration parameter Allow integrations to replace profile picture icons must be enabled for the replacement to take effect. | No |
attachments | Attachments to the message used for richer formatting options. | If text is not defined, yes |
type | Defines the type of publication, mainly for use by plugins.If not empty, must start with " custom_". | No |
Example code with parameters
Here is how to generate a more complete message with parameters, some of which can replace parameters already set when creating the webhook (username, preferred channel, avatar...) as indicated in the table above:
curl -i -X POST -H 'Content-Type: application/json' \
-d '{
"username": "System Monitor",
"icon_url": "https://cdn-icons-png.flaticon.com/512/5971/5971593.png",
"text": "### System Status Report\nEnvironment: PRODUCTION\nStatus: SUCCESSFUL\n\n---\n\n| Component | Version | Build ID | Status |\n|:----------|:-------:|:---------|:-------|\n| API-Core | 2.4.1 | #88421 | OK |\n| Web-UI | 1.9.0 | #88425 | OK |\n| Database | 14.5 | N/A | OK |\n\n---\n\n**Commit Reference:**\n`git-ref: a7f8e9c21b` \n\n**Summary:**\nAll automated integration tests passed successfully. No manual intervention is required. Please contact the DevOps team for further details regarding this release."
}' \
https://faq-infomaniakaruh.kchat.infomaniak.com/hooks/019c23e9-a9a8-735c-b6ce-0a69df63aaf0Result of a similar example in image: