snarkvm_console_account/compute_key/
from_bits.rs1use super::*;
17
18impl<N: Network> FromBits for ComputeKey<N> {
19 fn from_bits_le(bits_le: &[bool]) -> Result<Self> {
21 let group_size_in_bits = Group::<N>::size_in_bits();
22
23 let (pk_sig_start, pk_sig_end) = (0, group_size_in_bits);
24 let (pr_sig_start, pr_sig_end) = (pk_sig_end, pk_sig_end + group_size_in_bits);
25
26 let Some(pk_sig_bits) = bits_le.get(pk_sig_start..pk_sig_end) else {
27 bail!("Unable to recover the 'pk_sig' (LE) bits for the compute key");
28 };
29 let Some(pr_sig_bits) = bits_le.get(pr_sig_start..pr_sig_end) else {
30 bail!("Unable to recover the 'pr_sig' (LE) bits for the compute key");
31 };
32
33 Self::try_from((Group::from_bits_le(pk_sig_bits)?, Group::from_bits_le(pr_sig_bits)?))
34 }
35
36 fn from_bits_be(bits_be: &[bool]) -> Result<Self> {
38 let group_size_in_bits = Group::<N>::size_in_bits();
39
40 let (pk_sig_start, pk_sig_end) = (0, group_size_in_bits);
41 let (pr_sig_start, pr_sig_end) = (pk_sig_end, pk_sig_end + group_size_in_bits);
42
43 let Some(pk_sig_bits) = bits_be.get(pk_sig_start..pk_sig_end) else {
44 bail!("Unable to recover the 'pk_sig' (BE) bits for the compute key");
45 };
46 let Some(pr_sig_bits) = bits_be.get(pr_sig_start..pr_sig_end) else {
47 bail!("Unable to recover the 'pr_sig' (BE) bits for the compute key");
48 };
49
50 Self::try_from((Group::from_bits_be(pk_sig_bits)?, Group::from_bits_be(pr_sig_bits)?))
51 }
52}
53
54#[cfg(test)]
55mod tests {
56 use super::*;
57 use snarkvm_console_network::MainnetV0;
58
59 type CurrentNetwork = MainnetV0;
60
61 const ITERATIONS: usize = 100;
62
63 fn check_from_bits_le() -> Result<()> {
64 let rng = &mut TestRng::default();
65
66 for i in 0..ITERATIONS {
67 let expected = ComputeKey::<CurrentNetwork>::try_from(PrivateKey::new(rng).unwrap()).unwrap();
69
70 let given_bits = expected.to_bits_le();
71 assert_eq!(ComputeKey::<CurrentNetwork>::size_in_bits(), given_bits.len());
72
73 let candidate = ComputeKey::<CurrentNetwork>::from_bits_le(&given_bits)?;
74 assert_eq!(expected, candidate);
75
76 let candidate = [given_bits, vec![false; i]].concat();
78
79 let candidate = ComputeKey::<CurrentNetwork>::from_bits_le(&candidate)?;
80 assert_eq!(expected, candidate);
81 assert_eq!(ComputeKey::<CurrentNetwork>::size_in_bits(), candidate.to_bits_le().len());
82 }
83 Ok(())
84 }
85
86 fn check_from_bits_be() -> Result<()> {
87 let rng = &mut TestRng::default();
88
89 for i in 0..ITERATIONS {
90 let expected = ComputeKey::<CurrentNetwork>::try_from(PrivateKey::new(rng).unwrap()).unwrap();
92
93 let given_bits = expected.to_bits_be();
94 assert_eq!(ComputeKey::<CurrentNetwork>::size_in_bits(), given_bits.len());
95
96 let candidate = ComputeKey::<CurrentNetwork>::from_bits_be(&given_bits)?;
97 assert_eq!(expected, candidate);
98
99 let candidate = [given_bits, vec![false; i]].concat();
101
102 let candidate = ComputeKey::<CurrentNetwork>::from_bits_be(&candidate)?;
103 assert_eq!(expected, candidate);
104 assert_eq!(ComputeKey::<CurrentNetwork>::size_in_bits(), candidate.to_bits_be().len());
105 }
106 Ok(())
107 }
108
109 #[test]
110 fn test_from_bits_le() -> Result<()> {
111 check_from_bits_le()
112 }
113
114 #[test]
115 fn test_from_bits_be() -> Result<()> {
116 check_from_bits_be()
117 }
118}