data:image/s3,"s3://crabby-images/a416a/a416a17e11dfcd52081f8a00e85aa5edaff2ce57" alt=""
Rpc.cgi
After the XXE, we found another bug in Webmin. This time it’s rpc.cgi which is vulnerable. More precisely a call to “unserialise_variable” function is done before than checking if the current user is root, admin or sysadm. As parameter of “unserialise_variable”, there is the content of the HTTP POST request :
data:image/s3,"s3://crabby-images/74f38/74f38ac0cd4230fda15e861250bc950f9528af75" alt=""
Web-lib-funcs.pl
In order to call rpc.cgi and trigger the vulnerability we need 2 prerequisites :
- User-agent set to “webmin” (Webmin interprets this as log with basic auth rather than session cookie) ;
- Valid Basic auth for a user of Webmin (for this exemple, we use a freshly created user “toto” with default rights).
Once these two conditions are met we can go further and look around unserialise_variable in web-lib-funcs.pl :
data:image/s3,"s3://crabby-images/9cbcb/9cbcbff1a23de627418e7e02192a7076706015dc" alt=""
If someone POST an OBJECT it will be used directly in the “eval” statement and so… executed… as root. More precisely it’s $cls that will be executed which corresponds to the regexp match.
Exploit
The only thing left to do is write our own code and display the result.
data:image/s3,"s3://crabby-images/4a2ea/4a2ea17fe8a84eda7d7ebf7b5470b5203afd75fb" alt=""
Response from vendor / fix
Thanks for the bug report! Can you check if this patch fixes the issue for you : https://github.com/webmin/
webmin/commit/ df8a43fb4bdc9c858874f72773bcba 597ae9432c Fortunately this isn’t super high risk, as any Webmin user with permissions to call rpc.cgi can already execute any code was root.
data:image/s3,"s3://crabby-images/9ec43/9ec43297af5a70c28fa5aaf82e3e0bb16a9771e4" alt=""
“Fortunately this isn’t super high risk, as any Webmin user with permissions to call rpc.cgi can already execute any code was root. ”
FYI this is incorrect. This bug allows users to escalate privileges to root.