Add shutdown and pause command
Signed-off-by: trivernis <trivernis@protonmail.com>pull/2/head
parent
e9c70bc754
commit
6c9df7e044
@ -1,12 +1,14 @@
|
||||
use serenity::framework::standard::macros::group;
|
||||
|
||||
use ping::PING_COMMAND;
|
||||
use shutdown::SHUTDOWN_COMMAND;
|
||||
use stats::STATS_COMMAND;
|
||||
|
||||
pub(crate) mod help;
|
||||
mod ping;
|
||||
mod shutdown;
|
||||
mod stats;
|
||||
|
||||
#[group]
|
||||
#[commands(ping, stats)]
|
||||
#[commands(ping, stats, shutdown)]
|
||||
pub struct Misc;
|
||||
|
@ -0,0 +1,18 @@
|
||||
use serenity::framework::standard::macros::command;
|
||||
use serenity::framework::standard::CommandResult;
|
||||
use serenity::model::channel::Message;
|
||||
use serenity::prelude::*;
|
||||
use std::process;
|
||||
|
||||
#[command]
|
||||
#[description("Shutdown")]
|
||||
#[usage("shutdown")]
|
||||
#[example("shutdown")]
|
||||
#[owners_only]
|
||||
async fn shutdown(ctx: &Context, msg: &Message) -> CommandResult {
|
||||
log::info!("Shutting down...");
|
||||
msg.channel_id
|
||||
.say(ctx, ":night_with_stars: Good night ....")
|
||||
.await?;
|
||||
process::exit(0);
|
||||
}
|
@ -0,0 +1,33 @@
|
||||
use serenity::framework::standard::macros::command;
|
||||
use serenity::framework::standard::CommandResult;
|
||||
use serenity::model::channel::Message;
|
||||
use serenity::prelude::*;
|
||||
|
||||
use crate::commands::music::get_queue_for_guild;
|
||||
|
||||
#[command]
|
||||
#[only_in(guilds)]
|
||||
#[description("Pauses playback")]
|
||||
#[usage("pause")]
|
||||
#[allowed_roles("DJ")]
|
||||
async fn pause(ctx: &Context, msg: &Message) -> CommandResult {
|
||||
let guild = msg.guild(&ctx.cache).await.unwrap();
|
||||
log::debug!("Pausing playback for guild {}", guild.id);
|
||||
let queue = get_queue_for_guild(ctx, &guild.id).await?;
|
||||
let mut queue_lock = queue.lock().await;
|
||||
|
||||
if let Some(_) = queue_lock.current() {
|
||||
queue_lock.pause();
|
||||
if queue_lock.paused() {
|
||||
log::debug!("Paused");
|
||||
msg.channel_id.say(ctx, "Paused playback").await?;
|
||||
} else {
|
||||
log::debug!("Resumed");
|
||||
msg.channel_id.say(ctx, "Resumed playback").await?;
|
||||
}
|
||||
} else {
|
||||
msg.channel_id.say(ctx, "Nothing to pause").await?;
|
||||
}
|
||||
|
||||
Ok(())
|
||||
}
|
Loading…
Reference in New Issue