events: reorder types in file module
This commit is contained in:
parent
deea762b8e
commit
0e11996545
@ -14,124 +14,6 @@ use super::{
|
|||||||
};
|
};
|
||||||
use crate::{serde::Base64, MxcUri};
|
use crate::{serde::Base64, MxcUri};
|
||||||
|
|
||||||
/// The encryption info of a file sent to a room with end-to-end encryption enabled.
|
|
||||||
///
|
|
||||||
/// To create an instance of this type, first create a `EncryptedContentInit` and convert it via
|
|
||||||
/// `EncryptedContent::from` / `.into()`.
|
|
||||||
#[derive(Clone, Debug, Deserialize, Serialize)]
|
|
||||||
#[cfg_attr(not(feature = "unstable-exhaustive-types"), non_exhaustive)]
|
|
||||||
pub struct EncryptedContent {
|
|
||||||
/// A [JSON Web Key](https://tools.ietf.org/html/rfc7517#appendix-A.3) object.
|
|
||||||
pub key: JsonWebKey,
|
|
||||||
|
|
||||||
/// The 128-bit unique counter block used by AES-CTR, encoded as unpadded base64.
|
|
||||||
pub iv: 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.
|
|
||||||
pub hashes: BTreeMap<String, Base64>,
|
|
||||||
|
|
||||||
/// Version of the encrypted attachments protocol.
|
|
||||||
///
|
|
||||||
/// Must be `v2`.
|
|
||||||
pub v: String,
|
|
||||||
}
|
|
||||||
|
|
||||||
/// Initial set of fields of `EncryptedContent`.
|
|
||||||
///
|
|
||||||
/// This struct will not be updated even if additional fields are added to `EncryptedContent` in a
|
|
||||||
/// new (non-breaking) release of the Matrix specification.
|
|
||||||
#[derive(Debug)]
|
|
||||||
#[allow(clippy::exhaustive_structs)]
|
|
||||||
pub struct EncryptedContentInit {
|
|
||||||
/// A [JSON Web Key](https://tools.ietf.org/html/rfc7517#appendix-A.3) object.
|
|
||||||
pub key: JsonWebKey,
|
|
||||||
|
|
||||||
/// The 128-bit unique counter block used by AES-CTR, encoded as unpadded base64.
|
|
||||||
pub iv: 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.
|
|
||||||
pub hashes: BTreeMap<String, Base64>,
|
|
||||||
|
|
||||||
/// Version of the encrypted attachments protocol.
|
|
||||||
///
|
|
||||||
/// Must be `v2`.
|
|
||||||
pub v: String,
|
|
||||||
}
|
|
||||||
|
|
||||||
impl From<EncryptedContentInit> for EncryptedContent {
|
|
||||||
fn from(init: EncryptedContentInit) -> Self {
|
|
||||||
let EncryptedContentInit { key, iv, hashes, v } = init;
|
|
||||||
Self { key, iv, hashes, v }
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/// Information about a file content.
|
|
||||||
#[derive(Clone, Debug, Default, Serialize, Deserialize)]
|
|
||||||
#[cfg_attr(not(feature = "unstable-exhaustive-types"), non_exhaustive)]
|
|
||||||
pub struct FileContentInfo {
|
|
||||||
/// The original filename of the uploaded file.
|
|
||||||
#[serde(skip_serializing_if = "Option::is_none")]
|
|
||||||
pub name: Option<String>,
|
|
||||||
|
|
||||||
/// The mimetype of the file, e.g. “application/msword”.
|
|
||||||
#[serde(skip_serializing_if = "Option::is_none")]
|
|
||||||
pub mimetype: Option<String>,
|
|
||||||
|
|
||||||
/// The size of the file in bytes.
|
|
||||||
#[serde(skip_serializing_if = "Option::is_none")]
|
|
||||||
pub size: Option<UInt>,
|
|
||||||
}
|
|
||||||
|
|
||||||
impl FileContentInfo {
|
|
||||||
/// Creates an empty `FileContentInfo`.
|
|
||||||
pub fn new() -> Self {
|
|
||||||
Self::default()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/// File content.
|
|
||||||
#[derive(Clone, Debug, Serialize, Deserialize)]
|
|
||||||
#[cfg_attr(not(feature = "unstable-exhaustive-types"), non_exhaustive)]
|
|
||||||
pub struct FileContent {
|
|
||||||
/// The URL to the file.
|
|
||||||
pub url: Box<MxcUri>,
|
|
||||||
|
|
||||||
/// Information about the uploaded file.
|
|
||||||
#[serde(flatten, skip_serializing_if = "Option::is_none")]
|
|
||||||
pub info: Option<Box<FileContentInfo>>,
|
|
||||||
|
|
||||||
/// Information on the encrypted file.
|
|
||||||
///
|
|
||||||
/// Required if file is encrypted.
|
|
||||||
#[serde(flatten, skip_serializing_if = "Option::is_none")]
|
|
||||||
pub encryption_info: Option<Box<EncryptedContent>>,
|
|
||||||
}
|
|
||||||
|
|
||||||
impl FileContent {
|
|
||||||
/// Creates a new non-encrypted `FileContent` with the given url and file info.
|
|
||||||
pub fn plain(url: Box<MxcUri>, info: Option<Box<FileContentInfo>>) -> Self {
|
|
||||||
Self { url, info, encryption_info: None }
|
|
||||||
}
|
|
||||||
|
|
||||||
/// Creates a new encrypted `FileContent` with the given url, encryption info and file info.
|
|
||||||
pub fn encrypted(
|
|
||||||
url: Box<MxcUri>,
|
|
||||||
encryption_info: EncryptedContent,
|
|
||||||
info: Option<Box<FileContentInfo>>,
|
|
||||||
) -> Self {
|
|
||||||
Self { url, info, encryption_info: Some(Box::new(encryption_info)) }
|
|
||||||
}
|
|
||||||
|
|
||||||
/// Whether the file is encrypted.
|
|
||||||
pub fn is_encrypted(&self) -> bool {
|
|
||||||
self.encryption_info.is_some()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/// The payload for an extensible text message.
|
/// The payload for an extensible text message.
|
||||||
#[derive(Clone, Debug, Serialize, Deserialize, EventContent)]
|
#[derive(Clone, Debug, Serialize, Deserialize, EventContent)]
|
||||||
#[cfg_attr(not(feature = "unstable-exhaustive-types"), non_exhaustive)]
|
#[cfg_attr(not(feature = "unstable-exhaustive-types"), non_exhaustive)]
|
||||||
@ -203,3 +85,121 @@ impl FileEventContent {
|
|||||||
Self { message, file: FileContent::encrypted(url, encryption_info, info), relates_to: None }
|
Self { message, file: FileContent::encrypted(url, encryption_info, info), relates_to: None }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// File content.
|
||||||
|
#[derive(Clone, Debug, Serialize, Deserialize)]
|
||||||
|
#[cfg_attr(not(feature = "unstable-exhaustive-types"), non_exhaustive)]
|
||||||
|
pub struct FileContent {
|
||||||
|
/// The URL to the file.
|
||||||
|
pub url: Box<MxcUri>,
|
||||||
|
|
||||||
|
/// Information about the uploaded file.
|
||||||
|
#[serde(flatten, skip_serializing_if = "Option::is_none")]
|
||||||
|
pub info: Option<Box<FileContentInfo>>,
|
||||||
|
|
||||||
|
/// Information on the encrypted file.
|
||||||
|
///
|
||||||
|
/// Required if file is encrypted.
|
||||||
|
#[serde(flatten, skip_serializing_if = "Option::is_none")]
|
||||||
|
pub encryption_info: Option<Box<EncryptedContent>>,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl FileContent {
|
||||||
|
/// Creates a new non-encrypted `FileContent` with the given url and file info.
|
||||||
|
pub fn plain(url: Box<MxcUri>, info: Option<Box<FileContentInfo>>) -> Self {
|
||||||
|
Self { url, info, encryption_info: None }
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Creates a new encrypted `FileContent` with the given url, encryption info and file info.
|
||||||
|
pub fn encrypted(
|
||||||
|
url: Box<MxcUri>,
|
||||||
|
encryption_info: EncryptedContent,
|
||||||
|
info: Option<Box<FileContentInfo>>,
|
||||||
|
) -> Self {
|
||||||
|
Self { url, info, encryption_info: Some(Box::new(encryption_info)) }
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Whether the file is encrypted.
|
||||||
|
pub fn is_encrypted(&self) -> bool {
|
||||||
|
self.encryption_info.is_some()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Information about a file content.
|
||||||
|
#[derive(Clone, Debug, Default, Serialize, Deserialize)]
|
||||||
|
#[cfg_attr(not(feature = "unstable-exhaustive-types"), non_exhaustive)]
|
||||||
|
pub struct FileContentInfo {
|
||||||
|
/// The original filename of the uploaded file.
|
||||||
|
#[serde(skip_serializing_if = "Option::is_none")]
|
||||||
|
pub name: Option<String>,
|
||||||
|
|
||||||
|
/// The mimetype of the file, e.g. “application/msword”.
|
||||||
|
#[serde(skip_serializing_if = "Option::is_none")]
|
||||||
|
pub mimetype: Option<String>,
|
||||||
|
|
||||||
|
/// The size of the file in bytes.
|
||||||
|
#[serde(skip_serializing_if = "Option::is_none")]
|
||||||
|
pub size: Option<UInt>,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl FileContentInfo {
|
||||||
|
/// Creates an empty `FileContentInfo`.
|
||||||
|
pub fn new() -> Self {
|
||||||
|
Self::default()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// The encryption info of a file sent to a room with end-to-end encryption enabled.
|
||||||
|
///
|
||||||
|
/// To create an instance of this type, first create a `EncryptedContentInit` and convert it via
|
||||||
|
/// `EncryptedContent::from` / `.into()`.
|
||||||
|
#[derive(Clone, Debug, Deserialize, Serialize)]
|
||||||
|
#[cfg_attr(not(feature = "unstable-exhaustive-types"), non_exhaustive)]
|
||||||
|
pub struct EncryptedContent {
|
||||||
|
/// A [JSON Web Key](https://tools.ietf.org/html/rfc7517#appendix-A.3) object.
|
||||||
|
pub key: JsonWebKey,
|
||||||
|
|
||||||
|
/// The 128-bit unique counter block used by AES-CTR, encoded as unpadded base64.
|
||||||
|
pub iv: 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.
|
||||||
|
pub hashes: BTreeMap<String, Base64>,
|
||||||
|
|
||||||
|
/// Version of the encrypted attachments protocol.
|
||||||
|
///
|
||||||
|
/// Must be `v2`.
|
||||||
|
pub v: String,
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Initial set of fields of `EncryptedContent`.
|
||||||
|
///
|
||||||
|
/// This struct will not be updated even if additional fields are added to `EncryptedContent` in a
|
||||||
|
/// new (non-breaking) release of the Matrix specification.
|
||||||
|
#[derive(Debug)]
|
||||||
|
#[allow(clippy::exhaustive_structs)]
|
||||||
|
pub struct EncryptedContentInit {
|
||||||
|
/// A [JSON Web Key](https://tools.ietf.org/html/rfc7517#appendix-A.3) object.
|
||||||
|
pub key: JsonWebKey,
|
||||||
|
|
||||||
|
/// The 128-bit unique counter block used by AES-CTR, encoded as unpadded base64.
|
||||||
|
pub iv: 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.
|
||||||
|
pub hashes: BTreeMap<String, Base64>,
|
||||||
|
|
||||||
|
/// Version of the encrypted attachments protocol.
|
||||||
|
///
|
||||||
|
/// Must be `v2`.
|
||||||
|
pub v: String,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl From<EncryptedContentInit> for EncryptedContent {
|
||||||
|
fn from(init: EncryptedContentInit) -> Self {
|
||||||
|
let EncryptedContentInit { key, iv, hashes, v } = init;
|
||||||
|
Self { key, iv, hashes, v }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user