fix serialize for keypair

This commit is contained in:
John Smith 2023-06-29 20:49:15 -04:00
parent 17e4d17984
commit d044f646bf
5 changed files with 29 additions and 4 deletions

View File

@ -1,5 +1,4 @@
mod blake3digest512; mod blake3digest512;
mod byte_array_types;
mod dh_cache; mod dh_cache;
mod envelope; mod envelope;
mod receipt; mod receipt;
@ -13,7 +12,7 @@ pub mod tests;
pub mod vld0; pub mod vld0;
pub use blake3digest512::*; pub use blake3digest512::*;
pub use byte_array_types::*;
pub use crypto_system::*; pub use crypto_system::*;
pub use dh_cache::*; pub use dh_cache::*;
pub use envelope::*; pub use envelope::*;

View File

@ -3,8 +3,7 @@ use super::*;
#[derive( #[derive(
Clone, Clone,
Copy, Copy,
Serialize, Default,
Deserialize,
PartialOrd, PartialOrd,
Ord, Ord,
PartialEq, PartialEq,
@ -87,3 +86,26 @@ impl TryFrom<&str> for KeyPair {
Self::try_decode(value) Self::try_decode(value)
} }
} }
impl serde::Serialize for KeyPair {
fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
where
S: serde::Serializer,
{
let s = self.encode();
serde::Serialize::serialize(&s, serializer)
}
}
impl<'de> serde::Deserialize<'de> for KeyPair {
fn deserialize<D>(deserializer: D) -> Result<Self, D::Error>
where
D: serde::Deserializer<'de>,
{
let s = <String as serde::Deserialize>::deserialize(deserializer)?;
if s == "" {
return Ok(KeyPair::default());
}
KeyPair::try_decode(s.as_str()).map_err(serde::de::Error::custom)
}
}

View File

@ -41,10 +41,12 @@ pub fn common_crypto_kinds(a: &[CryptoKind], b: &[CryptoKind]) -> Vec<CryptoKind
out out
} }
mod byte_array_types;
mod crypto_typed; mod crypto_typed;
mod crypto_typed_group; mod crypto_typed_group;
mod keypair; mod keypair;
pub use byte_array_types::*;
pub use crypto_typed::*; pub use crypto_typed::*;
pub use crypto_typed_group::*; pub use crypto_typed_group::*;
pub use keypair::*; pub use keypair::*;

View File

@ -150,6 +150,8 @@ class _JsonVeilidAPI(VeilidAPI):
# Parse line as ndjson # Parse line as ndjson
j = json.loads(linebytes.strip()) j = json.loads(linebytes.strip())
print(f"linebytes: {linebytes}")
if self.validate_schema: if self.validate_schema:
_schema_validate(_VALIDATOR_RECV_MESSAGE, j) _schema_validate(_VALIDATOR_RECV_MESSAGE, j)