RpcBuilder

Struct RpcBuilder 

Source
pub struct RpcBuilder<Query, Handler>
where Query: RpcType, Query::Response: Debug + Send + Sync, Query::Error: Debug + Send + Sync, Handler: Send + Sync,
{ reference: Query::RpcReference, request: Arc<dyn RpcType<Response = Query::Response, RpcReference = Query::RpcReference, Error = Query::Error> + Send + Sync>, handler: Handler, }

Fields§

§reference: Query::RpcReference§request: Arc<dyn RpcType<Response = Query::Response, RpcReference = Query::RpcReference, Error = Query::Error> + Send + Sync>§handler: Handler

Implementations§

Source§

impl<Query, Handler> RpcBuilder<Query, Handler>
where Handler: ResponseHandler<Query = Query> + Send + Sync, Query: RpcType + 'static, Query::Response: Debug + Send + Sync, Query::Error: Debug + Send + Sync,

Source

pub fn new( request: Query, reference: impl Into<Query::RpcReference>, handler: Handler, ) -> Self

Source

pub fn at(self, reference: impl Into<Query::RpcReference>) -> Self

Set the block reference for the query.

Source

pub fn map<MappedType>( self, map: impl Fn(Handler::Response) -> MappedType + Send + Sync + 'static, ) -> RpcBuilder<Query, PostprocessHandler<MappedType, Handler>>

Post-process the response of the query.

This is useful if you want to convert one type to another.

§Example
use near_api::*;

let balance: NearToken = Contract("some_contract.testnet".parse()?)
        .call_function("get_balance", ())?
        .read_only()
        .map(|balance: Data<u128>| NearToken::from_yoctonear(balance.data))
        .fetch_from_testnet()
        .await?;
println!("Balance: {}", balance);
Source

pub fn and_then<MappedType>( self, map: impl Fn(Handler::Response) -> Result<MappedType, Box<dyn Error + Send + Sync>> + Send + Sync + 'static, ) -> RpcBuilder<Query, AndThenHandler<MappedType, Handler>>

Post-process the response of the query with error handling

This is useful if you want to convert one type to another but your function might fail.

The error will be wrapped in a QueryError::ConversionError and returned to the caller.

§Example
use near_api::*;

let balance: NearToken = Contract("some_contract.testnet".parse()?)
        .call_function("get_balance", ())?
        .read_only()
        .and_then(|balance: Data<String>| Ok(NearToken::from_yoctonear(balance.data.parse()?)))
        .fetch_from_testnet()
        .await?;
println!("Balance: {}", balance);
Source

pub async fn fetch_from( self, network: &NetworkConfig, ) -> Result<Handler::Response, QueryError<Query::Error>>

Fetch the query from the provided network.

Source

pub async fn fetch_from_mainnet( self, ) -> Result<Handler::Response, QueryError<Query::Error>>

Fetch the query from the default mainnet network configuration.

Source

pub async fn fetch_from_testnet( self, ) -> Result<Handler::Response, QueryError<Query::Error>>

Fetch the query from the default testnet network configuration.

Auto Trait Implementations§

§

impl<Query, Handler> Freeze for RpcBuilder<Query, Handler>
where <Query as RpcType>::RpcReference: Freeze, Handler: Freeze,

§

impl<Query, Handler> !RefUnwindSafe for RpcBuilder<Query, Handler>

§

impl<Query, Handler> Send for RpcBuilder<Query, Handler>

§

impl<Query, Handler> Sync for RpcBuilder<Query, Handler>

§

impl<Query, Handler> Unpin for RpcBuilder<Query, Handler>
where <Query as RpcType>::RpcReference: Unpin, Handler: Unpin,

§

impl<Query, Handler> !UnwindSafe for RpcBuilder<Query, Handler>

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> 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> PolicyExt for T
where T: ?Sized,

Source§

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

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

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

Source§

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

Source§

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