Enum solana_client::thin_client::ThinClient

source ·
pub enum ThinClient {
    Quic(ThinClient<QuicPool, QuicConnectionManager, QuicConfig>),
    Udp(ThinClient<UdpPool, UdpConnectionManager, UdpConfig>),
}
Expand description

A thin wrapper over thin-client/ThinClient to ease construction of the ThinClient for code dealing both with udp and quic. For the scenario only using udp or quic, use thin-client/ThinClient directly.

Variants§

Implementations§

source§

impl ThinClient

source

pub fn new( rpc_addr: SocketAddr, tpu_addr: SocketAddr, connection_cache: Arc<ConnectionCache> ) -> Self

Create a new ThinClient that will interface with the Rpc at rpc_addr using TCP and the Tpu at tpu_addr over transactions_socket using Quic or UDP (currently hardcoded to UDP)

source

pub fn new_socket_with_timeout( rpc_addr: SocketAddr, tpu_addr: SocketAddr, timeout: Duration, connection_cache: Arc<ConnectionCache> ) -> Self

source

pub fn new_from_addrs( rpc_addrs: Vec<SocketAddr>, tpu_addrs: Vec<SocketAddr>, connection_cache: Arc<ConnectionCache> ) -> Self

source

pub fn rpc_client(&self) -> &RpcClient

source

pub fn retry_transfer_until_confirmed( &self, keypair: &Keypair, transaction: &mut Transaction, tries: usize, min_confirmed_blocks: usize ) -> TransportResult<Signature>

source

pub fn retry_transfer( &self, keypair: &Keypair, transaction: &mut Transaction, tries: usize ) -> TransportResult<Signature>

source

pub fn send_and_confirm_transaction<T: Signers + ?Sized>( &self, keypairs: &T, transaction: &mut Transaction, tries: usize, pending_confirmations: usize ) -> TransportResult<Signature>

source

pub fn poll_get_balance(&self, pubkey: &Pubkey) -> TransportResult<u64>

source

pub fn poll_get_balance_with_commitment( &self, pubkey: &Pubkey, commitment_config: CommitmentConfig ) -> TransportResult<u64>

source

pub fn wait_for_balance( &self, pubkey: &Pubkey, expected_balance: Option<u64> ) -> Option<u64>

source

pub fn get_program_accounts_with_config( &self, pubkey: &Pubkey, config: RpcProgramAccountsConfig ) -> TransportResult<Vec<(Pubkey, Account)>>

source

pub fn wait_for_balance_with_commitment( &self, pubkey: &Pubkey, expected_balance: Option<u64>, commitment_config: CommitmentConfig ) -> Option<u64>

source

pub fn poll_for_signature_with_commitment( &self, signature: &Signature, commitment_config: CommitmentConfig ) -> TransportResult<()>

source

pub fn get_num_blocks_since_signature_confirmation( &mut self, sig: &Signature ) -> TransportResult<usize>

Trait Implementations§

source§

impl AsyncClient for ThinClient

source§

fn async_send_versioned_transaction( &self, transaction: VersionedTransaction ) -> TransportResult<Signature>

Send a signed versioned transaction, but don’t wait to see if the server accepted it.
source§

fn async_send_versioned_transaction_batch( &self, batch: Vec<VersionedTransaction> ) -> TransportResult<()>

Send a batch of signed versioned transactions without confirmation.
source§

fn async_send_transaction( &self, transaction: Transaction ) -> Result<Signature, TransportError>

Send a signed transaction, but don’t wait to see if the server accepted it.
source§

fn async_send_batch( &self, transactions: Vec<Transaction> ) -> Result<(), TransportError>

Send a batch of signed transactions without confirmation.
source§

fn async_send_message<T>( &self, keypairs: &T, message: Message, recent_blockhash: Hash ) -> Result<Signature, TransportError>
where T: Signers + ?Sized,

Create a transaction from the given message, and send it to the server, but don’t wait for to see if the server accepted it.
source§

fn async_send_instruction( &self, keypair: &Keypair, instruction: Instruction, recent_blockhash: Hash ) -> Result<Signature, TransportError>

Create a transaction from a single instruction that only requires a single signer. Then send it to the server, but don’t wait for a reply.
source§

fn async_transfer( &self, lamports: u64, keypair: &Keypair, pubkey: &Pubkey, recent_blockhash: Hash ) -> Result<Signature, TransportError>

Attempt to transfer lamports from keypair to pubkey, but don’t wait to confirm.
source§

impl Client for ThinClient

source§

impl SyncClient for ThinClient

source§

fn send_and_confirm_message<T: Signers + ?Sized>( &self, keypairs: &T, message: Message ) -> TransportResult<Signature>

Create a transaction from the given message, and send it to the server, retrying as-needed.
source§

fn send_and_confirm_instruction( &self, keypair: &Keypair, instruction: Instruction ) -> TransportResult<Signature>

Create a transaction from a single instruction that only requires a single signer. Then send it to the server, retrying as-needed.
source§

fn transfer_and_confirm( &self, lamports: u64, keypair: &Keypair, pubkey: &Pubkey ) -> TransportResult<Signature>

Transfer lamports from keypair to pubkey, retrying until the transfer completes or produces and error.
source§

