chore(deps): update dependency webpack-dev-server to v5 [security] #3272
  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:
3.11.3->5.2.1GitHub Vulnerability Alerts
CVE-2025-30359
Summary
Source code may be stolen when you access a malicious web site.
Details
Because the request for classic script by a script tag is not subject to same origin policy, an attacker can inject
<script src="http://localhost:8080/main.js">in their site and run the script. Note that the attacker has to know the port and the output entrypoint script path. Combined with prototype pollution, the attacker can get a reference to the webpack runtime variables.By using
Function::toStringagainst the values in__webpack_modules__, the attacker can get the source code.PoC
npm inpx webpack-dev-serverhttps://e29c9a88-a242-4fb4-9e64-b24c9d29b35b.pages.dev/The script in the POC site is:
This script uses the function generated by
renderRequire.Especially, it uses the fact that
Array::forEachis called for__webpack_require__.iandexecOptionscontains__webpack_require__.It uses prototype pollution against
Array::forEachto extract__webpack_require__reference.Impact
This vulnerability can result in the source code to be stolen for users that uses a predictable port and output path for the entrypoint script.
Old content
Summary
Source code may be stolen when you use
output.iife: falseand access a malicious web site.Details
When
output.iife: falseis set, some global variables for the webpack runtime are declared on thewindowobject (e.g.__webpack_modules__).Because the request for classic script by a script tag is not subject to same origin policy, an attacker can inject
<script src="http://localhost:8080/main.js">in their site and run the script. Note that the attacker has to know the port and the output entrypoint script path. By running that, the webpack runtime variables will be declared on thewindowobject.By using
Function::toStringagainst the values in__webpack_modules__, the attacker can get the source code.I pointed out
output.iife: false, but if there are other options that makes the webpack runtime variables to be declared on thewindowobject, the same will apply for those cases.PoC
npm inpx webpack-dev-serverhttps://852aafa3-5f83-44da-9fc6-ea116d0e3035.pages.dev/src/index.jsand other scripts loaded.The script in the POC site is:
Impact
This vulnerability can result in the source code to be stolen for users that has
output.iife: falseoption set and uses a predictable port and output path for the entrypoint script.CVE-2025-30360
Summary
Source code may be stolen when you access a malicious web site with non-Chromium based browser.
Details
The
Originheader is checked to prevent Cross-site WebSocket hijacking from happening which was reported by CVE-2018-14732.But webpack-dev-server always allows IP address
Originheaders.https://github.com/webpack/webpack-dev-server/blob/55220a800ba4e30dbde2d98785ecf4c80b32f711/lib/Server.js#L3113-L3127
This allows websites that are served on IP addresses to connect WebSocket.
By using the same method described in the article linked from CVE-2018-14732, the attacker get the source code.
related commit: webpack/webpack-dev-server@72efaab (note that
checkHostfunction was only used for Host header to prevent DNS rebinding attacks so this change itself is fine.This vulnerability does not affect Chrome 94+ (and other Chromium based browsers) users due to the non-HTTPS private access blocking feature.
PoC
npm inpx webpack-dev-serverhttp://{ipaddress}/?target=http://localhost:8080&file=mainwith a non-Chromium browser (I used Firefox 134.0.1)src/index.jsin the extracted directorysrc/index.jsThe script in the POC site is:
Impact
This vulnerability can result in the source code to be stolen for users that uses a predictable port and uses a non-Chromium based browser.
Release Notes
webpack/webpack-dev-server (webpack-dev-server)
v5.2.1Compare Source
Security
Access-Control-Allow-OriginheaderOriginheader are not allowed to connect to WebSocket server unless configured byallowedHostsor it different from theHostheaderThe above changes may make the dev server not work if you relied on such behavior, but unfortunately they carry security risks, so they were considered as fixes.
Bug Fixes
v5.2.0Compare Source
Features
getClientEntryandgetClientHotEntrymethods to get clients entries (dc642a8)Bug Fixes
v5.1.0Compare Source
Features
appoption to beFunction(by default only withconnectcompatibility frameworks) (3096148)serveroption to beFunction(#5275) (02a1c6d)connectandconnectcompatibility frameworks which support HTTP2 (#5267) (6509a3f)Bug Fixes
platformproperty to determinate the target (#5269) (c3b532c)rimrafwithrm(#5162) (1a1561f)devServer: false(#5272) (8b341cb)5.0.4 (2024-03-19)
Bug Fixes
5.0.3 (2024-03-12)
Bug Fixes
5.0.2 (2024-02-16)
Bug Fixes
5.0.1 (2024-02-13)
Bug Fixes
require-trusted-types-for(#5046) (e115436)v5.0.4Compare Source
v5.0.3Compare Source
v5.0.2Compare Source
v5.0.1Compare Source
v5.0.0Compare Source
Migration Guide and Changes.
4.15.1 (2023-06-09)
Bug Fixes
::withlocalhostbefore openBrowser() (#4856) (874c44b)@types/ws(#4899) (34bcec2)v4.15.2Compare Source
4.15.2 (2024-03-20)
Bug Fixes
v4.15.1Compare Source
v4.15.0Compare Source
Features
v4.14.0Compare Source
Features
4.13.3 (2023-04-15)
Bug Fixes
4.13.2 (2023-03-31)
Bug Fixes
4.13.1 (2023-03-18)
Bug Fixes
v4.13.3Compare Source
v4.13.2Compare Source
v4.13.1Compare Source
v4.13.0Compare Source
Features
client.overlay.runtimeErrorsoption to control runtime errors (#4773) (dca2366)v4.12.0Compare Source
Features
sockjs_urloption (onlysockjs) using thewebSocketServer.options.sockjsUrloption (#4586) (69a2fba)Bug Fixes
experiments.buildHttp(#4585) (5b846cb)NODE_PATHenv variable (#4581) (b857e6f)4.11.1 (2022-09-19)
Bug Fixes
client.loggingoption for all logs (#4572) (375835c)v4.11.1Compare Source
v4.11.0Compare Source
Features
Bug Fixes
4.10.1 (2022-08-29)
Bug Fixes
v4.10.1Compare Source
v4.10.0Compare Source
Features
clientoptions via resource URL (#4274) (216e3cb)Bug Fixes
4.9.3 (2022-06-29)
Bug Fixes
4.9.2 (2022-06-06)
Bug Fixes
@types/serve-staticto dependencies (#4468) (af83deb)4.9.1 (2022-05-31)
Bug Fixes
v4.9.3Compare Source
v4.9.2Compare Source
v4.9.1Compare Source
v4.9.0Compare Source
Features
Bug Fixes
4.8.1 (2022-04-06)
Bug Fixes
v4.8.1Compare Source
v4.8.0Compare Source
Features
Bug Fixes
--no-client-reconnect(#4248) (317648d)--no-client(#4250) (c3b6690)--no-history-api-fallback(#4277) (d63a0a2)negatedDescriptiononly for typeboolean(#4280) (fcf8e8e)4.7.4 (2022-02-02)
Bug Fixes
proxyoption (#4173) (efec2f5)--open-app-nameand--web-socket-server(#4215) (329679a)4.7.3 (2022-01-11)
Security
selfsignedto2.0.0version4.7.2 (2021-12-29)
Bug Fixes
onAfterSetupMiddlewareaftersetupMiddlewares(as behavior earlier) (f6bc644)4.7.1 (2021-12-22)
Bug Fixes
urlpackage, fixed compatibility with future webpack defaults (#4132) (4e5d8ea)v4.7.4Compare Source
v4.7.3Compare Source
v4.7.2Compare Source
v4.7.1Compare Source
v4.7.0Compare Source
Features
setupMiddlewaresoption and deprecatedonAfterSetupMiddlewareandonBeforeSetupMiddlewareoptions (#4068) (c13aa56)cacertoption (#4115) (c73ddfb)Bug Fixes
watchFilesoptions (#4057) (75f3817)ClientLogging(#4084) (9b7ae7b)--open-appdeprecated in favor of--open-app-name(#4091) (693c28a)httpsandhttp2(#4069) (d8d5d71)--web-socket-serverdescription (#4098) (65955e9)listenandclosedeprecation warning message (#4097) (b217a19)httpsandserveroptions (#4094) (f97c9e2)v4.6.0Compare Source
Features
chokidaroptions (#4025) (5026601)Bug Fixes
v4.5.0Compare Source
Features
--web-socket-server-typeoption for CLI (#4001) (17c390a)https/http2option, migration guide forhttpsand migration guide forhttp2(because we usespdyfor http2 dueexpressdoesn't support http2) (#4003) (521cf85)Bug Fixes
v4.4.0Compare Source
Features
serveroption, now you can pass server options, example{ server: { type: 'http', options: { maxHeaderSize: 32768 } } }, available options forhttpandhttps, note - forhttp2is usedspdy, options specified in theserver.optionsoption take precedence overhttps/http2options (#3940) (a70a7ef)client.reconnectoption (#3912) (5edad76)startCallbackandendCallback(#3969) (b0928ac)Bug Fixes
4.3.1 (2021-10-04)
Bug Fixes
v4.3.1Compare Source
v4.3.0Compare Source
Features
headersoption (#3847) (9911437)Bug Fixes
portoption property (ed67f66)4.2.1 (2021-09-13)
Bug Fixes
4.2.0 (2021-09-09)
Features
http.caoption (CLI option added too) (should be used insteadcacert, because we will remove it in the next major release in favor thehttps.caoption)https.crloption (CLI options added too), more informationhttps.ca/https.cacert/https.cert/https.crl/https.key/https.pfxoptions are now accept Arrays ofBuffer/string/Path to file, using--https-*-resetCLI options you can reset these optionshttps.pfx/https.keycan beObject[], more informationhttpsoptions can now accept custom options, you can use:Bug Fixes
file:andchrome-extensions:protocol by default (#3822) (138f064)https.cacertoption (#3820) (0002ebf)4.1.1 (2021-09-07)
Bug Fixes
magicHtmloption (#3772) (b80610f)ansi-htmlwithansi-html-communityto avoid CVE (#3801) (36fd214)v4.2.1Compare Source
v4.2.0Compare Source
v4.1.1Compare Source
v4.1.0Compare Source
Features
magicHtmloption (#3717) (4831f58)hotandlive-reloadfor client using search params (1c57680)hotoption is enabled with the HMR plugin in config (#3744) (6cb1e4e)Bug Fixes
Disconnected!toinfo(fde27f5)--allowed-hosts allcorrectly (#3720) (326ed56)bypassoption withtarget/routeroptions for proxy (b5dd568)v4.0.0Compare Source
Configuration
📅 Schedule: Branch creation - "" in timezone America/New_York, Automerge - At any time (no schedule defined).
🚦 Automerge: Disabled by config. Please merge this manually once you are satisfied.
♻ Rebasing: Never, or you tick the rebase/retry checkbox.
🔕 Ignore: Close this PR and you won't be reminded about this update again.
This PR was generated by Mend Renovate. View the repository job log.