use serde::Deserialize;
use serde::de::Unexpected;
use serde::de;
use serde::Deserializer;
use zigbee2mqtt_types_base_types::LastSeen;
#[cfg_attr(feature = "debug", derive(Debug))]
#[cfg_attr(feature = "clone", derive(Clone))]
#[derive(Deserialize)]
pub struct ZigbeeBe468 {
pub action: ZigbeeBe468Action,
pub action_source_name: ZigbeeBe468Actionsourcename,
pub action_user: f64,
pub battery: f64,
pub linkquality: f64,
pub lock_state: ZigbeeBe468Lockstate,
#[serde(deserialize_with = "zigbeebe468_state_deserializer")]
pub state: bool,
pub last_seen: Option<LastSeen>,
pub elapsed: Option<u64>,
}
fn zigbeebe468_state_deserializer<'de, D>(deserializer: D) -> Result<bool, D::Error>
where
D: Deserializer<'de>,
{
match String::deserialize(deserializer)?.as_ref() {
"LOCK" => Ok(true),
"UNLOCK" => Ok(false),
other => Err(de::Error::invalid_value(
Unexpected::Str(other),
&"Value expected was either LOCK or UNLOCK",
)),
}
}
#[cfg_attr(feature = "debug", derive(Debug))]
#[cfg_attr(feature = "clone", derive(Clone))]
#[derive(Deserialize, PartialEq)]
pub enum ZigbeeBe468Action {
#[serde(rename = "auto_lock")]
AutoLock,
#[serde(rename = "key_lock")]
KeyLock,
#[serde(rename = "key_unlock")]
KeyUnlock,
#[serde(rename = "lock")]
Lock,
#[serde(rename = "lock_failure_invalid_pin_or_id")]
LockFailureInvalidPinOrId,
#[serde(rename = "lock_failure_invalid_schedule")]
LockFailureInvalidSchedule,
#[serde(rename = "manual_lock")]
ManualLock,
#[serde(rename = "manual_unlock")]
ManualUnlock,
#[serde(rename = "non_access_user_operational_event")]
NonAccessUserOperationalEvent,
#[serde(rename = "one_touch_lock")]
OneTouchLock,
#[serde(rename = "schedule_lock")]
ScheduleLock,
#[serde(rename = "schedule_unlock")]
ScheduleUnlock,
#[serde(rename = "unknown")]
Unknown,
#[serde(rename = "unlock")]
Unlock,
#[serde(rename = "unlock_failure_invalid_pin_or_id")]
UnlockFailureInvalidPinOrId,
#[serde(rename = "unlock_failure_invalid_schedule")]
UnlockFailureInvalidSchedule,
}
#[cfg_attr(feature = "debug", derive(Debug))]
#[cfg_attr(feature = "clone", derive(Clone))]
#[derive(Deserialize, PartialEq)]
pub enum ZigbeeBe468Actionsourcename {
#[serde(rename = "keypad")]
Keypad,
#[serde(rename = "manual")]
Manual,
#[serde(rename = "rf")]
Rf,
#[serde(rename = "rfid")]
Rfid,
}
#[cfg_attr(feature = "debug", derive(Debug))]
#[cfg_attr(feature = "clone", derive(Clone))]
#[derive(Deserialize, PartialEq)]
pub enum ZigbeeBe468Lockstate {
#[serde(rename = "locked")]
Locked,
#[serde(rename = "not_fully_locked")]
NotFullyLocked,
#[serde(rename = "unlocked")]
Unlocked,
}
#[cfg(all(feature = "last_seen_epoch", feature = "last_seen_iso_8601"))]
compile_error!{"Feature last_seen epoch and iso_8601 are mutually exclusive and cannot be enabled together.
This was done because it is a global setting in zigbee2mqtt and therefor can't see a reason both would be enabled.
If you have a any reason to have both ways enabled please submit an issue to https://gitlab.com/seam345/zigbee2mqtt-types/-/issues"}