Struct BatchedQueueAccount

Source
pub struct BatchedQueueAccount<'a> {
    pub value_vecs: [ZeroCopyVecU64<'a, [u8; 32]>; 2],
    pub hash_chain_stores: [ZeroCopyVecU64<'a, [u8; 32]>; 2],
    /* private fields */
}
Expand description

Batched queue zero copy account. Used for output queues in light protocol. Output queues store compressed account hashes, to be appended to the associated batched Merkle tree in batches with a zero-knowledge proof (zkp), ie. it stores hashes and commits these to hash chains. Each hash chain is used as public input for a batch append zkp.

An output queue is configured with:

  1. 2 batches
  2. 2 value vecs (one for each batch) value vec length = batch size
  3. 2 hash chain vecs (one for each batch) hash chain store length = batch size /zkp batch size

Default config:

  • 50,000 batch size
  • 500 zkp batch size

Initialization:

  • an output queue is initialized in combination with a state Merkle tree
  • init_batched_state_merkle_tree_from_account_info

For deserialization use:

  • in program: output_from_account_info
  • in client: output_from_bytes

To insert a value the account compression program uses:

  • insert_into_current_batch

A compressed account can be spent or read while in the output queue.

To spend, the account compression program uses:

  • check_leaf_index_could_exist_in_batches in combination with prove_inclusion_by_index_and_zero_out_leaf

To read, light the system program uses:

  • prove_inclusion_by_index

Fields§

§value_vecs: [ZeroCopyVecU64<'a, [u8; 32]>; 2]§hash_chain_stores: [ZeroCopyVecU64<'a, [u8; 32]>; 2]

Implementations§

Source§

impl<'a> BatchedQueueAccount<'a>

Source

pub fn output_from_account_info<A: AccountInfoTrait>( account_info: &A, ) -> Result<BatchedQueueAccount<'a>, BatchedMerkleTreeError>

Deserialize an output BatchedQueueAccount from account info. Should be used in solana programs. Checks that:

  1. the program owner is the light account compression program,
  2. discriminator,
  3. queue type is output queue type.
Source

pub fn output_from_bytes( account_data: &'a mut [u8], ) -> Result<BatchedQueueAccount<'a>, BatchedMerkleTreeError>

Deserialize a BatchedQueueAccount from bytes. Should only be used in client. Checks the discriminator and queue type.

Source

pub fn init( account_data: &'a mut [u8], metadata: QueueMetadata, output_queue_batch_size: u64, output_queue_zkp_batch_size: u64, num_iters: u64, bloom_filter_capacity: u64, pubkey: Pubkey, ) -> Result<BatchedQueueAccount<'a>, BatchedMerkleTreeError>

Source

pub fn insert_into_current_batch( &mut self, hash_chain_value: &[u8; 32], current_slot: &u64, ) -> Result<(), BatchedMerkleTreeError>

Insert a value into the current batch of this output queue account.

  1. insert value into a value vec and hash chain store.
  2. Increment next_index.
Source

pub fn prove_inclusion_by_index( &mut self, leaf_index: u64, hash_chain_value: &[u8; 32], ) -> Result<bool, BatchedMerkleTreeError>

Proves inclusion of leaf index if it exists in one of the batches.

  1. Iterate over all batches
  2. Check if leaf index could exist in the batch. 2.1 If yes, check whether value at index is equal to hash_chain_value. Throw error if not.
  3. Return true if leaf index exists in one of the batches.

Note, this method does not fail but returns false if the leaf index is out of range for any batch.

Source

pub fn prove_inclusion_by_index_and_zero_out_leaf( &mut self, leaf_index: u64, hash_chain_value: &[u8; 32], prove_by_index: bool, ) -> Result<(), BatchedMerkleTreeError>

Zero out a leaf by index if it exists in the queues hash_chain_value vec. If prove_by_index is true fail if leaf is not found.

Source

pub fn get_metadata(&self) -> &BatchedQueueMetadata

Source

pub fn get_metadata_mut(&mut self) -> &mut BatchedQueueMetadata

Source

pub fn get_num_inserted_in_current_batch(&self) -> u64

Returns the number of elements inserted in the current batch. If current batch state is inserted, returns 0.

Source

pub fn is_associated(&self, pubkey: &Pubkey) -> bool

Returns true if the pubkey is the associated Merkle tree of the queue.

Source

pub fn check_is_associated( &self, pubkey: &Pubkey, ) -> Result<(), BatchedMerkleTreeError>

Check if the pubkey is the associated Merkle tree of the queue.

Source

pub fn tree_is_full(&self) -> bool

Returns true if the tree is full.

Source

pub fn check_tree_is_full(&self) -> Result<(), BatchedMerkleTreeError>

Check if the tree is full.

Source

pub fn pubkey(&self) -> &Pubkey

Methods from Deref<Target = BatchedQueueMetadata>§

Source

pub const LEN: usize = 552usize

Source

pub fn init( &mut self, meta_data: QueueMetadata, batch_size: u64, zkp_batch_size: u64, bloom_filter_capacity: u64, num_iters: u64, queue_pubkey: &Pubkey, ) -> Result<(), BatchedMerkleTreeError>

Trait Implementations§

Source§

impl<'a> Debug for BatchedQueueAccount<'a>

Source§

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

Formats the value using the given formatter. Read more
Source§

impl Deref for BatchedQueueAccount<'_>

Source§

type Target = BatchedQueueMetadata

The resulting type after dereferencing.
Source§

fn deref(&self) -> &Self::Target

Dereferences the value.
Source§

impl DerefMut for BatchedQueueAccount<'_>

Source§

fn deref_mut(&mut self) -> &mut Self::Target

Mutably dereferences the value.
Source§

impl Discriminator for BatchedQueueAccount<'_>

Source§

impl<'a> PartialEq for BatchedQueueAccount<'a>

Source§

fn eq(&self, other: &BatchedQueueAccount<'a>) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl<'a> StructuralPartialEq for BatchedQueueAccount<'a>

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

Source§

fn conv<T>(self) -> T
where Self: Into<T>,

Converts self into T using Into<T>. Read more
Source§

impl<T> FmtForward for T

Source§

fn fmt_binary(self) -> FmtBinary<Self>
where Self: Binary,

Causes self to use its Binary implementation when Debug-formatted.
Source§

fn fmt_display(self) -> FmtDisplay<Self>
where Self: Display,

Causes self to use its Display implementation when Debug-formatted.
Source§

fn fmt_lower_exp(self) -> FmtLowerExp<Self>
where Self: LowerExp,

Causes self to use its LowerExp implementation when Debug-formatted.
Source§

fn fmt_lower_hex(self) -> FmtLowerHex<Self>
where Self: LowerHex,

Causes self to use its LowerHex implementation when Debug-formatted.
Source§

fn fmt_octal(self) -> FmtOctal<Self>
where Self: Octal,

Causes self to use its Octal implementation when Debug-formatted.
Source§

fn fmt_pointer(self) -> FmtPointer<Self>
where Self: Pointer,

Causes self to use its Pointer implementation when Debug-formatted.
Source§

fn fmt_upper_exp(self) -> FmtUpperExp<Self>
where Self: UpperExp,

Causes self to use its UpperExp implementation when Debug-formatted.
Source§

fn fmt_upper_hex(self) -> FmtUpperHex<Self>
where Self: UpperHex,

Causes self to use its UpperHex implementation when Debug-formatted.
Source§

fn fmt_list(self) -> FmtList<Self>
where &'a Self: for<'a> IntoIterator,

Formats each item in a sequence. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

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

Source§

fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> R
where Self: Sized,

Pipes by value. This is generally the method you want to use. Read more
Source§

fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> R
where R: 'a,

Borrows self and passes that borrow into the pipe function. Read more
Source§

fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> R
where R: 'a,

Mutably borrows self and passes that borrow into the pipe function. Read more
Source§

fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
where Self: Borrow<B>, B: 'a + ?Sized, R: 'a,

Borrows self, then passes self.borrow() into the pipe function. Read more
Source§

fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
where Self: BorrowMut<B>, B: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.borrow_mut() into the pipe function. Read more
Source§

fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
where Self: AsRef<U>, U: 'a + ?Sized, R: 'a,

Borrows self, then passes self.as_ref() into the pipe function.
Source§

fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
where Self: AsMut<U>, U: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.as_mut() into the pipe function.
Source§

fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
where Self: Deref<Target = T>, T: 'a + ?Sized, R: 'a,

Borrows self, then passes self.deref() into the pipe function.
Source§

fn pipe_deref_mut<'a, T, R>( &'a mut self, func: impl FnOnce(&'a mut T) -> R, ) -> R
where Self: DerefMut<Target = T> + Deref, T: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.deref_mut() into the pipe function.
Source§

impl<P, T> Receiver for P
where P: Deref<Target = T> + ?Sized, T: ?Sized,

Source§

type Target = T

🔬This is a nightly-only experimental API. (arbitrary_self_types)
The target type on which the method may be called.
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T> Tap for T

Source§

fn tap(self, func: impl FnOnce(&Self)) -> Self

Immutable access to a value. Read more
Source§

fn tap_mut(self, func: impl FnOnce(&mut Self)) -> Self

Mutable access to a value. Read more
Source§

fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
where Self: Borrow<B>, B: ?Sized,

Immutable access to the Borrow<B> of a value. Read more
Source§

fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
where Self: BorrowMut<B>, B: ?Sized,

Mutable access to the BorrowMut<B> of a value. Read more
Source§

fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
where Self: AsRef<R>, R: ?Sized,

Immutable access to the AsRef<R> view of a value. Read more
Source§

fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
where Self: AsMut<R>, R: ?Sized,

Mutable access to the AsMut<R> view of a value. Read more
Source§

fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
where Self: Deref<Target = T>, T: ?Sized,

Immutable access to the Deref::Target of a value. Read more
Source§

fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
where Self: DerefMut<Target = T> + Deref, T: ?Sized,

Mutable access to the Deref::Target of a value. Read more
Source§

fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self

Calls .tap() only in debug builds, and is erased in release builds.
Source§

fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self

Calls .tap_mut() only in debug builds, and is erased in release builds.
Source§

fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
where Self: Borrow<B>, B: ?Sized,

Calls .tap_borrow() only in debug builds, and is erased in release builds.
Source§

fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
where Self: BorrowMut<B>, B: ?Sized,

Calls .tap_borrow_mut() only in debug builds, and is erased in release builds.
Source§

fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
where Self: AsRef<R>, R: ?Sized,

Calls .tap_ref() only in debug builds, and is erased in release builds.
Source§

fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
where Self: AsMut<R>, R: ?Sized,

Calls .tap_ref_mut() only in debug builds, and is erased in release builds.
Source§

fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
where Self: Deref<Target = T>, T: ?Sized,

Calls .tap_deref() only in debug builds, and is erased in release builds.
Source§

fn tap_deref_mut_dbg<T>(self, func: impl FnOnce(&mut T)) -> Self
where Self: DerefMut<Target = T> + Deref, T: ?Sized,

Calls .tap_deref_mut() only in debug builds, and is erased in release builds.
Source§

impl<T> TryConv for T

Source§

fn try_conv<T>(self) -> Result<T, Self::Error>
where Self: TryInto<T>,

Attempts to convert self into T using TryInto<T>. Read more
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