2020-12-05 15:57:11 +03:00
|
|
|
use std::{env,process};
|
2020-11-28 17:31:08 +03:00
|
|
|
|
|
|
|
use futures::StreamExt;
|
2020-12-05 15:57:11 +03:00
|
|
|
use reqwest;
|
2020-11-28 17:31:08 +03:00
|
|
|
use telegram_bot::types::chat::MessageChat;
|
|
|
|
use telegram_bot::*;
|
2020-12-05 15:57:11 +03:00
|
|
|
#[macro_use]
|
|
|
|
extern crate log;
|
|
|
|
use env_logger::Env;
|
2020-11-28 17:31:08 +03:00
|
|
|
|
|
|
|
mod commands;
|
|
|
|
mod db;
|
2020-11-29 16:23:27 +03:00
|
|
|
mod errors;
|
|
|
|
mod utils;
|
2020-11-28 17:31:08 +03:00
|
|
|
|
2020-12-05 15:57:11 +03:00
|
|
|
async fn handler(api: Api, message: Message, token: String) -> Result<(), errors::Error> {
|
2020-11-28 17:31:08 +03:00
|
|
|
match message.kind {
|
|
|
|
MessageKind::Text { ref data, .. } => {
|
2020-11-29 16:23:27 +03:00
|
|
|
let title = utils::get_title(&message);
|
2020-11-28 17:31:08 +03:00
|
|
|
|
|
|
|
println!(
|
2020-11-29 16:23:27 +03:00
|
|
|
"<{}({})>[{}({})]: {}",
|
2020-11-28 17:31:08 +03:00
|
|
|
&message.chat.id(),
|
|
|
|
title,
|
|
|
|
&message.from.id,
|
|
|
|
&message.from.first_name,
|
|
|
|
data
|
|
|
|
);
|
|
|
|
match data.as_str() {
|
|
|
|
"/here" => commands::here(api, message).await?,
|
|
|
|
_ => (),
|
|
|
|
}
|
|
|
|
}
|
2020-12-05 15:57:11 +03:00
|
|
|
MessageKind::Photo {
|
|
|
|
ref caption,
|
|
|
|
ref data,
|
|
|
|
..
|
|
|
|
} => {
|
|
|
|
let title = utils::get_title(&message);
|
|
|
|
println!(
|
|
|
|
"<{}({})>[{}({})]: *PHOTO* {}",
|
|
|
|
&message.chat.id(),
|
|
|
|
title,
|
|
|
|
&message.from.id,
|
|
|
|
&message.from.first_name,
|
|
|
|
caption.clone().unwrap_or("NO_TITLE".to_string())
|
|
|
|
);
|
|
|
|
utils::get_files(api, message, token).await?;
|
|
|
|
}
|
|
|
|
|
|
|
|
MessageKind::Document { ref caption, .. } => {
|
|
|
|
let title = utils::get_title(&message);
|
|
|
|
println!(
|
|
|
|
"<{}({})>[{}({})]: *DOCUMENT* {}",
|
|
|
|
&message.chat.id(),
|
|
|
|
title,
|
|
|
|
&message.from.id,
|
|
|
|
&message.from.first_name,
|
|
|
|
caption.clone().unwrap_or("NO_TITLE".to_string())
|
|
|
|
);
|
|
|
|
/*match utils::get_files(api, message, token).await {
|
|
|
|
Ok(count) => println!("Got {} files successfully.", count),
|
|
|
|
Err(e) => println!("Couldn't get files: {:?}", e)
|
|
|
|
}
|
|
|
|
|
|
|
|
*/
|
|
|
|
utils::get_files(api, message, token).await?;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
MessageKind::Sticker { ref data, .. } => {
|
|
|
|
let title = utils::get_title(&message);
|
|
|
|
println!(
|
|
|
|
"<{}({})>[{}({})]: *STICKER*",
|
|
|
|
&message.chat.id(),
|
|
|
|
title,
|
|
|
|
&message.from.id,
|
|
|
|
&message.from.first_name,
|
|
|
|
);
|
|
|
|
utils::get_files(api, message, token).await?;
|
|
|
|
}
|
|
|
|
|
|
|
|
MessageKind::Voice { .. } => {
|
|
|
|
let title = utils::get_title(&message);
|
|
|
|
println!(
|
|
|
|
"<{}({})>[{}({})]: *VOICE*",
|
|
|
|
&message.chat.id(),
|
|
|
|
title,
|
|
|
|
&message.from.id,
|
|
|
|
&message.from.first_name,
|
|
|
|
);
|
|
|
|
utils::get_files(api, message, token).await?;
|
|
|
|
}
|
|
|
|
|
|
|
|
MessageKind::Video { .. } => {
|
|
|
|
let title = utils::get_title(&message);
|
|
|
|
println!(
|
|
|
|
"<{}({})>[{}({})]: *VIDEO*",
|
|
|
|
&message.chat.id(),
|
|
|
|
title,
|
|
|
|
&message.from.id,
|
|
|
|
&message.from.first_name,
|
|
|
|
);
|
|
|
|
utils::get_files(api, message, token).await?;
|
|
|
|
}
|
|
|
|
|
|
|
|
MessageKind::VideoNote { .. } => {
|
|
|
|
let title = utils::get_title(&message);
|
|
|
|
println!(
|
|
|
|
"<{}({})>[{}({})]: *VIDEO_NOTE*",
|
|
|
|
&message.chat.id(),
|
|
|
|
title,
|
|
|
|
&message.from.id,
|
|
|
|
&message.from.first_name,
|
|
|
|
);
|
|
|
|
utils::get_files(api, message, token).await?;
|
|
|
|
}
|
2020-11-28 17:31:08 +03:00
|
|
|
_ => (),
|
|
|
|
};
|
|
|
|
Ok(())
|
|
|
|
}
|
|
|
|
|
|
|
|
#[tokio::main]
|
2020-11-29 16:23:27 +03:00
|
|
|
async fn main() -> Result<(), errors::Error> {
|
2020-12-05 15:57:11 +03:00
|
|
|
env_logger::from_env(Env::default().default_filter_or("debug")).init();
|
|
|
|
let token = match env::var("TELEGRAM_BOT_TOKEN") {
|
|
|
|
Ok(token) => token,
|
|
|
|
Err(_) => {
|
|
|
|
error!("TELEGRAM_BOT_TOKEN not set");
|
|
|
|
process::exit(0x0001);
|
|
|
|
},
|
|
|
|
};
|
|
|
|
let api = Api::new(token.clone());
|
2020-11-28 17:31:08 +03:00
|
|
|
|
|
|
|
// 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 {
|
2020-12-05 15:57:11 +03:00
|
|
|
db::add_user(message.clone()).await?;
|
|
|
|
db::add_conf(message.clone()).await?;
|
2020-11-29 16:23:27 +03:00
|
|
|
|
2020-12-05 15:57:11 +03:00
|
|
|
handler(api.clone(), message, token.clone()).await?;
|
2020-11-28 17:31:08 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
Ok(())
|
|
|
|
}
|