Skip to content

Arbitrary remote code execution within `wrangler dev` Workers sandbox

Critical severity GitHub Reviewed Published Dec 29, 2023 in cloudflare/workers-sdk • Updated Jan 3, 2024

Package

npm wrangler (npm)

Affected versions

>= 3.0.0, < 3.19.0
>= 2.0.0, < 2.20.2

Patched versions

3.19.0
2.20.2

Description

Impact

The V8 inspector intentionally allows arbitrary code execution within the Workers sandbox for debugging. wrangler dev would previously start an inspector server listening on all network interfaces. This would allow an attacker on the local network to connect to the inspector and run arbitrary code. Additionally, the inspector server did not validate Origin/Host headers, granting an attacker that can trick any user on the local network into opening a malicious website the ability to run code. If wrangler dev --remote was being used, an attacker could access production resources if they were bound to the worker.

Patches

This issue was fixed in wrangler@3.19.0 and wrangler@2.20.2. Whilst wrangler dev's inspector server listens on local interfaces by default as of wrangler@3.16.0, an SSRF vulnerability in miniflare allowed access from the local network until wrangler@3.18.0. wrangler@3.19.0 and wrangler@2.20.2 introduced validation for the Origin/Host headers.

Workarounds

Unfortunately, Wrangler doesn't provide any configuration for which host that inspector server should listen on. Please upgrade to at least wrangler@3.16.0, and configure Wrangler to listen on local interfaces instead with wrangler dev --ip 127.0.0.1 to prevent SSRF. This removes the local network as an attack vector, but does not prevent an attack from visiting a malicious website.

References

References

@mskowroncf mskowroncf published to cloudflare/workers-sdk Dec 29, 2023
Published by the National Vulnerability Database Dec 29, 2023
Published to the GitHub Advisory Database Jan 3, 2024
Reviewed Jan 3, 2024
Last updated Jan 3, 2024

Severity

Critical
9.3
/ 10

CVSS base metrics

Attack vector
Adjacent
Attack complexity
Low
Privileges required
None
User interaction
None
Scope
Changed
Confidentiality
High
Integrity
High
Availability
None
CVSS:3.1/AV:A/AC:L/PR:N/UI:N/S:C/C:H/I:H/A:N

Weaknesses

CVE ID

CVE-2023-7080

GHSA ID

GHSA-f8mp-x433-5wpf

Credits

Checking history
See something to contribute? Suggest improvements for this vulnerability.