Enum ImportKeyError

Source
pub enum ImportKeyError {
    Syntax,
    Type,
    InvalidKeyFormat,
    Generic(Error),
}
Expand description

Errors that can occur when importing cryptographic keys.

These errors map to the exceptions defined in the Web Crypto API specification for key import operations.

See MDN Documentation

Variants§

§

Syntax

Indicates that the key usage array is empty for a secret or private key.

This error occurs when:

  • No key usages are specified during import
  • The key type requires at least one usage to be specified

Key usages typically include operations like “encrypt”, “decrypt”, “sign”, or “verify”.

§

Type

Indicates that the key data is not suitable for the specified format.

This error occurs when:

  • The key data is malformed
  • The key data doesn’t match the expected format
  • The key data is invalid for the specified algorithm

For example, trying to import non-AES data as an AES key would trigger this error.

§

InvalidKeyFormat

Indicates that an invalid key format was specified during import.

This error occurs when:

  • The specified format (e.g., “raw”, “pkcs8”, “spki”, “jwk”) is not supported
  • The specified format is not appropriate for the key type

For example, trying to import a symmetric key using “spki” format would trigger this error.

§

Generic(Error)

A wrapper for other types of errors that may occur during key import.

This includes general Web Crypto API errors and other unexpected failures.

Trait Implementations§

Source§

impl Clone for ImportKeyError

Source§

fn clone(&self) -> ImportKeyError

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 Debug for ImportKeyError

Source§

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

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

impl Display for ImportKeyError

Source§

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

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

impl Error for ImportKeyError

Source§

fn source(&self) -> Option<&(dyn Error + 'static)>

Returns the lower-level source of this error, if any. Read more
1.0.0 · Source§

fn description(&self) -> &str

👎Deprecated since 1.42.0: use the Display impl or to_string()
1.0.0 · Source§

fn cause(&self) -> Option<&dyn Error>

👎Deprecated since 1.33.0: replaced by Error::source, which can support downcasting
Source§

fn provide<'a>(&'a self, request: &mut Request<'a>)

🔬This is a nightly-only experimental API. (error_generic_member_access)
Provides type-based access to context intended for error reports. Read more
Source§

impl From<Error> for ImportKeyError

Source§

fn from(source: Error) -> Self

Converts to this type from the input type.
Source§

impl From<JsValue> for ImportKeyError

Source§

fn from(value: JsValue) -> Self

Converts a JavaScript value into an ImportKeyError.

Maps specific DOM exceptions to their corresponding ImportKeyError variants:

  • SyntaxErrorImportKeyError::Syntax
  • DataErrorImportKeyError::InvalidKeyFormat
  • JavaScript SyntaxErrorImportKeyError::Type
  • Other errors → ImportKeyError::Generic
§Arguments
  • value - The JavaScript value to convert
§Returns

The corresponding ImportKeyError variant

Auto Trait Implementations§

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

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

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> 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> ToString for T
where T: Display + ?Sized,

Source§

fn to_string(&self) -> String

Converts the given value to a String. 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.