<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:dc="http://purl.org/dc/elements/1.1/">
  <channel>
    <title>Forem: Adeyemi Adeleye</title>
    <description>The latest articles on Forem by Adeyemi Adeleye (@countyemi).</description>
    <link>https://forem.com/countyemi</link>
    <image>
      <url>https://media2.dev.to/dynamic/image/width=90,height=90,fit=cover,gravity=auto,format=auto/https:%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Fuser%2Fprofile_image%2F1660133%2F85c67a7c-aad7-4212-9f81-1a04fb3dcc43.jpg</url>
      <title>Forem: Adeyemi Adeleye</title>
      <link>https://forem.com/countyemi</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://forem.com/feed/countyemi"/>
    <language>en</language>
    <item>
      <title>Let's Pretend to be Hackers</title>
      <dc:creator>Adeyemi Adeleye</dc:creator>
      <pubDate>Fri, 21 Jun 2024 04:18:08 +0000</pubDate>
      <link>https://forem.com/countyemi/lets-pretend-to-be-hackers-2g8l</link>
      <guid>https://forem.com/countyemi/lets-pretend-to-be-hackers-2g8l</guid>
      <description>&lt;p&gt;In this article, we will pretend to do some of the things a hacker might do in trying to gain access to a network. &lt;/p&gt;

&lt;p&gt;For this, we will run the following services in the network:&lt;/p&gt;

&lt;ol&gt;
&lt;li&gt;Apache service running on port 80&lt;/li&gt;
&lt;li&gt;MySQL service running on port 3306&lt;/li&gt;
&lt;li&gt;Flask server on port 5000&lt;/li&gt;
&lt;/ol&gt;

&lt;p&gt;We will run all these services on a single server using docker containers.&lt;br&gt;
For this:&lt;/p&gt;

&lt;ol&gt;
&lt;li&gt;  Create a server with a public IP address on any cloud 
 provider. For this, I used AWS&lt;/li&gt;
&lt;li&gt;  Install docker and docker compose on the server. I used 
 the script below for the installation.
&lt;/li&gt;
&lt;/ol&gt;
&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;_for pkg in docker.io docker-doc docker-compose docker-compose-v2 podman-docker containerd runc;\
 do sudo apt-get remove $pkg; done

# Add Docker's official GPG key:
sudo apt update -y
sudo apt install ca-certificates curl -y
sudo install -m 0755 -d /etc/apt/keyrings
sudo curl -fsSL https://download.docker.com/linux/ubuntu/gpg -o /etc/apt/keyrings/docker.asc
sudo chmod a+r /etc/apt/keyrings/docker.asc

# Add the repository to Apt sources:
echo \
  "deb [arch=$(dpkg --print-architecture) signed-by=/etc/apt/keyrings/docker.asc] https://download.docker.com/linux/ubuntu \
  $(. /etc/os-release &amp;amp;&amp;amp; echo "$VERSION_CODENAME") stable" | \
  sudo tee /etc/apt/sources.list.d/docker.list &amp;gt; /dev/null
sudo apt update -y

sudo apt install docker-ce docker-ce-cli containerd.io \
docker-buildx-plugin docker-compose-plugin git -y

mkdir -p ~/.docker/cli-plugins/
curl -SL https://github.com/docker/compose/releases/download/v2.3.3/\
docker-compose-linux-x86_64 -o ~/.docker/cli-plugins/docker-compose
chmod +x ~/.docker/cli-plugins/docker-compose_

&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;


&lt;ol&gt;
&lt;li&gt; Write Dockerfile for the apache and flask server:&lt;/li&gt;
&lt;/ol&gt;

&lt;p&gt;Apache server&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;#use the apache image. Latest version
FROM httpd

