zigbee2mqtt_types_vendor_fischer___honsel/
lib.rs1use serde::Deserialize;
2use serde::de::Unexpected;
3use serde::de;
4use serde::Deserializer;
5use zigbee2mqtt_types_base_types::LastSeen;
6#[cfg_attr(feature = "debug", derive(Debug))]
10#[cfg_attr(feature = "clone", derive(Clone))]
11#[derive(Deserialize)]
12pub struct Zigbee020b0b {
13 pub brightness: f64,
15 pub color_temp: f64,
17 pub color_temp_startup: f64,
19 pub linkquality: f64,
21 pub power_on_behavior: Zigbee020b0bPoweronbehavior,
23 #[serde(deserialize_with = "zigbee020b0b_state_deserializer")]
26 pub state: bool,
27 pub last_seen: Option<LastSeen>,
29 pub elapsed: Option<u64>,
31}
32fn zigbee020b0b_state_deserializer<'de, D>(deserializer: D) -> Result<bool, D::Error>
34where
35 D: Deserializer<'de>,
36{
37 match String::deserialize(deserializer)?.as_ref() {
38 "ON" => Ok(true),
39 "OFF" => Ok(false),
40 other => Err(de::Error::invalid_value(
41 Unexpected::Str(other),
42 &"Value expected was either ON or OFF",
43 )),
44 }
45}
46
47
48#[cfg_attr(feature = "debug", derive(Debug))]
49#[cfg_attr(feature = "clone", derive(Clone))]
50#[derive(Deserialize, PartialEq)]
51pub enum Zigbee020b0bPoweronbehavior {
52 #[serde(rename = "off")]
53 Off,
54 #[serde(rename = "on")]
55 On,
56 #[serde(rename = "previous")]
57 Previous,
58 #[serde(rename = "toggle")]
59 Toggle,
60}
61#[cfg(all(feature = "last_seen_epoch", feature = "last_seen_iso_8601"))]
62compile_error!{"Feature last_seen epoch and iso_8601 are mutually exclusive and cannot be enabled together.
63This was done because it is a global setting in zigbee2mqtt and therefor can't see a reason both would be enabled.
64If you have a any reason to have both ways enabled please submit an issue to https://gitlab.com/seam345/zigbee2mqtt-types/-/issues"}