Telegram media bot

Clippy workflow Cargo workflow Formatting workflow

Telegram bot written in rust for aliasing different media (currently only stickers are supported).

How it works

Initially, no aliases are specified. They can be added using /add command, which starts an addition process:

add_demo

After that, you can use specified aliases enclosed in colons in your messages. The bot will send the associated media to the chat:

replacing_demo

Usage

The bot is (hopefully still) running at http://t.me/textmedia_bot. * Add it to a chat (or start a conversation in PM) * (If using in chat) Give admin rights if you wish all messages in the chat to be seen. * Use it according to /start and /help

How to run it by yourself

Requirements

Older versions may work, however they were not tested.

Launching

You can use cargo install or manually clone into repository then either install on a machine or build and run in the folder.

Using cargo install

Arguments

There is one optional argument - Redis address. You should specify only the address itself, without redis:// prefix.

Usage example: tg-media-bot 127.0.0.1

Bugs/problems

If any bugs related to the code were found, create an issue with its description.

Planned work/features

Kind of sorted according to importance (higher - more preferable) * more automatic deployment * add proper (unit) tests * add support for any media * inline search * more elegant way to handle common commands * marking symbol specification (colons may cause conflict) however can be avoided right now by not giving admin rights to the bot, so it does not see all the messages * resolve TODOs (not critical, just better practices)