[
    {
        "file_name": "peb_modifier.py",
        "file_content": "import ctypes\nimport ctypes.wintypes\nfrom ctypes import wintypes\n\n# Define the PROCESS_BASIC_INFORMATION structure\nclass PROCESS_BASIC_INFORMATION(ctypes.Structure):\n    _fields_ = [\n        (\"Reserved1\", wintypes.PVOID),\n        (\"PebBaseAddress\", wintypes.PVOID),\n        (\"Reserved2\", wintypes.PVOID * 2),\n        (\"UniqueProcessId\", wintypes.HANDLE),\n        (\"ParentProcessId\", wintypes.HANDLE)\n    ]\n\n# Define the PEB structure\nclass PEB(ctypes.Structure):\n    _fields_ = [\n        (\"Reserved1\", wintypes.BYTE * 2),\n        (\"BeingDebugged\", wintypes.BOOL),\n        (\"Reserved2\", wintypes.BYTE * 1),\n        (\"Reserved3\", wintypes.PVOID),\n        (\"Ldr\", wintypes.PVOID),\n        (\"ProcessParameters\", wintypes.PVOID),\n        (\"SubSystemData\", wintypes.PVOID),\n        (\"ProcessHeap\", wintypes.PVOID),\n        (\"FastPebLock\", wintypes.PVOID),\n        (\"FastPebLockRoutine\", wintypes.PVOID),\n        (\"FastPebUnlockRoutine\", wintypes.PVOID),\n        (\"EnvironmentUpdateCount\", wintypes.DWORD),\n        (\"KernelCallbackTable\", wintypes.PVOID),\n        (\"SystemReserved\", wintypes.PVOID * 1),\n        (\"AtlThunkSListPtr\", wintypes.PVOID),\n        (\"Reserved4\", wintypes.PVOID * 5),\n        (\"PostProcessInitRoutine\", wintypes.PVOID),\n        (\"Reserved5\", wintypes.PVOID * 2),\n        (\"Reserved6\", wintypes.PVOID * 2),\n        (\"Reserved7\", wintypes.PVOID),\n        (\"SessionId\", wintypes.DWORD)\n    ]\n\n# Define the RTL_USER_PROCESS_PARAMETERS structure\nclass RTL_USER_PROCESS_PARAMETERS(ctypes.Structure):\n    _fields_ = [\n        (\"MaximumLength\", wintypes.ULONG),\n        (\"Length\", wintypes.ULONG),\n        (\"Flags\", wintypes.ULONG),\n        (\"DebugFlags\", wintypes.ULONG),\n        (\"ConsoleHandle\", wintypes.HANDLE),\n        (\"ConsoleFlags\", wintypes.ULONG),\n        (\"StandardInput\", wintypes.HANDLE),\n        (\"StandardOutput\", wintypes.HANDLE),\n        (\"StandardError\", wintypes.HANDLE),\n        (\"CurrentDirectory\", wintypes.UNICODE_STRING),\n        (\"DllPath\", wintypes.UNICODE_STRING),\n        (\"ImagePathName\", wintypes.UNICODE_STRING),\n        (\"CommandLine\", wintypes.UNICODE_STRING),\n        (\"Environment\", wintypes.PVOID),\n        (\"StartingX\", wintypes.ULONG),\n        (\"StartingY\", wintypes.ULONG),\n        (\"CountX\", wintypes.ULONG),\n        (\"CountY\", wintypes.ULONG),\n        (\"CountCharsX\", wintypes.ULONG),\n        (\"CountCharsY\", wintypes.ULONG),\n        (\"FillAttribute\", wintypes.WORD),\n        (\"WindowFlags\", wintypes.WORD),\n        (\"ShowWindowFlags\", wintypes.ULONG),\n        (\"WindowTitle\", wintypes.UNICODE_STRING),\n        (\"DesktopInfo\", wintypes.UNICODE_STRING),\n        (\"ShellInfo\", wintypes.UNICODE_STRING),\n        (\"RuntimeData\", wintypes.UNICODE_STRING),\n        (\"CurrentDirectories\", wintypes.PVOID * 32),\n        (\"EnvironmentSize\", wintypes.ULONG),\n        (\"EnvironmentVersion\", wintypes.ULONG),\n        (\"PackageDependencyData\", wintypes.PVOID),\n        (\"ProcessGroupId\", wintypes.ULONG),\n        (\"LoaderThreads\", wintypes.PVOID)\n    ]\n\n# Function to get the PEB address of the target process\ndef get_peb_address(process_handle):\n    basic_info = PROCESS_BASIC_INFORMATION()\n    size = ctypes.sizeof(basic_info)\n    if ctypes.windll.ntdll.NtQueryInformationProcess(process_handle, 0, ctypes.byref(basic_info), size, None) != 0:\n        raise ctypes.WinError()\n    return basic_info.PebBaseAddress\n\n# Function to modify the command line in the PEB structure\ndef modify_command_line(process_handle, new_command_line):\n    peb_address = get_peb_address(process_handle)\n    peb = PEB.from_address(peb_address)\n    process_params = RTL_USER_PROCESS_PARAMETERS.from_address(peb.ProcessParameters)\n\n    # Allocate memory for the new command line\n    new_command_line_bytes = new_command_line.encode('utf-16le')\n    new_command_line_ptr = ctypes.windll.kernel32.VirtualAllocEx(\n        process_handle,\n        None,\n        len(new_command_line_bytes),\n        0x1000 | 0x2000,\n        0x40\n    )\n\n    if not new_command_line_ptr:\n        raise ctypes.WinError()\n\n    # Write the new command line to the allocated memory\n    if not ctypes.windll.kernel32.WriteProcessMemory(\n            process_handle,\n            new_command_line_ptr,\n            new_command_line_bytes,\n            len(new_command_line_bytes),\n            None\n    ):\n        raise ctypes.WinError()\n\n    # Update the CommandLine field in RTL_USER_PROCESS_PARAMETERS\n    process_params.CommandLine.Length = len(new_command_line_bytes)\n    process_params.CommandLine.MaximumLength = len(new_command_line_bytes)\n    process_params.CommandLine.Buffer = new_command_line_ptr\n\n    # Write the updated RTL_USER_PROCESS_PARAMETERS back to the process memory\n    if not ctypes.windll.kernel32.WriteProcessMemory(\n            process_handle,\n            ctypes.addressof(process_params),\n            ctypes.byref(process_params),\n            ctypes.sizeof(process_params),\n            None\n    ):\n        raise ctypes.WinError()\n\n# Example usage\nif __name__ == \"__main__\":\n    import sys\n    if len(sys.argv) != 3:\n        print(\"Usage: python peb_modifier.py <process_id> <new_command_line>\")\n        sys.exit(1)\n\n    process_id = int(sys.argv[1])\n    new_command_line = sys.argv[2]\n\n    process_handle = ctypes.windll.kernel32.OpenProcess(0x001F0FFF, False, process_id)\n    if not process_handle:\n        raise ctypes.WinError()\n\n    try:\n        modify_command_line(process_handle, new_command_line)\n        print(f\"Command line modified successfully for process ID {process_id}\")\n    finally:\n        ctypes.windll.kernel32.CloseHandle(process_handle)"
    },
    {
        "file_name": "requirements.txt",
        "file_content": "ctypes"
    }
]