Skip to content

Commit

Permalink
Add Bulletproof rewind functionality
Browse files Browse the repository at this point in the history
This is closely modelled on Grin's soliution, but using two private keys:
- Interfaces:
  - create a rewindable ZK proof with up to 23 bytes additional embedded proof
    data
  - extract the value and 23 bytes proof data only
  - extract the value, blinding factor and 23 bytes proof data
- Required:
  - two rewind nonces, based on a two public rewind keys and the value
    commitment
  - two blinding nonces, based on the two private rewind keys and the value
    commitment
- Use:
  - the two rewind nonces are used to extract the value and 23 bytes embedded
    proof data
  - the two rewind nonces and two blinding nonces are used to extract the
    value, blinding factor and 23 bytes embedded proof data
  • Loading branch information
hansieodendaal committed Nov 30, 2020
1 parent 464acb7 commit 72d89cf
Show file tree
Hide file tree
Showing 6 changed files with 866 additions and 13 deletions.
12 changes: 12 additions & 0 deletions src/errors.rs
Original file line number Diff line number Diff line change
Expand Up @@ -45,6 +45,18 @@ pub enum ProofError {
/// consider its errors to be internal errors.
#[cfg_attr(feature = "std", error("Internal error during proof creation: {0}"))]
ProvingError(MPCError),
/// This error results from trying to rewind a proof with the wrong rewind nonce
#[cfg_attr(
feature = "std",
error("Rewinding the proof failed, invalid commitment extracted")
)]
InvalidCommitmentExtracted,
/// This error results from trying to rewind a proof with an invalid rewind key separator
#[cfg_attr(
feature = "std",
error("Trying to rewind a proof with the wrong rewind key separator")
)]
InvalidRewindKeySeparator,
}

impl From<MPCError> for ProofError {
Expand Down
3 changes: 2 additions & 1 deletion src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,8 @@ mod notes {
mod errors;
mod generators;
mod inner_product_proof;
mod range_proof;
// TODO: Do not expose `range_proof` publicly
pub mod range_proof;
mod transcript;

pub use crate::errors::ProofError;
Expand Down
Loading

0 comments on commit 72d89cf

Please sign in to comment.