Description
In nghttp2 before version 1.41.0, the overly large HTTP/2 SETTINGS frame payload causes denial of service. The proof of concept attack involves a malicious client constructing a SETTINGS frame with a length of 14,400 bytes (2400 individual settings entries) over and over again. The attack causes the CPU to spike at 100%. nghttp2 v1.41.0 fixes this vulnerability. There is a workaround to this vulnerability. Implement nghttp2_on_frame_recv_callback callback, and if received frame is SETTINGS frame and the number of settings entries are large (e.g., > 32), then drop the connection.
Remediation
References
Related Vulnerabilities
Joomla Insufficient Verification of Data Authenticity Vulnerability (CVE-2020-15699)
phpMyAdmin Exposure of Sensitive Information to an Unauthorized Actor Vulnerability (CVE-2013-5000)
WordPress Plugin Swiss Toolkit For WP Security Bypass (1.0.7)
Plone CMS Permissions, Privileges, and Access Controls Vulnerability (CVE-2016-4041)