DydxCredential

Struct DydxCredential 

Source
pub struct DydxCredential {
    pub address: String,
    pub authenticator_ids: Vec<u64>,
    /* private fields */
}
Expand description

dYdX wallet credentials for signing blockchain transactions.

Uses secp256k1 for signing as per Cosmos SDK specifications. The underlying SigningKey from cosmrs (backed by k256) implements Zeroize, ensuring private key material is securely cleared from memory on drop.

Fields§

§address: String

Bech32-encoded account address (e.g., dydx1…).

§authenticator_ids: Vec<u64>

Optional authenticator IDs for permissioned key trading.

Implementations§

Source§

impl DydxCredential

Source

pub fn from_mnemonic( mnemonic_phrase: &str, account_index: u32, authenticator_ids: Vec<u64>, ) -> Result<Self>

Creates a new DydxCredential from a mnemonic phrase.

§Errors

Returns an error if the mnemonic is invalid or key derivation fails.

Source

pub fn from_private_key( private_key_hex: &str, authenticator_ids: Vec<u64>, ) -> Result<Self>

Creates a new DydxCredential from a raw private key.

§Errors

Returns an error if private key is invalid.

Source

pub fn account_id(&self) -> Result<AccountId>

Returns the account ID for this credential.

§Errors

Returns an error if the address cannot be parsed as a valid account ID.

Source

pub fn sign(&self, sign_doc: &SignDoc) -> Result<Vec<u8>>

Signs a transaction SignDoc.

This produces the signature bytes that will be included in the transaction.

§Errors

Returns an error if SignDoc serialization or signing fails.

Source

pub fn sign_bytes(&self, message: &[u8]) -> Result<Vec<u8>>

Signs raw message bytes.

Used for custom signing operations outside of standard transaction flow.

§Errors

Returns an error if signing fails.

Source

pub fn public_key(&self) -> PublicKey

Returns the public key for this credential.

Trait Implementations§

Source§

impl Debug for DydxCredential

Source§

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

Formats the value using the given formatter. Read more

Auto Trait Implementations§

Blanket Implementations§

§

impl<T> Any for T
where T: 'static + ?Sized,

§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
§

impl<T> Borrow<T> for T
where T: ?Sized,

§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
§

impl<T> BorrowMut<T> for T
where T: ?Sized,

§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
§

impl<T> From<T> for T

§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T> Instrument for T

§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided [Span], returning an Instrumented wrapper. Read more
§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
§

impl<T, U> Into<U> for T
where U: From<T>,

§

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> IntoEither for T

Source§

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

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

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
§

impl<T> IntoRequest<T> for T

§

fn into_request(self) -> Request<T>

Wrap the input message T in a tonic::Request
§

impl<L> LayerExt<L> for L

§

fn named_layer<S>(&self, service: S) -> Layered<<L as Layer<S>>::Service, S>
where L: Layer<S>,

Applies the layer to a service and wraps it in [Layered].
§

impl<T> PolicyExt for T
where T: ?Sized,

§

fn and<P, B, E>(self, other: P) -> And<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns [Action::Follow] only if self and other return Action::Follow. Read more
§

fn or<P, B, E>(self, other: P) -> Or<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns [Action::Follow] if either self or other returns Action::Follow. Read more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

§

type Error = Infallible

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

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

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

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
§

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

§

fn vzip(self) -> V

§

impl<T> WithSubscriber for T

§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

impl<T> Ungil for T
where T: Send,