This commit is contained in:
2024-05-13 21:28:53 +02:00
parent 0f71849302
commit 1f6cc010e0
5 changed files with 49 additions and 22 deletions

View File

@@ -0,0 +1,13 @@
use serenity::{all::CommandOptionType, builder::*};
pub fn register() -> CreateCommand {
CreateCommand::new("copy_message")
.description("Не вызывать, только для настройки")
.add_option(
CreateCommandOption::new(
CommandOptionType::Integer, "message_id", "ID сообщения"
)
.required(true)
)
}

View File

@@ -1,7 +0,0 @@
use serenity::builder::*;
pub fn register() -> CreateCommand {
CreateCommand::new("create_message")
.description("Не вызывать, только для настройки")
}

View File

@@ -1,3 +1,3 @@
pub mod add_game;
pub mod delete_game;
pub mod create_message;
pub mod copy_message;

View File

@@ -11,6 +11,8 @@ pub struct Config {
pub discord_guild_id: u64,
pub discord_channel_id: u64,
pub discord_bot_activity: String,
// pub discord_game_list_channel_id: u64,
// pub discord_game_list_message_id: u64,
pub telegram_bot_token: String,
pub telegram_channel_id: i128,
}
@@ -23,6 +25,8 @@ impl Config {
discord_guild_id: get_env("DISCORD_GUILD_ID").parse().unwrap(),
discord_channel_id: get_env("DISCORD_CHANNEL_ID").parse().unwrap(),
discord_bot_activity: get_env("DISCORD_BOT_ACTIVITY"),
// discord_game_list_channel_id: get_env("DISCORD_GAME_LIST_CHANNEL_ID").parse().unwrap(),
// discord_game_list_message_id: get_env("DISCORD_GAME_LIST_MESSAGE_ID").parse().unwrap(),
telegram_bot_token: get_env("TELEGRAM_BOT_TOKEN"),
telegram_channel_id: get_env("TELEGRAM_CHANNEL_ID").parse().unwrap(),
}

View File

@@ -29,22 +29,39 @@ struct Handler;
impl EventHandler for Handler {
async fn interaction_create(&self, ctx: Context, interaction: Interaction) {
if let Interaction::Command(command) = interaction {
println!("Received command interaction: {command:#?}");
match command.data.name.as_str() {
"create_message" => {
let message_id = command.data.options[0].value.as_str().unwrap().parse::<u64>().unwrap();
let message = command.channel_id.message(&ctx.http, message_id).await.unwrap();
let content = match command.data.name.as_str() {
"create_message" => Some("#init".to_string()),
_ => Some("not implemented :(".to_string()),
};
if let Some(content) = content {
let data = CreateInteractionResponseMessage::new().content(content);
let data = CreateInteractionResponseMessage::new().content(message.content);
let builder = CreateInteractionResponse::Message(data);
if let Err(why) = command.create_response(&ctx.http, builder).await {
println!("Cannot respond to slash command: {why}");
}
},
"add_game" => {
// let message = command.channel_id.message(&ctx.http, config::CONFIG.discord_game_list_message_id).await.unwrap();
let data = CreateInteractionResponseMessage::new().content("Игра добавлена!").ephemeral(true);
let builder = CreateInteractionResponse::Message(data);
if let Err(why) = command.create_response(&ctx.http, builder).await {
println!("Cannot respond to slash command: {why}");
}
},
"delete_game" => {
// let message = command.channel_id.message(&ctx.http, config::CONFIG.discord_game_list_message_id).await.unwrap();
let data = CreateInteractionResponseMessage::new().content("Игра удалена!").ephemeral(true);
let builder = CreateInteractionResponse::Message(data);
if let Err(why) = command.create_response(&ctx.http, builder).await {
println!("Cannot respond to slash command: {why}");
}
},
_ => (),
};
} else if let Interaction::Autocomplete(interaction) = interaction {
// println!("Received autocomplete interaction: {interaction:#?}");
println!("Received autocomplete interaction: {interaction:#?}");
// let content = match interaction.data.name.as_str() {
// "game" => {
@@ -96,7 +113,7 @@ impl EventHandler for Handler {
vec![
commands::add_game::register(),
commands::delete_game::register(),
commands::create_message::register()
commands::copy_message::register(),
]
).await.unwrap();
}