Gradle's failure to disable repositories failing to answer can expose builds to malicious artifacts
Description
Gradle is a build automation tool, and its native-platform tool provides Java bindings for native APIs. When resolving dependencies in versions before 9.3.0, some exceptions were not treated as fatal errors and would not cause a repository to be disabled. If a build encountered one of these exceptions, Gradle would continue to the next repository in the list and potentially resolve dependencies from a different repository. An exception like NoHttpResponseException can indicate transient errors. If the errors persist after a maximum number of retries, Gradle would continue to the next repository. This behavior could allow an attacker to disrupt the service of a repository and leverage another repository to serve malicious artifacts. This attack requires the attacker to have control over a repository after the disrupted repository. Gradle has introduced a change in behavior in Gradle 9.3.0 to stop searching other repositories when encountering these errors.
AI Insight
LLM-synthesized narrative grounded in this CVE's description and references.
Affected products
5- osv-coords3 versions
< 8.14.4-r0+ 2 more
- (no CPE)range: < 8.14.4-r0
- (no CPE)range: < 8.14.4-r0
- (no CPE)range: < 9.3.0
Patches
Vulnerability mechanics
References
1- github.com/gradle/gradle/security/advisories/GHSA-mqwm-5m85-gmcvmitrex_refsource_CONFIRM
News mentions
0No linked articles in our index yet.