#[non_exhaustive]pub struct QueryBuilder<'agent> {
pub effective_canister_id: Principal,
pub canister_id: Principal,
pub method_name: String,
pub arg: Vec<u8>,
pub ingress_expiry_datetime: Option<u64>,
pub use_nonce: bool,
/* private fields */
}Expand description
A query request builder.
This makes it easier to do query calls without actually passing all arguments.
Fields (Non-exhaustive)§
This struct is marked as non-exhaustive
Struct { .. } syntax; cannot be matched against without a wildcard ..; and struct update syntax will not work.effective_canister_id: PrincipalThe effective canister ID of the destination.
canister_id: PrincipalThe principal ID of the canister being called.
method_name: StringThe name of the canister method being called.
arg: Vec<u8>The argument blob to be passed to the method.
ingress_expiry_datetime: Option<u64>The Unix timestamp that the request will expire at.
use_nonce: boolWhether to include a nonce with the message.
Implementations§
Source§impl<'agent> QueryBuilder<'agent>
impl<'agent> QueryBuilder<'agent>
Sourcepub fn new(
agent: &'agent Agent,
canister_id: Principal,
method_name: String,
) -> Self
pub fn new( agent: &'agent Agent, canister_id: Principal, method_name: String, ) -> Self
Creates a new query builder with an agent for a particular canister method.
Sourcepub fn with_effective_canister_id(self, canister_id: Principal) -> Self
pub fn with_effective_canister_id(self, canister_id: Principal) -> Self
Sets the effective canister ID of the destination.
Sourcepub fn with_arg<A: Into<Vec<u8>>>(self, arg: A) -> Self
pub fn with_arg<A: Into<Vec<u8>>>(self, arg: A) -> Self
Sets the argument blob to pass to the canister. For most canisters this should be a Candid-serialized tuple.
Sourcepub fn expire_at(self, time: impl Into<OffsetDateTime>) -> Self
pub fn expire_at(self, time: impl Into<OffsetDateTime>) -> Self
Sets ingress_expiry_datetime to the provided timestamp, at nanosecond precision.
Sourcepub fn expire_after(self, duration: Duration) -> Self
pub fn expire_after(self, duration: Duration) -> Self
Sets ingress_expiry_datetime to max(now, 4min).
Sourcepub fn with_nonce_generation(self) -> Self
pub fn with_nonce_generation(self) -> Self
Uses a nonce generated with the agent’s configured nonce factory. By default queries do not use nonces, and thus may get a (briefly) cached response.
Sourcepub async fn call(self) -> Result<Vec<u8>, AgentError>
pub async fn call(self) -> Result<Vec<u8>, AgentError>
Make a query call. This will return a byte vector.
Sourcepub async fn call_with_verification(self) -> Result<Vec<u8>, AgentError>
pub async fn call_with_verification(self) -> Result<Vec<u8>, AgentError>
Make a query call with signature verification. This will return a byte vector.
Compared with call, this method will always verify the signature of the query response
regardless the Agent level configuration from AgentBuilder::with_verify_query_signatures.
Sourcepub async fn call_without_verification(self) -> Result<Vec<u8>, AgentError>
pub async fn call_without_verification(self) -> Result<Vec<u8>, AgentError>
Make a query call without signature verification. This will return a byte vector.
Compared with call, this method will never verify the signature of the query response
regardless the Agent level configuration from AgentBuilder::with_verify_query_signatures.
Sourcepub fn sign(self) -> Result<SignedQuery, AgentError>
pub fn sign(self) -> Result<SignedQuery, AgentError>
Sign a query call. This will return a signed::SignedQuery
which contains all fields of the query and the signed query in CBOR encoding
Sourcepub fn into_envelope(self) -> Result<EnvelopeContent, AgentError>
pub fn into_envelope(self) -> Result<EnvelopeContent, AgentError>
Converts the query builder into EnvelopeContent for external signing or storage.
Trait Implementations§
Source§impl<'agent> Clone for QueryBuilder<'agent>
impl<'agent> Clone for QueryBuilder<'agent>
Source§fn clone(&self) -> QueryBuilder<'agent>
fn clone(&self) -> QueryBuilder<'agent>
1.0.0§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read moreSource§impl<'agent> Debug for QueryBuilder<'agent>
impl<'agent> Debug for QueryBuilder<'agent>
Source§impl<'agent> IntoFuture for QueryBuilder<'agent>
impl<'agent> IntoFuture for QueryBuilder<'agent>
Source§type IntoFuture = Pin<Box<dyn Future<Output = Result<Vec<u8>, AgentError>> + Send + 'agent>>
type IntoFuture = Pin<Box<dyn Future<Output = Result<Vec<u8>, AgentError>> + Send + 'agent>>
Source§type Output = Result<Vec<u8>, AgentError>
type Output = Result<Vec<u8>, AgentError>
Source§fn into_future(self) -> Self::IntoFuture
fn into_future(self) -> Self::IntoFuture
Auto Trait Implementations§
impl<'agent> Freeze for QueryBuilder<'agent>
impl<'agent> !RefUnwindSafe for QueryBuilder<'agent>
impl<'agent> Send for QueryBuilder<'agent>
impl<'agent> Sync for QueryBuilder<'agent>
impl<'agent> Unpin for QueryBuilder<'agent>
impl<'agent> !UnwindSafe for QueryBuilder<'agent>
Blanket Implementations§
§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
§unsafe fn clone_to_uninit(&self, dest: *mut u8)
unsafe fn clone_to_uninit(&self, dest: *mut u8)
clone_to_uninit)