use serde in trusted-dealer
This commit is contained in:
parent
af1d45980e
commit
760c3fc8df
|
@ -1045,6 +1045,7 @@ dependencies = [
|
||||||
"hex",
|
"hex",
|
||||||
"itertools 0.11.0",
|
"itertools 0.11.0",
|
||||||
"rand",
|
"rand",
|
||||||
|
"serde_json",
|
||||||
"thiserror",
|
"thiserror",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
|
|
@ -12,3 +12,5 @@ rand = "0.8"
|
||||||
hex = "0.4"
|
hex = "0.4"
|
||||||
itertools = "0.11.0"
|
itertools = "0.11.0"
|
||||||
exitcode = "1.1.2"
|
exitcode = "1.1.2"
|
||||||
|
serde_json = "1.0"
|
||||||
|
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
use frost::keys::{PublicKeyPackage, SecretShare, VerifiableSecretSharingCommitment};
|
use frost::keys::{PublicKeyPackage, SecretShare};
|
||||||
use frost::Identifier;
|
use frost::Identifier;
|
||||||
use frost_ed25519 as frost;
|
use frost_ed25519 as frost;
|
||||||
use itertools::Itertools;
|
use itertools::Itertools;
|
||||||
|
@ -8,17 +8,6 @@ pub trait Logger {
|
||||||
fn log(&mut self, value: String);
|
fn log(&mut self, value: String);
|
||||||
}
|
}
|
||||||
|
|
||||||
fn encode_commitment(vss_commitment: &VerifiableSecretSharingCommitment) -> String {
|
|
||||||
let serialized = vss_commitment.serialize();
|
|
||||||
let num = serialized.len();
|
|
||||||
|
|
||||||
let mut out = hex::encode([num as u8]);
|
|
||||||
for cc in serialized {
|
|
||||||
out = out + &hex::encode(cc)
|
|
||||||
}
|
|
||||||
out
|
|
||||||
}
|
|
||||||
|
|
||||||
fn get_identifier_value(i: Identifier) -> String {
|
fn get_identifier_value(i: Identifier) -> String {
|
||||||
let s = i.serialize();
|
let s = i.serialize();
|
||||||
let le_bytes: [u8; 2] = [s[0], s[1]];
|
let le_bytes: [u8; 2] = [s[0], s[1]];
|
||||||
|
@ -31,8 +20,8 @@ pub fn print_values(
|
||||||
logger: &mut dyn Logger,
|
logger: &mut dyn Logger,
|
||||||
) {
|
) {
|
||||||
logger.log(format!(
|
logger.log(format!(
|
||||||
"Group public key: {}",
|
"Public key package:\n{}",
|
||||||
hex::encode(pubkeys.group_public().serialize())
|
serde_json::to_string(pubkeys).unwrap()
|
||||||
));
|
));
|
||||||
|
|
||||||
println!("---");
|
println!("---");
|
||||||
|
@ -40,16 +29,8 @@ pub fn print_values(
|
||||||
for (k, v) in keys.iter().sorted_by_key(|x| x.0) {
|
for (k, v) in keys.iter().sorted_by_key(|x| x.0) {
|
||||||
logger.log(format!("Participant: {}", get_identifier_value(*k)));
|
logger.log(format!("Participant: {}", get_identifier_value(*k)));
|
||||||
logger.log(format!(
|
logger.log(format!(
|
||||||
"Secret share: {}",
|
"Secret share:\n{}",
|
||||||
hex::encode(v.value().serialize())
|
serde_json::to_string(v).unwrap()
|
||||||
));
|
|
||||||
logger.log(format!(
|
|
||||||
"Public key: {}",
|
|
||||||
hex::encode(pubkeys.signer_pubkeys()[k].serialize())
|
|
||||||
));
|
|
||||||
logger.log(format!(
|
|
||||||
"Your verifiable secret sharing commitment: {}",
|
|
||||||
encode_commitment(v.commitment())
|
|
||||||
));
|
));
|
||||||
println!("---")
|
println!("---")
|
||||||
}
|
}
|
||||||
|
@ -57,29 +38,9 @@ pub fn print_values(
|
||||||
|
|
||||||
#[cfg(test)]
|
#[cfg(test)]
|
||||||
mod tests {
|
mod tests {
|
||||||
use crate::output::{encode_commitment, get_identifier_value};
|
use crate::output::get_identifier_value;
|
||||||
use frost::{keys::VerifiableSecretSharingCommitment, Identifier};
|
use frost::Identifier;
|
||||||
use frost_ed25519 as frost;
|
use frost_ed25519 as frost;
|
||||||
use hex::FromHex;
|
|
||||||
|
|
||||||
#[test]
|
|
||||||
fn check_encode_commitment() {
|
|
||||||
let coeff_comm_1 = "538d43e67bc9c22a3befdf24e68f29bfc9bcbd844736e5b82fdab1545bceddcf";
|
|
||||||
let coeff_comm_2 = "6bc2053a2bedc6a071c74495965c960a6d2655720edba2a5aa68b8e160c9f55d";
|
|
||||||
let coeff_comm_3 = "eb73cfae619afa59984754e5f3e93ba2357164ce113b09e542365d8313d6f091";
|
|
||||||
|
|
||||||
let expected = "03".to_string() + coeff_comm_1 + coeff_comm_2 + coeff_comm_3;
|
|
||||||
|
|
||||||
let decoded_1 = <[u8; 32]>::from_hex(coeff_comm_1).unwrap();
|
|
||||||
let decoded_2 = <[u8; 32]>::from_hex(coeff_comm_2).unwrap();
|
|
||||||
let decoded_3 = <[u8; 32]>::from_hex(coeff_comm_3).unwrap();
|
|
||||||
|
|
||||||
let vss_commitment =
|
|
||||||
VerifiableSecretSharingCommitment::deserialize(vec![decoded_1, decoded_2, decoded_3])
|
|
||||||
.unwrap();
|
|
||||||
let commitment = encode_commitment(&vss_commitment);
|
|
||||||
assert!(commitment == expected)
|
|
||||||
}
|
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn check_get_identifier_value() {
|
fn check_get_identifier_value() {
|
||||||
|
|
Loading…
Reference in New Issue