From cdc42d7154bccbf33c647bedc3a0759c21c223de Mon Sep 17 00:00:00 2001 From: Marie Birner Date: Thu, 9 Nov 2023 19:39:23 +0100 Subject: [PATCH 1/7] [BUGFIX] color text dark-mode --- templates/kiosk.html.tera | 2 +- templates/log.html.tera | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/templates/kiosk.html.tera b/templates/kiosk.html.tera index 321e7ca..7be754b 100644 --- a/templates/kiosk.html.tera +++ b/templates/kiosk.html.tera @@ -37,7 +37,7 @@ {{ log::show(log=log, state="on_water", allowed_to_close=true, only_ones=false) }} {% endfor %} {% else %} -

Kein Boot am Wasser

+

Kein Boot am Wasser

{% endif %} diff --git a/templates/log.html.tera b/templates/log.html.tera index dab1c77..24d54ee 100644 --- a/templates/log.html.tera +++ b/templates/log.html.tera @@ -39,7 +39,7 @@ {% endif %} {% endfor %} {% else %} -

Kein Boot am Wasser

+

Kein Boot am Wasser

{% endif %} From 9b86d93979f6e193a23ac86f3abb3cc999cf97d3 Mon Sep 17 00:00:00 2001 From: philipp Date: Thu, 9 Nov 2023 22:02:31 +0100 Subject: [PATCH 2/7] try to get new people --- templates/includes/footer.html.tera | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/templates/includes/footer.html.tera b/templates/includes/footer.html.tera index abdc14c..2d74b77 100644 --- a/templates/includes/footer.html.tera +++ b/templates/includes/footer.html.tera @@ -2,7 +2,7 @@
- ASKÖ Ruderverein Donau Linz © {{ now() | date(format="%Y") }} + Erstellt vom ASKÖ Ruderverein Donau Linz ... und dir?
From e5f6a543e1cbaae10688cb4c02edfbaa4ac26909 Mon Sep 17 00:00:00 2001 From: philipp Date: Fri, 10 Nov 2023 09:03:04 +0100 Subject: [PATCH 3/7] improve text --- templates/includes/footer.html.tera | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/templates/includes/footer.html.tera b/templates/includes/footer.html.tera index 2d74b77..4e2a942 100644 --- a/templates/includes/footer.html.tera +++ b/templates/includes/footer.html.tera @@ -2,7 +2,7 @@
- Erstellt vom ASKÖ Ruderverein Donau Linz ... und dir? + Erstellt vom ASKÖ Ruderverein Donau Linz ... und dir?
From a3c7461c2b89be5aa581366bb1722a0c54e880b7 Mon Sep 17 00:00:00 2001 From: philipp Date: Tue, 14 Nov 2023 23:09:33 +0100 Subject: [PATCH 4/7] don't allow to add entry which is not completed today --- src/model/logbook.rs | 20 ++++++++++++-------- src/tera/log.rs | 2 ++ 2 files changed, 14 insertions(+), 8 deletions(-) diff --git a/src/model/logbook.rs b/src/model/logbook.rs index 21913c3..eb1442a 100644 --- a/src/model/logbook.rs +++ b/src/model/logbook.rs @@ -1,4 +1,4 @@ -use chrono::NaiveDateTime; +use chrono::{NaiveDateTime, Utc}; use rocket::FromForm; use serde::Serialize; use sqlx::{FromRow, Sqlite, SqlitePool, Transaction}; @@ -99,6 +99,7 @@ pub enum LogbookUpdateError { ShipmasterNotInRowers, SteeringPersonNotInRowers, UserNotAllowedToUseBoat, + OnlyAllowedToEndTripsEndingToday, } #[derive(Debug, PartialEq)] @@ -120,6 +121,7 @@ pub enum LogbookCreateError { ShipmasterNotInRowers, NotYourEntry, ArrivalSetButNotRemainingTwo, + OnlyAllowedToEndTripsEndingToday, } impl From for LogbookCreateError { @@ -140,6 +142,9 @@ impl From for LogbookCreateError { LogbookUpdateError::UserNotAllowedToUseBoat => { LogbookCreateError::UserNotAllowedToUseBoat } + LogbookUpdateError::OnlyAllowedToEndTripsEndingToday => { + LogbookCreateError::OnlyAllowedToEndTripsEndingToday + } } } } @@ -446,13 +451,8 @@ ORDER BY departure DESC } if !boat.shipmaster_allowed(user).await && self.shipmaster != user.id { - //second part: - //shipmaster has - //entered a - //different user, - //then the user - //should be able - //to `home` it + //second part: shipmaster has entered a different user, then the user should be able to + //`home` it return Err(LogbookUpdateError::UserNotAllowedToUseBoat); } @@ -468,6 +468,10 @@ ORDER BY departure DESC if arr.timestamp() <= dep.timestamp() { return Err(LogbookUpdateError::ArrivalNotAfterDeparture); } + let today = Utc::now().date_naive(); + if arr.date() != today && !user.is_admin { + return Err(LogbookUpdateError::OnlyAllowedToEndTripsEndingToday); + } Log::create_with_tx(db, format!("New trip: {log:?}")).await; diff --git a/src/tera/log.rs b/src/tera/log.rs index 1b1ca87..0c7dd6f 100644 --- a/src/tera/log.rs +++ b/src/tera/log.rs @@ -182,6 +182,7 @@ async fn create_logbook( Err(LogbookCreateError::ShipmasterNotInRowers) => Flash::error(Redirect::to("/log"), "Schiffsführer nicht in Liste der Ruderer!"), Err(LogbookCreateError::NotYourEntry) => Flash::error(Redirect::to("/log"), "Nicht deine Ausfahrt!"), Err(LogbookCreateError::ArrivalSetButNotRemainingTwo) => Flash::error(Redirect::to("/log"), "Ankunftszeit gesetzt aber nicht Distanz + Strecke"), + Err(LogbookCreateError::OnlyAllowedToEndTripsEndingToday) => Flash::error(Redirect::to("/log"), format!("Nur Ausfahrten, die heute enden dürfen eingetragen werden. Für einen Nachtrag schreibe alle Daten Philipp (Tel. nr. siehe Signal oder it@rudernlinz.at).")), } } @@ -251,6 +252,7 @@ async fn home_logbook( match logbook.home(db, &user.user, data.into_inner()).await { Ok(_) => Flash::success(Redirect::to("/log"), "Ausfahrt korrekt eingetragen"), Err(LogbookUpdateError::TooManyRowers(expected, actual)) => Flash::error(Redirect::to("/log"), format!("Zu viele Ruderer (Boot fasst maximal {expected}, es wurden jedoch {actual} Ruderer ausgewählt)")), + Err(LogbookUpdateError::OnlyAllowedToEndTripsEndingToday) => Flash::error(Redirect::to("/log"), format!("Nur Ausfahrten, die heute enden dürfen eingetragen werden. Für einen Nachtrag schreibe alle Daten Philipp (Tel. nr. siehe Signal oder it@rudernlinz.at).")), Err(e) => Flash::error( Redirect::to("/log"), format!("Eintrag {logbook_id} konnte nicht abgesendet werden (Fehler: {e:?})!"), From 59b5b1bf974485ec82ce2adac3b95b7514fb1a8f Mon Sep 17 00:00:00 2001 From: philipp Date: Wed, 15 Nov 2023 18:27:46 +0100 Subject: [PATCH 5/7] use new fancy rudernlinz links --- templates/ergo.html.tera | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/templates/ergo.html.tera b/templates/ergo.html.tera index 5f2ece2..b134ed7 100644 --- a/templates/ergo.html.tera +++ b/templates/ergo.html.tera @@ -20,7 +20,7 @@
  • Überblick der Challenges
  • Eintragung ist jederzeit möglich, alle Daten die bis Sonntag 23:59 hier hochgeladen wurden, werden gesammelt an die Ister Ergo Challenge geschickt
  • Dientag + Donnerstag → gemeinsames Training; bitte um Anmeldung, damit jeder einen Ergo hat
  • -
  • Offizielle Ergebnisse, bei Fehlern direkt mit Christian (Ister) Kontakt aufnehmen
  • +
  • Offizielle Ergebnisse: Dirty Thirty (rudernlinz.at/dt) / Dirty Dozen (rudernlinz.at/dd), bei Fehlern direkt mit Christian (Ister) Kontakt aufnehmen
  • Noch mehr Infos zur Ergo-Challenge findest du hier
  • From 5b4238da92e61fcdd9d37e2903d53e235fa720e0 Mon Sep 17 00:00:00 2001 From: philipp Date: Thu, 16 Nov 2023 15:35:52 +0100 Subject: [PATCH 6/7] update tests to use current date --- src/model/logbook.rs | 6 ++++-- src/tera/log.rs | 31 ++++++++++++++++++++----------- 2 files changed, 24 insertions(+), 13 deletions(-) diff --git a/src/model/logbook.rs b/src/model/logbook.rs index eb1442a..f837de9 100644 --- a/src/model/logbook.rs +++ b/src/model/logbook.rs @@ -797,6 +797,8 @@ mod test { let logbook = Logbook::find_by_id(&pool, 1).await.unwrap(); let user = User::find_by_id(&pool, 2).await.unwrap(); + let current_date = chrono::Local::now().format("%Y-%m-%d").to_string(); + logbook .home( &pool, @@ -810,8 +812,8 @@ mod test { shipmaster: Some(2), steering_person: Some(2), shipmaster_only_steering: false, - departure: "1990-01-01T10:00".into(), - arrival: "1990-01-01T12:00".into(), + departure: format!("{}T10:00", current_date), + arrival: format!("{}T12:00", current_date), }, ) .await diff --git a/src/tera/log.rs b/src/tera/log.rs index 0c7dd6f..7d7c0ca 100644 --- a/src/tera/log.rs +++ b/src/tera/log.rs @@ -524,11 +524,12 @@ mod test { .header(ContentType::Form) // Set the content type to form .body("name=admin&password=admin"); // Add the form data to the request body; login.dispatch().await; + let current_date = chrono::Local::now().format("%Y-%m-%d").to_string(); - let req = client - .post("/log") - .header(ContentType::Form) - .body("boat_id=1&shipmaster=4&departure=2199-12-31T10:00&steering_person=4&rowers[]=4"); + let req = client.post("/log").header(ContentType::Form).body(format!( + "boat_id=1&shipmaster=4&departure={0}T10:00&steering_person=4&rowers[]=4", + current_date + )); let response = req.dispatch().await; assert_eq!(response.status(), Status::SeeOther); @@ -556,10 +557,12 @@ mod test { let req = client.get("/log/kiosk/ekrv2019/Linz"); let _ = req.dispatch().await; + let current_date = chrono::Local::now().format("%Y-%m-%d").to_string(); + let req = client .post("/log/1") .header(ContentType::Form) - .body("destination=Ottensheim&distance_in_km=25&shipmaster=2&steering_person=2&departure=1990-01-01T10:00&arrival=1990-01-01T12:00&rowers[]=2"); + .body(format!("destination=Ottensheim&distance_in_km=25&shipmaster=2&steering_person=2&departure={0}T10:00&arrival={0}T12:00&rowers[]=2", current_date)); let response = req.dispatch().await; assert_eq!(response.status(), Status::SeeOther); @@ -666,9 +669,10 @@ mod test { .unwrap() .id; let shipmaster_id = User::find_by_name(&db, "rower2".into()).await.unwrap().id; + let current_date = chrono::Local::now().format("%Y-%m-%d").to_string(); let req = client.post("/log").header(ContentType::Form).body(format!( - "boat_id={boat_id}&shipmaster={shipmaster_id}&departure=1199-12-31T10:00&steering_person={shipmaster_id}&rowers[]={shipmaster_id}" + "boat_id={boat_id}&shipmaster={shipmaster_id}&departure={0}T10:00&steering_person={shipmaster_id}&rowers[]={shipmaster_id}", current_date )); let response = req.dispatch().await; @@ -697,7 +701,7 @@ mod test { let req = client .post(format!("/log/{log_id}")) .header(ContentType::Form) - .body(format!("destination=Ottensheim&distance_in_km=25&shipmaster={shipmaster_id}&steering_person={shipmaster_id}&departure=1990-01-01T10:00&arrival=1990-01-01T12:00&rowers[]={shipmaster_id}")); + .body(format!("destination=Ottensheim&distance_in_km=25&shipmaster={shipmaster_id}&steering_person={shipmaster_id}&departure={0}T10:00&arrival=1990-01-01T12:00&rowers[]={shipmaster_id}", current_date)); let response = req.dispatch().await; assert_eq!(response.status(), Status::SeeOther); @@ -884,11 +888,12 @@ mod test { .header(ContentType::Form) // Set the content type to form .body("name=rower2&password=rower"); // Add the form data to the request body; login.dispatch().await; + let current_date = chrono::Local::now().format("%Y-%m-%d").to_string(); let req = client .post("/log/1") .header(ContentType::Form) - .body("destination=Ottensheim&distance_in_km=25&shipmaster=1&steering_person=1&departure=1199-12-12T10:00&arrival=1199-12-12T12:00&rowers[]=1"); + .body(format!("destination=Ottensheim&distance_in_km=25&shipmaster=1&steering_person=1&departure={0}T10:00&arrival={0}T12:00&rowers[]=1", current_date)); let response = req.dispatch().await; assert_eq!(response.status(), Status::SeeOther); @@ -914,8 +919,10 @@ mod test { let boat_id = Boat::find_by_name(db, boat_name).await.unwrap().id; let shipmaster_id = User::find_by_name(db, &shipmaster_name).await.unwrap().id; + let current_date = chrono::Local::now().format("%Y-%m-%d").to_string(); + let req = client.post("/log").header(ContentType::Form).body(format!( - "boat_id={boat_id}&shipmaster={shipmaster_id}&departure=1199-12-31T10:00&steering_person={shipmaster_id}&rowers[]={shipmaster_id}" + "boat_id={boat_id}&shipmaster={shipmaster_id}&departure={current_date}T10:00&steering_person={shipmaster_id}&rowers[]={shipmaster_id}" )); let response = req.dispatch().await; @@ -937,7 +944,7 @@ mod test { let req = client .post(format!("/log/{log_id}")) .header(ContentType::Form) - .body(format!("destination=Ottensheim&distance_in_km=25&shipmaster={shipmaster_id}&steering_person={shipmaster_id}&departure=1199-12-31T10:00&arrival=1199-12-31T12:00&rowers[]={shipmaster_id}")); + .body(format!("destination=Ottensheim&distance_in_km=25&shipmaster={shipmaster_id}&steering_person={shipmaster_id}&departure={current_date}T10:00&arrival={current_date}T12:00&rowers[]={shipmaster_id}")); let response = req.dispatch().await; assert_eq!(response.status(), Status::SeeOther); @@ -964,8 +971,10 @@ mod test { let boat_id = Boat::find_by_name(db, boat_name).await.unwrap().id; let shipmaster_id = User::find_by_name(db, &shipmaster_name).await.unwrap().id; + let current_date = chrono::Local::now().format("%Y-%m-%d").to_string(); + let req = client.post("/log").header(ContentType::Form).body(format!( - "boat_id={boat_id}&shipmaster={shipmaster_id}&departure=2199-12-31T10:00&steering_person={shipmaster_id}&rowers[]={shipmaster_id}" + "boat_id={boat_id}&shipmaster={shipmaster_id}&departure={current_date}T10:00&steering_person={shipmaster_id}&rowers[]={shipmaster_id}" )); let response = req.dispatch().await; From a87832e4f4e9bbeb2e14a5fcc6102b84141663b4 Mon Sep 17 00:00:00 2001 From: philipp Date: Thu, 16 Nov 2023 15:36:38 +0100 Subject: [PATCH 7/7] update tests to use current date --- src/tera/log.rs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/tera/log.rs b/src/tera/log.rs index 7d7c0ca..ea006e7 100644 --- a/src/tera/log.rs +++ b/src/tera/log.rs @@ -701,7 +701,7 @@ mod test { let req = client .post(format!("/log/{log_id}")) .header(ContentType::Form) - .body(format!("destination=Ottensheim&distance_in_km=25&shipmaster={shipmaster_id}&steering_person={shipmaster_id}&departure={0}T10:00&arrival=1990-01-01T12:00&rowers[]={shipmaster_id}", current_date)); + .body(format!("destination=Ottensheim&distance_in_km=25&shipmaster={shipmaster_id}&steering_person={shipmaster_id}&departure={0}T10:00&arrival={0}T12:00&rowers[]={shipmaster_id}", current_date)); let response = req.dispatch().await; assert_eq!(response.status(), Status::SeeOther);