late-submissions
Elnu 3 years ago
parent 514d57eef4
commit 7a11c52c4d

@ -11,8 +11,8 @@ use std::fs::File;
use std::fs::OpenOptions; use std::fs::OpenOptions;
use std::io::Read; use std::io::Read;
use std::io::Write; use std::io::Write;
use std::process::Command;
use std::path::Path; use std::path::Path;
use std::process::Command;
use slug::slugify; use slug::slugify;
@ -46,7 +46,11 @@ fn get_submission_images_dir() -> String {
} }
fn get_submission_data_path() -> String { fn get_submission_data_path() -> String {
format!("{}/data/challenges/{}.json", get_hugo_path(), get_challenge_number()) format!(
"{}/data/challenges/{}.json",
get_hugo_path(),
get_challenge_number()
)
} }
fn get_submission_data() -> Vec<Value> { fn get_submission_data() -> Vec<Value> {
@ -74,9 +78,14 @@ fn set_submission_data(submission_data: Vec<Value>) {
let mut submission_data_file = OpenOptions::new() let mut submission_data_file = OpenOptions::new()
.write(true) .write(true)
.truncate(true) .truncate(true)
.open(get_submission_data_path()).unwrap(); .open(get_submission_data_path())
.unwrap();
submission_data_file submission_data_file
.write_all(serde_json::to_string_pretty(&submission_data).unwrap().as_bytes()) .write_all(
serde_json::to_string_pretty(&submission_data)
.unwrap()
.as_bytes(),
)
.unwrap(); .unwrap();
} }
@ -223,7 +232,10 @@ async fn submit(ctx: &Context, msg: &Message) -> CommandResult {
if invalid_types { if invalid_types {
message.push_str("\nSome of your attachments could not be uploaded; only **.png**, **.jpg**, and **.jpeg** files are permitted."); message.push_str("\nSome of your attachments could not be uploaded; only **.png**, **.jpg**, and **.jpeg** files are permitted.");
} }
Command::new("hugo").current_dir(&hugo_path).spawn().expect("Failed to rebuild site"); Command::new("hugo")
.current_dir(&hugo_path)
.spawn()
.expect("Failed to rebuild site");
} else if invalid_types { } else if invalid_types {
message.push_str("Sorry, your submission could not be uploaded; only **.png**, **.jpg**, and **.jpeg** files are permitted."); message.push_str("Sorry, your submission could not be uploaded; only **.png**, **.jpg**, and **.jpeg** files are permitted.");
} }
@ -248,12 +260,27 @@ async fn images(ctx: &Context, msg: &Message) -> CommandResult {
}; };
let challenge_number = get_challenge_number(); let challenge_number = get_challenge_number();
if images.len() == 0 { if images.len() == 0 {
msg.reply(&ctx.http, format!("You haven't submitted anything for Tegaki Tuesday #{}.", challenge_number)).await?; msg.reply(
return Ok(()) &ctx.http,
format!(
"You haven't submitted anything for Tegaki Tuesday #{}.",
challenge_number
),
)
.await?;
return Ok(());
} }
let mut message = String::from(format!("Your submission images for Tegaki Tuesday #{}:\n", challenge_number)); let mut message = String::from(format!(
"Your submission images for Tegaki Tuesday #{}:\n",
challenge_number
));
for (i, image) in images.iter().enumerate() { for (i, image) in images.iter().enumerate() {
message.push_str(&format!("{}<https://tegakituesday.com/{}/{}>\n", to_fullwidth(&(i + 1).to_string()), challenge_number, image)); message.push_str(&format!(
"{}<https://tegakituesday.com/{}/{}>\n",
to_fullwidth(&(i + 1).to_string()),
challenge_number,
image
));
} }
msg.reply(&ctx.http, message).await?; msg.reply(&ctx.http, message).await?;
Ok(()) Ok(())
@ -268,11 +295,15 @@ async fn imageDelete(ctx: &Context, msg: &Message, mut args: Args) -> CommandRes
Ok(value) => number = value, Ok(value) => number = value,
Err(_) => { Err(_) => {
msg.reply(&ctx.http, format!("Please provide the image number you want to delete. You can get a list of your submitted images using `{}images`.", env::var("PREFIX").unwrap())).await?; msg.reply(&ctx.http, format!("Please provide the image number you want to delete. You can get a list of your submitted images using `{}images`.", env::var("PREFIX").unwrap())).await?;
return Ok(()) return Ok(());
} }
} }
if number < 1 { if number < 1 {
msg.reply(&ctx.http, "That isn't a valid image number. Image numbers start at 1.").await?; msg.reply(
&ctx.http,
"That isn't a valid image number. Image numbers start at 1.",
)
.await?;
return Ok(()); return Ok(());
} }
let challenge_number = get_challenge_number(); let challenge_number = get_challenge_number();
@ -284,14 +315,25 @@ async fn imageDelete(ctx: &Context, msg: &Message, mut args: Args) -> CommandRes
let mut images = submission["images"].as_array().unwrap().clone(); let mut images = submission["images"].as_array().unwrap().clone();
let image_count = images.len(); let image_count = images.len();
if image_count < number.try_into().unwrap() { if image_count < number.try_into().unwrap() {
msg.reply(&ctx.http, if image_count == 0 { msg.reply(
// This is an edge case that should never happen. &ctx.http,
// In this scenario, there is submission data with an empty image list. if image_count == 0 {
// Submission data should be deleted uppon imageDelete if there are no images remaining. // This is an edge case that should never happen.
format!("You haven't submitted anything for Tegaki Tuesday #{}.", challenge_number) // In this scenario, there is submission data with an empty image list.
} else { // Submission data should be deleted uppon imageDelete if there are no images remaining.
format!("That image number doesn't exist, you only have {} image{}.", image_count, if image_count == 1 { "" } else { "s" }) format!(
}).await?; "You haven't submitted anything for Tegaki Tuesday #{}.",
challenge_number
)
} else {
format!(
"That image number doesn't exist, you only have {} image{}.",
image_count,
if image_count == 1 { "" } else { "s" }
)
},
)
.await?;
return Ok(()); return Ok(());
} }
let index = number as usize - 1; let index = number as usize - 1;
@ -302,7 +344,7 @@ async fn imageDelete(ctx: &Context, msg: &Message, mut args: Args) -> CommandRes
Ok(_) => (), Ok(_) => (),
// No need to worry about if the file is already missing // No need to worry about if the file is already missing
Err(ref e) if e.kind() == std::io::ErrorKind::NotFound => (), Err(ref e) if e.kind() == std::io::ErrorKind::NotFound => (),
Err(_) => panic!("Failed to remove file") Err(_) => panic!("Failed to remove file"),
}; };
let mut message = String::from(format!("Deleted **{}** from your submission.", image)); let mut message = String::from(format!("Deleted **{}** from your submission.", image));
if images.len() == 1 { if images.len() == 1 {
@ -336,7 +378,8 @@ async fn imageDelete(ctx: &Context, msg: &Message, mut args: Args) -> CommandRes
Path::new(old).extension().unwrap().to_str().unwrap() Path::new(old).extension().unwrap().to_str().unwrap()
); );
let to = format!("{}/{}", submission_images_dir, new); let to = format!("{}/{}", submission_images_dir, new);
fs_extra::file::move_file(from, to, &fs_extra::file::CopyOptions::default()).unwrap(); fs_extra::file::move_file(from, to, &fs_extra::file::CopyOptions::default())
.unwrap();
*image = new.into(); *image = new.into();
} }
submission["images"] = images.into(); submission["images"] = images.into();
@ -345,6 +388,13 @@ async fn imageDelete(ctx: &Context, msg: &Message, mut args: Args) -> CommandRes
msg.reply(&ctx.http, message).await?; msg.reply(&ctx.http, message).await?;
return Ok(()); return Ok(());
} }
msg.reply(&ctx.http, format!("You haven't submitted anything for Tegaki Tuesday #{}.", challenge_number)).await?; msg.reply(
&ctx.http,
format!(
"You haven't submitted anything for Tegaki Tuesday #{}.",
challenge_number
),
)
.await?;
Ok(()) Ok(())
} }

@ -43,7 +43,19 @@ impl EventHandler for Handler {
} }
#[group] #[group]
#[commands(joyo, jinmeiyo, kyoiku, jlpt, hyogai, so, challenge, submit, images, imageDelete, sleep)] #[commands(
joyo,
jinmeiyo,
kyoiku,
jlpt,
hyogai,
so,
challenge,
submit,
images,
imageDelete,
sleep
)]
struct General; struct General;
#[tokio::main] #[tokio::main]

Loading…
Cancel
Save