I recently rented a tiny VPS with cpanel in order to have a better understanding of all of the cpanel files, scripts, and so on. During browsing cpanel files, I discovered that some scripts are only visible to webmail users, while others are only visible to cPanel or WHM users. I noticed that all links in Webmail go to scripts in the following directories inside /usr/local/cpanel/base/:
data:image/s3,"s3://crabby-images/8427d/8427d44a6a829d1313235a9aee4f2a3275fad65b" alt="🚨 Critical Vulnerability in Sitepad cPanel plugin ≤ 1.7.0 image 10 - 🚨 Critical Vulnerability in Sitepad cPanel plugin ≤ 1.7.0"
So, the next thing that I was checking is which of these directories are also cPanel users accessing, so I logged in as a cPanel user in another browser, crtl+u on the page, and searched for links to these paths.
data:image/s3,"s3://crabby-images/5deed/5deed797575fad1aa723d5335163826ef35833a6" alt="🚨 Critical Vulnerability in Sitepad cPanel plugin ≤ 1.7.0 image 14 - 🚨 Critical Vulnerability in Sitepad cPanel plugin ≤ 1.7.0"
The 3rdparty folder had interesting links such as: PHPMyAdmin and phpPgAdmin:
data:image/s3,"s3://crabby-images/73790/7379002cbe84fdd00387ce227ea1a26f2635a4e8" alt="🚨 Critical Vulnerability in Sitepad cPanel plugin ≤ 1.7.0 image 11 - 🚨 Critical Vulnerability in Sitepad cPanel plugin ≤ 1.7.0"
So I tried accessing them from Webmail, but they were all checking user permissions and wouldn’t let me access them from webmail.
data:image/s3,"s3://crabby-images/0c839/0c83969a2a35d12adba59fead640e121b61f74f6" alt="🚨 Critical Vulnerability in Sitepad cPanel plugin ≤ 1.7.0 image 15 - 🚨 Critical Vulnerability in Sitepad cPanel plugin ≤ 1.7.0"
But, the sitepad link /3rdparty/sitepad/index.live.php was accessible because it’s a simple symlink to the /usr/local/sitepad/www/ directory
data:image/s3,"s3://crabby-images/ce764/ce76471e3e7c205e0cd93a59c09a87b080b4583a" alt="🚨 Critical Vulnerability in Sitepad cPanel plugin ≤ 1.7.0 image 12 - 🚨 Critical Vulnerability in Sitepad cPanel plugin ≤ 1.7.0"
And this file includes the index.php file without checking any permissions:
data:image/s3,"s3://crabby-images/48e3a/48e3a7c8a2cd5cc03445fcd4e9c7677fb40c537b" alt="🚨 Critical Vulnerability in Sitepad cPanel plugin ≤ 1.7.0 image 13 - 🚨 Critical Vulnerability in Sitepad cPanel plugin ≤ 1.7.0"
As a result in cPanel logged-in Webmail users can edit the URL parameters to access Sitepad plugin.
Steps to Reproduce
Steps to reproduce the issue in SitePad ≤ 1.7.0:
- Log into a Webmail (domain.com/webmail)
- Edit URL and add /3rdparty/sitepad/index.live.php after the cpsess_XXX part
that’s it.
data:image/s3,"s3://crabby-images/bad16/bad164fd5e76701b84b72af8bee48e74b32557b5" alt="🚨 Critical Vulnerability in Sitepad cPanel plugin ≤ 1.7.0 image 39 1024x456 - 🚨 Critical Vulnerability in Sitepad cPanel plugin ≤ 1.7.0"
Webmail users can now edit pages or even delete entire websites.
Impact
According to builtwith, there are about 50.000 known Sitepad websites, with around 30.000 of them being vulnerable due to the use of Sitepad Page Builder as a cPanel plugin. This means that any of these sites could be accessed through hacked email accounts or former employees.
Because a single cPanel account can host many domains/websites, the majority of these sites can be used to obtain access to other websites on the account, including WordPress sites.
This extends the total number of websites and cpanel accounts that can be potentially exploited with this bug to thousands more.
Vulnerability is Fixed in SitePad 1.7.1
I reported the vulnerability to Sitepad and the next day they notified me that they’ve started working on fixing it.
data:image/s3,"s3://crabby-images/34f7b/34f7b77549e220f8bcdfcc2be85ab12e7dea50b9" alt="🚨 Critical Vulnerability in Sitepad cPanel plugin ≤ 1.7.0 image 9 - 🚨 Critical Vulnerability in Sitepad cPanel plugin ≤ 1.7.0"
In SitePad 1.7.1 the issue was fixed:
data:image/s3,"s3://crabby-images/906ca/906cab3f2357bb2b5c3368a8bfb5fb6400564e84" alt="🚨 Critical Vulnerability in Sitepad cPanel plugin ≤ 1.7.0 chrome NojXcO23xk 1024x499 - 🚨 Critical Vulnerability in Sitepad cPanel plugin ≤ 1.7.0"
By adding the following check inside the index.php file
data:image/s3,"s3://crabby-images/4206b/4206ba053945f01ba0a2795113efdeb046101174" alt="🚨 Critical Vulnerability in Sitepad cPanel plugin ≤ 1.7.0 image 118 - 🚨 Critical Vulnerability in Sitepad cPanel plugin ≤ 1.7.0"
And now if you try to access SitePad from a Webmail account you will get an error message: Child failed to make LIVEAPI connection to cPanel.
data:image/s3,"s3://crabby-images/d3b37/d3b378b2238250e9a4b14aa9940b16111f0eb8b9" alt="🚨 Critical Vulnerability in Sitepad cPanel plugin ≤ 1.7.0 image 117 - 🚨 Critical Vulnerability in Sitepad cPanel plugin ≤ 1.7.0"
Report Timeline
- 30.03.2022 – Vulnerability discovered
- 31.03.2022 – Report submitted to Softaculous – ticket ID #156870
- 01.04.2022 – Softaculous replicated the issue
- 13.04.2022 – The issue is resolved in version 1.7.1
- 01.05.2022 – Vulnerability disclosed on this blog