use std::fmt; use std::collections::HashMap; use serde::{Serializer, Deserializer, Serialize, Deserialize}; use serde::de::{self, Visitor}; #[derive(Default, PartialOrd, Ord, Clone, Hash, PartialEq)] pub struct FixedBytes32([u8; 32]); impl From<[u8; 32]> for FixedBytes32 { fn from(x: [u8; 32]) -> FixedBytes32 { FixedBytes32(x) } } impl std::convert::AsRef<[u8]> for FixedBytes32 { fn as_ref(&self) -> &[u8] { &self.0[..] } } impl Eq for FixedBytes32 {} impl fmt::Debug for FixedBytes32 { fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result { write!(f, "{}", hex::encode(self.0)) } } struct FixedBytes32Visitor; impl<'de> Visitor<'de> for FixedBytes32Visitor { type Value = FixedBytes32; fn expecting(&self, formatter: &mut fmt::Formatter) -> fmt::Result { formatter.write_str("a byte slice of size 32") } fn visit_bytes(self, value: &[u8]) -> Result { if value.len() == 32 { let mut res = [0u8; 32]; res.copy_from_slice(value); Ok(res.into()) } else { Err(E::custom(format!("Invalid byte string length {}, expected 32", value.len()))) } } } impl<'de> Deserialize<'de> for FixedBytes32 { fn deserialize>(deserializer: D) -> Result { deserializer.deserialize_bytes(FixedBytes32Visitor) } } impl Serialize for FixedBytes32 { fn serialize(&self, serializer: S) -> Result { serializer.serialize_bytes(&self.0[..]) } } impl FixedBytes32 { pub fn as_slice(&self) -> &[u8] { &self.0[..] } pub fn as_slice_mut(&mut self) -> &mut [u8] { &mut self.0[..] } } pub type UUID = FixedBytes32; pub type Hash = FixedBytes32; // Network management #[derive(Clone, Debug, Serialize, Deserialize)] pub struct NetworkConfig { pub members: HashMap, pub version: u64, } #[derive(Clone, Debug, Serialize, Deserialize)] pub struct NetworkConfigEntry { pub datacenter: String, pub n_tokens: u32, } // Data management #[derive(Debug, Serialize, Deserialize)] pub struct SplitpointMeta { bucket: String, key: String, timestamp: u64, uuid: UUID, deleted: bool, } #[derive(Debug, Serialize, Deserialize)] pub struct VersionMeta { bucket: String, key: String, timestamp: u64, uuid: UUID, deleted: bool, mime_type: String, size: u64, is_complete: bool, data: VersionData, } #[derive(Debug, Serialize, Deserialize)] pub enum VersionData { Inline(Vec), FirstBlock(Hash), } #[derive(Debug, Serialize, Deserialize)] pub struct BlockMeta { version_uuid: UUID, offset: u64, hash: Hash, } #[derive(Debug, Serialize, Deserialize)] pub struct BlockReverseMeta { versions: Vec, deleted_versions: Vec, }