Add saving periods

This commit is contained in:
Tobias Reisinger 2021-11-05 16:32:30 +01:00
parent 12d57d020f
commit 483fd60daa
13 changed files with 271 additions and 52 deletions

View file

@ -1,20 +1,18 @@
use std::env;
use diesel::dsl::sql;
use diesel::prelude::*;
use diesel_migrations::embed_migrations;
use dotenv::dotenv;
use errors::DatabaseError;
use models::*;
use schema::schedules::dsl::*;
use crate::types::EmgauwaUid;
pub mod errors;
pub mod models;
pub mod schema;
mod types;
use diesel::prelude::*;
use diesel::dsl::sql;
use dotenv::dotenv;
use std::env;
use models::*;
use schema::schedules::dsl::*;
use diesel_migrations::embed_migrations;
use errors::DatabaseError;
use types::EmgauwaUid;
embed_migrations!("migrations");
@ -34,18 +32,27 @@ pub fn run_migrations() {
pub fn get_schedules() -> Vec<Schedule> {
let connection = get_connection();
schedules
.limit(5)
.load::<Schedule>(&connection)
.expect("Error loading schedules")
}
pub fn create_schedule(new_name: &str) -> Result<Schedule, DatabaseError> {
pub fn get_schedule_by_uid(filter_uid: EmgauwaUid) -> Result<Schedule, DatabaseError> {
let connection = get_connection();
let result = schedules
.filter(uid.eq(filter_uid))
.first::<Schedule>(&connection)
.or(Err(DatabaseError::NotFound))?;
Ok(result)
}
pub fn create_schedule(new_name: &str, new_periods: &Periods) -> Result<Schedule, DatabaseError> {
let connection = get_connection();
let new_schedule = NewSchedule {
uid: &EmgauwaUid::default(),
name: new_name,
periods: "",
periods: new_periods
};
diesel::insert_into(schedules)