Struct ruma::encryption::DeviceKeys
source · #[non_exhaustive]pub struct DeviceKeys {
pub user_id: OwnedUserId,
pub device_id: OwnedDeviceId,
pub algorithms: Vec<EventEncryptionAlgorithm>,
pub keys: BTreeMap<OwnedKeyId<DeviceKeyAlgorithm, DeviceId>, String>,
pub signatures: Signatures<OwnedUserId, Base64PublicKeyOrDeviceId>,
pub unsigned: UnsignedDeviceInfo,
}
Expand description
Identity keys for a device.
Fields (Non-exhaustive)§
This struct is marked as non-exhaustive
Non-exhaustive structs could have additional fields added in future. Therefore, non-exhaustive structs cannot be constructed in external crates using the traditional
Struct { .. }
syntax; cannot be matched against without a wildcard ..
; and struct update syntax will not work.user_id: OwnedUserId
The ID of the user the device belongs to.
Must match the user ID used when logging in.
device_id: OwnedDeviceId
The ID of the device these keys belong to.
Must match the device ID used when logging in.
algorithms: Vec<EventEncryptionAlgorithm>
The encryption algorithms supported by this device.
keys: BTreeMap<OwnedKeyId<DeviceKeyAlgorithm, DeviceId>, String>
Public identity keys.
signatures: Signatures<OwnedUserId, Base64PublicKeyOrDeviceId>
Signatures for the device key object.
unsigned: UnsignedDeviceInfo
Additional data added to the device key information by intermediate servers, and not covered by the signatures.
Implementations§
source§impl DeviceKeys
impl DeviceKeys
sourcepub fn new(
user_id: OwnedUserId,
device_id: OwnedDeviceId,
algorithms: Vec<EventEncryptionAlgorithm>,
keys: BTreeMap<OwnedKeyId<DeviceKeyAlgorithm, DeviceId>, String>,
signatures: Signatures<OwnedUserId, Base64PublicKeyOrDeviceId>,
) -> DeviceKeys
pub fn new( user_id: OwnedUserId, device_id: OwnedDeviceId, algorithms: Vec<EventEncryptionAlgorithm>, keys: BTreeMap<OwnedKeyId<DeviceKeyAlgorithm, DeviceId>, String>, signatures: Signatures<OwnedUserId, Base64PublicKeyOrDeviceId>, ) -> DeviceKeys
Creates a new DeviceKeys
from the given user id, device id, algorithms, keys and
signatures.
Trait Implementations§
source§impl Clone for DeviceKeys
impl Clone for DeviceKeys
source§fn clone(&self) -> DeviceKeys
fn clone(&self) -> DeviceKeys
Returns a copy of the value. Read more
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source
. Read moresource§impl Debug for DeviceKeys
impl Debug for DeviceKeys
source§impl<'de> Deserialize<'de> for DeviceKeys
impl<'de> Deserialize<'de> for DeviceKeys
source§fn deserialize<__D>(
__deserializer: __D,
) -> Result<DeviceKeys, <__D as Deserializer<'de>>::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(
__deserializer: __D,
) -> Result<DeviceKeys, <__D as Deserializer<'de>>::Error>where
__D: Deserializer<'de>,
Deserialize this value from the given Serde deserializer. Read more
source§impl Serialize for DeviceKeys
impl Serialize for DeviceKeys
source§fn serialize<__S>(
&self,
__serializer: __S,
) -> Result<<__S as Serializer>::Ok, <__S as Serializer>::Error>where
__S: Serializer,
fn serialize<__S>(
&self,
__serializer: __S,
) -> Result<<__S as Serializer>::Ok, <__S as Serializer>::Error>where
__S: Serializer,
Serialize this value into the given Serde serializer. Read more
Auto Trait Implementations§
impl Freeze for DeviceKeys
impl RefUnwindSafe for DeviceKeys
impl Send for DeviceKeys
impl Sync for DeviceKeys
impl Unpin for DeviceKeys
impl UnwindSafe for DeviceKeys
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
source§default unsafe fn clone_to_uninit(&self, dst: *mut T)
default unsafe fn clone_to_uninit(&self, dst: *mut T)
🔬This is a nightly-only experimental API. (
clone_to_uninit
)