24 releases

1.0.0-alpha.24 Dec 31, 2024
1.0.0-alpha.22 Nov 1, 2024
1.0.0-alpha.20 Jul 13, 2024
1.0.0-alpha.16 Feb 29, 2024
1.0.0-alpha.3 Jul 12, 2023

#530 in Web programming

Download history 37/week @ 2024-09-25 23/week @ 2024-10-02 126/week @ 2024-10-30 20/week @ 2024-11-06 13/week @ 2024-11-13 13/week @ 2024-11-20 5/week @ 2024-11-27 13/week @ 2024-12-04 18/week @ 2024-12-11 310/week @ 2024-12-25 29/week @ 2025-01-01 16/week @ 2025-01-08

355 downloads per month
Used in telers-macros

MIT/Apache

2MB
45K SLoC

telers

An asynchronous framework for Telegram Bot API written in Rust

Telers make it easy to create Telegram bots in Rust.

Before you start, make sure that you have a basic understanding of the Telegram Bot API, because types and methods in the library have the same fields and types as in the documentation.

More information about this crate can be found in the crate documentation.

Highlights

  • Asynchronous. Built on top of Tokio, a powerful asynchronous runtime.
  • Easy to use. Provides a simple and intuitive API for creating bots.
  • Based on aiogram. Inspired by the framework written in Python and tries to provide a similar functionality.
  • Routers, Middlewares, Filters and Handlers. Provides a powerful system of routers, middlewares, filters and handlers to make your code more readable and maintainable, and simplify the creation of bots.
  • Extractors. Have similar system of extractors as in axum and actix.

Examples

  • Echo bot. This example shows how to create an echo bot.
  • Context. This example shows how to use context to save data.
  • Extensions. This example shows how to use extensions to save data.
  • Extractor. This example shows how to use extractor to extract data.
  • Text formatting. This example shows how to format text.
  • Text case filters. This example shows how to create text case filters.
  • Stats updates middleware. This example shows how to create a middleware that count incoming updates.
  • Input file. This example shows how to send files by the bot.
  • Finite state machine. This example shows how to use a finite state machine (conversation).
  • Router tree. This example shows how to create a router tree.
  • Bot http client. This example shows how to set a custom bot HTTP client.
  • Axum and echo bot. This example shows how to create an echo bot and run it concurrently with polling axum server.

You may consider checking out this directory for more examples.

Community

Telegram

License

This project is licensed under either of the following licenses, at your option:

Dependencies

~11–24MB
~341K SLoC