teloxide/examples/inline.rs

65 lines
2.7 KiB
Rust
Raw Normal View History

use teloxide::{
2022-03-24 17:25:42 +06:00
prelude::*,
types::{
InlineQueryResult, InlineQueryResultArticle, InputMessageContent, InputMessageContentText,
},
Bot,
};
2021-08-18 21:54:32 -07:00
#[tokio::main]
async fn main() {
pretty_env_logger::init();
log::info!("Starting inline bot...");
2022-01-06 13:30:27 +02:00
let bot = Bot::from_env();
2022-01-06 13:30:27 +02:00
2022-01-26 15:51:51 +06:00
let handler = Update::filter_inline_query().branch(dptree::endpoint(
|bot: Bot, q: InlineQuery| async move {
2022-01-26 15:51:51 +06:00
// First, create your actual response
let google_search = InlineQueryResultArticle::new(
// Each item needs a unique ID, as well as the response container for the
// items. These can be whatever, as long as they don't
// conflict.
"01".to_string(),
// What the user will actually see
"Google Search",
// What message will be sent when clicked/tapped
InputMessageContent::Text(InputMessageContentText::new(format!(
"https://www.google.com/search?q={}",
q.query,
2022-01-26 15:51:51 +06:00
))),
);
// While constructing them from the struct itself is possible, it is preferred
// to use the builder pattern if you wish to add more
// information to your result. Please refer to the documentation
// for more detailed information about each field. https://docs.rs/teloxide/latest/teloxide/types/struct.InlineQueryResultArticle.html
let ddg_search = InlineQueryResultArticle::new(
"02".to_string(),
"DuckDuckGo Search".to_string(),
InputMessageContent::Text(InputMessageContentText::new(format!(
"https://duckduckgo.com/?q={}",
q.query
2022-01-26 15:51:51 +06:00
))),
)
.description("DuckDuckGo Search")
2022-02-03 20:39:32 +06:00
.thumb_url("https://duckduckgo.com/assets/logo_header.v108.png".parse().unwrap())
.url("https://duckduckgo.com/about".parse().unwrap()); // Note: This is the url that will open if they click the thumbnail
2021-08-18 21:54:32 -07:00
2022-01-26 15:51:51 +06:00
let results = vec![
InlineQueryResult::Article(google_search),
InlineQueryResult::Article(ddg_search),
];
2022-01-26 15:51:51 +06:00
// Send it off! One thing to note -- the ID we use here must be of the query
// we're responding to.
let response = bot.answer_inline_query(&q.id, results).send().await;
2022-01-26 15:51:51 +06:00
if let Err(err) = response {
log::error!("Error in handler: {:?}", err);
}
respond(())
},
));
Dispatcher::builder(bot, handler).enable_ctrlc_handler().build().dispatch().await;
2021-08-18 21:54:32 -07:00
}