pub struct StoredKeypackage {
pub keypackage_ref: Vec<u8>,
pub keypackage: Vec<u8>,
}Expand description
Entity representing a persisted KeyPackage
Fields§
§keypackage_ref: Vec<u8>§keypackage: Vec<u8>Trait Implementations§
Source§impl BorrowPrimaryKey for StoredKeypackage
impl BorrowPrimaryKey for StoredKeypackage
type BorrowedPrimaryKey = [u8]
Source§fn borrow_primary_key(&self) -> &Self::BorrowedPrimaryKey
fn borrow_primary_key(&self) -> &Self::BorrowedPrimaryKey
Borrow this entity’s primary key without copying any data. Read more
Source§fn get_borrowed<'life0, 'life1, 'async_trait, Q>(
conn: &'life0 mut Self::ConnectionType,
key: &'life1 Q,
) -> Pin<Box<dyn Future<Output = CryptoKeystoreResult<Option<Self>>> + Send + 'async_trait>>where
Self::PrimaryKey: Borrow<Q>,
Q: KeyType + 'async_trait,
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
fn get_borrowed<'life0, 'life1, 'async_trait, Q>(
conn: &'life0 mut Self::ConnectionType,
key: &'life1 Q,
) -> Pin<Box<dyn Future<Output = CryptoKeystoreResult<Option<Self>>> + Send + 'async_trait>>where
Self::PrimaryKey: Borrow<Q>,
Q: KeyType + 'async_trait,
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
Get an entity by a borrowed form of its primary key. Read more
Source§impl Clone for StoredKeypackage
impl Clone for StoredKeypackage
Source§fn clone(&self) -> StoredKeypackage
fn clone(&self) -> StoredKeypackage
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 StoredKeypackage
impl Debug for StoredKeypackage
Source§impl Decryptable<'static> for StoredKeypackage
impl Decryptable<'static> for StoredKeypackage
Source§impl<'de> Deserialize<'de> for StoredKeypackage
impl<'de> Deserialize<'de> for StoredKeypackage
Source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
Deserialize this value from the given Serde deserializer. Read more
Source§impl<'a> Encrypting<'a> for StoredKeypackage
impl<'a> Encrypting<'a> for StoredKeypackage
Source§type EncryptedForm = StoredKeypackageEncrypt<'a>
type EncryptedForm = StoredKeypackageEncrypt<'a>
This type must be serializable, but can depend on the lifetime of
self to reduce copying.Source§fn encrypt(
&'a self,
cipher: &Aes256Gcm,
) -> CryptoKeystoreResult<StoredKeypackageEncrypt<'_>>
fn encrypt( &'a self, cipher: &Aes256Gcm, ) -> CryptoKeystoreResult<StoredKeypackageEncrypt<'_>>
Make an instance of the encrypted form of this struct, for which all sensitive fields have been encrypted.
Source§impl Entity for StoredKeypackage
impl Entity for StoredKeypackage
fn id_raw(&self) -> &[u8] ⓘ
fn find_all<'life0, 'async_trait>(
conn: &'life0 mut Self::ConnectionType,
params: EntityFindParams,
) -> Pin<Box<dyn Future<Output = CryptoKeystoreResult<Vec<Self>>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
fn find_one<'life0, 'life1, 'async_trait>(
conn: &'life0 mut Self::ConnectionType,
id: &'life1 StringEntityId<'_>,
) -> Pin<Box<dyn Future<Output = CryptoKeystoreResult<Option<Self>>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
fn count<'life0, 'async_trait>(
conn: &'life0 mut Self::ConnectionType,
) -> Pin<Box<dyn Future<Output = CryptoKeystoreResult<usize>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
Source§fn merge_key(&self) -> Vec<u8> ⓘ
fn merge_key(&self) -> Vec<u8> ⓘ
The query results that are obtained during a transaction
from the transaction cache and the database are merged by this key.
fn find_many<'life0, 'life1, 'async_trait>(
conn: &'life0 mut Self::ConnectionType,
ids: &'life1 [StringEntityId<'_>],
) -> Pin<Box<dyn Future<Output = CryptoKeystoreResult<Vec<Self>>> + Send + 'async_trait>>where
Self: Send + 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
Source§impl Entity for StoredKeypackage
impl Entity for StoredKeypackage
Source§type PrimaryKey = Vec<u8>
type PrimaryKey = Vec<u8>
Each distinct
PrimaryKey uniquely identifies either 0 or 1 instance. Read moreSource§fn get<'life0, 'life1, 'async_trait>(
conn: &'life0 mut Self::ConnectionType,
key: &'life1 Self::PrimaryKey,
) -> Pin<Box<dyn Future<Output = CryptoKeystoreResult<Option<Self>>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
fn get<'life0, 'life1, 'async_trait>(
conn: &'life0 mut Self::ConnectionType,
key: &'life1 Self::PrimaryKey,
) -> Pin<Box<dyn Future<Output = CryptoKeystoreResult<Option<Self>>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
Get an entity by its primary key. Read more
Source§fn count<'life0, 'async_trait>(
conn: &'life0 mut Self::ConnectionType,
) -> Pin<Box<dyn Future<Output = CryptoKeystoreResult<u32>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
fn count<'life0, 'async_trait>(
conn: &'life0 mut Self::ConnectionType,
) -> Pin<Box<dyn Future<Output = CryptoKeystoreResult<u32>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
Count the number of entities of this type in the database.
Source§fn load_all<'life0, 'async_trait>(
conn: &'life0 mut Self::ConnectionType,
) -> Pin<Box<dyn Future<Output = CryptoKeystoreResult<Vec<Self>>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
fn load_all<'life0, 'async_trait>(
conn: &'life0 mut Self::ConnectionType,
) -> Pin<Box<dyn Future<Output = CryptoKeystoreResult<Vec<Self>>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
Retrieve all entities of this type from the database.
Source§impl EntityBase for StoredKeypackage
impl EntityBase for StoredKeypackage
Source§const COLLECTION_NAME: &'static str = "mls_keypackages"
const COLLECTION_NAME: &'static str = "mls_keypackages"
Beware: if you change the value of this constant on any WASM entity, you’ll need to do a data migration
not only because it is used as reference to the object store names but also for the value of the aad.
type ConnectionType = SqlCipherConnection
type AutoGeneratedFields = ()
fn to_missing_key_err_kind() -> MissingKeyErrorKind
fn to_transaction_entity(self) -> Entity
fn downcast<T: EntityBase>(&self) -> Option<&T>
Source§impl EntityBase for StoredKeypackage
impl EntityBase for StoredKeypackage
Source§const COLLECTION_NAME: &'static str = "mls_keypackages"
const COLLECTION_NAME: &'static str = "mls_keypackages"
Beware: if you change the value of this constant on any WASM entity, you’ll need to do a data migration
not only because it is used as reference to the object store names but also for the value of the aad.
type ConnectionType = SqlCipherConnection
type AutoGeneratedFields = ()
fn to_transaction_entity(self) -> Entity
fn downcast<T: EntityBase>(&self) -> Option<&T>
Source§impl<'a> EntityDatabaseMutation<'a> for StoredKeypackage
impl<'a> EntityDatabaseMutation<'a> for StoredKeypackage
type Transaction = TransactionWrapper<'a>
Source§fn save<'life0, 'async_trait>(
&'a self,
tx: &'life0 Self::Transaction,
) -> Pin<Box<dyn Future<Output = CryptoKeystoreResult<()>> + Send + 'async_trait>>where
Self: 'async_trait,
'a: 'async_trait,
'life0: 'async_trait,
fn save<'life0, 'async_trait>(
&'a self,
tx: &'life0 Self::Transaction,
) -> Pin<Box<dyn Future<Output = CryptoKeystoreResult<()>> + Send + 'async_trait>>where
Self: 'async_trait,
'a: 'async_trait,
'life0: 'async_trait,
Use the transaction’s interface to save this entity to the database
Source§fn count<'life0, 'async_trait>(
tx: &'life0 Self::Transaction,
) -> Pin<Box<dyn Future<Output = CryptoKeystoreResult<u32>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
fn count<'life0, 'async_trait>(
tx: &'life0 Self::Transaction,
) -> Pin<Box<dyn Future<Output = CryptoKeystoreResult<u32>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
Use the transaction’s interface to count the number of entities of this type in the database.
Source§fn delete<'life0, 'life1, 'async_trait>(
tx: &'life0 Self::Transaction,
id: &'life1 Self::PrimaryKey,
) -> Pin<Box<dyn Future<Output = CryptoKeystoreResult<bool>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
fn delete<'life0, 'life1, 'async_trait>(
tx: &'life0 Self::Transaction,
id: &'life1 Self::PrimaryKey,
) -> Pin<Box<dyn Future<Output = CryptoKeystoreResult<bool>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
Use the transaction’s inteface to delete this entity from the database. Read more
Source§impl<'a> EntityDeleteBorrowed<'a> for StoredKeypackage
impl<'a> EntityDeleteBorrowed<'a> for StoredKeypackage
Source§fn delete_borrowed<'life0, 'life1, 'async_trait, Q>(
tx: &'life0 <Self as EntityDatabaseMutation<'a>>::Transaction,
id: &'life1 Q,
) -> Pin<Box<dyn Future<Output = CryptoKeystoreResult<bool>> + Send + 'async_trait>>where
Self::PrimaryKey: Borrow<Q>,
Q: KeyType + 'async_trait,
Self: 'async_trait,
'a: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
fn delete_borrowed<'life0, 'life1, 'async_trait, Q>(
tx: &'life0 <Self as EntityDatabaseMutation<'a>>::Transaction,
id: &'life1 Q,
) -> Pin<Box<dyn Future<Output = CryptoKeystoreResult<bool>> + Send + 'async_trait>>where
Self::PrimaryKey: Borrow<Q>,
Q: KeyType + 'async_trait,
Self: 'async_trait,
'a: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
Delete an entity by a borrowed form of its primary key. Read more
Source§impl EntityTransactionExt for StoredKeypackage
impl EntityTransactionExt for StoredKeypackage
fn save<'life0, 'life1, 'life2, 'async_trait>(
&'life0 self,
transaction: &'life1 TransactionWrapper<'life2>,
) -> Pin<Box<dyn Future<Output = CryptoKeystoreResult<()>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
'life2: 'async_trait,
fn delete_fail_on_missing_id<'life0, 'life1, 'life2, 'async_trait>(
transaction: &'life0 TransactionWrapper<'life1>,
id: StringEntityId<'life2>,
) -> Pin<Box<dyn Future<Output = CryptoKeystoreResult<()>> + Send + 'async_trait>>where
'life0: 'async_trait,
'life1: 'async_trait,
'life2: 'async_trait,
fn pre_save<'a, 'async_trait>(
&'a mut self,
) -> Pin<Box<dyn Future<Output = CryptoKeystoreResult<Self::AutoGeneratedFields>> + Send + 'async_trait>>where
Self: Send + 'async_trait,
'a: 'async_trait,
fn delete<'life0, 'life1, 'life2, 'async_trait>(
tx: &'life0 TransactionWrapper<'life1>,
id: StringEntityId<'life2>,
) -> Pin<Box<dyn Future<Output = CryptoKeystoreResult<()>> + Send + 'async_trait>>where
Self: Send + 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
'life2: 'async_trait,
Source§impl PartialEq for StoredKeypackage
impl PartialEq for StoredKeypackage
Source§impl Serialize for StoredKeypackage
impl Serialize for StoredKeypackage
Source§impl ToValue for StoredKeypackage
impl ToValue for StoredKeypackage
Source§impl Zeroize for StoredKeypackage
impl Zeroize for StoredKeypackage
impl Eq for StoredKeypackage
impl StructuralPartialEq for StoredKeypackage
Auto Trait Implementations§
impl Freeze for StoredKeypackage
impl RefUnwindSafe for StoredKeypackage
impl Send for StoredKeypackage
impl Sync for StoredKeypackage
impl Unpin for StoredKeypackage
impl UnwindSafe for StoredKeypackage
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§impl<E> DecryptData for Ewhere
E: Entity,
impl<E> DecryptData for Ewhere
E: Entity,
Source§fn decrypt_data(
cipher: &AesGcm<Aes256, UInt<UInt<UInt<UInt<UTerm, B1>, B1>, B0>, B0>>,
primary_key: &<E as Entity>::PrimaryKey,
data: &[u8],
) -> Result<Vec<u8>, CryptoKeystoreError>
fn decrypt_data( cipher: &AesGcm<Aes256, UInt<UInt<UInt<UInt<UTerm, B1>, B1>, B0>, B0>>, primary_key: &<E as Entity>::PrimaryKey, data: &[u8], ) -> Result<Vec<u8>, CryptoKeystoreError>
Decrypt some data, symmetrically to the process
encrypt_data uses.Source§impl<E> EncryptData for Ewhere
E: Entity,
impl<E> EncryptData for Ewhere
E: Entity,
Source§impl<T> EntityIdStringExt for Twhere
T: Entity,
impl<T> EntityIdStringExt for Twhere
T: Entity,
§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Checks if this value is equivalent to the given key. Read more
§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Checks if this value is equivalent to the given key. Read more
§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Compare self to
key and return true if they are equal.Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more