mirror of
https://github.com/eRgo35/lyra.git
synced 2026-02-04 04:16:11 +01:00
mute
This commit is contained in:
44
src/commands/music/mute.rs
Normal file
44
src/commands/music/mute.rs
Normal file
@@ -0,0 +1,44 @@
|
|||||||
|
use serenity::framework::standard::macros::command;
|
||||||
|
use serenity::framework::standard::CommandResult;
|
||||||
|
use serenity::model::prelude::*;
|
||||||
|
use serenity::prelude::*;
|
||||||
|
|
||||||
|
use crate::commands::misc::check_msg;
|
||||||
|
|
||||||
|
#[command]
|
||||||
|
#[only_in(guilds)]
|
||||||
|
async fn mute(ctx: &Context, msg: &Message) -> CommandResult {
|
||||||
|
let guild_id = msg.guild_id.unwrap();
|
||||||
|
|
||||||
|
let manager = songbird::get(ctx)
|
||||||
|
.await
|
||||||
|
.expect("Client placed at init")
|
||||||
|
.clone();
|
||||||
|
|
||||||
|
let handler_lock = match manager.get(guild_id) {
|
||||||
|
Some(handler) => handler,
|
||||||
|
None => {
|
||||||
|
check_msg(msg.reply(ctx, "Not in a voice channel").await);
|
||||||
|
|
||||||
|
return Ok(());
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
let mut handler = handler_lock.lock().await;
|
||||||
|
|
||||||
|
if handler.is_mute() {
|
||||||
|
check_msg(msg.channel_id.say(&ctx.http, "Already muted").await);
|
||||||
|
} else {
|
||||||
|
if let Err(err) = handler.mute(true).await {
|
||||||
|
check_msg(
|
||||||
|
msg.channel_id
|
||||||
|
.say(&ctx.http, format!("Failed: {:?}", err))
|
||||||
|
.await,
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
check_msg(msg.channel_id.say(&ctx.http, "Muted").await);
|
||||||
|
}
|
||||||
|
|
||||||
|
Ok(())
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user