HTB - Nibbles
Overview
Nibbles was the first easy HTB target that I pwned, and probably the majority of HTB users as well, as it was used as an example at the Penetration Test job path.
Nibbles is a fairly simple machine, however with the inclusion of a login blacklist, it is a fair bit more challenging to find valid credentials. Luckily, a username can be enumerated and guessing the correct password does not take long for most.
1. Information Gathering
What we know beforehand:
- Target’s IP address.
- Targets OS: Linux.
- The room focus on web app testing.
Checklist:
- 1 Port scanning
- 2 Banner Grabbing
Port scanning
data:image/s3,"s3://crabby-images/a2723/a2723d9e186e32570b8243cd5b679ed7bbcf717a" alt="Nmap scan results"
Banner grabbing
data:image/s3,"s3://crabby-images/2ecda/2ecda5e720f4df016fb79908ddc0b36bf489e1e3" alt="Banner grabbing with netcat"
Next steps
- Web enumeration
- SSH credentials
2. Web enumeration
Checklist:
- 1 Check tools used
- 1.1 Wappalyzer
- 1.2
whatweb
- 2 View page source
- 2.1 Enumerate
/nibbleblog
dir & search public exploits- 2.1.1 CVE-2015-6967
works on < 4.0.5
- 2.1.2 Metasploit module tested on 4.0.3
works on 4.0.3 & needs valid creds –>
image.php
cleanup error
- 2.1.1 CVE-2015-6967
- 2.1 Enumerate
- 3 Dir-busting
- 3.1 Enumerate subdirectories
- 4 Upload a PHP reverse shell directly on
My Image
plugin.
Checking technologies
data:image/s3,"s3://crabby-images/d9a88/d9a88a09da3ed255ca82002a813bafefd7702ccd" alt="Wappalyzer technologies"
data:image/s3,"s3://crabby-images/8fe86/8fe86ba094c9f79ecd1722ad06142955b7b6fb46" alt="whatweb technologies"
Viewing page source
data:image/s3,"s3://crabby-images/b1002/b100231ad2e2d9513fdb8987ecce627da11865f1" alt="Homepage's page source"
Add to checklist: Enumerate
/nibbleblog
dir & search public exploits.
Searching for public exploits
data:image/s3,"s3://crabby-images/d0ccb/d0ccbfa7fd33f464402f615fe6fb3a2bdb1c273f" alt="Nibbleblog public exploit"
CVE-2015-6967: Unrestricted file upload vulnerability in the My Image plugin in Nibbleblog before 4.0.5 allows remote administrators to execute arbitrary code by uploading a file with an executable extension, then accessing it via a direct request to the file in content/private/plugins/my_image/image.php.
Metasploit module
data:image/s3,"s3://crabby-images/e246c/e246cf59bd22f6614b185143ffddfff06ceb9282" alt="Metasploit module options"
data:image/s3,"s3://crabby-images/27d9a/27d9a587eec750054a646d8084f51356c3d0f530" alt="Metasploit module options"
Dir-busting
data:image/s3,"s3://crabby-images/9d9a8/9d9a879d12375267593b359417834584252dccdc" alt="Gobuster's scan results"
Enumerating subdirectories
data:image/s3,"s3://crabby-images/c7338/c7338b8fce8ff86203bb1df561e077f044ac3d2d" alt="README subdirectory-Nibbleblog's version"
Nibbleblog v4.0.3 –> Metasploit module, need to find creds.
data:image/s3,"s3://crabby-images/5a17b/5a17bed85e7d3c5a12b9e07ebf07161ddb02c3da" alt="content subdirectory-users.xml file"
Username,
admin
, obtained, still missing password for Logging in & Metasploit. After trying several passwords,admin:nibbles
works.
Metasploit’s module erroring
data:image/s3,"s3://crabby-images/cb1ac/cb1ac2296a0678b761771193054fc0353611911a" alt="Metasploit error message"
MSF error: tried re-installing
My Image
plugin, and althoughimage.php
is not there, still same error.
Uplading a PHP reverse shell
data:image/s3,"s3://crabby-images/1fa4e/1fa4e2ed8c180248884b5d38ba18f47447325b7f" alt="My Image plugin configurations"
data:image/s3,"s3://crabby-images/2b574/2b57478cec1f2b19a584d407fadb8d4f5118f6f8" alt="Shell upload"
data:image/s3,"s3://crabby-images/57033/57033d1fbbbc1cbe060862efc176ebf1f12d69f1" alt="Reverse shell obtained"
3. Initial Foothold
Checklist:
- 1 Stabilize shell
- 2 Search for
user.txt
- 3 Check current user’s privileges
Stabilizing shell & searching for user.txt
data:image/s3,"s3://crabby-images/91027/910277fe2944a3d1047f7694296cb4e610c65be8" alt="Upgrading revese shell and getting user flag"
Checking current user’s privs
data:image/s3,"s3://crabby-images/7e39a/7e39a0eaf7311daea207e7f0dc6980719215583d" alt="Checking current user's privileges"
nibbles
can runmonitor.sh
asroot
with no pass. Exploit it to get a root shell.
4. Privilege Escalation
Checklist:
- 1 Try to exploit
monitor.sh
- 2 Search for
root.txt
Exploiting monitor.sh
data:image/s3,"s3://crabby-images/1c74b/1c74b6a25d12ae118cf49f6099ac2ff159d576f1" alt="Personal_zip file"
data:image/s3,"s3://crabby-images/f5e12/f5e1266b75dd7e5617d3d871c3bdd3145c930a5b" alt="Checking script's permissions"
data:image/s3,"s3://crabby-images/498cf/498cf5d866d8f0664f21ebf692ce95159f4bceaf" alt="Adding root shell code"
Searching for root.txt
data:image/s3,"s3://crabby-images/69d28/69d28dedad544eb279cc514416cc0d6bdb352694" alt="Getting root shell and root.txt"
data:image/s3,"s3://crabby-images/baddd/baddde80b9f4963a5c18927b3bc0907c0a644242" alt="Nibbles machine pwnd"