2023-04-04 12:19:56 +02:00
|
|
|
use chrono::NaiveDate;
|
|
|
|
use serde::Serialize;
|
|
|
|
use sqlx::SqlitePool;
|
|
|
|
|
2023-04-04 15:16:21 +02:00
|
|
|
#[derive(Serialize, Clone)]
|
2023-04-04 12:19:56 +02:00
|
|
|
pub struct PlannedEvent {
|
|
|
|
id: i64,
|
|
|
|
name: String,
|
|
|
|
planned_amount_cox: i64,
|
|
|
|
allow_guests: bool,
|
|
|
|
trip_details_id: i64,
|
|
|
|
planned_starting_time: String,
|
|
|
|
max_people: i64,
|
|
|
|
day: String,
|
|
|
|
notes: Option<String>,
|
|
|
|
}
|
|
|
|
|
2023-04-04 15:16:21 +02:00
|
|
|
#[derive(Serialize)]
|
|
|
|
pub struct PlannedEventWithUser {
|
|
|
|
#[serde(flatten)]
|
|
|
|
planned_event: PlannedEvent,
|
2023-04-06 20:08:58 +02:00
|
|
|
cox_needed: bool,
|
2023-04-05 17:25:22 +02:00
|
|
|
cox: Vec<Registration>,
|
|
|
|
rower: Vec<Registration>,
|
|
|
|
}
|
|
|
|
|
|
|
|
//TODO: move to appropriate place
|
|
|
|
#[derive(Serialize)]
|
|
|
|
pub struct Registration {
|
|
|
|
pub name: String,
|
|
|
|
pub registered_at: String,
|
2023-04-04 15:16:21 +02:00
|
|
|
}
|
|
|
|
|
2023-04-04 12:19:56 +02:00
|
|
|
impl PlannedEvent {
|
2023-04-04 15:16:21 +02:00
|
|
|
pub async fn get_for_day(db: &SqlitePool, day: NaiveDate) -> Vec<PlannedEventWithUser> {
|
2023-04-04 19:49:27 +02:00
|
|
|
let day = format!("{day}");
|
2023-04-04 15:16:21 +02:00
|
|
|
let events = sqlx::query_as!(
|
2023-04-04 12:19:56 +02:00
|
|
|
PlannedEvent,
|
2023-04-04 19:49:27 +02:00
|
|
|
"SELECT planned_event.id, name, planned_amount_cox, allow_guests, trip_details_id, planned_starting_time, max_people, day, notes
|
2023-04-04 12:19:56 +02:00
|
|
|
FROM planned_event
|
|
|
|
INNER JOIN trip_details ON planned_event.trip_details_id = trip_details.id
|
2023-04-04 19:49:27 +02:00
|
|
|
WHERE day=?",
|
2023-04-04 12:23:41 +02:00
|
|
|
day
|
2023-04-04 12:19:56 +02:00
|
|
|
)
|
|
|
|
.fetch_all(db)
|
|
|
|
.await
|
2023-04-04 15:16:21 +02:00
|
|
|
.unwrap(); //TODO: fixme
|
|
|
|
|
|
|
|
let mut ret = Vec::new();
|
|
|
|
for event in events {
|
2023-04-06 20:08:58 +02:00
|
|
|
let cox = Self::get_all_cox_for_id(db, event.id).await;
|
2023-04-04 15:16:21 +02:00
|
|
|
ret.push(PlannedEventWithUser {
|
|
|
|
planned_event: event.clone(),
|
2023-04-06 20:08:58 +02:00
|
|
|
cox_needed: event.planned_amount_cox > cox.len() as i64,
|
|
|
|
cox,
|
2023-04-04 15:16:21 +02:00
|
|
|
rower: Self::get_all_rower_for_id(db, event.id).await,
|
2023-04-04 19:49:27 +02:00
|
|
|
});
|
2023-04-04 15:16:21 +02:00
|
|
|
}
|
|
|
|
ret
|
|
|
|
}
|
|
|
|
|
2023-04-05 22:01:50 +02:00
|
|
|
pub async fn is_full(db: &SqlitePool, trip_details_id: i64) -> bool {
|
2023-04-04 15:16:21 +02:00
|
|
|
let amount_currently_registered = sqlx::query!(
|
2023-04-04 19:49:27 +02:00
|
|
|
"SELECT COUNT(*) as count FROM user_trip WHERE trip_details_id = ?",
|
2023-04-04 15:16:21 +02:00
|
|
|
trip_details_id
|
|
|
|
)
|
|
|
|
.fetch_one(db)
|
|
|
|
.await
|
|
|
|
.unwrap(); //TODO: fixme
|
2023-04-04 19:49:27 +02:00
|
|
|
let amount_currently_registered = i64::from(amount_currently_registered.count);
|
2023-04-04 15:16:21 +02:00
|
|
|
|
|
|
|
let amount_allowed_to_register = sqlx::query!(
|
2023-04-05 17:25:22 +02:00
|
|
|
"SELECT max_people FROM trip_details WHERE id = ?",
|
2023-04-04 15:16:21 +02:00
|
|
|
trip_details_id
|
|
|
|
)
|
|
|
|
.fetch_one(db)
|
|
|
|
.await
|
|
|
|
.unwrap(); //TODO: fixme
|
|
|
|
let amount_allowed_to_register = amount_allowed_to_register.max_people;
|
|
|
|
|
2023-04-05 22:01:50 +02:00
|
|
|
amount_currently_registered >= amount_allowed_to_register
|
2023-04-04 15:16:21 +02:00
|
|
|
}
|
|
|
|
|
2023-04-05 17:25:22 +02:00
|
|
|
async fn get_all_cox_for_id(db: &SqlitePool, id: i64) -> Vec<Registration> {
|
|
|
|
sqlx::query_as!(
|
|
|
|
Registration,
|
2023-04-04 15:16:21 +02:00
|
|
|
"
|
2023-04-05 17:25:22 +02:00
|
|
|
SELECT (SELECT name FROM user WHERE cox_id = id) as name, (SELECT created_at FROM user WHERE cox_id = id) as registered_at FROM trip WHERE planned_event_id = ?
|
2023-04-04 15:16:21 +02:00
|
|
|
",
|
|
|
|
id
|
|
|
|
)
|
|
|
|
.fetch_all(db)
|
|
|
|
.await
|
2023-04-05 17:25:22 +02:00
|
|
|
.unwrap() //TODO: fixme
|
2023-04-04 15:16:21 +02:00
|
|
|
}
|
|
|
|
|
2023-04-05 17:25:22 +02:00
|
|
|
async fn get_all_rower_for_id(db: &SqlitePool, id: i64) -> Vec<Registration> {
|
|
|
|
sqlx::query_as!(
|
|
|
|
Registration,
|
2023-04-04 15:16:21 +02:00
|
|
|
"
|
2023-04-05 17:25:22 +02:00
|
|
|
SELECT
|
|
|
|
(SELECT name FROM user WHERE user_trip.user_id = user.id) as name,
|
|
|
|
(SELECT created_at FROM user WHERE user_trip.user_id = user.id) as registered_at
|
|
|
|
FROM user_trip WHERE trip_details_id = (SELECT trip_details_id FROM planned_event WHERE id = ?)
|
2023-04-04 15:16:21 +02:00
|
|
|
",
|
|
|
|
id
|
|
|
|
)
|
|
|
|
.fetch_all(db)
|
|
|
|
.await
|
2023-04-05 17:25:22 +02:00
|
|
|
.unwrap() //TODO: fixme
|
2023-04-04 12:19:56 +02:00
|
|
|
}
|
|
|
|
|
2023-04-04 19:49:27 +02:00
|
|
|
pub async fn create(
|
2023-04-04 12:19:56 +02:00
|
|
|
db: &SqlitePool,
|
|
|
|
name: String,
|
|
|
|
planned_amount_cox: i32,
|
|
|
|
allow_guests: bool,
|
|
|
|
trip_details_id: i64,
|
|
|
|
) {
|
|
|
|
sqlx::query!(
|
|
|
|
"INSERT INTO planned_event(name, planned_amount_cox, allow_guests, trip_details_id) VALUES(?, ?, ?, ?)",
|
|
|
|
name, planned_amount_cox, allow_guests, trip_details_id
|
|
|
|
)
|
|
|
|
.execute(db)
|
|
|
|
.await
|
|
|
|
.unwrap(); //TODO: fixme
|
|
|
|
}
|
|
|
|
|
|
|
|
pub async fn delete(db: &SqlitePool, id: i64) {
|
|
|
|
sqlx::query!("DELETE FROM planned_event WHERE id = ?", id)
|
|
|
|
.execute(db)
|
|
|
|
.await
|
|
|
|
.unwrap(); //TODO: fixme
|
|
|
|
}
|
|
|
|
}
|