### Postauth RCE in latest NagiosXI
[Last time](https://code610.blogspot.com/2019/12/multiple-xss-bugs-in-nagios-569.html) I described few XSS bugs for latest Nagios (5.6.9). During the research and code review I found a possibility for RCE. Below you will find the details from the journey. Here we go...
We will ([again](https://code610.blogspot.com/2019/12/multiple-xss-bugs-in-nagios-569.html)) start here:
data:image/s3,"s3://crabby-images/6625a/6625a76727852d196d10417a0d8a6a32faa9a983" alt=""
I used 'latest' available version - 5.6.9 - for VirtualBox, downloaded [here.](https://www.nagios.com/downloads/nagios-xi/vmware/)
As you (probably;)) [read/remember](https://code610.blogspot.com/2019/12/multiple-xss-bugs-in-nagios-569.html), in scheduled reporting we have a persistent XSS. [Sometimes](https://code610.blogspot.com/p/found.html) when I found a bug 'related to OWASP' (so for example: XSS) I'm trying to check the source code of webapp ('if available') to look for similar cases:
data:image/s3,"s3://crabby-images/166c4/166c4d6811c069a617e77bdc320ebe5896e16870" alt=""
So, to see a bigger picture:
data:image/s3,"s3://crabby-images/90391/90391c8d85efc805caf4289761d16462e64f0f61" alt=""
As you can see on the screen:
\- we can create file on server
\- we can inject some garbage on the filename (like '> or ">)
\- we are using php 'to run command'
Cool. My goal was to get RCE here. ;)
So the case was:
\- attacker (logged-in normal/registered user) will inject malicious payload in scheduler
\- scheduler will run attached code when using cron*
*(in source you will see that our injection is possible when script will do: rm -f <ourString>but we will get to that later;))
Checking again (and again...):
data:image/s3,"s3://crabby-images/90a95/90a9585557fceff9e7276cb8bde4519cad388f44" alt=""
Still nothing. The case is: how to inject a string to cron-not-to-php? Hm... I (still) don't know yet.
I tried to use the same command (in other shell windows) as was the command injected to the (created) script. I was wondering, maybe I'll find the injection string this way...
data:image/s3,"s3://crabby-images/e99ee/e99ee9dd83a65fcb12bcb276bd9a513baeb168e3" alt=""
Still - nope.
So after a 'day with Nagios VM' we should be somewhere here, reading logs ;)
data:image/s3,"s3://crabby-images/60f00/60f007fab555e0869ee872664f758d36a2ceaa9b" alt=""
we are here again:
data:image/s3,"s3://crabby-images/b51c5/b51c53a96fae7a1018a474e4b38e4a54f53fe96d" alt=""
After few more times/requests I decided to check logs again... this time I found this:
data:image/s3,"s3://crabby-images/b117c/b117ca93e0eab0af3a83f922e4e7174f40d27005" alt=""
Well. Yes, /etc/issue is printed to the log file ;D
As you can see, payload should write file to /tmp/qwe. And in fact, it is true, but we are looking in wrong /tmp/ directory. ;) Check it out:
data:image/s3,"s3://crabby-images/1113e/1113ee3718bfd80597d59b1dc365b76e6f4dba66" alt=""
So no we should be somewhere here, verifying:
data:image/s3,"s3://crabby-images/823cb/823cb47187b12f20f1f37a51e1f502dab0947143" alt=""
I used revshell from [pentestmonkey](http://pentestmonkey.net/tools/web-shells/php-reverse-shell) (thanks!):
data:image/s3,"s3://crabby-images/fe8b6/fe8b6dd821ce0646e7ec169e836f14d398c2c48d" alt=""
Quick configuration and we should be here:
data:image/s3,"s3://crabby-images/9398f/9398f11e0e8428582fbb4fc54704edbbbc6a335c" alt=""
暂无评论