[
    {
        "file_name": "thread_hijacker.py",
        "file_content": "import ctypes\nimport threading\n\n# Function to hijack a thread\ndef hijack_thread(target_thread, new_target):\n    \"\"\"\n    Hijacks the given thread to execute a new target function.\n\n    :param target_thread: The thread object to hijack.\n    :param new_target: The new function to execute in the hijacked thread.\n    \"\"\"\n    # Get the thread's native ID\n    tid = target_thread.native_id\n\n    # Open the thread handle\n    thread_handle = ctypes.windll.kernel32.OpenThread(0x001F03FF, False, tid)\n\n    # Suspend the thread\n    ctypes.windll.kernel32.SuspendThread(thread_handle)\n\n    # Get the context of the thread\n    context = ctypes.windll.kernel32.GetThreadContext(thread_handle)\n\n    # Set the instruction pointer to the new target function\n    context.Eip = ctypes.cast(new_target, ctypes.c_void_p).value\n\n    # Set the context back to the thread\n    ctypes.windll.kernel32.SetThreadContext(thread_handle, context)\n\n    # Resume the thread\n    ctypes.windll.kernel32.ResumeThread(thread_handle)\n\n    # Close the thread handle\n    ctypes.windll.kernel32.CloseHandle(thread_handle)\n\n# Example new target function\ndef new_target_function():\n    print(\"Thread has been hijacked and is now executing this function.\")\n\n# Example usage\nif __name__ == \"__main__\":\n    # Create a thread that will be hijacked\n    target_thread = threading.Thread(target=lambda: print(\"Original thread function\"))\n    target_thread.start()\n\n    # Wait for the thread to start\n    threading.Event().wait(1)\n\n    # Hijack the thread\n    hijack_thread(target_thread, new_target_function)\n\n    # Wait for the hijacked thread to finish\n    target_thread.join()"
    },
    {
        "file_name": "hijack_example.py",
        "file_content": "import threading\nimport time\nfrom thread_hijacker import hijack_thread\n\n# Function to be executed by the original thread\ndef original_function():\n    print(\"Original function is running...\")\n    time.sleep(5)\n    print(\"Original function finished.\")\n\n# Function to be executed after hijacking\ndef hijacked_function():\n    print(\"Thread has been hijacked and is now executing this function.\")\n\nif __name__ == \"__main__\":\n    # Create and start the original thread\n    original_thread = threading.Thread(target=original_function)\n    original_thread.start()\n\n    # Wait for the thread to start\n    time.sleep(1)\n\n    # Hijack the thread\n    hijack_thread(original_thread, hijacked_function)\n\n    # Wait for the hijacked thread to finish\n    original_thread.join()"
    },
    {
        "file_name": "README.md",
        "file_content": "# Thread Hijacking Example\n\nThis project demonstrates how to hijack a thread in Python using the `ctypes` library to interact with the Windows API. The hijacking process involves suspending the target thread, modifying its instruction pointer to point to a new function, and then resuming the thread.\n\n## Files\n\n1. **thread_hijacker.py**: Contains the `hijack_thread` function and an example usage.\n2. **hijack_example.py**: Demonstrates how to use the `hijack_thread` function to hijack a thread.\n\n## Usage\n\n1. Run `hijack_example.py` to see the thread hijacking in action.\n2. The original thread will start executing `original_function`, but after 1 second, it will be hijacked to execute `hijacked_function`.\n\n## Notes\n\n- This example is specific to Windows due to the use of the Windows API.\n- The `ctypes` library is used to call Windows functions directly from Python.\n- Thread hijacking can be useful in certain scenarios but should be used with caution as it can lead to unpredictable behavior if not handled properly."
    }
]