GHSA-7c2q-5qmr-v76q

Suggest an improvement
Source
https://github.com/advisories/GHSA-7c2q-5qmr-v76q
Import Source
https://github.com/github/advisory-database/blob/main/advisories/github-reviewed/2023/10/GHSA-7c2q-5qmr-v76q/GHSA-7c2q-5qmr-v76q.json
JSON Data
https://api.osv.dev/v1/vulns/GHSA-7c2q-5qmr-v76q
Published
2023-10-27T21:55:44Z
Modified
2024-12-06T05:38:37.245326Z
Severity
  • 7.5 (High) CVSS_V3 - CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:H CVSS Calculator
Summary
DoS vulnerabilities persist in ESAPI file uploads despite remediation of CVE-2023-24998
Details

Impact

ESAPI 2.5.2.0 and later addressed the DoS vulnerability described in CVE-2023-24998, which Apache Commons FileUpload 1.5 attempted to remediate. But while writing up a new security bulletin regarding the impact on the affected ESAPI HTTPUtilities.getFileUploads methods (or more specifically those methods in the DefaultHTTPUtilities implementation class), I realized that a DoS vulnerability still persists in ESAPI and for that matter in Apache Commons FileUpload as well.

Related to

CVE-2023-24998

Patches

ESAPI 2.5.2.0 or later.

Workarounds

  • See the 'Solutions' section of Security Bulletin 11, in the References section. If you are not using ESAPI file uploads, see also the 'Workarounds' section.
  • Deploy an external WAF or other suitable DoS protection.
  • Add additional defenses to your code using HTTPUtilities.getFileUpload, such as requiring prior authentication, restricting how many / much content can be uploaded per user per day or per hour, etc. (It is the opinion of the ESAPI development team that such required controls should not be added to ESAPI because it is a general purpose security library and thus ESAPI ought not be enforcing generic policies like these on everyone, especially it it could break existing code bases.)

References

Security Bulletin 11: How Does CVE-2023-24998 Impact ESAPI? New ESAPI 2.5.2.0 or later Javadoc on HTTPUtilities.getFileUploads: https://javadoc.io/static/org.owasp.esapi/esapi/2.5.2.0/org/owasp/esapi/HTTPUtilities.html#getFileUploads-javax.servlet.http.HttpServletRequest-java.io.File-java.util.List- (Note: This link won't work until the 2.5.2.0 release is made official.)

Final Word

(Especially to GitHub Advance Security team / GitHub as a CNA) -- I do not really wish to file a CVE for this. I had originally considered it, but there is no real way to address the general DoS scenarios for file uploads without breaking ESAPI client code which we are not willing to do. The clients have to take some responsibility for this themselves. In the next ESAPI release, I am going to add a reference to the appropriate Javadoc to this GitHub Security Advisory, but that's the best we can do. If you wish to discuss this with me, please first contact me via email at kevin.w.wall@gmail.com.

Database specific
{
    "nvd_published_at": null,
    "cwe_ids": [],
    "severity": "HIGH",
    "github_reviewed": true,
    "github_reviewed_at": "2023-10-27T21:55:44Z"
}
References

Affected packages

Maven / org.owasp.esapi:esapi

Package

Name
org.owasp.esapi:esapi
View open source insights on deps.dev
Purl
pkg:maven/org.owasp.esapi/esapi

Affected ranges

Type
ECOSYSTEM
Events
Introduced
0Unknown introduced version / All previous versions are affected
Fixed
2.5.2.0

Affected versions

2.*

2.0GA
2.0_rc9
2.0_rc10
2.0_rc11
2.0.1
2.1.0
2.1.0.1
2.2.0.0-RC2
2.2.0.0-RC3
2.2.0.0
2.2.1.0-RC1
2.2.1.0
2.2.1.1
2.2.2.0
2.2.3.0
2.2.3.1
2.3.0.0
2.4.0.0
2.5.0.0
2.5.1.0