Crates.io | telegram-bot-async-raw |
lib.rs | telegram-bot-async-raw |
version | 0.8.2 |
source | src |
created_at | 2020-01-01 05:30:05.38275 |
updated_at | 2020-01-01 05:32:08.096946 |
description | Telegram Bot API types |
homepage | |
repository | https://github.com/crackcomm/telegram-bot |
max_upload_size | |
id | 194049 |
size | 143,350 |
Documentation: | Latest crates.io version |
A library for writing your own Telegram bots. More information here. Official API here.
Here is a simple example (see example/simple.rs
):
extern crate futures;
extern crate telegram_bot_async;
extern crate tokio;
use std::env;
use futures::{Stream, future::lazy};
use telegram_bot_async::*;
fn main() {
tokio::runtime::current_thread::Runtime::new().unwrap().block_on(lazy(|| {
let token = env::var("TELEGRAM_BOT_TOKEN").unwrap();
let api = Api::new_default(token).unwrap();
// Convert stream to the stream with errors in result
let stream = api.stream().then(|mb_update| {
let res: Result<Result<Update, Error>, ()> = Ok(mb_update);
res
});
// Print update or error for each update.
stream.for_each(move |update| {
match update {
Ok(update) => {
// If the received update contains a new message...
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.spawn(message.text_reply(format!(
"Hi, {}! You just wrote '{}'",
&message.from.first_name, data
)));
}
}
}
Err(_) => {}
}
Ok(())
})
})).unwrap();
}
You can find a bigger examples in the examples
.
This library is available via crates.io
. In order to use it, just add this to your Cargo.toml
:
telegram-bot-async = "0.7"
Yes please! Every type of contribution is welcome: Create issues, hack some code or make suggestions. Don't know where to start? Good first issues are tagged with up for grab.