From 02e1f77f65fc93c65dfa10b9ac72660e09fd92c9 Mon Sep 17 00:00:00 2001 From: philipp Date: Tue, 21 May 2024 18:28:56 +0200 Subject: [PATCH 1/2] don't allow to delete an event if someone is registered --- src/model/planned_event.rs | 20 +++++++++++++++++++- 1 file changed, 19 insertions(+), 1 deletion(-) diff --git a/src/model/planned_event.rs b/src/model/planned_event.rs index 6ecef00..2db5692 100644 --- a/src/model/planned_event.rs +++ b/src/model/planned_event.rs @@ -240,11 +240,29 @@ INNER JOIN trip_details ON planned_event.trip_details_id = trip_details.id", .unwrap(); //Okay, as planned_event can only be created with proper DB backing } - pub async fn delete(&self, db: &SqlitePool) { + pub async fn delete(&self, db: &SqlitePool) -> Result<(), String> { + if Registration::all_rower(db, self.trip_details_id) + .await + .len() + > 0 + { + return Err( + "Event kann nicht gelöscht werden, weil mind. 1 Ruderer angemeldet ist.".into(), + ); + } + if Registration::all_cox(db, self.trip_details_id).await.len() > 0 { + return Err( + "Event kann nicht gelöscht werden, weil mind. 1 Steuerperson angemeldet ist." + .into(), + ); + } + sqlx::query!("DELETE FROM planned_event WHERE id = ?", self.id) .execute(db) .await .unwrap(); //Okay, as PlannedEvent can only be created with proper DB backing + + Ok(()) } pub async fn get_ics_feed(db: &SqlitePool) -> String { From 1bf1cc9c680228ae96877cbec55de698a43734a1 Mon Sep 17 00:00:00 2001 From: philipp Date: Tue, 21 May 2024 18:34:17 +0200 Subject: [PATCH 2/2] inform user in case event can't be deleted --- src/tera/admin/planned_event.rs | 13 +++++++------ 1 file changed, 7 insertions(+), 6 deletions(-) diff --git a/src/tera/admin/planned_event.rs b/src/tera/admin/planned_event.rs index d198c30..18a04e9 100644 --- a/src/tera/admin/planned_event.rs +++ b/src/tera/admin/planned_event.rs @@ -78,12 +78,13 @@ async fn update( #[get("/planned-event//delete")] async fn delete(db: &State, id: i64, _admin: PlannedEventUser) -> Flash { - match PlannedEvent::find_by_id(db, id).await { - Some(planned_event) => { - planned_event.delete(db).await; - Flash::success(Redirect::to("/planned"), "Event gelöscht") - } - None => Flash::error(Redirect::to("/planned"), "PlannedEvent does not exist"), + let Some(event) = PlannedEvent::find_by_id(db, id).await else { + return Flash::error(Redirect::to("/planned"), "PlannedEvent does not exist"); + }; + + match event.delete(db).await { + Ok(()) => Flash::success(Redirect::to("/planned"), "Event gelöscht"), + Err(e) => Flash::error(Redirect::to("/planned"), e), } }