基本信息
- https://app.hackthebox.com/machines/MonitorsTwo
- 10.10.11.211
data:image/s3,"s3://crabby-images/01af4/01af4e46b31ee50ab8e54c296cc37d3fb4d9a440" alt=""
端口扫描
22和80:
1 | nmap -sC -sV -Pn 10.10.11.211 |
80
cacti 1.2.22:
data:image/s3,"s3://crabby-images/b2c15/b2c15a2d39d147a0f68a1aabf9407abe0041b41e" alt=""
cacti
搜到这个:
- Cacti: Unauthenticated Remote Code Execution | Sonar
https://www.sonarsource.com/blog/cacti-unauthenticated-remote-code-execution/ - sAsPeCt488/CVE-2022-46169: PoC for CVE-2022-46169 - Unauthenticated RCE on Cacti <= 1.2.22
https://github.com/sAsPeCt488/CVE-2022-46169
也可以直接用msf:
1 | msf6 > use exploit/linux/http/cacti_unauthenticated_cmd_injection |
打到容器的www-data:
data:image/s3,"s3://crabby-images/7fc40/7fc406b85bf23fe6cf32154f8c2d1250a9ff2ff2" alt=""
/entrypoint.sh
根目录发现entrypoint.sh,查看内容得到mysql:
data:image/s3,"s3://crabby-images/8ebfb/8ebfbc5b119249570d36faad5fa72761239be0b0" alt=""
mysql
mysql中获取到两个hash,破解出来marcus的密码:
1 | mysql --host=db --user=root --password=root cacti -e "show tables" |
data:image/s3,"s3://crabby-images/095fd/095fd3d31479596337abd6a4afc24387b2c0d2a7" alt=""
user flag
marcus ssh登录,得到user flag:
data:image/s3,"s3://crabby-images/f0932/f093264a7fc889f3ca03f5b795e3d41a84f7aa73" alt=""
另外登录时提示有邮件,查看邮件里面提到三个漏洞:
1 | cat /var/mail/marcus |
提权信息
根据邮件中信息,提权应该是通过CVE-2021-41091:
- Insufficiently restricted permissions on data directory · Advisory · moby/moby
https://github.com/moby/moby/security/advisories/GHSA-3fwx-pjgw-3558
根据描述就是外部宿主机调用docker内suid程序
Docker
回到容器的www-data,检查suid发现/sbin/capsh:
data:image/s3,"s3://crabby-images/510c5/510c5bcaebf8bc6c6dcabc598afd1b159c737259" alt=""
docker root
利用capsh的suid得到容器的root:
- capsh | GTFOBins
https://gtfobins.github.io/gtfobins/capsh/#suid
然后给容器内的bash添加suid
1 | /sbin/capsh --gid=0 --uid=0 -- |
data:image/s3,"s3://crabby-images/e6436/e64365c2b24c7cdb9fafd95dca514493023eeb2f" alt=""
提权 & root flag
再回到marcus ,查看挂载得到对应目录,然后直接运行docker内的suid bash得到root:
1 | marcus@monitorstwo:~$ findmnt |
data:image/s3,"s3://crabby-images/711ca/711cae96c892ec2fcec67dbef23f6e0f5eb21022" alt=""
data:image/s3,"s3://crabby-images/5c14e/5c14e280bf1e5772dc51f6b554a82157612000eb" alt=""
shadow
1 | root:$6$KQUOT7rGEpEUTjFc$hA2mxdKhpH7RQ3g5ZGjzkPrRpq1jCqmiZY9SgqaoTb1BI6APMo14Ed/Ptbfnf5MAkCbBbHEbRqwzPc301fuat1:19366:0:99999:7::: |
参考资料
- Cacti: Unauthenticated Remote Code Execution | Sonar
https://www.sonarsource.com/blog/cacti-unauthenticated-remote-code-execution/ - sAsPeCt488/CVE-2022-46169: PoC for CVE-2022-46169 - Unauthenticated RCE on Cacti <= 1.2.22
https://github.com/sAsPeCt488/CVE-2022-46169 - capsh | GTFOBins
https://gtfobins.github.io/gtfobins/capsh/#suid - Insufficiently restricted permissions on data directory · Advisory · moby/moby
https://github.com/moby/moby/security/advisories/GHSA-3fwx-pjgw-3558