reminder-bot/src/commands/reminder_cmds.rs

68 lines
1.8 KiB
Rust
Raw Normal View History

2020-09-01 14:34:50 +00:00
use regex_command_attr::command;
use serenity::{
client::Context,
model::{
channel::{
Message,
},
},
framework::standard::CommandResult,
};
use crate::{
models::{
ChannelData,
UserData,
},
SQLPool,
time_parser::TimeParser,
};
use chrono::NaiveDateTime;
#[command]
async fn pause(ctx: &Context, msg: &Message, args: String) -> CommandResult {
let pool = ctx.data.read().await
.get::<SQLPool>().cloned().expect("Could not get SQLPool from data");
let user_data = UserData::from_id(&msg.author, &ctx, &pool).await.unwrap();
let mut channel = ChannelData::from_channel(msg.channel(&ctx).await.unwrap(), &pool).await.unwrap();
2020-09-01 14:34:50 +00:00
if args.len() == 0 {
channel.paused = !channel.paused;
channel.paused_until = None;
channel.commit_changes(&pool).await;
2020-09-01 14:34:50 +00:00
if channel.paused {
let _ = msg.channel_id.say(&ctx, user_data.response(&pool, "paused/paused_indefinite").await).await;
2020-09-01 14:34:50 +00:00
}
else {
let _ = msg.channel_id.say(&ctx, user_data.response(&pool, "paused/unpaused").await).await;
2020-09-01 14:34:50 +00:00
}
}
else {
let parser = TimeParser::new(args, user_data.timezone.parse().unwrap());
let pause_until = parser.timestamp();
match pause_until {
Ok(timestamp) => {
channel.paused = true;
channel.paused_until = Some(NaiveDateTime::from_timestamp(timestamp, 0));
channel.commit_changes(&pool).await;
2020-09-01 14:34:50 +00:00
let _ = msg.channel_id.say(&ctx, user_data.response(&pool, "paused/paused_until").await).await;
2020-09-01 14:34:50 +00:00
},
Err(_) => {
let _ = msg.channel_id.say(&ctx, user_data.response(&pool, "paused/invalid_time").await).await;
2020-09-01 14:34:50 +00:00
},
}
}
Ok(())
}