Struct JsBip39

Source
pub struct JsBip39 { /* private fields */ }
Expand description

Tool for generating, validating and parsing BIP-0039 phrases in different supported languages.

Implementations§

Source§

impl JsBip39

Source

pub fn new(lang_code: &str) -> Result<JsBip39, JsValue>

Creates an object that can handle BIP39 phrases in a given language. (e.g. ‘en’)

Source

pub fn generate(&self) -> Result<JsBip39Phrase, JsValue>

Creates a new phrase using the CSPRNG available on the platform.

Source

pub fn entropy(&self, entropy: &[u8]) -> Result<JsBip39Phrase, JsValue>

Creates a new phrase using the 256 bits of entropy provided in a buffer. IOP encourages using 24 word phrases everywhere.

Source

pub fn short_entropy(&self, entropy: &[u8]) -> Result<JsBip39Phrase, JsValue>

Creates a new phrase using the entropy provided in a buffer. This method is only for compatibility with other wallets. Check the BIP39 standard for the buffer sizes allowed.

Source

pub fn validate_phrase(&self, phrase: &str) -> Result<(), JsValue>

Validates a whole BIP39 mnemonic phrase. Because the phrase contains some checksum, the whole phrase can be invalid even when each word itself is valid. Note also, that the standards only allows NFKD normalization of Unicode codepoints, and a single space between words, but this library is more tolerant and provides normalization for those.

Source

pub fn list_words(&self, prefix: &str) -> Box<[JsValue]>

Lists all words in the BIP39 dictionary, which start with the given prefix.

Can be used in 3 different ways:

  • When the prefix is empty, the sorted list of all words are returned
  • When the prefix is a partial word, the returned list can be used for auto-completion
  • When the returned list is empty, the prefix is not a valid word in the dictionary
Source

pub fn phrase(&self, phrase: &str) -> Result<JsBip39Phrase, JsValue>

Validates a whole 24-word BIP39 mnemonic phrase and returns an intermediate object that can be later converted into a Seed with an optional password.

Source

pub fn short_phrase(&self, phrase: &str) -> Result<JsBip39Phrase, JsValue>

Validates a whole BIP39 mnemonic phrase and returns an intermediate object similar to {@link phrase}. This method is only for compatibility with other wallets. Check the BIP39 standard for the number of words allowed.

Trait Implementations§

Source§

impl Clone for JsBip39

Source§

fn clone(&self) -> JsBip39

Returns a duplicate 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 JsBip39

Source§

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

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

impl From<JsBip39> for JsValue

Source§

fn from(value: JsBip39) -> JsValue

Converts to this type from the input type.
Source§

impl FromWasmAbi for JsBip39

Source§

type Abi = u32

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

unsafe fn from_abi(js: u32) -> JsBip39

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

impl IntoWasmAbi for JsBip39

Source§

type Abi = u32

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

fn into_abi(self) -> u32

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

impl LongRefFromWasmAbi for JsBip39

Source§

type Abi = u32

Same as RefFromWasmAbi::Abi
Source§

type Anchor = RcRef<JsBip39>

Same as RefFromWasmAbi::Anchor
Source§

unsafe fn long_ref_from_abi( js: <JsBip39 as LongRefFromWasmAbi>::Abi, ) -> <JsBip39 as LongRefFromWasmAbi>::Anchor

Same as RefFromWasmAbi::ref_from_abi
Source§

impl OptionFromWasmAbi for JsBip39

Source§

fn is_none(abi: &<JsBip39 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 JsBip39

Source§

fn none() -> <JsBip39 as IntoWasmAbi>::Abi

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

impl RefFromWasmAbi for JsBip39

Source§

type Abi = u32

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

type Anchor = RcRef<JsBip39>

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: <JsBip39 as RefFromWasmAbi>::Abi, ) -> <JsBip39 as RefFromWasmAbi>::Anchor

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

impl RefMutFromWasmAbi for JsBip39

Source§

type Abi = u32

Same as RefFromWasmAbi::Abi
Source§

type Anchor = RcRefMut<JsBip39>

Same as RefFromWasmAbi::Anchor
Source§

unsafe fn ref_mut_from_abi( js: <JsBip39 as RefMutFromWasmAbi>::Abi, ) -> <JsBip39 as RefMutFromWasmAbi>::Anchor

Same as RefFromWasmAbi::ref_from_abi
Source§

impl TryFromJsValue for JsBip39

Source§

type Error = JsValue

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

fn try_from_js_value( value: JsValue, ) -> Result<JsBip39, <JsBip39 as TryFromJsValue>::Error>

Performs the conversion.
Source§

impl VectorFromWasmAbi for JsBip39

Source§

impl VectorIntoWasmAbi for JsBip39

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

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

Source§

fn vzip(self) -> V