From 7c83d6d6766cc996a8eafbb7d6b7d39e3b7362fa Mon Sep 17 00:00:00 2001 From: Taylor Hornby Date: Thu, 5 May 2022 12:37:43 -0600 Subject: [PATCH] Label consensus rules in orchard --- src/bundle.rs | 2 ++ src/bundle/batch.rs | 2 ++ 2 files changed, 4 insertions(+) diff --git a/src/bundle.rs b/src/bundle.rs index c70ca6350..fab0c700e 100644 --- a/src/bundle.rs +++ b/src/bundle.rs @@ -111,6 +111,7 @@ impl Flags { /// /// [txencoding]: https://zips.z.cash/protocol/protocol.pdf#txnencoding pub fn from_byte(value: u8) -> Option { + // TCR:bad-txns-v5-reserved-bits-nonzero if value & FLAGS_EXPECTED_UNSET == 0 { Some(Self::from_parts( value & FLAG_SPENDS_ENABLED != 0, @@ -371,6 +372,7 @@ impl> Bundle { /// This can be used to validate the [`Authorized::binding_signature`] returned from /// [`Bundle::authorization`]. pub fn binding_validating_key(&self) -> redpallas::VerificationKey { + // *TCR:bad-txns-orchard-binding-signature-invalid (self .actions .iter() diff --git a/src/bundle/batch.rs b/src/bundle/batch.rs index c60d0cd55..b41a96fd0 100644 --- a/src/bundle/batch.rs +++ b/src/bundle/batch.rs @@ -67,6 +67,8 @@ impl BatchValidator { /// figure out which of the accumulated bundles might be invalid; if that information /// is desired, construct separate [`BatchValidator`]s for sub-batches of the bundles. pub fn validate(self, vk: &VerifyingKey, rng: R) -> bool { + // *TCR:bad-txns-orchard-binding-signature-invalid + if self.signatures.is_empty() { // An empty batch is always valid, but is not free to run; skip it. // Note that a transaction has at least a binding signature, so if