#delete all files in the root directory
RUN rm -r /usr/local/apache2/htdocs/*

#copy our web file to the root directory. TAKE NOTE OF THE FILE LOCATION
COPY ./index.html /usr/local/apache2/htdocs/

#run apache on port 80
EXPOSE 80

&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Flask server&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;#use pyhton3 image
FROM python:3

#set the working directory
WORKDIR /usr/src/app

#install flask module. Since our program needs the flask module to run
RUN pip install Flask

#copy our script into the working directory. TAKE NOTE OF THE FILE LOCATION
COPY server.py .

#run the container on port 5000
EXPOSE 5000

#run the server script
CMD ["python", "server.py"]

&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Here is the content of the server.py file:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;
from flask import Flask

app = Flask(__name__)

@app.route('/')

def index():

    return '&amp;lt;h1&amp;gt;Connected&amp;lt;/h1&amp;gt;'

if __name__ == '__main__':

    app.run(host='0.0.0.0', port=5000, debug=True)


&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;ol&gt;
&lt;li&gt; Write the docker compose file to run the containers
&lt;/li&gt;
&lt;/ol&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;version: '3.8'

services:
#run MySQL container
  mysql:
    image: mysql:5.7
    container_name: mysql-container
#get environment variables from .env file
    environment:
      MYSQL_ROOT_PASSWORD: ${MYSQL_ROOT_PASSWORD}
      MYSQL_DATABASE: ${MYSQL_DATABASE}
      MYSQL_USER: ${MYSQL_USER}
      MYSQL_PASSWORD: ${MYSQL_PASSWORD}
#bind port 3306 to 3306
    ports:
      - "3306:3306"
#run apache container
  apache:
    build:
#build container image from the Dockerfile in /apache
      context: ./apache
    container_name: apache-container
#bind port 80 to 80
    ports:
      - "80:80"
#run flask container
  flask:
    build:
#build container image from the Dockerfile in /flask
      context: ./flask
    container_name: flask-container
#bind port 80 to 80
    ports:
      - "5000:5000"


&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Just before running compose up, verify your files and directory structure. Heres what mine looks like:&lt;br&gt;
&lt;a href="https://media.dev.to/cdn-cgi/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2F9e4yh0bj42xvxm7vlwzf.JPG" class="article-body-image-wrapper"&gt;&lt;img src="https://media.dev.to/cdn-cgi/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2F9e4yh0bj42xvxm7vlwzf.JPG" alt="Image description" width="800" height="513"&gt;&lt;/a&gt;&lt;br&gt;
Now run docker compose up&lt;/p&gt;

&lt;p&gt;&lt;a href="https://media.dev.to/cdn-cgi/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fl3xaahec6405cdxwlu54.JPG" class="article-body-image-wrapper"&gt;&lt;img src="https://media.dev.to/cdn-cgi/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fl3xaahec6405cdxwlu54.JPG" alt="Image description" width="800" height="604"&gt;&lt;/a&gt;&lt;br&gt;
Verify the containers are running with docker ps&lt;/p&gt;

&lt;p&gt;&lt;a href="https://media.dev.to/cdn-cgi/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fjaxyf3db50qpw8ozs7du.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media.dev.to/cdn-cgi/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fjaxyf3db50qpw8ozs7du.png" alt="Image description" width="800" height="269"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;If any of your containers are not running, follow these steps:&lt;/p&gt;

&lt;ol&gt;
&lt;li&gt; Run docker ps –a. Copy the container id&lt;/li&gt;
&lt;li&gt; Run docker logs . This will give you an insight as to what went wrong.
In this case, all services are running.
Now its time to test our port scanner. Here’s the code for the port scanner. FEEL FREE TO MODIFY TO SUIT YOU.
I used the socket module from:&lt;a href="https://docs.python.org/3/library/socket.html"&gt;&lt;/a&gt;
&lt;/li&gt;
&lt;/ol&gt;
&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;#import socket module
import socket
#function to perform the port scan
def scan(host, port_range=6000):

""" 
    performs port scan on the given host/ip-address.
    scans port range 1 - 6000

    Takes two parameters: 
    host: takes ip-address or hostname as a string
    port_range: optional. default is 6000

    """

    try:
        ip = socket.gethostbyname(host)
    except socket.gaierror:
        print(f"Cannot resolve {host}")
        return

    print(f"Scanning host {ip}...")

    for port in range(1, port_range + 1):
        sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)

        try:
            result = sock.connect_ex((ip, port))
            if result == 0:
                print(f"Port {port} is open")
            sock.close()
        except socket.error:
            pass

host = input("Enter host to scan: ")
scan(host)

&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;


&lt;p&gt;Testing time:&lt;br&gt;
Run &lt;code&gt;python3 &amp;lt;file name&amp;gt;&lt;/code&gt;&lt;/p&gt;

&lt;p&gt;&lt;a href="https://media.dev.to/cdn-cgi/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2F63jmq2w67fxrygo72vbs.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media.dev.to/cdn-cgi/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2F63jmq2w67fxrygo72vbs.png" alt="Image description" width="800" height="364"&gt;&lt;/a&gt;&lt;br&gt;
Our little scanner is able to detect four open ports on our server.&lt;br&gt;
We can go a step further to try to check what services are running on those ports. For this, we will write another python script.&lt;br&gt;
For this, we will use the requests module from &lt;a href="https://pypi.org/project/requests/"&gt;&lt;/a&gt;&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;#import requests module
import requests

def app_version(host, port):

     """ 
    tries to detect the service running on the given address and port

    Takes two parameters: 
    host: takes ip-address or hostname as a string
    port: takes the port number

    """
    try:
        url = f"http://{host}:{port}/"
        response = requests.get(url)
       #we will find the information in the header attribute of the response 
       #from the header metadata, we can retrieve the information 
        header = response.headers.get('Server')

        if header:
            return header, header.split('/')[1]
        else:
            return None

    except Exception as e:
        print(f"Error retrieving application version: {e}")
        return None


host = input ("Enter host to check: ")
port = input ("Enter port to check: ")
app = app_version(host, port)
print(f"{app} running on port: {port} \n \n")

&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;lets test this:&lt;/p&gt;

&lt;p&gt;&lt;a href="https://media.dev.to/cdn-cgi/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fxafvibej8ainmc9r0bpl.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media.dev.to/cdn-cgi/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fxafvibej8ainmc9r0bpl.png" alt="Image description" width="800" height="394"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Our code returns the service and version running on port 80 and 5000.&lt;br&gt;
Port 3306 returned an error because MySQL uses a different protocol from http. We can include that in our code, or write a separate script for that.&lt;br&gt;
But this will do for now. You can go ahead and check the versions detected here for known vulnerabilities.&lt;br&gt;
See you next time&lt;/p&gt;

</description>
      <category>cybersecurity</category>
      <category>devops</category>
      <category>docker</category>
      <category>cloudcomputing</category>
    </item>
  </channel>
</rss>
