-
Notifications
You must be signed in to change notification settings - Fork 912
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
More BOLT updates, to latest. #5592
More BOLT updates, to latest. #5592
Conversation
56a2fca
to
ee46461
Compare
doc/GOSSIP_STORE.md
Outdated
- Always check the major version number! We will increment it if the format | ||
changes in a way that breaks readers. | ||
- Ignore unknown flags in the header. | ||
- Ignore unknown messages. |
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.
I was reading this as "Ignore any message of unknown type." Is there any other validation a reader should be expected to perform? If so, we should be explicit.
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.
No, that's it, so I made it more explicit.
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.
This was great - I learned a few things. I like the gossip_store versioning and new documentation.
ACK 6e4e104
I should note this predictably upsets lnprototest during test_bolt7-01-channel_announcement-success.py. Will need to bring the test up to speed with a 12 block delay after closing tx. |
Some things that made CI upset are fixed on |
6e4e104
to
87461d7
Compare
Seems there is a mismatch between bolts and string in lnprototest:
|
OK, so this now depends on new lnprototest, which requires #5621... |
87461d7
to
16046f9
Compare
OK, I folded the #5621 into this (at a point before we add the 12 block delay), so this PR will actually pass. |
16046f9
to
b9258af
Compare
Trivial rebase for minor test conflict. |
Seems some of the blockheights are off by 12 blocks, so this seems to be either the wrong commit or we need to adjust heights in tests. I'll be ignoring failures in the lnprototest config in CI until this PR is merged. |
Wtf... Ok, I'll try to get to my laptop today and figure out what I did. I meant to only add the lnprototest changes :( |
Which I disagreed with, and has been fixed. Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
If they really upgrade directly from 0.9.2, it will simply delete the store and re-fetch it. We still update from v9 (which could be v0.11), since it's a noop. Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
We rewrite the file to compact it, but as a side effect we recalculate the checksums! Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
Many changes to gossmap (including the pending ones!) don't actually concern readers, as long as they obey certain rules: 1. Ignore unknown messages. 2. Treat all 16 upper bits of length as flags, ignore unknown ones. So now we split the version byte into MAJOR and MINOR, and you can ignore MINOR changes. We don't expose the internal version (for creating the map) programmatically: you should really hardcode what major version you understand! Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
And in the next patch, gossipd will no longer put new ones in. Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
We will now simply reject old-style ones as invalid. Turns out the only trace we could find is a channel between two nodes unconnected to the rest of the network. Signed-off-by: Rusty Russell <rusty@rustcorp.com.au> Changelog-Changed: Protocol: We now require all channel_update messages include htlc_maximum_msat (as per latest BOLTs)
Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
Signed-off-by: Rusty Russell <rusty@rustcorp.com.au> Changelog-Added: Protocol: We now set the `dont_forward` bit on private channel_update's message_flags (as per latest BOLTs).
It's a bit more optimal, and tells gossipd exactly what height the spend occurred at (with multiple blocks, it's not always the current height!). It will need that next patch. Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
Signed-off-by: Vincenzo Palazzo <vincenzopalazzodev@gmail.com>
This adds a new "chan_dying" message to the gossip_store, but since we already changed the minor version in this PR, we don't bump it again. Signed-off-by: Rusty Russell <rusty@rustcorp.com.au> Changelog-Added: Protocol: We now delay forgetting funding-spent channels for 12 blocks (as per latest BOLTs, to support splicing in future).
Simple quote update. Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
Mainly for @vincenzopalazzo who is thinking of writing a Rust version! Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
b9258af
to
101b008
Compare
Ah, it really was a conflict! That multichan test did need fixing, done now. |
Includes the 12-block delay, removing non-htlc_maximum_msat updates, and setting the
dont_forward
bit!Currently breaks lnprototest as expected, I'll have to fix that!
Closes: #5548
Closes #5562