-
Notifications
You must be signed in to change notification settings - Fork 11
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
transport: Introduce common listener for tcp and websocket #147
Conversation
Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io>
Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io>
Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io>
Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io>
Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io>
Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io>
Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io>
Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io>
Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io>
Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io>
Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io>
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.
Looks good!
I would, may be, go one step further and make SocketListener
completely unaware of whether it deals with TCP or WebSocket. Basically, the main difference is the code path in get_socket_address()
, and may be this can be made external to SocketListener
. The PR already simplifies a lot and is good in it's current form, so we can do this in a follow-up if you consider this valuable/doable.
Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io>
Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io>
Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io>
Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io>
Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io>
Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io>
Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io>
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.
Everything looks good!
Signed-off-by: Alexandru Vasile <alexandru.vasile@parity.io>
## [0.6.0] - 2024-06-14 This release introduces breaking changes into `kad` module. The API has been extended as following: - An event `KademliaEvent::IncomingRecord` has been added. - New methods `KademliaHandle::store_record()` / `KademliaHandle::try_store_record()` have been introduced. This allows implementing manual incoming DHT record validation by configuring `Kademlia` with `IncomingRecordValidationMode::Manual`. Also, it is now possible to enable `TCP_NODELAY` on sockets. Multiple refactorings to remove the code duplications and improve the implementation robustness have been done. ### Added - Support manual DHT record insertion ([#135](#135)) - transport: Make `TCP_NODELAY` configurable ([#146](#146)) ### Changed - transport: Introduce common listener for tcp and websocket ([#147](#147)) - transport/common: Share DNS lookups between TCP and WebSocket ([#151](#151)) ### Fixed - ping: Make ping fault tolerant wrt outbound substreams races ([#133](#133)) - crypto/noise: Make noise fault tolerant ([#142](#142)) - protocol/notif: Fix panic on missing peer state ([#143](#143)) - transport: Fix erroneous handling of secondary connections ([#149](#149))
This PR aims to remove duplicated code for socket listener between TCP and WebSocket transports.
Changes done:
common
modulePart of #70.