-
Notifications
You must be signed in to change notification settings - Fork 913
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
Websocket not experimental, don't advertize, fix address parsing #6173
Merged
rustyrussell
merged 12 commits into
ElementsProject:master
from
rustyrussell:guilt/websocket-not-experimental
May 31, 2023
Merged
Websocket not experimental, don't advertize, fix address parsing #6173
rustyrussell
merged 12 commits into
ElementsProject:master
from
rustyrussell:guilt/websocket-not-experimental
May 31, 2023
Conversation
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
rustyrussell
force-pushed
the
guilt/websocket-not-experimental
branch
from
May 26, 2023 07:31
334dfed
to
db35f5a
Compare
rustyrussell
force-pushed
the
guilt/websocket-not-experimental
branch
from
May 29, 2023 05:19
7df636e
to
70a6e0c
Compare
Rolled in fixes from @m-schmoock and improved schema, as well as actually updated tests now we've deprecated the old version (which found a bug, fixed!). |
rustyrussell
force-pushed
the
guilt/websocket-not-experimental
branch
from
May 29, 2023 11:48
70a6e0c
to
7d2cc5c
Compare
Trivial rebase onto master to fix clash in generated files.... |
rustyrussell
force-pushed
the
guilt/websocket-not-experimental
branch
5 times, most recently
from
May 30, 2023 00:44
10e907e
to
4818d25
Compare
This is an internal type: it has no API guarantees (indeed, I'm about to change it, which is how I discovered scb was using it). Fortunately for every case we care about, it is actually a wireaddr (in theory the peer can connect locally using a local socket, but this is mostly for testing and is a very strange setup, and so simply don't do scb for those). In this case, the wire encoding is a single byte followed by the wireaddr, so open-code that in scb_wire.csv for compatibility. Signed-off-by: Rusty Russell <[email protected]>
This contained cut & paste code, and it wasn't clear to me that the first loop included DNS entries with IPv6 entries. Instead, allow the iterator to take multiple types, and use a switch statement so compile will break as new types are added. Signed-off-by: Rusty Russell <[email protected]>
1. Make it the standard "return the error" pattern. 2. Rather than flags to indicate what types are allowed, have the callers check the return explicitly. 3. Document the APIs. Signed-off-by: Rusty Russell <[email protected]>
I never really liked this hack: websockets are useful, advertizing them not so much. Note that we never actually documented that we would advertize these! Changelog-EXPERIMENTAL: Protocol: Removed support for advertizing websocket addresses in gossip. Signed-off-by: Rusty Russell <[email protected]>
Signed-off-by: Rusty Russell <[email protected]>
This is a major cleanup to how we parse addresses. 1. parse_wireaddr now supports the "dns:" prefix to support dns records (type 5). 2. We are less reliant on separate_address_and_port() which gets confused by that colon. 3. We explicitly test every possible address type we can get back from parsing, and handle them appropriately. We update the documentation to use the clearer HOSTNAME vs DNS prefixes now we also have `dns:` as a prefix. Changelog-Added: Config: `bind` can now take `dns:` prefix to advertize DNS records. Signed-off-by: Rusty Russell <[email protected]>
This obsoletes the use of --announce-addr-dns which I know Michael didn't really like either. Changelog-Deprecated: Config: `announce-addr-dns`; use `--bind-addr=dns:ADDR` for finer control. Signed-off-by: Rusty Russell <[email protected]>
These are only likely to confuse users, by silently changing behavior. Changelog-Deprecated: Config: bind-addr=xxx.onion and addr=xxx.onion, use announce=xxx.onion (which was always equivalent). Changelog-Deprecated: Config: addr=/socketpath, use listen=/socketpath (which was always equivalent).
Now it's not a public type, we need a way to refer to it. Signed-off-by: Rusty Russell <[email protected]>
Changelog-Added: Config: `bind=ws:...` to explicitly listen on a websocket. Signed-off-by: Rusty Russell <[email protected]>
…d=ws: Changelog-Deprecated: `experimental-websocket-port`: use `--bind=ws::<portnum>`. Signed-off-by: Rusty Russell <[email protected]>
rustyrussell
force-pushed
the
guilt/websocket-not-experimental
branch
2 times, most recently
from
May 30, 2023 05:00
bee38cf
to
cb5c857
Compare
I wasted far too much time on this, disable and reenable later. Signed-off-by: Rusty Russell <[email protected]>
rustyrussell
force-pushed
the
guilt/websocket-not-experimental
branch
from
May 30, 2023 05:16
cb5c857
to
ec72619
Compare
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Changing wireaddr_internal is how I found out it was written into static_channel_backup! So fix that first, then the rest is fairly trivial.