-
Notifications
You must be signed in to change notification settings - Fork 3
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
Update socket.io packages to v4 (major) #89
Open
renovate
wants to merge
1
commit into
master
Choose a base branch
from
renovate/major-socket.io-packages
base: master
Could not load branches
Branch not found: {{ refName }}
Loading
Could not load tags
Nothing to show
Loading
Are you sure you want to change the base?
Some commits from the old base branch may be removed from the timeline,
and old review comments may become outdated.
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
39260d4
to
1466f6a
Compare
1466f6a
to
60c75be
Compare
60c75be
to
a14fd2a
Compare
a14fd2a
to
6430b6a
Compare
6430b6a
to
7d2443a
Compare
7d2443a
to
c4a381f
Compare
c4a381f
to
9af7615
Compare
9af7615
to
3f767dd
Compare
3f767dd
to
9264aac
Compare
9264aac
to
d842036
Compare
d842036
to
cc11f6d
Compare
cc11f6d
to
079974d
Compare
079974d
to
7ace7dc
Compare
7ace7dc
to
98107fb
Compare
98107fb
to
96f65b6
Compare
96f65b6
to
de895fc
Compare
de895fc
to
5631d93
Compare
5631d93
to
bee1ac3
Compare
bee1ac3
to
eb4b880
Compare
eb4b880
to
dd2c4a4
Compare
44ab9f8
to
e3a6b4f
Compare
e3a6b4f
to
49d025b
Compare
49d025b
to
7d6bb99
Compare
7d6bb99
to
bf674c3
Compare
bf674c3
to
1414016
Compare
1414016
to
2c74780
Compare
2c74780
to
c7933da
Compare
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Labels
None yet
0 participants
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.
This PR contains the following updates:
2.4.1
->4.8.1
2.4.0
->4.8.1
Release Notes
socketio/socket.io (socket.io)
v4.8.1
Compare Source
Bug Fixes
Dependencies
engine.io-client@~6.6.1
(no change)ws@~8.17.1
(no change)v4.8.0
Compare Source
Features
Custom transport implementations
The
transports
option now accepts an array of transport implementations:Here is the list of provided implementations:
Fetch
fetch()
method.NodeXHR
XMLHttpRequest
object provided by thexmlhttprequest-ssl
package.XHR
XMLHttpRequest
object.NodeWebSocket
WebSocket
object provided by thews
package.WebSocket
WebSocket
object.WebTransport
WebTransport
object.Usage:
Fetch
NodeXHR
XHR
NodeWebSocket
WebSocket
WebTransport
(1) since v18.0.0
(2) since v21.0.0
Added in f4d898e and b11763b.
Test each low-level transports
When setting the
tryAllTransports
option totrue
, if the first transport (usually, HTTP long-polling) fails, then the other transports will be tested too:This feature is useful in two cases:
transports: ["websocket", "polling"]
)The only potential downside is that the connection attempt could take more time in case of failure, as there have been reports of WebSocket connection errors taking several seconds before being detected (that's one reason for using HTTP long-polling first). That's why the option defaults to
false
for now.Added in 579b243.
Bug Fixes
Dependencies
engine.io-client@~6.6.1
(diff and diff)ws@~8.17.1
(diff)v4.7.5
Compare Source
Bug Fixes
Links
engine.io@~6.5.2
(no change)ws@~8.11.0
(no change)v4.7.4
Compare Source
Bug Fixes
Links
engine.io@~6.5.2
(no change)ws@~8.11.0
(no change)v4.7.3
Compare Source
Bug Fixes
Links
engine.io@~6.5.2
(no change)ws@~8.11.0
(no change)v4.7.2
Compare Source
Bug Fixes
Links
engine.io@~6.5.2
(diff)ws@~8.11.0
(no change)v4.7.1
Compare Source
The client bundle contains a few fixes regarding the WebTransport support.
Links
engine.io@~6.5.0
(no change)ws@~8.11.0
(no change)v4.7.0
Compare Source
Bug Fixes
Features
Support for WebTransport
The Socket.IO server can now use WebTransport as the underlying transport.
WebTransport is a web API that uses the HTTP/3 protocol as a bidirectional transport. It's intended for two-way communications between a web client and an HTTP/3 server.
References:
Until WebTransport support lands in Node.js, you can use the
@fails-components/webtransport
package:Added in 123b68c.
Client bundles with CORS headers
The bundles will now have the right
Access-Control-Allow-xxx
headers.Added in 63f181c.
Links
engine.io@~6.5.0
(diff)ws@~8.11.0
(no change)v4.6.2
Compare Source
Bug Fixes
types
condition to the top (#4698) (3d44aae)Links
engine.io@~6.4.2
(diff)ws@~8.11.0
(no change)v4.6.1
Compare Source
Bug Fixes
Links
engine.io@~6.4.1
(diff)ws@~8.11.0
(no change)v4.6.0
Compare Source
Bug Fixes
Features
Promise-based acknowledgements
This commit adds some syntactic sugar around acknowledgements:
emitWithAck()
serverSideEmitWithAck()
Added in 184f3cf.
Connection state recovery
This feature allows a client to reconnect after a temporary disconnection and restore its state:
Usage:
Here's how it works:
id
attribute, which is public and can be freely shared)The in-memory adapter already supports this feature, and we will soon update the Postgres and MongoDB adapters. We will also create a new adapter based on Redis Streams, which will support this feature.
Added in 54d5ee0.
Compatibility (for real) with Express middlewares
This feature implements middlewares at the Engine.IO level, because Socket.IO middlewares are meant for namespace authorization and are not executed during a classic HTTP request/response cycle.
Syntax:
A workaround was possible by using the allowRequest option and the "headers" event, but this feels way cleaner and works with upgrade requests too.
Added in 24786e7.
Error details in the disconnecting and disconnect events
The
disconnect
event will now contain additional details about the disconnection reason.Added in 8aa9499.
Automatic removal of empty child namespaces
This commit adds a new option, "cleanupEmptyChildNamespaces". With this option enabled (disabled by default), when a socket disconnects from a dynamic namespace and if there are no other sockets connected to it then the namespace will be cleaned up and its adapter will be closed.
Added in 5d9220b.
A new "addTrailingSlash" option
The trailing slash which was added by default can now be disabled:
In the example above, the clients can omit the trailing slash and use
/socket.io
instead of/socket.io/
.Added in d0fd474.
Performance Improvements
Links:
engine.io@~6.4.0
(diff)ws@~8.11.0
(diff)v4.5.4
Compare Source
This release contains a bump of:
engine.io
in order to fix CVE-2022-41940socket.io-parser
in order to fix CVE-2022-2421.Links:
engine.io@~6.2.1
(diff)ws@~8.2.3
v4.5.3
Compare Source
Bug Fixes
Links:
~6.2.0
~8.2.3
v4.5.2
Compare Source
Bug Fixes
Links:
~6.2.0
~8.2.3
v4.5.1
Compare Source
Bug Fixes
Links:
~6.2.0
~8.2.3
v4.5.0
Compare Source
Bug Fixes
Features
This is similar to
onAny()
, but for outgoing packets.Syntax:
Syntax:
So that clients in HTTP long-polling can decide how many packets they have to send to stay under the maxHttpBufferSize
value.
This is a backward compatible change which should not mandate a new major revision of the protocol (we stay in v4), as
we only add a field in the JSON-encoded handshake data:
Links:
~6.2.0
(diff)~8.2.3
v4.4.1
Compare Source
Bug Fixes
RemoteSocket.data
type safe (#4234) (770ee59)SocketData
type to custom namespaces (#4233) (f2b8de7)Links:
~6.1.0
(diff)~8.2.3
v4.4.0
Compare Source
Bug Fixes
Features
socket.data
(#4159) (fe8730c)Links:
~6.1.0
(diff)~8.2.3
v4.3.2
Compare Source
Bug Fixes
Links:
~6.0.0
~8.2.3
v4.3.1
Compare Source
Bug Fixes
Links:
~6.0.0
~8.2.3
v4.3.0
Compare Source
For this release, most of the work was done on the client side, see here.
Bug Fixes
Features
Links:
~6.0.0
(diff)~8.2.3
(diff)v4.2.0
Compare Source
Bug Fixes
Features
Links:
~5.2.0
~7.4.2
v4.1.3
Compare Source
Bug Fixes
Links:
~5.1.0
~7.4.2
v4.1.2
Compare Source
Bug Fixes
Links:
~5.1.0
~7.4.2
v4.1.1
Compare Source
Bug Fixes
Links:
~5.1.0
~7.4.2
v4.1.0
Compare Source
Blog post: https://socket.io/blog/socket-io-4-1-0/
Features
engine.io
)engine.io
)Links:
~5.1.0
~7.4.2
v4.0.2
Compare Source
Bug Fixes
Links:
~5.0.0
~7.4.2
v4.0.1
Compare Source
Bug Fixes
Links:
~5.0.0
~7.4.2
v4.0.0
Compare Source
Blog post: https://socket.io/blog/socket-io-4-release/
Migration guide: https://socket.io/docs/v3/migrating-from-3-x-to-4-0/
Bug Fixes
Features
BREAKING CHANGES
io.to(...)
now returns an immutable operatorPreviously, broadcasting to a given room (by calling
io.to()
) would mutate the io instance, which could lead to surprising behaviors, like:Calling
io.to()
(or any other broadcast modifier) will now return an immutable instance.Links:
~5.0.0
~7.4.2
v3.1.2
Compare Source
Bug Fixes
Links:
~4.1.0
~7.4.2
v3.1.1
Compare Source
Bug Fixes
Links:
~4.1.0
~7.4.2
v3.1.0
Compare Source
In order to ease the migration to Socket.IO v3, the v3 server is now able to communicate with v2 clients:
Note: the
allowEIO3
refers to the version 3 of the Engine.IO protocol which is used in Socket.IO v2Features
Bug Fixes
Links:
~4.1.0
~7.4.2
v3.0.5
Compare Source
Bug Fixes
Reverts
Links:
~4.0.6
~7.4.2
v3.0.4
Compare Source
Links:
~4.0.0
^7.1.2
v3.0.3
Compare Source
Links:
~4.0.0
^7.1.2
v3.0.2
Compare Source
Bug Fixes
Links:
~4.0.0
^7.1.2
v3.0.1
Compare Source
Bug Fixes
Links:
~4.0.0
^7.1.2
v3.0.0
Compare Source
More details about this release in the blog post: https://socket.io/blog/socket-io-3-release/
Dedicated migration guide: https://socket.io/docs/migrating-from-2-x-to-3-0/
Bug Fixes
Features
BREAKING CHANGES
the Socket#use() method is removed (see 5c73733)
Socket#join() and Socket#leave() do not accept a callback argument anymore.
Before:
After:
Before:
The 'origins' option was used in the allowRequest method, in order to
determine whether the request should pass or not. And the Engine.IO
server would implicitly add the necessary Access-Control-Allow-xxx
headers.
After:
The already existing 'allowRequest' option can be used for validation:
Socket#rooms is now a Set instead of an object
Namespace#connected is now a Map instead of an object
there is no more implicit connection to the default namespace:
This method was kept for backward-compatibility with pre-1.0 versions.
Links:
~4.0.0
^7.1.2
v2.5.1
Compare Source
Bug Fixes
Links:
-
~3.6.0
(no change)~7.5.10
v2.5.0
Compare Source
The default value of the
maxHttpBufferSize
option has been decreased from 100 MB to 1 MB, in order to prevent attacks by denial of service.Security advisory: GHSA-j4f2-536g-r55m
Bug Fixes
Links:
~3.6.0
(diff)~7.4.2
Configuration
📅 Schedule: Branch creation - At any time (no schedule defined), Automerge - At any time (no schedule defined).
🚦 Automerge: Disabled by config. Please merge this manually once you are satisfied.
♻ Rebasing: Whenever PR becomes conflicted, or you tick the rebase/retry checkbox.
🔕 Ignore: Close this PR and you won't be reminded about these updates again.
This PR was generated by Mend Renovate. View the repository job log.