52 Commits

Author SHA1 Message Date
c469d49ff7 Update custom consumption dependencies
All checks were successful
continuous-integration/drone/push Build is passing
continuous-integration/drone/tag Build is passing
2025-12-08 20:45:04 +01:00
45ece6d052 Add anonymous route to get access to all relays at once
Some checks failed
continuous-integration/drone/push Build is failing
2025-12-08 20:16:57 +01:00
fee7841253 Update frontend dependencies 2025-12-08 18:52:29 +01:00
af69a3f1d9 Updated backend dependencies 2025-12-08 15:36:31 +01:00
c30e2327e0 Merge pull request 'Update dependency typescript-eslint to ^8.48.1' (#383) from renovate/typescript-eslint-8.x into master
Some checks failed
continuous-integration/drone/push Build is failing
2025-12-07 00:35:45 +00:00
15dc46ae54 Update dependency typescript-eslint to ^8.48.1
Some checks failed
continuous-integration/drone/push Build is failing
continuous-integration/drone/pr Build is failing
2025-12-07 00:35:41 +00:00
0afe2e877a Merge pull request 'Update dependency @typescript-eslint/parser to ^8.48.1' (#382) from renovate/typescript-eslint-parser-8.x into master
Some checks failed
continuous-integration/drone/push Build is failing
2025-12-06 00:35:23 +00:00
29338a4a5e Update dependency @typescript-eslint/parser to ^8.48.1
Some checks failed
continuous-integration/drone/push Build is failing
continuous-integration/drone/pr Build is failing
2025-12-05 00:22:33 +00:00
8142f0c058 Merge pull request 'Update dependency @typescript-eslint/eslint-plugin to ^8.48.1' (#381) from renovate/typescript-eslint-eslint-plugin-8.x into master
Some checks failed
continuous-integration/drone/push Build is failing
2025-12-04 00:21:25 +00:00
04df3b28a8 Update dependency @typescript-eslint/eslint-plugin to ^8.48.1
Some checks failed
renovate/artifacts Artifact file update failure
continuous-integration/drone/push Build is failing
continuous-integration/drone/pr Build is failing
2025-12-04 00:21:19 +00:00
e0cbc56200 Merge pull request 'Update Rust crate actix-web to 4.12.1' (#380) from renovate/actix-web-4.x into master
Some checks failed
continuous-integration/drone/push Build is failing
2025-12-03 00:20:29 +00:00
18969a0947 Merge pull request 'Update dependency vite to ^7.2.6' (#379) from renovate/vite-7.x into master
Some checks failed
continuous-integration/drone/push Build is failing
2025-12-03 00:20:22 +00:00
c388ee40ce Update Rust crate actix-web to 4.12.1
Some checks failed
continuous-integration/drone/push Build is failing
continuous-integration/drone/pr Build is failing
2025-12-02 00:18:33 +00:00
f65b3603af Update dependency vite to ^7.2.6
Some checks failed
continuous-integration/drone/push Build is failing
continuous-integration/drone/pr Build is failing
2025-12-02 00:18:29 +00:00
9f8158357e Merge pull request 'Update Rust crate egui to 0.33.2' (#378) from renovate/egui-0.x into master
Some checks failed
continuous-integration/drone/push Build is failing
2025-12-01 00:19:01 +00:00
7b7a4a7144 Update Rust crate egui to 0.33.2
Some checks failed
renovate/artifacts Artifact file update failure
continuous-integration/drone/push Build is failing
continuous-integration/drone/pr Build is failing
2025-12-01 00:18:57 +00:00
d2b2790c41 Merge pull request 'Update dependency typescript-eslint to ^8.48.0' (#377) from renovate/typescript-eslint-8.x into master
All checks were successful
continuous-integration/drone/push Build is passing
2025-12-01 00:18:35 +00:00
3d6422757d Update dependency typescript-eslint to ^8.48.0
Some checks failed
continuous-integration/drone/push Build is passing
continuous-integration/drone/pr Build is failing
2025-11-30 00:18:33 +00:00
2d13fa5aab Merge pull request 'Update dependency globals to ^16.5.0' (#376) from renovate/globals-16.x into master
All checks were successful
continuous-integration/drone/push Build is passing
2025-11-30 00:18:23 +00:00
404539f5cd Update dependency globals to ^16.5.0
All checks were successful
continuous-integration/drone/push Build is passing
continuous-integration/drone/pr Build is passing
2025-11-29 00:20:02 +00:00
99ea7bae93 Merge pull request 'Update dependency @mui/x-charts to ^8.20.0' (#375) from renovate/mui-x-charts-8.x into master
All checks were successful
continuous-integration/drone/push Build is passing
2025-11-29 00:19:56 +00:00
6e49afb29a Update dependency @mui/x-charts to ^8.20.0
All checks were successful
continuous-integration/drone/push Build is passing
continuous-integration/drone/pr Build is passing
2025-11-28 00:18:45 +00:00
a17aa1c11e Merge pull request 'Update dependency @typescript-eslint/parser to ^8.48.0' (#374) from renovate/typescript-eslint-parser-8.x into master
All checks were successful
continuous-integration/drone/push Build is passing
2025-11-28 00:18:37 +00:00
964a26e535 Update dependency @typescript-eslint/parser to ^8.48.0
All checks were successful
continuous-integration/drone/push Build is passing
continuous-integration/drone/pr Build is passing
2025-11-27 00:21:05 +00:00
f41b266da1 Merge pull request 'Update dependency @typescript-eslint/eslint-plugin to ^8.48.0' (#373) from renovate/typescript-eslint-eslint-plugin-8.x into master
All checks were successful
continuous-integration/drone/push Build is passing
2025-11-27 00:20:59 +00:00
b01b6732dd Update dependency @typescript-eslint/eslint-plugin to ^8.48.0
All checks were successful
continuous-integration/drone/push Build is passing
continuous-integration/drone/pr Build is passing
2025-11-26 00:14:09 +00:00
c217e5f944 Merge pull request 'Update dependency @types/react to ^19.2.7' (#372) from renovate/react into master
All checks were successful
continuous-integration/drone/push Build is passing
2025-11-26 00:14:01 +00:00
247d1dd4ec Update dependency @types/react to ^19.2.7
All checks were successful
continuous-integration/drone/push Build is passing
continuous-integration/drone/pr Build is passing
2025-11-25 00:13:44 +00:00
c6a43ec868 Merge pull request 'Update dependency @fontsource/roboto to ^5.2.9' (#371) from renovate/fontsource-roboto-5.x into master
All checks were successful
continuous-integration/drone/push Build is passing
2025-11-25 00:13:37 +00:00
53a1c7e0e9 Update dependency @fontsource/roboto to ^5.2.9
All checks were successful
continuous-integration/drone/push Build is passing
continuous-integration/drone/pr Build is passing
2025-11-24 00:14:10 +00:00
852c58b560 Merge pull request 'Update dependency @mui/x-date-pickers to ^8.19.0' (#370) from renovate/mui-x-date-pickers-8.x into master
All checks were successful
continuous-integration/drone/push Build is passing
2025-11-24 00:14:01 +00:00
cb28426b23 Update dependency @mui/x-date-pickers to ^8.19.0
All checks were successful
continuous-integration/drone/push Build is passing
continuous-integration/drone/pr Build is passing
2025-11-23 00:16:31 +00:00
4a2828aa0c Merge pull request 'Update dependency @mui/x-charts to ^8.19.0' (#369) from renovate/mui-x-charts-8.x into master
All checks were successful
continuous-integration/drone/push Build is passing
2025-11-23 00:16:22 +00:00
26502589ac Update dependency @mui/x-charts to ^8.19.0
All checks were successful
continuous-integration/drone/push Build is passing
continuous-integration/drone/pr Build is passing
2025-11-22 00:13:56 +00:00
f0d210782e Merge pull request 'Update Rust crate rand to 0.10.0-rc.5' (#368) from renovate/rand-0.x into master
All checks were successful
continuous-integration/drone/push Build is passing
2025-11-22 00:13:47 +00:00
1f1c16fc9c Update Rust crate rand to 0.10.0-rc.5
All checks were successful
continuous-integration/drone/push Build is passing
continuous-integration/drone/pr Build is passing
2025-11-21 00:18:32 +00:00
16f0c9cee2 Merge pull request 'Update Rust crate clap to 4.5.53' (#367) from renovate/clap-4.x into master
All checks were successful
continuous-integration/drone/push Build is passing
2025-11-21 00:18:23 +00:00
ae001316d5 Update Rust crate clap to 4.5.53
All checks were successful
continuous-integration/drone/push Build is passing
continuous-integration/drone/pr Build is passing
2025-11-20 00:14:58 +00:00
572b43d9ac Merge pull request 'Update react' (#366) from renovate/react into master
All checks were successful
continuous-integration/drone/push Build is passing
2025-11-20 00:14:33 +00:00
c6c4eae7a2 Update react
All checks were successful
continuous-integration/drone/push Build is passing
continuous-integration/drone/pr Build is passing
2025-11-19 00:13:36 +00:00
831d4d444c Merge pull request 'Update dependency date-and-time to ^4.1.1' (#365) from renovate/date-and-time-4.x into master
All checks were successful
continuous-integration/drone/push Build is passing
2025-11-19 00:13:31 +00:00
cd19f1d69b Update dependency date-and-time to ^4.1.1
All checks were successful
continuous-integration/drone/push Build is passing
continuous-integration/drone/pr Build is passing
2025-11-18 00:15:41 +00:00
4ca2d7a763 Merge pull request 'Update Rust crate openssl-sys to 0.9.111' (#364) from renovate/openssl-sys-0.x into master
All checks were successful
continuous-integration/drone/push Build is passing
2025-11-18 00:15:33 +00:00
9c7df89bce Update Rust crate openssl-sys to 0.9.111
All checks were successful
continuous-integration/drone/push Build is passing
continuous-integration/drone/pr Build is passing
2025-11-17 00:14:07 +00:00
040def4089 Merge pull request 'Update dependency react-router-dom to ^7.9.6' (#363) from renovate/react-router-dom-7.x into master
All checks were successful
continuous-integration/drone/push Build is passing
2025-11-17 00:13:56 +00:00
ad27b656f4 Update dependency react-router-dom to ^7.9.6
All checks were successful
continuous-integration/drone/push Build is passing
continuous-integration/drone/pr Build is passing
2025-11-16 00:14:39 +00:00
53e4d09d6e Merge pull request 'Update dependency @vitejs/plugin-react to ^5.1.1' (#362) from renovate/vitejs-plugin-react-5.x into master
All checks were successful
continuous-integration/drone/push Build is passing
2025-11-16 00:14:33 +00:00
e0199b8ce9 Update dependency @vitejs/plugin-react to ^5.1.1
All checks were successful
continuous-integration/drone/push Build is passing
continuous-integration/drone/pr Build is passing
2025-11-15 00:14:26 +00:00
26c301d8ac Merge pull request 'Update dependency @typescript-eslint/parser to ^8.46.4' (#361) from renovate/typescript-eslint-parser-8.x into master
All checks were successful
continuous-integration/drone/push Build is passing
2025-11-15 00:14:17 +00:00
ab9ed2ad63 Update dependency @typescript-eslint/parser to ^8.46.4
All checks were successful
continuous-integration/drone/push Build is passing
continuous-integration/drone/pr Build is passing
2025-11-13 00:13:46 +00:00
38f06b45b9 Merge pull request 'Update dependency @types/react to ^19.2.3' (#360) from renovate/react into master
Some checks failed
continuous-integration/drone/push Build is failing
2025-11-12 00:15:26 +00:00
bfa6dfad0c Update dependency @types/react to ^19.2.3
Some checks failed
renovate/artifacts Artifact file update failure
continuous-integration/drone/push Build is failing
continuous-integration/drone/pr Build is failing
2025-11-12 00:15:23 +00:00
8 changed files with 1826 additions and 1797 deletions

File diff suppressed because it is too large Load Diff

View File

@@ -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"] }
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"

View File

@@ -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()

View File

@@ -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,66 @@ 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,
/// 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
relay_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 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 state = relays_state.iter().find(|s| s.id == r.id);
FullRelayState {
enabled: r.enabled,
is_on: state.map(|s| s.on).unwrap_or(false),
name: r.name,
priority: r.priority,
r#for: state.map(|s| s.r#for).unwrap_or(0),
total_uptime: 0,
daily_requirement: r.daily_runtime.map(|r| r.min_runtime),
relay_forced_state: state.map(|s| s.forced_state.clone()).unwrap_or_default(),
}
})
.collect(),
}))
}

File diff suppressed because it is too large Load Diff

View File

@@ -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.48.1",
"@typescript-eslint/parser": "^8.48.1",
"@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.48.1",
"vite": "^7.2.7"
}
}

File diff suppressed because it is too large Load Diff

View File

@@ -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.2"
eframe = "0.33.2"
lazy_static = "1.5.0"