Compare commits
No commits in common. "277b1592004d6743d034310c9a0bc9022bdaa202" and "929985c64af0a69db30c89e3c03d22294fc0935c" have entirely different histories.
277b159200
...
929985c64a
8 changed files with 50 additions and 47 deletions
|
@ -5,10 +5,11 @@ use sqlx::Sqlite;
|
|||
|
||||
use crate::db::{DbRelay, DbSchedule};
|
||||
use crate::errors::DatabaseError;
|
||||
use crate::types::Weekday;
|
||||
|
||||
pub struct DbJunctionRelaySchedule {
|
||||
pub id: i64,
|
||||
pub weekday: i64,
|
||||
pub weekday: Weekday,
|
||||
pub relay_id: i64,
|
||||
pub schedule_id: i64,
|
||||
}
|
||||
|
@ -31,7 +32,7 @@ impl DbJunctionRelaySchedule {
|
|||
pub async fn get_junction_by_relay_and_weekday(
|
||||
conn: &mut PoolConnection<Sqlite>,
|
||||
relay: &DbRelay,
|
||||
weekday: i64,
|
||||
weekday: Weekday,
|
||||
) -> Result<Option<DbJunctionRelaySchedule>, DatabaseError> {
|
||||
sqlx::query_as!(
|
||||
DbJunctionRelaySchedule,
|
||||
|
@ -64,7 +65,7 @@ impl DbJunctionRelaySchedule {
|
|||
pub async fn get_schedule(
|
||||
conn: &mut PoolConnection<Sqlite>,
|
||||
relay: &DbRelay,
|
||||
weekday: i64,
|
||||
weekday: Weekday,
|
||||
) -> Result<Option<DbSchedule>, DatabaseError> {
|
||||
sqlx::query_as!(
|
||||
DbSchedule,
|
||||
|
@ -100,7 +101,7 @@ impl DbJunctionRelaySchedule {
|
|||
conn: &mut PoolConnection<Sqlite>,
|
||||
relay: &DbRelay,
|
||||
schedule: &DbSchedule,
|
||||
weekday: i64,
|
||||
weekday: Weekday,
|
||||
) -> Result<DbJunctionRelaySchedule, DatabaseError> {
|
||||
match Self::get_junction_by_relay_and_weekday(conn, relay, weekday).await? {
|
||||
None => sqlx::query_as!(
|
||||
|
@ -138,7 +139,7 @@ impl DbJunctionRelaySchedule {
|
|||
schedules: Vec<&DbSchedule>,
|
||||
) -> Result<(), DatabaseError> {
|
||||
for (weekday, schedule) in schedules.iter().enumerate() {
|
||||
Self::set_schedule(conn, relay, schedule, weekday as i64).await?;
|
||||
Self::set_schedule(conn, relay, schedule, weekday as Weekday).await?;
|
||||
}
|
||||
Ok(())
|
||||
}
|
||||
|
|
|
@ -4,8 +4,10 @@ use serde_derive::{Deserialize, Serialize};
|
|||
use sqlx::pool::PoolConnection;
|
||||
use sqlx::Sqlite;
|
||||
|
||||
use crate::db::{DbController, DbJunctionTag, DbTag};
|
||||
use crate::db::{DbController, DbJunctionRelaySchedule, DbJunctionTag, DbSchedule, DbTag};
|
||||
use crate::errors::DatabaseError;
|
||||
use crate::types::Weekday;
|
||||
use crate::utils;
|
||||
|
||||
#[derive(Debug, Clone, Serialize, Deserialize)]
|
||||
pub struct DbRelay {
|
||||
|
@ -161,4 +163,14 @@ impl DbRelay {
|
|||
.await?
|
||||
.ok_or(DatabaseError::NotFound)
|
||||
}
|
||||
|
||||
pub async fn get_active_schedule(
|
||||
&self,
|
||||
conn: &mut PoolConnection<Sqlite>,
|
||||
) -> Result<DbSchedule, DatabaseError> {
|
||||
let weekday = utils::get_weekday();
|
||||
DbJunctionRelaySchedule::get_schedule(conn, self, weekday as Weekday)
|
||||
.await?
|
||||
.ok_or(DatabaseError::NotFound)
|
||||
}
|
||||
}
|
||||
|
|
|
@ -69,7 +69,7 @@ impl Controller {
|
|||
.iter_mut()
|
||||
.filter_map(|r| {
|
||||
r.reload_active_schedule(now.weekday);
|
||||
r.get_next_time(&now.time)
|
||||
r.active_schedule.get_next_time(&now.time)
|
||||
})
|
||||
.min()
|
||||
}
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
use std::time::Instant;
|
||||
|
||||
use chrono::{NaiveTime, Weekday};
|
||||
use chrono::NaiveTime;
|
||||
use futures::executor::block_on;
|
||||
use serde_derive::{Deserialize, Serialize};
|
||||
use sqlx::pool::PoolConnection;
|
||||
|
@ -9,7 +9,7 @@ use sqlx::Sqlite;
|
|||
use crate::db::{DbController, DbJunctionRelaySchedule, DbRelay, DbSchedule};
|
||||
use crate::errors::DatabaseError;
|
||||
use crate::models::FromDbModel;
|
||||
use crate::types::{EmgauwaUid, RelayState};
|
||||
use crate::types::{EmgauwaUid, RelayState, Weekday};
|
||||
use crate::utils;
|
||||
|
||||
#[derive(Serialize, Deserialize, Debug, Clone)]
|
||||
|
@ -19,7 +19,7 @@ pub struct Relay {
|
|||
pub controller: DbController,
|
||||
pub controller_id: EmgauwaUid,
|
||||
pub schedules: Vec<DbSchedule>,
|
||||
pub active_schedule: Option<DbSchedule>,
|
||||
pub active_schedule: DbSchedule,
|
||||
pub override_schedule: Option<DbSchedule>,
|
||||
pub is_on: Option<bool>,
|
||||
pub tags: Vec<String>,
|
||||
|
@ -29,7 +29,7 @@ pub struct Relay {
|
|||
pub pulsing: Option<Instant>,
|
||||
#[serde(
|
||||
skip,
|
||||
default = "utils::default_weekday",
|
||||
default = "utils::get_weekday",
|
||||
)]
|
||||
pub override_schedule_weekday: Weekday,
|
||||
}
|
||||
|
@ -55,6 +55,7 @@ impl FromDbModel for Relay {
|
|||
let controller_id = cache.uid.clone();
|
||||
|
||||
let schedules = block_on(DbJunctionRelaySchedule::get_schedules(conn, &db_model))?;
|
||||
let active_schedule = block_on(db_model.get_active_schedule(conn))?;
|
||||
|
||||
let is_on = None;
|
||||
|
||||
|
@ -63,12 +64,12 @@ impl FromDbModel for Relay {
|
|||
controller: cache,
|
||||
controller_id,
|
||||
schedules,
|
||||
active_schedule: None,
|
||||
active_schedule,
|
||||
override_schedule: None,
|
||||
is_on,
|
||||
tags,
|
||||
pulsing: None,
|
||||
override_schedule_weekday: utils::default_weekday(),
|
||||
override_schedule_weekday: Weekday::default(),
|
||||
})
|
||||
}
|
||||
}
|
||||
|
@ -78,23 +79,17 @@ impl Relay {
|
|||
self.r = block_on(self.r.reload(conn))?;
|
||||
self.schedules = block_on(DbJunctionRelaySchedule::get_schedules(conn, &self.r))?;
|
||||
|
||||
self.reload_active_schedule(utils::get_weekday());
|
||||
|
||||
Ok(())
|
||||
}
|
||||
|
||||
pub fn is_on(&self, now: &NaiveTime) -> bool {
|
||||
if let Some(active_schedule) = &self.active_schedule {
|
||||
active_schedule.is_on(now)
|
||||
} else {
|
||||
false
|
||||
}
|
||||
self.active_schedule.is_on(now)
|
||||
}
|
||||
|
||||
pub fn get_next_time(&self, now: &NaiveTime) -> Option<NaiveTime> {
|
||||
if let Some(active_schedule) = &self.active_schedule {
|
||||
active_schedule.get_next_time(now)
|
||||
} else {
|
||||
None
|
||||
}
|
||||
self.active_schedule.get_next_time(now)
|
||||
}
|
||||
|
||||
pub fn check_pulsing(&mut self, now: &Instant) -> Option<Instant> {
|
||||
|
@ -114,7 +109,7 @@ impl Relay {
|
|||
pub fn reload_active_schedule(&mut self, weekday: Weekday) {
|
||||
if let Some(schedule) = &self.override_schedule {
|
||||
if self.override_schedule_weekday == weekday {
|
||||
self.active_schedule = Some(schedule.clone());
|
||||
self.active_schedule = schedule.clone();
|
||||
return;
|
||||
}
|
||||
if self.override_schedule_weekday != weekday {
|
||||
|
@ -122,11 +117,11 @@ impl Relay {
|
|||
}
|
||||
}
|
||||
|
||||
self.active_schedule = Some(self.schedules.get(weekday as usize).unwrap().clone())
|
||||
self.active_schedule = self.schedules.get(weekday as usize).unwrap().clone()
|
||||
}
|
||||
|
||||
pub fn apply_state(&mut self, state: &RelayState) {
|
||||
self.active_schedule.clone_from(&state.active_schedule);
|
||||
self.active_schedule = state.active_schedule.clone();
|
||||
self.override_schedule.clone_from(&state.override_schedule);
|
||||
self.is_on = state.is_on;
|
||||
}
|
||||
|
|
|
@ -1,27 +1,26 @@
|
|||
use std::time::Instant;
|
||||
|
||||
use chrono::{Local, NaiveTime, Timelike, Weekday};
|
||||
use chrono::{Local, NaiveTime, Timelike};
|
||||
|
||||
use crate::types::Weekday;
|
||||
use crate::utils;
|
||||
|
||||
pub struct EmgauwaNow {
|
||||
pub time: NaiveTime,
|
||||
pub instant: Instant,
|
||||
pub weekday: Weekday,
|
||||
pub midnight: NaiveTime,
|
||||
}
|
||||
|
||||
impl EmgauwaNow {
|
||||
pub fn now(midnight: &NaiveTime) -> EmgauwaNow {
|
||||
pub fn now() -> EmgauwaNow {
|
||||
EmgauwaNow {
|
||||
time: Local::now().time(),
|
||||
instant: Instant::now(),
|
||||
weekday: utils::get_weekday(midnight),
|
||||
midnight: *midnight,
|
||||
weekday: utils::get_weekday(),
|
||||
}
|
||||
}
|
||||
|
||||
pub fn num_seconds_from_midnight(&self) -> u32 {
|
||||
pub fn time_in_s(&self) -> u32 {
|
||||
self.time.num_seconds_from_midnight()
|
||||
}
|
||||
}
|
||||
|
|
|
@ -16,6 +16,8 @@ use crate::db::DbSchedule;
|
|||
use crate::errors::EmgauwaError;
|
||||
use crate::models::{Controller, Relay};
|
||||
|
||||
pub type Weekday = i64;
|
||||
|
||||
#[derive(Debug, Serialize, Deserialize, Message)]
|
||||
#[rtype(result = "Result<(), EmgauwaError>")]
|
||||
pub enum ControllerWsAction {
|
||||
|
|
|
@ -4,7 +4,7 @@ use crate::models::Relay;
|
|||
|
||||
#[derive(Debug, Clone, Serialize, Deserialize)]
|
||||
pub struct RelayState {
|
||||
pub active_schedule: Option<DbSchedule>,
|
||||
pub active_schedule: DbSchedule,
|
||||
pub override_schedule: Option<DbSchedule>,
|
||||
pub is_on: Option<bool>
|
||||
}
|
||||
|
|
22
src/utils.rs
22
src/utils.rs
|
@ -2,13 +2,13 @@ use std::ffi::CString;
|
|||
use std::io::{Error, ErrorKind};
|
||||
use std::str::FromStr;
|
||||
|
||||
use chrono::{Datelike, NaiveTime, Weekday};
|
||||
use chrono::Datelike;
|
||||
use log::LevelFilter;
|
||||
use simple_logger::SimpleLogger;
|
||||
|
||||
use crate::errors::EmgauwaError;
|
||||
use crate::settings::Permissions;
|
||||
use crate::types::RelayStates;
|
||||
use crate::types::{RelayStates, Weekday};
|
||||
|
||||
pub fn init_logging(level: &str) -> Result<(), EmgauwaError> {
|
||||
let log_level: LevelFilter = LevelFilter::from_str(level)
|
||||
|
@ -92,18 +92,12 @@ fn drop_privileges_user(user: &str) -> Result<(), Error> {
|
|||
Ok(())
|
||||
}
|
||||
|
||||
pub fn get_weekday(midnight: &NaiveTime) -> Weekday {
|
||||
let dt = chrono::offset::Local::now().naive_local();
|
||||
let weekday = dt.weekday();
|
||||
if dt.time().lt(midnight) {
|
||||
weekday.pred()
|
||||
} else {
|
||||
weekday
|
||||
}
|
||||
}
|
||||
|
||||
pub fn default_weekday() -> Weekday {
|
||||
Weekday::Mon
|
||||
pub fn get_weekday() -> Weekday {
|
||||
(chrono::offset::Local::now()
|
||||
.date_naive()
|
||||
.weekday()
|
||||
.number_from_monday()
|
||||
- 1) as Weekday
|
||||
}
|
||||
|
||||
pub fn printable_relay_states(relay_states: &RelayStates) -> String {
|
||||
|
|
Loading…
Reference in a new issue