mirror of
https://github.com/serai-dex/serai.git
synced 2025-01-25 20:16:01 +00:00
13977f6287
Encryption used to be inlined into FROST. When writing the documentation, I realized it was decently hard to review. It also was antagonistic to other hosted DKG algorithms by not allowing code re-use. Encryption is now a standalone module, providing clear boundaries and reusability. Additionally, the DKG protocol itself used to use the ciphersuite's specified hash function (with an HKDF to prevent length extension attacks). Now, RecommendedTranscript is used to achieve much more robust transcripting and remove the HKDF dependency. This does add Blake2 into all consumers yet is preferred for its security properties and ease of review.
36 lines
1 KiB
TOML
36 lines
1 KiB
TOML
[package]
|
|
name = "dkg"
|
|
version = "0.2.0"
|
|
description = "Distributed key generation over ff/group"
|
|
license = "MIT"
|
|
repository = "https://github.com/serai-dex/serai/tree/develop/crypto/dkg"
|
|
authors = ["Luke Parker <lukeparker5132@gmail.com>"]
|
|
keywords = ["dkg", "multisig", "threshold", "ff", "group"]
|
|
edition = "2021"
|
|
|
|
[package.metadata.docs.rs]
|
|
all-features = true
|
|
rustdoc-args = ["--cfg", "docsrs"]
|
|
|
|
[dependencies]
|
|
thiserror = "1"
|
|
|
|
rand_core = "0.6"
|
|
|
|
zeroize = { version = "1.5", features = ["zeroize_derive"] }
|
|
subtle = "2"
|
|
|
|
hex = "0.4"
|
|
|
|
transcript = { package = "flexible-transcript", path = "../transcript", version = "0.2", features = ["recommended"] }
|
|
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"] }
|
|
|
|
schnorr = { package = "schnorr-signatures", path = "../schnorr", version = "0.2" }
|
|
dleq = { path = "../dleq", version = "0.2", features = ["serialize"] }
|
|
|
|
[features]
|
|
tests = []
|