CVE-2026-45162
Published:May 27, 2026
Updated:June 13, 2026
GM-374 Summary Multiple locations in Pimcore v11 call PHP's "unserialize()" on data from database columns and filesystem files without the "allowed_classes" restriction, enabling object injection if an attacker can control the serialized data source. Affected Component - Package: "pimcore/pimcore" and "pimcore/admin-ui-classic-bundle" - Files: - "lib/Tool/Authentication.php" (line 82) — session token deserialization - "models/Site/Dao.php" (line 68) — site domains from database - "models/DataObject/ClassDefinition/CustomLayout/Dao.php" (line 69) — layout definitions from database - "models/Tool/TmpStore/Dao.php" (line 64) — temporary store data from database - "models/Asset/WebDAV/Service.php" (line 36) — delete log from filesystem - "admin-ui-classic-bundle/src/Helper/Dashboard.php" (line 64) — dashboard config from filesystem Description Six locations in Pimcore core call "unserialize()" directly (bypassing "Tool\Serialize") on data sourced from database columns or filesystem files without passing the "allowed_classes" parameter. This means any class available in the autoloader will be instantiated during deserialization. If an attacker can write to the data source (e.g., via SQL injection targeting the "tmp_store", "sites", or "custom_layouts" tables, or via a file write vulnerability targeting the WebDAV delete log), they can inject serialized PHP gadget chains that execute arbitrary code when the data is deserialized. This is related to but distinct from the "Tool\Serialize::unserialize()" issue — these calls bypass the wrapper entirely. Impact PHP object injection leading to Remote Code Execution when chained with a data source write vulnerability. Pimcore's dependency tree (Guzzle, Symfony, Monolog, Doctrine) provides numerous known gadget chains. Proof of Concept 1. Identify a writable data source (e.g., "tmp_store" table via SQL injection, or "webdav-delete.dat" via file write) 2. Write a serialized PHP gadget chain (e.g., Monolog "BufferHandler" chain from phpggc) 3. Trigger the deserialization (e.g., access a page that reads TmpStore, or trigger a WebDAV operation) 4. The gadget chain executes with web server privileges Suggested Fix Add "allowed_classes" parameter to all "unserialize()" calls. Where no objects are needed, use "['allowed_classes' => false]". Consider migrating to JSON serialization for data that doesn't require object preservation. // Example fix for Site/Dao.php: $siteDomains = unserialize($site['domains'], ['allowed_classes' => false]); // Example fix for TmpStore/Dao.php: $item['data'] = unserialize($item['data'], ['allowed_classes' => false]); Resources - CWE-502: Deserialization of Untrusted Data - OWASP Deserialization Cheat Sheet - phpggc: PHP Generic Gadget Chains
Affected Packages
https://github.com/pimcore/pimcore.git (GITHUB):
Affected version(s) >=v5.0.0-RC <v12.3.7Fix Suggestion:
Update to version v12.3.7pimcore/pimcore (PHP):
Affected version(s) >=dev-release_10-4 <v12.3.7Fix Suggestion:
Update to version v12.3.7Related Resources (5)
Do you need more information?
Contact UsCVSS v4
Base Score:
8.9
Attack Vector
NETWORK
Attack Complexity
HIGH
Attack Requirements
NONE
Privileges Required
HIGH
User Interaction
NONE
Vulnerable System Confidentiality
HIGH
Vulnerable System Integrity
HIGH
Vulnerable System Availability
HIGH
Subsequent System Confidentiality
HIGH
Subsequent System Integrity
HIGH
Subsequent System Availability
HIGH
CVSS v3
Base Score:
8
Attack Vector
NETWORK
Attack Complexity
HIGH
Privileges Required
HIGH
User Interaction
NONE
Scope
CHANGED
Confidentiality
HIGH
Integrity
HIGH
Availability
HIGH
Weakness Type (CWE)
Deserialization of Untrusted Data
EPSS
Base Score:
0.20