From 89168ff11d4adb4ca51fe14e7d54fb2d69d392a8 Mon Sep 17 00:00:00 2001 From: Santo Cariotti Date: Thu, 29 Jul 2021 20:02:47 +0200 Subject: refactor: manage callbacks with tokio-stream --- src/main.rs | 20 +++++++++++++++++++- 1 file changed, 19 insertions(+), 1 deletion(-) (limited to 'src/main.rs') diff --git a/src/main.rs b/src/main.rs index 0ac5a4d..220b7ce 100644 --- a/src/main.rs +++ b/src/main.rs @@ -8,6 +8,8 @@ mod config; use crate::config::Config; +use tokio_stream::wrappers::UnboundedReceiverStream; + #[tokio::main] async fn main() -> Result<(), Box> { teloxide::enable_logging!(); @@ -23,7 +25,23 @@ async fn main() -> Result<(), Box> { panic!("You can't connect: `{}`, credentials are {:?}", e, config); } }; - teloxide::commands_repl(bot, "unict-reservation", commands::handler).await; + + Dispatcher::new(bot) + .messages_handler(|rx: DispatcherHandlerRx, Message>| { + UnboundedReceiverStream::new(rx).for_each_concurrent(None, |cx| async move { + commands::handler(cx).await.log_on_error().await; + }) + }) + .callback_queries_handler(|rx: DispatcherHandlerRx, CallbackQuery>| { + UnboundedReceiverStream::new(rx).for_each_concurrent(None, |cx| async move { + let data = &cx.update.data; + if let Some(d) = data { + println!("{}", d); + } + }) + }) + .dispatch() + .await; log::info!("Closing bot... Goodbye!"); Ok(()) -- cgit v1.2.3-18-g5258