Zebediah Figura z.figura12@gmail.com wrote:
@@ -1522,17 +1525,43 @@ DWORD WINAPI GetSecurityInfo( HANDLE handle, SE_OBJECT_TYPE type, SECURITY_INFOR } else {
HKEY key = NULL;if (type == SE_REGISTRY_KEY && (HandleToUlong(handle) >= HandleToUlong(HKEY_SPECIAL_ROOT_FIRST))&& (HandleToUlong(handle) <= HandleToUlong(HKEY_SPECIAL_ROOT_LAST))){REGSAM access = READ_CONTROL;DWORD ret;if (SecurityInfo & SACL_SECURITY_INFORMATION)access |= ACCESS_SYSTEM_SECURITY;if ((ret = RegOpenKeyExW( handle, L"\\", 0, access, &key )))return ret;handle = key;}status = NtQuerySecurityObject( handle, SecurityInfo, NULL, 0, &size ); if (status != STATUS_SUCCESS && status != STATUS_BUFFER_TOO_SMALL){RegCloseKey( key ); return RtlNtStatusToDosError( status );}
It would be helpful to test whether NtQuerySecurityObject() is supposed to handle such case on its own, without hacks on GetSecurityInfo() side.