279 static constexpr platform_id process_platform = IMAGE_FILE_MACHINE_I386;
281 static constexpr platform_id process_platform = IMAGE_FILE_MACHINE_AMD64;
283 static constexpr platform_id process_platform = IMAGE_FILE_MACHINE_ARMNT;
285 static constexpr platform_id process_platform = IMAGE_FILE_MACHINE_ARM64;
287 static constexpr platform_id process_platform =
"i386";
289 static constexpr platform_id process_platform =
"x86_64";
291 static constexpr platform_id process_platform =
"aarch64";
293 #error Unknown platform
331 HMODULE kernel32_handle;
332 kernel32_handle = LoadLibrary(_T(
"kernel32.dll"));
333 _Assume_(kernel32_handle);
334 BOOL(WINAPI * IsWow64Process2)(HANDLE hProcess, USHORT * pProcessMachine, USHORT * pNativeMachine);
335 *
reinterpret_cast<FARPROC*
>(&IsWow64Process2) = GetProcAddress(kernel32_handle,
"IsWow64Process2");
336 HANDLE process = GetCurrentProcess();
337 USHORT process_machine;
341 if (IsWow64Process2 && IsWow64Process2(process, &process_machine, &
os_platform)) {
342 wow64 = process_machine != IMAGE_FILE_MACHINE_UNKNOWN;
350 else if (IsWow64Process(process, &Wow64Process)) {
361 FreeLibrary(kernel32_handle);
363 memset(&m_utsn, 0,
sizeof(m_utsn));
364 if (uname(&m_utsn) != -1)
365 os_platform =
reinterpret_cast<platform_id
>(m_utsn.machine);
369 HWINSTA hWinSta = GetProcessWindowStation();
371 TCHAR sName[MAX_PATH];
372 if (GetUserObjectInformation(hWinSta, UOI_NAME, sName,
sizeof(sName), NULL)) {
373 sName[_countof(sName) - 1] = 0;
385 if (OpenProcessToken(GetCurrentProcess(), TOKEN_QUERY, &token_h)) {
388 TOKEN_ELEVATION elevation;
389 DWORD size =
sizeof(TOKEN_ELEVATION);
390 if (GetTokenInformation(token_h, TokenElevation, &elevation,
sizeof(elevation), &size))
391 elevated = elevation.TokenIsElevated;
393 GetTokenInformation(token.
get(), TokenGroups, NULL, 0, &size);
394 std::unique_ptr<TOKEN_GROUPS> groups((TOKEN_GROUPS*)
new uint8_t[size]);
395 if (GetTokenInformation(token.
get(), TokenGroups, (LPVOID)groups.get(), size, &size)) {
396 SID_IDENTIFIER_AUTHORITY authority = SECURITY_NT_AUTHORITY;
397 PSID sid_admins_h = NULL;
398 if (AllocateAndInitializeSid(&authority, 2, SECURITY_BUILTIN_DOMAIN_RID, DOMAIN_ALIAS_RID_ADMINS, 0, 0, 0, 0, 0, 0, &sid_admins_h)) {
399 struct SID_delete {
void operator()(_In_ PSID p)
const { FreeSid(p); } };
400 std::unique_ptr<void, SID_delete> sid_admins(sid_admins_h);
401 for (DWORD i = 0; i < groups->GroupCount; ++i)
402 if (EqualSid(sid_admins.get(), groups->Groups[i].Sid)) {
410#elif defined(__APPLE__)
412 gid_t gids[NGROUPS + 1];
413 for (
int i = 0, n = getgroups(_countof(gids), gids); i < n; ++i) {
414 struct group* group = getgrgid(gids[i]);
415 if (!group)
continue;
416 if (strcmp(group->gr_name,
"admin") == 0) {
432 struct utsname m_utsn;