catbuffer_rust/vrf_proof_builder.rs
1/*
2 * // Copyright (c) 2016-2019, Jaguar0625, gimre, BloodyRookie, Tech Bureau, Corp.
3 * // Copyright (c) 2020-present, Jaguar0625, gimre, BloodyRookie.
4 * // All rights reserved.
5 * //
6 * // This file is part of Catapult.
7 * //
8 * // Catapult is free software: you can redistribute it and/or modify
9 * // it under the terms of the GNU Lesser General Public License as published by
10 * // the Free Software Foundation, either version 3 of the License, or
11 * // (at your option) any later version.
12 * //
13 * // Catapult is distributed in the hope that it will be useful,
14 * // but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 * // GNU Lesser General Public License for more details.
17 * //
18 * // You should have received a copy of the GNU Lesser General Public License
19 * // along with Catapult. If not, see <http://www.gnu.org/licenses/>.
20 */
21
22use super::generator_utils::*;
23use super::proof_gamma_dto::*;
24use super::proof_scalar_dto::*;
25use super::proof_verification_hash_dto::*;
26
27/// Verfiable random function proof.
28#[derive(Debug, Clone)]
29pub struct VrfProofBuilder {
30 /// Gamma.
31 gamma: ProofGammaDto,
32 /// Verification hash.
33 verification_hash: ProofVerificationHashDto,
34 /// Scalar.
35 scalar: ProofScalarDto,
36}
37
38
39impl VrfProofBuilder {
40 /// Creates an instance of VrfProofBuilder from binary payload.
41 /// payload: Byte payload to use to serialize the object.
42 /// # Returns
43 /// A VrfProofBuilder.
44 pub fn from_binary(_bytes: &[u8]) -> Self {
45 let gamma = ProofGammaDto::from_binary(&_bytes); // kind:CUSTOM1
46 let mut _bytes = _bytes[gamma.get_size()..].to_vec();
47 let verification_hash = ProofVerificationHashDto::from_binary(&_bytes); // kind:CUSTOM1
48 let mut _bytes = _bytes[verification_hash.get_size()..].to_vec();
49 let scalar = ProofScalarDto::from_binary(&_bytes); // kind:CUSTOM1
50 let mut _bytes = _bytes[scalar.get_size()..].to_vec();
51 VrfProofBuilder { gamma, verification_hash, scalar }
52 }
53
54 /// Gets gamma.
55 ///
56 /// # Returns
57 /// A Gamma.
58 pub fn get_gamma(&self) -> ProofGammaDto {
59 self.gamma.clone()
60 }
61
62 /// Gets verification hash.
63 ///
64 /// # Returns
65 /// A Verification hash.
66 pub fn get_verification_hash(&self) -> ProofVerificationHashDto {
67 self.verification_hash.clone()
68 }
69
70 /// Gets scalar.
71 ///
72 /// # Returns
73 /// A Scalar.
74 pub fn get_scalar(&self) -> ProofScalarDto {
75 self.scalar.clone()
76 }
77
78 /// Gets the size of the type.
79 ///
80 /// Returns:
81 /// A size in bytes.
82 pub fn get_size(&self) -> usize {
83 let mut size = 0;
84 size += self.gamma.get_size(); // gamma;
85 size += self.verification_hash.get_size(); // verification_hash;
86 size += self.scalar.get_size(); // scalar;
87 size
88 }
89
90 /// Serializes self to bytes.
91 ///
92 /// # Returns
93 /// A Serialized bytes.
94 pub fn serializer(&self) -> Vec<u8> {
95 let mut buf: Vec<u8> = vec![];
96 buf.append(&mut self.gamma.serializer()); // kind:CUSTOM
97 buf.append(&mut self.verification_hash.serializer()); // kind:CUSTOM
98 buf.append(&mut self.scalar.serializer()); // kind:CUSTOM
99 buf
100 }
101}
102