mirror of
https://github.com/serai-dex/serai.git
synced 2025-01-20 17:54:38 +00:00
a25e6330bd
1) Removes the key image DLEq on the Monero side of things, as the produced signature share serves as a DLEq for it. 2) Removes the nonce DLEqs from modular-frost as they're unnecessary for monero-serai. Updates documentation accordingly. Without the proof the nonces are internally consistent, the produced signatures from modular-frost can be argued as a batch-verifiable CP93 DLEq (R0, R1, s), or as a GSP for the CP93 DLEq statement (which naturally produces (R0, R1, s)). The lack of proving the nonces consistent does make the process weaker, yet it's also unnecessary for the class of protocols this is intended to service. To provide DLEqs for the nonces would be to provide PoKs for the nonce commitments (in the traditional Schnorr case).
59 lines
2.2 KiB
TOML
59 lines
2.2 KiB
TOML
[package]
|
|
name = "modular-frost"
|
|
version = "0.8.1"
|
|
description = "Modular implementation of FROST over ff/group"
|
|
license = "MIT"
|
|
repository = "https://github.com/serai-dex/serai/tree/develop/crypto/frost"
|
|
authors = ["Luke Parker <lukeparker5132@gmail.com>"]
|
|
keywords = ["frost", "multisig", "threshold"]
|
|
edition = "2021"
|
|
rust-version = "1.74"
|
|
|
|
[package.metadata.docs.rs]
|
|
all-features = true
|
|
rustdoc-args = ["--cfg", "docsrs"]
|
|
|
|
[lints]
|
|
workspace = true
|
|
|
|
[dependencies]
|
|
thiserror = "1"
|
|
|
|
rand_core = { version = "0.6", default-features = false, features = ["std"] }
|
|
rand_chacha = { version = "0.3", default-features = false, features = ["std"] }
|
|
|
|
zeroize = { version = "^1.5", default-features = false, features = ["std", "zeroize_derive"] }
|
|
subtle = { version = "^2.4", default-features = false, features = ["std"] }
|
|
|
|
hex = { version = "0.4", default-features = false, features = ["std"], optional = true }
|
|
|
|
digest = { version = "0.10", default-features = false, features = ["std"] }
|
|
transcript = { package = "flexible-transcript", path = "../transcript", version = "^0.3.2", default-features = false, features = ["std", "recommended"] }
|
|
|
|
dalek-ff-group = { path = "../dalek-ff-group", version = "0.4", default-features = false, features = ["std"], optional = true }
|
|
minimal-ed448 = { path = "../ed448", version = "0.4", default-features = false, features = ["std"], optional = true }
|
|
|
|
ciphersuite = { path = "../ciphersuite", version = "^0.4.1", default-features = false, features = ["std"] }
|
|
|
|
multiexp = { path = "../multiexp", version = "0.4", default-features = false, features = ["std", "batch"] }
|
|
|
|
schnorr = { package = "schnorr-signatures", path = "../schnorr", version = "^0.5.1", default-features = false, features = ["std"] }
|
|
|
|
dkg = { path = "../dkg", version = "^0.5.1", default-features = false, features = ["std"] }
|
|
|
|
[dev-dependencies]
|
|
hex = "0.4"
|
|
serde_json = { version = "1", default-features = false, features = ["std"] }
|
|
|
|
dkg = { path = "../dkg", features = ["tests"] }
|
|
|
|
[features]
|
|
ed25519 = ["dalek-ff-group", "ciphersuite/ed25519"]
|
|
ristretto = ["dalek-ff-group", "ciphersuite/ristretto"]
|
|
|
|
secp256k1 = ["ciphersuite/secp256k1"]
|
|
p256 = ["ciphersuite/p256"]
|
|
|
|
ed448 = ["minimal-ed448", "ciphersuite/ed448"]
|
|
|
|
tests = ["hex", "rand_core/getrandom", "dkg/tests"]
|