/ ledger / puzzle / src / solution_id / serialize.rs
serialize.rs
 1  // Copyright (c) 2025-2026 ACDC Network
 2  // This file is part of the alphavm library.
 3  //
 4  // Alpha Chain | Delta Chain Protocol
 5  // International Monetary Graphite.
 6  //
 7  // Derived from Aleo (https://aleo.org) and ProvableHQ (https://provable.com).
 8  // They built world-class ZK infrastructure. We installed the EASY button.
 9  // Their cryptography: elegant. Our modifications: bureaucracy-compatible.
10  // Original brilliance: theirs. Robert's Rules: ours. Bugs: definitely ours.
11  //
12  // Original Aleo/ProvableHQ code subject to Apache 2.0 https://www.apache.org/licenses/LICENSE-2.0
13  // All modifications and new work: CC0 1.0 Universal Public Domain Dedication.
14  // No rights reserved. No permission required. No warranty. No refunds.
15  //
16  // https://creativecommons.org/publicdomain/zero/1.0/
17  // SPDX-License-Identifier: CC0-1.0
18  
19  use super::*;
20  
21  impl<N: Network> Serialize for SolutionID<N> {
22      /// Serializes the solution ID to a string or buffer.
23      fn serialize<S: Serializer>(&self, serializer: S) -> Result<S::Ok, S::Error> {
24          match serializer.is_human_readable() {
25              true => serializer.collect_str(self),
26              false => ToBytesSerializer::serialize_with_size_encoding(self, serializer),
27          }
28      }
29  }
30  
31  impl<'de, N: Network> Deserialize<'de> for SolutionID<N> {
32      /// Deserializes the solution ID from a string or buffer.
33      fn deserialize<D: Deserializer<'de>>(deserializer: D) -> Result<Self, D::Error> {
34          match deserializer.is_human_readable() {
35              true => FromStr::from_str(&String::deserialize(deserializer)?).map_err(de::Error::custom),
36              false => FromBytesDeserializer::<Self>::deserialize_with_size_encoding(deserializer, "solution ID"),
37          }
38      }
39  }
40  
41  #[cfg(test)]
42  mod tests {
43      use super::*;
44      use console::network::MainnetV0;
45  
46      type CurrentNetwork = MainnetV0;
47  
48      #[test]
49      fn test_serde_json() -> Result<()> {
50          let mut rng = TestRng::default();
51  
52          // Sample a new solution ID.
53          let expected = SolutionID::<CurrentNetwork>::from(rng.r#gen::<u64>());
54  
55          // Serialize
56          let expected_string = &expected.to_string();
57          let candidate_string = serde_json::to_string(&expected)?;
58          assert_eq!(expected, serde_json::from_str(&candidate_string)?);
59  
60          // Deserialize
61          assert_eq!(expected, SolutionID::from_str(expected_string)?);
62          assert_eq!(expected, serde_json::from_str(&candidate_string)?);
63  
64          Ok(())
65      }
66  
67      #[test]
68      fn test_bincode() -> Result<()> {
69          let mut rng = TestRng::default();
70  
71          // Sample a new solution ID.
72          let expected = SolutionID::<CurrentNetwork>::from(rng.r#gen::<u64>());
73  
74          // Serialize
75          let expected_bytes = expected.to_bytes_le()?;
76          let expected_bytes_with_size_encoding = bincode::serialize(&expected)?;
77          assert_eq!(&expected_bytes[..], &expected_bytes_with_size_encoding[8..]);
78  
79          // Deserialize
80          assert_eq!(expected, SolutionID::read_le(&expected_bytes[..])?);
81          assert_eq!(expected, bincode::deserialize(&expected_bytes_with_size_encoding[..])?);
82  
83          Ok(())
84      }
85  }