pub struct SecureWasmKemContext { /* private fields */ }Expand description
Secure WASM KEM Context
This context provides secure KEM operations with:
- Consistent error handling using Result<T, JsValue>
- Security validation for all inputs
- Protection against timing attacks
- Memory safety with automatic cleanup
Implementations§
Source§impl SecureWasmKemContext
impl SecureWasmKemContext
Sourcepub fn new() -> Result<SecureWasmKemContext, JsValue>
pub fn new() -> Result<SecureWasmKemContext, JsValue>
Create a new secure WASM KEM context
Sourcepub fn generate_keypair(
&mut self,
algorithm: &str,
randomness: Option<Uint8Array>,
) -> Result<JsValue, JsValue>
pub fn generate_keypair( &mut self, algorithm: &str, randomness: Option<Uint8Array>, ) -> Result<JsValue, JsValue>
Generate a KEM keypair
Sourcepub fn encapsulate(
&self,
algorithm: &str,
public_key: &Uint8Array,
randomness: Option<Uint8Array>,
) -> Result<JsValue, JsValue>
pub fn encapsulate( &self, algorithm: &str, public_key: &Uint8Array, randomness: Option<Uint8Array>, ) -> Result<JsValue, JsValue>
Encapsulate a shared secret
Sourcepub fn decapsulate(
&self,
algorithm: &str,
private_key: &Uint8Array,
ciphertext: &Uint8Array,
) -> Result<JsValue, JsValue>
pub fn decapsulate( &self, algorithm: &str, private_key: &Uint8Array, ciphertext: &Uint8Array, ) -> Result<JsValue, JsValue>
Decapsulate a shared secret
Sourcepub fn get_supported_algorithms(&self) -> Result<JsValue, JsValue>
pub fn get_supported_algorithms(&self) -> Result<JsValue, JsValue>
Get supported algorithms
Trait Implementations§
Source§impl From<SecureWasmKemContext> for JsValue
impl From<SecureWasmKemContext> for JsValue
Source§fn from(value: SecureWasmKemContext) -> JsValue
fn from(value: SecureWasmKemContext) -> JsValue
Converts to this type from the input type.
Source§impl FromWasmAbi for SecureWasmKemContext
impl FromWasmAbi for SecureWasmKemContext
Source§type Abi = WasmPtr<WasmRefCell<SecureWasmKemContext>>
type Abi = WasmPtr<WasmRefCell<SecureWasmKemContext>>
The Wasm ABI type that this converts from when coming back out from the
ABI boundary.
Source§unsafe fn from_abi(
js: <SecureWasmKemContext as FromWasmAbi>::Abi,
) -> SecureWasmKemContext
unsafe fn from_abi( js: <SecureWasmKemContext as FromWasmAbi>::Abi, ) -> SecureWasmKemContext
Source§impl IntoWasmAbi for SecureWasmKemContext
impl IntoWasmAbi for SecureWasmKemContext
Source§type Abi = WasmPtr<WasmRefCell<SecureWasmKemContext>>
type Abi = WasmPtr<WasmRefCell<SecureWasmKemContext>>
The Wasm ABI type that this converts into when crossing the ABI
boundary.
Source§fn into_abi(self) -> <SecureWasmKemContext as IntoWasmAbi>::Abi
fn into_abi(self) -> <SecureWasmKemContext as IntoWasmAbi>::Abi
Convert
self into Self::Abi so that it can be sent across the wasm
ABI boundary.Source§impl LongRefFromWasmAbi for SecureWasmKemContext
impl LongRefFromWasmAbi for SecureWasmKemContext
Source§type Abi = WasmPtr<WasmRefCell<SecureWasmKemContext>>
type Abi = WasmPtr<WasmRefCell<SecureWasmKemContext>>
Same as
RefFromWasmAbi::AbiSource§type Anchor = RcRef<SecureWasmKemContext>
type Anchor = RcRef<SecureWasmKemContext>
Same as
RefFromWasmAbi::AnchorSource§unsafe fn long_ref_from_abi(
js: <SecureWasmKemContext as LongRefFromWasmAbi>::Abi,
) -> <SecureWasmKemContext as LongRefFromWasmAbi>::Anchor
unsafe fn long_ref_from_abi( js: <SecureWasmKemContext as LongRefFromWasmAbi>::Abi, ) -> <SecureWasmKemContext as LongRefFromWasmAbi>::Anchor
Same as
RefFromWasmAbi::ref_from_abiSource§impl OptionFromWasmAbi for SecureWasmKemContext
impl OptionFromWasmAbi for SecureWasmKemContext
Source§fn is_none(abi: &<SecureWasmKemContext as FromWasmAbi>::Abi) -> bool
fn is_none(abi: &<SecureWasmKemContext as FromWasmAbi>::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 SecureWasmKemContext
impl OptionIntoWasmAbi for SecureWasmKemContext
Source§fn none() -> <SecureWasmKemContext as IntoWasmAbi>::Abi
fn none() -> <SecureWasmKemContext as IntoWasmAbi>::Abi
Returns an ABI instance indicating “none”, which JS will interpret as
the
None branch of this option. Read moreSource§impl RefFromWasmAbi for SecureWasmKemContext
impl RefFromWasmAbi for SecureWasmKemContext
Source§type Abi = WasmPtr<WasmRefCell<SecureWasmKemContext>>
type Abi = WasmPtr<WasmRefCell<SecureWasmKemContext>>
The Wasm ABI type references to
Self are recovered from.Source§type Anchor = RcRef<SecureWasmKemContext>
type Anchor = RcRef<SecureWasmKemContext>
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: <SecureWasmKemContext as RefFromWasmAbi>::Abi,
) -> <SecureWasmKemContext as RefFromWasmAbi>::Anchor
unsafe fn ref_from_abi( js: <SecureWasmKemContext as RefFromWasmAbi>::Abi, ) -> <SecureWasmKemContext as RefFromWasmAbi>::Anchor
Source§impl RefMutFromWasmAbi for SecureWasmKemContext
impl RefMutFromWasmAbi for SecureWasmKemContext
Source§type Abi = WasmPtr<WasmRefCell<SecureWasmKemContext>>
type Abi = WasmPtr<WasmRefCell<SecureWasmKemContext>>
Same as
RefFromWasmAbi::AbiSource§type Anchor = RcRefMut<SecureWasmKemContext>
type Anchor = RcRefMut<SecureWasmKemContext>
Same as
RefFromWasmAbi::AnchorSource§unsafe fn ref_mut_from_abi(
js: <SecureWasmKemContext as RefMutFromWasmAbi>::Abi,
) -> <SecureWasmKemContext as RefMutFromWasmAbi>::Anchor
unsafe fn ref_mut_from_abi( js: <SecureWasmKemContext as RefMutFromWasmAbi>::Abi, ) -> <SecureWasmKemContext as RefMutFromWasmAbi>::Anchor
Same as
RefFromWasmAbi::ref_from_abiSource§impl TryFromJsValue for SecureWasmKemContext
impl TryFromJsValue for SecureWasmKemContext
Source§fn try_from_js_value(value: JsValue) -> Result<SecureWasmKemContext, JsValue>
fn try_from_js_value(value: JsValue) -> Result<SecureWasmKemContext, JsValue>
Performs the conversion.
Source§fn try_from_js_value_ref(value: &JsValue) -> Option<SecureWasmKemContext>
fn try_from_js_value_ref(value: &JsValue) -> Option<SecureWasmKemContext>
Performs the conversion.
Source§impl VectorFromWasmAbi for SecureWasmKemContext
impl VectorFromWasmAbi for SecureWasmKemContext
type Abi = <Box<[JsValue]> as FromWasmAbi>::Abi
unsafe fn vector_from_abi( js: <SecureWasmKemContext as VectorFromWasmAbi>::Abi, ) -> Box<[SecureWasmKemContext]>
Source§impl VectorIntoWasmAbi for SecureWasmKemContext
impl VectorIntoWasmAbi for SecureWasmKemContext
type Abi = <Box<[JsValue]> as IntoWasmAbi>::Abi
fn vector_into_abi( vector: Box<[SecureWasmKemContext]>, ) -> <SecureWasmKemContext as VectorIntoWasmAbi>::Abi
Auto Trait Implementations§
impl Freeze for SecureWasmKemContext
impl !RefUnwindSafe for SecureWasmKemContext
impl Send for SecureWasmKemContext
impl Sync for SecureWasmKemContext
impl Unpin for SecureWasmKemContext
impl UnsafeUnpin for SecureWasmKemContext
impl !UnwindSafe for SecureWasmKemContext
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> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
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 moreSource§impl<T> Pointable for T
impl<T> Pointable for T
Source§impl<T> ReturnWasmAbi for Twhere
T: IntoWasmAbi,
impl<T> ReturnWasmAbi for Twhere
T: IntoWasmAbi,
Source§type Abi = <T as IntoWasmAbi>::Abi
type Abi = <T as IntoWasmAbi>::Abi
Same as
IntoWasmAbi::AbiSource§fn return_abi(self) -> <T as ReturnWasmAbi>::Abi
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.