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 serenity::framework::standard::macros::group;
|
||||||
|
|
||||||
use ping::PING_COMMAND;
|
use ping::PING_COMMAND;
|
||||||
|
use shutdown::SHUTDOWN_COMMAND;
|
||||||
use stats::STATS_COMMAND;
|
use stats::STATS_COMMAND;
|
||||||
|
|
||||||
pub(crate) mod help;
|
pub(crate) mod help;
|
||||||
mod ping;
|
mod ping;
|
||||||
|
mod shutdown;
|
||||||
mod stats;
|
mod stats;
|
||||||
|
|
||||||
#[group]
|
#[group]
|
||||||
#[commands(ping, stats)]
|
#[commands(ping, stats, shutdown)]
|
||||||
pub struct Misc;
|
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