Struct Cipher

Source
pub struct Cipher {
Show 26 fields pub id: Option<Uuid>, pub organization_id: Option<Uuid>, pub folder_id: Option<Uuid>, pub collection_ids: Vec<Uuid>, pub key: Option<EncString>, pub name: EncString, pub notes: Option<EncString>, pub type: CipherType, pub login: Option<Login>, pub identity: Option<Identity>, pub card: Option<Card>, pub secure_note: Option<SecureNote>, pub ssh_key: Option<SshKey>, pub favorite: bool, pub reprompt: CipherRepromptType, pub organization_use_totp: bool, pub edit: bool, pub permissions: Option<CipherPermissions>, pub view_password: bool, pub local_data: Option<LocalData>, pub attachments: Option<Vec<Attachment>>, pub fields: Option<Vec<Field>>, pub password_history: Option<Vec<PasswordHistory>>, pub creation_date: DateTime<Utc>, pub deleted_date: Option<DateTime<Utc>>, pub revision_date: DateTime<Utc>,
}

Fields§

§id: Option<Uuid>§organization_id: Option<Uuid>§folder_id: Option<Uuid>§collection_ids: Vec<Uuid>§key: Option<EncString>

More recent ciphers uses individual encryption keys to encrypt the other fields of the Cipher.

§name: EncString§notes: Option<EncString>§type: CipherType§login: Option<Login>§identity: Option<Identity>§card: Option<Card>§secure_note: Option<SecureNote>§ssh_key: Option<SshKey>§favorite: bool§reprompt: CipherRepromptType§organization_use_totp: bool§edit: bool§permissions: Option<CipherPermissions>§view_password: bool§local_data: Option<LocalData>§attachments: Option<Vec<Attachment>>§fields: Option<Vec<Field>>§password_history: Option<Vec<PasswordHistory>>§creation_date: DateTime<Utc>§deleted_date: Option<DateTime<Utc>>§revision_date: DateTime<Utc>

Implementations§

Source§

impl Cipher

Source

