[
    {
        "file_name": "memory_hijacker.py",
        "file_content": "import ctypes\nimport sys\nfrom ctypes import wintypes\n\n# Load the necessary Windows API functions\nkernel32 = ctypes.WinDLL('kernel32', use_last_error=True)\npsapi = ctypes.WinDLL('psapi', use_last_error=True)\n\n# Define the necessary structures\nclass MEMORY_BASIC_INFORMATION(ctypes.Structure):\n    _fields_ = [\n        (\"BaseAddress\", wintypes.LPVOID),\n        (\"AllocationBase\", wintypes.LPVOID),\n        (\"AllocationProtect\", wintypes.DWORD),\n        (\"RegionSize\", ctypes.c_size_t),\n        (\"State\", wintypes.DWORD),\n        (\"Protect\", wintypes.DWORD),\n        (\"Type\", wintypes.DWORD)\n    ]\n\n# Function to get the process handle\ndef get_process_handle(process_id):\n    \"\"\"Get the handle of the target process.\"\"\"\n    h_process = kernel32.OpenProcess(0x0010, False, process_id)\n    if not h_process:\n        raise ctypes.WinError(ctypes.get_last_error())\n    return h_process\n\n# Function to read memory from the target process\ndef read_memory(h_process, address, size):\n    \"\"\"Read memory from the target process.\"\"\"\n    buffer = ctypes.create_string_buffer(size)\n    bytes_read = wintypes.SIZE_T(0)\n    if not kernel32.ReadProcessMemory(h_process, address, buffer, size, ctypes.byref(bytes_read)):\n        raise ctypes.WinError(ctypes.get_last_error())\n    return buffer.raw\n\n# Function to write memory to the target process\ndef write_memory(h_process, address, data):\n    \"\"\"Write memory to the target process.\"\"\"\n    bytes_written = wintypes.SIZE_T(0)\n    if not kernel32.WriteProcessMemory(h_process, address, data, len(data), ctypes.byref(bytes_written)):\n        raise ctypes.WinError(ctypes.get_last_error())\n\n# Function to find the base address of a module in the target process\ndef find_module_base_address(h_process, module_name):\n    \"\"\"Find the base address of a module in the target process.\"\"\"\n    module_handle = wintypes.HMODULE()\n    if not psapi.EnumProcessModules(h_process, ctypes.byref(module_handle), ctypes.sizeof(module_handle), None):\n        raise ctypes.WinError(ctypes.get_last_error())\n    module_name_buffer = ctypes.create_string_buffer(256)\n    if not psapi.GetModuleBaseNameA(h_process, module_handle, module_name_buffer, ctypes.sizeof(module_name_buffer)):\n        raise ctypes.WinError(ctypes.get_last_error())\n    if module_name_buffer.value.decode() == module_name:\n        return module_handle\n    return None\n\n# Function to hijack memory\ndef hijack_memory(process_id, module_name, target_address, new_data):\n    \"\"\"Hijack memory in the target process.\"\"\"\n    h_process = get_process_handle(process_id)\n    module_base_address = find_module_base_address(h_process, module_name)\n    if not module_base_address:\n        raise ValueError(f\"Module {module_name} not found in the target process.\")\n    target_address = module_base_address + target_address\n    write_memory(h_process, target_address, new_data)\n    print(f\"Memory hijacked successfully at address {hex(target_address)}\")\n\nif __name__ == \"__main__\":\n    if len(sys.argv) != 5:\n        print(\"Usage: python memory_hijacker.py <process_id> <module_name> <target_address> <new_data>\")\n        sys.exit(1)\n\n    process_id = int(sys.argv[1])\n    module_name = sys.argv[2]\n    target_address = int(sys.argv[3], 16)\n    new_data = bytes.fromhex(sys.argv[4])\n\n    hijack_memory(process_id, module_name, target_address, new_data)"
    },
    {
        "file_name": "README.md",
        "file_content": "# Memory Hijacker\n\nThis script allows you to hijack memory in a target process by writing new data to a specified memory address. It is designed to work on Windows systems and uses the Windows API for process and memory manipulation.\n\n## Requirements\n\n- Python 3.x\n- Windows operating system\n\n## Usage\n\n1. Save the `memory_hijacker.py` script to your local machine.\n2. Open a command prompt and navigate to the directory containing the script.\n3. Run the script with the following arguments:"
    }
]