-
Notifications
You must be signed in to change notification settings - Fork 339
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
add Fallback
getter that returns Address
#2023
Conversation
Thanks for putting this together!
Chatted with @TheBlueMatt. From the perspective from
You could implement it for a tuple
For these two points, yeah, it would better if we use better types. Could you update the enum variants to use them?
Clone wasn't need but the bytes are eventually copied, so somewhat similar.
This seems right. Not sure how an LND-specific concept got into here lol. We inherited this code. 😛 |
Down to one unwrap in the address creation, so that's nice. Can do a |
Codecov ReportPatch coverage:
📣 This organization is not using Codecov’s GitHub App Integration. We recommend you install it so Codecov can continue to function properly for your repositories. Learn more Additional details and impacted files@@ Coverage Diff @@
## main #2023 +/- ##
==========================================
+ Coverage 91.04% 91.28% +0.23%
==========================================
Files 99 102 +3
Lines 51722 49994 -1728
Branches 51722 49994 -1728
==========================================
- Hits 47091 45635 -1456
+ Misses 4631 4359 -272
... and 99 files with indirect coverage changes Help us with your feedback. Take ten seconds to tell us how you rate us. Have a feature suggestion? Share it here. ☔ View full report in Codecov by Sentry. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Sorry about the delay. Travel go the best of me.
lightning-invoice/src/de.rs
Outdated
if bytes.len() != 20 { | ||
return Err(ParseError::InvalidPubKeyHashLength); | ||
} | ||
//TODO: refactor once const generics are available | ||
let mut pkh = [0u8; 20]; | ||
pkh.copy_from_slice(&bytes); | ||
let pkh = match PubkeyHash::from_slice(&bytes) { | ||
Ok(pkh) => pkh, | ||
Err(_) => return Err(ParseError::InvalidPubKeyHash), | ||
}; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
from_slice
will check the length, so we can remove our explicit check in favor of the new one. Probably could have the match
pattern on the exact error variant. That way we won't need to add a new error variant and we'll fail to compile if new variants are added upstream.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
nice, thank you this worked out great
lightning-invoice/src/de.rs
Outdated
if bytes.len() != 20 { | ||
return Err(ParseError::InvalidScriptHashLength); | ||
} | ||
let mut sh = [0u8; 20]; | ||
sh.copy_from_slice(&bytes); | ||
let sh = match ScriptHash::from_slice(&bytes) { | ||
Ok(sh) => sh, | ||
Err(_) => return Err(ParseError::InvalidScriptHash), | ||
}; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Likewise here.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
yeah I got to get rid of all three errors I added!
Any update on addressing the review feedback @futurepaul? |
Sorry for the long delay, will be able to get back to this in about a week |
okay @jkczyz @TheBlueMatt this addresses the review feedback |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Nice!
Please feel free to squash down your fixups so that each commit stands on its own and doesn't fix issues introduced in previous commits in the same PR. THen we'll get another reviewer here. |
61db97d
to
faf1e23
Compare
couldn't think of a clean way to separate out this work because the use of the bitcoin types directly impacted how the getter is written so hope it's okay I squashed down to one commit |
FWIW, you could add |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Just some nits that I missed but otherwise looks good.
faf1e23
to
cf0a90b
Compare
closes #882
I wasn't sure the exact right strategy and wrote this before seeing the most recent comment on this issue, so feel free to close if this is the wrong direction.
A few notes:
Into
because theFallback
on its own isn't enough to create anAddress
, you also need a network.Result
(and what errors that would require) because this is data that's already been successfully parsed and theoretically isn't wrong. Therefore I'm using unwraps which feels wrong, so would appreciate some input on that.bitcoin
lib'sWitnessVersion
,Script
, and hash types insideFallback
(there's even a todo onFallback
about using better types)Currency::Simnet
toNetwork::Regtest
, not sure if that's correct