pub struct Keypair(/* private fields */);
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) -> Self
pub fn generate<R>(csprng: &mut R) -> Self
Constructs a new, random Keypair
using a caller-provided RNG
Sourcepub fn from_bytes(bytes: &[u8]) -> Result<Self, SignatureError>
pub fn from_bytes(bytes: &[u8]) -> Result<Self, SignatureError>
Recovers a Keypair
from a byte array
Sourcepub fn from_base58_string(s: &str) -> Self
pub fn from_base58_string(s: &str) -> Self
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) -> Self
pub fn insecure_clone(&self) -> Self
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: Read>(reader: &mut R) -> Result<Self, Box<dyn Error>>
fn write<W: Write>(&self, writer: &mut W) -> Result<String, Box<dyn Error>>
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§impl SeedDerivable for Keypair
Available on crate feature seed-derivable
only.
impl SeedDerivable for Keypair
Available on crate feature
seed-derivable
only.fn from_seed(seed: &[u8]) -> Result<Self, Box<dyn Error>>
fn from_seed_and_derivation_path( seed: &[u8], derivation_path: Option<DerivationPath>, ) -> Result<Self, Box<dyn Error>>
fn from_seed_phrase_and_passphrase( seed_phrase: &str, passphrase: &str, ) -> Result<Self, 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