From 43a9bac87d5f2dd3a59769e710ef0c08ac5790ae Mon Sep 17 00:00:00 2001 From: Hirrolot Date: Wed, 27 Apr 2022 01:01:15 +0600 Subject: [PATCH] Replace `examples/dispatching_features.rs` with `examples/purchase.rs` --- examples/dispatching_features.rs | 158 ------------------------------- src/dispatching/mod.rs | 2 +- 2 files changed, 1 insertion(+), 159 deletions(-) delete mode 100644 examples/dispatching_features.rs diff --git a/examples/dispatching_features.rs b/examples/dispatching_features.rs deleted file mode 100644 index 91ef0808..00000000 --- a/examples/dispatching_features.rs +++ /dev/null @@ -1,158 +0,0 @@ -// This example provide a quick overview of the new features in the -// `dispatching` module. - -use rand::Rng; - -use teloxide::{ - prelude::*, - types::{Dice, Update, UserId}, - utils::command::BotCommands, -}; - -#[tokio::main] -async fn main() { - pretty_env_logger::init(); - log::info!("Starting dispatching features bot..."); - - let bot = Bot::from_env().auto_send(); - - let parameters = ConfigParameters { - bot_maintainer: UserId(0), // Paste your ID to run this bot. - maintainer_username: None, - }; - - let handler = Update::filter_message() - // You can use branching to define multiple ways in which an update will be handled. If the - // first branch fails, an update will be passed to the second branch, and so on. - .branch( - dptree::entry() - // Filter commands: the next handlers will receive a parsed `SimpleCommand`. - .filter_command::() - // If a command parsing fails, this handler will not be executed. - .endpoint(simple_commands_handler), - ) - .branch( - // Filter a maintainer by a used ID. - dptree::filter(|msg: Message, cfg: ConfigParameters| { - msg.from().map(|user| user.id == cfg.bot_maintainer).unwrap_or_default() - }) - .filter_command::() - .endpoint( - |msg: Message, bot: AutoSend, cmd: MaintainerCommands| async move { - match cmd { - MaintainerCommands::Rand { from, to } => { - let mut rng = rand::rngs::OsRng::default(); - let value: u64 = rng.gen_range(from..=to); - - bot.send_message(msg.chat.id, value.to_string()).await?; - Ok(()) - } - } - }, - ), - ) - .branch( - // Filtering allow you to filter updates by some condition. - dptree::filter(|msg: Message| msg.chat.is_group() || msg.chat.is_supergroup()) - // An endpoint is the last update handler. - .endpoint(|msg: Message, bot: AutoSend| async move { - log::info!("Received a message from a group chat."); - bot.send_message(msg.chat.id, "This is a group chat.").await?; - respond(()) - }), - ) - .branch( - // There are some extension filtering functions on `Message`. The following filter will - // filter only messages with dices. - Message::filter_dice().endpoint( - |msg: Message, dice: Dice, bot: AutoSend| async move { - bot.send_message(msg.chat.id, format!("Dice value: {}", dice.value)) - .reply_to_message_id(msg.id) - .await?; - Ok(()) - }, - ), - ); - - Dispatcher::builder(bot, handler) - // Here you specify initial dependencies that all handlers will receive; they can be - // database connections, configurations, and other auxiliary arguments. It is similar to - // `actix_web::Extensions`. - .dependencies(dptree::deps![parameters]) - // If no handler succeeded to handle an update, this closure will be called. - .default_handler(|upd| async move { - log::warn!("Unhandled update: {:?}", upd); - }) - // If the dispatcher fails for some reason, execute this handler. - .error_handler(LoggingErrorHandler::with_custom_text( - "An error has occurred in the dispatcher", - )) - .build() - .setup_ctrlc_handler() - .dispatch() - .await; -} - -#[derive(Clone)] -struct ConfigParameters { - bot_maintainer: UserId, - maintainer_username: Option, -} - -#[derive(BotCommands, Clone)] -#[command(rename = "lowercase", description = "Simple commands")] -enum SimpleCommand { - #[command(description = "shows this message.")] - Help, - #[command(description = "shows maintainer info.")] - Maintainer, - #[command(description = "shows your ID.")] - MyId, -} - -#[derive(BotCommands, Clone)] -#[command(rename = "lowercase", description = "Maintainer commands")] -enum MaintainerCommands { - #[command(parse_with = "split", description = "generate a number within range")] - Rand { from: u64, to: u64 }, -} - -async fn simple_commands_handler( - msg: Message, - bot: AutoSend, - cmd: SimpleCommand, - cfg: ConfigParameters, - me: teloxide::types::Me, -) -> Result<(), teloxide::RequestError> { - let text = match cmd { - SimpleCommand::Help => { - if msg.from().unwrap().id == cfg.bot_maintainer { - format!( - "{}\n\n{}", - SimpleCommand::descriptions(), - MaintainerCommands::descriptions() - ) - } else if msg.chat.is_group() || msg.chat.is_supergroup() { - SimpleCommand::descriptions().username_from_me(&me).to_string() - } else { - SimpleCommand::descriptions().to_string() - } - } - SimpleCommand::Maintainer => { - if msg.from().unwrap().id == cfg.bot_maintainer { - "Maintainer is you!".into() - } else if let Some(username) = cfg.maintainer_username { - format!("Maintainer is @{username}") - } else { - format!("Maintainer ID is {}", cfg.bot_maintainer) - } - } - SimpleCommand::MyId => { - format!("{}", msg.from().unwrap().id) - } - }; - - bot.send_message(msg.chat.id, text).await?; - - Ok(()) -} diff --git a/src/dispatching/mod.rs b/src/dispatching/mod.rs index ef958901..471cc218 100644 --- a/src/dispatching/mod.rs +++ b/src/dispatching/mod.rs @@ -88,7 +88,7 @@ //! which allows you to deal with such objects as a bot and various update types //! easily. //! -//! For a more involved example, see [`examples/dispatching_features.rs`](https://github.com/teloxide/teloxide/blob/master/examples/dispatching_features.rs). +//! For a more involved example, see [`examples/purchase.rs`](https://github.com/teloxide/teloxide/blob/master/examples/purchase.rs). //! //! TODO: explain a more involved example with multiple branches. //!