ruma_client_api/sync/
sync_events.rsuse js_int::UInt;
use ruma_common::OwnedUserId;
use serde::{self, Deserialize, Serialize};
pub mod v3;
#[cfg(feature = "unstable-msc3575")]
pub mod v4;
#[cfg(feature = "unstable-msc4186")]
pub mod v5;
#[derive(Clone, Debug, Default, Deserialize, Serialize)]
#[cfg_attr(not(feature = "unstable-exhaustive-types"), non_exhaustive)]
pub struct UnreadNotificationsCount {
#[serde(skip_serializing_if = "Option::is_none")]
pub highlight_count: Option<UInt>,
#[serde(skip_serializing_if = "Option::is_none")]
pub notification_count: Option<UInt>,
}
impl UnreadNotificationsCount {
pub fn new() -> Self {
Default::default()
}
pub fn is_empty(&self) -> bool {
self.highlight_count.is_none() && self.notification_count.is_none()
}
}
#[derive(Clone, Debug, Default, Deserialize, Serialize)]
#[cfg_attr(not(feature = "unstable-exhaustive-types"), non_exhaustive)]
pub struct DeviceLists {
#[serde(default, skip_serializing_if = "Vec::is_empty")]
pub changed: Vec<OwnedUserId>,
#[serde(default, skip_serializing_if = "Vec::is_empty")]
pub left: Vec<OwnedUserId>,
}
impl DeviceLists {
pub fn new() -> Self {
Default::default()
}
pub fn is_empty(&self) -> bool {
self.changed.is_empty() && self.left.is_empty()
}
}