Bringing webhooks into Telegram. Push messages to chats via URL with a simple API
Webhooks over Telegram (WoT)
WoT aims to provide a simple API for registering webhooks and sending messages to Telegram chats via them
using a single secret URL.
Just like in Discord or Slack. You simply POST
a message to chats:
Features
- Easy-to-use RESTful API
- Simple authorization
- Simple subscribing and unsubscribing process
- Multiple webhooks support
- Formatting support
- Attachments support (WIP)
- Multiplatform Kotlin SDK for WoT (WIP)
- Automatic payload mapping from other services (WIP)
- Supervisor Bot that simplifies interactions with the API (WIP)
Running
To run the server you should have Java 17+ and Docker Compose installed.
Build the image:
./gradlew wot-server:bootBuildImage
Edit the docker-compose.yml
file and configure the secret key used for authorization:
# ./wot-server/docker/docker-compose.yml
# ...
services:
# ...
wot-server:
# ...
environment:
# ...
SIMPLE_SECURITY_AUTHENTICATION_SECRET: my_secret_key
# ...
# ...
# ...
# ...
Run the containers:
docker-compose -f ./wot-server/docker/docker-compose.yml up -d
Usage
Let’s start with creating a webhook:
POST http://localhost:9696/api/webhooks
Content-Type: application/json
Authorization: ...
{
"name": "my-webhook",
"botToken": "your bot token",
"private": true,
"targets": []
}
Now open the Telegram bot with which the webhook is bound and send /subscribe
.
Since this webhook is marked as private
, we have to send its nonce which we got in the response.
Well, let’s send a message now:
POST http://localhost:9696/<webhook nonce>
Content-Type: application/json
{
"content": {
"sources": [
{
"type": "REGULAR",
"value": "Hello, world!",
"subsources": []
}
]
}
}
Authorization
Each request to /api/**
path must include a secret key within the Authorization
header.
See Running for more info.
SDKs
- wot-client: WoT API client for Kotlin Multiplatform. Currently, WIP.
License
Copyright 2022 Webhooks over Telegram project contributors
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
https://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.