pub struct Request<N: Network> { /* private fields */ }
Implementations§
Source§impl<N: Network> Request<N>
impl<N: Network> Request<N>
Sourcepub fn sign<R: Rng + CryptoRng>(
private_key: &PrivateKey<N>,
program_id: ProgramID<N>,
function_name: Identifier<N>,
inputs: impl ExactSizeIterator<Item = impl TryInto<Value<N>>>,
input_types: &[ValueType<N>],
root_tvk: Option<Field<N>>,
is_root: bool,
rng: &mut R,
) -> Result<Self>
pub fn sign<R: Rng + CryptoRng>( private_key: &PrivateKey<N>, program_id: ProgramID<N>, function_name: Identifier<N>, inputs: impl ExactSizeIterator<Item = impl TryInto<Value<N>>>, input_types: &[ValueType<N>], root_tvk: Option<Field<N>>, is_root: bool, rng: &mut R, ) -> Result<Self>
Returns the request for a given private key, program ID, function name, inputs, input types, and RNG, where: challenge := HashToScalar(r * G, pk_sig, pr_sig, signer, [tvk, tcm, function ID, input IDs]) response := r - challenge * sk_sig
Source§impl<N: Network> Request<N>
impl<N: Network> Request<N>
Sourcepub fn verify(&self, input_types: &[ValueType<N>], is_root: bool) -> bool
pub fn verify(&self, input_types: &[ValueType<N>], is_root: bool) -> bool
Returns true
if the request is valid, and false
otherwise.
Verifies (challenge == challenge’) && (address == address’) && (serial_numbers == serial_numbers’) where: challenge’ := HashToScalar(r * G, pk_sig, pr_sig, signer, [tvk, tcm, function ID, input IDs])
Source§impl<N: Network> Request<N>
impl<N: Network> Request<N>
Sourcepub const fn network_id(&self) -> &U16<N>
pub const fn network_id(&self) -> &U16<N>
Returns the network ID.
Sourcepub const fn program_id(&self) -> &ProgramID<N>
pub const fn program_id(&self) -> &ProgramID<N>
Returns the program ID.
Sourcepub const fn function_name(&self) -> &Identifier<N>
pub const fn function_name(&self) -> &Identifier<N>
Returns the function name.
Trait Implementations§
Source§impl<'de, N: Network> Deserialize<'de> for Request<N>
impl<'de, N: Network> Deserialize<'de> for Request<N>
Source§fn deserialize<D: Deserializer<'de>>(deserializer: D) -> Result<Self, D::Error>
fn deserialize<D: Deserializer<'de>>(deserializer: D) -> Result<Self, D::Error>
Deserializes the request from a string or bytes.
Source§impl<N: Network> From<(Address<N>, Integer<N, u16>, ProgramID<N>, Identifier<N>, Vec<InputID<N>>, Vec<Value<N>>, Signature<N>, Field<N>, Field<N>, Field<N>, Field<N>)> for Request<N>
impl<N: Network> From<(Address<N>, Integer<N, u16>, ProgramID<N>, Identifier<N>, Vec<InputID<N>>, Vec<Value<N>>, Signature<N>, Field<N>, Field<N>, Field<N>, Field<N>)> for Request<N>
Source§fn from(
(signer, network_id, program_id, function_name, input_ids, inputs, signature, sk_tag, tvk, tcm, scm): (Address<N>, U16<N>, ProgramID<N>, Identifier<N>, Vec<InputID<N>>, Vec<Value<N>>, Signature<N>, Field<N>, Field<N>, Field<N>, Field<N>),
) -> Self
fn from( (signer, network_id, program_id, function_name, input_ids, inputs, signature, sk_tag, tvk, tcm, scm): (Address<N>, U16<N>, ProgramID<N>, Identifier<N>, Vec<InputID<N>>, Vec<Value<N>>, Signature<N>, Field<N>, Field<N>, Field<N>, Field<N>), ) -> Self
Note: See Request::sign
to create the request. This method is used to eject from a circuit.
impl<N: Eq + Network> Eq for Request<N>
impl<N: Network> StructuralPartialEq for Request<N>
Auto Trait Implementations§
impl<N> Freeze for Request<N>where
<N as Environment>::Field: Freeze,
<N as Environment>::Projective: Freeze,
<N as Environment>::Scalar: Freeze,
impl<N> RefUnwindSafe for Request<N>where
<N as Environment>::Field: RefUnwindSafe,
<N as Environment>::Projective: RefUnwindSafe,
N: RefUnwindSafe,
<N as Environment>::Scalar: RefUnwindSafe,
impl<N> Send for Request<N>
impl<N> Sync for Request<N>
impl<N> Unpin for Request<N>where
<N as Environment>::Field: Unpin,
<N as Environment>::Projective: Unpin,
N: Unpin,
<N as Environment>::Scalar: Unpin,
impl<N> UnwindSafe for Request<N>where
<N as Environment>::Field: UnwindSafe,
<N as Environment>::Projective: UnwindSafe,
N: UnwindSafe,
<N as Environment>::Scalar: UnwindSafe,
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<'de, T> DeserializeExt<'de> for Twhere
T: DeserializeOwned,
impl<'de, T> DeserializeExt<'de> for Twhere
T: DeserializeOwned,
fn take_from_value<D>(
value: &mut Value,
field: &str,
) -> Result<T, <D as Deserializer<'de>>::Error>where
D: Deserializer<'de>,
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Compare self to
key
and return true
if they are equal.Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
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 moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
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