Infinite Loop when reading malformed objects in pypdf
Description
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.
AI Insight
LLM-synthesized narrative grounded in this CVE's description and references.
Affected packages
Versions sourced from the GitHub Security Advisory.
| Package | Affected versions | Patched versions |
|---|---|---|
PyPDF2PyPI | >= 2.10.5, < 2.10.6 | 2.10.6 |
Affected products
2Patches
Vulnerability mechanics
References
6- github.com/advisories/GHSA-hm9v-vj3r-r55mghsaADVISORY
- nvd.nist.gov/vuln/detail/CVE-2023-36807ghsaADVISORY
- github.com/py-pdf/pypdf/commit/e6531a25325e7e0174b6a1ba03b57320b5227f6bghsaWEB
- github.com/py-pdf/pypdf/issues/1329ghsax_refsource_MISCWEB
- github.com/py-pdf/pypdf/pull/1331ghsax_refsource_MISCWEB
- github.com/py-pdf/pypdf/security/advisories/GHSA-hm9v-vj3r-r55mghsax_refsource_CONFIRMWEB
News mentions
0No linked articles in our index yet.