Struct ruma::events::room::EncryptedFile
source · #[non_exhaustive]pub struct EncryptedFile {
pub url: OwnedMxcUri,
pub key: JsonWebKey,
pub iv: Base64,
pub hashes: BTreeMap<String, Base64>,
pub v: String,
}
Expand description
A file sent to a room with end-to-end encryption enabled.
To create an instance of this type, first create a EncryptedFileInit
and convert it via
EncryptedFile::from
/ .into()
.
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.url: OwnedMxcUri
The URL to the file.
key: JsonWebKey
A JSON Web Key object.
iv: Base64
The 128-bit unique counter block used by AES-CTR, encoded as unpadded base64.
hashes: BTreeMap<String, Base64>
A map from an algorithm name to a hash of the ciphertext, encoded as unpadded base64.
Clients should support the SHA-256 hash, which uses the key sha256.
v: String
Version of the encrypted attachments protocol.
Must be v2
.
Trait Implementations§
source§impl Clone for EncryptedFile
impl Clone for EncryptedFile
source§fn clone(&self) -> EncryptedFile
fn clone(&self) -> EncryptedFile
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 EncryptedFile
impl Debug for EncryptedFile
source§impl<'de> Deserialize<'de> for EncryptedFile
impl<'de> Deserialize<'de> for EncryptedFile
source§fn deserialize<__D>(
__deserializer: __D,
) -> Result<EncryptedFile, <__D as Deserializer<'de>>::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(
__deserializer: __D,
) -> Result<EncryptedFile, <__D as Deserializer<'de>>::Error>where
__D: Deserializer<'de>,
Deserialize this value from the given Serde deserializer. Read more
source§impl From<EncryptedFileInit> for EncryptedFile
impl From<EncryptedFileInit> for EncryptedFile
source§fn from(init: EncryptedFileInit) -> EncryptedFile
fn from(init: EncryptedFileInit) -> EncryptedFile
Converts to this type from the input type.
source§impl Serialize for EncryptedFile
impl Serialize for EncryptedFile
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 EncryptedFile
impl RefUnwindSafe for EncryptedFile
impl Send for EncryptedFile
impl Sync for EncryptedFile
impl Unpin for EncryptedFile
impl UnwindSafe for EncryptedFile
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
)