Description
The Blocksy theme for WordPress is vulnerable to PHP Object Injection leading to Remote Code Execution via the 'blocksy_meta' REST API field and the V200 database migration in versions up to and including 2.1.35. This is due to insufficient input sanitization in the blocksy_sanitize_post_meta_options() function, which only blocks values containing '<' or '>' and does not prevent serialized PHP object strings from being stored in post meta, combined with the SearchReplacer::run_recursively() function unconditionally deserializing all string values via @unserialize() during migration without restricting allowed classes. This makes it possible for authenticated attackers, with contributor-level access and above, to inject a serialized Blocksy\RaiiPattern object into post meta that, when the V200 migration runs on an upgraded site, is deserialized and triggers RaiiPattern::__destruct(), which executes arbitrary PHP callables via call_user_func().
Problem types
CWE-502 Deserialization of Untrusted Data
Product status
Any version
Timeline
| 2026-05-12: | Vendor Notified |
| 2026-06-08: | Disclosed |
Credits
Quốc Huy
References
www.wordfence.com/...-ce8d-4632-9fd1-d63502c2dfcd?source=cve
themes.trac.wordpress.org/...ng/utils/db-search-replacer.php
themes.trac.wordpress.org/...ng/utils/db-search-replacer.php
themes.trac.wordpress.org/...nk/admin/helpers/meta-boxes.php
themes.trac.wordpress.org/...41/admin/helpers/meta-boxes.php
themes.trac.wordpress.org/...unk/admin/helpers/validator.php
themes.trac.wordpress.org/....41/admin/helpers/validator.php
themes.trac.wordpress.org/...cksy/trunk/inc/classes/raii.php
themes.trac.wordpress.org/...ksy/2.1.41/inc/classes/raii.php
themes.trac.wordpress.org/...ng/utils/db-search-replacer.php
themes.trac.wordpress.org/...35/admin/helpers/meta-boxes.php
themes.trac.wordpress.org/....35/admin/helpers/validator.php
themes.trac.wordpress.org/...ksy/2.1.35/inc/classes/raii.php