client-api: Add some missing constructors / non-exhaustive attributes

This commit is contained in:
Jonas Platte 2020-09-17 00:07:22 +02:00
parent b05121877b
commit 219cea9c1e
No known key found for this signature in database
GPG Key ID: 7D261D771D915378
2 changed files with 38 additions and 2 deletions

View File

@ -69,3 +69,10 @@ impl<'a> Request<'a> {
} }
} }
} }
impl Response {
/// Creates a new `Response` with the given session identifier.
pub fn new(sid: String) -> Self {
Self { sid, submit_url: None }
}
}

View File

@ -48,7 +48,8 @@ impl From<Capabilities> for Response {
} }
/// Contains information about all the capabilities that the server supports. /// Contains information about all the capabilities that the server supports.
#[derive(Clone, Debug, Serialize, Deserialize)] #[derive(Clone, Debug, Default, Serialize, Deserialize)]
#[cfg_attr(not(feature = "unstable-exhaustive-types"), non_exhaustive)]
pub struct Capabilities { pub struct Capabilities {
/// Capability to indicate if the user can change their password. /// Capability to indicate if the user can change their password.
#[serde(rename = "m.change_password", skip_serializing_if = "Option::is_none")] #[serde(rename = "m.change_password", skip_serializing_if = "Option::is_none")]
@ -64,25 +65,53 @@ pub struct Capabilities {
pub custom_capabilities: BTreeMap<String, JsonValue>, pub custom_capabilities: BTreeMap<String, JsonValue>,
} }
impl Capabilities {
/// Creates empty `Capabilities`.
pub fn new() -> Self {
Default::default()
}
}
/// Information about the m.change_password capability /// Information about the m.change_password capability
#[derive(Clone, Copy, Debug, Serialize, Deserialize)] #[derive(Clone, Copy, Debug, Serialize, Deserialize)]
#[cfg_attr(not(feature = "unstable-exhaustive-types"), non_exhaustive)]
pub struct ChangePasswordCapability { pub struct ChangePasswordCapability {
/// True if the user can change their password, false otherwise. /// True if the user can change their password, false otherwise.
pub enabled: bool, pub enabled: bool,
} }
impl ChangePasswordCapability {
/// Creates a new `ChangePasswordCapability` with the given enabled flag.
pub fn new(enabled: bool) -> Self {
Self { enabled }
}
}
/// Information about the m.room_versions capability /// Information about the m.room_versions capability
#[derive(Clone, Debug, Serialize, Deserialize)] #[derive(Clone, Debug, Serialize, Deserialize)]
#[cfg_attr(not(feature = "unstable-exhaustive-types"), non_exhaustive)]
pub struct RoomVersionsCapability { pub struct RoomVersionsCapability {
/// The default room version the server is using for new rooms. /// The default room version the server is using for new rooms.
pub default: String, pub default: RoomVersionId,
/// A detailed description of the room versions the server supports. /// A detailed description of the room versions the server supports.
pub available: BTreeMap<RoomVersionId, RoomVersionStability>, pub available: BTreeMap<RoomVersionId, RoomVersionStability>,
} }
impl RoomVersionsCapability {
/// Creates a new `RoomVersionsCapability` with the given default room version ID and room
/// version descriptions.
pub fn new(
default: RoomVersionId,
available: BTreeMap<RoomVersionId, RoomVersionStability>,
) -> Self {
Self { default, available }
}
}
/// The stability of a room version /// The stability of a room version
#[derive(Clone, Copy, Debug, Serialize, Deserialize)] #[derive(Clone, Copy, Debug, Serialize, Deserialize)]
#[cfg_attr(not(feature = "unstable-exhaustive-types"), non_exhaustive)]
pub enum RoomVersionStability { pub enum RoomVersionStability {
/// Support for the given version is stable. /// Support for the given version is stable.
#[serde(rename = "stable")] #[serde(rename = "stable")]