Skip to content

Commit

Permalink
Add ValueCommitTrapdoor::to_bytes
Browse files Browse the repository at this point in the history
This is necessary to encode `bsk` into a PCZT.
  • Loading branch information
str4d committed Nov 19, 2024
1 parent 23a167e commit 7d8cdee
Show file tree
Hide file tree
Showing 2 changed files with 13 additions and 0 deletions.
3 changes: 3 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,9 @@ and this project adheres to Rust's notion of

## [Unreleased]

### Added
- `orchard::value::ValueCommitTrapdoor::to_bytes`

## [0.10.0] - 2024-10-02

### Changed
Expand Down
10 changes: 10 additions & 0 deletions src/value.rs
Original file line number Diff line number Diff line change
Expand Up @@ -232,6 +232,16 @@ impl ValueCommitTrapdoor {
pub fn from_bytes(bytes: [u8; 32]) -> CtOption<Self> {
pallas::Scalar::from_repr(bytes).map(ValueCommitTrapdoor)
}

/// Returns the byte encoding of this trapdoor.
///
/// This is a low-level API, requiring a detailed understanding of the
/// [use of value commitment trapdoors][orchardbalance] in the Zcash protocol
/// to use correctly and securely. It is intended to be used in combination
/// with [`ValueCommitment::derive`], and PCZTs.
pub fn to_bytes(&self) -> [u8; 32] {
self.0.to_repr()
}
}

impl Add<&ValueCommitTrapdoor> for ValueCommitTrapdoor {
Expand Down

0 comments on commit 7d8cdee

Please sign in to comment.