MITRE ATT&CK - Resource Development - Building Custom Tools
MITRE ATT&CK - Resource Development - Building Custom Tools
1. Local Enumeration - Architecture
The difference between reconnaissance and enumeration stands in the former being the act of scouting or exploring with the aim of gaining information. On the other hand, enumeration is the second phase centered around the obtainment of information missed during the first phase. E.g. The versions of services or operating systems scanned on the target's machine.
The architecture of the Linux operating system contains the following components: the Kernel, System Library, Hardware layer, System, and Shell utility. In terms of security, valuable information is contained within these components. Nonetheless, specific versions of the components are vulnerable to adversary threats.
Enumerating the architecture is crucial in gaining information and using it to determine the machine environment.
Create a bash script using gedit in order to enumerate the architecture of the local machine by using the following command:
# sudo gedit arch-enum
uname -a <unix name all: prints name, version, and other details regarding the current machine and OS
arch <print the computer architecture>
getconf LONG_BIT <examines to see if the OS kernel is 32 bit or 64 bit)
lsb_release -a <obtains specific information specific to the local Linux dist>
env <current environment>
Make the bash script executable:
2. Local Enumeration - Running Processes
Linux systems provide a variety of system services (processes). Each service is assigned a unique PID (process identification number). The system reuses old PIDs for new processes if no possible combinations are left. A process may be initiated as a foreground or background process. By default, all commands running in the shell will start as foreground processes. Init is a daemon process, which begins when a computer boots. Init is the parent of all other running processes be that directly or indirectly. As such, it is typically assigned “pid=1“.
Use the following command to create a bash script using gedit, which will be used to enumerate and monitor local running processes:
# sudo gedit proc-enum
#!/bin/bash
sudo netstat -antup
top
Commands used for local process enumeration in the bash file are:
• netstat -antup (network statistics) command is used to display detailed information on the network status of the local machine.
• top command is used to list all active processes and threads currently managed by the Linux Kernel.
Make the bash script executable in order to use it with the following command:
Run the bash script and analyze the displayed output:
3. Local Enumeration - Weak File Permissions
Files with weak permissions allow privilege escalation on the system. This occurs due to permissions on the files being overly lenient. Low level users may gain root access to the system if they have writing permission on a file owned by the root or a group with sudo privileges.
Create a bash script named file-enum in /home/admin using nano to enumerate weak file permissions in the local machine:
# sudo nano file-enum
Add the commands shown below to the script:
Commands used for local weak file enumeration in the bash file are:
• whoami - displays the username of the current user.
• id - displays the UID and all groups associated with a user.
• pwd - displays the current path.
• finger - provides details on all the users currently logged in.
• find / -perm /6000 - lists out all the SUID and SGID files.
Make the bash script executable by using the following command:
# sudo chmod +x file‑enum
Run the bash script and analyze the displayed output:
# ./file‑enum
4. Resolving Hostname to IP with Python
The following steps focus on building custom tools using Python. Python is a valuable exploit development tool used to discover, explore, and exploit a wide range of vulnerabilities. Python scripts are agile and easy to write. As such, swift iteration is present when designing and testing exploit code due to Python using its own interpreter
Create a Python script to resolve the Hostname to IP by using the Socket library containing the functions below:
• import socket - a Python library used to connect two nodes on a network with the aim of fostering communication.
• hostname - is a unique identifier (parameter) for the target's machine.
• ipAddress - is a unique identifier (parameter) for the target's machine IP. When given a hostname, the gethostbyname() function returns the IP address of the host.
• print() - used to display the operation.
Use gedit to create a file for the Python script:
# sudo gedit host‑ip.py
Write the code as shown below:
Afterwards, run the python script and resolve the host www.lab.com using the following command:
Comments
Post a Comment