pub struct Keypair(/* private fields */);
Available on crate feature
full
only.Expand description
A vanilla Ed25519 key pair
Implementations§
Source§impl Keypair
impl Keypair
Sourcepub const SECRET_KEY_LENGTH: usize = 32usize
pub const SECRET_KEY_LENGTH: usize = 32usize
Can be used for generating a Keypair without a dependency on rand
types
Sourcepub fn generate<R>(csprng: &mut R) -> Keypair
pub fn generate<R>(csprng: &mut R) -> Keypair
Constructs a new, random Keypair
using a caller-provided RNG
Sourcepub fn from_base58_string(s: &str) -> Keypair
pub fn from_base58_string(s: &str) -> Keypair
Recovers a Keypair
from a base58-encoded string
Sourcepub fn to_base58_string(&self) -> String
pub fn to_base58_string(&self) -> String
Returns this Keypair
as a base58-encoded string
Sourcepub fn insecure_clone(&self) -> Keypair
pub fn insecure_clone(&self) -> Keypair
Allows Keypair cloning
Note that the Clone
trait is intentionally unimplemented because making a
second copy of sensitive secret keys in memory is usually a bad idea.
Only use this in tests or when strictly required. Consider using std::sync::Arc<Keypair>
instead.
Trait Implementations§
Source§impl EncodableKey for Keypair
impl EncodableKey for Keypair
fn read<R>(reader: &mut R) -> Result<Keypair, Box<dyn Error>>where
R: Read,
fn write<W>(&self, writer: &mut W) -> Result<String, Box<dyn Error>>where
W: Write,
fn read_from_file<F>(path: F) -> Result<Self, Box<dyn Error>>
fn write_to_file<F>(&self, outfile: F) -> Result<String, Box<dyn Error>>
Source§impl EncodableKeypair for Keypair
impl EncodableKeypair for Keypair
Source§fn encodable_pubkey(&self) -> <Keypair as EncodableKeypair>::Pubkey
fn encodable_pubkey(&self) -> <Keypair as EncodableKeypair>::Pubkey
Returns the associated pubkey. Use this function specifically for settings that involve
reading or writing pubkeys. For other settings, use Signer::pubkey()
instead.
type Pubkey = Pubkey
Source§impl SeedDerivable for Keypair
impl SeedDerivable for Keypair
fn from_seed(seed: &[u8]) -> Result<Keypair, Box<dyn Error>>
fn from_seed_and_derivation_path( seed: &[u8], derivation_path: Option<DerivationPath>, ) -> Result<Keypair, Box<dyn Error>>
fn from_seed_phrase_and_passphrase( seed_phrase: &str, passphrase: &str, ) -> Result<Keypair, Box<dyn Error>>
Source§impl Signer for Keypair
impl Signer for Keypair
Source§fn pubkey(&self) -> Pubkey
fn pubkey(&self) -> Pubkey
Infallibly gets the implementor’s public key. Returns the all-zeros
Pubkey
if the implementor has none.Source§fn try_pubkey(&self) -> Result<Pubkey, SignerError>
fn try_pubkey(&self) -> Result<Pubkey, SignerError>
Fallibly gets the implementor’s public key
Source§fn sign_message(&self, message: &[u8]) -> Signature
fn sign_message(&self, message: &[u8]) -> Signature
Infallibly produces an Ed25519 signature over the provided
message
bytes. Returns the all-zeros Signature
if signing is not possible.Source§fn try_sign_message(&self, message: &[u8]) -> Result<Signature, SignerError>
fn try_sign_message(&self, message: &[u8]) -> Result<Signature, SignerError>
Fallibly produces an Ed25519 signature over the provided
message
bytes.Source§fn is_interactive(&self) -> bool
fn is_interactive(&self) -> bool
Whether the implementation requires user interaction to sign
Auto Trait Implementations§
impl Freeze for Keypair
impl RefUnwindSafe for Keypair
impl Send for Keypair
impl Sync for Keypair
impl Unpin for Keypair
impl UnwindSafe for Keypair
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> 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