Skip to content

Commit 106992c

Browse files
committed
Use TaggedHash in merkle::verify_signature
An earlier commit introduced TaggedHash for use in sign_message. For consistency, use it in verify_signature, too.
1 parent 2f41650 commit 106992c

File tree

3 files changed

+18
-24
lines changed

3 files changed

+18
-24
lines changed

lightning/src/offers/invoice.rs

Lines changed: 9 additions & 12 deletions
Original file line numberDiff line numberDiff line change
@@ -1175,8 +1175,9 @@ impl TryFrom<ParsedMessage<FullInvoiceTlvStream>> for Bolt12Invoice {
11751175
None => return Err(Bolt12ParseError::InvalidSemantics(Bolt12SemanticError::MissingSignature)),
11761176
Some(signature) => signature,
11771177
};
1178+
let message = TaggedHash::new(SIGNATURE_TAG, &bytes);
11781179
let pubkey = contents.fields().signing_pubkey;
1179-
merkle::verify_signature(&signature, SIGNATURE_TAG, &bytes, pubkey)?;
1180+
merkle::verify_signature(&signature, message, pubkey)?;
11801181

11811182
Ok(Bolt12Invoice { bytes, contents, signature })
11821183
}
@@ -1279,7 +1280,7 @@ mod tests {
12791280
use crate::ln::inbound_payment::ExpandedKey;
12801281
use crate::ln::msgs::DecodeError;
12811282
use crate::offers::invoice_request::InvoiceRequestTlvStreamRef;
1282-
use crate::offers::merkle::{SignError, SignatureTlvStreamRef, self};
1283+
use crate::offers::merkle::{SignError, SignatureTlvStreamRef, TaggedHash, self};
12831284
use crate::offers::offer::{Amount, OfferBuilder, OfferTlvStreamRef, Quantity};
12841285
use crate::offers::parse::{Bolt12ParseError, Bolt12SemanticError};
12851286
use crate::offers::payer::PayerTlvStreamRef;
@@ -1391,11 +1392,9 @@ mod tests {
13911392
assert_eq!(invoice.fallbacks(), vec![]);
13921393
assert_eq!(invoice.invoice_features(), &Bolt12InvoiceFeatures::empty());
13931394
assert_eq!(invoice.signing_pubkey(), recipient_pubkey());
1394-
assert!(
1395-
merkle::verify_signature(
1396-
&invoice.signature, SIGNATURE_TAG, &invoice.bytes, recipient_pubkey()
1397-
).is_ok()
1398-
);
1395+
1396+
let message = TaggedHash::new(SIGNATURE_TAG, &invoice.bytes);
1397+
assert!(merkle::verify_signature(&invoice.signature, message, recipient_pubkey()).is_ok());
13991398

14001399
let digest = Message::from_slice(&invoice.signable_hash()).unwrap();
14011400
let pubkey = recipient_pubkey().into();
@@ -1490,11 +1489,9 @@ mod tests {
14901489
assert_eq!(invoice.fallbacks(), vec![]);
14911490
assert_eq!(invoice.invoice_features(), &Bolt12InvoiceFeatures::empty());
14921491
assert_eq!(invoice.signing_pubkey(), recipient_pubkey());
1493-
assert!(
1494-
merkle::verify_signature(
1495-
&invoice.signature, SIGNATURE_TAG, &invoice.bytes, recipient_pubkey()
1496-
).is_ok()
1497-
);
1492+
1493+
let message = TaggedHash::new(SIGNATURE_TAG, &invoice.bytes);
1494+
assert!(merkle::verify_signature(&invoice.signature, message, recipient_pubkey()).is_ok());
14981495

14991496
assert_eq!(
15001497
invoice.as_tlv_stream(),

lightning/src/offers/invoice_request.rs

Lines changed: 5 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -792,7 +792,8 @@ impl TryFrom<Vec<u8>> for InvoiceRequest {
792792
None => return Err(Bolt12ParseError::InvalidSemantics(Bolt12SemanticError::MissingSignature)),
793793
Some(signature) => signature,
794794
};
795-
merkle::verify_signature(&signature, SIGNATURE_TAG, &bytes, contents.payer_id)?;
795+
let message = TaggedHash::new(SIGNATURE_TAG, &bytes);
796+
merkle::verify_signature(&signature, message, contents.payer_id)?;
796797

797798
Ok(InvoiceRequest { bytes, contents, signature })
798799
}
@@ -926,11 +927,9 @@ mod tests {
926927
assert_eq!(invoice_request.quantity(), None);
927928
assert_eq!(invoice_request.payer_id(), payer_pubkey());
928929
assert_eq!(invoice_request.payer_note(), None);
929-
assert!(
930-
merkle::verify_signature(
931-
&invoice_request.signature, SIGNATURE_TAG, &invoice_request.bytes, payer_pubkey()
932-
).is_ok()
933-
);
930+
931+
let message = TaggedHash::new(SIGNATURE_TAG, &invoice_request.bytes);
932+
assert!(merkle::verify_signature(&invoice_request.signature, message, payer_pubkey()).is_ok());
934933

935934
assert_eq!(
936935
invoice_request.as_tlv_stream(),

lightning/src/offers/merkle.rs

Lines changed: 4 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -81,17 +81,15 @@ where
8181
Ok(signature)
8282
}
8383

84-
/// Verifies the signature with a pubkey over the given bytes using a tagged hash as the message
84+
/// Verifies the signature with a pubkey over the given message using a tagged hash as the message
8585
/// digest.
86-
///
87-
/// Panics if `bytes` is not a well-formed TLV stream containing at least one TLV record.
8886
pub(super) fn verify_signature(
89-
signature: &Signature, tag: &str, bytes: &[u8], pubkey: PublicKey,
87+
signature: &Signature, message: TaggedHash, pubkey: PublicKey,
9088
) -> Result<(), secp256k1::Error> {
91-
let digest = message_digest(tag, bytes);
89+
let digest = message.as_digest();
9290
let pubkey = pubkey.into();
9391
let secp_ctx = Secp256k1::verification_only();
94-
secp_ctx.verify_schnorr(signature, &digest, &pubkey)
92+
secp_ctx.verify_schnorr(signature, digest, &pubkey)
9593
}
9694

9795
pub(super) fn message_digest(tag: &str, bytes: &[u8]) -> Message {

0 commit comments

Comments
 (0)