#[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: OwnedUserIdThe ID of the user the device belongs to.
Must match the user ID used when logging in.
device_id: OwnedDeviceIdThe 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: UnsignedDeviceInfoAdditional 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
 Available on crate feature events only.
pub fn new( user_id: OwnedUserId, device_id: OwnedDeviceId, algorithms: Vec<EventEncryptionAlgorithm>, keys: BTreeMap<OwnedKeyId<DeviceKeyAlgorithm, DeviceId>, String>, signatures: Signatures<OwnedUserId, Base64PublicKeyOrDeviceId>, ) -> DeviceKeys
events only.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 duplicate 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