snarkvm_ledger_narwhal_batch_header/to_id.rs
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67
// Copyright 2024 Aleo Network Foundation
// This file is part of the snarkVM library.
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at:
// http://www.apache.org/licenses/LICENSE-2.0
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
use super::*;
impl<N: Network> BatchHeader<N> {
/// Returns the batch ID.
pub fn to_id(&self) -> Result<Field<N>> {
Self::compute_batch_id(
self.author,
self.round,
self.timestamp,
self.committee_id,
&self.transmission_ids,
&self.previous_certificate_ids,
)
}
}
impl<N: Network> BatchHeader<N> {
/// Returns the batch ID.
pub fn compute_batch_id(
author: Address<N>,
round: u64,
timestamp: i64,
committee_id: Field<N>,
transmission_ids: &IndexSet<TransmissionID<N>>,
previous_certificate_ids: &IndexSet<Field<N>>,
) -> Result<Field<N>> {
let mut preimage = Vec::new();
// Insert the author.
author.write_le(&mut preimage)?;
// Insert the round number.
round.write_le(&mut preimage)?;
// Insert the timestamp.
timestamp.write_le(&mut preimage)?;
// Insert the committee ID.
committee_id.write_le(&mut preimage)?;
// Insert the number of transmissions.
u32::try_from(transmission_ids.len())?.write_le(&mut preimage)?;
// Insert the transmission IDs.
for transmission_id in transmission_ids {
transmission_id.write_le(&mut preimage)?;
}
// Insert the number of previous certificate IDs.
u32::try_from(previous_certificate_ids.len())?.write_le(&mut preimage)?;
// Insert the previous certificate IDs.
for certificate_id in previous_certificate_ids {
// Insert the certificate ID.
certificate_id.write_le(&mut preimage)?;
}
// Hash the preimage.
N::hash_bhp1024(&preimage.to_bits_le())
}
}