Skip to content

Commit

Permalink
Fix naming cmstar -> cmstar_bytes and cm -> cmstar
Browse files Browse the repository at this point in the history
  • Loading branch information
nuttycom committed Apr 15, 2021
1 parent 00d04de commit b2b3efd
Show file tree
Hide file tree
Showing 3 changed files with 21 additions and 21 deletions.
30 changes: 15 additions & 15 deletions components/zcash_note_encryption/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -74,8 +74,8 @@ pub trait Domain {
type IncomingViewingKey;
type OutgoingViewingKey;
type ValueCommitment;
type NoteCommitment;
type ExtractedCommitment: Eq + TryFrom<Self::NoteCommitment>;
type ExtractedCommitment;
type ExtractedCommitmentBytes: Eq + TryFrom<Self::ExtractedCommitment>;
type Memo;

fn derive_esk(note: &Self::Note) -> Option<Self::EphemeralSecretKey>;
Expand Down Expand Up @@ -111,7 +111,7 @@ pub trait Domain {
fn derive_ock(
ovk: &Self::OutgoingViewingKey,
cv: &Self::ValueCommitment,
cm: &Self::NoteCommitment,
cmstar: &Self::ExtractedCommitment,
ephemeral_key: &EphemeralKeyBytes,
) -> OutgoingCipherKey;

Expand All @@ -127,7 +127,7 @@ pub trait Domain {
check: F,
) -> NoteValidity;

fn note_commitment(note: &Self::Note) -> Self::NoteCommitment;
fn cmstar(note: &Self::Note) -> Self::ExtractedCommitment;

fn parse_note_plaintext_without_memo_ivk(
&self,
Expand Down Expand Up @@ -157,7 +157,7 @@ pub trait Domain {

pub trait ShieldedOutput<D: Domain> {
fn epk(&self) -> &D::EphemeralPublicKey;
fn cmstar(&self) -> D::ExtractedCommitment;
fn cmstar_bytes(&self) -> D::ExtractedCommitmentBytes;
fn enc_ciphertext(&self) -> &[u8];
}

Expand Down Expand Up @@ -288,11 +288,11 @@ impl<D: Domain> NoteEncryption<D> {
pub fn encrypt_outgoing_plaintext<R: RngCore>(
&self,
cv: &D::ValueCommitment,
cm: &D::NoteCommitment,
cmstar: &D::ExtractedCommitment,
rng: &mut R,
) -> [u8; OUT_CIPHERTEXT_SIZE] {
let (ock, input) = if let Some(ovk) = &self.ovk {
let ock = D::derive_ock(ovk, &cv, &cm, &D::epk_bytes(&self.epk));
let ock = D::derive_ock(ovk, &cv, &cmstar, &D::epk_bytes(&self.epk));
let input = D::outgoing_plaintext_bytes(&self.note, &self.esk);

(ock, input)
Expand Down Expand Up @@ -355,7 +355,7 @@ pub fn try_note_decryption<D: Domain, Output: ShieldedOutput<D>>(
domain,
ivk,
output.epk(),
&output.cmstar(),
&output.cmstar_bytes(),
&plaintext,
)?;
let memo = domain.extract_memo(&plaintext);
Expand All @@ -367,12 +367,12 @@ fn parse_note_plaintext_without_memo_ivk<D: Domain>(
domain: &D,
ivk: &D::IncomingViewingKey,
epk: &D::EphemeralPublicKey,
cmstar: &D::ExtractedCommitment,
cmstar_bytes: &D::ExtractedCommitmentBytes,
plaintext: &[u8],
) -> Option<(D::Note, D::Recipient)> {
let (note, to) = domain.parse_note_plaintext_without_memo_ivk(ivk, &plaintext)?;

if let NoteValidity::Valid = check_note_validity::<D>(&note, epk, cmstar) {
if let NoteValidity::Valid = check_note_validity::<D>(&note, epk, cmstar_bytes) {
Some((note, to))
} else {
None
Expand All @@ -382,10 +382,10 @@ fn parse_note_plaintext_without_memo_ivk<D: Domain>(
fn check_note_validity<D: Domain>(
note: &D::Note,
epk: &D::EphemeralPublicKey,
cmstar: &D::ExtractedCommitment,
cmstar_bytes: &D::ExtractedCommitmentBytes,
) -> NoteValidity {
if D::ExtractedCommitment::try_from(D::note_commitment(&note))
.map_or(false, |cs| &cs == cmstar)
if D::ExtractedCommitmentBytes::try_from(D::cmstar(&note))
.map_or(false, |cs| &cs == cmstar_bytes)
{
let epk_bytes = D::epk_bytes(epk);
D::check_epk_bytes(&note, |derived_esk| {
Expand Down Expand Up @@ -428,7 +428,7 @@ pub fn try_compact_note_decryption<D: Domain, Output: ShieldedOutput<D>>(
plaintext.copy_from_slice(output.enc_ciphertext());
ChaCha20Ietf::xor(key.as_ref(), &[0u8; 12], 1, &mut plaintext);

parse_note_plaintext_without_memo_ivk(domain, ivk, output.epk(), &output.cmstar(), &plaintext)
parse_note_plaintext_without_memo_ivk(domain, ivk, output.epk(), &output.cmstar_bytes(), &plaintext)
}

/// Recovery of the full note plaintext by the sender.
Expand Down Expand Up @@ -484,7 +484,7 @@ pub fn try_output_recovery_with_ock<D: Domain, Output: ShieldedOutput<D>>(
domain.parse_note_plaintext_without_memo_ovk(&pk_d, &esk, output.epk(), &plaintext)?;
let memo = domain.extract_memo(&plaintext);

if let NoteValidity::Valid = check_note_validity::<D>(&note, output.epk(), &output.cmstar()) {
if let NoteValidity::Valid = check_note_validity::<D>(&note, output.epk(), &output.cmstar_bytes()) {
Some((note, to, memo))
} else {
None
Expand Down
8 changes: 4 additions & 4 deletions zcash_primitives/src/sapling/note_encryption.rs
Original file line number Diff line number Diff line change
Expand Up @@ -127,8 +127,8 @@ impl<P: consensus::Parameters> Domain for SaplingDomain<P> {
type IncomingViewingKey = SaplingIvk;
type OutgoingViewingKey = OutgoingViewingKey;
type ValueCommitment = jubjub::ExtendedPoint;
type NoteCommitment = bls12_381::Scalar;
type ExtractedCommitment = [u8; 32];
type ExtractedCommitment = bls12_381::Scalar;
type ExtractedCommitmentBytes = [u8; 32];
type Memo = MemoBytes;

fn derive_esk(note: &Self::Note) -> Option<Self::EphemeralSecretKey> {
Expand Down Expand Up @@ -206,7 +206,7 @@ impl<P: consensus::Parameters> Domain for SaplingDomain<P> {
fn derive_ock(
ovk: &Self::OutgoingViewingKey,
cv: &Self::ValueCommitment,
cmu: &Self::NoteCommitment,
cmu: &Self::ExtractedCommitment,
epk: &EphemeralKeyBytes,
) -> OutgoingCipherKey {
prf_ock(ovk, cv, cmu, epk)
Expand Down Expand Up @@ -265,7 +265,7 @@ impl<P: consensus::Parameters> Domain for SaplingDomain<P> {
})
}

fn note_commitment(note: &Self::Note) -> Self::NoteCommitment {
fn cmstar(note: &Self::Note) -> Self::ExtractedCommitment {
note.cmu()
}

Expand Down
4 changes: 2 additions & 2 deletions zcash_primitives/src/transaction/components/sapling.rs
Original file line number Diff line number Diff line change
Expand Up @@ -123,7 +123,7 @@ impl<P: consensus::Parameters> ShieldedOutput<SaplingDomain<P>> for OutputDescri
&self.ephemeral_key
}

fn cmstar(&self) -> [u8; 32] {
fn cmstar_bytes(&self) -> [u8; 32] {
self.cmu.to_repr()
}

Expand Down Expand Up @@ -235,7 +235,7 @@ impl<P: consensus::Parameters> ShieldedOutput<SaplingDomain<P>> for CompactOutpu
&self.epk
}

fn cmstar(&self) -> [u8; 32] {
fn cmstar_bytes(&self) -> [u8; 32] {
self.cmu.to_repr()
}

Expand Down

0 comments on commit b2b3efd

Please sign in to comment.