pypdf is a pure-python PDF library capable of splitting, merging, cropping, and transforming the pages of PDF files. In version 2.10.5 an attacker who uses this vulnerability can craft a PDF which leads to an infinite loop. This infinite loop blocks the current process and can utilize a single core of the CPU by 100%. It does not affect memory usage. That is, for example, the case if the user extracted metadata from such a malformed PDF. Versions prior to 2.10.5 throw an error, but do not hang forever. This issue was fixed with https://github.com/py-pdf/pypdf/pull/1331 which has been included in release 2.10.6. Users are advised to upgrade. Users unable to upgrade should modify `PyPDF2/generic/_data_structures.py::read_object` to an an error throwing case. See GHSA-hm9v-vj3r-r55m for details.
References
Link Resource
https://github.com/py-pdf/pypdf/issues/1329 Exploit Issue Tracking Vendor Advisory
https://github.com/py-pdf/pypdf/pull/1331 Patch
https://github.com/py-pdf/pypdf/security/advisories/GHSA-hm9v-vj3r-r55m Exploit Mitigation Patch Vendor Advisory
History

No history.

cve-icon MITRE Information

Status: PUBLISHED

Assigner: GitHub_M

Published: 2023-06-30T18:38:10.303Z

Updated: 2023-06-30T18:38:10.303Z

Reserved: 2023-06-27T15:43:18.383Z


Link: CVE-2023-36807

JSON object: View

cve-icon NVD Information

Status : Analyzed

Published: 2023-06-30T19:15:09.283

Modified: 2023-07-10T16:32:45.017


Link: CVE-2023-36807

JSON object: View

cve-icon Redhat Information

No data.

CWE