Bug 2239392 (CVE-2021-32751) - CVE-2021-32751 gradle: Arbitrary code execution via specially crafted environment variables
Summary: CVE-2021-32751 gradle: Arbitrary code execution via specially crafted environ...
Keywords:
Status: NEW
Alias: CVE-2021-32751
Product: Security Response
Classification: Other
Component: vulnerability
Version: unspecified
Hardware: All
OS: Linux
medium
medium
Target Milestone: ---
Assignee: Product Security
QA Contact:
URL:
Whiteboard:
Depends On: 2239394 2239395 2239396
Blocks: 2107217
TreeView+ depends on / blocked
 
Reported: 2023-09-18 06:59 UTC by Avinash Hanwate
Modified: 2023-09-30 15:38 UTC (History)
26 users (show)

Fixed In Version: Gradle 7.2
Doc Type: If docs needed, set a value
Doc Text:
A flaw was found in Gradle, which allows a remote, authenticated attacker to execute arbitrary code on the system caused by a flaw in start and gradlew. By sending specially crafted environment variables, an attacker can execute arbitrary code on the system.
Clone Of:
Environment:
Last Closed:
Embargoed:


Attachments (Terms of Use)

Description Avinash Hanwate 2023-09-18 06:59:24 UTC
Gradle is a build tool with a focus on build automation. In versions prior to 7.2, start scripts generated by the `application` plugin and the `gradlew` script are both vulnerable to arbitrary code execution when an attacker is able to change environment variables for the user running the script. This may impact those who use `gradlew` on Unix-like systems or use the scripts generated by Gradle in their application on Unix-like systems. For this vulnerability to be exploitable, an attacker needs to be able to set the value of particular environment variables and have those environment variables be seen by the vulnerable scripts. This issue has been patched in Gradle 7.2 by removing the use of `eval` and requiring the use of the `bash` shell. There are a few workarounds available. For CI/CD systems using the Gradle build tool, one may ensure that untrusted users are unable to change environment variables for the user that executes `gradlew`. If one is unable to upgrade to Gradle 7.2, one may generate a new `gradlew` script with Gradle 7.2 and use it for older versions of Gradle. For applications using start scripts generated by Gradle, one may ensure that untrusted users are unable to change environment variables for the user that executes the start script. A vulnerable start script could be manually patched to remove the use of `eval` or the use of environment variables that affect the application's command line. If the application is simple enough, one may be able to avoid the use of the start scripts by running the application directly with Java command.

Comment 1 Avinash Hanwate 2023-09-18 07:08:16 UTC
Created picocli tracking bugs for this issue:

Affects: fedora-38 [bug 2239395]


Note You need to log in before you can comment on or make changes to this bug.