Go to file
dependabot[bot] f2d086661d
Bump thiserror from 1.0.55 to 1.0.56 (#114)
Bumps [thiserror](https://github.com/dtolnay/thiserror) from 1.0.55 to 1.0.56.
- [Release notes](https://github.com/dtolnay/thiserror/releases)
- [Commits](https://github.com/dtolnay/thiserror/compare/1.0.55...1.0.56)

---
updated-dependencies:
- dependency-name: thiserror
  dependency-type: direct:production
  update-type: version-update:semver-patch
...

Signed-off-by: dependabot[bot] <support@github.com>
Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
2024-01-16 20:43:29 +00:00
.github Bump reviewdog/action-actionlint from 1.39.1 to 1.40.0 (#102) 2024-01-11 17:02:58 -03:00
coordinator Bump clap from 4.4.14 to 4.4.17 (#117) 2024-01-16 17:53:53 +00:00
dkg update reddsa and remove manual into_positive_y() invocations (#104) 2024-01-05 16:40:32 +00:00
participant update reddsa and remove manual into_positive_y() invocations (#104) 2024-01-05 16:40:32 +00:00
tests update reddsa and remove manual into_positive_y() invocations (#104) 2024-01-05 16:40:32 +00:00
trusted-dealer update reddsa and remove manual into_positive_y() invocations (#104) 2024-01-05 16:40:32 +00:00
.gitignore Add Participant project (#15) 2023-06-15 13:23:37 -03:00
Cargo.lock Bump thiserror from 1.0.55 to 1.0.56 (#114) 2024-01-16 20:43:29 +00:00
Cargo.toml point to main reddsa 2023-10-06 11:57:25 -03:00
LICENSE-APACHE Print group public key (#283) 2023-04-17 11:01:27 +01:00
LICENSE-MIT Validate inputs (#283) 2023-04-11 13:56:23 +01:00
Makefile.toml Improve consistency of testing across projects (#76) 2023-09-27 13:27:01 -03:00
README.md Update READMEs (#54) (#71) 2023-08-21 19:01:16 -03:00
codecov.yml Add config for CI pipeline and code coverage 2023-04-25 13:30:31 +01:00
rust-toolchain.toml add rust-toolchain.toml (#103) 2024-01-16 17:10:37 +00:00

README.md

Zcash Foundation FROST Demos

This will be part of a set of demos and a proof of concept application that uses the FROST libraries and reference implementation. The purpose of these demos is to:

  1. identify gaps in our documentation
  2. provide usage examples for developer facing documentation
  3. provide reference implementations for developers wanting to use FROST in a “real world” scenario.

This demo uses the (Ed25519, SHA-512) ciphersuite. The crate can be found here.

About FROST (Flexible Round-Optimised Schnorr Threshold signatures)

Unlike signatures in a single-party setting, threshold signatures require cooperation among a threshold number of signers, each holding a share of a common private key. The security of threshold schemes in general assume that an adversary can corrupt strictly fewer than a threshold number of participants.

Two-Round Threshold Schnorr Signatures with FROST presents a variant of a Flexible Round-Optimized Schnorr Threshold (FROST) signature scheme originally defined in FROST20. FROST reduces network overhead during threshold signing operations while employing a novel technique to protect against forgery attacks applicable to prior Schnorr-based threshold signature constructions. This variant of FROST requires two rounds to compute a signature, and implements signing efficiency improvements described by Schnorr21. Single-round signing with FROST is not implemented here.

Projects

This repo contains 4 projects:

  1. Trusted Dealer
  2. DKG
  3. Coordinator
  4. Participant

Status ⚠

Trusted Dealer demo - WIP DKG demo - WIP Coordinator demo - WIP Participant demo - WIP

Usage

NOTE: This is for demo purposes only and should not be used in production.

You will need to have Rust and Cargo installed.

To run:

  1. Clone the repo. Run git clone https://github.com/ZcashFoundation/frost-zcash-demo.git
  2. Run cargo install

and in separate terminals: 3. Run cargo run --bin trusted-dealer or cargo run --bin dkg 4. Run cargo run --bin coordinator 5. Run cargo run --bin participants. Do this in separate terminals for separate participants.

Developer Information

Pre-commit checks

  1. Run cargo make all

Coverage

Test coverage checks are performed in the pipeline. This is configured here: .github/workflows/coverage.yaml To run these locally:

  1. Install coverage tool by running cargo install cargo-llvm-cov
  2. Run cargo make cov (you may be asked if you want to install llvm-tools-preview, if so type Y)