Spaces:
Build error
Build error
File size: 1,685 Bytes
84d2a97 |
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 |
//! Storage - is a crate which contains all service functions, abstracted from the external interface
//!
//! It provides all functions, which could be used from REST (or any other interface), but do not
//! implement any concrete interface.
use content_manager::collection_meta_ops::CollectionMetaOperations;
use content_manager::consensus_manager::ConsensusStateRef;
use content_manager::consensus_ops::ConsensusOperations;
use content_manager::errors::StorageError;
use content_manager::toc::TableOfContent;
use types::ClusterStatus;
pub mod content_manager;
pub mod dispatcher;
pub mod issues_subscribers;
pub mod rbac;
pub mod types;
pub mod serialize_peer_addresses {
use std::collections::HashMap;
use itertools::Itertools;
use serde::{self, de, Deserialize, Deserializer, Serialize, Serializer};
use crate::types::PeerAddressById;
pub fn serialize<S>(addresses: &PeerAddressById, serializer: S) -> Result<S::Ok, S::Error>
where
S: Serializer,
{
let addresses: HashMap<u64, String> = addresses
.clone()
.into_iter()
.map(|(id, address)| (id, format!("{address}")))
.collect();
addresses.serialize(serializer)
}
pub fn deserialize<'de, D>(deserializer: D) -> Result<PeerAddressById, D::Error>
where
D: Deserializer<'de>,
{
let addresses: HashMap<u64, String> = HashMap::deserialize(deserializer)?;
addresses
.into_iter()
.map(|(id, address)| address.parse().map(|address| (id, address)))
.try_collect()
.map_err(|err| de::Error::custom(format!("Failed to parse uri: {err}")))
}
}
|