use serde::{Deserialize, Serialize};
#[derive(Debug, Clone, PartialEq, Serialize, Deserialize)]
#[serde(rename_all = "camelCase")]
pub struct StorageQuery<Key> {
pub key: Key,
#[serde(rename = "type")]
pub query_type: StorageQueryType,
}
#[derive(Debug, Clone, PartialEq, Serialize, Deserialize)]
#[serde(rename_all = "camelCase")]
pub struct PaginatedStorageQuery<Key> {
pub key: Key,
#[serde(rename = "type")]
pub query_type: StorageQueryType,
#[serde(skip_serializing_if = "Option::is_none")]
#[serde(default)]
pub pagination_start_key: Option<Key>,
}
#[derive(Debug, Clone, PartialEq, Serialize, Deserialize)]
#[serde(rename_all = "camelCase")]
pub enum StorageQueryType {
Value,
Hash,
ClosestDescendantMerkleValue,
DescendantsValues,
DescendantsHashes,
}
impl StorageQueryType {
pub fn is_descendant_query(&self) -> bool {
matches!(self, Self::DescendantsValues | Self::DescendantsHashes)
}
}
#[derive(Debug, Clone, PartialEq, Serialize, Deserialize)]
#[serde(rename_all = "camelCase")]
pub struct StorageResult {
pub key: String,
#[serde(flatten)]
pub result: StorageResultType,
#[serde(skip_serializing_if = "Option::is_none")]
#[serde(default)]
pub child_trie_key: Option<String>,
}
#[derive(Debug, Clone, PartialEq, Eq, Serialize, Deserialize)]
#[serde(rename_all = "camelCase")]
pub enum StorageResultType {
Value(String),
Hash(String),
ClosestDescendantMerkleValue(String),
}
#[derive(Debug, Clone, PartialEq, Serialize, Deserialize)]
#[serde(rename_all = "camelCase")]
pub struct StorageResultErr {
pub key: String,
#[serde(flatten)]
pub error: StorageResultType,
}
#[derive(Debug, Clone, PartialEq, Serialize, Deserialize)]
#[serde(rename_all = "camelCase")]
#[serde(tag = "event")]
pub enum ArchiveStorageEvent {
Storage(StorageResult),
StorageError(ArchiveStorageMethodErr),
StorageDone,
}
impl ArchiveStorageEvent {
pub fn err(error: String) -> Self {
Self::StorageError(ArchiveStorageMethodErr { error })
}
pub fn result(result: StorageResult) -> Self {
Self::Storage(result)
}
pub fn is_done(&self) -> bool {
matches!(self, Self::StorageDone)
}
pub fn is_err(&self) -> bool {
matches!(self, Self::StorageError(_))
}
pub fn is_result(&self) -> bool {
matches!(self, Self::Storage(_))
}
}
#[derive(Debug, Clone, PartialEq, Serialize, Deserialize)]
#[serde(rename_all = "camelCase")]
pub struct ArchiveStorageMethodOk {
pub result: Vec<StorageResult>,
pub discarded_items: usize,
}
#[derive(Debug, Clone, PartialEq, Eq, Serialize, Deserialize)]
#[serde(rename_all = "camelCase")]
pub struct ArchiveStorageMethodErr {
pub error: String,
}
#[derive(Debug, Clone, Copy, PartialEq, Eq, Hash, Serialize, Deserialize)]
#[serde(rename_all = "camelCase")]
pub enum ArchiveStorageDiffType {
Value,
Hash,
}
#[derive(Debug, Clone, PartialEq, Serialize, Deserialize)]
#[serde(rename_all = "camelCase")]
pub struct ArchiveStorageDiffItem<Key> {
pub key: Key,
pub return_type: ArchiveStorageDiffType,
#[serde(skip_serializing_if = "Option::is_none")]
#[serde(default)]
pub child_trie_key: Option<Key>,
}
#[derive(Debug, Clone, PartialEq, Serialize, Deserialize)]
#[serde(rename_all = "camelCase")]
pub struct ArchiveStorageDiffMethodResult {
pub result: Vec<ArchiveStorageDiffResult>,
}
#[derive(Debug, Clone, Copy, PartialEq, Eq, Serialize, Deserialize)]
#[serde(rename_all = "camelCase")]
pub enum ArchiveStorageDiffOperationType {
Added,
Modified,
Deleted,
}
#[derive(Debug, Clone, PartialEq, Eq, Serialize, Deserialize)]
#[serde(rename_all = "camelCase")]
pub struct ArchiveStorageDiffResult {
pub key: String,
#[serde(flatten)]
pub result: StorageResultType,
#[serde(rename = "type")]
pub operation_type: ArchiveStorageDiffOperationType,
#[serde(skip_serializing_if = "Option::is_none")]
#[serde(default)]
pub child_trie_key: Option<String>,
}
#[derive(Debug, Clone, PartialEq, Eq, Serialize, Deserialize)]
#[serde(rename_all = "camelCase")]
#[serde(tag = "event")]
pub enum ArchiveStorageDiffEvent {
StorageDiff(ArchiveStorageDiffResult),
StorageDiffError(ArchiveStorageMethodErr),
StorageDiffDone,
}
impl ArchiveStorageDiffEvent {
pub fn err(error: String) -> Self {
Self::StorageDiffError(ArchiveStorageMethodErr { error })
}
pub fn is_done(&self) -> bool {
matches!(self, Self::StorageDiffDone)
}
pub fn is_err(&self) -> bool {
matches!(self, Self::StorageDiffError(_))
}
}
#[cfg(test)]
mod tests {
use super::*;
#[test]
fn archive_diff_input() {
let item = ArchiveStorageDiffItem {
key: "0x1",
return_type: ArchiveStorageDiffType::Value,
child_trie_key: None,
};
let ser = serde_json::to_string(&item).unwrap();
let exp = r#"{"key":"0x1","returnType":"value"}"#;
assert_eq!(ser, exp);
let dec: ArchiveStorageDiffItem<&str> = serde_json::from_str(exp).unwrap();
assert_eq!(dec, item);
let item = ArchiveStorageDiffItem {
key: "0x1",
return_type: ArchiveStorageDiffType::Hash,
child_trie_key: None,
};
let ser = serde_json::to_string(&item).unwrap();
let exp = r#"{"key":"0x1","returnType":"hash"}"#;
assert_eq!(ser, exp);
let dec: ArchiveStorageDiffItem<&str> = serde_json::from_str(exp).unwrap();
assert_eq!(dec, item);
let item = ArchiveStorageDiffItem {
key: "0x1",
return_type: ArchiveStorageDiffType::Value,
child_trie_key: Some("0x2"),
};
let ser = serde_json::to_string(&item).unwrap();
let exp = r#"{"key":"0x1","returnType":"value","childTrieKey":"0x2"}"#;
assert_eq!(ser, exp);
let dec: ArchiveStorageDiffItem<&str> = serde_json::from_str(exp).unwrap();
assert_eq!(dec, item);
let item = ArchiveStorageDiffItem {
key: "0x1",
return_type: ArchiveStorageDiffType::Hash,
child_trie_key: Some("0x2"),
};
let ser = serde_json::to_string(&item).unwrap();
let exp = r#"{"key":"0x1","returnType":"hash","childTrieKey":"0x2"}"#;
assert_eq!(ser, exp);
let dec: ArchiveStorageDiffItem<&str> = serde_json::from_str(exp).unwrap();
assert_eq!(dec, item);
}
#[test]
fn archive_diff_output() {
let item = ArchiveStorageDiffResult {
key: "0x1".into(),
result: StorageResultType::Value("res".into()),
operation_type: ArchiveStorageDiffOperationType::Added,
child_trie_key: None,
};
let ser = serde_json::to_string(&item).unwrap();
let exp = r#"{"key":"0x1","value":"res","type":"added"}"#;
assert_eq!(ser, exp);
let dec: ArchiveStorageDiffResult = serde_json::from_str(exp).unwrap();
assert_eq!(dec, item);
let item = ArchiveStorageDiffResult {
key: "0x1".into(),
result: StorageResultType::Hash("res".into()),
operation_type: ArchiveStorageDiffOperationType::Modified,
child_trie_key: None,
};
let ser = serde_json::to_string(&item).unwrap();
let exp = r#"{"key":"0x1","hash":"res","type":"modified"}"#;
assert_eq!(ser, exp);
let dec: ArchiveStorageDiffResult = serde_json::from_str(exp).unwrap();
assert_eq!(dec, item);
let item = ArchiveStorageDiffResult {
key: "0x1".into(),
result: StorageResultType::Hash("res".into()),
operation_type: ArchiveStorageDiffOperationType::Deleted,
child_trie_key: Some("0x2".into()),
};
let ser = serde_json::to_string(&item).unwrap();
let exp = r#"{"key":"0x1","hash":"res","type":"deleted","childTrieKey":"0x2"}"#;
assert_eq!(ser, exp);
let dec: ArchiveStorageDiffResult = serde_json::from_str(exp).unwrap();
assert_eq!(dec, item);
}
#[test]
fn storage_result() {
let item = StorageResult {
key: "0x1".into(),
result: StorageResultType::Value("res".into()),
child_trie_key: None,
};
let ser = serde_json::to_string(&item).unwrap();
let exp = r#"{"key":"0x1","value":"res"}"#;
assert_eq!(ser, exp);
let dec: StorageResult = serde_json::from_str(exp).unwrap();
assert_eq!(dec, item);
let item = StorageResult {
key: "0x1".into(),
result: StorageResultType::Hash("res".into()),
child_trie_key: None,
};
let ser = serde_json::to_string(&item).unwrap();
let exp = r#"{"key":"0x1","hash":"res"}"#;
assert_eq!(ser, exp);
let dec: StorageResult = serde_json::from_str(exp).unwrap();
assert_eq!(dec, item);
let item = StorageResult {
key: "0x1".into(),
result: StorageResultType::ClosestDescendantMerkleValue("res".into()),
child_trie_key: None,
};
let ser = serde_json::to_string(&item).unwrap();
let exp = r#"{"key":"0x1","closestDescendantMerkleValue":"res"}"#;
assert_eq!(ser, exp);
let dec: StorageResult = serde_json::from_str(exp).unwrap();
assert_eq!(dec, item);
}
#[test]
fn storage_query() {
let item = StorageQuery { key: "0x1", query_type: StorageQueryType::Value };
let ser = serde_json::to_string(&item).unwrap();
let exp = r#"{"key":"0x1","type":"value"}"#;
assert_eq!(ser, exp);
let dec: StorageQuery<&str> = serde_json::from_str(exp).unwrap();
assert_eq!(dec, item);
let item = StorageQuery { key: "0x1", query_type: StorageQueryType::Hash };
let ser = serde_json::to_string(&item).unwrap();
let exp = r#"{"key":"0x1","type":"hash"}"#;
assert_eq!(ser, exp);
let dec: StorageQuery<&str> = serde_json::from_str(exp).unwrap();
assert_eq!(dec, item);
let item = StorageQuery { key: "0x1", query_type: StorageQueryType::DescendantsValues };
let ser = serde_json::to_string(&item).unwrap();
let exp = r#"{"key":"0x1","type":"descendantsValues"}"#;
assert_eq!(ser, exp);
let dec: StorageQuery<&str> = serde_json::from_str(exp).unwrap();
assert_eq!(dec, item);
let item = StorageQuery { key: "0x1", query_type: StorageQueryType::DescendantsHashes };
let ser = serde_json::to_string(&item).unwrap();
let exp = r#"{"key":"0x1","type":"descendantsHashes"}"#;
assert_eq!(ser, exp);
let dec: StorageQuery<&str> = serde_json::from_str(exp).unwrap();
assert_eq!(dec, item);
let item =
StorageQuery { key: "0x1", query_type: StorageQueryType::ClosestDescendantMerkleValue };
let ser = serde_json::to_string(&item).unwrap();
let exp = r#"{"key":"0x1","type":"closestDescendantMerkleValue"}"#;
assert_eq!(ser, exp);
let dec: StorageQuery<&str> = serde_json::from_str(exp).unwrap();
assert_eq!(dec, item);
}
#[test]
fn storage_query_paginated() {
let item = PaginatedStorageQuery {
key: "0x1",
query_type: StorageQueryType::Value,
pagination_start_key: None,
};
let ser = serde_json::to_string(&item).unwrap();
let exp = r#"{"key":"0x1","type":"value"}"#;
assert_eq!(ser, exp);
let dec: StorageQuery<&str> = serde_json::from_str(exp).unwrap();
assert_eq!(dec.key, item.key);
assert_eq!(dec.query_type, item.query_type);
let dec: PaginatedStorageQuery<&str> = serde_json::from_str(exp).unwrap();
assert_eq!(dec, item);
let item = PaginatedStorageQuery {
key: "0x1",
query_type: StorageQueryType::Value,
pagination_start_key: Some("0x2"),
};
let ser = serde_json::to_string(&item).unwrap();
let exp = r#"{"key":"0x1","type":"value","paginationStartKey":"0x2"}"#;
assert_eq!(ser, exp);
let dec: PaginatedStorageQuery<&str> = serde_json::from_str(exp).unwrap();
assert_eq!(dec, item);
}
}