implement op command to give myself admin permissions

This commit is contained in:
mykola2312 2024-03-02 04:55:23 +02:00
parent 2ae4708438
commit c9eb89d4e8
4 changed files with 69 additions and 2 deletions

View file

@ -1,4 +1,5 @@
pub mod bot;
pub mod dl;
pub mod op;
pub mod sanitize;
pub mod types;

View file

@ -9,10 +9,12 @@ use teloxide::dispatching::{dialogue, dialogue::InMemStorage, UpdateHandler};
use teloxide::{prelude::*, update_listeners::Polling, utils::command::BotCommands};
use tracing::{event, Level};
use super::dl::cmd_download;
use super::types::*;
use crate::db::DbPool;
use super::dl::cmd_download;
use super::op::cmd_op;
fn parse_env<T>(name: &str) -> T
where
T: FromStr,
@ -54,7 +56,8 @@ fn schema() -> UpdateHandler<HandlerErr> {
let command_handler = teloxide::filter_command::<Command, _>()
.branch(case![Command::Test].endpoint(cmd_test))
.branch(case![Command::Download(url)].endpoint(cmd_download));
.branch(case![Command::Download(url)].endpoint(cmd_download))
.branch(case![Command::OP].endpoint(cmd_op));
let message_handler = Update::filter_message().branch(command_handler);
let raw_message_handler = Update::filter_message().branch(dptree::endpoint(handle_message));
@ -71,6 +74,9 @@ enum Command {
#[command(alias = "dl")]
Download(String),
#[command(alias = "op")]
OP
}
async fn cmd_test(bot: Bot, msg: Message, _db: DbPool) -> HandlerResult {

30
src/bot/op.rs Normal file
View file

@ -0,0 +1,30 @@
use sqlx::Row;
use teloxide::prelude::*;
use tracing::{event, Level};
use super::types::HandlerResult;
use crate::db::{user::create_user, DbPool};
pub async fn cmd_op(bot: Bot, msg: Message, db: DbPool) -> HandlerResult {
let admins: i64 = sqlx::query("SELECT COUNT(*) FROM user WHERE is_admin = 1")
.fetch_one(&db)
.await?
.get(0);
if let Some(user) = msg.from() {
if admins == 0 {
let user = create_user(db, user, true, true).await?;
event!(
Level::INFO,
"opped {} - {}",
user.tg_id,
user.username.unwrap_or(user.first_name)
);
bot.send_message(msg.chat.id, "Now you're an admin").await?;
} else {
bot.send_message(msg.chat.id, "You can't do that anymore").await?;
}
}
Ok(())
}

30
src/db/user.rs Normal file
View file

@ -0,0 +1,30 @@
use teloxide::types;
use super::{DbPool, User};
pub async fn create_user(
db: DbPool,
user: &types::User,
can_download: bool,
is_admin: bool,
) -> Result<User, sqlx::Error> {
sqlx::query(
"INSERT OR IGNORE INTO user
(tg_id, username, first_name, last_name, can_download, is_admin)
VALUES ($1,$2,$3,$4,$5,$6);",
)
.bind(user.id.0 as i64)
.bind(&user.username)
.bind(&user.first_name)
.bind(&user.last_name)
.bind(can_download as i64)
.bind(is_admin as i64)
.execute(&db)
.await?;
let user: User = sqlx::query_as("SELECT * FROM user WHERE tg_id = $1 LIMIT 1;")
.bind(user.id.0 as i64)
.fetch_one(&db)
.await?;
Ok(user)
}