mirror of
https://github.com/serai-dex/serai.git
synced 2025-01-10 21:04:40 +00:00
Have Ciphersuite re-export Group
This commit is contained in:
parent
af5702fccd
commit
e08adcc1ac
22 changed files with 54 additions and 65 deletions
3
Cargo.lock
generated
3
Cargo.lock
generated
|
@ -1695,7 +1695,6 @@ dependencies = [
|
||||||
"ciphersuite",
|
"ciphersuite",
|
||||||
"dleq",
|
"dleq",
|
||||||
"flexible-transcript",
|
"flexible-transcript",
|
||||||
"group",
|
|
||||||
"multiexp",
|
"multiexp",
|
||||||
"rand_core 0.6.4",
|
"rand_core 0.6.4",
|
||||||
"schnorr-signatures",
|
"schnorr-signatures",
|
||||||
|
@ -4675,7 +4674,6 @@ dependencies = [
|
||||||
"dkg",
|
"dkg",
|
||||||
"dleq",
|
"dleq",
|
||||||
"flexible-transcript",
|
"flexible-transcript",
|
||||||
"group",
|
|
||||||
"hex",
|
"hex",
|
||||||
"minimal-ed448",
|
"minimal-ed448",
|
||||||
"multiexp",
|
"multiexp",
|
||||||
|
@ -7521,7 +7519,6 @@ dependencies = [
|
||||||
"ciphersuite",
|
"ciphersuite",
|
||||||
"dalek-ff-group",
|
"dalek-ff-group",
|
||||||
"flexible-transcript",
|
"flexible-transcript",
|
||||||
"group",
|
|
||||||
"hex",
|
"hex",
|
||||||
"multiexp",
|
"multiexp",
|
||||||
"rand_core 0.6.4",
|
"rand_core 0.6.4",
|
||||||
|
|
|
@ -14,6 +14,7 @@ use subtle::ConstantTimeEq;
|
||||||
use digest::{core_api::BlockSizeUser, Digest, HashMarker};
|
use digest::{core_api::BlockSizeUser, Digest, HashMarker};
|
||||||
use transcript::SecureDigest;
|
use transcript::SecureDigest;
|
||||||
|
|
||||||
|
pub use group;
|
||||||
use group::{
|
use group::{
|
||||||
ff::{Field, PrimeField, PrimeFieldBits},
|
ff::{Field, PrimeField, PrimeFieldBits},
|
||||||
Group, GroupOps,
|
Group, GroupOps,
|
||||||
|
|
|
@ -24,9 +24,8 @@ serde = { version = "1", features = ["derive"], optional = true }
|
||||||
transcript = { package = "flexible-transcript", path = "../transcript", version = "0.2", features = ["recommended"] }
|
transcript = { package = "flexible-transcript", path = "../transcript", version = "0.2", features = ["recommended"] }
|
||||||
chacha20 = { version = "0.9", features = ["zeroize"] }
|
chacha20 = { version = "0.9", features = ["zeroize"] }
|
||||||
|
|
||||||
group = "0.12"
|
|
||||||
multiexp = { path = "../multiexp", version = "0.2", features = ["batch"] }
|
|
||||||
ciphersuite = { path = "../ciphersuite", version = "0.1", features = ["std"] }
|
ciphersuite = { path = "../ciphersuite", version = "0.1", features = ["std"] }
|
||||||
|
multiexp = { path = "../multiexp", version = "0.2", features = ["batch"] }
|
||||||
|
|
||||||
schnorr = { package = "schnorr-signatures", path = "../schnorr", version = "0.2" }
|
schnorr = { package = "schnorr-signatures", path = "../schnorr", version = "0.2" }
|
||||||
dleq = { path = "../dleq", version = "0.2", features = ["serialize"] }
|
dleq = { path = "../dleq", version = "0.2", features = ["serialize"] }
|
||||||
|
|
|
@ -17,9 +17,8 @@ use chacha20::{
|
||||||
use transcript::{Transcript, RecommendedTranscript};
|
use transcript::{Transcript, RecommendedTranscript};
|
||||||
|
|
||||||
#[cfg(test)]
|
#[cfg(test)]
|
||||||
use group::ff::Field;
|
use ciphersuite::group::ff::Field;
|
||||||
use group::GroupEncoding;
|
use ciphersuite::{group::GroupEncoding, Ciphersuite};
|
||||||
use ciphersuite::Ciphersuite;
|
|
||||||
use multiexp::BatchVerifier;
|
use multiexp::BatchVerifier;
|
||||||
|
|
||||||
use schnorr::SchnorrSignature;
|
use schnorr::SchnorrSignature;
|
||||||
|
@ -222,7 +221,7 @@ impl<C: Ciphersuite, E: Encryptable> EncryptedMessage<C, E> {
|
||||||
from: Participant,
|
from: Participant,
|
||||||
to: C::G,
|
to: C::G,
|
||||||
) {
|
) {
|
||||||
use group::ff::PrimeField;
|
use ciphersuite::group::ff::PrimeField;
|
||||||
|
|
||||||
let mut repr = <C::F as PrimeField>::Repr::default();
|
let mut repr = <C::F as PrimeField>::Repr::default();
|
||||||
for b in repr.as_mut().iter_mut() {
|
for b in repr.as_mut().iter_mut() {
|
||||||
|
@ -246,7 +245,7 @@ impl<C: Ciphersuite, E: Encryptable> EncryptedMessage<C, E> {
|
||||||
from: Participant,
|
from: Participant,
|
||||||
to: C::G,
|
to: C::G,
|
||||||
) {
|
) {
|
||||||
use group::ff::PrimeField;
|
use ciphersuite::group::ff::PrimeField;
|
||||||
|
|
||||||
// Assumes the share isn't randomly 1
|
// Assumes the share isn't randomly 1
|
||||||
let repr = C::F::one().to_repr();
|
let repr = C::F::one().to_repr();
|
||||||
|
|
|
@ -10,11 +10,13 @@ use zeroize::{Zeroize, ZeroizeOnDrop, Zeroizing};
|
||||||
|
|
||||||
use transcript::{Transcript, RecommendedTranscript};
|
use transcript::{Transcript, RecommendedTranscript};
|
||||||
|
|
||||||
use group::{
|
use ciphersuite::{
|
||||||
|
group::{
|
||||||
ff::{Field, PrimeField},
|
ff::{Field, PrimeField},
|
||||||
Group, GroupEncoding,
|
Group, GroupEncoding,
|
||||||
|
},
|
||||||
|
Ciphersuite,
|
||||||
};
|
};
|
||||||
use ciphersuite::Ciphersuite;
|
|
||||||
use multiexp::{multiexp_vartime, BatchVerifier};
|
use multiexp::{multiexp_vartime, BatchVerifier};
|
||||||
|
|
||||||
use schnorr::SchnorrSignature;
|
use schnorr::SchnorrSignature;
|
||||||
|
|
|
@ -16,13 +16,14 @@ use thiserror::Error;
|
||||||
|
|
||||||
use zeroize::{Zeroize, Zeroizing};
|
use zeroize::{Zeroize, Zeroizing};
|
||||||
|
|
||||||
use group::{
|
use ciphersuite::{
|
||||||
|
group::{
|
||||||
ff::{Field, PrimeField},
|
ff::{Field, PrimeField},
|
||||||
GroupEncoding,
|
GroupEncoding,
|
||||||
|
},
|
||||||
|
Ciphersuite,
|
||||||
};
|
};
|
||||||
|
|
||||||
use ciphersuite::Ciphersuite;
|
|
||||||
|
|
||||||
/// Encryption types and utilities used to secure DKG messages.
|
/// Encryption types and utilities used to secure DKG messages.
|
||||||
pub mod encryption;
|
pub mod encryption;
|
||||||
|
|
||||||
|
|
|
@ -7,9 +7,7 @@ use std::{
|
||||||
|
|
||||||
use rand_core::{RngCore, CryptoRng};
|
use rand_core::{RngCore, CryptoRng};
|
||||||
|
|
||||||
use group::GroupEncoding;
|
use ciphersuite::{group::GroupEncoding, Ciphersuite};
|
||||||
|
|
||||||
use ciphersuite::Ciphersuite;
|
|
||||||
|
|
||||||
use transcript::{Transcript, RecommendedTranscript};
|
use transcript::{Transcript, RecommendedTranscript};
|
||||||
use dleq::DLEqProof;
|
use dleq::DLEqProof;
|
||||||
|
|
|
@ -3,9 +3,7 @@ use std::collections::HashMap;
|
||||||
|
|
||||||
use rand_core::{RngCore, CryptoRng};
|
use rand_core::{RngCore, CryptoRng};
|
||||||
|
|
||||||
use group::ff::Field;
|
use ciphersuite::{group::ff::Field, Ciphersuite};
|
||||||
|
|
||||||
use ciphersuite::Ciphersuite;
|
|
||||||
|
|
||||||
use crate::{Participant, ThresholdCore, ThresholdKeys, lagrange};
|
use crate::{Participant, ThresholdCore, ThresholdKeys, lagrange};
|
||||||
|
|
||||||
|
|
|
@ -5,9 +5,7 @@ use rand_core::{RngCore, CryptoRng};
|
||||||
|
|
||||||
use zeroize::Zeroize;
|
use zeroize::Zeroize;
|
||||||
|
|
||||||
use group::Group;
|
use ciphersuite::{group::Group, Ciphersuite};
|
||||||
|
|
||||||
use ciphersuite::Ciphersuite;
|
|
||||||
|
|
||||||
use crate::{
|
use crate::{
|
||||||
promote::{GeneratorPromotion, GeneratorProof},
|
promote::{GeneratorPromotion, GeneratorProof},
|
||||||
|
|
|
@ -26,12 +26,11 @@ hex = { version = "0.4", optional = true }
|
||||||
digest = "0.10"
|
digest = "0.10"
|
||||||
transcript = { package = "flexible-transcript", path = "../transcript", version = "0.2", features = ["recommended"] }
|
transcript = { package = "flexible-transcript", path = "../transcript", version = "0.2", features = ["recommended"] }
|
||||||
|
|
||||||
group = "0.12"
|
|
||||||
ciphersuite = { path = "../ciphersuite", version = "0.1", features = ["std"] }
|
|
||||||
|
|
||||||
dalek-ff-group = { path = "../dalek-ff-group", version = "^0.1.2", optional = true }
|
dalek-ff-group = { path = "../dalek-ff-group", version = "^0.1.2", optional = true }
|
||||||
minimal-ed448 = { path = "../ed448", version = "^0.1.2", optional = true }
|
minimal-ed448 = { path = "../ed448", version = "^0.1.2", optional = true }
|
||||||
|
|
||||||
|
ciphersuite = { path = "../ciphersuite", version = "0.1", features = ["std"] }
|
||||||
|
|
||||||
multiexp = { path = "../multiexp", version = "0.2", features = ["batch"] }
|
multiexp = { path = "../multiexp", version = "0.2", features = ["batch"] }
|
||||||
|
|
||||||
schnorr = { package = "schnorr-signatures", path = "../schnorr", version = "0.2" }
|
schnorr = { package = "schnorr-signatures", path = "../schnorr", version = "0.2" }
|
||||||
|
|
|
@ -1,10 +1,7 @@
|
||||||
use digest::Digest;
|
use digest::Digest;
|
||||||
|
|
||||||
use group::GroupEncoding;
|
|
||||||
|
|
||||||
use minimal_ed448::{Scalar, Point};
|
use minimal_ed448::{Scalar, Point};
|
||||||
|
pub use ciphersuite::{group::GroupEncoding, Shake256_114, Ed448};
|
||||||
pub use ciphersuite::{Shake256_114, Ed448};
|
|
||||||
|
|
||||||
use crate::{curve::Curve, algorithm::Hram};
|
use crate::{curve::Curve, algorithm::Hram};
|
||||||
|
|
||||||
|
|
|
@ -1,6 +1,4 @@
|
||||||
use group::GroupEncoding;
|
use ciphersuite::{group::GroupEncoding, Ciphersuite};
|
||||||
|
|
||||||
use ciphersuite::Ciphersuite;
|
|
||||||
|
|
||||||
use crate::{curve::Curve, algorithm::Hram};
|
use crate::{curve::Curve, algorithm::Hram};
|
||||||
|
|
||||||
|
|
|
@ -8,13 +8,14 @@ use subtle::ConstantTimeEq;
|
||||||
|
|
||||||
use digest::{Digest, Output};
|
use digest::{Digest, Output};
|
||||||
|
|
||||||
use group::{
|
pub use ciphersuite::{
|
||||||
|
group::{
|
||||||
ff::{Field, PrimeField},
|
ff::{Field, PrimeField},
|
||||||
Group,
|
Group,
|
||||||
|
},
|
||||||
|
Ciphersuite,
|
||||||
};
|
};
|
||||||
|
|
||||||
pub use ciphersuite::Ciphersuite;
|
|
||||||
|
|
||||||
#[cfg(any(feature = "ristretto", feature = "ed25519"))]
|
#[cfg(any(feature = "ristretto", feature = "ed25519"))]
|
||||||
mod dalek;
|
mod dalek;
|
||||||
#[cfg(feature = "ristretto")]
|
#[cfg(feature = "ristretto")]
|
||||||
|
|
|
@ -21,7 +21,7 @@ use zeroize::{Zeroize, Zeroizing};
|
||||||
|
|
||||||
use transcript::Transcript;
|
use transcript::Transcript;
|
||||||
|
|
||||||
use group::{ff::PrimeField, Group, GroupEncoding};
|
use ciphersuite::group::{ff::PrimeField, Group, GroupEncoding};
|
||||||
use multiexp::multiexp_vartime;
|
use multiexp::multiexp_vartime;
|
||||||
|
|
||||||
use dleq::MultiDLEqProof;
|
use dleq::MultiDLEqProof;
|
||||||
|
|
|
@ -11,7 +11,7 @@ use zeroize::{Zeroize, Zeroizing};
|
||||||
|
|
||||||
use transcript::Transcript;
|
use transcript::Transcript;
|
||||||
|
|
||||||
use group::{ff::PrimeField, GroupEncoding};
|
use ciphersuite::group::{ff::PrimeField, GroupEncoding};
|
||||||
use multiexp::BatchVerifier;
|
use multiexp::BatchVerifier;
|
||||||
|
|
||||||
use crate::{
|
use crate::{
|
||||||
|
@ -195,7 +195,7 @@ impl<C: Curve> Writable for SignatureShare<C> {
|
||||||
#[cfg(any(test, feature = "tests"))]
|
#[cfg(any(test, feature = "tests"))]
|
||||||
impl<C: Curve> SignatureShare<C> {
|
impl<C: Curve> SignatureShare<C> {
|
||||||
pub(crate) fn invalidate(&mut self) {
|
pub(crate) fn invalidate(&mut self) {
|
||||||
use group::ff::Field;
|
use ciphersuite::group::ff::Field;
|
||||||
|
|
||||||
self.0 += C::F::one();
|
self.0 += C::F::one();
|
||||||
}
|
}
|
||||||
|
|
|
@ -7,7 +7,7 @@ use rand_chacha::ChaCha20Rng;
|
||||||
|
|
||||||
use transcript::{Transcript, RecommendedTranscript};
|
use transcript::{Transcript, RecommendedTranscript};
|
||||||
|
|
||||||
use group::{ff::Field, Group, GroupEncoding};
|
use ciphersuite::group::{ff::Field, Group, GroupEncoding};
|
||||||
|
|
||||||
use dleq::MultiDLEqProof;
|
use dleq::MultiDLEqProof;
|
||||||
pub use dkg::tests::{key_gen, recover_key};
|
pub use dkg::tests::{key_gen, recover_key};
|
||||||
|
|
|
@ -9,7 +9,7 @@ use zeroize::Zeroizing;
|
||||||
use rand_core::{RngCore, CryptoRng, SeedableRng};
|
use rand_core::{RngCore, CryptoRng, SeedableRng};
|
||||||
use rand_chacha::ChaCha20Rng;
|
use rand_chacha::ChaCha20Rng;
|
||||||
|
|
||||||
use group::{ff::PrimeField, GroupEncoding};
|
use ciphersuite::group::{ff::PrimeField, GroupEncoding};
|
||||||
|
|
||||||
use crate::{
|
use crate::{
|
||||||
curve::Curve,
|
curve::Curve,
|
||||||
|
|
|
@ -19,9 +19,8 @@ zeroize = { version = "^1.5", features = ["zeroize_derive"] }
|
||||||
|
|
||||||
transcript = { package = "flexible-transcript", path = "../transcript", version = "0.2" }
|
transcript = { package = "flexible-transcript", path = "../transcript", version = "0.2" }
|
||||||
|
|
||||||
group = "0.12"
|
|
||||||
multiexp = { path = "../multiexp", version = "0.2", features = ["batch"] }
|
|
||||||
ciphersuite = { path = "../ciphersuite", version = "0.1" }
|
ciphersuite = { path = "../ciphersuite", version = "0.1" }
|
||||||
|
multiexp = { path = "../multiexp", version = "0.2", features = ["batch"] }
|
||||||
|
|
||||||
[dev-dependencies]
|
[dev-dependencies]
|
||||||
hex = "0.4"
|
hex = "0.4"
|
||||||
|
|
|
@ -4,12 +4,14 @@ use zeroize::Zeroize;
|
||||||
|
|
||||||
use transcript::{Transcript, SecureDigest, DigestTranscript};
|
use transcript::{Transcript, SecureDigest, DigestTranscript};
|
||||||
|
|
||||||
use group::{
|
use ciphersuite::{
|
||||||
|
group::{
|
||||||
ff::{Field, PrimeField},
|
ff::{Field, PrimeField},
|
||||||
Group, GroupEncoding,
|
Group, GroupEncoding,
|
||||||
|
},
|
||||||
|
Ciphersuite,
|
||||||
};
|
};
|
||||||
use multiexp::multiexp_vartime;
|
use multiexp::multiexp_vartime;
|
||||||
use ciphersuite::Ciphersuite;
|
|
||||||
|
|
||||||
use crate::SchnorrSignature;
|
use crate::SchnorrSignature;
|
||||||
|
|
||||||
|
|
|
@ -5,15 +5,15 @@ use rand_core::{RngCore, CryptoRng};
|
||||||
|
|
||||||
use zeroize::{Zeroize, Zeroizing};
|
use zeroize::{Zeroize, Zeroizing};
|
||||||
|
|
||||||
use group::{
|
use ciphersuite::{
|
||||||
|
group::{
|
||||||
ff::{Field, PrimeField},
|
ff::{Field, PrimeField},
|
||||||
Group, GroupEncoding,
|
Group, GroupEncoding,
|
||||||
|
},
|
||||||
|
Ciphersuite,
|
||||||
};
|
};
|
||||||
|
|
||||||
use multiexp::{multiexp_vartime, BatchVerifier};
|
use multiexp::{multiexp_vartime, BatchVerifier};
|
||||||
|
|
||||||
use ciphersuite::Ciphersuite;
|
|
||||||
|
|
||||||
pub mod aggregate;
|
pub mod aggregate;
|
||||||
|
|
||||||
#[cfg(test)]
|
#[cfg(test)]
|
||||||
|
|
|
@ -3,11 +3,12 @@ use core::ops::Deref;
|
||||||
use zeroize::Zeroizing;
|
use zeroize::Zeroizing;
|
||||||
use rand_core::OsRng;
|
use rand_core::OsRng;
|
||||||
|
|
||||||
use group::{ff::Field, Group};
|
use ciphersuite::{
|
||||||
|
group::{ff::Field, Group},
|
||||||
|
Ciphersuite, Ed25519,
|
||||||
|
};
|
||||||
use multiexp::BatchVerifier;
|
use multiexp::BatchVerifier;
|
||||||
|
|
||||||
use ciphersuite::{Ciphersuite, Ed25519};
|
|
||||||
|
|
||||||
use crate::{
|
use crate::{
|
||||||
SchnorrSignature,
|
SchnorrSignature,
|
||||||
aggregate::{SchnorrAggregator, SchnorrAggregate},
|
aggregate::{SchnorrAggregator, SchnorrAggregate},
|
||||||
|
|
|
@ -5,9 +5,8 @@
|
||||||
|
|
||||||
use sha2::{Digest, Sha512};
|
use sha2::{Digest, Sha512};
|
||||||
|
|
||||||
use group::GroupEncoding;
|
|
||||||
use dalek_ff_group::Scalar;
|
use dalek_ff_group::Scalar;
|
||||||
use ciphersuite::{Ciphersuite, Ed25519};
|
use ciphersuite::{group::GroupEncoding, Ciphersuite, Ed25519};
|
||||||
|
|
||||||
use crate::SchnorrSignature;
|
use crate::SchnorrSignature;
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue