Telegram Bot API Webhooks Framework, for Rubyists.
BOTServer configures, tests and deploys bots, running a fast rack server for webhooks routing.
Details about Telegram Bot API long polling vs webhooks: Telegram Bot Platform
There are at least three Telegram Bot Ruby clients (as far as I know), here listed Telegram BOT Ruby clients:
- https://github.com/atipugin/telegram-bot-ruby
- https://github.com/eljojo/telegram_bot
- https://github.com/shouya/telegram-bot
NOTE: All of them implement Telegram Bot API long polling way, with
getUpdates
endpoint. No one of these gems implement the webhooks mode.
-
Webhooks vs long polling
BOTServer first goal is to set-up a Ruby way to manage Telegram Bot API webhooks
Updates
, a performance improvement in comparison with HTTPS long polling mode.This project is related to telegram-bot-ruby gem, Alexander Tipugin's excellent Telegram Bot client APIs wrapper; to thank him for his work, I tried to solve issue #19: setting up webhooks with telegram-bot-ruby ?. BOTServer closed the issue :)
-
Multiple bots webhooks updates routing
Receiving HTTPS webhooks callbacks is probably more efficient than getting updates on a long polling connection, but the real need of webhooks is when you have dozen, hundreds of bots to manage at once with your server. In this scenario, it could pretty impossible to manage in a single host, using long polling connections, because the need to maintain open too many Ruby processes/ HTTPS (persistent) connections.
** BOTServer is a toolkit to test and deploy Bot tokens to receive webhooks with a very simple dynamic routing server: a rack server that dispatch dinamically incoming token webhooks, calling update method of an instance of a class generated with a template sckeleton, that define the bot. Details: Telegram Bot Architecture(s)**
TELEGRAM Bot API Server
--------------------------------------------------------------------
v v v ^ ^ ^
| | | | | |
| | | SSL/HTTPS | | |
| | | front-end BOTServer | | |
| | | +-------+ Rack router | | |
| | | | | +------+ | | |
| | | | | | | +-------+ HTTPS send | | |
| | | | | | |---->| App 1 |-------------+ | |
| | | | | HTTP | | +-------+ | |
| | | | | POST | | | |
| | +--->| |------>| | +-------+ HTTPS send | |
| +----->| |------>| |---->| App 2 |---------------+ |
+------->| |------>| | +-------+ |
webhooks | | | | |
HTTPS POST | | | | +-------+ HTTPS send |
| | | |---->| App |-----------------+
| | | Thin | +-------+
| NGINX | +------+
+-------+
BOTServer is a devops utility to:
- set-up and test tokens/webhooks
- generate a template app for each bot
- run a webhooks router/server.
Here assembly instruction steps:
- Installation (web/proxy server, Ruby project code)
- Get Telegram Bot token(s)
- Update configuration files
- Create (self-signed) Certificate
- Configure "Webhooks mode" for each token
- Generate template for each bot
- Deploy and run _BOTServer
Keep calm and follow step by step instrctions: Assembly instructions in 7 steps
After installation of the project, just run rake
from your project home:
$ rake
rake app:new[token] # Create bot app template for given token
rake certificate:new # Create SSL certificate
rake certificate:show # Show public certificate
rake proxy:config:new # Generate nginx proxy SSL configuration from server.yml data
rake proxy:restart # Restart proxy server
rake proxy:start # Start proxy server
rake proxy:stop # Stop proxy server
rake server:config:show # Show server configuration: /home/solyaris/BOTServer/config/server.yml
rake server:config:test # Check server configuration: /home/solyaris/BOTServer/config/server.yml
rake server:log # Tail -f rack sever logfile: /home/solyaris/BOTServer/log/thin.log
rake server:pid # Show rack server pid
rake server:restart # Restart rack server
rake server:start # Start rack server
rake server:stop # Stop rack server
rake tokens:show # Show tokens configuration file: /home/solyaris/BOTServer/config/tokens.yml
rake tokens:test # Verify if tokens are valid, online querying Telegram Server
rake webhook:reset[token] # Reset webhook for a given token
rake webhook:set[token] # Set webhook for a given token