From ea72b06c18f2a02795cdb590d05f277cf7157da8 Mon Sep 17 00:00:00 2001 From: philipp Date: Fri, 28 Apr 2023 21:18:50 +0200 Subject: [PATCH 1/5] add migration --- migration.sql | 12 +++++++++++- 1 file changed, 11 insertions(+), 1 deletion(-) diff --git a/migration.sql b/migration.sql index 01a9b5e..a9d2fc6 100644 --- a/migration.sql +++ b/migration.sql @@ -13,7 +13,9 @@ CREATE TABLE IF NOT EXISTS "trip_details" ( "planned_starting_time" text NOT NULL, "max_people" INTEGER NOT NULL, "day" TEXT NOT NULL, - "notes" TEXT + "notes" TEXT, + "trip_type_id" INTEGER, + FOREIGN KEY(trip_type_id) REFERENCES trip_type(id) ); CREATE TABLE IF NOT EXISTS "planned_event" ( @@ -52,3 +54,11 @@ CREATE TABLE IF NOT EXISTS "log" ( "msg" text NOT NULL, "created_at" text NOT NULL DEFAULT CURRENT_TIMESTAMP ); + +CREATE TABLE IF NOT EXISTS "trip_type" ( + "id" integer NOT NULL PRIMARY KEY AUTOINCREMENT, + "name" text NOT NULL UNIQUE, + "desc" text NOT NULL, + "question" text NOT NULL, + "icon" text NOT NULL +); From 34e2b697ea24cea535ab1fe139c2580a24b3d119 Mon Sep 17 00:00:00 2001 From: philipp Date: Fri, 28 Apr 2023 21:19:01 +0200 Subject: [PATCH 2/5] add seeds --- seeds.sql | 1 + 1 file changed, 1 insertion(+) diff --git a/seeds.sql b/seeds.sql index 5b67d82..b860c99 100644 --- a/seeds.sql +++ b/seeds.sql @@ -12,3 +12,4 @@ INSERT INTO "planned_event" (name, planned_amount_cox, trip_details_id) VALUES(' INSERT INTO "trip_details" (planned_starting_time, max_people, day, notes) VALUES('11:00', 1, '1970-01-02', 'trip_details for trip from cox'); INSERT INTO "trip" (cox_id, trip_details_id) VALUES(4, 2); +INSERT INTO "trip_type" (name, desc, question, icon) VALUES ('Regatta', 'Regatta!', 'Kein normales Event. Das ist eine Regatta! Willst du wirklich teilnehmen?', '🏅') From bd5a28b3420335063c0c234786555aeeda2904ec Mon Sep 17 00:00:00 2001 From: philipp Date: Fri, 28 Apr 2023 21:19:30 +0200 Subject: [PATCH 3/5] send triptype to frontend --- src/model/mod.rs | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) diff --git a/src/model/mod.rs b/src/model/mod.rs index 0115c70..1029bf2 100644 --- a/src/model/mod.rs +++ b/src/model/mod.rs @@ -3,22 +3,23 @@ use serde::Serialize; use sqlx::SqlitePool; use self::{ - planned_event::{PlannedEvent, PlannedEventWithUser}, - trip::{Trip, TripWithUser}, + planned_event::{PlannedEvent, PlannedEventWithUserAndTriptype}, + trip::{Trip, TripWithUserAndType}, }; pub mod log; pub mod planned_event; pub mod trip; pub mod tripdetails; +pub mod triptype; pub mod user; pub mod usertrip; #[derive(Serialize)] pub struct Day { day: NaiveDate, - planned_events: Vec, - trips: Vec, + planned_events: Vec, + trips: Vec, } impl Day { From 3d5ad309043d11e37bf8af42494c287db38e4f7f Mon Sep 17 00:00:00 2001 From: philipp Date: Fri, 28 Apr 2023 21:19:51 +0200 Subject: [PATCH 4/5] send triptype to frontend --- src/model/planned_event.rs | 27 +++++++++++----- src/model/trip.rs | 18 ++++++++--- src/model/tripdetails.rs | 15 ++++++--- src/model/triptype.rs | 55 +++++++++++++++++++++++++++++++++ src/model/user.rs | 2 +- src/rest/admin/planned_event.rs | 2 ++ src/rest/cox.rs | 2 ++ src/rest/mod.rs | 9 ++++-- 8 files changed, 109 insertions(+), 21 deletions(-) create mode 100644 src/model/triptype.rs diff --git a/src/model/planned_event.rs b/src/model/planned_event.rs index 4d1fdd8..1012cc9 100644 --- a/src/model/planned_event.rs +++ b/src/model/planned_event.rs @@ -1,10 +1,10 @@ use chrono::NaiveDate; use serde::Serialize; -use sqlx::SqlitePool; +use sqlx::{FromRow, SqlitePool}; -use super::tripdetails::TripDetails; +use super::{tripdetails::TripDetails, triptype::TripType}; -#[derive(Serialize, Clone)] +#[derive(Serialize, Clone, FromRow)] pub struct PlannedEvent { pub id: i64, name: String, @@ -15,12 +15,14 @@ pub struct PlannedEvent { max_people: i64, day: String, notes: Option, + trip_type_id: Option, } #[derive(Serialize)] -pub struct PlannedEventWithUser { +pub struct PlannedEventWithUserAndTriptype { #[serde(flatten)] planned_event: PlannedEvent, + trip_type: Option, cox_needed: bool, cox: Vec, rower: Vec, @@ -39,7 +41,8 @@ impl PlannedEvent { sqlx::query_as!( Self, " -SELECT planned_event.id, name, planned_amount_cox, allow_guests, trip_details_id, planned_starting_time, max_people, day, notes +SELECT + planned_event.id, planned_event.name, planned_amount_cox, allow_guests, trip_details_id, planned_starting_time, max_people, day, notes, trip_type_id FROM planned_event INNER JOIN trip_details ON planned_event.trip_details_id = trip_details.id WHERE planned_event.id like ? @@ -51,11 +54,14 @@ WHERE planned_event.id like ? .ok() } - pub async fn get_for_day(db: &SqlitePool, day: NaiveDate) -> Vec { + pub async fn get_for_day( + db: &SqlitePool, + day: NaiveDate, + ) -> Vec { let day = format!("{day}"); let events = sqlx::query_as!( PlannedEvent, - "SELECT planned_event.id, name, planned_amount_cox, allow_guests, trip_details_id, planned_starting_time, max_people, day, notes + "SELECT planned_event.id, planned_event.name, planned_amount_cox, allow_guests, trip_details_id, planned_starting_time, max_people, day, notes, trip_type_id FROM planned_event INNER JOIN trip_details ON planned_event.trip_details_id = trip_details.id WHERE day=?", @@ -68,11 +74,16 @@ WHERE day=?", let mut ret = Vec::new(); for event in events { let cox = event.get_all_cox(db).await; - ret.push(PlannedEventWithUser { + let mut trip_type = None; + if let Some(trip_type_id) = event.trip_type_id { + trip_type = TripType::find_by_id(db, trip_type_id).await; + } + ret.push(PlannedEventWithUserAndTriptype { planned_event: event.clone(), cox_needed: event.planned_amount_cox > cox.len() as i64, cox, rower: event.get_all_rower(db).await, + trip_type, }); } ret diff --git a/src/model/trip.rs b/src/model/trip.rs index c40bbfa..fb9d8b8 100644 --- a/src/model/trip.rs +++ b/src/model/trip.rs @@ -5,6 +5,7 @@ use sqlx::SqlitePool; use super::{ planned_event::{PlannedEvent, Registration}, tripdetails::TripDetails, + triptype::TripType, user::CoxUser, }; @@ -18,13 +19,15 @@ pub struct Trip { max_people: i64, day: String, notes: Option, + trip_type_id: Option, } #[derive(Serialize)] -pub struct TripWithUser { +pub struct TripWithUserAndType { #[serde(flatten)] trip: Trip, rower: Vec, + trip_type: Option, } impl Trip { @@ -44,7 +47,7 @@ impl Trip { sqlx::query_as!( Self, " -SELECT trip.id, cox_id, user.name as cox_name, trip_details_id, planned_starting_time, max_people, day, notes +SELECT trip.id, cox_id, user.name as cox_name, trip_details_id, planned_starting_time, max_people, day, notes, trip_type_id FROM trip INNER JOIN trip_details ON trip.trip_details_id = trip_details.id INNER JOIN user ON trip.cox_id = user.id @@ -92,12 +95,12 @@ WHERE trip.id=? } } - pub async fn get_for_day(db: &SqlitePool, day: NaiveDate) -> Vec { + pub async fn get_for_day(db: &SqlitePool, day: NaiveDate) -> Vec { let day = format!("{day}"); let trips = sqlx::query_as!( Trip, " -SELECT trip.id, cox_id, user.name as cox_name, trip_details_id, planned_starting_time, max_people, day, notes +SELECT trip.id, cox_id, user.name as cox_name, trip_details_id, planned_starting_time, max_people, day, notes, trip_type_id FROM trip INNER JOIN trip_details ON trip.trip_details_id = trip_details.id INNER JOIN user ON trip.cox_id = user.id @@ -110,8 +113,13 @@ WHERE day=? .unwrap(); //TODO: fixme let mut ret = Vec::new(); for trip in trips { - ret.push(TripWithUser { + let mut trip_type = None; + if let Some(trip_type_id) = trip.trip_type_id { + trip_type = TripType::find_by_id(db, trip_type_id).await; + } + ret.push(TripWithUserAndType { trip: trip.clone(), + trip_type, rower: trip.get_all_rower(db).await, }); } diff --git a/src/model/tripdetails.rs b/src/model/tripdetails.rs index 663620d..fcdf28e 100644 --- a/src/model/tripdetails.rs +++ b/src/model/tripdetails.rs @@ -8,6 +8,7 @@ pub struct TripDetails { max_people: i64, day: String, notes: Option, + trip_type_id: Option, } impl TripDetails { @@ -15,7 +16,7 @@ impl TripDetails { sqlx::query_as!( TripDetails, " -SELECT id, planned_starting_time, max_people, day, notes +SELECT id, planned_starting_time, max_people, day, notes, trip_type_id FROM trip_details WHERE id like ? ", @@ -33,13 +34,15 @@ WHERE id like ? max_people: i32, day: String, notes: Option, + trip_type_id: Option, ) -> i64 { let query = sqlx::query!( - "INSERT INTO trip_details(planned_starting_time, max_people, day, notes) VALUES(?, ?, ?, ?)" , + "INSERT INTO trip_details(planned_starting_time, max_people, day, notes, trip_type_id) VALUES(?, ?, ?, ?, ?)" , planned_starting_time, max_people, day, - notes + notes, + trip_type_id ) .execute(db) .await @@ -94,11 +97,11 @@ mod test { let pool = testdb!(); assert_eq!( - TripDetails::create(&pool, "10:00".into(), 2, "1970-01-01".into(), None).await, + TripDetails::create(&pool, "10:00".into(), 2, "1970-01-01".into(), None, None).await, 3, ); assert_eq!( - TripDetails::create(&pool, "10:00".into(), 2, "1970-01-01".into(), None).await, + TripDetails::create(&pool, "10:00".into(), 2, "1970-01-01".into(), None, None).await, 4, ); } @@ -115,4 +118,6 @@ mod test { fn test_true_full() { //TODO: register user for trip_details = 1; check if is_full returns true } + + //TODO: add new tripdetails test with trip_type != None } diff --git a/src/model/triptype.rs b/src/model/triptype.rs new file mode 100644 index 0000000..f13e634 --- /dev/null +++ b/src/model/triptype.rs @@ -0,0 +1,55 @@ +use serde::{Deserialize, Serialize}; +use sqlx::{FromRow, SqlitePool}; + +#[derive(FromRow, Debug, Serialize, Deserialize, Clone)] +pub struct TripType { + pub id: i64, + name: String, + desc: String, + question: String, + icon: String, +} + +impl TripType { + pub async fn find_by_id(db: &SqlitePool, id: i64) -> Option { + sqlx::query_as!( + Self, + " +SELECT id, name, desc, question, icon +FROM trip_type +WHERE id like ? + ", + id + ) + .fetch_one(db) + .await + .ok() + } + + pub async fn all(db: &SqlitePool) -> Vec { + sqlx::query_as!( + Self, + " +SELECT id, name, desc, question, icon +FROM trip_type + " + ) + .fetch_all(db) + .await + .unwrap() //TODO: fixme + } +} + +#[cfg(test)] +mod test { + use crate::testdb; + + use sqlx::SqlitePool; + + #[sqlx::test] + fn test_find_true() { + let pool = testdb!(); + } + + //TODO: write tests +} diff --git a/src/model/user.rs b/src/model/user.rs index ac9f85b..767636b 100644 --- a/src/model/user.rs +++ b/src/model/user.rs @@ -16,7 +16,7 @@ pub struct User { pub name: String, pw: Option, pub is_cox: bool, - is_admin: bool, + pub is_admin: bool, is_guest: bool, #[serde(default = "bool::default")] deleted: bool, diff --git a/src/rest/admin/planned_event.rs b/src/rest/admin/planned_event.rs index 61cd20f..ff0c30f 100644 --- a/src/rest/admin/planned_event.rs +++ b/src/rest/admin/planned_event.rs @@ -18,6 +18,7 @@ struct AddPlannedEventForm { planned_starting_time: String, max_people: i32, notes: Option, + trip_type: Option, } #[post("/planned-event", data = "")] @@ -33,6 +34,7 @@ async fn create( data.max_people, data.day.clone(), data.notes.clone(), + data.trip_type, ) .await; diff --git a/src/rest/cox.rs b/src/rest/cox.rs index 5e379ea..caeefda 100644 --- a/src/rest/cox.rs +++ b/src/rest/cox.rs @@ -21,6 +21,7 @@ struct AddTripForm { planned_starting_time: String, max_people: i32, notes: Option, + trip_type: Option, } #[post("/trip", data = "")] @@ -32,6 +33,7 @@ async fn create(db: &State, data: Form, cox: CoxUser) - data.max_people, data.day.clone(), data.notes.clone(), + data.trip_type, ) .await; let trip_details = TripDetails::find_by_id(db, trip_details_id).await.unwrap(); //Okay, bc just diff --git a/src/rest/mod.rs b/src/rest/mod.rs index 4c8222b..327f848 100644 --- a/src/rest/mod.rs +++ b/src/rest/mod.rs @@ -13,6 +13,7 @@ use sqlx::SqlitePool; use crate::model::{ log::Log, tripdetails::TripDetails, + triptype::TripType, user::User, usertrip::{UserTrip, UserTripError}, Day, @@ -26,6 +27,8 @@ mod cox; async fn index(db: &State, user: User, flash: Option>) -> Template { let mut days = Vec::new(); + let mut context = Context::new(); + let mut show_next_n_days = 6; if user.is_cox { let end_of_year = NaiveDate::from_ymd_opt(Local::now().year(), 12, 31).unwrap(); @@ -34,14 +37,16 @@ async fn index(db: &State, user: User, flash: Option Date: Fri, 28 Apr 2023 21:30:13 +0200 Subject: [PATCH 5/5] reorder migratoin --- migration.sql | 15 ++++++++------- 1 file changed, 8 insertions(+), 7 deletions(-) diff --git a/migration.sql b/migration.sql index a9d2fc6..6f74a40 100644 --- a/migration.sql +++ b/migration.sql @@ -8,6 +8,14 @@ CREATE TABLE IF NOT EXISTS "user" ( "deleted" boolean NOT NULL DEFAULT FALSE ); +CREATE TABLE IF NOT EXISTS "trip_type" ( + "id" integer NOT NULL PRIMARY KEY AUTOINCREMENT, + "name" text NOT NULL UNIQUE, + "desc" text NOT NULL, + "question" text NOT NULL, + "icon" text NOT NULL +); + CREATE TABLE IF NOT EXISTS "trip_details" ( "id" integer NOT NULL PRIMARY KEY AUTOINCREMENT, "planned_starting_time" text NOT NULL, @@ -55,10 +63,3 @@ CREATE TABLE IF NOT EXISTS "log" ( "created_at" text NOT NULL DEFAULT CURRENT_TIMESTAMP ); -CREATE TABLE IF NOT EXISTS "trip_type" ( - "id" integer NOT NULL PRIMARY KEY AUTOINCREMENT, - "name" text NOT NULL UNIQUE, - "desc" text NOT NULL, - "question" text NOT NULL, - "icon" text NOT NULL -);