-
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
Wumbo channel support #3612
Wumbo channel support #3612
Conversation
7699065
to
e816d77
Compare
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.
common/features.c
Outdated
const struct feature_set *ours, | ||
const u8 *theirfeatures) |
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.
Nit: inconsistent naming, should be theirs
and ours, or
theirfeaturesand
ourfeatures`.
else | ||
continue; |
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 should likely at least produce a warning that the plugin is not in sync with lightningd
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 figure it's always legal to add a field. Though perhaps libplugin should consider itself more tightly bound?
This will help with the next patch, where we wean off using a global for features: connectd.c has access to the feature bits. Since connectd might now want to send a message, it needs the crypto_state non-const, which makes this less trivial than it would otherwise be. Signed-off-by: Rusty Russell <[email protected]>
Turns out that unnecessary: all callers can access the feature_set, so make it much more like a normal primitive. Signed-off-by: Rusty Russell <[email protected]>
Shows what features we use in various contexts, including those added by plugins in getmanifest. Signed-off-by: Rusty Russell <[email protected]> Changelog-Added: Plugin: `feature_set` object added to `init`
Signed-off-by: Rusty Russell <[email protected]>
This is useful in general, but in particular it allows fundchannel to avoid YA query to figure out if it can wumbo. Signed-off-by: Rusty Russell <[email protected]> Changelog-Added: JSON: `connect` returns `features` of the connected peer on success.
This means we correctly reject invoices with features we don't understand. Signed-off-by: Rusty Russell <[email protected]>
Signed-off-by: Rusty Russell <[email protected]>
b7fa526
to
d50abc3
Compare
OK, I fixed some tests, and did a sweep to rename all the feature sets to "our_features" or "their_features" where appropriate. |
d50abc3
to
7f7b69e
Compare
…arge_channel. Note that now we check capacity once we've figured out which peer, which broke a test (we returned "unknown peer" instead of "capacity exceeded"), so we rework that too. Signed-off-by: Rusty Russell <[email protected]>
Signed-off-by: Rusty Russell <[email protected]> Changelog-added: `large-channels` option to negotiate opening larger channels.
Signed-off-by: Rusty Russell <[email protected]>
…icit. It's almost always "their_features" and "our_features" respectively, so make those names clear. Suggested-by: @cdecker Signed-off-by: Rusty Russell <[email protected]>
7f7b69e
to
6ea51f0
Compare
Ack 6ea51f0 |
This adds a
--wumbo
(or, more prosiacly) a--large-channels
option (off by default) which means:option_support_large_channel
from the spec.Before merging, someone should interop this with Eclair: in particular, it's the first feature we advertize in the channel_announcement, and we can't advertize the channel if we don't both agree on how that's represented!