#Exploit Title: CMS Made Simple v2.2.17 – Stored Cross-Site Scripting (XSS) (Authenticated)
#Date: 25 June 2023
#Exploit Author: Okan Kurtulus
#Vendor Homepage: https://www.cmsmadesimple.org
#Version: 2.2.17
#Tested on: Ubuntu 18.04
#CVE: 2023-36970
#Proof of Concept:
1-) Install the system through the website and login with any user. (It is also possible to login with low authorized users.)
2-) After logging in, click “File Manager” under “Content” from the left menu.
data:image/s3,"s3://crabby-images/d678c/d678cd01c36b40476ec850e1eda7700e3b12df21" alt=""
3-) At first, I wanted to upload by adding the XSS payload to the file name, but I encountered an error. My guess is there is a control mechanism.
data:image/s3,"s3://crabby-images/dc669/dc669e4046e612739663c176f8b12b371f24aa2d" alt=""
data:image/s3,"s3://crabby-images/6e1f3/6e1f382ef01d8bbd3fadff54650f69ec32a6f11c" alt=""
4-) Then I caught the normal file upload request with HTTP proxy. In the relevant request, I sent a payload to the filename parameter as follows.
1.txt<img src=x onerror=alert(1)>
data:image/s3,"s3://crabby-images/0395c/0395c4c5f3552adcbc0fb0b97ec4166d7e9c2f40" alt=""
data:image/s3,"s3://crabby-images/7c942/7c94216ae004a70e1e1850b31979dd4d799ea642" alt=""
5-) We see that Stored XSS is triggered when we click on the “File Manager” button under “Content” in the left menu.
data:image/s3,"s3://crabby-images/98457/984575f9f114cb3c56f938fb586eda59ee58741c" alt=""