Compare commits
64 Commits
22fe694916
...
renovate/n
| Author | SHA1 | Date | |
|---|---|---|---|
| e593111568 | |||
| 3b9fd41905 | |||
| ad03f72f51 | |||
| b43b27a17e | |||
| 9a7cabe4a7 | |||
| 0d1baac2b7 | |||
| eae781a613 | |||
| ff47f86792 | |||
| 8398bb17ed | |||
| cfcb7a0ebb | |||
| 465477e862 | |||
| 6075085b0b | |||
| c469d49ff7 | |||
| 45ece6d052 | |||
| fee7841253 | |||
| af69a3f1d9 | |||
| c30e2327e0 | |||
| 15dc46ae54 | |||
| 0afe2e877a | |||
| 29338a4a5e | |||
| 8142f0c058 | |||
| 04df3b28a8 | |||
| e0cbc56200 | |||
| 18969a0947 | |||
| c388ee40ce | |||
| f65b3603af | |||
| 9f8158357e | |||
| 7b7a4a7144 | |||
| d2b2790c41 | |||
| 3d6422757d | |||
| 2d13fa5aab | |||
| 404539f5cd | |||
| 99ea7bae93 | |||
| 6e49afb29a | |||
| a17aa1c11e | |||
| 964a26e535 | |||
| f41b266da1 | |||
| b01b6732dd | |||
| c217e5f944 | |||
| 247d1dd4ec | |||
| c6a43ec868 | |||
| 53a1c7e0e9 | |||
| 852c58b560 | |||
| cb28426b23 | |||
| 4a2828aa0c | |||
| 26502589ac | |||
| f0d210782e | |||
| 1f1c16fc9c | |||
| 16f0c9cee2 | |||
| ae001316d5 | |||
| 572b43d9ac | |||
| c6c4eae7a2 | |||
| 831d4d444c | |||
| cd19f1d69b | |||
| 4ca2d7a763 | |||
| 9c7df89bce | |||
| 040def4089 | |||
| ad27b656f4 | |||
| 53e4d09d6e | |||
| e0199b8ce9 | |||
| 26c301d8ac | |||
| ab9ed2ad63 | |||
| 38f06b45b9 | |||
| bfa6dfad0c |
@@ -5,7 +5,7 @@ name: default
|
||||
|
||||
steps:
|
||||
- name: web_build
|
||||
image: node:23
|
||||
image: node:25
|
||||
volumes:
|
||||
- name: web_app
|
||||
path: /tmp/web_build
|
||||
|
||||
1053
central_backend/Cargo.lock
generated
1053
central_backend/Cargo.lock
generated
File diff suppressed because it is too large
Load Diff
@@ -4,24 +4,24 @@ version = "1.0.3"
|
||||
edition = "2024"
|
||||
|
||||
[dependencies]
|
||||
log = "0.4.28"
|
||||
log = "0.4.29"
|
||||
env_logger = "0.11.8"
|
||||
lazy_static = "1.5.0"
|
||||
dotenvy = "0.15.7"
|
||||
clap = { version = "4.5.51", features = ["derive", "env"] }
|
||||
clap = { version = "4.5.53", features = ["derive", "env"] }
|
||||
anyhow = "1.0.100"
|
||||
thiserror = "2.0.17"
|
||||
openssl = { version = "0.10.75" }
|
||||
openssl-sys = "0.9.110"
|
||||
libc = "0.2.177"
|
||||
openssl-sys = "0.9.111"
|
||||
libc = "0.2.178"
|
||||
foreign-types-shared = "0.1.1"
|
||||
asn1 = "0.23.0"
|
||||
actix-web = { version = "4.11.0", features = ["openssl"] }
|
||||
actix-web = { version = "4.12.1", features = ["openssl"] }
|
||||
futures = "0.3.31"
|
||||
serde = { version = "1.0.228", features = ["derive"] }
|
||||
reqwest = { version = "0.12.24", features = ["json"] }
|
||||
reqwest = { version = "0.12.25", features = ["json"] }
|
||||
serde_json = "1.0.145"
|
||||
rand = "0.10.0-rc.0"
|
||||
rand = "0.10.0-rc.5"
|
||||
actix = "0.13.5"
|
||||
actix-identity = "0.9.0"
|
||||
actix-session = { version = "0.11.0", features = ["cookie-session"] }
|
||||
@@ -29,14 +29,14 @@ actix-cors = "0.7.1"
|
||||
actix-multipart = { version = "0.7.2", features = ["derive"] }
|
||||
actix-remote-ip = "0.1.0"
|
||||
futures-util = "0.3.31"
|
||||
uuid = { version = "1.18.1", features = ["v4", "serde"] }
|
||||
uuid = { version = "1.19.0", features = ["v4", "serde"] }
|
||||
semver = { version = "1.0.27", features = ["serde"] }
|
||||
lazy-regex = "3.4.2"
|
||||
tokio = { version = "1.48.0", features = ["full"] }
|
||||
tokio_schedule = "0.3.2"
|
||||
mime_guess = "2.0.5"
|
||||
rust-embed = "8.8.0"
|
||||
jsonwebtoken = { version = "10.1.0", features = ["use_pem", "rust_crypto"] }
|
||||
rust-embed = "8.9.0"
|
||||
jsonwebtoken = { version = "10.2.0", features = ["use_pem", "rust_crypto"] }
|
||||
prettytable-rs = "0.10.0"
|
||||
chrono = "0.4.42"
|
||||
serde_yml = "0.0.12"
|
||||
|
||||
@@ -389,7 +389,7 @@ impl Handler<SynchronizeDevice> for EnergyActor {
|
||||
pub struct ResDevState {
|
||||
pub id: DeviceId,
|
||||
last_ping: u64,
|
||||
online: bool,
|
||||
pub online: bool,
|
||||
}
|
||||
|
||||
/// Get the state of devices
|
||||
|
||||
@@ -48,6 +48,10 @@ pub async fn unsecure_server(energy_actor: EnergyActorAddr) -> anyhow::Result<()
|
||||
"/relay/{id}/legacy_state",
|
||||
web::get().to(unsecure_relay_controller::legacy_state),
|
||||
)
|
||||
.route(
|
||||
"/relay/relays_full_state",
|
||||
web::get().to(unsecure_relay_controller::relays_full_state),
|
||||
)
|
||||
})
|
||||
.bind(&AppConfig::get().unsecure_listen_address)?
|
||||
.run()
|
||||
|
||||
@@ -1,5 +1,6 @@
|
||||
use crate::devices::device::DeviceRelayID;
|
||||
use crate::energy::{energy_actor, relay_state_history};
|
||||
use crate::energy::engine::RelayForcedState;
|
||||
use crate::energy::{consumption, energy_actor, relay_state_history};
|
||||
use crate::server::WebEnergyActor;
|
||||
use crate::server::custom_error::HttpResult;
|
||||
use actix_web::{HttpResponse, web};
|
||||
@@ -58,3 +59,80 @@ pub async fn legacy_state(
|
||||
required_uptime: relay.daily_runtime.map(|r| r.min_runtime).unwrap_or(0),
|
||||
}))
|
||||
}
|
||||
|
||||
#[derive(serde::Serialize)]
|
||||
pub struct FullRelayState {
|
||||
/// Indicates if the relay (or its parent device) is enabled or not
|
||||
enabled: bool,
|
||||
/// Indicate if the device is online or not
|
||||
online: bool,
|
||||
/// Indicates if relay is on or off
|
||||
is_on: bool,
|
||||
/// Relay name
|
||||
name: String,
|
||||
/// Relay priority (0 = lowest)
|
||||
priority: usize,
|
||||
/// Duration since last change of state
|
||||
r#for: usize,
|
||||
/// Total uptime since last reset
|
||||
total_uptime: usize,
|
||||
/// Required uptime during a day (in seconds)
|
||||
daily_requirement: Option<usize>,
|
||||
/// Forced relay state
|
||||
forced_state: RelayForcedState,
|
||||
}
|
||||
|
||||
#[derive(serde::Serialize)]
|
||||
pub struct RelaysFullState {
|
||||
/// Current global consumption, if successful
|
||||
curr_consumption: Option<i32>,
|
||||
/// Cached consumption
|
||||
cached_consumption: i32,
|
||||
/// Total relays consumptions
|
||||
relays_consumption: usize,
|
||||
/// Individual relays state
|
||||
relays: Vec<FullRelayState>,
|
||||
}
|
||||
|
||||
pub async fn relays_full_state(energy_actor: WebEnergyActor) -> HttpResult {
|
||||
let cached_consumption = energy_actor.send(energy_actor::GetCurrConsumption).await?;
|
||||
let relays_consumption = energy_actor.send(energy_actor::RelaysConsumption).await?;
|
||||
let curr_consumption = consumption::get_curr_consumption().await.ok();
|
||||
let devices = energy_actor.send(energy_actor::GetDeviceLists).await?;
|
||||
let devices_state = energy_actor.send(energy_actor::GetDevicesState).await?;
|
||||
let mut relays = energy_actor.send(energy_actor::GetRelaysList).await?;
|
||||
relays.sort_by_key(|r| -(r.priority as i64));
|
||||
let relays_state = energy_actor.send(energy_actor::GetAllRelaysState).await?;
|
||||
|
||||
Ok(HttpResponse::Ok().json(RelaysFullState {
|
||||
curr_consumption,
|
||||
cached_consumption,
|
||||
relays_consumption,
|
||||
relays: relays
|
||||
.into_iter()
|
||||
.map(|r| {
|
||||
let device = devices
|
||||
.iter()
|
||||
.find(|d| d.relays.iter().any(|sr| sr.id == r.id))
|
||||
.expect("All relay shall have an associated device!");
|
||||
let device_state = devices_state.iter().find(|s| s.id == device.id);
|
||||
let relay_state = relays_state.iter().find(|s| s.id == r.id);
|
||||
let total_uptime = relay_state_history::relay_total_runtime_adjusted(&r);
|
||||
|
||||
FullRelayState {
|
||||
enabled: r.enabled && device.enabled,
|
||||
online: device_state.map(|d| d.online).unwrap_or(false),
|
||||
is_on: relay_state.map(|s| s.on).unwrap_or(false),
|
||||
name: r.name,
|
||||
priority: r.priority,
|
||||
r#for: relay_state.map(|s| s.r#for).unwrap_or(0),
|
||||
total_uptime,
|
||||
daily_requirement: r.daily_runtime.map(|r| r.min_runtime),
|
||||
forced_state: relay_state
|
||||
.map(|s| s.forced_state.clone())
|
||||
.unwrap_or_default(),
|
||||
}
|
||||
})
|
||||
.collect(),
|
||||
}))
|
||||
}
|
||||
|
||||
1417
central_frontend/package-lock.json
generated
1417
central_frontend/package-lock.json
generated
File diff suppressed because it is too large
Load Diff
@@ -12,34 +12,34 @@
|
||||
"dependencies": {
|
||||
"@emotion/react": "^11.14.0",
|
||||
"@emotion/styled": "^11.14.1",
|
||||
"@fontsource/roboto": "^5.2.8",
|
||||
"@fontsource/roboto": "^5.2.9",
|
||||
"@mdi/js": "^7.4.47",
|
||||
"@mdi/react": "^1.6.1",
|
||||
"@mui/icons-material": "^7.3.5",
|
||||
"@mui/material": "^7.3.5",
|
||||
"@mui/x-charts": "^8.16.0",
|
||||
"@mui/x-date-pickers": "^8.17.0",
|
||||
"date-and-time": "^4.1.0",
|
||||
"@mui/icons-material": "^7.3.6",
|
||||
"@mui/material": "^7.3.6",
|
||||
"@mui/x-charts": "^8.21.0",
|
||||
"@mui/x-date-pickers": "^8.21.0",
|
||||
"date-and-time": "^4.1.1",
|
||||
"dayjs": "^1.11.19",
|
||||
"filesize": "^11.0.13",
|
||||
"react": "^19.2.0",
|
||||
"react-dom": "^19.2.0",
|
||||
"react-router-dom": "^7.9.5",
|
||||
"react": "^19.2.1",
|
||||
"react-dom": "^19.2.1",
|
||||
"react-router-dom": "^7.10.1",
|
||||
"semver": "^7.7.3"
|
||||
},
|
||||
"devDependencies": {
|
||||
"@types/react": "^19.2.2",
|
||||
"@types/react-dom": "^19.2.2",
|
||||
"@types/react": "^19.2.7",
|
||||
"@types/react-dom": "^19.2.3",
|
||||
"@types/semver": "^7.7.1",
|
||||
"@typescript-eslint/eslint-plugin": "^8.46.4",
|
||||
"@typescript-eslint/parser": "^8.46.3",
|
||||
"@vitejs/plugin-react": "^5.1.0",
|
||||
"@typescript-eslint/eslint-plugin": "^8.49.0",
|
||||
"@typescript-eslint/parser": "^8.49.0",
|
||||
"@vitejs/plugin-react": "^5.1.2",
|
||||
"eslint": "^9.39.1",
|
||||
"eslint-plugin-react-hooks": "^7.0.1",
|
||||
"eslint-plugin-react-refresh": "^0.4.24",
|
||||
"globals": "^16.4.0",
|
||||
"globals": "^16.5.0",
|
||||
"typescript": "^5.9.3",
|
||||
"typescript-eslint": "^8.46.3",
|
||||
"vite": "^7.1.12"
|
||||
"typescript-eslint": "^8.49.0",
|
||||
"vite": "^7.2.7"
|
||||
}
|
||||
}
|
||||
|
||||
1674
custom_consumption/Cargo.lock
generated
1674
custom_consumption/Cargo.lock
generated
File diff suppressed because it is too large
Load Diff
@@ -5,8 +5,8 @@ edition = "2024"
|
||||
|
||||
[dependencies]
|
||||
env_logger = "0.11.8"
|
||||
log = "0.4.28"
|
||||
clap = { version = "4.5.51", features = ["derive", "env"] }
|
||||
egui = "0.32.3"
|
||||
eframe = "0.32.3"
|
||||
log = "0.4.29"
|
||||
clap = { version = "4.5.53", features = ["derive", "env"] }
|
||||
egui = "0.33.3"
|
||||
eframe = "0.33.3"
|
||||
lazy_static = "1.5.0"
|
||||
|
||||
Reference in New Issue
Block a user