snarkvm_console_network/lib.rs
1// Copyright (c) 2019-2026 Provable Inc.
2// This file is part of the snarkVM library.
3
4// Licensed under the Apache License, Version 2.0 (the "License");
5// you may not use this file except in compliance with the License.
6// You may obtain a copy of the License at:
7
8// http://www.apache.org/licenses/LICENSE-2.0
9
10// Unless required by applicable law or agreed to in writing, software
11// distributed under the License is distributed on an "AS IS" BASIS,
12// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13// See the License for the specific language governing permissions and
14// limitations under the License.
15
16#![forbid(unsafe_code)]
17#![allow(clippy::too_many_arguments)]
18#![warn(clippy::cast_possible_truncation)]
19
20#[macro_use]
21extern crate lazy_static;
22
23pub use snarkvm_console_network_environment as environment;
24pub use snarkvm_console_network_environment::*;
25
26mod helpers;
27pub use helpers::*;
28
29mod canary_v0;
30pub use canary_v0::*;
31
32mod consensus_heights;
33pub use consensus_heights::*;
34
35mod mainnet_v0;
36pub use mainnet_v0::*;
37
38mod testnet_v0;
39
40pub use testnet_v0::*;
41
42pub mod prelude {
43 #[cfg(feature = "wasm")]
44 pub use crate::get_or_init_consensus_version_heights;
45 pub use crate::{
46 CANARY_V0_CONSENSUS_VERSION_HEIGHTS,
47 CanaryV0,
48 ConsensusVersion,
49 MAINNET_V0_CONSENSUS_VERSION_HEIGHTS,
50 MainnetV0,
51 Network,
52 TEST_CONSENSUS_VERSION_HEIGHTS,
53 TESTNET_V0_CONSENSUS_VERSION_HEIGHTS,
54 TestnetV0,
55 consensus_config_value,
56 consensus_config_value_by_version,
57 environment::prelude::*,
58 };
59}
60
61pub use crate::environment::prelude::*;
62
63use snarkvm_algorithms::{
64 AlgebraicSponge,
65 crypto_hash::PoseidonSponge,
66 snark::varuna::{CircuitProvingKey, CircuitVerifyingKey, VarunaHidingMode},
67 srs::{UniversalProver, UniversalVerifier},
68};
69use snarkvm_console_algorithms::{BHP512, BHP1024, Poseidon2, Poseidon4, Poseidon8};
70use snarkvm_console_collections::merkle_tree::{MerklePath, MerkleTree};
71use snarkvm_console_types::{Field, Group, Scalar};
72use snarkvm_curves::PairingEngine;
73
74use indexmap::IndexMap;
75use std::sync::{Arc, OnceLock};
76
77/// A helper type for the BHP Merkle tree.
78pub type BHPMerkleTree<N, const DEPTH: u8> = MerkleTree<N, BHP1024<N>, BHP512<N>, DEPTH>;
79/// A helper type for the Poseidon Merkle tree.
80pub type PoseidonMerkleTree<N, const DEPTH: u8> = MerkleTree<N, Poseidon4<N>, Poseidon2<N>, DEPTH>;
81
82/// Helper types for the Varuna parameters.
83type Fq<N> = <<N as Environment>::PairingCurve as PairingEngine>::Fq;
84pub type FiatShamir<N> = PoseidonSponge<Fq<N>, 2, 1>;
85pub type FiatShamirParameters<N> = <FiatShamir<N> as AlgebraicSponge<Fq<N>, 2>>::Parameters;
86
87/// Helper types for the Varuna proving and verifying key.
88pub(crate) type VarunaProvingKey<N> = CircuitProvingKey<<N as Environment>::PairingCurve, VarunaHidingMode>;
89pub(crate) type VarunaVerifyingKey<N> = CircuitVerifyingKey<<N as Environment>::PairingCurve>;
90
91/// A list of consensus versions and their corresponding block heights.
92static CONSENSUS_VERSION_HEIGHTS: OnceLock<[(ConsensusVersion, u32); NUM_CONSENSUS_VERSIONS]> = OnceLock::new();
93
94pub trait Network:
95 'static
96 + Environment
97 + Copy
98 + Clone
99 + Debug
100 + Eq
101 + PartialEq
102 + core::hash::Hash
103 + Serialize
104 + DeserializeOwned
105 + for<'a> Deserialize<'a>
106 + Send
107 + Sync
108{
109 /// The network ID.
110 const ID: u16;
111 /// The (long) network name.
112 const NAME: &'static str;
113 /// The short network name (used, for example, in query URLs).
114 const SHORT_NAME: &'static str;
115
116 /// The function name for the inclusion circuit.
117 const INCLUSION_FUNCTION_NAME: &'static str;
118
119 /// The fixed timestamp of the genesis block.
120 const GENESIS_TIMESTAMP: i64;
121 /// The genesis block coinbase target.
122 const GENESIS_COINBASE_TARGET: u64;
123 /// The genesis block proof target.
124 const GENESIS_PROOF_TARGET: u64;
125 /// The maximum number of solutions that can be included per block as a power of 2.
126 const MAX_SOLUTIONS_AS_POWER_OF_TWO: u8 = 2; // 4 solutions
127 /// The maximum number of solutions that can be included per block.
128 const MAX_SOLUTIONS: usize = 1 << Self::MAX_SOLUTIONS_AS_POWER_OF_TWO; // 4 solutions
129
130 /// The starting supply of Aleo credits.
131 const STARTING_SUPPLY: u64 = 1_500_000_000_000_000; // 1.5B credits
132 /// The maximum supply of Aleo credits.
133 /// This value represents the absolute upper bound on all ALEO created over the lifetime of the network.
134 const MAX_SUPPLY: u64 = 5_000_000_000_000_000; // 5B credits
135 /// The block height that upper bounds the total supply of Aleo credits to 5 billion.
136 #[cfg(not(feature = "test"))]
137 const MAX_SUPPLY_LIMIT_HEIGHT: u32 = 263_527_685;
138 /// The block height that upper bounds the total supply of Aleo credits to 5 billion.
139 /// This is deliberately set to a low value for testing purposes only.
140 #[cfg(feature = "test")]
141 const MAX_SUPPLY_LIMIT_HEIGHT: u32 = 5;
142 /// The cost in microcredits per byte for the deployment transaction.
143 const DEPLOYMENT_FEE_MULTIPLIER: u64 = 1_000; // 1 millicredit per byte
144 /// The multiplier in microcredits for each command in the constructor.
145 const CONSTRUCTOR_FEE_MULTIPLIER: u64 = 100; // 100x per command
146 /// The constant that divides the storage polynomial.
147 const EXECUTION_STORAGE_FEE_SCALING_FACTOR: u64 = 5000;
148 /// The maximum size execution transactions can be before a quadratic storage penalty applies.
149 const EXECUTION_STORAGE_PENALTY_THRESHOLD: u64 = 5000;
150 /// The cost in microcredits per constraint for the deployment transaction.
151 const SYNTHESIS_FEE_MULTIPLIER: u64 = 25; // 25 microcredits per constraint
152 /// The maximum number of variables in a deployment.
153 const MAX_DEPLOYMENT_VARIABLES: u64 = 1 << 21; // 2,097,152 variables
154 /// The maximum number of constraints in a deployment.
155 const MAX_DEPLOYMENT_CONSTRAINTS: u64 = 1 << 21; // 2,097,152 constraints
156 /// The maximum number of instances to verify in a batch proof.
157 const MAX_BATCH_PROOF_INSTANCES: usize = 128;
158 /// The maximum number of microcredits that can be spent as a fee.
159 const MAX_FEE: u64 = 1_000_000_000_000_000;
160 /// A list of consensus versions and their corresponding transaction spend limits in microcredits.
161 // Note: This value must **not** decrease without considering the impact on transaction validity.
162 const TRANSACTION_SPEND_LIMIT: [(ConsensusVersion, u64); 2] =
163 [(ConsensusVersion::V1, 100_000_000), (ConsensusVersion::V10, 4_000_000)];
164 /// The compute discount approved by ARC 0005.
165 const ARC_0005_COMPUTE_DISCOUNT: u64 = 25;
166
167 /// The anchor height, defined as the expected number of blocks to reach the coinbase target.
168 const ANCHOR_HEIGHT: u32 = Self::ANCHOR_TIME as u32 / Self::BLOCK_TIME as u32;
169 /// The anchor time in seconds.
170 const ANCHOR_TIME: u16 = 25;
171 /// The expected time per block in seconds.
172 const BLOCK_TIME: u16 = 10;
173 /// The number of blocks per epoch.
174 #[cfg(not(feature = "test"))]
175 const NUM_BLOCKS_PER_EPOCH: u32 = 3600 / Self::BLOCK_TIME as u32; // 360 blocks == ~1 hour
176 /// The number of blocks per epoch.
177 /// This is deliberately set to a low value for testing purposes only.
178 #[cfg(feature = "test")]
179 const NUM_BLOCKS_PER_EPOCH: u32 = 10;
180
181 /// The maximum number of entries in data.
182 const MAX_DATA_ENTRIES: usize = 32;
183 /// The maximum recursive depth of an entry.
184 /// Note: This value must be strictly less than u8::MAX.
185 const MAX_DATA_DEPTH: usize = 32;
186 /// The maximum number of fields in data (must not exceed u16::MAX).
187 #[allow(clippy::cast_possible_truncation)]
188 const MAX_DATA_SIZE_IN_FIELDS: u32 = ((128 * 1024 * 8) / Field::<Self>::SIZE_IN_DATA_BITS) as u32;
189
190 /// The minimum number of entries in a struct.
191 const MIN_STRUCT_ENTRIES: usize = 1; // This ensures the struct is not empty.
192 /// The maximum number of entries in a struct.
193 const MAX_STRUCT_ENTRIES: usize = Self::MAX_DATA_ENTRIES;
194
195 /// The minimum number of elements in an array.
196 const MIN_ARRAY_ELEMENTS: usize = 1; // This ensures the array is not empty.
197 /// A list of (consensus_version, size) pairs indicating the maximum number of elements in an array.
198 const MAX_ARRAY_ELEMENTS: [(ConsensusVersion, usize); 3] =
199 [(ConsensusVersion::V1, 32), (ConsensusVersion::V11, 512), (ConsensusVersion::V14, 2048)];
200
201 /// The minimum number of entries in a record.
202 const MIN_RECORD_ENTRIES: usize = 1; // This accounts for 'record.owner'.
203 /// The maximum number of entries in a record.
204 const MAX_RECORD_ENTRIES: usize = Self::MIN_RECORD_ENTRIES.saturating_add(Self::MAX_DATA_ENTRIES);
205
206 /// The maximum program size by number of characters.
207 const MAX_PROGRAM_SIZE: [(ConsensusVersion, usize); 2] = [
208 (ConsensusVersion::V1, 100_000), // 100 kB
209 (ConsensusVersion::V14, 512_000), // 512 kB
210 ];
211 /// The maximum number of mappings in a program.
212 const MAX_MAPPINGS: usize = 31;
213 /// The maximum number of functions in a program.
214 const MAX_FUNCTIONS: usize = 31;
215 /// The maximum number of structs in a program.
216 const MAX_STRUCTS: usize = 10 * Self::MAX_FUNCTIONS;
217 /// The maximum number of records in a program.
218 const MAX_RECORDS: usize = 10 * Self::MAX_FUNCTIONS;
219 /// The maximum number of closures in a program.
220 const MAX_CLOSURES: usize = 2 * Self::MAX_FUNCTIONS;
221 /// The maximum number of operands in an instruction.
222 const MAX_OPERANDS: usize = Self::MAX_INPUTS;
223 /// The maximum number of instructions in a closure or function.
224 const MAX_INSTRUCTIONS: usize = u16::MAX as usize;
225 /// The maximum number of commands in finalize.
226 const MAX_COMMANDS: usize = u16::MAX as usize;
227 /// The maximum number of write commands in finalize.
228 const MAX_WRITES: [(ConsensusVersion, u16); 2] = [(ConsensusVersion::V1, 16), (ConsensusVersion::V14, 32)];
229 /// The maximum number of `position` commands in finalize.
230 const MAX_POSITIONS: usize = u8::MAX as usize;
231
232 /// The maximum number of inputs per transition.
233 const MAX_INPUTS: usize = 16;
234 /// The maximum number of outputs per transition.
235 const MAX_OUTPUTS: usize = 16;
236
237 /// The maximum number of imports.
238 const MAX_IMPORTS: usize = 64;
239
240 /// A list of consensus versions and their corresponding maximum transaction sizes in bytes.
241 ///
242 /// A transaction consists of fixed identifiers, deployment data, and fees.
243 /// Fixed components include identifiers, ownership, checksums, and fees.
244 /// Variable components include the program bytecode and verifying-key entries.
245 /// Verifying-key entries scale with the number of functions and records.
246 ///
247 /// MAX_TRANSACTION_SIZE = C + MAX_PROGRAM_SIZE + (673 + 58) * (MAX_FUNCTIONS + MAX_RECORDS)
248 /// C = fixed size components (Up to 2367 bytes)
249 // Note: This value must **not** decrease without considering the impact on transaction validity.
250 const MAX_TRANSACTION_SIZE: [(ConsensusVersion, usize); 2] = [
251 (ConsensusVersion::V1, 128_000), // 128 kB
252 (ConsensusVersion::V14, 768_000), // 768 kB
253 ];
254
255 /// The state root type.
256 type StateRoot: Bech32ID<Field<Self>>;
257 /// The block hash type.
258 type BlockHash: Bech32ID<Field<Self>>;
259 /// The ratification ID type.
260 type RatificationID: Bech32ID<Field<Self>>;
261 /// The transaction ID type.
262 type TransactionID: Bech32ID<Field<Self>>;
263 /// The transition ID type.
264 type TransitionID: Bech32ID<Field<Self>>;
265 /// The transmission checksum type.
266 type TransmissionChecksum: IntegerType;
267
268 /// A list of (consensus_version, block_height) pairs indicating when each consensus version takes effect.
269 /// Documentation for what is changed at each version can be found in `N::CONSENSUS_VERSION`
270 /// Do not read this directly outside of tests, use `N::CONSENSUS_VERSION_HEIGHTS()` instead.
271 const _CONSENSUS_VERSION_HEIGHTS: [(ConsensusVersion, u32); NUM_CONSENSUS_VERSIONS];
272
273 /// A list of (consensus_version, size) pairs indicating the maximum number of validators in a committee.
274 // Note: This value must **not** decrease without considering the impact on serialization.
275 // Decreasing this value will break backwards compatibility of serialization without explicit
276 // declaration of migration based on round number rather than block height.
277 // Increasing this value will require a migration to prevent forking during network upgrades.
278 const MAX_CERTIFICATES: [(ConsensusVersion, u16); 5];
279
280 /// Returns the list of consensus versions.
281 #[allow(non_snake_case)]
282 #[cfg(not(any(test, feature = "test", feature = "test_consensus_heights")))]
283 fn CONSENSUS_VERSION_HEIGHTS() -> &'static [(ConsensusVersion, u32); NUM_CONSENSUS_VERSIONS] {
284 // Initialize the consensus version heights directly from the constant.
285 CONSENSUS_VERSION_HEIGHTS.get_or_init(|| Self::_CONSENSUS_VERSION_HEIGHTS)
286 }
287 /// Returns the list of test consensus versions.
288 #[allow(non_snake_case)]
289 #[cfg(any(test, feature = "test", feature = "test_consensus_heights"))]
290 fn CONSENSUS_VERSION_HEIGHTS() -> &'static [(ConsensusVersion, u32); NUM_CONSENSUS_VERSIONS] {
291 CONSENSUS_VERSION_HEIGHTS.get_or_init(load_test_consensus_heights)
292 }
293
294 /// A set of incrementing consensus version heights used for tests.
295 #[allow(non_snake_case)]
296 #[cfg(any(test, feature = "test", feature = "test_consensus_heights"))]
297 const TEST_CONSENSUS_VERSION_HEIGHTS: [(ConsensusVersion, u32); NUM_CONSENSUS_VERSIONS] =
298 TEST_CONSENSUS_VERSION_HEIGHTS;
299 /// Returns the consensus version which is active at the given height.
300 #[allow(non_snake_case)]
301 fn CONSENSUS_VERSION(seek_height: u32) -> anyhow::Result<ConsensusVersion> {
302 match Self::CONSENSUS_VERSION_HEIGHTS().binary_search_by(|(_, height)| height.cmp(&seek_height)) {
303 // If a consensus version was found at this height, return it.
304 Ok(index) => Ok(Self::CONSENSUS_VERSION_HEIGHTS()[index].0),
305 // If the specified height was not found, determine whether to return an appropriate version.
306 Err(index) => {
307 if index == 0 {
308 Err(anyhow!("Expected consensus version 1 to exist at height 0."))
309 } else {
310 // Return the appropriate version belonging to the height *lower* than the sought height.
311 Ok(Self::CONSENSUS_VERSION_HEIGHTS()[index - 1].0)
312 }
313 }
314 }
315 }
316 /// Returns the height at which a specified consensus version becomes active.
317 #[allow(non_snake_case)]
318 fn CONSENSUS_HEIGHT(version: ConsensusVersion) -> Result<u32> {
319 Ok(Self::CONSENSUS_VERSION_HEIGHTS().get(version as usize - 1).ok_or(anyhow!("Invalid consensus version"))?.1)
320 }
321 /// Returns the last `MAX_ARRAY_ELEMENTS` value.
322 #[allow(non_snake_case)]
323 fn LATEST_MAX_ARRAY_ELEMENTS() -> usize {
324 Self::MAX_ARRAY_ELEMENTS.last().expect("MAX_ARRAY_ELEMENTS must have at least one entry").1
325 }
326 /// Returns the last `MAX_CERTIFICATES` value.
327 #[allow(non_snake_case)]
328 fn LATEST_MAX_CERTIFICATES() -> u16 {
329 Self::MAX_CERTIFICATES.last().expect("MAX_CERTIFICATES must have at least one entry").1
330 }
331
332 /// Returns the last `MAX_PROGRAM_SIZE` value.
333 #[allow(non_snake_case)]
334 fn LATEST_MAX_PROGRAM_SIZE() -> usize {
335 Self::MAX_PROGRAM_SIZE.last().expect("MAX_PROGRAM_SIZE must have at least one entry").1
336 }
337
338 /// Returns the last `MAX_WRITES` value.
339 #[allow(non_snake_case)]
340 fn LATEST_MAX_WRITES() -> u16 {
341 Self::MAX_WRITES.last().expect("MAX_WRITES must have at least one entry").1
342 }
343
344 /// Returns the last `MAX_TRANSACTION_SIZE` value.
345 #[allow(non_snake_case)]
346 fn LATEST_MAX_TRANSACTION_SIZE() -> usize {
347 Self::MAX_TRANSACTION_SIZE.last().expect("MAX_TRANSACTION_SIZE must have at least one entry").1
348 }
349
350 /// Returns the block height where the the inclusion proof will be updated.
351 #[allow(non_snake_case)]
352 fn INCLUSION_UPGRADE_HEIGHT() -> Result<u32>;
353
354 /// Returns the genesis block bytes.
355 fn genesis_bytes() -> &'static [u8];
356
357 /// Returns the restrictions list as a JSON-compatible string.
358 fn restrictions_list_as_str() -> &'static str;
359
360 /// Returns the proving key for the given function name in the v0 version of `credits.aleo`.
361 fn get_credits_v0_proving_key(function_name: String) -> Result<&'static Arc<VarunaProvingKey<Self>>>;
362
363 /// Returns the verifying key for the given function name in the v0 version of `credits.aleo`.
364 fn get_credits_v0_verifying_key(function_name: String) -> Result<&'static Arc<VarunaVerifyingKey<Self>>>;
365
366 /// Returns the proving key for the given function name in `credits.aleo`.
367 fn get_credits_proving_key(function_name: String) -> Result<&'static Arc<VarunaProvingKey<Self>>>;
368
369 /// Returns the verifying key for the given function name in `credits.aleo`.
370 fn get_credits_verifying_key(function_name: String) -> Result<&'static Arc<VarunaVerifyingKey<Self>>>;
371
372 #[cfg(not(feature = "wasm"))]
373 /// Returns the `proving key` for the inclusion_v0 circuit.
374 fn inclusion_v0_proving_key() -> &'static Arc<VarunaProvingKey<Self>>;
375
376 #[cfg(feature = "wasm")]
377 /// Returns the `proving key` for the inclusion_v0 circuit.
378 fn inclusion_v0_proving_key(bytes: Option<Vec<u8>>) -> &'static Arc<VarunaProvingKey<Self>>;
379
380 /// Returns the `verifying key` for the inclusion_v0 circuit.
381 fn inclusion_v0_verifying_key() -> &'static Arc<VarunaVerifyingKey<Self>>;
382
383 #[cfg(not(feature = "wasm"))]
384 /// Returns the `proving key` for the inclusion circuit.
385 fn inclusion_proving_key() -> &'static Arc<VarunaProvingKey<Self>>;
386
387 #[cfg(feature = "wasm")]
388 fn inclusion_proving_key(bytes: Option<Vec<u8>>) -> &'static Arc<VarunaProvingKey<Self>>;
389
390 /// Returns the `verifying key` for the inclusion circuit.
391 fn inclusion_verifying_key() -> &'static Arc<VarunaVerifyingKey<Self>>;
392
393 #[cfg(not(feature = "wasm"))]
394 /// Returns the `proving key` for the translation circuit.
395 fn translation_credits_proving_key() -> &'static Arc<VarunaProvingKey<Self>>;
396
397 #[cfg(feature = "wasm")]
398 /// Returns the `proving key` for the translation circuit.
399 fn translation_credits_proving_key(bytes: Option<Vec<u8>>) -> &'static Arc<VarunaProvingKey<Self>>;
400
401 /// Returns the `verifying key` for the translation circuit.
402 fn translation_credits_verifying_key() -> &'static Arc<VarunaVerifyingKey<Self>>;
403
404 /// Returns the powers of `G`.
405 fn g_powers() -> &'static Vec<Group<Self>>;
406
407 /// Returns the scalar multiplication on the generator `G`.
408 fn g_scalar_multiply(scalar: &Scalar<Self>) -> Group<Self>;
409
410 /// Returns the Varuna universal prover.
411 fn varuna_universal_prover() -> &'static UniversalProver<Self::PairingCurve>;
412
413 /// Returns the Varuna universal verifier.
414 fn varuna_universal_verifier() -> &'static UniversalVerifier<Self::PairingCurve>;
415
416 /// Returns the sponge parameters for Varuna.
417 fn varuna_fs_parameters() -> &'static FiatShamirParameters<Self>;
418
419 /// Returns the commitment domain as a constant field element.
420 fn commitment_domain() -> Field<Self>;
421
422 /// Returns the encryption domain as a constant field element.
423 fn encryption_domain() -> Field<Self>;
424
425 /// Returns the graph key domain as a constant field element.
426 fn graph_key_domain() -> Field<Self>;
427
428 /// Returns the serial number domain as a constant field element.
429 fn serial_number_domain() -> Field<Self>;
430
431 /// Returns a BHP commitment with an input hasher of 256-bits and randomizer.
432 fn commit_bhp256(input: &[bool], randomizer: &Scalar<Self>) -> Result<Field<Self>>;
433
434 /// Returns a BHP commitment with an input hasher of 512-bits and randomizer.
435 fn commit_bhp512(input: &[bool], randomizer: &Scalar<Self>) -> Result<Field<Self>>;
436
437 /// Returns a BHP commitment with an input hasher of 768-bits and randomizer.
438 fn commit_bhp768(input: &[bool], randomizer: &Scalar<Self>) -> Result<Field<Self>>;
439
440 /// Returns a BHP commitment with an input hasher of 1024-bits and randomizer.
441 fn commit_bhp1024(input: &[bool], randomizer: &Scalar<Self>) -> Result<Field<Self>>;
442
443 /// Returns a Pedersen commitment for the given (up to) 64-bit input and randomizer.
444 fn commit_ped64(input: &[bool], randomizer: &Scalar<Self>) -> Result<Field<Self>>;
445
446 /// Returns a Pedersen commitment for the given (up to) 128-bit input and randomizer.
447 fn commit_ped128(input: &[bool], randomizer: &Scalar<Self>) -> Result<Field<Self>>;
448
449 /// Returns a BHP commitment with an input hasher of 256-bits and randomizer.
450 fn commit_to_group_bhp256(input: &[bool], randomizer: &Scalar<Self>) -> Result<Group<Self>>;
451
452 /// Returns a BHP commitment with an input hasher of 512-bits and randomizer.
453 fn commit_to_group_bhp512(input: &[bool], randomizer: &Scalar<Self>) -> Result<Group<Self>>;
454
455 /// Returns a BHP commitment with an input hasher of 768-bits and randomizer.
456 fn commit_to_group_bhp768(input: &[bool], randomizer: &Scalar<Self>) -> Result<Group<Self>>;
457
458 /// Returns a BHP commitment with an input hasher of 1024-bits and randomizer.
459 fn commit_to_group_bhp1024(input: &[bool], randomizer: &Scalar<Self>) -> Result<Group<Self>>;
460
461 /// Returns a Pedersen commitment for the given (up to) 64-bit input and randomizer.
462 fn commit_to_group_ped64(input: &[bool], randomizer: &Scalar<Self>) -> Result<Group<Self>>;
463
464 /// Returns a Pedersen commitment for the given (up to) 128-bit input and randomizer.
465 fn commit_to_group_ped128(input: &[bool], randomizer: &Scalar<Self>) -> Result<Group<Self>>;
466
467 /// Returns the BHP hash with an input hasher of 256-bits.
468 fn hash_bhp256(input: &[bool]) -> Result<Field<Self>>;
469
470 /// Returns the BHP hash with an input hasher of 512-bits.
471 fn hash_bhp512(input: &[bool]) -> Result<Field<Self>>;
472
473 /// Returns the BHP hash with an input hasher of 768-bits.
474 fn hash_bhp768(input: &[bool]) -> Result<Field<Self>>;
475
476 /// Returns the BHP hash with an input hasher of 1024-bits.
477 fn hash_bhp1024(input: &[bool]) -> Result<Field<Self>>;
478
479 /// Returns the Keccak hash with a 256-bit output.
480 fn hash_keccak256(input: &[bool]) -> Result<Vec<bool>>;
481
482 /// Returns the Keccak hash with a 384-bit output.
483 fn hash_keccak384(input: &[bool]) -> Result<Vec<bool>>;
484
485 /// Returns the Keccak hash with a 512-bit output.
486 fn hash_keccak512(input: &[bool]) -> Result<Vec<bool>>;
487
488 /// Returns the Pedersen hash for a given (up to) 64-bit input.
489 fn hash_ped64(input: &[bool]) -> Result<Field<Self>>;
490
491 /// Returns the Pedersen hash for a given (up to) 128-bit input.
492 fn hash_ped128(input: &[bool]) -> Result<Field<Self>>;
493
494 /// Returns the Poseidon hash with an input rate of 2.
495 fn hash_psd2(input: &[Field<Self>]) -> Result<Field<Self>>;
496
497 /// Returns the Poseidon hash with an input rate of 4.
498 fn hash_psd4(input: &[Field<Self>]) -> Result<Field<Self>>;
499
500 /// Returns the Poseidon hash with an input rate of 8.
501 fn hash_psd8(input: &[Field<Self>]) -> Result<Field<Self>>;
502
503 /// Returns the SHA-3 hash with a 256-bit output.
504 fn hash_sha3_256(input: &[bool]) -> Result<Vec<bool>>;
505
506 /// Returns the SHA-3 hash with a 384-bit output.
507 fn hash_sha3_384(input: &[bool]) -> Result<Vec<bool>>;
508
509 /// Returns the SHA-3 hash with a 512-bit output.
510 fn hash_sha3_512(input: &[bool]) -> Result<Vec<bool>>;
511
512 /// Returns the extended Poseidon hash with an input rate of 2.
513 fn hash_many_psd2(input: &[Field<Self>], num_outputs: u16) -> Vec<Field<Self>>;
514
515 /// Returns the extended Poseidon hash with an input rate of 4.
516 fn hash_many_psd4(input: &[Field<Self>], num_outputs: u16) -> Vec<Field<Self>>;
517
518 /// Returns the extended Poseidon hash with an input rate of 8.
519 fn hash_many_psd8(input: &[Field<Self>], num_outputs: u16) -> Vec<Field<Self>>;
520
521 /// Returns the BHP hash with an input hasher of 256-bits.
522 fn hash_to_group_bhp256(input: &[bool]) -> Result<Group<Self>>;
523
524 /// Returns the BHP hash with an input hasher of 512-bits.
525 fn hash_to_group_bhp512(input: &[bool]) -> Result<Group<Self>>;
526
527 /// Returns the BHP hash with an input hasher of 768-bits.
528 fn hash_to_group_bhp768(input: &[bool]) -> Result<Group<Self>>;
529
530 /// Returns the BHP hash with an input hasher of 1024-bits.
531 fn hash_to_group_bhp1024(input: &[bool]) -> Result<Group<Self>>;
532
533 /// Returns the Pedersen hash for a given (up to) 64-bit input.
534 fn hash_to_group_ped64(input: &[bool]) -> Result<Group<Self>>;
535
536 /// Returns the Pedersen hash for a given (up to) 128-bit input.
537 fn hash_to_group_ped128(input: &[bool]) -> Result<Group<Self>>;
538
539 /// Returns the Poseidon hash with an input rate of 2 on the affine curve.
540 fn hash_to_group_psd2(input: &[Field<Self>]) -> Result<Group<Self>>;
541
542 /// Returns the Poseidon hash with an input rate of 4 on the affine curve.
543 fn hash_to_group_psd4(input: &[Field<Self>]) -> Result<Group<Self>>;
544
545 /// Returns the Poseidon hash with an input rate of 8 on the affine curve.
546 fn hash_to_group_psd8(input: &[Field<Self>]) -> Result<Group<Self>>;
547
548 /// Returns the Poseidon hash with an input rate of 2 on the scalar field.
549 fn hash_to_scalar_psd2(input: &[Field<Self>]) -> Result<Scalar<Self>>;
550
551 /// Returns the Poseidon hash with an input rate of 4 on the scalar field.
552 fn hash_to_scalar_psd4(input: &[Field<Self>]) -> Result<Scalar<Self>>;
553
554 /// Returns the Poseidon hash with an input rate of 8 on the scalar field.
555 fn hash_to_scalar_psd8(input: &[Field<Self>]) -> Result<Scalar<Self>>;
556
557 /// Returns a Merkle tree with a BHP leaf hasher of 1024-bits and a BHP path hasher of 512-bits.
558 fn merkle_tree_bhp<const DEPTH: u8>(leaves: &[Vec<bool>]) -> Result<BHPMerkleTree<Self, DEPTH>>;
559
560 /// Returns a Merkle tree with a Poseidon leaf hasher with input rate of 4 and a Poseidon path hasher with input rate of 2.
561 fn merkle_tree_psd<const DEPTH: u8>(leaves: &[Vec<Field<Self>>]) -> Result<PoseidonMerkleTree<Self, DEPTH>>;
562
563 /// Returns `true` if the given Merkle path is valid for the given root and leaf.
564 #[allow(clippy::ptr_arg)]
565 fn verify_merkle_path_bhp<const DEPTH: u8>(
566 path: &MerklePath<Self, DEPTH>,
567 root: &Field<Self>,
568 leaf: &Vec<bool>,
569 ) -> bool;
570
571 /// Returns `true` if the given Merkle path is valid for the given root and leaf.
572 #[allow(clippy::ptr_arg)]
573 fn verify_merkle_path_psd<const DEPTH: u8>(
574 path: &MerklePath<Self, DEPTH>,
575 root: &Field<Self>,
576 leaf: &Vec<Field<Self>>,
577 ) -> bool;
578
579 /// Returns the Poseidon leaf hasher for dynamic records (rate 8).
580 fn dynamic_record_leaf_hasher() -> &'static Poseidon8<Self>;
581
582 /// Returns the Poseidon path hasher for dynamic records (rate 2).
583 fn dynamic_record_path_hasher() -> &'static Poseidon2<Self>;
584}
585
586/// Returns the consensus version heights, initializing them if necessary.
587///
588/// If a `heights` string is provided, it must be a comma-separated list of ascending block heights
589/// starting from zero (e.g., `"0,2,3,4,..."`) with a number of heights exactly equal to the value
590/// of the Network trait's `NUM_CONSENSUS_VERSIONS` constant. These heights correspond to the
591/// activation block of each `ConsensusVersion`.
592///
593/// If `heights` is `None`, the function will use SnarkVM's default test consensus heights.
594///
595/// This function caches the initialized heights, and can be set only once. Further calls will
596/// return the cached heights.
597///
598/// This method should be called by `wasm` users who need to set test values for consensus heights
599/// for purposes such as testing on a local devnet. If this method needs to be used, it should be
600/// called immediately after the wasm module is initialized.
601#[cfg(feature = "wasm")]
602pub fn get_or_init_consensus_version_heights(
603 heights: Option<String>,
604) -> [(ConsensusVersion, u32); NUM_CONSENSUS_VERSIONS] {
605 let heights = load_test_consensus_heights_inner(heights);
606 *CONSENSUS_VERSION_HEIGHTS.get_or_init(|| heights)
607}