KIOPTRIX - Level 1.3 (#4)
- Layout for this exercise:
data:image/s3,"s3://crabby-images/6a447/6a44764418df3c42a01e85b24745109257da7107" alt=""
1 - INTRODUCTION
- The goal of this exercise is the study of the hacking process for the vulnerable machine Kioptrix Level 1.3 (#4)
- Kioptrix Level 1.3 (#4) can be downloaded from here:
https://www.vulnhub.com/entry/kioptrix-level-13-4,25/
data:image/s3,"s3://crabby-images/ed5f6/ed5f603d30c3022f98999f18541d2a5f956eb5f2" alt=""
- Once downloaded, extracted and opened with WMware:
data:image/s3,"s3://crabby-images/62c49/62c49ba2734d6985a34ba8e93f38769e9c96d3ad" alt=""
2 - ENUMERATION
- First, using netdiscover let's notice that the only IP address in the local network working with WMware is 192.168.1.14, so it should correspond to the vulnerable machine Kioptrix:
data:image/s3,"s3://crabby-images/262c9/262c9f01012d9c3286c480be58f59a7391d121d8" alt=""
data:image/s3,"s3://crabby-images/f6b7a/f6b7ab31252d990ad155b56c33f30919d94a2eff" alt=""
- Scanning with Nmap:
data:image/s3,"s3://crabby-images/b156e/b156ef58fddea0efcd880c8578ba3f5f22f7d550" alt=""
- Using nbtscan:
data:image/s3,"s3://crabby-images/7fd27/7fd276a23f4daeca13cd69bb7b5ccf7ed67802a7" alt=""
- enum4linux discovers that there are at least 5 users: nobody, robert, root, john, loneferret.
data:image/s3,"s3://crabby-images/8ccf3/8ccf3db3ef75bb3f52c0e75fc44a6d1b55329cca" alt=""
data:image/s3,"s3://crabby-images/b03c1/b03c15296a263909ceb90cfc3af43f69bde7393b" alt=""
data:image/s3,"s3://crabby-images/e7f31/e7f31955511d30ee68e97e0f32fe27511f82e38f" alt=""
- dirb scans the structure of the website:
data:image/s3,"s3://crabby-images/9fe0e/9fe0ea163fb36d4090437e3174139caef5d8b458" alt=""
data:image/s3,"s3://crabby-images/7637f/7637f9b005635cf2b802f1ede24498e7ed208b6b" alt=""
- Connecting directly to the web server there is a Member Login:
data:image/s3,"s3://crabby-images/3723b/3723bbeb5fa8ac018ae20978c8ee34990acd0bae" alt=""
- Images:
data:image/s3,"s3://crabby-images/ac9fb/ac9fbc9982e7562f077ae3388211f96114edec02" alt=""
- john user's webpage:
data:image/s3,"s3://crabby-images/110c0/110c0ab61dd1f0030aa846f10be82065250caea8" alt=""
3 - EXPLOITATION
- Let's discover if there is a chance of SQL injection:
data:image/s3,"s3://crabby-images/80597/80597aa5e28303a871cc41ded1149300225f40a3" alt=""
- According to the server's answer the file /var/www/checklogin.php holds interesting information about the login process, what could be of use later:
data:image/s3,"s3://crabby-images/99811/998110c27386ca07b23e93bef8b28f7412d99147" alt=""
- Entering a basic SQL injection:
data:image/s3,"s3://crabby-images/d8fc8/d8fc8a8511b0e586098b8727b46d2697af7bfdb7" alt=""
data:image/s3,"s3://crabby-images/c57e1/c57e121865a35f34df16c00680f37f0319d16ca0" alt=""
- Surprisingly, the password for user john is revealed:
data:image/s3,"s3://crabby-images/f6efe/f6efe06af459219e62825527e82bbb36c943c039" alt=""
- Same thing for the user robert (beware of its base64 encoded appearance, it could be misleading):
data:image/s3,"s3://crabby-images/1e6b5/1e6b5d8321e6ed31639f63cc73317dc09ff1dfa4" alt=""
- However, there is no successful result for the rest of the users, for instance for user root:
data:image/s3,"s3://crabby-images/2e4d4/2e4d4459a43e5a9a2295829339d503841d081a91" alt=""
- Now, let's use the credentials for connecting via SSH with users john and robert
data:image/s3,"s3://crabby-images/69c11/69c116807a1dded1190cff8ff2784f52cd35fc73" alt=""
data:image/s3,"s3://crabby-images/1e293/1e2938b5c965dfceb834c6f84a392ee1af6bc686" alt=""
- It seems that the available shell is very limited:
data:image/s3,"s3://crabby-images/46517/465170b5d9ec9e89665516308acb6fd0176f4db3" alt=""
- All information about lshell and how to bypass it:
https://www.aldeid.com/wiki/Lshell
- Trying to get a better shell with os.system('/bin/bash'):
data:image/s3,"s3://crabby-images/78dc3/78dc3b00b9b9e3a75ad19589bc78b9daa3c1bb44" alt=""
4 - PRIVILEGE ESCALATION
- Checking what's inside the /home directory:
data:image/s3,"s3://crabby-images/d978f/d978fb589f9c82b62ca7cb10d025e0f1122886a2" alt=""
- It is interesting to see that there are some references to a MYSQL database:
data:image/s3,"s3://crabby-images/341cc/341cc545339082207e4a8e78d53fb8e653f1b025" alt=""
- Trying to enter the database with root privileges, we have the gift that the administrator of the database forgot to set a password for the user root:
data:image/s3,"s3://crabby-images/21bcb/21bcbf582ef40375980723457ca9b2e10f76a725" alt=""
- Showing databases:
data:image/s3,"s3://crabby-images/c735e/c735eb0cba02fc10f50883e6239c97623737c078" alt=""
- We discover the same username/password information that already knew:
data:image/s3,"s3://crabby-images/36c08/36c084e3a6ed541a56971b8b9e20ad39f6241318" alt=""
data:image/s3,"s3://crabby-images/37d98/37d9857c67872bfe7460c6388aa237cd07ab0788" alt=""
- From the enumeration step we know that /var/www/checklogin.php has information about the login process:
data:image/s3,"s3://crabby-images/eb012/eb012ee57879ae2f6163dffa7aa88996e177761d" alt=""
- Opening /var/www/checklogin.php there is no password for root, as expected:
data:image/s3,"s3://crabby-images/3cd5b/3cd5b981455b3319aa50dc67e17eaed5852df482" alt=""
- So, the conclusion is that the mysql database can be run with root privileges and no password.
- The approach to achieve Privilege Escalation will be to take advantage of the fact that the database is being run as root with no password.
- We can run a User Defined Function (UDF) to execute commands on the underlying operating system:
http://bernardodamele.blogspot.com/2009/01/command-execution-with-mysql-udf.html
- lib_mysqludf_sys is an UDF library with functions to interact with the execution environment in which MySQL runs.
- Luckily, we already have it installed
data:image/s3,"s3://crabby-images/1606d/1606d3cb17f6c7f2f7c2cc2a94d29739cc6e0c1f" alt=""
- Otherwise it could be downloaded from here:
https://github.com/mysqludf/lib_mysqludf_sys
- One of the UDF funcions is sys_exec, what executes arbitrary commands like for instance usermod -a -G admin john , modifying the user john's account by appending it to the admin group, and giving him root privileges:
data:image/s3,"s3://crabby-images/24328/24328913dbd9c0614083e9ac0f366ecaa1cb5501" alt=""
- Now, a root shell is achieved:
data:image/s3,"s3://crabby-images/8b4b8/8b4b843aab2057a6fa770575f90014bce62ba810" alt=""
5 - CAPTURING THE FLAG
- Going to the /root folder:
data:image/s3,"s3://crabby-images/97e06/97e0664f39db7411b68c2f11192b64773cb17126" alt=""