[Snyk] Upgrade: express, socket.io, socket.io-client#96
Open
WilliamUK17 wants to merge 1 commit intomainfrom
Open
[Snyk] Upgrade: express, socket.io, socket.io-client#96WilliamUK17 wants to merge 1 commit intomainfrom
WilliamUK17 wants to merge 1 commit intomainfrom
Conversation
Snyk has created this PR to upgrade:
- express from 4.18.1 to 4.19.2.
See this package in npm: https://www.npmjs.com/package/express
- socket.io from 4.5.1 to 4.7.5.
See this package in npm: https://www.npmjs.com/package/socket.io
- socket.io-client from 4.5.1 to 4.7.5.
See this package in npm: https://www.npmjs.com/package/socket.io-client
See this project in Snyk:
https://app.snyk.io/org/p4r4d0xshado/project/f28c3a8b-ef9d-404b-9fb0-90812d837979?utm_source=github&utm_medium=referral&page=upgrade-pr
This file contains hidden or 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
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.
Snyk has created this PR to upgrade multiple dependencies.
👯 The following dependencies are linked and will therefore be updated together.ℹ️ Keep your dependencies up-to-date. This makes it easier to fix existing vulnerabilities and to more quickly identify and fix newly disclosed vulnerabilities when they affect your project.
express
from 4.18.1 to 4.19.2 | 5 versions ahead of your current version | 6 months ago
on 2024-03-25
socket.io
from 4.5.1 to 4.7.5 | 13 versions ahead of your current version | 6 months ago
on 2024-03-14
socket.io-client
from 4.5.1 to 4.7.5 | 14 versions ahead of your current version | 6 months ago
on 2024-03-14
Issues fixed by the recommended upgrade:
SNYK-JS-WS-7266574
SNYK-JS-ENGINEIO-5496331
SNYK-JS-SOCKETIO-7278048
SNYK-JS-SOCKETIOPARSER-5596892
SNYK-JS-SOCKETIOPARSER-5596892
SNYK-JS-EXPRESS-6474509
Release notes
Package name: express
-
4.19.2 - 2024-03-25
-
4.19.1 - 2024-03-20
- Fix ci after location patch by @ wesleytodd in #5552
- fixed un-edited version in history.md for 4.19.0 by @ wesleytodd in #5556
-
4.19.0 - 2024-03-20
- fix typo in release date by @ UlisesGascon in #5527
- docs: nominating @ wesleytodd to be project captian by @ wesleytodd in #5511
- docs: loosen TC activity rules by @ wesleytodd in #5510
- Add note on how to update docs for new release by @ crandmck in #5541
- Prevent open redirect allow list bypass due to encodeurl
- Release 4.19.0 by @ wesleytodd in #5551
- @ crandmck made their first contribution in #5541
-
4.18.3 - 2024-02-29
- Fix routing requests without method
- deps: [email protected]
- Fix strict json error message on Node.js 19+
- deps: content-type@~1.0.5
- deps: [email protected]
- Use https: protocol instead of deprecated git: protocol by @ vcsjones in #5032
- build: [email protected] and [email protected] by @ abenhamdine in #5034
- ci: update actions/checkout to v3 by @ armujahid in #5027
- test: remove unused function arguments in params by @ raksbisht in #5124
- Remove unused originalIndex from acceptParams by @ raksbisht in #5119
- Fixed typos by @ raksbisht in #5117
- examples: remove unused params by @ raksbisht in #5113
- fix: parameter str is not described in JSDoc by @ raksbisht in #5130
- fix: typos in History.md by @ raksbisht in #5131
- build : add [email protected] by @ abenhamdine in #5028
- test: remove unused function arguments in params by @ raksbisht in #5137
- use random port in test so it won't fail on already listening by @ rluvaton in #5162
- tests: use cb() instead of done() by @ kristof-low in #5233
- examples: remove multipart example by @ riddlew in #5195
- Update support Node.js@18 in the CI by @ UlisesGascon in #5490
- Fix favicon-related bug in cookie-sessions example by @ DmytroKondrashov in #5414
- Release 4.18.3 by @ UlisesGascon in #5505
- @ vcsjones made their first contribution in #5032
- @ abenhamdine made their first contribution in #5034
- @ armujahid made their first contribution in #5027
- @ raksbisht made their first contribution in #5124
- @ rluvaton made their first contribution in #5162
- @ kristof-low made their first contribution in #5233
- @ riddlew made their first contribution in #5195
- @ DmytroKondrashov made their first contribution in #5414
-
4.18.2 - 2022-10-08
- Fix regression routing a large stack in a single route
- deps: [email protected]
- deps: [email protected]
- perf: remove unnecessary object clone
- deps: [email protected]
-
4.18.1 - 2022-04-29
- Fix hanging on large stack of sync routes
from express GitHub release notesWhat's Changed
Full Changelog: 4.19.0...4.19.1
What's Changed
New Contributors
Full Changelog: 4.18.3...4.19.0
Main Changes
Other Changes
New Contributors
Full Changelog: 4.18.2...4.18.3
Package name: socket.io
-
4.7.5 - 2024-03-14
- close the adapters when the server is closed (bf64870)
- remove duplicate pipeline when serving bundle (e426f3e)
- Diff: 4.7.4...4.7.5
- Client release: 4.7.5
-
4.7.4 - 2024-01-12
- typings: calling io.emit with no arguments incorrectly errored (cb6d2e0), closes #4914
- Diff: 4.7.3...4.7.4
- Client release: 4.7.4
-
4.7.3 - 2024-01-03
- return the first response when broadcasting to a single socket (#4878) (df8e70f)
- typings: allow to bind to a non-secure Http2Server (#4853) (8c9ebc3)
- Diff: 4.7.2...4.7.3
- Client release: 4.7.3
-
4.7.2 - 2023-08-02
- clean up child namespace when client is rejected in middleware (#4773) (0731c0d)
- webtransport: properly handle WebTransport-only connections (3468a19)
- webtransport: add proper framing (a306db0)
- Diff: 4.7.1...4.7.2
- Client release: 4.7.2
-
4.7.1 - 2023-06-28
- Diff: 4.7.0...4.7.1
- Client release: 4.7.1
-
4.7.0 - 2023-06-22
- remove the Partial modifier from the socket.data type (#4740) (e5c62ca)
- https://w3c.github.io/webtransport/
- https://developer.mozilla.org/en-US/docs/Web/API/WebTransport
- https://developer.chrome.com/articles/webtransport/
https://w3c.github.io/webtransport/#custom-certificate-requirements)
- Diff: 4.6.2...4.7.0
- Client release: 4.7.0
-
4.6.2 - 2023-05-31
- exports: move
- Diff: 4.6.1...4.6.2
- Client release: 4.6.2
-
4.6.1 - 2023-02-20
-
4.6.0 - 2023-02-07
-
4.6.0-alpha1 - 2023-01-25
-
4.5.4 - 2022-11-22
-
4.5.3 - 2022-10-15
-
4.5.2 - 2022-09-02
-
4.5.1 - 2022-05-17
from socket.io GitHub release notesBug Fixes
Links
engine.io@~6.5.2(no change)ws@~8.11.0(no change)Bug Fixes
Links
engine.io@~6.5.2(no change)ws@~8.11.0(no change)Bug Fixes
Links
engine.io@~6.5.2(no change)ws@~8.11.0(no change)Bug Fixes
Links
engine.io@~6.5.2(diff)ws@~8.11.0(no change)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)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/webtransportpackage:const cert = readFileSync("/path/to/my/cert.pem");
const key = readFileSync("/path/to/my/key.pem");
const httpsServer = createServer({
key,
cert
});
httpsServer.listen(3000);
const io = new Server(httpsServer, {
transports: ["polling", "websocket", "webtransport"] // WebTransport is not enabled by default
});
const h3Server = new Http3Server({
port: 3000,
host: "0.0.0.0",
secret: "changeit",
cert,
privKey: key,
});
(async () => {
const stream = await h3Server.sessionStream("/socket.io/");
const sessionReader = stream.getReader();
while (true) {
const { done, value } = await sessionReader.read();
if (done) {
break;
}
io.engine.onWebTransportSession(value);
}
})();
h3Server.startServer();">
Added in 123b68c.
Client bundles with CORS headers
The bundles will now have the right
Access-Control-Allow-xxxheaders.Added in 63f181c.
Links
engine.io@~6.5.0(diff)ws@~8.11.0(no change)Bug Fixes
typescondition to the top (#4698) (3d44aae)Links
engine.io@~6.4.2(diff)ws@~8.11.0(no change)Package name: socket.io-client
Bug Fixes
Links
engine.io-client@~6.5.2(no change)ws@~8.11.0(no change)There were some minor bug fixes on the server side, which mandate a client bump.
Links
engine.io-client@~6.5.2(no change)ws@~8.11.0(no change)Bug Fixes
Links
engine.io-client@~6.5.2(no change)ws@~8.11.0(no change)Some bug fixes are included from the
engine.io-clientpackage:Links
engine.io-client@~6.5.2(diff)ws@~8.11.0(no change)Some bug fixes are included from the
engine.io-clientpackage:Links
engine.io-client@~6.5.1(diff)ws@~8.11.0(no change)Bug Fixes
Features
Support for WebTransport
The Engine.IO client 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:
For Node.js clients: until WebTransport support lands in Node.js, you can use the
@ fails-components/webtransportpackage:global.WebTransport = WebTransport;
Added in 7195c0f.
Cookie management for the Node.js client
When setting the
withCredentialsoption totrue, the Node.js client will now include the cookies in the HTTP requests, making it easier to use it with cookie-based sticky sessions.withCredentials: true
});">
Added in 5fc88a6.
Conditional import of the ESM build with debug logs
By default, the ESM build does not include the
debugpackage in the browser environments, because it increases the bundle size (see 16b6569).Which means that, unfortunately, debug logs are not available in the devtools console, even when setting the
localStorage.debug = ...attribute.You can now import the build which includes the
debugpackages with a conditional import. Example with vite:import react from '@ vitejs/plugin-react'
export default defineConfig({
plugins: [react()],
server: {
port: 4000
},
resolve: {
conditions: ["development"]
}
})
Reference: https://v2.vitejs.dev/config/#resolve-conditions
Added in 781d753.
Links
~6.5.0(diff)~8.11.0(no change)Bug Fixes
typescondition to the top (#1580) (7ead241)Links
~6.4.0(no change)~8.11.0(no change)Bug Fixes
Links
~6.4.0(no change)~8.11.0(no change)Bug Fixes
Features
A new "addTrailingSlash" option
The trailing slash which was added by default can now be disabled:
addTrailingSlash: false
});">
In the example above, the request URL will be
https://example.com/socket.ioinstead ofhttps://example.com/socket.io/.Added in 21a6e12.
Promise-based acknowledgements
This commit adds some syntactic sugar around acknowledgements:
const response = await socket.emitWithAck("hello", "world");
// with a specific timeout
try {
const response = await socket.timeout(1000).emitWithAck("hello", "world");
} catch (err) {
// the server did not acknowledge the event in the given delay
}
Note: environments that do not support Promises will need to add a polyfill in order to use this feature.
Added in 47b979d.
Connection state recovery
This feature allows a client to reconnect after a temporary disconnection and restore its ID and receive any packets that was missed during the disconnection gap. It must be enabled on the server side.
A new boolean attribute named
recoveredis added on thesocketobject:Added in 54d5ee0 (server) and b4e20c5 (client).
Retry mechanism
Two new options are available:
retries: the maximum number of retries. Above the limit, the packet will be discarded.ackTimeout: the default timeout in milliseconds used when waiting for an acknowledgement (not to be mixed up with the already existingtimeoutoption, which is used by the Manager during the connection)retries: 3,
ackTimeout: 10000
});
// implicit ack
socket.emit("my-event")<span clas...