6 个版本

0.8.0 2020年11月14日
0.7.0 2020年3月21日
0.6.3 2019年7月17日
0.6.1 2018年2月17日
0.6.0 2018年1月9日

#30 in #telegram-api

Download history 201/week @ 2023-12-14 197/week @ 2023-12-21 50/week @ 2023-12-28 69/week @ 2024-01-04 152/week @ 2024-01-11 156/week @ 2024-01-18 94/week @ 2024-01-25 52/week @ 2024-02-01 138/week @ 2024-02-08 202/week @ 2024-02-15 201/week @ 2024-02-22 212/week @ 2024-02-29 266/week @ 2024-03-07 230/week @ 2024-03-14 291/week @ 2024-03-21 275/week @ 2024-03-28

1,066 每月下载量
6 包中使用 (直接使用 2 个)

MIT 许可证

210KB
5.5K SLoC

Rust Telegram Bot 库

Build Status Tests Tests License Crates.io

文档 最新 crates.io 版本 master

用于编写您自己的 Telegram 机器人的库。更多信息 这里。官方 API 这里

示例

以下是一个简单的示例(见 example/simple.rs

use std::env;

use futures::StreamExt;
use telegram_bot::*;

#[tokio::main]
async fn main() -> Result<(), Error> {
    let token = env::var("TELEGRAM_BOT_TOKEN").expect("TELEGRAM_BOT_TOKEN not set");
    let api = Api::new(token);

    // Fetch new updates via long poll method
    let mut stream = api.stream();
    while let Some(update) = stream.next().await {
        // If the received update contains a new message...
        let update = update?;
        if let UpdateKind::Message(message) = update.kind {
            if let MessageKind::Text { ref data, .. } = message.kind {
                // Print received text message to stdout.
                println!("<{}>: {}", &message.from.first_name, data);

                // Answer message with "Hi".
                api.send(message.text_reply(format!(
                    "Hi, {}! You just wrote '{}'",
                    &message.from.first_name, data
                )))
                .await?;
            }
        }
    }
    Ok(())
}

更大的示例可以在 examples 中找到。

使用方法

此库可通过 crates.io 获取。要使用它,只需将其添加到您的 Cargo.toml

telegram-bot = "0.7"

此库允许您轻松地进行机器人的端到端测试:只需指定 TELEGRAM_API_URL 环境变量,将其指向您的伪造 Telegram 测试服务器。可以使用 tracing 框架收集大量诊断信息,见 example/tracing.rs)。

协作

请!所有类型的贡献都受欢迎:创建问题、修改代码或提出建议。不知道从哪里开始?标记为 up for grab 的问题非常适合入门。

依赖项

~1.1–2MB
~42K SLoC