pub(super) fn decrypt_cipher_key( ctx: &mut KeyStoreContext<'_, KeyIds>, key: SymmetricKeyId, ciphers_key: &Option<EncString>, ) -> Result<SymmetricKeyId, CryptoError>

Decrypt the individual encryption key for this cipher into the provided KeyStoreContext and return it’s identifier. Note that some ciphers do not have individual encryption keys, in which case this will return the provided key identifier instead

§Arguments
  • ctx - The key store context where the cipher key will be decrypted, if it exists
  • key - The key to use to decrypt the cipher key, this should be the user or organization key
  • ciphers_key - The encrypted cipher key
Source

fn get_kind(&self) -> Option<&dyn CipherKind>

Temporary helper to return a CipherKind instance based on the cipher type.

Source

fn decrypt_subtitle( &self, ctx: &mut KeyStoreContext<'_, KeyIds>, key: SymmetricKeyId, ) -> Result<String, CryptoError>

Returns the decrypted subtitle for the cipher, if applicable.

Source

fn get_copyable_fields(&self) -> Vec<CopyableCipherFields>

Returns a list of copyable field names for this cipher, based on the cipher type and populated properties.

Trait Implementations§

Source§

impl Clone for Cipher

Source§

fn clone(&self) -> Cipher

Returns a copy of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl<UT> ConvertError<UT> for Cipher

Source§

fn try_convert_unexpected_callback_error( e: UnexpectedUniFFICallbackError, ) -> Result<Self>

Source§

impl Debug for Cipher

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Decryptable<KeyIds, SymmetricKeyId, CipherListView> for Cipher

Source§

impl Decryptable<KeyIds, SymmetricKeyId, CipherView> for Cipher

Source§

impl<'de> Deserialize<'de> for Cipher

Source§

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 Encryptable<KeyIds, SymmetricKeyId, Cipher> for CipherView

Source§

impl<UT> FfiConverter<UT> for Cipher

Source§

const TYPE_ID_META: MetadataBuffer

Type ID metadata, serialized into a [MetadataBuffer].
Source§

type FfiType = RustBuffer

The low-level type used for passing values of this type over the FFI. Read more
Source§

fn lower(v: Self) -> RustBuffer

Lower a rust value of the target type, into an FFI value of type Self::FfiType. Read more
Source§

fn try_lift(buf: RustBuffer) -> Result<Self>

Lift a rust value of the target type, from an FFI value of type Self::FfiType. Read more
Source§

fn write(obj: Self, buf: &mut Vec<u8>)

Write a rust value into a buffer, to send over the FFI in serialized form. Read more
Source§

fn try_read(buf: &mut &[u8]) -> Result<Self>

Read a rust value from a buffer, received over the FFI in serialized form. Read more
Source§

impl From<Cipher> for JsValue

Source§

fn from(value: Cipher) -> Self

Converts to this type from the input type.
Source§

impl FromWasmAbi for Cipher
where Self: DeserializeOwned,

Source§

type Abi = <JsType as FromWasmAbi>::Abi

The Wasm ABI type that this converts from when coming back out from the ABI boundary.
Source§

unsafe fn from_abi(js: Self::Abi) -> Self

Recover a Self from Self::Abi. Read more
Source§

impl IdentifyKey<SymmetricKeyId> for Cipher

Source§

impl IntoWasmAbi for Cipher

Source§

type Abi = <JsType as IntoWasmAbi>::Abi

The Wasm ABI type that this converts into when crossing the ABI boundary.
Source§

fn into_abi(self) -> Self::Abi

Convert self into Self::Abi so that it can be sent across the wasm ABI boundary.
Source§

impl<UT> Lift<UT> for Cipher

Source§

type FfiType = <Cipher as FfiConverter<UT>>::FfiType

Source§

fn try_lift(v: Self::FfiType) -> Result<Self>

Source§

fn try_read(buf: &mut &[u8]) -> Result<Self>

§

fn try_lift_from_rust_buffer(v: RustBuffer) -> Result<Self, Error>

Convenience method
Source§

impl<UT> LiftRef<UT> for Cipher

Source§

impl<UT> LiftReturn<UT> for Cipher

Source§

type ReturnType = <Cipher as Lift<UT>>::FfiType

FFI return type for trait interfaces
Source§

fn try_lift_successful_return(v: Self::ReturnType) -> Result<Self>

Lift a successfully returned value from a trait interface
§

fn lift_foreign_return( ffi_return: Self::ReturnType, call_status: RustCallStatus, ) -> Self

Lift a foreign returned value from a trait interface Read more
§

fn lift_error(_buf: RustBuffer) -> Self

Lift a Rust value for a callback interface method error result Read more
§

fn handle_callback_unexpected_error(e: UnexpectedUniFFICallbackError) -> Self

Lift a Rust value for an unexpected callback interface error Read more
Source§

impl<UT> Lower<UT> for Cipher

Source§

type FfiType = <Cipher as FfiConverter<UT>>::FfiType

Source§

fn lower(obj: Self) -> Self::FfiType

Source§

fn write(obj: Self, buf: &mut Vec<u8>)

§

fn lower_into_rust_buffer(obj: Self) -> RustBuffer

Convenience method
Source§

impl<UT> LowerError<UT> for Cipher

Source§

fn lower_error(obj: Self) -> RustBuffer

Lower this value for scaffolding function return Read more
Source§

impl<UT> LowerReturn<UT> for Cipher

Source§

type ReturnType = <Cipher as Lower<UT>>::FfiType

The type that should be returned by scaffolding functions for this type. Read more
Source§

fn lower_return(v: Self) -> Result<Self::ReturnType, RustCallError>

Lower the return value from an scaffolding call Read more
§

fn handle_failed_lift( error: LiftArgsError, ) -> Result<Self::ReturnType, RustCallError>

Lower the return value for failed argument lifts Read more
Source§

impl OptionFromWasmAbi for Cipher
where Self: DeserializeOwned,

Source§

fn is_none(js: &Self::Abi) -> bool

Tests whether the argument is a “none” instance. If so it will be deserialized as None, and otherwise it will be passed to FromWasmAbi.
Source§

impl OptionIntoWasmAbi for Cipher

Source§

fn none() -> Self::Abi

Returns an ABI instance indicating “none”, which JS will interpret as the None branch of this option. Read more
Source§

impl RefFromWasmAbi for Cipher
where Self: DeserializeOwned,

Source§

type Abi = <JsType as RefFromWasmAbi>::Abi

The Wasm ABI type references to Self are recovered from.
Source§

type Anchor = SelfOwner<Cipher>

The type that holds the reference to Self for the duration of the invocation of the function that has an &Self parameter. This is required to ensure that the lifetimes don’t persist beyond one function call, and so that they remain anonymous.
Source§

unsafe fn ref_from_abi(js: Self::Abi) -> Self::Anchor

Recover a Self::Anchor from Self::Abi. Read more
Source§

impl RepositoryItem for Cipher

Source§

const NAME: &'static str = "Cipher"

The name of the type implementing this trait.
Source§

fn type_id() -> TypeId

Returns the TypeId of the type implementing this trait.
Source§

impl Serialize for Cipher

Source§

fn serialize<__S>(&self, __serializer: __S) -> Result<__S::Ok, __S::Error>
where __S: Serializer,

Serialize this value into the given Serde serializer. Read more
Source§

impl TryFrom<CipherDetailsResponseModel> for Cipher

Source§

type Error = VaultParseError

The type returned in the event of a conversion error.
Source§

fn try_from(cipher: CipherDetailsResponseModel) -> Result<Self, Self::Error>

Performs the conversion.
Source§

impl Tsify for Cipher

Source§

const DECL: &'static str = "export interface Cipher {\n id: Uuid | undefined;\n organizationId: Uuid | undefined;\n folderId: Uuid | undefined;\n collectionIds: Uuid[];\n /**\n * More recent ciphers uses individual encryption keys to encrypt the other fields of the\n * Cipher.\n */\n key: EncString | undefined;\n name: EncString;\n notes: EncString | undefined;\n type: CipherType;\n login: Login | undefined;\n identity: Identity | undefined;\n card: Card | undefined;\n secureNote: SecureNote | undefined;\n sshKey: SshKey | undefined;\n favorite: boolean;\n reprompt: CipherRepromptType;\n organizationUseTotp: boolean;\n edit: boolean;\n permissions: CipherPermissions | undefined;\n viewPassword: boolean;\n localData: LocalData | undefined;\n attachments: Attachment[] | undefined;\n fields: Field[] | undefined;\n passwordHistory: PasswordHistory[] | undefined;\n creationDate: DateTime<Utc>;\n deletedDate: DateTime<Utc> | undefined;\n revisionDate: DateTime<Utc>;\n}"

Source§

const SERIALIZATION_CONFIG: SerializationConfig

Source§

type JsType = JsType

§

fn into_js(&self) -> Result<Self::JsType, Error>
where Self: Serialize,

§

fn from_js<T>(js: T) -> Result<Self, Error>
where T: Into<JsValue>, Self: DeserializeOwned,

Source§

impl<UT> TypeId<UT> for Cipher

Source§

const TYPE_ID_META: MetadataBuffer

Source§

impl VectorFromWasmAbi for Cipher
where Self: DeserializeOwned,

Source§

type Abi = <JsType as VectorFromWasmAbi>::Abi

Source§

unsafe fn vector_from_abi(js: Self::Abi) -> Box<[Self]>

Source§

impl VectorIntoWasmAbi for Cipher

Source§

type Abi = <JsType as VectorIntoWasmAbi>::Abi

Source§

fn vector_into_abi(vector: Box<[Self]>) -> Self::Abi

Source§

impl WasmDescribe for Cipher

Source§

impl WasmDescribeVector for Cipher

Source§

impl Internal for Cipher

Auto Trait Implementations§

§

impl Freeze for Cipher

§

impl RefUnwindSafe for Cipher

§

impl Send for Cipher

§

impl Sync for Cipher

§

impl Unpin for Cipher

§

impl UnwindSafe for Cipher

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
§

impl<T> CompatExt for T

§

fn compat(self) -> Compat<T>

Applies the [Compat] adapter by value. Read more
§

fn compat_ref(&self) -> Compat<&T>

Applies the [Compat] adapter by shared reference. Read more
§

fn compat_mut(&mut self) -> Compat<&mut T>

Applies the [Compat] adapter by mutable reference. Read more
Source§

impl<T> DynClone for T
where T: Clone,

Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T, UT> HandleAlloc<UT> for T
where T: Send + Sync,

§

fn new_handle(value: Arc<T>) -> Handle

Create a new handle for an Arc value Read more
§

unsafe fn clone_handle(handle: Handle) -> Handle

Clone a handle Read more
§

unsafe fn consume_handle(handle: Handle) -> Arc<T>

Consume a handle, getting back the initial Arc<> Read more
§

unsafe fn get_arc(handle: Handle) -> Arc<Self>

Get a clone of the Arc<> using a “borrowed” handle. Read more
§

impl<T> Instrument for T

§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided [Span], returning an Instrumented wrapper. Read more
§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> IntoEither for T

Source§

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 more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

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
§

impl<T> Pointable for T

§

const ALIGN: usize

The alignment of pointer.
§

type Init = T

The type for initializers.
§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
§

impl<T> PolicyExt for T
where T: ?Sized,

§

fn and<P, B, E>(self, other: P) -> And<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns [Action::Follow] only if self and other return Action::Follow. Read more
§

fn or<P, B, E>(self, other: P) -> Or<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns [Action::Follow] if either self or other returns Action::Follow. Read more
Source§

impl<T> ReturnWasmAbi for T
where T: IntoWasmAbi,

Source§

type Abi = <T as IntoWasmAbi>::Abi

Same as IntoWasmAbi::Abi
Source§

fn return_abi(self) -> <T as ReturnWasmAbi>::Abi

Same as IntoWasmAbi::into_abi, except that it may throw and never return in the case of Err.
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

§

fn vzip(self) -> V

§

impl<T> WithSubscriber for T

§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a [WithDispatch] wrapper. Read more
Source§

impl<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,

§

impl<T> ErasedDestructor for T
where T: 'static,