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
// Copyright (C) 2019-2023 Aleo Systems Inc.
// 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.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,
        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 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())
    }
}