summaryrefslogtreecommitdiffstats
path: root/src/app/data_harvester/battery_harvester.rs
blob: c4623cad9e2596e310b8e192d03f5b372aee5871 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
use battery::{
    units::{power::watt, ratio::percent, time::second, Time},
    Battery, Manager,
};

#[derive(Debug, Clone)]
pub struct BatteryHarvest {
    pub charge_percent: f64,
    pub secs_until_full: Option<i64>,
    pub secs_until_empty: Option<i64>,
    pub power_consumption_rate_watts: f64,
    pub health_percent: f64,
}

fn convert_optional_time_to_optional_seconds(optional_time: Option<Time>) -> Option<i64> {
    if let Some(time) = optional_time {
        Some(f64::from(time.get::<second>()) as i64)
    } else {
        None
    }
}

pub fn refresh_batteries(manager: &Manager, batteries: &mut [Battery]) -> Vec<BatteryHarvest> {
    batteries
        .iter_mut()
        .filter_map(|battery| {
            if manager.refresh(battery).is_ok() {
                Some(BatteryHarvest {
                    secs_until_full: convert_optional_time_to_optional_seconds(
                        battery.time_to_full(),
                    ),
                    secs_until_empty: convert_optional_time_to_optional_seconds(
                        battery.time_to_empty(),
                    ),
                    charge_percent: f64::from(battery.state_of_charge().get::<percent>()),
                    power_consumption_rate_watts: f64::from(battery.energy_rate().get::<watt>()),
                    health_percent: f64::from(battery.state_of_health().get::<percent>()),
                })
            } else {
                None
            }
        })
        .collect::<Vec<_>>()
}