pub struct CompactTxStreamerClient<T> { /* private fields */ }

Implementations§

source§

impl CompactTxStreamerClient<Channel>

source

pub async fn connect<D>(dst: D) -> Result<Self, Error>
where D: TryInto<Endpoint>, D::Error: Into<StdError>,

Attempt to create a new client by connecting to a given endpoint.

source§

impl<T> CompactTxStreamerClient<T>
where T: GrpcService<BoxBody>, T::Error: Into<StdError>, T::ResponseBody: Body<Data = Bytes> + Send + 'static, <T::ResponseBody as Body>::Error: Into<StdError> + Send,

source

pub fn new(inner: T) -> Self

source

pub fn with_origin(inner: T, origin: Uri) -> Self

source

pub fn with_interceptor<F>( inner: T, interceptor: F, ) -> CompactTxStreamerClient<InterceptedService<T, F>>
where F: Interceptor, T::ResponseBody: Default, T: Service<Request<BoxBody>, Response = Response<<T as GrpcService<BoxBody>>::ResponseBody>>, <T as Service<Request<BoxBody>>>::Error: Into<StdError> + Send + Sync,

source

pub fn send_compressed(self, encoding: CompressionEncoding) -> Self

Compress requests with the given encoding.

This requires the server to support it otherwise it might respond with an error.

source

pub fn accept_compressed(self, encoding: CompressionEncoding) -> Self

Enable decompressing responses.

source

pub fn max_decoding_message_size(self, limit: usize) -> Self

Limits the maximum size of a decoded message.

Default: 4MB

source

pub fn max_encoding_message_size(self, limit: usize) -> Self

Limits the maximum size of an encoded message.

Default: usize::MAX

source

pub async fn get_latest_block( &mut self, request: impl IntoRequest<ChainSpec>, ) -> Result<Response<BlockId>, Status>

Return the height of the tip of the best chain

source

pub async fn get_block( &mut self, request: impl IntoRequest<BlockId>, ) -> Result<Response<CompactBlock>, Status>

Return the compact block corresponding to the given block identifier

source

pub async fn get_block_nullifiers( &mut self, request: impl IntoRequest<BlockId>, ) -> Result<Response<CompactBlock>, Status>

Same as GetBlock except actions contain only nullifiers

source

pub async fn get_block_range( &mut self, request: impl IntoRequest<BlockRange>, ) -> Result<Response<Streaming<CompactBlock>>, Status>

Return a list of consecutive compact blocks

source

pub async fn get_block_range_nullifiers( &mut self, request: impl IntoRequest<BlockRange>, ) -> Result<Response<Streaming<CompactBlock>>, Status>

Same as GetBlockRange except actions contain only nullifiers

source

pub async fn get_transaction( &mut self, request: impl IntoRequest<TxFilter>, ) -> Result<Response<RawTransaction>, Status>

Return the requested full (not compact) transaction (as from zcashd)

source

pub async fn send_transaction( &mut self, request: impl IntoRequest<RawTransaction>, ) -> Result<Response<SendResponse>, Status>

Submit the given transaction to the Zcash network

source

pub async fn get_taddress_txids( &mut self, request: impl IntoRequest<TransparentAddressBlockFilter>, ) -> Result<Response<Streaming<RawTransaction>>, Status>

Return the txids corresponding to the given t-address within the given block range

source

pub async fn get_taddress_balance( &mut self, request: impl IntoRequest<AddressList>, ) -> Result<Response<Balance>, Status>

source

pub async fn get_taddress_balance_stream( &mut self, request: impl IntoStreamingRequest<Message = Address>, ) -> Result<Response<Balance>, Status>

source

pub async fn get_mempool_tx( &mut self, request: impl IntoRequest<Exclude>, ) -> Result<Response<Streaming<CompactTx>>, Status>

Return the compact transactions currently in the mempool; the results can be a few seconds out of date. If the Exclude list is empty, return all transactions; otherwise return all except those in the Exclude list (if any); this allows the client to avoid receiving transactions that it already has (from an earlier call to this rpc). The transaction IDs in the Exclude list can be shortened to any number of bytes to make the request more bandwidth-efficient; if two or more transactions in the mempool match a shortened txid, they are all sent (none is excluded). Transactions in the exclude list that don’t exist in the mempool are ignored.

source

pub async fn get_mempool_stream( &mut self, request: impl IntoRequest<Empty>, ) -> Result<Response<Streaming<RawTransaction>>, Status>

Return a stream of current Mempool transactions. This will keep the output stream open while there are mempool transactions. It will close the returned stream when a new block is mined.

source

pub async fn get_tree_state( &mut self, request: impl IntoRequest<BlockId>, ) -> Result<Response<TreeState>, Status>

GetTreeState returns the note commitment tree state corresponding to the given block. See section 3.7 of the Zcash protocol specification. It returns several other useful values also (even though they can be obtained using GetBlock). The block can be specified by either height or hash.

source

pub async fn get_latest_tree_state( &mut self, request: impl IntoRequest<Empty>, ) -> Result<Response<TreeState>, Status>

source

pub async fn get_subtree_roots( &mut self, request: impl IntoRequest<GetSubtreeRootsArg>, ) -> Result<Response<Streaming<SubtreeRoot>>, Status>

Returns a stream of information about roots of subtrees of the Sapling and Orchard note commitment trees.

source

pub async fn get_address_utxos( &mut self, request: impl IntoRequest<GetAddressUtxosArg>, ) -> Result<Response<GetAddressUtxosReplyList>, Status>

source

pub async fn get_address_utxos_stream( &mut self, request: impl IntoRequest<GetAddressUtxosArg>, ) -> Result<Response<Streaming<GetAddressUtxosReply>>, Status>

source

pub async fn get_lightd_info( &mut self, request: impl IntoRequest<Empty>, ) -> Result<Response<LightdInfo>, Status>

Return information about this lightwalletd instance and the blockchain

source

pub async fn ping( &mut self, request: impl IntoRequest<Duration>, ) -> Result<Response<PingResponse>, Status>

Testing-only, requires lightwalletd –ping-very-insecure (do not enable in production)

Trait Implementations§

source§

impl<T: Clone> Clone for CompactTxStreamerClient<T>

source§

fn clone(&self) -> CompactTxStreamerClient<T>

Returns a copy 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<T: Debug> Debug for CompactTxStreamerClient<T>

source§

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

Formats the value using the given formatter. Read more

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§

default unsafe fn clone_to_uninit(&self, dst: *mut T)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T> FromRef<T> for T
where T: Clone,

§

fn from_ref(input: &T) -> T

Converts to this type from a reference to the input type.
§

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

source§

fn into_request(self) -> Request<T>

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

impl<T> ToOwned for T
where T: Clone,

§

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

§

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

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