aboutsummaryrefslogtreecommitdiffstats
path: root/src/controllers
diff options
context:
space:
mode:
authorHarald Eilertsen <haraldei@anduin.net>2020-08-23 15:03:13 +0200
committerHarald Eilertsen <haraldei@anduin.net>2020-08-23 15:03:13 +0200
commit0a2d6fc06fc1988f860ab81fe53d1e6dae470407 (patch)
tree031cca26771c25a06c291a3c12551b8517451b72 /src/controllers
parent129e8d34906584b5e6c3eeeb18958fc5e2c39c33 (diff)
downloadramaskrik-social-0a2d6fc06fc1988f860ab81fe53d1e6dae470407.tar.gz
ramaskrik-social-0a2d6fc06fc1988f860ab81fe53d1e6dae470407.tar.bz2
ramaskrik-social-0a2d6fc06fc1988f860ab81fe53d1e6dae470407.zip
Implement deleting screenings from web ui.
Diffstat (limited to 'src/controllers')
-rw-r--r--src/controllers/screening.rs13
1 files changed, 12 insertions, 1 deletions
diff --git a/src/controllers/screening.rs b/src/controllers/screening.rs
index b76ae65..9e78130 100644
--- a/src/controllers/screening.rs
+++ b/src/controllers/screening.rs
@@ -22,7 +22,7 @@ use crate::{
};
use std::result::Result;
-use rocket::{get, post};
+use rocket::{delete, get, post};
use rocket::request::{Form, FromForm};
use rocket::response::Redirect;
use rocket_contrib::{
@@ -82,3 +82,14 @@ pub fn create_screening(db: db::Connection, screening: Form<NewScreeningForm>) -
db.create_screening(dbg!(screening.room_id), dbg!(screening.film_id), date, start_time, end_time)?;
Ok(Redirect::to("/screenings"))
}
+
+#[derive(FromForm)]
+pub struct DeleteScreeningForm {
+ screening_id: i32,
+}
+
+#[delete("/", format = "application/x-www-form-urlencoded", data = "<screening>")]
+pub fn delete(db: db::Connection, screening: Form<DeleteScreeningForm>) -> Result<Redirect, Box<dyn Error>> {
+ db.delete_screening(screening.screening_id)?;
+ Ok(Redirect::to("/screenings"))
+}