fn get_account_data(&self, pubkey: &Pubkey) -> TransportResult<Option<Vec<u8>>>

Get an account or None if not found.
source§

fn get_account(&self, pubkey: &Pubkey) -> TransportResult<Option<Account>>

Get an account or None if not found.
source§

fn get_account_with_commitment( &self, pubkey: &Pubkey, commitment_config: CommitmentConfig ) -> TransportResult<Option<Account>>

Get an account or None if not found. Uses explicit commitment configuration.
source§

fn get_balance(&self, pubkey: &Pubkey) -> TransportResult<u64>

Get account balance or 0 if not found.
source§

fn get_balance_with_commitment( &self, pubkey: &Pubkey, commitment_config: CommitmentConfig ) -> TransportResult<u64>

Get account balance or 0 if not found. Uses explicit commitment configuration.
source§

fn get_minimum_balance_for_rent_exemption( &self, data_len: usize ) -> TransportResult<u64>

source§

fn get_recent_blockhash(&self) -> TransportResult<(Hash, FeeCalculator)>

👎Deprecated since 1.9.0: Please use get_latest_blockhash instead
Get recent blockhash
source§

fn get_recent_blockhash_with_commitment( &self, commitment_config: CommitmentConfig ) -> TransportResult<(Hash, FeeCalculator, Slot)>

👎Deprecated since 1.9.0: Please use get_latest_blockhash_with_commitment and get_latest_blockhash_with_commitment instead
Get recent blockhash. Uses explicit commitment configuration.
source§

fn get_fee_calculator_for_blockhash( &self, blockhash: &Hash ) -> TransportResult<Option<FeeCalculator>>

👎Deprecated since 1.9.0: Please use get_fee_for_message or is_blockhash_valid instead
Get Some(FeeCalculator) associated with blockhash if it is still in the BlockhashQueue, otherwise None`
source§

fn get_fee_rate_governor(&self) -> TransportResult<FeeRateGovernor>

👎Deprecated since 1.9.0: Please do not use, will no longer be available in the future
Get recent fee rate governor
source§

fn get_signature_status( &self, signature: &Signature ) -> TransportResult<Option<Result<()>>>

Get signature status.
source§

fn get_signature_status_with_commitment( &self, signature: &Signature, commitment_config: CommitmentConfig ) -> TransportResult<Option<Result<()>>>

Get signature status. Uses explicit commitment configuration.
source§

fn get_slot(&self) -> TransportResult<u64>

Get last known slot
source§

fn get_slot_with_commitment( &self, commitment_config: CommitmentConfig ) -> TransportResult<u64>

Get last known slot. Uses explicit commitment configuration.
source§

fn get_epoch_info(&self) -> TransportResult<EpochInfo>

source§

fn get_transaction_count(&self) -> TransportResult<u64>

Get transaction count
source§

fn get_transaction_count_with_commitment( &self, commitment_config: CommitmentConfig ) -> TransportResult<u64>

Get transaction count. Uses explicit commitment configuration.
source§

fn poll_for_signature_confirmation( &self, signature: &Signature, min_confirmed_blocks: usize ) -> TransportResult<usize>

Poll until the signature has been confirmed by at least min_confirmed_blocks
source§

fn poll_for_signature(&self, signature: &Signature) -> TransportResult<()>

Poll to confirm a transaction.
source§

fn get_new_blockhash( &self, blockhash: &Hash ) -> TransportResult<(Hash, FeeCalculator)>

👎Deprecated since 1.9.0: Please do not use, will no longer be available in the future
source§

fn get_latest_blockhash(&self) -> TransportResult<Hash>

Get last known blockhash
source§

fn get_latest_blockhash_with_commitment( &self, commitment_config: CommitmentConfig ) -> TransportResult<(Hash, u64)>

Get latest blockhash with last valid block height. Uses explicit commitment configuration.
source§

fn is_blockhash_valid( &self, blockhash: &Hash, commitment_config: CommitmentConfig ) -> TransportResult<bool>

Check if the blockhash is valid
source§

fn get_fee_for_message(&self, message: &Message) -> TransportResult<u64>

Calculate the fee for a Message

Auto Trait Implementations§

Blanket Implementations§

source§

impl<T> AbiExample for T

source§

default fn example() -> T

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<'a, T, E> AsTaggedExplicit<'a, E> for T
where T: 'a,

source§

fn explicit(self, class: Class, tag: u32) -> TaggedParser<'a, Explicit, Self, E>

source§

impl<'a, T, E> AsTaggedImplicit<'a, E> for T
where T: 'a,

source§

fn implicit( self, class: Class, constructed: bool, tag: u32 ) -> TaggedParser<'a, Implicit, Self, E>

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

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T> Instrument for T

source§

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

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

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
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> 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
source§

impl<T> Pointable for T

source§

const ALIGN: usize = _

The alignment of pointer.
§

type Init = T

The type for initializers.
source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
source§

impl<T> Same for T

§

type Output = T

Should always be Self
source§

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

§

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>,

§

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

source§

impl<T> WithSubscriber for T

source§

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
source§

fn with_current_subscriber(self) -> WithDispatch<Self>

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