2004-08-09 20:47:22 +02:00
/*
* Unit tests for security functions
*
* Copyright ( c ) 2004 Mike McCormack
2011-03-16 11:45:43 +01:00
* Copyright ( c ) 2011 Dmitry Timoshkov
2004-08-09 20:47:22 +02:00
*
* This library is free software ; you can redistribute it and / or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation ; either
* version 2.1 of the License , or ( at your option ) any later version .
*
* This library is distributed in the hope that it will be useful ,
* but WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the GNU
* Lesser General Public License for more details .
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library ; if not , write to the Free Software
2006-05-18 14:49:52 +02:00
* Foundation , Inc . , 51 Franklin St , Fifth Floor , Boston , MA 02110 - 1301 , USA
2004-08-09 20:47:22 +02:00
*/
2006-08-04 14:17:58 +02:00
# include <stdarg.h>
2004-08-09 20:47:22 +02:00
# include <stdio.h>
2006-08-04 14:17:58 +02:00
# include "ntstatus.h"
# define WIN32_NO_STATUS
2004-08-09 20:47:22 +02:00
# include "windef.h"
# include "winbase.h"
# include "winerror.h"
2004-08-16 23:07:50 +02:00
# include "aclapi.h"
2004-09-16 22:27:52 +02:00
# include "winnt.h"
2006-05-13 17:56:59 +02:00
# include "sddl.h"
2006-08-04 14:17:58 +02:00
# include "ntsecapi.h"
2006-12-01 00:53:21 +01:00
# include "lmcons.h"
2006-08-04 14:17:58 +02:00
# include "wine/test.h"
2004-08-09 20:47:22 +02:00
2014-01-10 10:26:20 +01:00
# ifndef PROCESS_QUERY_LIMITED_INFORMATION
# define PROCESS_QUERY_LIMITED_INFORMATION 0x1000
# endif
2012-03-15 09:11:06 +01:00
/* PROCESS_ALL_ACCESS in Vista+ PSDKs is incompatible with older Windows versions */
# define PROCESS_ALL_ACCESS_NT4 (PROCESS_ALL_ACCESS & ~0xf000)
2014-01-10 10:26:20 +01:00
# define PROCESS_ALL_ACCESS_VISTA (PROCESS_ALL_ACCESS | 0xf000)
2012-03-15 09:11:06 +01:00
2012-04-18 09:29:46 +02:00
# ifndef EVENT_QUERY_STATE
# define EVENT_QUERY_STATE 0x0001
# endif
2013-12-26 08:34:14 +01:00
# ifndef SEMAPHORE_QUERY_STATE
# define SEMAPHORE_QUERY_STATE 0x0001
# endif
2014-01-10 10:26:16 +01:00
# ifndef THREAD_SET_LIMITED_INFORMATION
# define THREAD_SET_LIMITED_INFORMATION 0x0400
# define THREAD_QUERY_LIMITED_INFORMATION 0x0800
# endif
# define THREAD_ALL_ACCESS_NT4 (STANDARD_RIGHTS_REQUIRED | SYNCHRONIZE | 0x3ff)
# define THREAD_ALL_ACCESS_VISTA (STANDARD_RIGHTS_REQUIRED | SYNCHRONIZE | 0xffff)
2007-10-21 08:58:21 +02:00
/* copied from Wine winternl.h - not included in the Windows SDK */
typedef enum _OBJECT_INFORMATION_CLASS {
ObjectBasicInformation ,
ObjectNameInformation ,
ObjectTypeInformation ,
ObjectAllInformation ,
ObjectDataInformation
} OBJECT_INFORMATION_CLASS , * POBJECT_INFORMATION_CLASS ;
typedef struct _OBJECT_BASIC_INFORMATION {
ULONG Attributes ;
ACCESS_MASK GrantedAccess ;
ULONG HandleCount ;
ULONG PointerCount ;
ULONG PagedPoolUsage ;
ULONG NonPagedPoolUsage ;
ULONG Reserved [ 3 ] ;
ULONG NameInformationLength ;
ULONG TypeInformationLength ;
ULONG SecurityDescriptorLength ;
LARGE_INTEGER CreateTime ;
} OBJECT_BASIC_INFORMATION , * POBJECT_BASIC_INFORMATION ;
2012-08-17 16:22:01 +02:00
# define expect_eq(expr, value, type, format) { type ret_ = expr; ok((value) == ret_, #expr " expected " format " got " format "\n", (value), (ret_)); }
2007-09-27 19:34:53 +02:00
2007-11-02 11:33:36 +01:00
static BOOL ( WINAPI * pAddAccessAllowedAceEx ) ( PACL , DWORD , DWORD , DWORD , PSID ) ;
static BOOL ( WINAPI * pAddAccessDeniedAceEx ) ( PACL , DWORD , DWORD , DWORD , PSID ) ;
static BOOL ( WINAPI * pAddAuditAccessAceEx ) ( PACL , DWORD , DWORD , DWORD , PSID , BOOL , BOOL ) ;
2010-10-01 13:33:37 +02:00
static VOID ( WINAPI * pBuildTrusteeWithSidA ) ( PTRUSTEEA pTrustee , PSID pSid ) ;
static VOID ( WINAPI * pBuildTrusteeWithNameA ) ( PTRUSTEEA pTrustee , LPSTR pName ) ;
static VOID ( WINAPI * pBuildTrusteeWithObjectsAndNameA ) ( PTRUSTEEA pTrustee ,
2006-03-26 13:39:58 +02:00
POBJECTS_AND_NAME_A pObjName ,
SE_OBJECT_TYPE ObjectType ,
LPSTR ObjectTypeName ,
LPSTR InheritedObjectTypeName ,
LPSTR Name ) ;
2010-10-01 13:33:37 +02:00
static VOID ( WINAPI * pBuildTrusteeWithObjectsAndSidA ) ( PTRUSTEEA pTrustee ,
2006-03-26 13:39:58 +02:00
POBJECTS_AND_SID pObjSid ,
GUID * pObjectGuid ,
GUID * pInheritedObjectGuid ,
PSID pSid ) ;
2010-10-01 13:33:37 +02:00
static LPSTR ( WINAPI * pGetTrusteeNameA ) ( PTRUSTEEA pTrustee ) ;
static BOOL ( WINAPI * pMakeSelfRelativeSD ) ( PSECURITY_DESCRIPTOR , PSECURITY_DESCRIPTOR , LPDWORD ) ;
static BOOL ( WINAPI * pConvertSidToStringSidA ) ( PSID pSid , LPSTR * str ) ;
static BOOL ( WINAPI * pConvertStringSidToSidA ) ( LPCSTR str , PSID pSid ) ;
2009-11-10 13:04:55 +01:00
static BOOL ( WINAPI * pCheckTokenMembership ) ( HANDLE , PSID , PBOOL ) ;
2007-07-20 13:53:44 +02:00
static BOOL ( WINAPI * pConvertStringSecurityDescriptorToSecurityDescriptorA ) ( LPCSTR , DWORD ,
PSECURITY_DESCRIPTOR * , PULONG ) ;
2008-10-13 23:02:06 +02:00
static BOOL ( WINAPI * pConvertStringSecurityDescriptorToSecurityDescriptorW ) ( LPCWSTR , DWORD ,
PSECURITY_DESCRIPTOR * , PULONG ) ;
2007-09-25 22:12:50 +02:00
static BOOL ( WINAPI * pConvertSecurityDescriptorToStringSecurityDescriptorA ) ( PSECURITY_DESCRIPTOR , DWORD ,
SECURITY_INFORMATION , LPSTR * , PULONG ) ;
2010-10-01 13:33:37 +02:00
static BOOL ( WINAPI * pGetFileSecurityA ) ( LPCSTR , SECURITY_INFORMATION ,
2005-03-28 12:00:59 +02:00
PSECURITY_DESCRIPTOR , DWORD , LPDWORD ) ;
2010-10-01 13:33:37 +02:00
static BOOL ( WINAPI * pSetFileSecurityA ) ( LPCSTR , SECURITY_INFORMATION ,
2008-11-05 08:01:46 +01:00
PSECURITY_DESCRIPTOR ) ;
2007-08-14 11:05:04 +02:00
static DWORD ( WINAPI * pGetNamedSecurityInfoA ) ( LPSTR , SE_OBJECT_TYPE , SECURITY_INFORMATION ,
PSID * , PSID * , PACL * , PACL * ,
PSECURITY_DESCRIPTOR * ) ;
2013-10-15 10:15:45 +02:00
static DWORD ( WINAPI * pSetNamedSecurityInfoA ) ( LPSTR , SE_OBJECT_TYPE , SECURITY_INFORMATION ,
2012-11-26 20:08:57 +01:00
PSID , PSID , PACL , PACL ) ;
2009-06-27 12:48:46 +02:00
static PDWORD ( WINAPI * pGetSidSubAuthority ) ( PSID , DWORD ) ;
static PUCHAR ( WINAPI * pGetSidSubAuthorityCount ) ( PSID ) ;
static BOOL ( WINAPI * pIsValidSid ) ( PSID ) ;
2010-10-01 13:33:37 +02:00
static DWORD ( WINAPI * pRtlAdjustPrivilege ) ( ULONG , BOOLEAN , BOOLEAN , PBOOLEAN ) ;
static BOOL ( WINAPI * pCreateWellKnownSid ) ( WELL_KNOWN_SID_TYPE , PSID , PSID , DWORD * ) ;
static BOOL ( WINAPI * pDuplicateTokenEx ) ( HANDLE , DWORD , LPSECURITY_ATTRIBUTES ,
2007-03-16 22:37:14 +01:00
SECURITY_IMPERSONATION_LEVEL , TOKEN_TYPE , PHANDLE ) ;
2004-08-09 20:47:22 +02:00
2010-10-01 13:33:37 +02:00
static NTSTATUS ( WINAPI * pLsaQueryInformationPolicy ) ( LSA_HANDLE , POLICY_INFORMATION_CLASS , PVOID * ) ;
static NTSTATUS ( WINAPI * pLsaClose ) ( LSA_HANDLE ) ;
static NTSTATUS ( WINAPI * pLsaFreeMemory ) ( PVOID ) ;
static NTSTATUS ( WINAPI * pLsaOpenPolicy ) ( PLSA_UNICODE_STRING , PLSA_OBJECT_ATTRIBUTES , ACCESS_MASK , PLSA_HANDLE ) ;
2007-01-25 07:43:18 +01:00
static NTSTATUS ( WINAPI * pNtQueryObject ) ( HANDLE , OBJECT_INFORMATION_CLASS , PVOID , ULONG , PULONG ) ;
2007-08-14 11:05:04 +02:00
static DWORD ( WINAPI * pSetEntriesInAclW ) ( ULONG , PEXPLICIT_ACCESSW , PACL , PACL * ) ;
2011-01-01 21:19:55 +01:00
static DWORD ( WINAPI * pSetEntriesInAclA ) ( ULONG , PEXPLICIT_ACCESSA , PACL , PACL * ) ;
2007-11-02 11:33:36 +01:00
static BOOL ( WINAPI * pSetSecurityDescriptorControl ) ( PSECURITY_DESCRIPTOR , SECURITY_DESCRIPTOR_CONTROL ,
SECURITY_DESCRIPTOR_CONTROL ) ;
2008-08-25 14:16:25 +02:00
static DWORD ( WINAPI * pGetSecurityInfo ) ( HANDLE , SE_OBJECT_TYPE , SECURITY_INFORMATION ,
PSID * , PSID * , PACL * , PACL * , PSECURITY_DESCRIPTOR * ) ;
2012-11-15 18:16:23 +01:00
static DWORD ( WINAPI * pSetSecurityInfo ) ( HANDLE , SE_OBJECT_TYPE , SECURITY_INFORMATION ,
PSID , PSID , PACL , PACL ) ;
2009-01-13 20:54:32 +01:00
static NTSTATUS ( WINAPI * pNtAccessCheck ) ( PSECURITY_DESCRIPTOR , HANDLE , ACCESS_MASK , PGENERIC_MAPPING ,
PPRIVILEGE_SET , PULONG , PULONG , NTSTATUS * ) ;
2011-08-02 09:09:18 +02:00
static BOOL ( WINAPI * pCreateRestrictedToken ) ( HANDLE , DWORD , DWORD , PSID_AND_ATTRIBUTES , DWORD ,
PLUID_AND_ATTRIBUTES , DWORD , PSID_AND_ATTRIBUTES , PHANDLE ) ;
2012-11-15 18:16:23 +01:00
static BOOL ( WINAPI * pGetAclInformation ) ( PACL , LPVOID , DWORD , ACL_INFORMATION_CLASS ) ;
static BOOL ( WINAPI * pGetAce ) ( PACL , DWORD , LPVOID * ) ;
2006-08-04 14:17:58 +02:00
2004-11-04 05:52:17 +01:00
static HMODULE hmod ;
2007-01-25 07:43:18 +01:00
static int myARGC ;
static char * * myARGV ;
2004-11-04 05:52:17 +01:00
2012-11-13 05:31:25 +01:00
struct strsid_entry
{
const char * str ;
DWORD flags ;
} ;
# define STRSID_OK 0
# define STRSID_OPT 1
2004-09-16 22:27:52 +02:00
struct sidRef
{
SID_IDENTIFIER_AUTHORITY auth ;
const char * refStr ;
} ;
2004-08-09 20:47:22 +02:00
2004-11-04 05:52:17 +01:00
static void init ( void )
{
2007-07-20 13:53:44 +02:00
HMODULE hntdll ;
hntdll = GetModuleHandleA ( " ntdll.dll " ) ;
pNtQueryObject = ( void * ) GetProcAddress ( hntdll , " NtQueryObject " ) ;
2009-01-13 20:54:32 +01:00
pNtAccessCheck = ( void * ) GetProcAddress ( hntdll , " NtAccessCheck " ) ;
2007-01-25 07:43:18 +01:00
2013-10-15 10:15:45 +02:00
hmod = GetModuleHandleA ( " advapi32.dll " ) ;
2007-11-02 11:33:36 +01:00
pAddAccessAllowedAceEx = ( void * ) GetProcAddress ( hmod , " AddAccessAllowedAceEx " ) ;
pAddAccessDeniedAceEx = ( void * ) GetProcAddress ( hmod , " AddAccessDeniedAceEx " ) ;
pAddAuditAccessAceEx = ( void * ) GetProcAddress ( hmod , " AddAuditAccessAceEx " ) ;
2009-11-10 13:04:55 +01:00
pCheckTokenMembership = ( void * ) GetProcAddress ( hmod , " CheckTokenMembership " ) ;
2007-07-20 13:53:44 +02:00
pConvertStringSecurityDescriptorToSecurityDescriptorA =
( void * ) GetProcAddress ( hmod , " ConvertStringSecurityDescriptorToSecurityDescriptorA " ) ;
2008-10-13 23:02:06 +02:00
pConvertStringSecurityDescriptorToSecurityDescriptorW =
( void * ) GetProcAddress ( hmod , " ConvertStringSecurityDescriptorToSecurityDescriptorW " ) ;
2007-09-25 22:12:50 +02:00
pConvertSecurityDescriptorToStringSecurityDescriptorA =
( void * ) GetProcAddress ( hmod , " ConvertSecurityDescriptorToStringSecurityDescriptorA " ) ;
2010-10-01 13:33:37 +02:00
pGetFileSecurityA = ( void * ) GetProcAddress ( hmod , " GetFileSecurityA " ) ;
pSetFileSecurityA = ( void * ) GetProcAddress ( hmod , " SetFileSecurityA " ) ;
pCreateWellKnownSid = ( void * ) GetProcAddress ( hmod , " CreateWellKnownSid " ) ;
2007-08-14 11:05:04 +02:00
pGetNamedSecurityInfoA = ( void * ) GetProcAddress ( hmod , " GetNamedSecurityInfoA " ) ;
2012-11-26 20:08:57 +01:00
pSetNamedSecurityInfoA = ( void * ) GetProcAddress ( hmod , " SetNamedSecurityInfoA " ) ;
2009-06-27 12:48:46 +02:00
pGetSidSubAuthority = ( void * ) GetProcAddress ( hmod , " GetSidSubAuthority " ) ;
pGetSidSubAuthorityCount = ( void * ) GetProcAddress ( hmod , " GetSidSubAuthorityCount " ) ;
pIsValidSid = ( void * ) GetProcAddress ( hmod , " IsValidSid " ) ;
2007-11-02 11:33:36 +01:00
pMakeSelfRelativeSD = ( void * ) GetProcAddress ( hmod , " MakeSelfRelativeSD " ) ;
2007-08-14 11:05:04 +02:00
pSetEntriesInAclW = ( void * ) GetProcAddress ( hmod , " SetEntriesInAclW " ) ;
2011-01-01 21:19:55 +01:00
pSetEntriesInAclA = ( void * ) GetProcAddress ( hmod , " SetEntriesInAclA " ) ;
2007-11-02 11:33:36 +01:00
pSetSecurityDescriptorControl = ( void * ) GetProcAddress ( hmod , " SetSecurityDescriptorControl " ) ;
2008-08-25 14:16:25 +02:00
pGetSecurityInfo = ( void * ) GetProcAddress ( hmod , " GetSecurityInfo " ) ;
2012-11-15 18:16:23 +01:00
pSetSecurityInfo = ( void * ) GetProcAddress ( hmod , " SetSecurityInfo " ) ;
2011-08-02 09:09:18 +02:00
pCreateRestrictedToken = ( void * ) GetProcAddress ( hmod , " CreateRestrictedToken " ) ;
2012-07-31 00:09:02 +02:00
pConvertSidToStringSidA = ( void * ) GetProcAddress ( hmod , " ConvertSidToStringSidA " ) ;
pConvertStringSidToSidA = ( void * ) GetProcAddress ( hmod , " ConvertStringSidToSidA " ) ;
2012-11-15 18:16:23 +01:00
pGetAclInformation = ( void * ) GetProcAddress ( hmod , " GetAclInformation " ) ;
pGetAce = ( void * ) GetProcAddress ( hmod , " GetAce " ) ;
2007-01-25 07:43:18 +01:00
2007-07-20 13:53:44 +02:00
myARGC = winetest_get_mainargs ( & myARGV ) ;
2004-11-04 05:52:17 +01:00
}
2005-06-09 11:48:36 +02:00
static void test_sid ( void )
2004-08-09 20:47:22 +02:00
{
2004-09-16 22:27:52 +02:00
struct sidRef refs [ ] = {
{ { { 0x00 , 0x00 , 0x33 , 0x44 , 0x55 , 0x66 } } , " S-1-860116326-1 " } ,
{ { { 0x00 , 0x00 , 0x01 , 0x02 , 0x03 , 0x04 } } , " S-1-16909060-1 " } ,
{ { { 0x00 , 0x00 , 0x00 , 0x01 , 0x02 , 0x03 } } , " S-1-66051-1 " } ,
{ { { 0x00 , 0x00 , 0x00 , 0x00 , 0x01 , 0x02 } } , " S-1-258-1 " } ,
{ { { 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x02 } } , " S-1-2-1 " } ,
{ { { 0x00 , 0x00 , 0x00 , 0x00 , 0x00 , 0x0c } } , " S-1-12-1 " } ,
} ;
2012-11-13 05:31:25 +01:00
struct strsid_entry strsid_table [ ] = {
{ " AO " , STRSID_OK } , { " RU " , STRSID_OK } , { " AN " , STRSID_OK } , { " AU " , STRSID_OK } ,
{ " BA " , STRSID_OK } , { " BG " , STRSID_OK } , { " BO " , STRSID_OK } , { " BU " , STRSID_OK } ,
{ " CA " , STRSID_OPT } , { " CG " , STRSID_OK } , { " CO " , STRSID_OK } , { " DA " , STRSID_OPT } ,
{ " DC " , STRSID_OPT } , { " DD " , STRSID_OPT } , { " DG " , STRSID_OPT } , { " DU " , STRSID_OPT } ,
{ " EA " , STRSID_OPT } , { " ED " , STRSID_OK } , { " WD " , STRSID_OK } , { " PA " , STRSID_OPT } ,
{ " IU " , STRSID_OK } , { " LA " , STRSID_OK } , { " LG " , STRSID_OK } , { " LS " , STRSID_OK } ,
{ " SY " , STRSID_OK } , { " NU " , STRSID_OK } , { " NO " , STRSID_OK } , { " NS " , STRSID_OK } ,
{ " PO " , STRSID_OK } , { " PS " , STRSID_OK } , { " PU " , STRSID_OK } , { " RS " , STRSID_OPT } ,
{ " RD " , STRSID_OK } , { " RE " , STRSID_OK } , { " RC " , STRSID_OK } , { " SA " , STRSID_OPT } ,
{ " SO " , STRSID_OK } , { " SU " , STRSID_OK } } ;
2004-09-16 22:27:52 +02:00
const char noSubAuthStr [ ] = " S-1-5 " ;
unsigned int i ;
PSID psid = NULL ;
2007-09-25 04:04:11 +02:00
SID * pisid ;
2004-08-09 20:47:22 +02:00
BOOL r ;
2004-09-16 22:27:52 +02:00
LPSTR str = NULL ;
2004-08-09 20:47:22 +02:00
2012-07-31 00:09:02 +02:00
if ( ! pConvertSidToStringSidA | | ! pConvertStringSidToSidA )
{
win_skip ( " ConvertSidToStringSidA or ConvertStringSidToSidA not available \n " ) ;
2004-09-16 22:27:52 +02:00
return ;
2012-07-31 00:09:02 +02:00
}
2004-08-09 20:47:22 +02:00
2004-09-16 22:27:52 +02:00
r = pConvertStringSidToSidA ( NULL , NULL ) ;
ok ( ! r , " expected failure with NULL parameters \n " ) ;
if ( GetLastError ( ) = = ERROR_CALL_NOT_IMPLEMENTED )
2004-08-09 20:47:22 +02:00
return ;
2004-09-16 22:27:52 +02:00
ok ( GetLastError ( ) = = ERROR_INVALID_PARAMETER ,
2006-10-04 12:37:30 +02:00
" expected GetLastError() is ERROR_INVALID_PARAMETER, got %d \n " ,
2004-09-16 22:27:52 +02:00
GetLastError ( ) ) ;
r = pConvertStringSidToSidA ( refs [ 0 ] . refStr , NULL ) ;
ok ( ! r & & GetLastError ( ) = = ERROR_INVALID_PARAMETER ,
2006-10-04 12:37:30 +02:00
" expected GetLastError() is ERROR_INVALID_PARAMETER, got %d \n " ,
2004-09-16 22:27:52 +02:00
GetLastError ( ) ) ;
r = pConvertStringSidToSidA ( NULL , & str ) ;
ok ( ! r & & GetLastError ( ) = = ERROR_INVALID_PARAMETER ,
2006-10-04 12:37:30 +02:00
" expected GetLastError() is ERROR_INVALID_PARAMETER, got %d \n " ,
2004-09-16 22:27:52 +02:00
GetLastError ( ) ) ;
r = pConvertStringSidToSidA ( noSubAuthStr , & psid ) ;
ok ( ! r ,
" expected failure with no sub authorities \n " ) ;
ok ( GetLastError ( ) = = ERROR_INVALID_SID ,
2006-10-04 12:37:30 +02:00
" expected GetLastError() is ERROR_INVALID_SID, got %d \n " ,
2004-09-16 22:27:52 +02:00
GetLastError ( ) ) ;
2007-09-25 04:04:11 +02:00
ok ( pConvertStringSidToSidA ( " S-1-5-21-93476-23408-4576 " , & psid ) , " ConvertStringSidToSidA failed \n " ) ;
2009-01-13 10:57:53 +01:00
pisid = psid ;
2007-09-25 04:04:11 +02:00
ok ( pisid - > SubAuthorityCount = = 4 , " Invalid sub authority count - expected 4, got %d \n " , pisid - > SubAuthorityCount ) ;
2011-08-03 23:50:18 +02:00
ok ( pisid - > SubAuthority [ 0 ] = = 21 , " Invalid subauthority 0 - expected 21, got %d \n " , pisid - > SubAuthority [ 0 ] ) ;
ok ( pisid - > SubAuthority [ 3 ] = = 4576 , " Invalid subauthority 0 - expected 4576, got %d \n " , pisid - > SubAuthority [ 3 ] ) ;
2007-09-25 04:04:11 +02:00
LocalFree ( str ) ;
2009-12-02 15:32:07 +01:00
LocalFree ( psid ) ;
2007-09-25 04:04:11 +02:00
2004-09-16 22:27:52 +02:00
for ( i = 0 ; i < sizeof ( refs ) / sizeof ( refs [ 0 ] ) ; i + + )
{
r = AllocateAndInitializeSid ( & refs [ i ] . auth , 1 , 1 , 0 , 0 , 0 , 0 , 0 , 0 , 0 ,
& psid ) ;
ok ( r , " failed to allocate sid \n " ) ;
r = pConvertSidToStringSidA ( psid , & str ) ;
ok ( r , " failed to convert sid \n " ) ;
2005-03-14 18:20:58 +01:00
if ( r )
{
ok ( ! strcmp ( str , refs [ i ] . refStr ) ,
" incorrect sid, expected %s, got %s \n " , refs [ i ] . refStr , str ) ;
2004-09-16 22:27:52 +02:00
LocalFree ( str ) ;
2005-03-14 18:20:58 +01:00
}
2004-09-16 22:27:52 +02:00
if ( psid )
FreeSid ( psid ) ;
r = pConvertStringSidToSidA ( refs [ i ] . refStr , & psid ) ;
ok ( r , " failed to parse sid string \n " ) ;
2009-01-13 10:57:53 +01:00
pisid = psid ;
2004-09-16 22:27:52 +02:00
ok ( pisid & &
! memcmp ( pisid - > IdentifierAuthority . Value , refs [ i ] . auth . Value ,
sizeof ( refs [ i ] . auth ) ) ,
" string sid %s didn't parse to expected value \n "
2006-10-04 12:37:30 +02:00
" (got 0x%04x%08x, expected 0x%04x%08x) \n " ,
2004-09-16 22:27:52 +02:00
refs [ i ] . refStr ,
MAKEWORD ( pisid - > IdentifierAuthority . Value [ 1 ] ,
pisid - > IdentifierAuthority . Value [ 0 ] ) ,
MAKELONG ( MAKEWORD ( pisid - > IdentifierAuthority . Value [ 5 ] ,
pisid - > IdentifierAuthority . Value [ 4 ] ) ,
MAKEWORD ( pisid - > IdentifierAuthority . Value [ 3 ] ,
pisid - > IdentifierAuthority . Value [ 2 ] ) ) ,
MAKEWORD ( refs [ i ] . auth . Value [ 1 ] , refs [ i ] . auth . Value [ 0 ] ) ,
MAKELONG ( MAKEWORD ( refs [ i ] . auth . Value [ 5 ] , refs [ i ] . auth . Value [ 4 ] ) ,
MAKEWORD ( refs [ i ] . auth . Value [ 3 ] , refs [ i ] . auth . Value [ 2 ] ) ) ) ;
if ( psid )
LocalFree ( psid ) ;
}
2006-07-29 13:45:23 +02:00
2012-11-13 05:31:25 +01:00
/* string constant format not supported before XP */
r = pConvertStringSidToSidA ( strsid_table [ 0 ] . str , & psid ) ;
if ( ! r )
{
win_skip ( " String constant format not supported \n " ) ;
return ;
}
LocalFree ( psid ) ;
for ( i = 0 ; i < sizeof ( strsid_table ) / sizeof ( strsid_table [ 0 ] ) ; i + + )
{
char * temp ;
SetLastError ( 0xdeadbeef ) ;
r = pConvertStringSidToSidA ( strsid_table [ i ] . str , & psid ) ;
if ( ! ( strsid_table [ i ] . flags & STRSID_OPT ) )
{
ok ( r , " %s: got %u \n " , strsid_table [ i ] . str , GetLastError ( ) ) ;
}
if ( r )
{
if ( ( winetest_debug > 1 ) & & ( pConvertSidToStringSidA ( psid , & temp ) ) )
{
trace ( " %s: %s \n " , strsid_table [ i ] . str , temp ) ;
LocalFree ( temp ) ;
}
LocalFree ( psid ) ;
}
else
{
if ( GetLastError ( ) ! = ERROR_INVALID_SID )
trace ( " %s: couldn't be converted, returned %d \n " , strsid_table [ i ] . str , GetLastError ( ) ) ;
else
trace ( " %s: couldn't be converted \n " , strsid_table [ i ] . str ) ;
}
}
2004-08-16 23:07:50 +02:00
}
2005-06-09 11:48:36 +02:00
static void test_trustee ( void )
2004-08-16 23:07:50 +02:00
{
2006-03-26 13:39:58 +02:00
GUID ObjectType = { 0x12345678 , 0x1234 , 0x5678 , { 0x11 , 0x22 , 0x33 , 0x44 , 0x55 , 0x66 , 0x77 , 0x88 } } ;
GUID InheritedObjectType = { 0x23456789 , 0x2345 , 0x6786 , { 0x2 , 0x33 , 0x44 , 0x55 , 0x66 , 0x77 , 0x88 , 0x99 } } ;
GUID ZeroGuid ;
2013-10-15 10:15:45 +02:00
OBJECTS_AND_NAME_A oan ;
2006-03-26 13:39:58 +02:00
OBJECTS_AND_SID oas ;
2013-10-15 10:15:45 +02:00
TRUSTEEA trustee ;
2004-08-16 23:07:50 +02:00
PSID psid ;
2006-03-26 13:39:58 +02:00
char szObjectTypeName [ ] = " ObjectTypeName " ;
char szInheritedObjectTypeName [ ] = " InheritedObjectTypeName " ;
char szTrusteeName [ ] = " szTrusteeName " ;
2006-03-28 14:43:18 +02:00
SID_IDENTIFIER_AUTHORITY auth = { { 0x11 , 0x22 , 0 , 0 , 0 , 0 } } ;
2006-03-26 13:39:58 +02:00
memset ( & ZeroGuid , 0x00 , sizeof ( ZeroGuid ) ) ;
2004-08-16 23:07:50 +02:00
2010-10-01 13:33:37 +02:00
pBuildTrusteeWithSidA = ( void * ) GetProcAddress ( hmod , " BuildTrusteeWithSidA " ) ;
pBuildTrusteeWithNameA = ( void * ) GetProcAddress ( hmod , " BuildTrusteeWithNameA " ) ;
pBuildTrusteeWithObjectsAndNameA = ( void * ) GetProcAddress ( hmod , " BuildTrusteeWithObjectsAndNameA " ) ;
pBuildTrusteeWithObjectsAndSidA = ( void * ) GetProcAddress ( hmod , " BuildTrusteeWithObjectsAndSidA " ) ;
pGetTrusteeNameA = ( void * ) GetProcAddress ( hmod , " GetTrusteeNameA " ) ;
2006-03-26 13:39:58 +02:00
if ( ! pBuildTrusteeWithSidA | | ! pBuildTrusteeWithNameA | |
! pBuildTrusteeWithObjectsAndNameA | | ! pBuildTrusteeWithObjectsAndSidA | |
! pGetTrusteeNameA )
2005-02-14 12:06:16 +01:00
return ;
2004-11-03 23:14:55 +01:00
if ( ! AllocateAndInitializeSid ( & auth , 1 , 42 , 0 , 0 , 0 , 0 , 0 , 0 , 0 , & psid ) )
{
trace ( " failed to init SID \n " ) ;
return ;
}
2004-08-16 23:07:50 +02:00
2006-03-26 13:39:58 +02:00
/* test BuildTrusteeWithSidA */
2004-08-16 23:07:50 +02:00
memset ( & trustee , 0xff , sizeof trustee ) ;
2005-02-14 12:06:16 +01:00
pBuildTrusteeWithSidA ( & trustee , psid ) ;
2004-08-16 23:07:50 +02:00
ok ( trustee . pMultipleTrustee = = NULL , " pMultipleTrustee wrong \n " ) ;
ok ( trustee . MultipleTrusteeOperation = = NO_MULTIPLE_TRUSTEE ,
" MultipleTrusteeOperation wrong \n " ) ;
ok ( trustee . TrusteeForm = = TRUSTEE_IS_SID , " TrusteeForm wrong \n " ) ;
ok ( trustee . TrusteeType = = TRUSTEE_IS_UNKNOWN , " TrusteeType wrong \n " ) ;
2009-01-13 10:57:53 +01:00
ok ( trustee . ptstrName = = psid , " ptstrName wrong \n " ) ;
2006-03-26 13:39:58 +02:00
/* test BuildTrusteeWithObjectsAndSidA (test 1) */
memset ( & trustee , 0xff , sizeof trustee ) ;
memset ( & oas , 0xff , sizeof ( oas ) ) ;
pBuildTrusteeWithObjectsAndSidA ( & trustee , & oas , & ObjectType ,
& InheritedObjectType , psid ) ;
ok ( trustee . pMultipleTrustee = = NULL , " pMultipleTrustee wrong \n " ) ;
ok ( trustee . MultipleTrusteeOperation = = NO_MULTIPLE_TRUSTEE , " MultipleTrusteeOperation wrong \n " ) ;
ok ( trustee . TrusteeForm = = TRUSTEE_IS_OBJECTS_AND_SID , " TrusteeForm wrong \n " ) ;
ok ( trustee . TrusteeType = = TRUSTEE_IS_UNKNOWN , " TrusteeType wrong \n " ) ;
ok ( trustee . ptstrName = = ( LPSTR ) & oas , " ptstrName wrong \n " ) ;
ok ( oas . ObjectsPresent = = ( ACE_OBJECT_TYPE_PRESENT | ACE_INHERITED_OBJECT_TYPE_PRESENT ) , " ObjectsPresent wrong \n " ) ;
ok ( ! memcmp ( & oas . ObjectTypeGuid , & ObjectType , sizeof ( GUID ) ) , " ObjectTypeGuid wrong \n " ) ;
ok ( ! memcmp ( & oas . InheritedObjectTypeGuid , & InheritedObjectType , sizeof ( GUID ) ) , " InheritedObjectTypeGuid wrong \n " ) ;
ok ( oas . pSid = = psid , " pSid wrong \n " ) ;
/* test GetTrusteeNameA */
ok ( pGetTrusteeNameA ( & trustee ) = = ( LPSTR ) & oas , " GetTrusteeName returned wrong value \n " ) ;
/* test BuildTrusteeWithObjectsAndSidA (test 2) */
memset ( & trustee , 0xff , sizeof trustee ) ;
memset ( & oas , 0xff , sizeof ( oas ) ) ;
pBuildTrusteeWithObjectsAndSidA ( & trustee , & oas , NULL ,
& InheritedObjectType , psid ) ;
ok ( trustee . pMultipleTrustee = = NULL , " pMultipleTrustee wrong \n " ) ;
ok ( trustee . MultipleTrusteeOperation = = NO_MULTIPLE_TRUSTEE , " MultipleTrusteeOperation wrong \n " ) ;
ok ( trustee . TrusteeForm = = TRUSTEE_IS_OBJECTS_AND_SID , " TrusteeForm wrong \n " ) ;
ok ( trustee . TrusteeType = = TRUSTEE_IS_UNKNOWN , " TrusteeType wrong \n " ) ;
ok ( trustee . ptstrName = = ( LPSTR ) & oas , " ptstrName wrong \n " ) ;
ok ( oas . ObjectsPresent = = ACE_INHERITED_OBJECT_TYPE_PRESENT , " ObjectsPresent wrong \n " ) ;
ok ( ! memcmp ( & oas . ObjectTypeGuid , & ZeroGuid , sizeof ( GUID ) ) , " ObjectTypeGuid wrong \n " ) ;
ok ( ! memcmp ( & oas . InheritedObjectTypeGuid , & InheritedObjectType , sizeof ( GUID ) ) , " InheritedObjectTypeGuid wrong \n " ) ;
ok ( oas . pSid = = psid , " pSid wrong \n " ) ;
2004-08-16 23:07:50 +02:00
FreeSid ( psid ) ;
2004-08-09 20:47:22 +02:00
2004-08-19 21:01:12 +02:00
/* test BuildTrusteeWithNameA */
memset ( & trustee , 0xff , sizeof trustee ) ;
2006-03-26 13:39:58 +02:00
pBuildTrusteeWithNameA ( & trustee , szTrusteeName ) ;
2004-08-19 21:01:12 +02:00
ok ( trustee . pMultipleTrustee = = NULL , " pMultipleTrustee wrong \n " ) ;
ok ( trustee . MultipleTrusteeOperation = = NO_MULTIPLE_TRUSTEE ,
" MultipleTrusteeOperation wrong \n " ) ;
ok ( trustee . TrusteeForm = = TRUSTEE_IS_NAME , " TrusteeForm wrong \n " ) ;
ok ( trustee . TrusteeType = = TRUSTEE_IS_UNKNOWN , " TrusteeType wrong \n " ) ;
2006-03-26 13:39:58 +02:00
ok ( trustee . ptstrName = = szTrusteeName , " ptstrName wrong \n " ) ;
/* test BuildTrusteeWithObjectsAndNameA (test 1) */
memset ( & trustee , 0xff , sizeof trustee ) ;
memset ( & oan , 0xff , sizeof ( oan ) ) ;
pBuildTrusteeWithObjectsAndNameA ( & trustee , & oan , SE_KERNEL_OBJECT , szObjectTypeName ,
szInheritedObjectTypeName , szTrusteeName ) ;
ok ( trustee . pMultipleTrustee = = NULL , " pMultipleTrustee wrong \n " ) ;
ok ( trustee . MultipleTrusteeOperation = = NO_MULTIPLE_TRUSTEE , " MultipleTrusteeOperation wrong \n " ) ;
ok ( trustee . TrusteeForm = = TRUSTEE_IS_OBJECTS_AND_NAME , " TrusteeForm wrong \n " ) ;
ok ( trustee . TrusteeType = = TRUSTEE_IS_UNKNOWN , " TrusteeType wrong \n " ) ;
2013-10-15 10:15:45 +02:00
ok ( trustee . ptstrName = = ( LPSTR ) & oan , " ptstrName wrong \n " ) ;
2006-03-26 13:39:58 +02:00
ok ( oan . ObjectsPresent = = ( ACE_OBJECT_TYPE_PRESENT | ACE_INHERITED_OBJECT_TYPE_PRESENT ) , " ObjectsPresent wrong \n " ) ;
ok ( oan . ObjectType = = SE_KERNEL_OBJECT , " ObjectType wrong \n " ) ;
ok ( oan . InheritedObjectTypeName = = szInheritedObjectTypeName , " InheritedObjectTypeName wrong \n " ) ;
ok ( oan . ptstrName = = szTrusteeName , " szTrusteeName wrong \n " ) ;
/* test GetTrusteeNameA */
ok ( pGetTrusteeNameA ( & trustee ) = = ( LPSTR ) & oan , " GetTrusteeName returned wrong value \n " ) ;
/* test BuildTrusteeWithObjectsAndNameA (test 2) */
memset ( & trustee , 0xff , sizeof trustee ) ;
memset ( & oan , 0xff , sizeof ( oan ) ) ;
pBuildTrusteeWithObjectsAndNameA ( & trustee , & oan , SE_KERNEL_OBJECT , NULL ,
szInheritedObjectTypeName , szTrusteeName ) ;
ok ( trustee . pMultipleTrustee = = NULL , " pMultipleTrustee wrong \n " ) ;
ok ( trustee . MultipleTrusteeOperation = = NO_MULTIPLE_TRUSTEE , " MultipleTrusteeOperation wrong \n " ) ;
ok ( trustee . TrusteeForm = = TRUSTEE_IS_OBJECTS_AND_NAME , " TrusteeForm wrong \n " ) ;
ok ( trustee . TrusteeType = = TRUSTEE_IS_UNKNOWN , " TrusteeType wrong \n " ) ;
ok ( trustee . ptstrName = = ( LPSTR ) & oan , " ptstrName wrong \n " ) ;
ok ( oan . ObjectsPresent = = ACE_INHERITED_OBJECT_TYPE_PRESENT , " ObjectsPresent wrong \n " ) ;
ok ( oan . ObjectType = = SE_KERNEL_OBJECT , " ObjectType wrong \n " ) ;
ok ( oan . InheritedObjectTypeName = = szInheritedObjectTypeName , " InheritedObjectTypeName wrong \n " ) ;
ok ( oan . ptstrName = = szTrusteeName , " szTrusteeName wrong \n " ) ;
/* test BuildTrusteeWithObjectsAndNameA (test 3) */
memset ( & trustee , 0xff , sizeof trustee ) ;
memset ( & oan , 0xff , sizeof ( oan ) ) ;
pBuildTrusteeWithObjectsAndNameA ( & trustee , & oan , SE_KERNEL_OBJECT , szObjectTypeName ,
NULL , szTrusteeName ) ;
ok ( trustee . pMultipleTrustee = = NULL , " pMultipleTrustee wrong \n " ) ;
ok ( trustee . MultipleTrusteeOperation = = NO_MULTIPLE_TRUSTEE , " MultipleTrusteeOperation wrong \n " ) ;
ok ( trustee . TrusteeForm = = TRUSTEE_IS_OBJECTS_AND_NAME , " TrusteeForm wrong \n " ) ;
ok ( trustee . TrusteeType = = TRUSTEE_IS_UNKNOWN , " TrusteeType wrong \n " ) ;
2013-10-15 10:15:45 +02:00
ok ( trustee . ptstrName = = ( LPSTR ) & oan , " ptstrName wrong \n " ) ;
2006-03-26 13:39:58 +02:00
ok ( oan . ObjectsPresent = = ACE_OBJECT_TYPE_PRESENT , " ObjectsPresent wrong \n " ) ;
ok ( oan . ObjectType = = SE_KERNEL_OBJECT , " ObjectType wrong \n " ) ;
ok ( oan . InheritedObjectTypeName = = NULL , " InheritedObjectTypeName wrong \n " ) ;
ok ( oan . ptstrName = = szTrusteeName , " szTrusteeName wrong \n " ) ;
2004-08-19 21:01:12 +02:00
}
2004-11-04 05:52:17 +01:00
/* If the first isn't defined, assume none is */
# ifndef SE_MIN_WELL_KNOWN_PRIVILEGE
# define SE_MIN_WELL_KNOWN_PRIVILEGE 2L
# define SE_CREATE_TOKEN_PRIVILEGE 2L
# define SE_ASSIGNPRIMARYTOKEN_PRIVILEGE 3L
# define SE_LOCK_MEMORY_PRIVILEGE 4L
# define SE_INCREASE_QUOTA_PRIVILEGE 5L
# define SE_MACHINE_ACCOUNT_PRIVILEGE 6L
# define SE_TCB_PRIVILEGE 7L
# define SE_SECURITY_PRIVILEGE 8L
# define SE_TAKE_OWNERSHIP_PRIVILEGE 9L
# define SE_LOAD_DRIVER_PRIVILEGE 10L
# define SE_SYSTEM_PROFILE_PRIVILEGE 11L
# define SE_SYSTEMTIME_PRIVILEGE 12L
# define SE_PROF_SINGLE_PROCESS_PRIVILEGE 13L
# define SE_INC_BASE_PRIORITY_PRIVILEGE 14L
# define SE_CREATE_PAGEFILE_PRIVILEGE 15L
# define SE_CREATE_PERMANENT_PRIVILEGE 16L
# define SE_BACKUP_PRIVILEGE 17L
# define SE_RESTORE_PRIVILEGE 18L
# define SE_SHUTDOWN_PRIVILEGE 19L
# define SE_DEBUG_PRIVILEGE 20L
# define SE_AUDIT_PRIVILEGE 21L
# define SE_SYSTEM_ENVIRONMENT_PRIVILEGE 22L
2008-11-10 09:48:15 +01:00
# define SE_CHANGE_NOTIFY_PRIVILEGE 23L
2004-11-04 05:52:17 +01:00
# define SE_REMOTE_SHUTDOWN_PRIVILEGE 24L
# define SE_UNDOCK_PRIVILEGE 25L
# define SE_SYNC_AGENT_PRIVILEGE 26L
# define SE_ENABLE_DELEGATION_PRIVILEGE 27L
# define SE_MANAGE_VOLUME_PRIVILEGE 28L
# define SE_IMPERSONATE_PRIVILEGE 29L
# define SE_CREATE_GLOBAL_PRIVILEGE 30L
# define SE_MAX_WELL_KNOWN_PRIVILEGE SE_CREATE_GLOBAL_PRIVILEGE
# endif /* ndef SE_MIN_WELL_KNOWN_PRIVILEGE */
static void test_allocateLuid ( void )
{
BOOL ( WINAPI * pAllocateLocallyUniqueId ) ( PLUID ) ;
LUID luid1 , luid2 ;
BOOL ret ;
2005-02-14 22:04:45 +01:00
pAllocateLocallyUniqueId = ( void * ) GetProcAddress ( hmod , " AllocateLocallyUniqueId " ) ;
2004-11-04 05:52:17 +01:00
if ( ! pAllocateLocallyUniqueId ) return ;
ret = pAllocateLocallyUniqueId ( & luid1 ) ;
if ( ! ret & & GetLastError ( ) = = ERROR_CALL_NOT_IMPLEMENTED )
return ;
ok ( ret ,
2006-10-04 12:37:30 +02:00
" AllocateLocallyUniqueId failed: %d \n " , GetLastError ( ) ) ;
2004-12-27 18:26:37 +01:00
ret = pAllocateLocallyUniqueId ( & luid2 ) ;
ok ( ret ,
2006-10-04 12:37:30 +02:00
" AllocateLocallyUniqueId failed: %d \n " , GetLastError ( ) ) ;
2004-11-04 05:52:17 +01:00
ok ( luid1 . LowPart > SE_MAX_WELL_KNOWN_PRIVILEGE | | luid1 . HighPart ! = 0 ,
" AllocateLocallyUniqueId returned a well-known LUID \n " ) ;
ok ( luid1 . LowPart ! = luid2 . LowPart | | luid1 . HighPart ! = luid2 . HighPart ,
" AllocateLocallyUniqueId returned non-unique LUIDs \n " ) ;
2004-12-27 18:26:37 +01:00
ret = pAllocateLocallyUniqueId ( NULL ) ;
ok ( ! ret & & GetLastError ( ) = = ERROR_NOACCESS ,
2006-10-04 12:37:30 +02:00
" AllocateLocallyUniqueId(NULL) didn't return ERROR_NOACCESS: %d \n " ,
2004-11-04 05:52:17 +01:00
GetLastError ( ) ) ;
}
static void test_lookupPrivilegeName ( void )
{
2005-06-09 11:48:36 +02:00
BOOL ( WINAPI * pLookupPrivilegeNameA ) ( LPCSTR , PLUID , LPSTR , LPDWORD ) ;
2004-11-04 05:52:17 +01:00
char buf [ MAX_PATH ] ; /* arbitrary, seems long enough */
DWORD cchName = sizeof ( buf ) ;
LUID luid = { 0 , 0 } ;
LONG i ;
BOOL ret ;
/* check whether it's available first */
2005-02-14 22:04:45 +01:00
pLookupPrivilegeNameA = ( void * ) GetProcAddress ( hmod , " LookupPrivilegeNameA " ) ;
2004-11-04 05:52:17 +01:00
if ( ! pLookupPrivilegeNameA ) return ;
luid . LowPart = SE_CREATE_TOKEN_PRIVILEGE ;
ret = pLookupPrivilegeNameA ( NULL , & luid , buf , & cchName ) ;
if ( ! ret & & GetLastError ( ) = = ERROR_CALL_NOT_IMPLEMENTED )
return ;
/* check with a short buffer */
cchName = 0 ;
luid . LowPart = SE_CREATE_TOKEN_PRIVILEGE ;
2004-12-27 18:26:37 +01:00
ret = pLookupPrivilegeNameA ( NULL , & luid , NULL , & cchName ) ;
ok ( ! ret & & GetLastError ( ) = = ERROR_INSUFFICIENT_BUFFER ,
2006-10-04 12:37:30 +02:00
" LookupPrivilegeNameA didn't fail with ERROR_INSUFFICIENT_BUFFER: %d \n " ,
2004-11-04 05:52:17 +01:00
GetLastError ( ) ) ;
ok ( cchName = = strlen ( " SeCreateTokenPrivilege " ) + 1 ,
" LookupPrivilegeNameA returned an incorrect required length for \n "
2006-10-04 12:37:30 +02:00
" SeCreateTokenPrivilege (got %d, expected %d) \n " , cchName ,
2006-06-13 13:56:18 +02:00
lstrlenA ( " SeCreateTokenPrivilege " ) + 1 ) ;
2004-11-04 05:52:17 +01:00
/* check a known value and its returned length on success */
cchName = sizeof ( buf ) ;
ok ( pLookupPrivilegeNameA ( NULL , & luid , buf , & cchName ) & &
cchName = = strlen ( " SeCreateTokenPrivilege " ) ,
" LookupPrivilegeNameA returned an incorrect output length for \n "
2006-10-04 12:37:30 +02:00
" SeCreateTokenPrivilege (got %d, expected %d) \n " , cchName ,
2005-02-14 12:52:48 +01:00
( int ) strlen ( " SeCreateTokenPrivilege " ) ) ;
2004-11-04 05:52:17 +01:00
/* check known values */
2008-11-10 09:47:29 +01:00
for ( i = SE_MIN_WELL_KNOWN_PRIVILEGE ; i < = SE_MAX_WELL_KNOWN_PRIVILEGE ; i + + )
2004-11-04 05:52:17 +01:00
{
luid . LowPart = i ;
cchName = sizeof ( buf ) ;
2004-12-27 18:26:37 +01:00
ret = pLookupPrivilegeNameA ( NULL , & luid , buf , & cchName ) ;
2005-03-22 17:39:02 +01:00
ok ( ret | | GetLastError ( ) = = ERROR_NO_SUCH_PRIVILEGE ,
2006-10-04 12:37:30 +02:00
" LookupPrivilegeNameA(0.%d) failed: %d \n " , i , GetLastError ( ) ) ;
2004-11-04 05:52:17 +01:00
}
/* check a bogus LUID */
luid . LowPart = 0xdeadbeef ;
cchName = sizeof ( buf ) ;
2004-12-27 18:26:37 +01:00
ret = pLookupPrivilegeNameA ( NULL , & luid , buf , & cchName ) ;
ok ( ! ret & & GetLastError ( ) = = ERROR_NO_SUCH_PRIVILEGE ,
2006-10-04 12:37:30 +02:00
" LookupPrivilegeNameA didn't fail with ERROR_NO_SUCH_PRIVILEGE: %d \n " ,
2004-11-04 05:52:17 +01:00
GetLastError ( ) ) ;
/* check on a bogus system */
luid . LowPart = SE_CREATE_TOKEN_PRIVILEGE ;
cchName = sizeof ( buf ) ;
2004-12-27 18:26:37 +01:00
ret = pLookupPrivilegeNameA ( " b0gu5.Nam3 " , & luid , buf , & cchName ) ;
2008-08-07 12:57:44 +02:00
ok ( ! ret & & ( GetLastError ( ) = = RPC_S_SERVER_UNAVAILABLE | |
GetLastError ( ) = = RPC_S_INVALID_NET_ADDR ) /* w2k8 */ ,
" LookupPrivilegeNameA didn't fail with RPC_S_SERVER_UNAVAILABLE or RPC_S_INVALID_NET_ADDR: %d \n " ,
2004-11-04 05:52:17 +01:00
GetLastError ( ) ) ;
}
struct NameToLUID
{
const char * name ;
2005-02-14 22:04:45 +01:00
DWORD lowPart ;
2004-11-04 05:52:17 +01:00
} ;
static void test_lookupPrivilegeValue ( void )
{
static const struct NameToLUID privs [ ] = {
{ " SeCreateTokenPrivilege " , SE_CREATE_TOKEN_PRIVILEGE } ,
{ " SeAssignPrimaryTokenPrivilege " , SE_ASSIGNPRIMARYTOKEN_PRIVILEGE } ,
{ " SeLockMemoryPrivilege " , SE_LOCK_MEMORY_PRIVILEGE } ,
{ " SeIncreaseQuotaPrivilege " , SE_INCREASE_QUOTA_PRIVILEGE } ,
{ " SeMachineAccountPrivilege " , SE_MACHINE_ACCOUNT_PRIVILEGE } ,
{ " SeTcbPrivilege " , SE_TCB_PRIVILEGE } ,
{ " SeSecurityPrivilege " , SE_SECURITY_PRIVILEGE } ,
{ " SeTakeOwnershipPrivilege " , SE_TAKE_OWNERSHIP_PRIVILEGE } ,
{ " SeLoadDriverPrivilege " , SE_LOAD_DRIVER_PRIVILEGE } ,
{ " SeSystemProfilePrivilege " , SE_SYSTEM_PROFILE_PRIVILEGE } ,
{ " SeSystemtimePrivilege " , SE_SYSTEMTIME_PRIVILEGE } ,
{ " SeProfileSingleProcessPrivilege " , SE_PROF_SINGLE_PROCESS_PRIVILEGE } ,
{ " SeIncreaseBasePriorityPrivilege " , SE_INC_BASE_PRIORITY_PRIVILEGE } ,
{ " SeCreatePagefilePrivilege " , SE_CREATE_PAGEFILE_PRIVILEGE } ,
{ " SeCreatePermanentPrivilege " , SE_CREATE_PERMANENT_PRIVILEGE } ,
{ " SeBackupPrivilege " , SE_BACKUP_PRIVILEGE } ,
{ " SeRestorePrivilege " , SE_RESTORE_PRIVILEGE } ,
{ " SeShutdownPrivilege " , SE_SHUTDOWN_PRIVILEGE } ,
{ " SeDebugPrivilege " , SE_DEBUG_PRIVILEGE } ,
{ " SeAuditPrivilege " , SE_AUDIT_PRIVILEGE } ,
{ " SeSystemEnvironmentPrivilege " , SE_SYSTEM_ENVIRONMENT_PRIVILEGE } ,
2008-11-10 09:48:15 +01:00
{ " SeChangeNotifyPrivilege " , SE_CHANGE_NOTIFY_PRIVILEGE } ,
2004-11-04 05:52:17 +01:00
{ " SeRemoteShutdownPrivilege " , SE_REMOTE_SHUTDOWN_PRIVILEGE } ,
{ " SeUndockPrivilege " , SE_UNDOCK_PRIVILEGE } ,
{ " SeSyncAgentPrivilege " , SE_SYNC_AGENT_PRIVILEGE } ,
{ " SeEnableDelegationPrivilege " , SE_ENABLE_DELEGATION_PRIVILEGE } ,
{ " SeManageVolumePrivilege " , SE_MANAGE_VOLUME_PRIVILEGE } ,
{ " SeImpersonatePrivilege " , SE_IMPERSONATE_PRIVILEGE } ,
{ " SeCreateGlobalPrivilege " , SE_CREATE_GLOBAL_PRIVILEGE } ,
} ;
BOOL ( WINAPI * pLookupPrivilegeValueA ) ( LPCSTR , LPCSTR , PLUID ) ;
2010-06-18 22:01:57 +02:00
unsigned int i ;
2004-11-04 05:52:17 +01:00
LUID luid ;
BOOL ret ;
/* check whether it's available first */
2005-02-14 22:04:45 +01:00
pLookupPrivilegeValueA = ( void * ) GetProcAddress ( hmod , " LookupPrivilegeValueA " ) ;
2004-11-04 05:52:17 +01:00
if ( ! pLookupPrivilegeValueA ) return ;
ret = pLookupPrivilegeValueA ( NULL , " SeCreateTokenPrivilege " , & luid ) ;
if ( ! ret & & GetLastError ( ) = = ERROR_CALL_NOT_IMPLEMENTED )
return ;
/* check a bogus system name */
2004-12-27 18:26:37 +01:00
ret = pLookupPrivilegeValueA ( " b0gu5.Nam3 " , " SeCreateTokenPrivilege " , & luid ) ;
2008-08-07 12:57:44 +02:00
ok ( ! ret & & ( GetLastError ( ) = = RPC_S_SERVER_UNAVAILABLE | |
GetLastError ( ) = = RPC_S_INVALID_NET_ADDR ) /* w2k8 */ ,
" LookupPrivilegeValueA didn't fail with RPC_S_SERVER_UNAVAILABLE or RPC_S_INVALID_NET_ADDR: %d \n " ,
2004-11-04 05:52:17 +01:00
GetLastError ( ) ) ;
/* check a NULL string */
2004-12-27 18:26:37 +01:00
ret = pLookupPrivilegeValueA ( NULL , 0 , & luid ) ;
ok ( ! ret & & GetLastError ( ) = = ERROR_NO_SUCH_PRIVILEGE ,
2006-10-04 12:37:30 +02:00
" LookupPrivilegeValueA didn't fail with ERROR_NO_SUCH_PRIVILEGE: %d \n " ,
2004-11-04 05:52:17 +01:00
GetLastError ( ) ) ;
/* check a bogus privilege name */
2004-12-27 18:26:37 +01:00
ret = pLookupPrivilegeValueA ( NULL , " SeBogusPrivilege " , & luid ) ;
ok ( ! ret & & GetLastError ( ) = = ERROR_NO_SUCH_PRIVILEGE ,
2006-10-04 12:37:30 +02:00
" LookupPrivilegeValueA didn't fail with ERROR_NO_SUCH_PRIVILEGE: %d \n " ,
2004-11-04 05:52:17 +01:00
GetLastError ( ) ) ;
/* check case insensitive */
2004-12-27 18:26:37 +01:00
ret = pLookupPrivilegeValueA ( NULL , " sEcREATEtOKENpRIVILEGE " , & luid ) ;
ok ( ret ,
2006-10-04 12:37:30 +02:00
" LookupPrivilegeValueA(NULL, sEcREATEtOKENpRIVILEGE, &luid) failed: %d \n " ,
2004-11-04 05:52:17 +01:00
GetLastError ( ) ) ;
for ( i = 0 ; i < sizeof ( privs ) / sizeof ( privs [ 0 ] ) ; i + + )
{
/* Not all privileges are implemented on all Windows versions, so
* don ' t worry if the call fails
*/
if ( pLookupPrivilegeValueA ( NULL , privs [ i ] . name , & luid ) )
{
ok ( luid . LowPart = = privs [ i ] . lowPart ,
" LookupPrivilegeValueA returned an invalid LUID for %s \n " ,
privs [ i ] . name ) ;
}
}
}
static void test_luid ( void )
{
test_allocateLuid ( ) ;
test_lookupPrivilegeName ( ) ;
test_lookupPrivilegeValue ( ) ;
}
2005-03-28 12:00:59 +02:00
static void test_FileSecurity ( void )
{
2008-11-05 08:01:46 +01:00
char wintmpdir [ MAX_PATH ] ;
char path [ MAX_PATH ] ;
char file [ MAX_PATH ] ;
2011-03-16 11:45:43 +01:00
HANDLE fh , token ;
DWORD sdSize , retSize , rc , granted , priv_set_len ;
PRIVILEGE_SET priv_set ;
BOOL status ;
2008-11-05 08:01:46 +01:00
BYTE * sd ;
2011-03-16 11:45:43 +01:00
GENERIC_MAPPING mapping = { FILE_READ_DATA , FILE_WRITE_DATA , FILE_EXECUTE , FILE_ALL_ACCESS } ;
2011-03-14 11:31:40 +01:00
const SECURITY_INFORMATION request = OWNER_SECURITY_INFORMATION
2008-11-05 08:01:46 +01:00
| GROUP_SECURITY_INFORMATION
| DACL_SECURITY_INFORMATION ;
if ( ! pGetFileSecurityA ) {
win_skip ( " GetFileSecurity is not available \n " ) ;
2005-03-28 12:00:59 +02:00
return ;
2008-11-05 08:01:46 +01:00
}
2005-03-28 12:00:59 +02:00
2008-11-05 08:01:46 +01:00
if ( ! pSetFileSecurityA ) {
win_skip ( " SetFileSecurity is not available \n " ) ;
2005-03-28 12:00:59 +02:00
return ;
}
2008-11-05 08:01:46 +01:00
if ( ! GetTempPathA ( sizeof ( wintmpdir ) , wintmpdir ) ) {
win_skip ( " GetTempPathA failed \n " ) ;
return ;
}
2005-03-28 12:00:59 +02:00
2008-11-05 08:01:46 +01:00
/* Create a temporary directory and in it a temporary file */
strcat ( strcpy ( path , wintmpdir ) , " rary " ) ;
2008-11-09 22:05:08 +01:00
SetLastError ( 0xdeadbeef ) ;
2008-11-05 08:01:46 +01:00
rc = CreateDirectoryA ( path , NULL ) ;
ok ( rc | | GetLastError ( ) = = ERROR_ALREADY_EXISTS , " CreateDirectoryA "
" failed for '%s' with %d \n " , path , GetLastError ( ) ) ;
strcat ( strcpy ( file , path ) , " \\ ess " ) ;
2008-11-09 22:05:08 +01:00
SetLastError ( 0xdeadbeef ) ;
2008-11-05 08:01:46 +01:00
fh = CreateFileA ( file , GENERIC_WRITE , 0 , NULL , CREATE_ALWAYS , 0 , NULL ) ;
ok ( fh ! = INVALID_HANDLE_VALUE , " CreateFileA "
" failed for '%s' with %d \n " , file , GetLastError ( ) ) ;
CloseHandle ( fh ) ;
/* For the temporary file ... */
/* Get size needed */
retSize = 0 ;
2008-11-09 22:05:08 +01:00
SetLastError ( 0xdeadbeef ) ;
2008-11-05 08:01:46 +01:00
rc = pGetFileSecurityA ( file , request , NULL , 0 , & retSize ) ;
2008-11-09 20:50:51 +01:00
if ( ! rc & & ( GetLastError ( ) = = ERROR_CALL_NOT_IMPLEMENTED ) ) {
win_skip ( " GetFileSecurityA is not implemented \n " ) ;
goto cleanup ;
}
2008-11-05 08:01:46 +01:00
ok ( ! rc , " GetFileSecurityA "
" was expected to fail for '%s' \n " , file ) ;
ok ( GetLastError ( ) = = ERROR_INSUFFICIENT_BUFFER , " GetFileSecurityA "
" returned %d; expected ERROR_INSUFFICIENT_BUFFER \n " , GetLastError ( ) ) ;
2008-11-07 13:34:11 +01:00
ok ( retSize > sizeof ( SECURITY_DESCRIPTOR ) , " GetFileSecurityA returned size %d \n " , retSize ) ;
2008-11-05 08:01:46 +01:00
sdSize = retSize ;
sd = HeapAlloc ( GetProcessHeap ( ) , 0 , sdSize ) ;
/* Get security descriptor for real */
2008-12-06 12:43:55 +01:00
retSize = - 1 ;
2008-11-09 22:05:08 +01:00
SetLastError ( 0xdeadbeef ) ;
2008-11-05 08:01:46 +01:00
rc = pGetFileSecurityA ( file , request , sd , sdSize , & retSize ) ;
ok ( rc , " GetFileSecurityA "
2008-11-09 22:05:08 +01:00
" was not expected to fail '%s': %d \n " , file , GetLastError ( ) ) ;
2008-12-06 12:43:55 +01:00
ok ( retSize = = sdSize | |
broken ( retSize = = 0 ) , /* NT4 */
" GetFileSecurityA returned size %d; expected %d \n " , retSize , sdSize ) ;
2008-11-05 08:01:46 +01:00
/* Use it to set security descriptor */
2008-11-09 22:05:08 +01:00
SetLastError ( 0xdeadbeef ) ;
2008-11-05 08:01:46 +01:00
rc = pSetFileSecurityA ( file , request , sd ) ;
ok ( rc , " SetFileSecurityA "
2008-11-09 22:05:08 +01:00
" was not expected to fail '%s': %d \n " , file , GetLastError ( ) ) ;
2008-11-05 08:01:46 +01:00
HeapFree ( GetProcessHeap ( ) , 0 , sd ) ;
2008-11-03 23:37:17 +01:00
/* Repeat for the temporary directory ... */
/* Get size needed */
retSize = 0 ;
2008-11-09 22:05:08 +01:00
SetLastError ( 0xdeadbeef ) ;
2008-11-03 23:37:17 +01:00
rc = pGetFileSecurityA ( path , request , NULL , 0 , & retSize ) ;
ok ( ! rc , " GetFileSecurityA "
" was expected to fail for '%s' \n " , path ) ;
ok ( GetLastError ( ) = = ERROR_INSUFFICIENT_BUFFER , " GetFileSecurityA "
" returned %d; expected ERROR_INSUFFICIENT_BUFFER \n " , GetLastError ( ) ) ;
2008-11-07 13:34:11 +01:00
ok ( retSize > sizeof ( SECURITY_DESCRIPTOR ) , " GetFileSecurityA returned size %d \n " , retSize ) ;
2008-11-03 23:37:17 +01:00
sdSize = retSize ;
sd = HeapAlloc ( GetProcessHeap ( ) , 0 , sdSize ) ;
/* Get security descriptor for real */
2008-12-06 12:43:55 +01:00
retSize = - 1 ;
2008-11-09 22:05:08 +01:00
SetLastError ( 0xdeadbeef ) ;
2008-11-03 23:37:17 +01:00
rc = pGetFileSecurityA ( path , request , sd , sdSize , & retSize ) ;
ok ( rc , " GetFileSecurityA "
2008-11-09 22:05:08 +01:00
" was not expected to fail '%s': %d \n " , path , GetLastError ( ) ) ;
2008-12-06 12:43:55 +01:00
ok ( retSize = = sdSize | |
broken ( retSize = = 0 ) , /* NT4 */
" GetFileSecurityA returned size %d; expected %d \n " , retSize , sdSize ) ;
2008-11-03 23:37:17 +01:00
/* Use it to set security descriptor */
2008-11-09 22:05:08 +01:00
SetLastError ( 0xdeadbeef ) ;
2008-11-03 23:37:17 +01:00
rc = pSetFileSecurityA ( path , request , sd ) ;
ok ( rc , " SetFileSecurityA "
2008-11-09 22:05:08 +01:00
" was not expected to fail '%s': %d \n " , path , GetLastError ( ) ) ;
2008-11-03 23:37:17 +01:00
HeapFree ( GetProcessHeap ( ) , 0 , sd ) ;
2008-11-05 08:01:46 +01:00
/* Old test */
strcpy ( wintmpdir , " \\ Should not exist " ) ;
2008-11-09 22:05:08 +01:00
SetLastError ( 0xdeadbeef ) ;
2008-11-05 08:01:46 +01:00
rc = pGetFileSecurityA ( wintmpdir , OWNER_SECURITY_INFORMATION , NULL , 0 , & sdSize ) ;
ok ( ! rc , " GetFileSecurityA should fail for not existing directories/files \n " ) ;
2008-11-09 20:50:51 +01:00
ok ( GetLastError ( ) = = ERROR_FILE_NOT_FOUND ,
" last error ERROR_FILE_NOT_FOUND expected, got %d \n " , GetLastError ( ) ) ;
cleanup :
/* Remove temporary file and directory */
DeleteFileA ( file ) ;
RemoveDirectoryA ( path ) ;
2011-03-16 11:45:43 +01:00
2011-03-17 10:22:31 +01:00
/* Test file access permissions for a file with FILE_ATTRIBUTE_ARCHIVE */
2011-03-16 11:45:43 +01:00
SetLastError ( 0xdeadbeef ) ;
2013-10-15 10:15:45 +02:00
rc = GetTempPathA ( sizeof ( wintmpdir ) , wintmpdir ) ;
2011-03-16 11:45:43 +01:00
ok ( rc , " GetTempPath error %d \n " , GetLastError ( ) ) ;
SetLastError ( 0xdeadbeef ) ;
2013-10-15 10:15:45 +02:00
rc = GetTempFileNameA ( wintmpdir , " tmp " , 0 , file ) ;
2011-03-16 11:45:43 +01:00
ok ( rc , " GetTempFileName error %d \n " , GetLastError ( ) ) ;
2013-10-15 10:15:45 +02:00
rc = GetFileAttributesA ( file ) ;
2011-03-16 11:45:43 +01:00
rc & = ~ FILE_ATTRIBUTE_NOT_CONTENT_INDEXED ;
ok ( rc = = FILE_ATTRIBUTE_ARCHIVE , " expected FILE_ATTRIBUTE_ARCHIVE got %#x \n " , rc ) ;
retSize = 0xdeadbeef ;
2013-10-15 10:15:45 +02:00
rc = GetFileSecurityA ( file , OWNER_SECURITY_INFORMATION | GROUP_SECURITY_INFORMATION | DACL_SECURITY_INFORMATION ,
NULL , 0 , & sdSize ) ;
2011-03-16 11:45:43 +01:00
ok ( ! rc , " GetFileSecurity should fail \n " ) ;
ok ( GetLastError ( ) = = ERROR_INSUFFICIENT_BUFFER ,
" expected ERROR_INSUFFICIENT_BUFFER got %d \n " , GetLastError ( ) ) ;
ok ( sdSize > sizeof ( SECURITY_DESCRIPTOR ) , " got sd size %d \n " , sdSize ) ;
sd = HeapAlloc ( GetProcessHeap ( ) , 0 , sdSize ) ;
retSize = 0xdeadbeef ;
SetLastError ( 0xdeadbeef ) ;
2013-10-15 10:15:45 +02:00
rc = GetFileSecurityA ( file , OWNER_SECURITY_INFORMATION | GROUP_SECURITY_INFORMATION | DACL_SECURITY_INFORMATION ,
sd , sdSize , & retSize ) ;
2011-03-16 11:45:43 +01:00
ok ( rc , " GetFileSecurity error %d \n " , GetLastError ( ) ) ;
2011-03-17 10:22:31 +01:00
ok ( retSize = = sdSize | | broken ( retSize = = 0 ) /* NT4 */ , " expected %d, got %d \n " , sdSize , retSize ) ;
2011-03-16 11:45:43 +01:00
SetLastError ( 0xdeadbeef ) ;
rc = OpenThreadToken ( GetCurrentThread ( ) , TOKEN_QUERY , TRUE , & token ) ;
ok ( ! rc , " OpenThreadToken should fail \n " ) ;
ok ( GetLastError ( ) = = ERROR_NO_TOKEN , " expected ERROR_NO_TOKEN, got %d \n " , GetLastError ( ) ) ;
SetLastError ( 0xdeadbeef ) ;
rc = ImpersonateSelf ( SecurityIdentification ) ;
ok ( rc , " ImpersonateSelf error %d \n " , GetLastError ( ) ) ;
SetLastError ( 0xdeadbeef ) ;
rc = OpenThreadToken ( GetCurrentThread ( ) , TOKEN_QUERY , TRUE , & token ) ;
ok ( rc , " OpenThreadToken error %d \n " , GetLastError ( ) ) ;
SetLastError ( 0xdeadbeef ) ;
rc = RevertToSelf ( ) ;
ok ( rc , " RevertToSelf error %d \n " , GetLastError ( ) ) ;
priv_set_len = sizeof ( priv_set ) ;
granted = 0xdeadbeef ;
status = 0xdeadbeef ;
SetLastError ( 0xdeadbeef ) ;
rc = AccessCheck ( sd , token , FILE_READ_DATA , & mapping , & priv_set , & priv_set_len , & granted , & status ) ;
ok ( rc , " AccessCheck error %d \n " , GetLastError ( ) ) ;
ok ( status = = 1 , " expected 1, got %d \n " , status ) ;
ok ( granted = = FILE_READ_DATA , " expected FILE_READ_DATA, got %#x \n " , granted ) ;
granted = 0xdeadbeef ;
status = 0xdeadbeef ;
SetLastError ( 0xdeadbeef ) ;
rc = AccessCheck ( sd , token , FILE_WRITE_DATA , & mapping , & priv_set , & priv_set_len , & granted , & status ) ;
ok ( rc , " AccessCheck error %d \n " , GetLastError ( ) ) ;
ok ( status = = 1 , " expected 1, got %d \n " , status ) ;
ok ( granted = = FILE_WRITE_DATA , " expected FILE_WRITE_DATA, got %#x \n " , granted ) ;
granted = 0xdeadbeef ;
status = 0xdeadbeef ;
SetLastError ( 0xdeadbeef ) ;
rc = AccessCheck ( sd , token , FILE_EXECUTE , & mapping , & priv_set , & priv_set_len , & granted , & status ) ;
ok ( rc , " AccessCheck error %d \n " , GetLastError ( ) ) ;
ok ( status = = 1 , " expected 1, got %d \n " , status ) ;
ok ( granted = = FILE_EXECUTE , " expected FILE_EXECUTE, got %#x \n " , granted ) ;
2011-03-24 09:57:21 +01:00
2011-03-17 10:22:31 +01:00
granted = 0xdeadbeef ;
status = 0xdeadbeef ;
SetLastError ( 0xdeadbeef ) ;
rc = AccessCheck ( sd , token , DELETE , & mapping , & priv_set , & priv_set_len , & granted , & status ) ;
ok ( rc , " AccessCheck error %d \n " , GetLastError ( ) ) ;
ok ( status = = 1 , " expected 1, got %d \n " , status ) ;
ok ( granted = = DELETE , " expected DELETE, got %#x \n " , granted ) ;
2011-03-16 11:45:43 +01:00
granted = 0xdeadbeef ;
status = 0xdeadbeef ;
SetLastError ( 0xdeadbeef ) ;
rc = AccessCheck ( sd , token , FILE_DELETE_CHILD , & mapping , & priv_set , & priv_set_len , & granted , & status ) ;
ok ( rc , " AccessCheck error %d \n " , GetLastError ( ) ) ;
ok ( status = = 1 , " expected 1, got %d \n " , status ) ;
ok ( granted = = FILE_DELETE_CHILD , " expected FILE_DELETE_CHILD, got %#x \n " , granted ) ;
2011-03-16 11:46:00 +01:00
2011-03-16 11:45:43 +01:00
granted = 0xdeadbeef ;
status = 0xdeadbeef ;
SetLastError ( 0xdeadbeef ) ;
rc = AccessCheck ( sd , token , 0x1ff , & mapping , & priv_set , & priv_set_len , & granted , & status ) ;
ok ( rc , " AccessCheck error %d \n " , GetLastError ( ) ) ;
ok ( status = = 1 , " expected 1, got %d \n " , status ) ;
ok ( granted = = 0x1ff , " expected 0x1ff, got %#x \n " , granted ) ;
2011-03-24 09:57:21 +01:00
2011-03-16 11:45:43 +01:00
granted = 0xdeadbeef ;
status = 0xdeadbeef ;
SetLastError ( 0xdeadbeef ) ;
rc = AccessCheck ( sd , token , FILE_ALL_ACCESS , & mapping , & priv_set , & priv_set_len , & granted , & status ) ;
ok ( rc , " AccessCheck error %d \n " , GetLastError ( ) ) ;
ok ( status = = 1 , " expected 1, got %d \n " , status ) ;
ok ( granted = = FILE_ALL_ACCESS , " expected FILE_ALL_ACCESS, got %#x \n " , granted ) ;
2011-03-24 09:57:21 +01:00
2011-03-16 11:45:43 +01:00
SetLastError ( 0xdeadbeef ) ;
rc = AccessCheck ( sd , token , 0xffffffff , & mapping , & priv_set , & priv_set_len , & granted , & status ) ;
ok ( ! rc , " AccessCheck should fail \n " ) ;
ok ( GetLastError ( ) = = ERROR_GENERIC_NOT_MAPPED , " expected ERROR_GENERIC_NOT_MAPPED, got %d \n " , GetLastError ( ) ) ;
2011-03-17 10:22:31 +01:00
/* Test file access permissions for a file with FILE_ATTRIBUTE_READONLY */
SetLastError ( 0xdeadbeef ) ;
2013-10-15 10:15:45 +02:00
fh = CreateFileA ( file , FILE_READ_DATA , FILE_SHARE_READ , NULL , CREATE_ALWAYS , FILE_ATTRIBUTE_READONLY , 0 ) ;
2011-03-17 10:22:31 +01:00
ok ( fh ! = INVALID_HANDLE_VALUE , " CreateFile error %d \n " , GetLastError ( ) ) ;
retSize = 0xdeadbeef ;
SetLastError ( 0xdeadbeef ) ;
rc = WriteFile ( fh , " 1 " , 1 , & retSize , NULL ) ;
ok ( ! rc , " WriteFile should fail \n " ) ;
ok ( GetLastError ( ) = = ERROR_ACCESS_DENIED , " expected ERROR_ACCESS_DENIED, got %d \n " , GetLastError ( ) ) ;
ok ( retSize = = 0 , " expected 0, got %d \n " , retSize ) ;
CloseHandle ( fh ) ;
2013-10-15 10:15:45 +02:00
rc = GetFileAttributesA ( file ) ;
2011-03-17 10:22:31 +01:00
rc & = ~ FILE_ATTRIBUTE_NOT_CONTENT_INDEXED ;
todo_wine
ok ( rc = = ( FILE_ATTRIBUTE_ARCHIVE | FILE_ATTRIBUTE_READONLY ) ,
" expected FILE_ATTRIBUTE_ARCHIVE|FILE_ATTRIBUTE_READONLY got %#x \n " , rc ) ;
SetLastError ( 0xdeadbeef ) ;
2013-10-15 10:15:45 +02:00
rc = SetFileAttributesA ( file , FILE_ATTRIBUTE_ARCHIVE ) ;
2011-03-17 10:22:31 +01:00
ok ( rc , " SetFileAttributes error %d \n " , GetLastError ( ) ) ;
SetLastError ( 0xdeadbeef ) ;
2013-10-15 10:15:45 +02:00
rc = DeleteFileA ( file ) ;
2011-03-17 10:22:31 +01:00
ok ( rc , " DeleteFile error %d \n " , GetLastError ( ) ) ;
SetLastError ( 0xdeadbeef ) ;
2013-10-15 10:15:45 +02:00
fh = CreateFileA ( file , FILE_READ_DATA , FILE_SHARE_READ , NULL , CREATE_ALWAYS , FILE_ATTRIBUTE_READONLY , 0 ) ;
2011-03-17 10:22:31 +01:00
ok ( fh ! = INVALID_HANDLE_VALUE , " CreateFile error %d \n " , GetLastError ( ) ) ;
retSize = 0xdeadbeef ;
SetLastError ( 0xdeadbeef ) ;
rc = WriteFile ( fh , " 1 " , 1 , & retSize , NULL ) ;
ok ( ! rc , " WriteFile should fail \n " ) ;
ok ( GetLastError ( ) = = ERROR_ACCESS_DENIED , " expected ERROR_ACCESS_DENIED, got %d \n " , GetLastError ( ) ) ;
ok ( retSize = = 0 , " expected 0, got %d \n " , retSize ) ;
CloseHandle ( fh ) ;
2013-10-15 10:15:45 +02:00
rc = GetFileAttributesA ( file ) ;
2011-03-17 10:22:31 +01:00
rc & = ~ FILE_ATTRIBUTE_NOT_CONTENT_INDEXED ;
ok ( rc = = ( FILE_ATTRIBUTE_ARCHIVE | FILE_ATTRIBUTE_READONLY ) ,
" expected FILE_ATTRIBUTE_ARCHIVE|FILE_ATTRIBUTE_READONLY got %#x \n " , rc ) ;
retSize = 0xdeadbeef ;
SetLastError ( 0xdeadbeef ) ;
2013-10-15 10:15:45 +02:00
rc = GetFileSecurityA ( file , OWNER_SECURITY_INFORMATION | GROUP_SECURITY_INFORMATION | DACL_SECURITY_INFORMATION ,
sd , sdSize , & retSize ) ;
2011-03-17 10:22:31 +01:00
ok ( rc , " GetFileSecurity error %d \n " , GetLastError ( ) ) ;
ok ( retSize = = sdSize | | broken ( retSize = = 0 ) /* NT4 */ , " expected %d, got %d \n " , sdSize , retSize ) ;
priv_set_len = sizeof ( priv_set ) ;
granted = 0xdeadbeef ;
status = 0xdeadbeef ;
SetLastError ( 0xdeadbeef ) ;
rc = AccessCheck ( sd , token , FILE_READ_DATA , & mapping , & priv_set , & priv_set_len , & granted , & status ) ;
ok ( rc , " AccessCheck error %d \n " , GetLastError ( ) ) ;
ok ( status = = 1 , " expected 1, got %d \n " , status ) ;
ok ( granted = = FILE_READ_DATA , " expected FILE_READ_DATA, got %#x \n " , granted ) ;
granted = 0xdeadbeef ;
status = 0xdeadbeef ;
SetLastError ( 0xdeadbeef ) ;
rc = AccessCheck ( sd , token , FILE_WRITE_DATA , & mapping , & priv_set , & priv_set_len , & granted , & status ) ;
ok ( rc , " AccessCheck error %d \n " , GetLastError ( ) ) ;
todo_wine {
ok ( status = = 1 , " expected 1, got %d \n " , status ) ;
ok ( granted = = FILE_WRITE_DATA , " expected FILE_WRITE_DATA, got %#x \n " , granted ) ;
}
granted = 0xdeadbeef ;
status = 0xdeadbeef ;
SetLastError ( 0xdeadbeef ) ;
rc = AccessCheck ( sd , token , FILE_EXECUTE , & mapping , & priv_set , & priv_set_len , & granted , & status ) ;
ok ( rc , " AccessCheck error %d \n " , GetLastError ( ) ) ;
ok ( status = = 1 , " expected 1, got %d \n " , status ) ;
ok ( granted = = FILE_EXECUTE , " expected FILE_EXECUTE, got %#x \n " , granted ) ;
2011-03-24 09:57:21 +01:00
2011-03-17 10:22:31 +01:00
granted = 0xdeadbeef ;
status = 0xdeadbeef ;
SetLastError ( 0xdeadbeef ) ;
rc = AccessCheck ( sd , token , DELETE , & mapping , & priv_set , & priv_set_len , & granted , & status ) ;
ok ( rc , " AccessCheck error %d \n " , GetLastError ( ) ) ;
todo_wine {
ok ( status = = 1 , " expected 1, got %d \n " , status ) ;
ok ( granted = = DELETE , " expected DELETE, got %#x \n " , granted ) ;
}
granted = 0xdeadbeef ;
status = 0xdeadbeef ;
SetLastError ( 0xdeadbeef ) ;
rc = AccessCheck ( sd , token , FILE_DELETE_CHILD , & mapping , & priv_set , & priv_set_len , & granted , & status ) ;
ok ( rc , " AccessCheck error %d \n " , GetLastError ( ) ) ;
todo_wine {
ok ( status = = 1 , " expected 1, got %d \n " , status ) ;
ok ( granted = = FILE_DELETE_CHILD , " expected FILE_DELETE_CHILD, got %#x \n " , granted ) ;
}
granted = 0xdeadbeef ;
status = 0xdeadbeef ;
SetLastError ( 0xdeadbeef ) ;
rc = AccessCheck ( sd , token , 0x1ff , & mapping , & priv_set , & priv_set_len , & granted , & status ) ;
ok ( rc , " AccessCheck error %d \n " , GetLastError ( ) ) ;
todo_wine {
ok ( status = = 1 , " expected 1, got %d \n " , status ) ;
ok ( granted = = 0x1ff , " expected 0x1ff, got %#x \n " , granted ) ;
}
granted = 0xdeadbeef ;
status = 0xdeadbeef ;
SetLastError ( 0xdeadbeef ) ;
rc = AccessCheck ( sd , token , FILE_ALL_ACCESS , & mapping , & priv_set , & priv_set_len , & granted , & status ) ;
ok ( rc , " AccessCheck error %d \n " , GetLastError ( ) ) ;
todo_wine {
ok ( status = = 1 , " expected 1, got %d \n " , status ) ;
ok ( granted = = FILE_ALL_ACCESS , " expected FILE_ALL_ACCESS, got %#x \n " , granted ) ;
}
SetLastError ( 0xdeadbeef ) ;
2013-10-15 10:15:45 +02:00
rc = DeleteFileA ( file ) ;
2011-03-17 10:22:31 +01:00
ok ( ! rc , " DeleteFile should fail \n " ) ;
ok ( GetLastError ( ) = = ERROR_ACCESS_DENIED , " expected ERROR_ACCESS_DENIED, got %d \n " , GetLastError ( ) ) ;
SetLastError ( 0xdeadbeef ) ;
2013-10-15 10:15:45 +02:00
rc = SetFileAttributesA ( file , FILE_ATTRIBUTE_ARCHIVE ) ;
2011-03-17 10:22:31 +01:00
ok ( rc , " SetFileAttributes error %d \n " , GetLastError ( ) ) ;
SetLastError ( 0xdeadbeef ) ;
2013-10-15 10:15:45 +02:00
rc = DeleteFileA ( file ) ;
2011-03-17 10:22:31 +01:00
ok ( rc , " DeleteFile error %d \n " , GetLastError ( ) ) ;
2011-03-16 11:45:43 +01:00
CloseHandle ( token ) ;
2011-03-17 10:22:31 +01:00
HeapFree ( GetProcessHeap ( ) , 0 , sd ) ;
2005-03-28 12:00:59 +02:00
}
2005-06-09 12:03:11 +02:00
static void test_AccessCheck ( void )
{
PSID EveryoneSid = NULL , AdminSid = NULL , UsersSid = NULL ;
PACL Acl = NULL ;
SECURITY_DESCRIPTOR * SecurityDescriptor = NULL ;
SID_IDENTIFIER_AUTHORITY SIDAuthWorld = { SECURITY_WORLD_SID_AUTHORITY } ;
SID_IDENTIFIER_AUTHORITY SIDAuthNT = { SECURITY_NT_AUTHORITY } ;
GENERIC_MAPPING Mapping = { KEY_READ , KEY_WRITE , KEY_EXECUTE , KEY_ALL_ACCESS } ;
ACCESS_MASK Access ;
BOOL AccessStatus ;
HANDLE Token ;
2007-02-15 17:25:20 +01:00
HANDLE ProcessToken ;
2005-06-09 12:03:11 +02:00
BOOL ret ;
DWORD PrivSetLen ;
PRIVILEGE_SET * PrivSet ;
BOOL res ;
2005-06-27 21:48:35 +02:00
HMODULE NtDllModule ;
BOOLEAN Enabled ;
2007-01-25 07:41:39 +01:00
DWORD err ;
2009-01-13 20:54:32 +01:00
NTSTATUS ntret , ntAccessStatus ;
2005-06-27 21:48:35 +02:00
2013-10-15 10:15:45 +02:00
NtDllModule = GetModuleHandleA ( " ntdll.dll " ) ;
2005-06-27 21:48:35 +02:00
if ( ! NtDllModule )
{
2007-03-28 10:00:28 +02:00
skip ( " not running on NT, skipping test \n " ) ;
2005-06-27 21:48:35 +02:00
return ;
}
2010-10-01 13:33:37 +02:00
pRtlAdjustPrivilege = ( void * ) GetProcAddress ( NtDllModule , " RtlAdjustPrivilege " ) ;
2007-03-28 10:00:28 +02:00
if ( ! pRtlAdjustPrivilege )
{
2009-02-26 09:45:07 +01:00
win_skip ( " missing RtlAdjustPrivilege, skipping test \n " ) ;
2007-03-28 10:00:28 +02:00
return ;
}
2005-06-09 12:03:11 +02:00
2005-06-22 14:00:01 +02:00
Acl = HeapAlloc ( GetProcessHeap ( ) , 0 , 256 ) ;
res = InitializeAcl ( Acl , 256 , ACL_REVISION ) ;
if ( ! res & & GetLastError ( ) = = ERROR_CALL_NOT_IMPLEMENTED )
{
2007-01-25 07:43:18 +01:00
skip ( " ACLs not implemented - skipping tests \n " ) ;
2007-10-02 08:59:02 +02:00
HeapFree ( GetProcessHeap ( ) , 0 , Acl ) ;
2005-06-22 14:00:01 +02:00
return ;
}
2006-10-04 12:37:30 +02:00
ok ( res , " InitializeAcl failed with error %d \n " , GetLastError ( ) ) ;
2005-06-22 14:00:01 +02:00
2005-06-09 12:03:11 +02:00
res = AllocateAndInitializeSid ( & SIDAuthWorld , 1 , SECURITY_WORLD_RID , 0 , 0 , 0 , 0 , 0 , 0 , 0 , & EveryoneSid ) ;
2006-10-04 12:37:30 +02:00
ok ( res , " AllocateAndInitializeSid failed with error %d \n " , GetLastError ( ) ) ;
2005-06-09 12:03:11 +02:00
res = AllocateAndInitializeSid ( & SIDAuthNT , 2 , SECURITY_BUILTIN_DOMAIN_RID ,
DOMAIN_ALIAS_RID_ADMINS , 0 , 0 , 0 , 0 , 0 , 0 , & AdminSid ) ;
2006-10-04 12:37:30 +02:00
ok ( res , " AllocateAndInitializeSid failed with error %d \n " , GetLastError ( ) ) ;
2005-06-09 12:03:11 +02:00
res = AllocateAndInitializeSid ( & SIDAuthNT , 2 , SECURITY_BUILTIN_DOMAIN_RID ,
DOMAIN_ALIAS_RID_USERS , 0 , 0 , 0 , 0 , 0 , 0 , & UsersSid ) ;
2006-10-04 12:37:30 +02:00
ok ( res , " AllocateAndInitializeSid failed with error %d \n " , GetLastError ( ) ) ;
2005-06-09 12:03:11 +02:00
SecurityDescriptor = HeapAlloc ( GetProcessHeap ( ) , 0 , SECURITY_DESCRIPTOR_MIN_LENGTH ) ;
res = InitializeSecurityDescriptor ( SecurityDescriptor , SECURITY_DESCRIPTOR_REVISION ) ;
2006-10-04 12:37:30 +02:00
ok ( res , " InitializeSecurityDescriptor failed with error %d \n " , GetLastError ( ) ) ;
2005-06-09 12:03:11 +02:00
res = SetSecurityDescriptorDacl ( SecurityDescriptor , TRUE , Acl , FALSE ) ;
2006-10-04 12:37:30 +02:00
ok ( res , " SetSecurityDescriptorDacl failed with error %d \n " , GetLastError ( ) ) ;
2005-06-09 12:03:11 +02:00
PrivSetLen = FIELD_OFFSET ( PRIVILEGE_SET , Privilege [ 16 ] ) ;
PrivSet = HeapAlloc ( GetProcessHeap ( ) , HEAP_ZERO_MEMORY , PrivSetLen ) ;
PrivSet - > PrivilegeCount = 16 ;
2007-02-15 17:25:20 +01:00
res = OpenProcessToken ( GetCurrentProcess ( ) , TOKEN_DUPLICATE | TOKEN_QUERY , & ProcessToken ) ;
ok ( res , " OpenProcessToken failed with error %d \n " , GetLastError ( ) ) ;
2005-06-09 12:03:11 +02:00
2005-06-27 21:48:35 +02:00
pRtlAdjustPrivilege ( SE_SECURITY_PRIVILEGE , FALSE , TRUE , & Enabled ) ;
2008-02-18 20:39:19 +01:00
res = DuplicateToken ( ProcessToken , SecurityImpersonation , & Token ) ;
2007-02-15 17:25:20 +01:00
ok ( res , " DuplicateToken failed with error %d \n " , GetLastError ( ) ) ;
2005-06-09 12:03:11 +02:00
2007-01-25 07:41:39 +01:00
/* SD without owner/group */
SetLastError ( 0xdeadbeef ) ;
2010-06-18 22:01:57 +02:00
Access = AccessStatus = 0x1abe11ed ;
2007-01-25 07:41:39 +01:00
ret = AccessCheck ( SecurityDescriptor , Token , KEY_QUERY_VALUE , & Mapping ,
PrivSet , & PrivSetLen , & Access , & AccessStatus ) ;
err = GetLastError ( ) ;
ok ( ! ret & & err = = ERROR_INVALID_SECURITY_DESCR , " AccessCheck should have "
" failed with ERROR_INVALID_SECURITY_DESCR, instead of %d \n " , err ) ;
2010-06-18 22:01:57 +02:00
ok ( Access = = 0x1abe11ed & & AccessStatus = = 0x1abe11ed ,
2007-01-25 07:41:39 +01:00
" Access and/or AccessStatus were changed! \n " ) ;
/* Set owner and group */
res = SetSecurityDescriptorOwner ( SecurityDescriptor , AdminSid , FALSE ) ;
ok ( res , " SetSecurityDescriptorOwner failed with error %d \n " , GetLastError ( ) ) ;
res = SetSecurityDescriptorGroup ( SecurityDescriptor , UsersSid , TRUE ) ;
ok ( res , " SetSecurityDescriptorGroup failed with error %d \n " , GetLastError ( ) ) ;
/* Generic access mask */
SetLastError ( 0xdeadbeef ) ;
2010-06-18 22:01:57 +02:00
Access = AccessStatus = 0x1abe11ed ;
2007-01-25 07:41:39 +01:00
ret = AccessCheck ( SecurityDescriptor , Token , GENERIC_READ , & Mapping ,
PrivSet , & PrivSetLen , & Access , & AccessStatus ) ;
err = GetLastError ( ) ;
ok ( ! ret & & err = = ERROR_GENERIC_NOT_MAPPED , " AccessCheck should have failed "
" with ERROR_GENERIC_NOT_MAPPED, instead of %d \n " , err ) ;
2010-06-18 22:01:57 +02:00
ok ( Access = = 0x1abe11ed & & AccessStatus = = 0x1abe11ed ,
2007-01-25 07:41:39 +01:00
" Access and/or AccessStatus were changed! \n " ) ;
2009-01-13 20:54:32 +01:00
/* Generic access mask - no privilegeset buffer */
SetLastError ( 0xdeadbeef ) ;
2010-06-18 22:01:57 +02:00
Access = AccessStatus = 0x1abe11ed ;
2009-01-13 20:54:32 +01:00
ret = AccessCheck ( SecurityDescriptor , Token , GENERIC_READ , & Mapping ,
NULL , & PrivSetLen , & Access , & AccessStatus ) ;
err = GetLastError ( ) ;
ok ( ! ret & & err = = ERROR_NOACCESS , " AccessCheck should have failed "
" with ERROR_NOACCESS, instead of %d \n " , err ) ;
2010-06-18 22:01:57 +02:00
ok ( Access = = 0x1abe11ed & & AccessStatus = = 0x1abe11ed ,
2009-01-13 20:54:32 +01:00
" Access and/or AccessStatus were changed! \n " ) ;
/* Generic access mask - no returnlength */
SetLastError ( 0xdeadbeef ) ;
2010-06-18 22:01:57 +02:00
Access = AccessStatus = 0x1abe11ed ;
2009-01-13 20:54:32 +01:00
ret = AccessCheck ( SecurityDescriptor , Token , GENERIC_READ , & Mapping ,
PrivSet , NULL , & Access , & AccessStatus ) ;
err = GetLastError ( ) ;
ok ( ! ret & & err = = ERROR_NOACCESS , " AccessCheck should have failed "
" with ERROR_NOACCESS, instead of %d \n " , err ) ;
2010-06-18 22:01:57 +02:00
ok ( Access = = 0x1abe11ed & & AccessStatus = = 0x1abe11ed ,
2009-01-13 20:54:32 +01:00
" Access and/or AccessStatus were changed! \n " ) ;
/* Generic access mask - no privilegeset buffer, no returnlength */
SetLastError ( 0xdeadbeef ) ;
2010-06-18 22:01:57 +02:00
Access = AccessStatus = 0x1abe11ed ;
2009-01-13 20:54:32 +01:00
ret = AccessCheck ( SecurityDescriptor , Token , GENERIC_READ , & Mapping ,
NULL , NULL , & Access , & AccessStatus ) ;
err = GetLastError ( ) ;
ok ( ! ret & & err = = ERROR_NOACCESS , " AccessCheck should have failed "
" with ERROR_NOACCESS, instead of %d \n " , err ) ;
2010-06-18 22:01:57 +02:00
ok ( Access = = 0x1abe11ed & & AccessStatus = = 0x1abe11ed ,
2009-01-13 20:54:32 +01:00
" Access and/or AccessStatus were changed! \n " ) ;
2007-10-16 10:50:15 +02:00
/* sd with no dacl present */
2010-06-18 22:01:57 +02:00
Access = AccessStatus = 0x1abe11ed ;
2007-10-16 10:50:15 +02:00
ret = SetSecurityDescriptorDacl ( SecurityDescriptor , FALSE , NULL , FALSE ) ;
ok ( ret , " SetSecurityDescriptorDacl failed with error %d \n " , GetLastError ( ) ) ;
ret = AccessCheck ( SecurityDescriptor , Token , KEY_READ , & Mapping ,
PrivSet , & PrivSetLen , & Access , & AccessStatus ) ;
ok ( ret , " AccessCheck failed with error %d \n " , GetLastError ( ) ) ;
ok ( AccessStatus & & ( Access = = KEY_READ ) ,
" AccessCheck failed to grant access with error %d \n " ,
GetLastError ( ) ) ;
2009-01-13 20:54:32 +01:00
/* sd with no dacl present - no privilegeset buffer */
SetLastError ( 0xdeadbeef ) ;
2010-06-18 22:01:57 +02:00
Access = AccessStatus = 0x1abe11ed ;
2009-01-13 20:54:32 +01:00
ret = AccessCheck ( SecurityDescriptor , Token , GENERIC_READ , & Mapping ,
NULL , & PrivSetLen , & Access , & AccessStatus ) ;
err = GetLastError ( ) ;
ok ( ! ret & & err = = ERROR_NOACCESS , " AccessCheck should have failed "
" with ERROR_NOACCESS, instead of %d \n " , err ) ;
2010-06-18 22:01:57 +02:00
ok ( Access = = 0x1abe11ed & & AccessStatus = = 0x1abe11ed ,
2009-01-13 20:54:32 +01:00
" Access and/or AccessStatus were changed! \n " ) ;
if ( pNtAccessCheck )
{
/* Generic access mask - no privilegeset buffer */
SetLastError ( 0xdeadbeef ) ;
2010-06-18 22:01:57 +02:00
Access = ntAccessStatus = 0x1abe11ed ;
2009-01-13 20:54:32 +01:00
ntret = pNtAccessCheck ( SecurityDescriptor , Token , GENERIC_READ , & Mapping ,
NULL , & PrivSetLen , & Access , & ntAccessStatus ) ;
err = GetLastError ( ) ;
ok ( ntret = = STATUS_ACCESS_VIOLATION ,
" NtAccessCheck should have failed with STATUS_ACCESS_VIOLATION, got %x \n " , ntret ) ;
ok ( err = = 0xdeadbeef ,
" NtAccessCheck shouldn't set last error, got %d \n " , err ) ;
2010-06-18 22:01:57 +02:00
ok ( Access = = 0x1abe11ed & & ntAccessStatus = = 0x1abe11ed ,
2009-01-13 20:54:32 +01:00
" Access and/or AccessStatus were changed! \n " ) ;
/* Generic access mask - no returnlength */
SetLastError ( 0xdeadbeef ) ;
2010-06-18 22:01:57 +02:00
Access = ntAccessStatus = 0x1abe11ed ;
2009-01-13 20:54:32 +01:00
ntret = pNtAccessCheck ( SecurityDescriptor , Token , GENERIC_READ , & Mapping ,
PrivSet , NULL , & Access , & ntAccessStatus ) ;
err = GetLastError ( ) ;
ok ( ntret = = STATUS_ACCESS_VIOLATION ,
" NtAccessCheck should have failed with STATUS_ACCESS_VIOLATION, got %x \n " , ntret ) ;
ok ( err = = 0xdeadbeef ,
" NtAccessCheck shouldn't set last error, got %d \n " , err ) ;
2010-06-18 22:01:57 +02:00
ok ( Access = = 0x1abe11ed & & ntAccessStatus = = 0x1abe11ed ,
2009-01-13 20:54:32 +01:00
" Access and/or AccessStatus were changed! \n " ) ;
/* Generic access mask - no privilegeset buffer, no returnlength */
SetLastError ( 0xdeadbeef ) ;
2010-06-18 22:01:57 +02:00
Access = ntAccessStatus = 0x1abe11ed ;
2009-01-13 20:54:32 +01:00
ntret = pNtAccessCheck ( SecurityDescriptor , Token , GENERIC_READ , & Mapping ,
NULL , NULL , & Access , & ntAccessStatus ) ;
err = GetLastError ( ) ;
ok ( ntret = = STATUS_ACCESS_VIOLATION ,
" NtAccessCheck should have failed with STATUS_ACCESS_VIOLATION, got %x \n " , ntret ) ;
ok ( err = = 0xdeadbeef ,
" NtAccessCheck shouldn't set last error, got %d \n " , err ) ;
2010-06-18 22:01:57 +02:00
ok ( Access = = 0x1abe11ed & & ntAccessStatus = = 0x1abe11ed ,
2009-01-13 20:54:32 +01:00
" Access and/or AccessStatus were changed! \n " ) ;
}
else
win_skip ( " NtAccessCheck unavailable. Skipping. \n " ) ;
2007-10-16 10:50:15 +02:00
/* sd with NULL dacl */
2010-06-18 22:01:57 +02:00
Access = AccessStatus = 0x1abe11ed ;
2007-10-16 10:50:15 +02:00
ret = SetSecurityDescriptorDacl ( SecurityDescriptor , TRUE , NULL , FALSE ) ;
ok ( ret , " SetSecurityDescriptorDacl failed with error %d \n " , GetLastError ( ) ) ;
ret = AccessCheck ( SecurityDescriptor , Token , KEY_READ , & Mapping ,
PrivSet , & PrivSetLen , & Access , & AccessStatus ) ;
ok ( ret , " AccessCheck failed with error %d \n " , GetLastError ( ) ) ;
ok ( AccessStatus & & ( Access = = KEY_READ ) ,
" AccessCheck failed to grant access with error %d \n " ,
GetLastError ( ) ) ;
/* sd with blank dacl */
ret = SetSecurityDescriptorDacl ( SecurityDescriptor , TRUE , Acl , FALSE ) ;
ok ( ret , " SetSecurityDescriptorDacl failed with error %d \n " , GetLastError ( ) ) ;
ret = AccessCheck ( SecurityDescriptor , Token , KEY_READ , & Mapping ,
PrivSet , & PrivSetLen , & Access , & AccessStatus ) ;
ok ( ret , " AccessCheck failed with error %d \n " , GetLastError ( ) ) ;
err = GetLastError ( ) ;
ok ( ! AccessStatus & & err = = ERROR_ACCESS_DENIED , " AccessCheck should have failed "
" with ERROR_ACCESS_DENIED, instead of %d \n " , err ) ;
ok ( ! Access , " Should have failed to grant any access, got 0x%08x \n " , Access ) ;
res = AddAccessAllowedAce ( Acl , ACL_REVISION , KEY_READ , EveryoneSid ) ;
2007-11-02 11:33:36 +01:00
ok ( res , " AddAccessAllowedAce failed with error %d \n " , GetLastError ( ) ) ;
2007-10-16 10:50:15 +02:00
res = AddAccessDeniedAce ( Acl , ACL_REVISION , KEY_SET_VALUE , AdminSid ) ;
ok ( res , " AddAccessDeniedAce failed with error %d \n " , GetLastError ( ) ) ;
/* sd with dacl */
2010-06-18 22:01:57 +02:00
Access = AccessStatus = 0x1abe11ed ;
2005-06-09 12:03:11 +02:00
ret = AccessCheck ( SecurityDescriptor , Token , KEY_READ , & Mapping ,
PrivSet , & PrivSetLen , & Access , & AccessStatus ) ;
2006-10-04 12:37:30 +02:00
ok ( ret , " AccessCheck failed with error %d \n " , GetLastError ( ) ) ;
2005-06-29 22:14:16 +02:00
ok ( AccessStatus & & ( Access = = KEY_READ ) ,
2006-10-04 12:37:30 +02:00
" AccessCheck failed to grant access with error %d \n " ,
2005-06-09 12:03:11 +02:00
GetLastError ( ) ) ;
ret = AccessCheck ( SecurityDescriptor , Token , MAXIMUM_ALLOWED , & Mapping ,
PrivSet , & PrivSetLen , & Access , & AccessStatus ) ;
2006-10-04 12:37:30 +02:00
ok ( ret , " AccessCheck failed with error %d \n " , GetLastError ( ) ) ;
2005-06-29 22:14:16 +02:00
ok ( AccessStatus ,
2006-10-04 12:37:30 +02:00
" AccessCheck failed to grant any access with error %d \n " ,
2005-06-09 12:03:11 +02:00
GetLastError ( ) ) ;
2006-10-04 12:37:30 +02:00
trace ( " AccessCheck with MAXIMUM_ALLOWED got Access 0x%08x \n " , Access ) ;
2005-06-09 12:03:11 +02:00
2007-01-25 07:41:39 +01:00
/* Access denied by SD */
SetLastError ( 0xdeadbeef ) ;
2010-06-18 22:01:57 +02:00
Access = AccessStatus = 0x1abe11ed ;
2007-01-25 07:41:39 +01:00
ret = AccessCheck ( SecurityDescriptor , Token , KEY_WRITE , & Mapping ,
PrivSet , & PrivSetLen , & Access , & AccessStatus ) ;
ok ( ret , " AccessCheck failed with error %d \n " , GetLastError ( ) ) ;
err = GetLastError ( ) ;
ok ( ! AccessStatus & & err = = ERROR_ACCESS_DENIED , " AccessCheck should have failed "
" with ERROR_ACCESS_DENIED, instead of %d \n " , err ) ;
ok ( ! Access , " Should have failed to grant any access, got 0x%08x \n " , Access ) ;
2005-06-27 21:48:35 +02:00
SetLastError ( 0 ) ;
PrivSet - > PrivilegeCount = 16 ;
ret = AccessCheck ( SecurityDescriptor , Token , ACCESS_SYSTEM_SECURITY , & Mapping ,
PrivSet , & PrivSetLen , & Access , & AccessStatus ) ;
ok ( ret & & ! AccessStatus & & GetLastError ( ) = = ERROR_PRIVILEGE_NOT_HELD ,
2006-10-04 12:37:30 +02:00
" AccessCheck should have failed with ERROR_PRIVILEGE_NOT_HELD, instead of %d \n " ,
2005-06-27 21:48:35 +02:00
GetLastError ( ) ) ;
2007-10-25 17:19:37 +02:00
ret = ImpersonateLoggedOnUser ( Token ) ;
ok ( ret , " ImpersonateLoggedOnUser failed with error %d \n " , GetLastError ( ) ) ;
2005-06-27 21:48:35 +02:00
ret = pRtlAdjustPrivilege ( SE_SECURITY_PRIVILEGE , TRUE , TRUE , & Enabled ) ;
if ( ! ret )
{
SetLastError ( 0 ) ;
PrivSet - > PrivilegeCount = 16 ;
ret = AccessCheck ( SecurityDescriptor , Token , ACCESS_SYSTEM_SECURITY , & Mapping ,
PrivSet , & PrivSetLen , & Access , & AccessStatus ) ;
ok ( ret & & AccessStatus & & GetLastError ( ) = = 0 ,
2006-10-04 12:37:30 +02:00
" AccessCheck should have succeeded, error %d \n " ,
2005-06-27 21:48:35 +02:00
GetLastError ( ) ) ;
ok ( Access = = ACCESS_SYSTEM_SECURITY ,
2006-10-04 12:37:30 +02:00
" Access should be equal to ACCESS_SYSTEM_SECURITY instead of 0x%08x \n " ,
2005-06-27 21:48:35 +02:00
Access ) ;
}
else
2005-06-28 15:52:01 +02:00
trace ( " Couldn't get SE_SECURITY_PRIVILEGE (0x%08x), skipping ACCESS_SYSTEM_SECURITY test \n " ,
2005-06-27 21:48:35 +02:00
ret ) ;
2007-10-25 17:19:37 +02:00
ret = RevertToSelf ( ) ;
ok ( ret , " RevertToSelf failed with error %d \n " , GetLastError ( ) ) ;
2005-06-27 21:48:35 +02:00
2007-10-25 17:19:23 +02:00
/* test INHERIT_ONLY_ACE */
ret = InitializeAcl ( Acl , 256 , ACL_REVISION ) ;
ok ( ret , " InitializeAcl failed with error %d \n " , GetLastError ( ) ) ;
2008-03-03 10:46:06 +01:00
/* NT doesn't have AddAccessAllowedAceEx. Skipping this call/test doesn't influence
* the next ones .
*/
if ( pAddAccessAllowedAceEx )
{
ret = pAddAccessAllowedAceEx ( Acl , ACL_REVISION , INHERIT_ONLY_ACE , KEY_READ , EveryoneSid ) ;
ok ( ret , " AddAccessAllowedAceEx failed with error %d \n " , GetLastError ( ) ) ;
}
else
2009-02-26 09:45:07 +01:00
win_skip ( " AddAccessAllowedAceEx is not available \n " ) ;
2007-10-25 17:19:23 +02:00
ret = AccessCheck ( SecurityDescriptor , Token , KEY_READ , & Mapping ,
PrivSet , & PrivSetLen , & Access , & AccessStatus ) ;
ok ( ret , " AccessCheck failed with error %d \n " , GetLastError ( ) ) ;
err = GetLastError ( ) ;
ok ( ! AccessStatus & & err = = ERROR_ACCESS_DENIED , " AccessCheck should have failed "
" with ERROR_ACCESS_DENIED, instead of %d \n " , err ) ;
ok ( ! Access , " Should have failed to grant any access, got 0x%08x \n " , Access ) ;
2007-02-15 17:25:20 +01:00
CloseHandle ( Token ) ;
res = DuplicateToken ( ProcessToken , SecurityAnonymous , & Token ) ;
ok ( res , " DuplicateToken failed with error %d \n " , GetLastError ( ) ) ;
SetLastError ( 0xdeadbeef ) ;
ret = AccessCheck ( SecurityDescriptor , Token , MAXIMUM_ALLOWED , & Mapping ,
PrivSet , & PrivSetLen , & Access , & AccessStatus ) ;
err = GetLastError ( ) ;
ok ( ! ret & & err = = ERROR_BAD_IMPERSONATION_LEVEL , " AccessCheck should have failed "
" with ERROR_BAD_IMPERSONATION_LEVEL, instead of %d \n " , err ) ;
CloseHandle ( Token ) ;
SetLastError ( 0xdeadbeef ) ;
ret = AccessCheck ( SecurityDescriptor , ProcessToken , KEY_READ , & Mapping ,
PrivSet , & PrivSetLen , & Access , & AccessStatus ) ;
err = GetLastError ( ) ;
ok ( ! ret & & err = = ERROR_NO_IMPERSONATION_TOKEN , " AccessCheck should have failed "
" with ERROR_NO_IMPERSONATION_TOKEN, instead of %d \n " , err ) ;
CloseHandle ( ProcessToken ) ;
2005-06-09 12:03:11 +02:00
if ( EveryoneSid )
FreeSid ( EveryoneSid ) ;
if ( AdminSid )
FreeSid ( AdminSid ) ;
if ( UsersSid )
FreeSid ( UsersSid ) ;
HeapFree ( GetProcessHeap ( ) , 0 , Acl ) ;
HeapFree ( GetProcessHeap ( ) , 0 , SecurityDescriptor ) ;
HeapFree ( GetProcessHeap ( ) , 0 , PrivSet ) ;
}
2006-05-13 17:56:59 +02:00
/* test GetTokenInformation for the various attributes */
static void test_token_attr ( void )
{
2007-02-21 18:10:45 +01:00
HANDLE Token , ImpersonationToken ;
2009-04-21 09:53:49 +02:00
DWORD Size , Size2 ;
2006-05-13 17:56:59 +02:00
TOKEN_PRIVILEGES * Privileges ;
TOKEN_GROUPS * Groups ;
TOKEN_USER * User ;
2009-04-21 09:53:49 +02:00
TOKEN_DEFAULT_DACL * Dacl ;
2006-05-13 17:56:59 +02:00
BOOL ret ;
2006-05-21 23:06:47 +02:00
DWORD i , GLE ;
LPSTR SidString ;
2007-02-21 18:10:45 +01:00
SECURITY_IMPERSONATION_LEVEL ImpersonationLevel ;
2009-04-21 09:53:49 +02:00
ACL * acl ;
2006-05-13 17:56:59 +02:00
2006-11-06 12:35:37 +01:00
/* cygwin-like use case */
2007-03-29 20:47:14 +02:00
SetLastError ( 0xdeadbeef ) ;
2006-11-06 12:35:37 +01:00
ret = OpenProcessToken ( GetCurrentProcess ( ) , MAXIMUM_ALLOWED , & Token ) ;
2007-03-29 20:47:14 +02:00
if ( ! ret & & ( GetLastError ( ) = = ERROR_CALL_NOT_IMPLEMENTED ) )
{
2009-02-26 09:45:07 +01:00
win_skip ( " OpenProcessToken is not implemented \n " ) ;
2007-03-29 20:47:14 +02:00
return ;
}
2006-11-06 12:35:37 +01:00
ok ( ret , " OpenProcessToken failed with error %d \n " , GetLastError ( ) ) ;
if ( ret )
{
2009-03-04 11:47:20 +01:00
DWORD buf [ 256 ] ; /* GetTokenInformation wants a dword-aligned buffer */
2007-02-21 18:10:45 +01:00
Size = sizeof ( buf ) ;
ret = GetTokenInformation ( Token , TokenUser , ( void * ) buf , Size , & Size ) ;
2007-02-21 14:59:59 +01:00
ok ( ret , " GetTokenInformation failed with error %d \n " , GetLastError ( ) ) ;
2007-02-21 18:10:45 +01:00
Size = sizeof ( ImpersonationLevel ) ;
ret = GetTokenInformation ( Token , TokenImpersonationLevel , & ImpersonationLevel , Size , & Size ) ;
GLE = GetLastError ( ) ;
ok ( ! ret & & ( GLE = = ERROR_INVALID_PARAMETER ) , " GetTokenInformation(TokenImpersonationLevel) on primary token should have failed with ERROR_INVALID_PARAMETER instead of %d \n " , GLE ) ;
2006-11-06 12:35:37 +01:00
CloseHandle ( Token ) ;
}
2006-06-24 23:36:40 +02:00
if ( ! pConvertSidToStringSidA )
2007-03-29 20:47:02 +02:00
{
2009-02-26 09:45:07 +01:00
win_skip ( " ConvertSidToStringSidA is not available \n " ) ;
2006-06-24 23:36:40 +02:00
return ;
2007-03-29 20:47:02 +02:00
}
2006-06-24 23:36:40 +02:00
2007-03-29 20:47:14 +02:00
SetLastError ( 0xdeadbeef ) ;
2009-04-21 09:53:49 +02:00
ret = OpenProcessToken ( GetCurrentProcess ( ) , TOKEN_ALL_ACCESS , & Token ) ;
2007-03-29 20:47:14 +02:00
ok ( ret , " OpenProcessToken failed with error %d \n " , GetLastError ( ) ) ;
2006-05-13 17:56:59 +02:00
/* groups */
2011-08-23 09:16:27 +02:00
/* insufficient buffer length */
SetLastError ( 0xdeadbeef ) ;
Size2 = 0 ;
ret = GetTokenInformation ( Token , TokenGroups , NULL , 0 , & Size2 ) ;
ok ( Size2 > 1 , " got %d \n " , Size2 ) ;
ok ( ! ret & & GetLastError ( ) = = ERROR_INSUFFICIENT_BUFFER ,
" %d with error %d \n " , ret , GetLastError ( ) ) ;
Size2 - = 1 ;
Groups = HeapAlloc ( GetProcessHeap ( ) , 0 , Size2 ) ;
memset ( Groups , 0xcc , Size2 ) ;
Size = 0 ;
ret = GetTokenInformation ( Token , TokenGroups , Groups , Size2 , & Size ) ;
ok ( Size > 1 , " got %d \n " , Size ) ;
2012-02-12 01:22:03 +01:00
ok ( ( ! ret & & GetLastError ( ) = = ERROR_INSUFFICIENT_BUFFER ) | | broken ( ret ) /* wow64 */ ,
2011-08-23 09:16:27 +02:00
" %d with error %d \n " , ret , GetLastError ( ) ) ;
2012-02-12 01:22:03 +01:00
if ( ! ret )
ok ( * ( ( BYTE * ) Groups ) = = 0xcc , " buffer altered \n " ) ;
2011-08-23 09:16:27 +02:00
HeapFree ( GetProcessHeap ( ) , 0 , Groups ) ;
2009-11-15 17:37:05 +01:00
SetLastError ( 0xdeadbeef ) ;
2006-05-13 17:56:59 +02:00
ret = GetTokenInformation ( Token , TokenGroups , NULL , 0 , & Size ) ;
2009-11-15 17:37:05 +01:00
ok ( ! ret & & GetLastError ( ) = = ERROR_INSUFFICIENT_BUFFER ,
" GetTokenInformation(TokenGroups) %s with error %d \n " ,
ret ? " succeeded " : " failed " , GetLastError ( ) ) ;
2006-05-13 17:56:59 +02:00
Groups = HeapAlloc ( GetProcessHeap ( ) , 0 , Size ) ;
2009-11-15 17:37:05 +01:00
SetLastError ( 0xdeadbeef ) ;
2006-05-13 17:56:59 +02:00
ret = GetTokenInformation ( Token , TokenGroups , Groups , Size , & Size ) ;
2006-10-04 12:37:30 +02:00
ok ( ret , " GetTokenInformation(TokenGroups) failed with error %d \n " , GetLastError ( ) ) ;
2009-11-15 17:37:05 +01:00
ok ( GetLastError ( ) = = 0xdeadbeef ,
" GetTokenInformation shouldn't have set last error to %d \n " ,
GetLastError ( ) ) ;
2006-05-13 17:56:59 +02:00
trace ( " TokenGroups: \n " ) ;
for ( i = 0 ; i < Groups - > GroupCount ; i + + )
{
DWORD NameLength = 255 ;
2013-10-15 10:15:45 +02:00
CHAR Name [ 255 ] ;
2006-05-13 17:56:59 +02:00
DWORD DomainLength = 255 ;
2013-10-15 10:15:45 +02:00
CHAR Domain [ 255 ] ;
2006-05-13 17:56:59 +02:00
SID_NAME_USE SidNameUse ;
Name [ 0 ] = ' \0 ' ;
Domain [ 0 ] = ' \0 ' ;
2013-10-15 10:15:45 +02:00
ret = LookupAccountSidA ( NULL , Groups - > Groups [ i ] . Sid , Name , & NameLength , Domain , & DomainLength , & SidNameUse ) ;
2007-03-16 02:39:47 +01:00
if ( ret )
2009-06-16 13:27:32 +02:00
{
2009-12-02 15:32:07 +01:00
pConvertSidToStringSidA ( Groups - > Groups [ i ] . Sid , & SidString ) ;
2009-06-16 13:27:32 +02:00
trace ( " %s, %s \\ %s use: %d attr: 0x%08x \n " , SidString , Domain , Name , SidNameUse , Groups - > Groups [ i ] . Attributes ) ;
LocalFree ( SidString ) ;
}
else trace ( " attr: 0x%08x LookupAccountSid failed with error %d \n " , Groups - > Groups [ i ] . Attributes , GetLastError ( ) ) ;
2006-05-13 17:56:59 +02:00
}
2006-08-04 14:17:58 +02:00
HeapFree ( GetProcessHeap ( ) , 0 , Groups ) ;
2006-05-13 17:56:59 +02:00
/* user */
ret = GetTokenInformation ( Token , TokenUser , NULL , 0 , & Size ) ;
ok ( ! ret & & ( GetLastError ( ) = = ERROR_INSUFFICIENT_BUFFER ) ,
2006-10-04 12:37:30 +02:00
" GetTokenInformation(TokenUser) failed with error %d \n " , GetLastError ( ) ) ;
2006-05-13 17:56:59 +02:00
User = HeapAlloc ( GetProcessHeap ( ) , 0 , Size ) ;
ret = GetTokenInformation ( Token , TokenUser , User , Size , & Size ) ;
ok ( ret ,
2006-10-04 12:37:30 +02:00
" GetTokenInformation(TokenUser) failed with error %d \n " , GetLastError ( ) ) ;
2006-05-13 17:56:59 +02:00
2006-05-21 22:25:44 +02:00
pConvertSidToStringSidA ( User - > User . Sid , & SidString ) ;
2006-10-04 12:37:30 +02:00
trace ( " TokenUser: %s attr: 0x%08x \n " , SidString , User - > User . Attributes ) ;
2006-05-13 17:56:59 +02:00
LocalFree ( SidString ) ;
2006-10-17 21:32:00 +02:00
HeapFree ( GetProcessHeap ( ) , 0 , User ) ;
2006-05-13 17:56:59 +02:00
/* privileges */
ret = GetTokenInformation ( Token , TokenPrivileges , NULL , 0 , & Size ) ;
ok ( ! ret & & ( GetLastError ( ) = = ERROR_INSUFFICIENT_BUFFER ) ,
2006-10-04 12:37:30 +02:00
" GetTokenInformation(TokenPrivileges) failed with error %d \n " , GetLastError ( ) ) ;
2006-05-13 17:56:59 +02:00
Privileges = HeapAlloc ( GetProcessHeap ( ) , 0 , Size ) ;
ret = GetTokenInformation ( Token , TokenPrivileges , Privileges , Size , & Size ) ;
ok ( ret ,
2006-10-04 12:37:30 +02:00
" GetTokenInformation(TokenPrivileges) failed with error %d \n " , GetLastError ( ) ) ;
2006-05-13 17:56:59 +02:00
trace ( " TokenPrivileges: \n " ) ;
for ( i = 0 ; i < Privileges - > PrivilegeCount ; i + + )
{
2013-10-15 10:15:45 +02:00
CHAR Name [ 256 ] ;
2006-05-13 17:56:59 +02:00
DWORD NameLen = sizeof ( Name ) / sizeof ( Name [ 0 ] ) ;
2013-10-15 10:15:45 +02:00
LookupPrivilegeNameA ( NULL , & Privileges - > Privileges [ i ] . Luid , Name , & NameLen ) ;
2006-10-04 12:37:30 +02:00
trace ( " \t %s, 0x%x \n " , Name , Privileges - > Privileges [ i ] . Attributes ) ;
2006-05-13 17:56:59 +02:00
}
2006-12-04 21:25:13 +01:00
HeapFree ( GetProcessHeap ( ) , 0 , Privileges ) ;
2007-02-21 18:10:45 +01:00
ret = DuplicateToken ( Token , SecurityAnonymous , & ImpersonationToken ) ;
ok ( ret , " DuplicateToken failed with error %d \n " , GetLastError ( ) ) ;
Size = sizeof ( ImpersonationLevel ) ;
ret = GetTokenInformation ( ImpersonationToken , TokenImpersonationLevel , & ImpersonationLevel , Size , & Size ) ;
ok ( ret , " GetTokenInformation(TokenImpersonationLevel) failed with error %d \n " , GetLastError ( ) ) ;
ok ( ImpersonationLevel = = SecurityAnonymous , " ImpersonationLevel should have been SecurityAnonymous instead of %d \n " , ImpersonationLevel ) ;
CloseHandle ( ImpersonationToken ) ;
2009-04-21 09:53:49 +02:00
/* default dacl */
ret = GetTokenInformation ( Token , TokenDefaultDacl , NULL , 0 , & Size ) ;
ok ( ! ret & & ( GetLastError ( ) = = ERROR_INSUFFICIENT_BUFFER ) ,
" GetTokenInformation(TokenDefaultDacl) failed with error %u \n " , GetLastError ( ) ) ;
Dacl = HeapAlloc ( GetProcessHeap ( ) , 0 , Size ) ;
ret = GetTokenInformation ( Token , TokenDefaultDacl , Dacl , Size , & Size ) ;
ok ( ret , " GetTokenInformation(TokenDefaultDacl) failed with error %u \n " , GetLastError ( ) ) ;
SetLastError ( 0xdeadbeef ) ;
ret = SetTokenInformation ( Token , TokenDefaultDacl , NULL , 0 ) ;
GLE = GetLastError ( ) ;
ok ( ! ret , " SetTokenInformation(TokenDefaultDacl) succeeded \n " ) ;
ok ( GLE = = ERROR_BAD_LENGTH , " expected ERROR_BAD_LENGTH got %u \n " , GLE ) ;
SetLastError ( 0xdeadbeef ) ;
ret = SetTokenInformation ( Token , TokenDefaultDacl , NULL , Size ) ;
GLE = GetLastError ( ) ;
ok ( ! ret , " SetTokenInformation(TokenDefaultDacl) succeeded \n " ) ;
ok ( GLE = = ERROR_NOACCESS , " expected ERROR_NOACCESS got %u \n " , GLE ) ;
acl = Dacl - > DefaultDacl ;
Dacl - > DefaultDacl = NULL ;
ret = SetTokenInformation ( Token , TokenDefaultDacl , Dacl , Size ) ;
ok ( ret , " SetTokenInformation(TokenDefaultDacl) succeeded \n " ) ;
Size2 = 0 ;
Dacl - > DefaultDacl = ( ACL * ) 0xdeadbeef ;
ret = GetTokenInformation ( Token , TokenDefaultDacl , Dacl , Size , & Size2 ) ;
ok ( ret , " GetTokenInformation(TokenDefaultDacl) failed with error %u \n " , GetLastError ( ) ) ;
ok ( Dacl - > DefaultDacl = = NULL , " expected NULL, got %p \n " , Dacl - > DefaultDacl ) ;
2010-10-22 07:49:38 +02:00
ok ( Size2 = = sizeof ( TOKEN_DEFAULT_DACL ) | | broken ( Size2 = = 2 * sizeof ( TOKEN_DEFAULT_DACL ) ) , /* WoW64 */
2010-11-17 15:07:47 +01:00
" got %u expected sizeof(TOKEN_DEFAULT_DACL) \n " , Size2 ) ;
2009-04-21 09:53:49 +02:00
Dacl - > DefaultDacl = acl ;
ret = SetTokenInformation ( Token , TokenDefaultDacl , Dacl , Size ) ;
ok ( ret , " SetTokenInformation(TokenDefaultDacl) failed with error %u \n " , GetLastError ( ) ) ;
2010-10-22 07:49:38 +02:00
if ( Size2 = = sizeof ( TOKEN_DEFAULT_DACL ) ) {
ret = GetTokenInformation ( Token , TokenDefaultDacl , Dacl , Size , & Size2 ) ;
ok ( ret , " GetTokenInformation(TokenDefaultDacl) failed with error %u \n " , GetLastError ( ) ) ;
} else
win_skip ( " TOKEN_DEFAULT_DACL size too small on WoW64 \n " ) ;
2009-04-21 09:53:49 +02:00
HeapFree ( GetProcessHeap ( ) , 0 , Dacl ) ;
2007-02-21 18:10:45 +01:00
CloseHandle ( Token ) ;
2006-05-13 17:56:59 +02:00
}
2006-08-12 14:27:57 +02:00
typedef union _MAX_SID
{
SID sid ;
char max [ SECURITY_MAX_SID_SIZE ] ;
} MAX_SID ;
static void test_sid_str ( PSID * sid )
{
char * str_sid ;
BOOL ret = pConvertSidToStringSidA ( sid , & str_sid ) ;
2006-10-04 12:37:30 +02:00
ok ( ret , " ConvertSidToStringSidA() failed: %d \n " , GetLastError ( ) ) ;
2006-08-12 14:27:57 +02:00
if ( ret )
{
char account [ MAX_PATH ] , domain [ MAX_PATH ] ;
SID_NAME_USE use ;
DWORD acc_size = MAX_PATH ;
DWORD dom_size = MAX_PATH ;
2013-10-15 10:15:45 +02:00
ret = LookupAccountSidA ( NULL , sid , account , & acc_size , domain , & dom_size , & use ) ;
2006-08-12 14:27:57 +02:00
ok ( ret | | ( ! ret & & ( GetLastError ( ) = = ERROR_NONE_MAPPED ) ) ,
2006-10-04 12:37:30 +02:00
" LookupAccountSid(%s) failed: %d \n " , str_sid , GetLastError ( ) ) ;
2006-08-12 14:27:57 +02:00
if ( ret )
trace ( " %s %s \\ %s %d \n " , str_sid , domain , account , use ) ;
else if ( GetLastError ( ) = = ERROR_NONE_MAPPED )
2006-08-27 22:36:23 +02:00
trace ( " %s couldn't be mapped \n " , str_sid ) ;
2006-08-12 14:27:57 +02:00
LocalFree ( str_sid ) ;
}
}
2010-10-01 13:33:37 +02:00
static const struct well_known_sid_value
2007-10-21 09:41:54 +02:00
{
BOOL without_domain ;
const char * sid_string ;
} well_known_sid_values [ ] = {
/* 0 */ { TRUE , " S-1-0-0 " } , { TRUE , " S-1-1-0 " } , { TRUE , " S-1-2-0 " } , { TRUE , " S-1-3-0 " } ,
/* 4 */ { TRUE , " S-1-3-1 " } , { TRUE , " S-1-3-2 " } , { TRUE , " S-1-3-3 " } , { TRUE , " S-1-5 " } ,
/* 8 */ { FALSE , " S-1-5-1 " } , { TRUE , " S-1-5-2 " } , { TRUE , " S-1-5-3 " } , { TRUE , " S-1-5-4 " } ,
/* 12 */ { TRUE , " S-1-5-6 " } , { TRUE , " S-1-5-7 " } , { TRUE , " S-1-5-8 " } , { TRUE , " S-1-5-9 " } ,
/* 16 */ { TRUE , " S-1-5-10 " } , { TRUE , " S-1-5-11 " } , { TRUE , " S-1-5-12 " } , { TRUE , " S-1-5-13 " } ,
/* 20 */ { TRUE , " S-1-5-14 " } , { FALSE , NULL } , { TRUE , " S-1-5-18 " } , { TRUE , " S-1-5-19 " } ,
/* 24 */ { TRUE , " S-1-5-20 " } , { TRUE , " S-1-5-32 " } ,
/* 26 */ { FALSE , " S-1-5-32-544 " } , { TRUE , " S-1-5-32-545 " } , { TRUE , " S-1-5-32-546 " } ,
/* 29 */ { TRUE , " S-1-5-32-547 " } , { TRUE , " S-1-5-32-548 " } , { TRUE , " S-1-5-32-549 " } ,
/* 32 */ { TRUE , " S-1-5-32-550 " } , { TRUE , " S-1-5-32-551 " } , { TRUE , " S-1-5-32-552 " } ,
/* 35 */ { TRUE , " S-1-5-32-554 " } , { TRUE , " S-1-5-32-555 " } , { TRUE , " S-1-5-32-556 " } ,
/* 38 */ { FALSE , " S-1-5-21-12-23-34-45-56-500 " } , { FALSE , " S-1-5-21-12-23-34-45-56-501 " } ,
/* 40 */ { FALSE , " S-1-5-21-12-23-34-45-56-502 " } , { FALSE , " S-1-5-21-12-23-34-45-56-512 " } ,
/* 42 */ { FALSE , " S-1-5-21-12-23-34-45-56-513 " } , { FALSE , " S-1-5-21-12-23-34-45-56-514 " } ,
/* 44 */ { FALSE , " S-1-5-21-12-23-34-45-56-515 " } , { FALSE , " S-1-5-21-12-23-34-45-56-516 " } ,
/* 46 */ { FALSE , " S-1-5-21-12-23-34-45-56-517 " } , { FALSE , " S-1-5-21-12-23-34-45-56-518 " } ,
/* 48 */ { FALSE , " S-1-5-21-12-23-34-45-56-519 " } , { FALSE , " S-1-5-21-12-23-34-45-56-520 " } ,
/* 50 */ { FALSE , " S-1-5-21-12-23-34-45-56-553 " } ,
2007-10-25 20:41:43 +02:00
/* Added in Windows Server 2003 */
2007-10-21 09:41:54 +02:00
/* 51 */ { TRUE , " S-1-5-64-10 " } , { TRUE , " S-1-5-64-21 " } , { TRUE , " S-1-5-64-14 " } ,
/* 54 */ { TRUE , " S-1-5-15 " } , { TRUE , " S-1-5-1000 " } , { FALSE , " S-1-5-32-557 " } ,
/* 57 */ { TRUE , " S-1-5-32-558 " } , { TRUE , " S-1-5-32-559 " } , { TRUE , " S-1-5-32-560 " } ,
2007-10-25 20:41:43 +02:00
/* 60 */ { TRUE , " S-1-5-32-561 " } , { TRUE , " S-1-5-32-562 " } ,
2007-10-21 09:41:54 +02:00
/* Added in Windows Vista: */
2007-10-25 20:41:43 +02:00
/* 62 */ { TRUE , " S-1-5-32-568 " } ,
2007-10-21 09:41:54 +02:00
/* 63 */ { TRUE , " S-1-5-17 " } , { FALSE , " S-1-5-32-569 " } , { TRUE , " S-1-16-0 " } ,
/* 66 */ { TRUE , " S-1-16-4096 " } , { TRUE , " S-1-16-8192 " } , { TRUE , " S-1-16-12288 " } ,
/* 69 */ { TRUE , " S-1-16-16384 " } , { TRUE , " S-1-5-33 " } , { TRUE , " S-1-3-4 " } ,
/* 72 */ { FALSE , " S-1-5-21-12-23-34-45-56-571 " } , { FALSE , " S-1-5-21-12-23-34-45-56-572 " } ,
2012-07-22 18:13:14 +02:00
/* 74 */ { TRUE , " S-1-5-22 " } , { FALSE , " S-1-5-21-12-23-34-45-56-521 " } , { TRUE , " S-1-5-32-573 " } ,
/* 77 */ { FALSE , " S-1-5-21-12-23-34-45-56-498 " } , { TRUE , " S-1-5-32-574 " } , { TRUE , " S-1-16-8448 " }
2007-10-21 09:41:54 +02:00
} ;
2009-01-25 23:27:04 +01:00
static void test_CreateWellKnownSid ( void )
2007-10-21 09:41:54 +02:00
{
SID_IDENTIFIER_AUTHORITY ident = { SECURITY_NT_AUTHORITY } ;
2009-04-15 14:59:10 +02:00
PSID domainsid , sid ;
DWORD size , error ;
BOOL ret ;
2010-06-18 22:01:57 +02:00
unsigned int i ;
2007-10-21 09:41:54 +02:00
if ( ! pCreateWellKnownSid )
{
2009-02-26 09:45:07 +01:00
win_skip ( " CreateWellKnownSid not available \n " ) ;
2007-10-21 09:41:54 +02:00
return ;
}
2009-04-15 14:59:10 +02:00
size = 0 ;
SetLastError ( 0xdeadbeef ) ;
ret = pCreateWellKnownSid ( WinInteractiveSid , NULL , NULL , & size ) ;
error = GetLastError ( ) ;
ok ( ! ret , " CreateWellKnownSid succeeded \n " ) ;
ok ( error = = ERROR_INSUFFICIENT_BUFFER , " expected ERROR_INSUFFICIENT_BUFFER, got %u \n " , error ) ;
ok ( size , " expected size > 0 \n " ) ;
SetLastError ( 0xdeadbeef ) ;
ret = pCreateWellKnownSid ( WinInteractiveSid , NULL , NULL , & size ) ;
error = GetLastError ( ) ;
ok ( ! ret , " CreateWellKnownSid succeeded \n " ) ;
ok ( error = = ERROR_INVALID_PARAMETER , " expected ERROR_INVALID_PARAMETER, got %u \n " , error ) ;
sid = HeapAlloc ( GetProcessHeap ( ) , 0 , size ) ;
ret = pCreateWellKnownSid ( WinInteractiveSid , NULL , sid , & size ) ;
ok ( ret , " CreateWellKnownSid failed %u \n " , GetLastError ( ) ) ;
HeapFree ( GetProcessHeap ( ) , 0 , sid ) ;
2007-10-21 09:41:54 +02:00
/* a domain sid usually have three subauthorities but we test that CreateWellKnownSid doesn't check it */
AllocateAndInitializeSid ( & ident , 6 , SECURITY_NT_NON_UNIQUE , 12 , 23 , 34 , 45 , 56 , 0 , 0 , & domainsid ) ;
for ( i = 0 ; i < sizeof ( well_known_sid_values ) / sizeof ( well_known_sid_values [ 0 ] ) ; i + + )
{
2010-10-01 13:33:37 +02:00
const struct well_known_sid_value * value = & well_known_sid_values [ i ] ;
2007-10-21 09:41:54 +02:00
char sid_buffer [ SECURITY_MAX_SID_SIZE ] ;
LPSTR str ;
DWORD cb ;
2007-10-21 11:01:56 +02:00
if ( value - > sid_string = = NULL )
2007-10-21 09:41:54 +02:00
continue ;
2007-10-25 20:41:43 +02:00
if ( i > WinAccountRasAndIasServersSid )
2007-10-21 09:41:54 +02:00
{
/* These SIDs aren't implemented by all Windows versions - detect it and break the loop */
cb = sizeof ( sid_buffer ) ;
if ( ! pCreateWellKnownSid ( i , domainsid , sid_buffer , & cb ) )
{
2010-06-18 22:01:57 +02:00
skip ( " Well known SIDs starting from %u are not implemented \n " , i ) ;
2007-10-21 09:41:54 +02:00
break ;
}
}
cb = sizeof ( sid_buffer ) ;
2010-06-18 22:01:57 +02:00
ok ( pCreateWellKnownSid ( i , value - > without_domain ? NULL : domainsid , sid_buffer , & cb ) , " Couldn't create well known sid %u \n " , i ) ;
2007-10-21 09:41:54 +02:00
expect_eq ( GetSidLengthRequired ( * GetSidSubAuthorityCount ( sid_buffer ) ) , cb , DWORD , " %d " ) ;
ok ( IsValidSid ( sid_buffer ) , " The sid is not valid \n " ) ;
2007-11-02 11:33:36 +01:00
ok ( pConvertSidToStringSidA ( sid_buffer , & str ) , " Couldn't convert SID to string \n " ) ;
2012-07-22 18:13:14 +02:00
ok ( strcmp ( str , value - > sid_string ) = = 0 , " %d: SID mismatch - expected %s, got %s \n " , i ,
2007-10-21 09:41:54 +02:00
value - > sid_string , str ) ;
LocalFree ( str ) ;
2007-10-21 11:01:56 +02:00
if ( value - > without_domain )
{
char buf2 [ SECURITY_MAX_SID_SIZE ] ;
cb = sizeof ( buf2 ) ;
2010-06-18 22:01:57 +02:00
ok ( pCreateWellKnownSid ( i , domainsid , buf2 , & cb ) , " Couldn't create well known sid %u with optional domain \n " , i ) ;
2007-10-21 11:01:56 +02:00
expect_eq ( GetSidLengthRequired ( * GetSidSubAuthorityCount ( sid_buffer ) ) , cb , DWORD , " %d " ) ;
2010-06-18 22:01:57 +02:00
ok ( memcmp ( buf2 , sid_buffer , cb ) = = 0 , " SID create with domain is different than without (%u) \n " , i ) ;
2007-10-21 11:01:56 +02:00
}
2007-10-21 09:41:54 +02:00
}
2009-12-02 15:32:07 +01:00
2010-01-07 03:26:39 +01:00
FreeSid ( domainsid ) ;
2007-10-21 09:41:54 +02:00
}
2006-07-06 04:53:52 +02:00
static void test_LookupAccountSid ( void )
{
SID_IDENTIFIER_AUTHORITY SIDAuthNT = { SECURITY_NT_AUTHORITY } ;
2009-04-09 11:26:51 +02:00
CHAR accountA [ MAX_PATH ] , domainA [ MAX_PATH ] , usernameA [ MAX_PATH ] ;
DWORD acc_sizeA , dom_sizeA , user_sizeA ;
2006-08-26 00:14:58 +02:00
DWORD real_acc_sizeA , real_dom_sizeA ;
WCHAR accountW [ MAX_PATH ] , domainW [ MAX_PATH ] ;
DWORD acc_sizeW , dom_sizeW ;
DWORD real_acc_sizeW , real_dom_sizeW ;
2006-07-06 04:53:52 +02:00
PSID pUsersSid = NULL ;
SID_NAME_USE use ;
BOOL ret ;
2010-09-21 12:54:50 +02:00
DWORD error , size , cbti = 0 ;
2006-08-12 14:27:57 +02:00
MAX_SID max_sid ;
2006-08-26 00:14:58 +02:00
CHAR * str_sidA ;
2006-07-20 13:05:46 +02:00
int i ;
2009-04-09 11:26:51 +02:00
HANDLE hToken ;
PTOKEN_USER ptiUser = NULL ;
2006-07-06 04:53:52 +02:00
/* native windows crashes if account size, domain size, or name use is NULL */
ret = AllocateAndInitializeSid ( & SIDAuthNT , 2 , SECURITY_BUILTIN_DOMAIN_RID ,
DOMAIN_ALIAS_RID_USERS , 0 , 0 , 0 , 0 , 0 , 0 , & pUsersSid ) ;
2006-08-17 21:24:21 +02:00
ok ( ret | | ( GetLastError ( ) = = ERROR_CALL_NOT_IMPLEMENTED ) ,
2006-10-04 12:37:30 +02:00
" AllocateAndInitializeSid failed with error %d \n " , GetLastError ( ) ) ;
2006-08-17 21:24:21 +02:00
/* not running on NT so give up */
if ( ! ret & & ( GetLastError ( ) = = ERROR_CALL_NOT_IMPLEMENTED ) )
return ;
2006-07-06 04:53:52 +02:00
2006-08-26 00:14:58 +02:00
real_acc_sizeA = MAX_PATH ;
real_dom_sizeA = MAX_PATH ;
ret = LookupAccountSidA ( NULL , pUsersSid , accountA , & real_acc_sizeA , domainA , & real_dom_sizeA , & use ) ;
ok ( ret , " LookupAccountSidA() Expected TRUE, got FALSE \n " ) ;
/* try NULL account */
acc_sizeA = MAX_PATH ;
dom_sizeA = MAX_PATH ;
ret = LookupAccountSidA ( NULL , pUsersSid , NULL , & acc_sizeA , domainA , & dom_sizeA , & use ) ;
ok ( ret , " LookupAccountSidA() Expected TRUE, got FALSE \n " ) ;
/* try NULL domain */
acc_sizeA = MAX_PATH ;
dom_sizeA = MAX_PATH ;
ret = LookupAccountSidA ( NULL , pUsersSid , accountA , & acc_sizeA , NULL , & dom_sizeA , & use ) ;
ok ( ret , " LookupAccountSidA() Expected TRUE, got FALSE \n " ) ;
/* try a small account buffer */
acc_sizeA = 1 ;
dom_sizeA = MAX_PATH ;
accountA [ 0 ] = 0 ;
ret = LookupAccountSidA ( NULL , pUsersSid , accountA , & acc_sizeA , domainA , & dom_sizeA , & use ) ;
ok ( ! ret , " LookupAccountSidA() Expected FALSE got TRUE \n " ) ;
ok ( GetLastError ( ) = = ERROR_INSUFFICIENT_BUFFER ,
2006-10-04 12:37:30 +02:00
" LookupAccountSidA() Expected ERROR_NOT_ENOUGH_MEMORY, got %u \n " , GetLastError ( ) ) ;
2006-08-26 00:14:58 +02:00
/* try a 0 sized account buffer */
acc_sizeA = 0 ;
dom_sizeA = MAX_PATH ;
accountA [ 0 ] = 0 ;
2011-02-09 01:05:49 +01:00
LookupAccountSidA ( NULL , pUsersSid , accountA , & acc_sizeA , domainA , & dom_sizeA , & use ) ;
2006-08-26 00:14:58 +02:00
/* this can fail or succeed depending on OS version but the size will always be returned */
ok ( acc_sizeA = = real_acc_sizeA + 1 ,
2006-10-04 12:37:30 +02:00
" LookupAccountSidA() Expected acc_size = %u, got %u \n " ,
2006-08-26 00:14:58 +02:00
real_acc_sizeA + 1 , acc_sizeA ) ;
/* try a 0 sized account buffer */
acc_sizeA = 0 ;
dom_sizeA = MAX_PATH ;
2011-02-09 01:05:49 +01:00
LookupAccountSidA ( NULL , pUsersSid , NULL , & acc_sizeA , domainA , & dom_sizeA , & use ) ;
2006-08-26 00:14:58 +02:00
/* this can fail or succeed depending on OS version but the size will always be returned */
ok ( acc_sizeA = = real_acc_sizeA + 1 ,
2006-10-04 12:37:30 +02:00
" LookupAccountSid() Expected acc_size = %u, got %u \n " ,
2006-08-26 00:14:58 +02:00
real_acc_sizeA + 1 , acc_sizeA ) ;
/* try a small domain buffer */
dom_sizeA = 1 ;
acc_sizeA = MAX_PATH ;
accountA [ 0 ] = 0 ;
ret = LookupAccountSidA ( NULL , pUsersSid , accountA , & acc_sizeA , domainA , & dom_sizeA , & use ) ;
ok ( ! ret , " LookupAccountSidA() Expected FALSE got TRUE \n " ) ;
ok ( GetLastError ( ) = = ERROR_INSUFFICIENT_BUFFER ,
2006-10-04 12:37:30 +02:00
" LookupAccountSidA() Expected ERROR_NOT_ENOUGH_MEMORY, got %u \n " , GetLastError ( ) ) ;
2006-08-26 00:14:58 +02:00
/* try a 0 sized domain buffer */
dom_sizeA = 0 ;
acc_sizeA = MAX_PATH ;
accountA [ 0 ] = 0 ;
2011-02-09 01:05:49 +01:00
LookupAccountSidA ( NULL , pUsersSid , accountA , & acc_sizeA , domainA , & dom_sizeA , & use ) ;
2006-08-26 00:14:58 +02:00
/* this can fail or succeed depending on OS version but the size will always be returned */
ok ( dom_sizeA = = real_dom_sizeA + 1 ,
2006-10-04 12:37:30 +02:00
" LookupAccountSidA() Expected dom_size = %u, got %u \n " ,
2006-08-26 00:14:58 +02:00
real_dom_sizeA + 1 , dom_sizeA ) ;
/* try a 0 sized domain buffer */
dom_sizeA = 0 ;
acc_sizeA = MAX_PATH ;
2011-02-09 01:05:49 +01:00
LookupAccountSidA ( NULL , pUsersSid , accountA , & acc_sizeA , NULL , & dom_sizeA , & use ) ;
2006-08-26 00:14:58 +02:00
/* this can fail or succeed depending on OS version but the size will always be returned */
ok ( dom_sizeA = = real_dom_sizeA + 1 ,
2006-10-04 12:37:30 +02:00
" LookupAccountSidA() Expected dom_size = %u, got %u \n " ,
2006-08-26 00:14:58 +02:00
real_dom_sizeA + 1 , dom_sizeA ) ;
real_acc_sizeW = MAX_PATH ;
real_dom_sizeW = MAX_PATH ;
ret = LookupAccountSidW ( NULL , pUsersSid , accountW , & real_acc_sizeW , domainW , & real_dom_sizeW , & use ) ;
ok ( ret , " LookupAccountSidW() Expected TRUE, got FALSE \n " ) ;
2006-08-19 15:17:30 +02:00
2008-10-18 23:09:14 +02:00
/* try an invalid system name */
real_acc_sizeA = MAX_PATH ;
real_dom_sizeA = MAX_PATH ;
ret = LookupAccountSidA ( " deepthought " , pUsersSid , accountA , & real_acc_sizeA , domainA , & real_dom_sizeA , & use ) ;
ok ( ! ret , " LookupAccountSidA() Expected FALSE got TRUE \n " ) ;
2008-10-27 21:24:52 +01:00
ok ( GetLastError ( ) = = RPC_S_SERVER_UNAVAILABLE | | GetLastError ( ) = = RPC_S_INVALID_NET_ADDR /* Vista */ ,
" LookupAccountSidA() Expected RPC_S_SERVER_UNAVAILABLE or RPC_S_INVALID_NET_ADDR, got %u \n " , GetLastError ( ) ) ;
2008-10-18 23:09:14 +02:00
2006-08-27 22:36:23 +02:00
/* native windows crashes if domainW or accountW is NULL */
2006-07-20 13:05:46 +02:00
2006-08-19 15:17:30 +02:00
/* try a small account buffer */
2006-08-26 00:14:58 +02:00
acc_sizeW = 1 ;
dom_sizeW = MAX_PATH ;
accountW [ 0 ] = 0 ;
ret = LookupAccountSidW ( NULL , pUsersSid , accountW , & acc_sizeW , domainW , & dom_sizeW , & use ) ;
ok ( ! ret , " LookupAccountSidW() Expected FALSE got TRUE \n " ) ;
ok ( GetLastError ( ) = = ERROR_INSUFFICIENT_BUFFER ,
2006-10-04 12:37:30 +02:00
" LookupAccountSidW() Expected ERROR_NOT_ENOUGH_MEMORY, got %u \n " , GetLastError ( ) ) ;
2006-08-19 15:17:30 +02:00
/* try a 0 sized account buffer */
2006-08-26 00:14:58 +02:00
acc_sizeW = 0 ;
dom_sizeW = MAX_PATH ;
accountW [ 0 ] = 0 ;
2011-02-09 01:05:49 +01:00
LookupAccountSidW ( NULL , pUsersSid , accountW , & acc_sizeW , domainW , & dom_sizeW , & use ) ;
2006-08-19 15:17:30 +02:00
/* this can fail or succeed depending on OS version but the size will always be returned */
2006-08-26 00:14:58 +02:00
ok ( acc_sizeW = = real_acc_sizeW + 1 ,
2006-10-04 12:37:30 +02:00
" LookupAccountSidW() Expected acc_size = %u, got %u \n " ,
2006-08-26 00:14:58 +02:00
real_acc_sizeW + 1 , acc_sizeW ) ;
2006-08-19 15:17:30 +02:00
/* try a 0 sized account buffer */
2006-08-26 00:14:58 +02:00
acc_sizeW = 0 ;
dom_sizeW = MAX_PATH ;
2011-02-09 01:05:49 +01:00
LookupAccountSidW ( NULL , pUsersSid , NULL , & acc_sizeW , domainW , & dom_sizeW , & use ) ;
2006-08-19 15:17:30 +02:00
/* this can fail or succeed depending on OS version but the size will always be returned */
2006-08-26 00:14:58 +02:00
ok ( acc_sizeW = = real_acc_sizeW + 1 ,
2006-10-04 12:37:30 +02:00
" LookupAccountSidW() Expected acc_size = %u, got %u \n " ,
2006-08-26 00:14:58 +02:00
real_acc_sizeW + 1 , acc_sizeW ) ;
2006-08-19 15:17:30 +02:00
/* try a small domain buffer */
2006-08-26 00:14:58 +02:00
dom_sizeW = 1 ;
acc_sizeW = MAX_PATH ;
accountW [ 0 ] = 0 ;
ret = LookupAccountSidW ( NULL , pUsersSid , accountW , & acc_sizeW , domainW , & dom_sizeW , & use ) ;
ok ( ! ret , " LookupAccountSidW() Expected FALSE got TRUE \n " ) ;
ok ( GetLastError ( ) = = ERROR_INSUFFICIENT_BUFFER ,
2006-10-04 12:37:30 +02:00
" LookupAccountSidW() Expected ERROR_NOT_ENOUGH_MEMORY, got %u \n " , GetLastError ( ) ) ;
2006-08-19 15:17:30 +02:00
/* try a 0 sized domain buffer */
2006-08-26 00:14:58 +02:00
dom_sizeW = 0 ;
acc_sizeW = MAX_PATH ;
accountW [ 0 ] = 0 ;
2011-02-09 01:05:49 +01:00
LookupAccountSidW ( NULL , pUsersSid , accountW , & acc_sizeW , domainW , & dom_sizeW , & use ) ;
2006-08-19 15:17:30 +02:00
/* this can fail or succeed depending on OS version but the size will always be returned */
2006-08-26 00:14:58 +02:00
ok ( dom_sizeW = = real_dom_sizeW + 1 ,
2006-10-04 12:37:30 +02:00
" LookupAccountSidW() Expected dom_size = %u, got %u \n " ,
2006-08-26 00:14:58 +02:00
real_dom_sizeW + 1 , dom_sizeW ) ;
2006-08-19 15:17:30 +02:00
/* try a 0 sized domain buffer */
2006-08-26 00:14:58 +02:00
dom_sizeW = 0 ;
acc_sizeW = MAX_PATH ;
2011-02-09 01:05:49 +01:00
LookupAccountSidW ( NULL , pUsersSid , accountW , & acc_sizeW , NULL , & dom_sizeW , & use ) ;
2006-08-19 15:17:30 +02:00
/* this can fail or succeed depending on OS version but the size will always be returned */
2006-08-26 00:14:58 +02:00
ok ( dom_sizeW = = real_dom_sizeW + 1 ,
2006-10-04 12:37:30 +02:00
" LookupAccountSidW() Expected dom_size = %u, got %u \n " ,
2006-08-26 00:14:58 +02:00
real_dom_sizeW + 1 , dom_sizeW ) ;
2006-08-19 15:17:30 +02:00
2010-09-21 12:54:50 +02:00
acc_sizeW = dom_sizeW = use = 0 ;
SetLastError ( 0xdeadbeef ) ;
ret = LookupAccountSidW ( NULL , pUsersSid , NULL , & acc_sizeW , NULL , & dom_sizeW , & use ) ;
error = GetLastError ( ) ;
ok ( ! ret , " LookupAccountSidW failed %u \n " , GetLastError ( ) ) ;
ok ( error = = ERROR_INSUFFICIENT_BUFFER , " expected ERROR_INSUFFICIENT_BUFFER, got %u \n " , error ) ;
ok ( acc_sizeW , " expected non-zero account size \n " ) ;
ok ( dom_sizeW , " expected non-zero domain size \n " ) ;
ok ( ! use , " expected zero use %u \n " , use ) ;
2006-10-17 21:32:00 +02:00
FreeSid ( pUsersSid ) ;
2009-04-09 11:26:51 +02:00
/* Test LookupAccountSid with Sid retrieved from token information.
This assumes this process is running under the account of the current user . */
ret = OpenProcessToken ( GetCurrentProcess ( ) , TOKEN_QUERY | TOKEN_DUPLICATE , & hToken ) ;
2011-02-09 01:05:49 +01:00
ok ( ret , " OpenProcessToken failed with error %d \n " , GetLastError ( ) ) ;
2009-04-09 11:26:51 +02:00
ret = GetTokenInformation ( hToken , TokenUser , NULL , 0 , & cbti ) ;
2011-02-09 01:05:49 +01:00
ok ( ! ret , " GetTokenInformation failed with error %d \n " , GetLastError ( ) ) ;
2010-01-06 23:38:27 +01:00
ptiUser = HeapAlloc ( GetProcessHeap ( ) , 0 , cbti ) ;
2009-04-09 11:26:51 +02:00
if ( GetTokenInformation ( hToken , TokenUser , ptiUser , cbti , & cbti ) )
{
acc_sizeA = dom_sizeA = MAX_PATH ;
ret = LookupAccountSidA ( NULL , ptiUser - > User . Sid , accountA , & acc_sizeA , domainA , & dom_sizeA , & use ) ;
ok ( ret , " LookupAccountSidA() Expected TRUE, got FALSE \n " ) ;
user_sizeA = MAX_PATH ;
ret = GetUserNameA ( usernameA , & user_sizeA ) ;
ok ( ret , " GetUserNameA() Expected TRUE, got FALSE \n " ) ;
2011-03-02 10:46:12 +01:00
ok ( lstrcmpA ( usernameA , accountA ) = = 0 , " LookupAccountSidA() Expected account name: %s got: %s \n " , usernameA , accountA ) ;
2009-04-09 11:26:51 +02:00
}
HeapFree ( GetProcessHeap ( ) , 0 , ptiUser ) ;
2006-07-20 13:05:46 +02:00
if ( pCreateWellKnownSid & & pConvertSidToStringSidA )
{
trace ( " Well Known SIDs: \n " ) ;
for ( i = 0 ; i < = 60 ; i + + )
{
size = SECURITY_MAX_SID_SIZE ;
if ( pCreateWellKnownSid ( i , NULL , & max_sid . sid , & size ) )
{
2006-08-26 00:14:58 +02:00
if ( pConvertSidToStringSidA ( & max_sid . sid , & str_sidA ) )
2006-07-20 13:05:46 +02:00
{
2006-08-26 00:14:58 +02:00
acc_sizeA = MAX_PATH ;
dom_sizeA = MAX_PATH ;
if ( LookupAccountSidA ( NULL , & max_sid . sid , accountA , & acc_sizeA , domainA , & dom_sizeA , & use ) )
trace ( " %d: %s %s \\ %s %d \n " , i , str_sidA , domainA , accountA , use ) ;
LocalFree ( str_sidA ) ;
2006-07-20 13:05:46 +02:00
}
}
else
2006-08-27 22:36:23 +02:00
{
if ( GetLastError ( ) ! = ERROR_INVALID_PARAMETER )
2006-10-04 12:37:30 +02:00
trace ( " CreateWellKnownSid(%d) failed: %d \n " , i , GetLastError ( ) ) ;
2006-08-27 22:36:23 +02:00
else
trace ( " %d: not supported \n " , i ) ;
}
2006-08-04 14:17:58 +02:00
}
2010-10-01 13:33:37 +02:00
pLsaQueryInformationPolicy = ( void * ) GetProcAddress ( hmod , " LsaQueryInformationPolicy " ) ;
pLsaOpenPolicy = ( void * ) GetProcAddress ( hmod , " LsaOpenPolicy " ) ;
pLsaFreeMemory = ( void * ) GetProcAddress ( hmod , " LsaFreeMemory " ) ;
pLsaClose = ( void * ) GetProcAddress ( hmod , " LsaClose " ) ;
2006-08-04 14:17:58 +02:00
if ( pLsaQueryInformationPolicy & & pLsaOpenPolicy & & pLsaFreeMemory & & pLsaClose )
{
NTSTATUS status ;
LSA_HANDLE handle ;
LSA_OBJECT_ATTRIBUTES object_attributes ;
ZeroMemory ( & object_attributes , sizeof ( object_attributes ) ) ;
2006-08-14 13:17:55 +02:00
object_attributes . Length = sizeof ( object_attributes ) ;
2006-08-04 14:17:58 +02:00
status = pLsaOpenPolicy ( NULL , & object_attributes , POLICY_ALL_ACCESS , & handle ) ;
2006-08-14 13:17:55 +02:00
ok ( status = = STATUS_SUCCESS | | status = = STATUS_ACCESS_DENIED ,
2006-10-04 12:37:30 +02:00
" LsaOpenPolicy(POLICY_ALL_ACCESS) returned 0x%08x \n " , status ) ;
2006-08-14 13:17:55 +02:00
/* try a more restricted access mask if necessary */
if ( status = = STATUS_ACCESS_DENIED ) {
trace ( " LsaOpenPolicy(POLICY_ALL_ACCESS) failed, trying POLICY_VIEW_LOCAL_INFORMATION \n " ) ;
status = pLsaOpenPolicy ( NULL , & object_attributes , POLICY_VIEW_LOCAL_INFORMATION , & handle ) ;
2006-10-04 12:37:30 +02:00
ok ( status = = STATUS_SUCCESS , " LsaOpenPolicy(POLICY_VIEW_LOCAL_INFORMATION) returned 0x%08x \n " , status ) ;
2006-08-14 13:17:55 +02:00
}
2006-08-04 14:17:58 +02:00
if ( status = = STATUS_SUCCESS )
{
PPOLICY_ACCOUNT_DOMAIN_INFO info ;
status = pLsaQueryInformationPolicy ( handle , PolicyAccountDomainInformation , ( PVOID * ) & info ) ;
2006-10-04 12:37:30 +02:00
ok ( status = = STATUS_SUCCESS , " LsaQueryInformationPolicy() failed, returned 0x%08x \n " , status ) ;
2006-08-04 14:17:58 +02:00
if ( status = = STATUS_SUCCESS )
{
ok ( info - > DomainSid ! = 0 , " LsaQueryInformationPolicy(PolicyAccountDomainInformation) missing SID \n " ) ;
if ( info - > DomainSid )
{
int count = * GetSidSubAuthorityCount ( info - > DomainSid ) ;
2006-08-12 14:27:57 +02:00
CopySid ( GetSidLengthRequired ( count ) , & max_sid , info - > DomainSid ) ;
test_sid_str ( ( PSID ) & max_sid . sid ) ;
2006-08-04 14:17:58 +02:00
max_sid . sid . SubAuthority [ count ] = DOMAIN_USER_RID_ADMIN ;
max_sid . sid . SubAuthorityCount = count + 1 ;
2006-08-12 14:27:57 +02:00
test_sid_str ( ( PSID ) & max_sid . sid ) ;
2006-08-04 14:17:58 +02:00
max_sid . sid . SubAuthority [ count ] = DOMAIN_USER_RID_GUEST ;
2006-08-12 14:27:57 +02:00
test_sid_str ( ( PSID ) & max_sid . sid ) ;
max_sid . sid . SubAuthority [ count ] = DOMAIN_GROUP_RID_ADMINS ;
test_sid_str ( ( PSID ) & max_sid . sid ) ;
max_sid . sid . SubAuthority [ count ] = DOMAIN_GROUP_RID_USERS ;
test_sid_str ( ( PSID ) & max_sid . sid ) ;
max_sid . sid . SubAuthority [ count ] = DOMAIN_GROUP_RID_GUESTS ;
test_sid_str ( ( PSID ) & max_sid . sid ) ;
max_sid . sid . SubAuthority [ count ] = DOMAIN_GROUP_RID_COMPUTERS ;
test_sid_str ( ( PSID ) & max_sid . sid ) ;
max_sid . sid . SubAuthority [ count ] = DOMAIN_GROUP_RID_CONTROLLERS ;
test_sid_str ( ( PSID ) & max_sid . sid ) ;
max_sid . sid . SubAuthority [ count ] = DOMAIN_GROUP_RID_CERT_ADMINS ;
test_sid_str ( ( PSID ) & max_sid . sid ) ;
max_sid . sid . SubAuthority [ count ] = DOMAIN_GROUP_RID_SCHEMA_ADMINS ;
test_sid_str ( ( PSID ) & max_sid . sid ) ;
max_sid . sid . SubAuthority [ count ] = DOMAIN_GROUP_RID_ENTERPRISE_ADMINS ;
test_sid_str ( ( PSID ) & max_sid . sid ) ;
max_sid . sid . SubAuthority [ count ] = DOMAIN_GROUP_RID_POLICY_ADMINS ;
test_sid_str ( ( PSID ) & max_sid . sid ) ;
max_sid . sid . SubAuthority [ count ] = DOMAIN_ALIAS_RID_RAS_SERVERS ;
test_sid_str ( ( PSID ) & max_sid . sid ) ;
max_sid . sid . SubAuthority [ count ] = 1000 ; /* first user account */
test_sid_str ( ( PSID ) & max_sid . sid ) ;
2006-08-04 14:17:58 +02:00
}
pLsaFreeMemory ( ( LPVOID ) info ) ;
}
status = pLsaClose ( handle ) ;
2006-10-04 12:37:30 +02:00
ok ( status = = STATUS_SUCCESS , " LsaClose() failed, returned 0x%08x \n " , status ) ;
2006-08-04 14:17:58 +02:00
}
2006-07-20 13:05:46 +02:00
}
}
2006-07-06 04:53:52 +02:00
}
2009-04-03 10:55:50 +02:00
static BOOL get_sid_info ( PSID psid , LPSTR * user , LPSTR * dom )
2006-12-01 00:53:21 +01:00
{
static CHAR account [ UNLEN + 1 ] ;
static CHAR domain [ UNLEN + 1 ] ;
DWORD size , dom_size ;
SID_NAME_USE use ;
* user = account ;
* dom = domain ;
size = dom_size = UNLEN + 1 ;
account [ 0 ] = ' \0 ' ;
domain [ 0 ] = ' \0 ' ;
2009-04-03 10:55:50 +02:00
SetLastError ( 0xdeadbeef ) ;
return LookupAccountSidA ( NULL , psid , account , & size , domain , & dom_size , & use ) ;
2006-12-01 00:53:21 +01:00
}
2009-03-31 15:59:54 +02:00
static void check_wellknown_name ( const char * name , WELL_KNOWN_SID_TYPE result )
2009-03-27 15:47:43 +01:00
{
2009-03-31 15:59:54 +02:00
SID_IDENTIFIER_AUTHORITY ident = { SECURITY_NT_AUTHORITY } ;
2010-01-07 03:26:39 +01:00
PSID domainsid = NULL ;
2009-03-31 15:59:54 +02:00
char wk_sid [ SECURITY_MAX_SID_SIZE ] ;
DWORD cb ;
2009-03-27 15:47:43 +01:00
DWORD sid_size , domain_size ;
SID_NAME_USE sid_use ;
2009-03-31 15:59:54 +02:00
LPSTR domain , account , sid_domain , wk_domain , wk_account ;
2009-03-27 15:47:43 +01:00
PSID psid ;
2009-04-03 10:55:50 +02:00
BOOL ret , ret2 ;
2009-03-27 15:47:43 +01:00
sid_size = 0 ;
domain_size = 0 ;
ret = LookupAccountNameA ( NULL , name , NULL , & sid_size , NULL , & domain_size , & sid_use ) ;
2011-02-17 02:22:17 +01:00
ok ( ! ret , " %s Should have failed to lookup account name \n " , name ) ;
2009-03-27 15:47:43 +01:00
psid = HeapAlloc ( GetProcessHeap ( ) , 0 , sid_size ) ;
domain = HeapAlloc ( GetProcessHeap ( ) , 0 , domain_size ) ;
ret = LookupAccountNameA ( NULL , name , psid , & sid_size , domain , & domain_size , & sid_use ) ;
2009-03-31 15:59:54 +02:00
if ( ! result )
2009-03-27 15:47:43 +01:00
{
ok ( ! ret , " %s Should have failed to lookup account name \n " , name ) ;
2009-04-03 10:55:50 +02:00
goto cleanup ;
2009-03-27 15:47:43 +01:00
}
2009-03-31 15:59:54 +02:00
AllocateAndInitializeSid ( & ident , 6 , SECURITY_NT_NON_UNIQUE , 12 , 23 , 34 , 45 , 56 , 0 , 0 , & domainsid ) ;
cb = sizeof ( wk_sid ) ;
if ( ! pCreateWellKnownSid ( result , domainsid , wk_sid , & cb ) )
{
2009-04-03 10:55:50 +02:00
win_skip ( " SID %i is not available on the system \n " , result ) ;
goto cleanup ;
}
ret2 = get_sid_info ( wk_sid , & wk_account , & wk_domain ) ;
if ( ! ret2 & & GetLastError ( ) = = ERROR_NONE_MAPPED )
{
win_skip ( " CreateWellKnownSid() succeeded but the account '%s' is not present (W2K) \n " , name ) ;
goto cleanup ;
2009-03-31 15:59:54 +02:00
}
get_sid_info ( psid , & account , & sid_domain ) ;
2009-03-27 15:47:43 +01:00
ok ( ret , " Failed to lookup account name %s \n " , name ) ;
ok ( sid_size ! = 0 , " sid_size was zero \n " ) ;
2009-03-31 15:59:54 +02:00
ok ( EqualSid ( psid , wk_sid ) , " (%s) Sids fail to match well known sid! \n " , name ) ;
2013-10-15 10:15:45 +02:00
ok ( ! lstrcmpA ( account , wk_account ) , " Expected %s , got %s \n " , account , wk_account ) ;
ok ( ! lstrcmpA ( domain , wk_domain ) , " Expected %s, got %s \n " , wk_domain , domain ) ;
2009-03-31 15:59:54 +02:00
ok ( sid_use = = SidTypeWellKnownGroup , " Expected Use (5), got %d \n " , sid_use ) ;
2009-03-27 15:47:43 +01:00
2009-04-03 10:55:50 +02:00
cleanup :
2010-01-07 03:26:39 +01:00
FreeSid ( domainsid ) ;
2009-03-27 15:47:43 +01:00
HeapFree ( GetProcessHeap ( ) , 0 , psid ) ;
HeapFree ( GetProcessHeap ( ) , 0 , domain ) ;
}
2006-12-01 00:53:21 +01:00
static void test_LookupAccountName ( void )
{
DWORD sid_size , domain_size , user_size ;
DWORD sid_save , domain_save ;
CHAR user_name [ UNLEN + 1 ] ;
2009-02-04 22:19:51 +01:00
CHAR computer_name [ UNLEN + 1 ] ;
2006-12-01 00:53:21 +01:00
SID_NAME_USE sid_use ;
LPSTR domain , account , sid_dom ;
PSID psid ;
BOOL ret ;
/* native crashes if (assuming all other parameters correct):
* - peUse is NULL
* - Sid is NULL and cbSid is > 0
* - cbSid or cchReferencedDomainName are NULL
* - ReferencedDomainName is NULL and cchReferencedDomainName is the correct size
*/
user_size = UNLEN + 1 ;
2007-08-16 14:07:36 +02:00
SetLastError ( 0xdeadbeef ) ;
2006-12-01 00:53:21 +01:00
ret = GetUserNameA ( user_name , & user_size ) ;
2007-08-16 14:07:36 +02:00
ok ( ret , " Failed to get user name : %d \n " , GetLastError ( ) ) ;
2006-12-01 00:53:21 +01:00
/* get sizes */
sid_size = 0 ;
domain_size = 0 ;
sid_use = 0xcafebabe ;
SetLastError ( 0xdeadbeef ) ;
ret = LookupAccountNameA ( NULL , user_name , NULL , & sid_size , NULL , & domain_size , & sid_use ) ;
2007-03-29 21:08:22 +02:00
if ( ! ret & & ( GetLastError ( ) = = ERROR_CALL_NOT_IMPLEMENTED ) )
{
2009-02-26 09:45:07 +01:00
win_skip ( " LookupAccountNameA is not implemented \n " ) ;
2007-03-29 21:08:22 +02:00
return ;
}
2006-12-01 00:53:21 +01:00
ok ( ! ret , " Expected 0, got %d \n " , ret ) ;
ok ( GetLastError ( ) = = ERROR_INSUFFICIENT_BUFFER ,
" Expected ERROR_INSUFFICIENT_BUFFER, got %d \n " , GetLastError ( ) ) ;
ok ( sid_size ! = 0 , " Expected non-zero sid size \n " ) ;
ok ( domain_size ! = 0 , " Expected non-zero domain size \n " ) ;
ok ( sid_use = = 0xcafebabe , " Expected 0xcafebabe, got %d \n " , sid_use ) ;
sid_save = sid_size ;
domain_save = domain_size ;
psid = HeapAlloc ( GetProcessHeap ( ) , 0 , sid_size ) ;
domain = HeapAlloc ( GetProcessHeap ( ) , 0 , domain_size ) ;
/* try valid account name */
ret = LookupAccountNameA ( NULL , user_name , psid , & sid_size , domain , & domain_size , & sid_use ) ;
get_sid_info ( psid , & account , & sid_dom ) ;
ok ( ret , " Failed to lookup account name \n " ) ;
ok ( sid_size = = GetLengthSid ( psid ) , " Expected %d, got %d \n " , GetLengthSid ( psid ) , sid_size ) ;
2013-10-15 10:15:45 +02:00
ok ( ! lstrcmpA ( account , user_name ) , " Expected %s, got %s \n " , user_name , account ) ;
ok ( ! lstrcmpA ( domain , sid_dom ) , " Expected %s, got %s \n " , sid_dom , domain ) ;
2008-10-18 21:46:35 +02:00
ok ( domain_size = = domain_save - 1 , " Expected %d, got %d \n " , domain_save - 1 , domain_size ) ;
2013-10-15 10:15:45 +02:00
ok ( strlen ( domain ) = = domain_size , " Expected %d, got %d \n " , lstrlenA ( domain ) , domain_size ) ;
2008-10-18 21:36:36 +02:00
ok ( sid_use = = SidTypeUser , " Expected SidTypeUser (%d), got %d \n " , SidTypeUser , sid_use ) ;
2008-01-22 16:36:45 +01:00
domain_size = domain_save ;
sid_size = sid_save ;
2011-03-16 11:45:34 +01:00
if ( PRIMARYLANGID ( GetSystemDefaultLangID ( ) ) ! = LANG_ENGLISH )
2008-02-16 14:11:57 +01:00
{
2011-08-03 23:50:18 +02:00
skip ( " Non-English locale (test with hardcoded 'Everyone') \n " ) ;
2008-02-16 14:11:57 +01:00
}
else
{
ret = LookupAccountNameA ( NULL , " Everyone " , psid , & sid_size , domain , & domain_size , & sid_use ) ;
get_sid_info ( psid , & account , & sid_dom ) ;
ok ( ret , " Failed to lookup account name \n " ) ;
ok ( sid_size ! = 0 , " sid_size was zero \n " ) ;
2013-10-15 10:15:45 +02:00
ok ( ! lstrcmpA ( account , " Everyone " ) , " Expected Everyone, got %s \n " , account ) ;
ok ( ! lstrcmpA ( domain , sid_dom ) , " Expected %s, got %s \n " , sid_dom , domain ) ;
2008-02-16 14:11:57 +01:00
ok ( domain_size = = 0 , " Expected 0, got %d \n " , domain_size ) ;
2013-10-15 10:15:45 +02:00
ok ( strlen ( domain ) = = domain_size , " Expected %d, got %d \n " , lstrlenA ( domain ) , domain_size ) ;
2008-10-18 20:54:32 +02:00
ok ( sid_use = = SidTypeWellKnownGroup , " Expected SidTypeWellKnownGroup (%d), got %d \n " , SidTypeWellKnownGroup , sid_use ) ;
2008-02-16 14:11:57 +01:00
domain_size = domain_save ;
}
2006-12-01 00:53:21 +01:00
/* NULL Sid with zero sid size */
SetLastError ( 0xdeadbeef ) ;
sid_size = 0 ;
ret = LookupAccountNameA ( NULL , user_name , NULL , & sid_size , domain , & domain_size , & sid_use ) ;
ok ( ! ret , " Expected 0, got %d \n " , ret ) ;
ok ( GetLastError ( ) = = ERROR_INSUFFICIENT_BUFFER ,
" Expected ERROR_INSUFFICIENT_BUFFER, got %d \n " , GetLastError ( ) ) ;
ok ( sid_size = = sid_save , " Expected %d, got %d \n " , sid_save , sid_size ) ;
ok ( domain_size = = domain_save , " Expected %d, got %d \n " , domain_save , domain_size ) ;
/* try cchReferencedDomainName - 1 */
SetLastError ( 0xdeadbeef ) ;
domain_size - - ;
ret = LookupAccountNameA ( NULL , user_name , NULL , & sid_size , domain , & domain_size , & sid_use ) ;
ok ( ! ret , " Expected 0, got %d \n " , ret ) ;
ok ( GetLastError ( ) = = ERROR_INSUFFICIENT_BUFFER ,
" Expected ERROR_INSUFFICIENT_BUFFER, got %d \n " , GetLastError ( ) ) ;
ok ( sid_size = = sid_save , " Expected %d, got %d \n " , sid_save , sid_size ) ;
ok ( domain_size = = domain_save , " Expected %d, got %d \n " , domain_save , domain_size ) ;
/* NULL ReferencedDomainName with zero domain name size */
SetLastError ( 0xdeadbeef ) ;
domain_size = 0 ;
ret = LookupAccountNameA ( NULL , user_name , psid , & sid_size , NULL , & domain_size , & sid_use ) ;
ok ( ! ret , " Expected 0, got %d \n " , ret ) ;
ok ( GetLastError ( ) = = ERROR_INSUFFICIENT_BUFFER ,
" Expected ERROR_INSUFFICIENT_BUFFER, got %d \n " , GetLastError ( ) ) ;
ok ( sid_size = = sid_save , " Expected %d, got %d \n " , sid_save , sid_size ) ;
ok ( domain_size = = domain_save , " Expected %d, got %d \n " , domain_save , domain_size ) ;
HeapFree ( GetProcessHeap ( ) , 0 , psid ) ;
HeapFree ( GetProcessHeap ( ) , 0 , domain ) ;
/* get sizes for NULL account name */
sid_size = 0 ;
domain_size = 0 ;
sid_use = 0xcafebabe ;
SetLastError ( 0xdeadbeef ) ;
ret = LookupAccountNameA ( NULL , NULL , NULL , & sid_size , NULL , & domain_size , & sid_use ) ;
2008-12-09 14:14:25 +01:00
if ( ! ret & & GetLastError ( ) = = ERROR_NONE_MAPPED )
win_skip ( " NULL account name doesn't work on NT4 \n " ) ;
else
2008-12-09 11:53:48 +01:00
{
ok ( ! ret , " Expected 0, got %d \n " , ret ) ;
ok ( GetLastError ( ) = = ERROR_INSUFFICIENT_BUFFER ,
" Expected ERROR_INSUFFICIENT_BUFFER, got %d \n " , GetLastError ( ) ) ;
ok ( sid_size ! = 0 , " Expected non-zero sid size \n " ) ;
ok ( domain_size ! = 0 , " Expected non-zero domain size \n " ) ;
ok ( sid_use = = 0xcafebabe , " Expected 0xcafebabe, got %d \n " , sid_use ) ;
psid = HeapAlloc ( GetProcessHeap ( ) , 0 , sid_size ) ;
domain = HeapAlloc ( GetProcessHeap ( ) , 0 , domain_size ) ;
/* try NULL account name */
ret = LookupAccountNameA ( NULL , NULL , psid , & sid_size , domain , & domain_size , & sid_use ) ;
get_sid_info ( psid , & account , & sid_dom ) ;
ok ( ret , " Failed to lookup account name \n " ) ;
/* Using a fixed string will not work on different locales */
2013-10-15 10:15:45 +02:00
ok ( ! lstrcmpA ( account , domain ) ,
2008-12-09 11:53:48 +01:00
" Got %s for account and %s for domain, these should be the same \n " ,
account , domain ) ;
ok ( sid_use = = SidTypeDomain , " Expected SidTypeDomain (%d), got %d \n " , SidTypeDomain , sid_use ) ;
HeapFree ( GetProcessHeap ( ) , 0 , psid ) ;
HeapFree ( GetProcessHeap ( ) , 0 , domain ) ;
}
2006-12-01 00:53:21 +01:00
/* try an invalid account name */
SetLastError ( 0xdeadbeef ) ;
sid_size = 0 ;
domain_size = 0 ;
ret = LookupAccountNameA ( NULL , " oogabooga " , NULL , & sid_size , NULL , & domain_size , & sid_use ) ;
ok ( ! ret , " Expected 0, got %d \n " , ret ) ;
2008-10-18 23:09:14 +02:00
ok ( GetLastError ( ) = = ERROR_NONE_MAPPED | |
broken ( GetLastError ( ) = = ERROR_TRUSTED_RELATIONSHIP_FAILURE ) ,
" Expected ERROR_NONE_MAPPED, got %d \n " , GetLastError ( ) ) ;
ok ( sid_size = = 0 , " Expected 0, got %d \n " , sid_size ) ;
ok ( domain_size = = 0 , " Expected 0, got %d \n " , domain_size ) ;
/* try an invalid system name */
SetLastError ( 0xdeadbeef ) ;
sid_size = 0 ;
domain_size = 0 ;
ret = LookupAccountNameA ( " deepthought " , NULL , NULL , & sid_size , NULL , & domain_size , & sid_use ) ;
ok ( ! ret , " Expected 0, got %d \n " , ret ) ;
2008-10-27 21:24:52 +01:00
ok ( GetLastError ( ) = = RPC_S_SERVER_UNAVAILABLE | | GetLastError ( ) = = RPC_S_INVALID_NET_ADDR /* Vista */ ,
" Expected RPC_S_SERVER_UNAVAILABLE or RPC_S_INVALID_NET_ADDR, got %d \n " , GetLastError ( ) ) ;
2008-10-18 23:09:14 +02:00
ok ( sid_size = = 0 , " Expected 0, got %d \n " , sid_size ) ;
ok ( domain_size = = 0 , " Expected 0, got %d \n " , domain_size ) ;
2009-02-04 22:19:51 +01:00
/* try with the computer name as the account name */
domain_size = sizeof ( computer_name ) ;
GetComputerNameA ( computer_name , & domain_size ) ;
sid_size = 0 ;
domain_size = 0 ;
ret = LookupAccountNameA ( NULL , computer_name , NULL , & sid_size , NULL , & domain_size , & sid_use ) ;
ok ( ! ret & & ( GetLastError ( ) = = ERROR_INSUFFICIENT_BUFFER | |
2009-02-12 23:27:53 +01:00
GetLastError ( ) = = ERROR_NONE_MAPPED /* in a domain */ | |
2009-02-04 22:19:51 +01:00
broken ( GetLastError ( ) = = ERROR_TRUSTED_DOMAIN_FAILURE ) | |
broken ( GetLastError ( ) = = ERROR_TRUSTED_RELATIONSHIP_FAILURE ) ) ,
" LookupAccountNameA failed: %d \n " , GetLastError ( ) ) ;
if ( GetLastError ( ) = = ERROR_INSUFFICIENT_BUFFER )
{
psid = HeapAlloc ( GetProcessHeap ( ) , 0 , sid_size ) ;
domain = HeapAlloc ( GetProcessHeap ( ) , 0 , domain_size ) ;
ret = LookupAccountNameA ( NULL , computer_name , psid , & sid_size , domain , & domain_size , & sid_use ) ;
ok ( ret , " LookupAccountNameA failed: %d \n " , GetLastError ( ) ) ;
2009-11-02 23:49:00 +01:00
ok ( sid_use = = SidTypeDomain | |
( sid_use = = SidTypeUser & & ! strcmp ( computer_name , user_name ) ) , " expected SidTypeDomain for %s, got %d \n " , computer_name , sid_use ) ;
2009-02-04 22:19:51 +01:00
HeapFree ( GetProcessHeap ( ) , 0 , domain ) ;
HeapFree ( GetProcessHeap ( ) , 0 , psid ) ;
}
2009-03-27 15:47:43 +01:00
/* Well Known names */
2009-03-31 15:59:54 +02:00
if ( ! pCreateWellKnownSid )
{
win_skip ( " CreateWellKnownSid not available \n " ) ;
return ;
}
2011-03-16 11:45:34 +01:00
if ( PRIMARYLANGID ( GetSystemDefaultLangID ( ) ) ! = LANG_ENGLISH )
2009-03-31 15:59:54 +02:00
{
2011-08-03 23:50:18 +02:00
skip ( " Non-English locale (skipping well known name creation tests) \n " ) ;
2009-03-31 15:59:54 +02:00
return ;
}
check_wellknown_name ( " LocalService " , WinLocalServiceSid ) ;
check_wellknown_name ( " Local Service " , WinLocalServiceSid ) ;
2009-03-27 15:47:43 +01:00
/* 2 spaces */
2009-03-31 15:59:54 +02:00
check_wellknown_name ( " Local Service " , 0 ) ;
check_wellknown_name ( " NetworkService " , WinNetworkServiceSid ) ;
check_wellknown_name ( " Network Service " , WinNetworkServiceSid ) ;
2009-03-27 15:47:43 +01:00
/* example of some names where the spaces are not optional */
2009-03-31 15:59:54 +02:00
check_wellknown_name ( " Terminal Server User " , WinTerminalServerSid ) ;
check_wellknown_name ( " TerminalServer User " , 0 ) ;
check_wellknown_name ( " TerminalServerUser " , 0 ) ;
check_wellknown_name ( " Terminal ServerUser " , 0 ) ;
2009-03-27 15:47:43 +01:00
2009-03-31 15:59:54 +02:00
check_wellknown_name ( " enterprise domain controllers " , WinEnterpriseControllersSid ) ;
check_wellknown_name ( " enterprisedomain controllers " , 0 ) ;
check_wellknown_name ( " enterprise domaincontrollers " , 0 ) ;
check_wellknown_name ( " enterprisedomaincontrollers " , 0 ) ;
2009-03-27 15:47:43 +01:00
/* case insensitivity */
2009-03-31 15:59:54 +02:00
check_wellknown_name ( " lOCAlServICE " , WinLocalServiceSid ) ;
2009-03-31 16:00:11 +02:00
/* fully qualified account names */
check_wellknown_name ( " NT AUTHORITY \\ LocalService " , WinLocalServiceSid ) ;
check_wellknown_name ( " nt authority \\ Network Service " , WinNetworkServiceSid ) ;
check_wellknown_name ( " nt authority test \\ Network Service " , 0 ) ;
check_wellknown_name ( " Dummy \\ Network Service " , 0 ) ;
check_wellknown_name ( " ntauthority \\ Network Service " , 0 ) ;
2006-12-01 00:53:21 +01:00
}
2007-09-27 19:34:53 +02:00
static void test_security_descriptor ( void )
{
SECURITY_DESCRIPTOR sd ;
char buf [ 8192 ] ;
DWORD size ;
2008-01-08 10:18:17 +01:00
BOOL isDefault , isPresent , ret ;
2007-09-27 19:34:53 +02:00
PACL pacl ;
PSID psid ;
2008-01-08 10:18:17 +01:00
SetLastError ( 0xdeadbeef ) ;
ret = InitializeSecurityDescriptor ( & sd , SECURITY_DESCRIPTOR_REVISION ) ;
if ( ret & & GetLastError ( ) = = ERROR_CALL_NOT_IMPLEMENTED )
{
2009-02-26 09:45:07 +01:00
win_skip ( " InitializeSecurityDescriptor is not implemented \n " ) ;
2008-01-08 10:18:17 +01:00
return ;
}
2007-09-27 19:34:53 +02:00
ok ( GetSecurityDescriptorOwner ( & sd , & psid , & isDefault ) , " GetSecurityDescriptorOwner failed \n " ) ;
expect_eq ( psid , NULL , PSID , " %p " ) ;
2007-09-27 19:36:58 +02:00
expect_eq ( isDefault , FALSE , BOOL , " %d " ) ;
2007-09-27 19:34:53 +02:00
sd . Control | = SE_DACL_PRESENT | SE_SACL_PRESENT ;
SetLastError ( 0xdeadbeef ) ;
size = 5 ;
expect_eq ( MakeSelfRelativeSD ( & sd , buf , & size ) , FALSE , BOOL , " %d " ) ;
expect_eq ( GetLastError ( ) , ERROR_INSUFFICIENT_BUFFER , DWORD , " %u " ) ;
ok ( size > 5 , " Size not increased \n " ) ;
if ( size < = 8192 )
{
expect_eq ( MakeSelfRelativeSD ( & sd , buf , & size ) , TRUE , BOOL , " %d " ) ;
ok ( GetSecurityDescriptorOwner ( & sd , & psid , & isDefault ) , " GetSecurityDescriptorOwner failed \n " ) ;
expect_eq ( psid , NULL , PSID , " %p " ) ;
2007-09-27 19:36:58 +02:00
expect_eq ( isDefault , FALSE , BOOL , " %d " ) ;
2008-03-06 21:10:49 +01:00
ok ( GetSecurityDescriptorGroup ( & sd , & psid , & isDefault ) , " GetSecurityDescriptorGroup failed \n " ) ;
2007-09-27 19:34:53 +02:00
expect_eq ( psid , NULL , PSID , " %p " ) ;
2007-09-27 19:36:58 +02:00
expect_eq ( isDefault , FALSE , BOOL , " %d " ) ;
2008-03-06 21:10:49 +01:00
ok ( GetSecurityDescriptorDacl ( & sd , & isPresent , & pacl , & isDefault ) , " GetSecurityDescriptorDacl failed \n " ) ;
2007-09-27 19:34:53 +02:00
expect_eq ( isPresent , TRUE , BOOL , " %d " ) ;
expect_eq ( psid , NULL , PSID , " %p " ) ;
expect_eq ( isDefault , FALSE , BOOL , " %d " ) ;
2008-03-06 21:10:49 +01:00
ok ( GetSecurityDescriptorSacl ( & sd , & isPresent , & pacl , & isDefault ) , " GetSecurityDescriptorSacl failed \n " ) ;
2007-09-27 19:34:53 +02:00
expect_eq ( isPresent , TRUE , BOOL , " %d " ) ;
expect_eq ( psid , NULL , PSID , " %p " ) ;
expect_eq ( isDefault , FALSE , BOOL , " %d " ) ;
}
}
2008-08-29 04:10:51 +02:00
# define TEST_GRANTED_ACCESS(a,b) test_granted_access(a,b,0,__LINE__)
# define TEST_GRANTED_ACCESS2(a,b,c) test_granted_access(a,b,c,__LINE__)
static void test_granted_access ( HANDLE handle , ACCESS_MASK access ,
ACCESS_MASK alt , int line )
2007-01-25 07:43:18 +01:00
{
OBJECT_BASIC_INFORMATION obj_info ;
NTSTATUS status ;
if ( ! pNtQueryObject )
{
skip_ ( __FILE__ , line ) ( " Not NT platform - skipping tests \n " ) ;
return ;
}
status = pNtQueryObject ( handle , ObjectBasicInformation , & obj_info ,
sizeof ( obj_info ) , NULL ) ;
ok_ ( __FILE__ , line ) ( ! status , " NtQueryObject with err: %08x \n " , status ) ;
2008-08-29 04:10:51 +02:00
if ( alt )
ok_ ( __FILE__ , line ) ( obj_info . GrantedAccess = = access | |
obj_info . GrantedAccess = = alt , " Granted access should be 0x%08x "
" or 0x%08x, instead of 0x%08x \n " , access , alt , obj_info . GrantedAccess ) ;
else
ok_ ( __FILE__ , line ) ( obj_info . GrantedAccess = = access , " Granted access should "
" be 0x%08x, instead of 0x%08x \n " , access , obj_info . GrantedAccess ) ;
2007-01-25 07:43:18 +01:00
}
2007-02-07 05:55:24 +01:00
# define CHECK_SET_SECURITY(o,i,e) \
do { \
2012-08-17 16:22:01 +02:00
BOOL res_ ; \
2007-02-07 05:55:24 +01:00
DWORD err ; \
SetLastError ( 0xdeadbeef ) ; \
2012-08-17 16:22:01 +02:00
res_ = SetKernelObjectSecurity ( o , i , SecurityDescriptor ) ; \
2007-02-07 05:55:24 +01:00
err = GetLastError ( ) ; \
if ( e = = ERROR_SUCCESS ) \
2012-08-17 16:22:01 +02:00
ok ( res_ , " SetKernelObjectSecurity failed with %d \n " , err ) ; \
2007-02-07 05:55:24 +01:00
else \
2012-08-17 16:22:01 +02:00
ok ( ! res_ & & err = = e , " SetKernelObjectSecurity should have failed " \
2007-02-07 05:55:24 +01:00
" with %s, instead of %d \n " , # e , err ) ; \
} while ( 0 )
2007-01-25 07:43:18 +01:00
static void test_process_security ( void )
{
BOOL res ;
2009-01-02 08:20:54 +01:00
PTOKEN_OWNER owner ;
PTOKEN_PRIMARY_GROUP group ;
2007-01-25 07:43:18 +01:00
PSID AdminSid = NULL , UsersSid = NULL ;
PACL Acl = NULL ;
SECURITY_DESCRIPTOR * SecurityDescriptor = NULL ;
char buffer [ MAX_PATH ] ;
PROCESS_INFORMATION info ;
STARTUPINFOA startup ;
SECURITY_ATTRIBUTES psa ;
2007-02-07 05:55:24 +01:00
HANDLE token , event ;
2009-01-02 08:20:54 +01:00
DWORD size ;
2007-01-25 07:43:18 +01:00
Acl = HeapAlloc ( GetProcessHeap ( ) , 0 , 256 ) ;
res = InitializeAcl ( Acl , 256 , ACL_REVISION ) ;
if ( ! res & & GetLastError ( ) = = ERROR_CALL_NOT_IMPLEMENTED )
{
2009-02-26 09:45:07 +01:00
win_skip ( " ACLs not implemented - skipping tests \n " ) ;
2007-10-02 08:59:02 +02:00
HeapFree ( GetProcessHeap ( ) , 0 , Acl ) ;
2007-01-25 07:43:18 +01:00
return ;
}
ok ( res , " InitializeAcl failed with error %d \n " , GetLastError ( ) ) ;
2007-02-07 05:55:24 +01:00
/* get owner from the token we might be running as a user not admin */
res = OpenProcessToken ( GetCurrentProcess ( ) , MAXIMUM_ALLOWED , & token ) ;
ok ( res , " OpenProcessToken failed with error %d \n " , GetLastError ( ) ) ;
2007-10-02 08:59:02 +02:00
if ( ! res )
{
HeapFree ( GetProcessHeap ( ) , 0 , Acl ) ;
return ;
}
2007-02-07 05:55:24 +01:00
2009-01-02 08:20:54 +01:00
res = GetTokenInformation ( token , TokenOwner , NULL , 0 , & size ) ;
ok ( ! res , " Expected failure, got %d \n " , res ) ;
ok ( GetLastError ( ) = = ERROR_INSUFFICIENT_BUFFER ,
" Expected ERROR_INSUFFICIENT_BUFFER, got %d \n " , GetLastError ( ) ) ;
owner = HeapAlloc ( GetProcessHeap ( ) , 0 , size ) ;
res = GetTokenInformation ( token , TokenOwner , owner , size , & size ) ;
2007-02-07 05:55:24 +01:00
ok ( res , " GetTokenInformation failed with error %d \n " , GetLastError ( ) ) ;
AdminSid = ( ( TOKEN_OWNER * ) owner ) - > Owner ;
2009-01-02 08:20:54 +01:00
res = GetTokenInformation ( token , TokenPrimaryGroup , NULL , 0 , & size ) ;
ok ( ! res , " Expected failure, got %d \n " , res ) ;
ok ( GetLastError ( ) = = ERROR_INSUFFICIENT_BUFFER ,
" Expected ERROR_INSUFFICIENT_BUFFER, got %d \n " , GetLastError ( ) ) ;
group = HeapAlloc ( GetProcessHeap ( ) , 0 , size ) ;
res = GetTokenInformation ( token , TokenPrimaryGroup , group , size , & size ) ;
2007-02-07 05:55:24 +01:00
ok ( res , " GetTokenInformation failed with error %d \n " , GetLastError ( ) ) ;
UsersSid = ( ( TOKEN_PRIMARY_GROUP * ) group ) - > PrimaryGroup ;
CloseHandle ( token ) ;
2007-10-02 08:59:02 +02:00
if ( ! res )
{
2009-01-02 08:20:54 +01:00
HeapFree ( GetProcessHeap ( ) , 0 , group ) ;
HeapFree ( GetProcessHeap ( ) , 0 , owner ) ;
2007-10-02 08:59:02 +02:00
HeapFree ( GetProcessHeap ( ) , 0 , Acl ) ;
return ;
}
2007-01-25 07:43:18 +01:00
res = AddAccessDeniedAce ( Acl , ACL_REVISION , PROCESS_VM_READ , AdminSid ) ;
ok ( res , " AddAccessDeniedAce failed with error %d \n " , GetLastError ( ) ) ;
res = AddAccessAllowedAce ( Acl , ACL_REVISION , PROCESS_ALL_ACCESS , AdminSid ) ;
2007-11-02 11:33:36 +01:00
ok ( res , " AddAccessAllowedAce failed with error %d \n " , GetLastError ( ) ) ;
2007-01-25 07:43:18 +01:00
SecurityDescriptor = HeapAlloc ( GetProcessHeap ( ) , 0 , SECURITY_DESCRIPTOR_MIN_LENGTH ) ;
res = InitializeSecurityDescriptor ( SecurityDescriptor , SECURITY_DESCRIPTOR_REVISION ) ;
ok ( res , " InitializeSecurityDescriptor failed with error %d \n " , GetLastError ( ) ) ;
2013-10-15 10:15:45 +02:00
event = CreateEventA ( NULL , TRUE , TRUE , " test_event " ) ;
2007-02-07 05:55:24 +01:00
ok ( event ! = NULL , " CreateEvent %d \n " , GetLastError ( ) ) ;
2007-02-27 15:28:18 +01:00
SecurityDescriptor - > Revision = 0 ;
CHECK_SET_SECURITY ( event , OWNER_SECURITY_INFORMATION , ERROR_UNKNOWN_REVISION ) ;
SecurityDescriptor - > Revision = SECURITY_DESCRIPTOR_REVISION ;
2007-02-07 05:55:24 +01:00
CHECK_SET_SECURITY ( event , OWNER_SECURITY_INFORMATION , ERROR_INVALID_SECURITY_DESCR ) ;
CHECK_SET_SECURITY ( event , GROUP_SECURITY_INFORMATION , ERROR_INVALID_SECURITY_DESCR ) ;
CHECK_SET_SECURITY ( event , SACL_SECURITY_INFORMATION , ERROR_ACCESS_DENIED ) ;
CHECK_SET_SECURITY ( event , DACL_SECURITY_INFORMATION , ERROR_SUCCESS ) ;
2007-02-27 15:28:18 +01:00
/* NULL DACL is valid and means default DACL from token */
SecurityDescriptor - > Control | = SE_DACL_PRESENT ;
CHECK_SET_SECURITY ( event , DACL_SECURITY_INFORMATION , ERROR_SUCCESS ) ;
2007-02-07 05:55:24 +01:00
2007-01-25 07:43:18 +01:00
/* Set owner and group and dacl */
res = SetSecurityDescriptorOwner ( SecurityDescriptor , AdminSid , FALSE ) ;
ok ( res , " SetSecurityDescriptorOwner failed with error %d \n " , GetLastError ( ) ) ;
2007-02-07 05:55:24 +01:00
CHECK_SET_SECURITY ( event , OWNER_SECURITY_INFORMATION , ERROR_SUCCESS ) ;
res = SetSecurityDescriptorGroup ( SecurityDescriptor , UsersSid , FALSE ) ;
2007-01-25 07:43:18 +01:00
ok ( res , " SetSecurityDescriptorGroup failed with error %d \n " , GetLastError ( ) ) ;
2007-02-07 05:55:24 +01:00
CHECK_SET_SECURITY ( event , GROUP_SECURITY_INFORMATION , ERROR_SUCCESS ) ;
2007-01-25 07:43:18 +01:00
res = SetSecurityDescriptorDacl ( SecurityDescriptor , TRUE , Acl , FALSE ) ;
ok ( res , " SetSecurityDescriptorDacl failed with error %d \n " , GetLastError ( ) ) ;
2007-02-07 05:55:24 +01:00
CHECK_SET_SECURITY ( event , DACL_SECURITY_INFORMATION , ERROR_SUCCESS ) ;
2007-01-25 07:43:18 +01:00
sprintf ( buffer , " %s tests/security.c test " , myARGV [ 0 ] ) ;
memset ( & startup , 0 , sizeof ( startup ) ) ;
startup . cb = sizeof ( startup ) ;
startup . dwFlags = STARTF_USESHOWWINDOW ;
startup . wShowWindow = SW_SHOWNORMAL ;
psa . nLength = sizeof ( psa ) ;
psa . lpSecurityDescriptor = SecurityDescriptor ;
psa . bInheritHandle = TRUE ;
/* Doesn't matter what ACL say we should get full access for ourselves */
2010-12-30 19:31:54 +01:00
res = CreateProcessA ( NULL , buffer , & psa , NULL , FALSE , 0 , NULL , NULL , & startup , & info ) ;
ok ( res , " CreateProcess with err:%d \n " , GetLastError ( ) ) ;
2012-03-15 09:11:06 +01:00
TEST_GRANTED_ACCESS2 ( info . hProcess , PROCESS_ALL_ACCESS_NT4 ,
2008-08-29 04:10:51 +02:00
STANDARD_RIGHTS_ALL | SPECIFIC_RIGHTS_ALL ) ;
2008-02-07 12:56:00 +01:00
winetest_wait_child_process ( info . hProcess ) ;
2007-01-25 07:43:18 +01:00
2008-02-07 12:56:00 +01:00
CloseHandle ( info . hProcess ) ;
CloseHandle ( info . hThread ) ;
2007-02-07 05:55:24 +01:00
CloseHandle ( event ) ;
2009-01-02 08:20:54 +01:00
HeapFree ( GetProcessHeap ( ) , 0 , group ) ;
HeapFree ( GetProcessHeap ( ) , 0 , owner ) ;
2007-01-25 07:43:18 +01:00
HeapFree ( GetProcessHeap ( ) , 0 , Acl ) ;
HeapFree ( GetProcessHeap ( ) , 0 , SecurityDescriptor ) ;
}
static void test_process_security_child ( void )
{
HANDLE handle , handle1 ;
2007-02-07 05:55:24 +01:00
BOOL ret ;
DWORD err ;
2007-01-25 07:43:18 +01:00
handle = OpenProcess ( PROCESS_TERMINATE , FALSE , GetCurrentProcessId ( ) ) ;
ok ( handle ! = NULL , " OpenProcess(PROCESS_TERMINATE) with err:%d \n " , GetLastError ( ) ) ;
TEST_GRANTED_ACCESS ( handle , PROCESS_TERMINATE ) ;
2011-01-02 18:48:08 +01:00
ret = DuplicateHandle ( GetCurrentProcess ( ) , handle , GetCurrentProcess ( ) ,
& handle1 , 0 , TRUE , DUPLICATE_SAME_ACCESS ) ;
ok ( ret , " duplicating handle err:%d \n " , GetLastError ( ) ) ;
2007-02-07 05:55:24 +01:00
TEST_GRANTED_ACCESS ( handle1 , PROCESS_TERMINATE ) ;
2007-01-25 07:43:18 +01:00
CloseHandle ( handle1 ) ;
2007-02-07 05:55:24 +01:00
SetLastError ( 0xdeadbeef ) ;
ret = DuplicateHandle ( GetCurrentProcess ( ) , handle , GetCurrentProcess ( ) ,
& handle1 , PROCESS_ALL_ACCESS , TRUE , 0 ) ;
err = GetLastError ( ) ;
todo_wine
ok ( ! ret & & err = = ERROR_ACCESS_DENIED , " duplicating handle should have failed "
" with STATUS_ACCESS_DENIED, instead of err:%d \n " , err ) ;
2007-01-25 07:43:18 +01:00
CloseHandle ( handle ) ;
/* These two should fail - they are denied by ACL */
handle = OpenProcess ( PROCESS_VM_READ , FALSE , GetCurrentProcessId ( ) ) ;
todo_wine
ok ( handle = = NULL , " OpenProcess(PROCESS_VM_READ) should have failed \n " ) ;
handle = OpenProcess ( PROCESS_ALL_ACCESS , FALSE , GetCurrentProcessId ( ) ) ;
todo_wine
ok ( handle = = NULL , " OpenProcess(PROCESS_ALL_ACCESS) should have failed \n " ) ;
/* Documented privilege elevation */
2011-01-02 18:48:08 +01:00
ret = DuplicateHandle ( GetCurrentProcess ( ) , GetCurrentProcess ( ) , GetCurrentProcess ( ) ,
& handle , 0 , TRUE , DUPLICATE_SAME_ACCESS ) ;
ok ( ret , " duplicating handle err:%d \n " , GetLastError ( ) ) ;
2012-03-15 09:11:06 +01:00
TEST_GRANTED_ACCESS2 ( handle , PROCESS_ALL_ACCESS_NT4 ,
2008-08-29 04:10:51 +02:00
STANDARD_RIGHTS_ALL | SPECIFIC_RIGHTS_ALL ) ;
2007-01-25 07:43:18 +01:00
CloseHandle ( handle ) ;
2007-02-07 05:55:24 +01:00
/* Same only explicitly asking for all access rights */
2011-01-02 18:48:08 +01:00
ret = DuplicateHandle ( GetCurrentProcess ( ) , GetCurrentProcess ( ) , GetCurrentProcess ( ) ,
& handle , PROCESS_ALL_ACCESS , TRUE , 0 ) ;
ok ( ret , " duplicating handle err:%d \n " , GetLastError ( ) ) ;
2012-03-15 09:11:06 +01:00
TEST_GRANTED_ACCESS2 ( handle , PROCESS_ALL_ACCESS_NT4 ,
2008-09-02 07:52:33 +02:00
PROCESS_ALL_ACCESS | PROCESS_QUERY_LIMITED_INFORMATION ) ;
2011-01-02 18:48:08 +01:00
ret = DuplicateHandle ( GetCurrentProcess ( ) , handle , GetCurrentProcess ( ) ,
& handle1 , PROCESS_VM_READ , TRUE , 0 ) ;
ok ( ret , " duplicating handle err:%d \n " , GetLastError ( ) ) ;
2007-02-07 05:55:24 +01:00
TEST_GRANTED_ACCESS ( handle1 , PROCESS_VM_READ ) ;
CloseHandle ( handle1 ) ;
CloseHandle ( handle ) ;
2007-01-25 07:43:18 +01:00
}
2007-02-15 17:25:58 +01:00
static void test_impersonation_level ( void )
{
HANDLE Token , ProcessToken ;
HANDLE Token2 ;
DWORD Size ;
TOKEN_PRIVILEGES * Privileges ;
TOKEN_USER * User ;
PRIVILEGE_SET * PrivilegeSet ;
BOOL AccessGranted ;
BOOL ret ;
HKEY hkey ;
DWORD error ;
2010-10-01 13:33:37 +02:00
pDuplicateTokenEx = ( void * ) GetProcAddress ( hmod , " DuplicateTokenEx " ) ;
2007-03-16 22:37:14 +01:00
if ( ! pDuplicateTokenEx ) {
2009-02-26 09:45:07 +01:00
win_skip ( " DuplicateTokenEx is not available \n " ) ;
2007-03-16 22:37:14 +01:00
return ;
}
2007-03-29 21:19:32 +02:00
SetLastError ( 0xdeadbeef ) ;
2007-02-15 17:25:58 +01:00
ret = ImpersonateSelf ( SecurityAnonymous ) ;
2007-03-29 21:19:32 +02:00
if ( ! ret & & ( GetLastError ( ) = = ERROR_CALL_NOT_IMPLEMENTED ) )
{
2009-02-26 09:45:07 +01:00
win_skip ( " ImpersonateSelf is not implemented \n " ) ;
2007-03-29 21:19:32 +02:00
return ;
}
2007-02-15 17:25:58 +01:00
ok ( ret , " ImpersonateSelf(SecurityAnonymous) failed with error %d \n " , GetLastError ( ) ) ;
ret = OpenThreadToken ( GetCurrentThread ( ) , TOKEN_QUERY | TOKEN_ADJUST_PRIVILEGES | TOKEN_QUERY_SOURCE | TOKEN_IMPERSONATE | TOKEN_ADJUST_DEFAULT , TRUE , & Token ) ;
ok ( ! ret , " OpenThreadToken should have failed \n " ) ;
error = GetLastError ( ) ;
ok ( error = = ERROR_CANT_OPEN_ANONYMOUS , " OpenThreadToken on anonymous token should have returned ERROR_CANT_OPEN_ANONYMOUS instead of %d \n " , error ) ;
/* can't perform access check when opening object against an anonymous impersonation token */
2007-02-16 00:21:40 +01:00
todo_wine {
2013-10-15 10:15:45 +02:00
error = RegOpenKeyExA ( HKEY_CURRENT_USER , " Software " , 0 , KEY_READ , & hkey ) ;
2009-08-26 12:40:29 +02:00
ok ( error = = ERROR_INVALID_HANDLE | | error = = ERROR_CANT_OPEN_ANONYMOUS ,
" RegOpenKeyEx should have failed with ERROR_INVALID_HANDLE or ERROR_CANT_OPEN_ANONYMOUS instead of %d \n " , error ) ;
2007-02-15 17:25:58 +01:00
}
RevertToSelf ( ) ;
ret = OpenProcessToken ( GetCurrentProcess ( ) , TOKEN_DUPLICATE , & ProcessToken ) ;
ok ( ret , " OpenProcessToken failed with error %d \n " , GetLastError ( ) ) ;
2007-03-16 22:37:14 +01:00
ret = pDuplicateTokenEx ( ProcessToken ,
2007-02-15 17:25:58 +01:00
TOKEN_QUERY | TOKEN_DUPLICATE | TOKEN_IMPERSONATE , NULL ,
SecurityAnonymous , TokenImpersonation , & Token ) ;
ok ( ret , " DuplicateTokenEx failed with error %d \n " , GetLastError ( ) ) ;
/* can't increase the impersonation level */
ret = DuplicateToken ( Token , SecurityIdentification , & Token2 ) ;
error = GetLastError ( ) ;
ok ( ! ret & & error = = ERROR_BAD_IMPERSONATION_LEVEL ,
" Duplicating a token and increasing the impersonation level should have failed with ERROR_BAD_IMPERSONATION_LEVEL instead of %d \n " , error ) ;
/* we can query anything from an anonymous token, including the user */
ret = GetTokenInformation ( Token , TokenUser , NULL , 0 , & Size ) ;
error = GetLastError ( ) ;
ok ( ! ret & & error = = ERROR_INSUFFICIENT_BUFFER , " GetTokenInformation(TokenUser) should have failed with ERROR_INSUFFICIENT_BUFFER instead of %d \n " , error ) ;
2008-10-15 23:17:24 +02:00
User = HeapAlloc ( GetProcessHeap ( ) , 0 , Size ) ;
2007-02-15 17:25:58 +01:00
ret = GetTokenInformation ( Token , TokenUser , User , Size , & Size ) ;
ok ( ret , " GetTokenInformation(TokenUser) failed with error %d \n " , GetLastError ( ) ) ;
HeapFree ( GetProcessHeap ( ) , 0 , User ) ;
/* PrivilegeCheck fails with SecurityAnonymous level */
ret = GetTokenInformation ( Token , TokenPrivileges , NULL , 0 , & Size ) ;
error = GetLastError ( ) ;
ok ( ! ret & & error = = ERROR_INSUFFICIENT_BUFFER , " GetTokenInformation(TokenPrivileges) should have failed with ERROR_INSUFFICIENT_BUFFER instead of %d \n " , error ) ;
2008-10-15 23:17:24 +02:00
Privileges = HeapAlloc ( GetProcessHeap ( ) , 0 , Size ) ;
2007-02-15 17:25:58 +01:00
ret = GetTokenInformation ( Token , TokenPrivileges , Privileges , Size , & Size ) ;
ok ( ret , " GetTokenInformation(TokenPrivileges) failed with error %d \n " , GetLastError ( ) ) ;
2008-10-15 23:17:24 +02:00
PrivilegeSet = HeapAlloc ( GetProcessHeap ( ) , 0 , FIELD_OFFSET ( PRIVILEGE_SET , Privilege [ Privileges - > PrivilegeCount ] ) ) ;
2007-02-15 17:25:58 +01:00
PrivilegeSet - > PrivilegeCount = Privileges - > PrivilegeCount ;
memcpy ( PrivilegeSet - > Privilege , Privileges - > Privileges , PrivilegeSet - > PrivilegeCount * sizeof ( PrivilegeSet - > Privilege [ 0 ] ) ) ;
PrivilegeSet - > Control = PRIVILEGE_SET_ALL_NECESSARY ;
HeapFree ( GetProcessHeap ( ) , 0 , Privileges ) ;
ret = PrivilegeCheck ( Token , PrivilegeSet , & AccessGranted ) ;
error = GetLastError ( ) ;
ok ( ! ret & & error = = ERROR_BAD_IMPERSONATION_LEVEL , " PrivilegeCheck for SecurityAnonymous token should have failed with ERROR_BAD_IMPERSONATION_LEVEL instead of %d \n " , error ) ;
CloseHandle ( Token ) ;
ret = ImpersonateSelf ( SecurityIdentification ) ;
ok ( ret , " ImpersonateSelf(SecurityIdentification) failed with error %d \n " , GetLastError ( ) ) ;
ret = OpenThreadToken ( GetCurrentThread ( ) , TOKEN_QUERY | TOKEN_ADJUST_PRIVILEGES | TOKEN_QUERY_SOURCE | TOKEN_IMPERSONATE | TOKEN_ADJUST_DEFAULT , TRUE , & Token ) ;
ok ( ret , " OpenThreadToken failed with error %d \n " , GetLastError ( ) ) ;
/* can't perform access check when opening object against an identification impersonation token */
2013-10-15 10:15:45 +02:00
error = RegOpenKeyExA ( HKEY_CURRENT_USER , " Software " , 0 , KEY_READ , & hkey ) ;
2007-02-15 17:25:58 +01:00
todo_wine {
2009-08-26 12:40:29 +02:00
ok ( error = = ERROR_INVALID_HANDLE | | error = = ERROR_BAD_IMPERSONATION_LEVEL ,
" RegOpenKeyEx should have failed with ERROR_INVALID_HANDLE or ERROR_BAD_IMPERSONATION_LEVEL instead of %d \n " , error ) ;
2007-02-15 17:25:58 +01:00
}
ret = PrivilegeCheck ( Token , PrivilegeSet , & AccessGranted ) ;
ok ( ret , " PrivilegeCheck for SecurityIdentification failed with error %d \n " , GetLastError ( ) ) ;
CloseHandle ( Token ) ;
RevertToSelf ( ) ;
ret = ImpersonateSelf ( SecurityImpersonation ) ;
ok ( ret , " ImpersonateSelf(SecurityImpersonation) failed with error %d \n " , GetLastError ( ) ) ;
ret = OpenThreadToken ( GetCurrentThread ( ) , TOKEN_QUERY | TOKEN_ADJUST_PRIVILEGES | TOKEN_QUERY_SOURCE | TOKEN_IMPERSONATE | TOKEN_ADJUST_DEFAULT , TRUE , & Token ) ;
ok ( ret , " OpenThreadToken failed with error %d \n " , GetLastError ( ) ) ;
2013-10-15 10:15:45 +02:00
error = RegOpenKeyExA ( HKEY_CURRENT_USER , " Software " , 0 , KEY_READ , & hkey ) ;
2007-02-15 17:25:58 +01:00
ok ( error = = ERROR_SUCCESS , " RegOpenKeyEx should have succeeded instead of failing with %d \n " , error ) ;
RegCloseKey ( hkey ) ;
ret = PrivilegeCheck ( Token , PrivilegeSet , & AccessGranted ) ;
ok ( ret , " PrivilegeCheck for SecurityImpersonation failed with error %d \n " , GetLastError ( ) ) ;
RevertToSelf ( ) ;
CloseHandle ( Token ) ;
CloseHandle ( ProcessToken ) ;
HeapFree ( GetProcessHeap ( ) , 0 , PrivilegeSet ) ;
}
2011-01-01 21:19:55 +01:00
static void test_SetEntriesInAclW ( void )
2007-03-19 15:05:52 +01:00
{
DWORD res ;
2008-01-22 16:36:04 +01:00
PSID EveryoneSid = NULL , UsersSid = NULL ;
PACL OldAcl = NULL , NewAcl ;
SID_IDENTIFIER_AUTHORITY SIDAuthWorld = { SECURITY_WORLD_SID_AUTHORITY } ;
SID_IDENTIFIER_AUTHORITY SIDAuthNT = { SECURITY_NT_AUTHORITY } ;
EXPLICIT_ACCESSW ExplicitAccess ;
static const WCHAR wszEveryone [ ] = { ' E ' , ' v ' , ' e ' , ' r ' , ' y ' , ' o ' , ' n ' , ' e ' , 0 } ;
2009-08-16 12:36:56 +02:00
static const WCHAR wszCurrentUser [ ] = { ' C ' , ' U ' , ' R ' , ' R ' , ' E ' , ' N ' , ' T ' , ' _ ' , ' U ' , ' S ' , ' E ' , ' R ' , ' \0 ' } ;
2007-03-19 15:05:52 +01:00
2007-08-14 11:05:04 +02:00
if ( ! pSetEntriesInAclW )
{
2008-11-29 12:38:30 +01:00
win_skip ( " SetEntriesInAclW is not available \n " ) ;
2007-08-14 11:05:04 +02:00
return ;
}
2008-01-22 16:36:04 +01:00
NewAcl = ( PACL ) 0xdeadbeef ;
res = pSetEntriesInAclW ( 0 , NULL , NULL , & NewAcl ) ;
2007-03-29 21:33:11 +02:00
if ( res = = ERROR_CALL_NOT_IMPLEMENTED )
{
2008-11-29 12:38:30 +01:00
win_skip ( " SetEntriesInAclW is not implemented \n " ) ;
2007-03-29 21:33:11 +02:00
return ;
}
ok ( res = = ERROR_SUCCESS , " SetEntriesInAclW failed: %u \n " , res ) ;
2008-12-06 12:43:55 +01:00
ok ( NewAcl = = NULL | |
broken ( NewAcl ! = NULL ) , /* NT4 */
" NewAcl=%p, expected NULL \n " , NewAcl ) ;
LocalFree ( NewAcl ) ;
2008-01-22 16:36:04 +01:00
OldAcl = HeapAlloc ( GetProcessHeap ( ) , 0 , 256 ) ;
res = InitializeAcl ( OldAcl , 256 , ACL_REVISION ) ;
if ( ! res & & GetLastError ( ) = = ERROR_CALL_NOT_IMPLEMENTED )
{
2008-11-29 12:38:30 +01:00
win_skip ( " ACLs not implemented - skipping tests \n " ) ;
2008-01-22 16:36:04 +01:00
HeapFree ( GetProcessHeap ( ) , 0 , OldAcl ) ;
return ;
}
ok ( res , " InitializeAcl failed with error %d \n " , GetLastError ( ) ) ;
res = AllocateAndInitializeSid ( & SIDAuthWorld , 1 , SECURITY_WORLD_RID , 0 , 0 , 0 , 0 , 0 , 0 , 0 , & EveryoneSid ) ;
ok ( res , " AllocateAndInitializeSid failed with error %d \n " , GetLastError ( ) ) ;
res = AllocateAndInitializeSid ( & SIDAuthNT , 2 , SECURITY_BUILTIN_DOMAIN_RID ,
DOMAIN_ALIAS_RID_USERS , 0 , 0 , 0 , 0 , 0 , 0 , & UsersSid ) ;
ok ( res , " AllocateAndInitializeSid failed with error %d \n " , GetLastError ( ) ) ;
res = AddAccessAllowedAce ( OldAcl , ACL_REVISION , KEY_READ , UsersSid ) ;
ok ( res , " AddAccessAllowedAce failed with error %d \n " , GetLastError ( ) ) ;
ExplicitAccess . grfAccessPermissions = KEY_WRITE ;
ExplicitAccess . grfAccessMode = GRANT_ACCESS ;
ExplicitAccess . grfInheritance = NO_INHERITANCE ;
2009-10-10 15:52:09 +02:00
ExplicitAccess . Trustee . TrusteeType = TRUSTEE_IS_WELL_KNOWN_GROUP ;
2008-01-22 16:36:04 +01:00
ExplicitAccess . Trustee . TrusteeForm = TRUSTEE_IS_SID ;
2009-01-13 10:57:53 +01:00
ExplicitAccess . Trustee . ptstrName = EveryoneSid ;
2009-10-10 15:52:09 +02:00
ExplicitAccess . Trustee . MultipleTrusteeOperation = 0xDEADBEEF ;
ExplicitAccess . Trustee . pMultipleTrustee = ( PVOID ) 0xDEADBEEF ;
res = pSetEntriesInAclW ( 1 , & ExplicitAccess , OldAcl , & NewAcl ) ;
ok ( res = = ERROR_SUCCESS , " SetEntriesInAclW failed: %u \n " , res ) ;
ok ( NewAcl ! = NULL , " returned acl was NULL \n " ) ;
LocalFree ( NewAcl ) ;
ExplicitAccess . Trustee . TrusteeType = TRUSTEE_IS_UNKNOWN ;
ExplicitAccess . Trustee . pMultipleTrustee = NULL ;
ExplicitAccess . Trustee . MultipleTrusteeOperation = NO_MULTIPLE_TRUSTEE ;
2008-01-22 16:36:04 +01:00
res = pSetEntriesInAclW ( 1 , & ExplicitAccess , OldAcl , & NewAcl ) ;
ok ( res = = ERROR_SUCCESS , " SetEntriesInAclW failed: %u \n " , res ) ;
ok ( NewAcl ! = NULL , " returned acl was NULL \n " ) ;
LocalFree ( NewAcl ) ;
2011-03-16 11:45:34 +01:00
if ( PRIMARYLANGID ( GetSystemDefaultLangID ( ) ) ! = LANG_ENGLISH )
2008-02-16 14:11:57 +01:00
{
2011-08-03 23:50:18 +02:00
skip ( " Non-English locale (test with hardcoded 'Everyone') \n " ) ;
2008-02-16 14:11:57 +01:00
}
else
{
2011-05-18 14:17:58 +02:00
ExplicitAccess . Trustee . TrusteeForm = TRUSTEE_IS_NAME ;
2008-02-16 14:11:57 +01:00
ExplicitAccess . Trustee . ptstrName = ( LPWSTR ) wszEveryone ;
res = pSetEntriesInAclW ( 1 , & ExplicitAccess , OldAcl , & NewAcl ) ;
ok ( res = = ERROR_SUCCESS , " SetEntriesInAclW failed: %u \n " , res ) ;
ok ( NewAcl ! = NULL , " returned acl was NULL \n " ) ;
LocalFree ( NewAcl ) ;
ExplicitAccess . Trustee . TrusteeForm = TRUSTEE_BAD_FORM ;
res = pSetEntriesInAclW ( 1 , & ExplicitAccess , OldAcl , & NewAcl ) ;
2008-12-06 12:43:55 +01:00
ok ( res = = ERROR_INVALID_PARAMETER | |
broken ( res = = ERROR_NOT_SUPPORTED ) , /* NT4 */
" SetEntriesInAclW failed: %u \n " , res ) ;
2008-11-29 12:38:30 +01:00
ok ( NewAcl = = NULL | |
broken ( NewAcl ! = NULL ) , /* NT4 */
" returned acl wasn't NULL: %p \n " , NewAcl ) ;
2008-02-16 14:11:57 +01:00
2011-05-18 14:17:58 +02:00
ExplicitAccess . Trustee . TrusteeForm = TRUSTEE_IS_NAME ;
2008-02-16 14:11:57 +01:00
ExplicitAccess . Trustee . MultipleTrusteeOperation = TRUSTEE_IS_IMPERSONATE ;
res = pSetEntriesInAclW ( 1 , & ExplicitAccess , OldAcl , & NewAcl ) ;
2008-12-06 12:43:55 +01:00
ok ( res = = ERROR_INVALID_PARAMETER | |
broken ( res = = ERROR_NOT_SUPPORTED ) , /* NT4 */
" SetEntriesInAclW failed: %u \n " , res ) ;
2008-11-29 12:38:30 +01:00
ok ( NewAcl = = NULL | |
broken ( NewAcl ! = NULL ) , /* NT4 */
" returned acl wasn't NULL: %p \n " , NewAcl ) ;
2008-02-16 14:11:57 +01:00
ExplicitAccess . Trustee . MultipleTrusteeOperation = NO_MULTIPLE_TRUSTEE ;
ExplicitAccess . grfAccessMode = SET_ACCESS ;
res = pSetEntriesInAclW ( 1 , & ExplicitAccess , OldAcl , & NewAcl ) ;
ok ( res = = ERROR_SUCCESS , " SetEntriesInAclW failed: %u \n " , res ) ;
ok ( NewAcl ! = NULL , " returned acl was NULL \n " ) ;
LocalFree ( NewAcl ) ;
}
2008-01-22 16:36:04 +01:00
2011-05-18 14:17:58 +02:00
ExplicitAccess . Trustee . TrusteeForm = TRUSTEE_IS_NAME ;
2009-08-16 12:36:56 +02:00
ExplicitAccess . Trustee . ptstrName = ( LPWSTR ) wszCurrentUser ;
res = pSetEntriesInAclW ( 1 , & ExplicitAccess , OldAcl , & NewAcl ) ;
ok ( res = = ERROR_SUCCESS , " SetEntriesInAclW failed: %u \n " , res ) ;
ok ( NewAcl ! = NULL , " returned acl was NULL \n " ) ;
LocalFree ( NewAcl ) ;
2008-01-22 16:36:04 +01:00
ExplicitAccess . grfAccessMode = REVOKE_ACCESS ;
ExplicitAccess . Trustee . TrusteeForm = TRUSTEE_IS_SID ;
2009-01-13 10:57:53 +01:00
ExplicitAccess . Trustee . ptstrName = UsersSid ;
2008-01-22 16:36:04 +01:00
res = pSetEntriesInAclW ( 1 , & ExplicitAccess , OldAcl , & NewAcl ) ;
ok ( res = = ERROR_SUCCESS , " SetEntriesInAclW failed: %u \n " , res ) ;
ok ( NewAcl ! = NULL , " returned acl was NULL \n " ) ;
LocalFree ( NewAcl ) ;
2010-01-07 03:26:39 +01:00
FreeSid ( UsersSid ) ;
FreeSid ( EveryoneSid ) ;
2008-01-22 16:36:04 +01:00
HeapFree ( GetProcessHeap ( ) , 0 , OldAcl ) ;
2007-03-19 15:05:52 +01:00
}
2011-01-01 21:19:55 +01:00
static void test_SetEntriesInAclA ( void )
{
DWORD res ;
PSID EveryoneSid = NULL , UsersSid = NULL ;
PACL OldAcl = NULL , NewAcl ;
SID_IDENTIFIER_AUTHORITY SIDAuthWorld = { SECURITY_WORLD_SID_AUTHORITY } ;
SID_IDENTIFIER_AUTHORITY SIDAuthNT = { SECURITY_NT_AUTHORITY } ;
2013-10-15 10:15:45 +02:00
EXPLICIT_ACCESSA ExplicitAccess ;
2011-01-01 21:19:55 +01:00
static const CHAR szEveryone [ ] = { ' E ' , ' v ' , ' e ' , ' r ' , ' y ' , ' o ' , ' n ' , ' e ' , 0 } ;
static const CHAR szCurrentUser [ ] = { ' C ' , ' U ' , ' R ' , ' R ' , ' E ' , ' N ' , ' T ' , ' _ ' , ' U ' , ' S ' , ' E ' , ' R ' , ' \0 ' } ;
if ( ! pSetEntriesInAclA )
{
win_skip ( " SetEntriesInAclA is not available \n " ) ;
return ;
}
NewAcl = ( PACL ) 0xdeadbeef ;
res = pSetEntriesInAclA ( 0 , NULL , NULL , & NewAcl ) ;
if ( res = = ERROR_CALL_NOT_IMPLEMENTED )
{
win_skip ( " SetEntriesInAclA is not implemented \n " ) ;
return ;
}
ok ( res = = ERROR_SUCCESS , " SetEntriesInAclA failed: %u \n " , res ) ;
ok ( NewAcl = = NULL | |
broken ( NewAcl ! = NULL ) , /* NT4 */
" NewAcl=%p, expected NULL \n " , NewAcl ) ;
LocalFree ( NewAcl ) ;
OldAcl = HeapAlloc ( GetProcessHeap ( ) , 0 , 256 ) ;
res = InitializeAcl ( OldAcl , 256 , ACL_REVISION ) ;
if ( ! res & & GetLastError ( ) = = ERROR_CALL_NOT_IMPLEMENTED )
{
win_skip ( " ACLs not implemented - skipping tests \n " ) ;
HeapFree ( GetProcessHeap ( ) , 0 , OldAcl ) ;
return ;
}
ok ( res , " InitializeAcl failed with error %d \n " , GetLastError ( ) ) ;
res = AllocateAndInitializeSid ( & SIDAuthWorld , 1 , SECURITY_WORLD_RID , 0 , 0 , 0 , 0 , 0 , 0 , 0 , & EveryoneSid ) ;
ok ( res , " AllocateAndInitializeSid failed with error %d \n " , GetLastError ( ) ) ;
res = AllocateAndInitializeSid ( & SIDAuthNT , 2 , SECURITY_BUILTIN_DOMAIN_RID ,
DOMAIN_ALIAS_RID_USERS , 0 , 0 , 0 , 0 , 0 , 0 , & UsersSid ) ;
ok ( res , " AllocateAndInitializeSid failed with error %d \n " , GetLastError ( ) ) ;
res = AddAccessAllowedAce ( OldAcl , ACL_REVISION , KEY_READ , UsersSid ) ;
ok ( res , " AddAccessAllowedAce failed with error %d \n " , GetLastError ( ) ) ;
ExplicitAccess . grfAccessPermissions = KEY_WRITE ;
ExplicitAccess . grfAccessMode = GRANT_ACCESS ;
ExplicitAccess . grfInheritance = NO_INHERITANCE ;
ExplicitAccess . Trustee . TrusteeType = TRUSTEE_IS_WELL_KNOWN_GROUP ;
ExplicitAccess . Trustee . TrusteeForm = TRUSTEE_IS_SID ;
ExplicitAccess . Trustee . ptstrName = EveryoneSid ;
2011-09-09 11:31:02 +02:00
ExplicitAccess . Trustee . MultipleTrusteeOperation = NO_MULTIPLE_TRUSTEE ;
ExplicitAccess . Trustee . pMultipleTrustee = NULL ;
2011-01-01 21:19:55 +01:00
res = pSetEntriesInAclA ( 1 , & ExplicitAccess , OldAcl , & NewAcl ) ;
ok ( res = = ERROR_SUCCESS , " SetEntriesInAclA failed: %u \n " , res ) ;
ok ( NewAcl ! = NULL , " returned acl was NULL \n " ) ;
LocalFree ( NewAcl ) ;
ExplicitAccess . Trustee . TrusteeType = TRUSTEE_IS_UNKNOWN ;
ExplicitAccess . Trustee . pMultipleTrustee = NULL ;
ExplicitAccess . Trustee . MultipleTrusteeOperation = NO_MULTIPLE_TRUSTEE ;
res = pSetEntriesInAclA ( 1 , & ExplicitAccess , OldAcl , & NewAcl ) ;
ok ( res = = ERROR_SUCCESS , " SetEntriesInAclA failed: %u \n " , res ) ;
ok ( NewAcl ! = NULL , " returned acl was NULL \n " ) ;
LocalFree ( NewAcl ) ;
2011-03-16 11:45:34 +01:00
if ( PRIMARYLANGID ( GetSystemDefaultLangID ( ) ) ! = LANG_ENGLISH )
2011-01-01 21:19:55 +01:00
{
2011-08-03 23:50:18 +02:00
skip ( " Non-English locale (test with hardcoded 'Everyone') \n " ) ;
2011-01-01 21:19:55 +01:00
}
else
{
2011-05-18 14:17:58 +02:00
ExplicitAccess . Trustee . TrusteeForm = TRUSTEE_IS_NAME ;
2011-01-01 21:19:55 +01:00
ExplicitAccess . Trustee . ptstrName = ( LPSTR ) szEveryone ;
res = pSetEntriesInAclA ( 1 , & ExplicitAccess , OldAcl , & NewAcl ) ;
ok ( res = = ERROR_SUCCESS , " SetEntriesInAclA failed: %u \n " , res ) ;
ok ( NewAcl ! = NULL , " returned acl was NULL \n " ) ;
LocalFree ( NewAcl ) ;
ExplicitAccess . Trustee . TrusteeForm = TRUSTEE_BAD_FORM ;
res = pSetEntriesInAclA ( 1 , & ExplicitAccess , OldAcl , & NewAcl ) ;
ok ( res = = ERROR_INVALID_PARAMETER | |
broken ( res = = ERROR_NOT_SUPPORTED ) , /* NT4 */
" SetEntriesInAclA failed: %u \n " , res ) ;
ok ( NewAcl = = NULL | |
broken ( NewAcl ! = NULL ) , /* NT4 */
" returned acl wasn't NULL: %p \n " , NewAcl ) ;
2011-05-18 14:17:58 +02:00
ExplicitAccess . Trustee . TrusteeForm = TRUSTEE_IS_NAME ;
2011-01-01 21:19:55 +01:00
ExplicitAccess . Trustee . MultipleTrusteeOperation = TRUSTEE_IS_IMPERSONATE ;
res = pSetEntriesInAclA ( 1 , & ExplicitAccess , OldAcl , & NewAcl ) ;
ok ( res = = ERROR_INVALID_PARAMETER | |
broken ( res = = ERROR_NOT_SUPPORTED ) , /* NT4 */
" SetEntriesInAclA failed: %u \n " , res ) ;
ok ( NewAcl = = NULL | |
broken ( NewAcl ! = NULL ) , /* NT4 */
" returned acl wasn't NULL: %p \n " , NewAcl ) ;
ExplicitAccess . Trustee . MultipleTrusteeOperation = NO_MULTIPLE_TRUSTEE ;
ExplicitAccess . grfAccessMode = SET_ACCESS ;
res = pSetEntriesInAclA ( 1 , & ExplicitAccess , OldAcl , & NewAcl ) ;
ok ( res = = ERROR_SUCCESS , " SetEntriesInAclA failed: %u \n " , res ) ;
ok ( NewAcl ! = NULL , " returned acl was NULL \n " ) ;
LocalFree ( NewAcl ) ;
}
2011-05-18 14:17:58 +02:00
ExplicitAccess . Trustee . TrusteeForm = TRUSTEE_IS_NAME ;
2011-01-01 21:19:55 +01:00
ExplicitAccess . Trustee . ptstrName = ( LPSTR ) szCurrentUser ;
res = pSetEntriesInAclA ( 1 , & ExplicitAccess , OldAcl , & NewAcl ) ;
ok ( res = = ERROR_SUCCESS , " SetEntriesInAclA failed: %u \n " , res ) ;
ok ( NewAcl ! = NULL , " returned acl was NULL \n " ) ;
LocalFree ( NewAcl ) ;
ExplicitAccess . grfAccessMode = REVOKE_ACCESS ;
ExplicitAccess . Trustee . TrusteeForm = TRUSTEE_IS_SID ;
ExplicitAccess . Trustee . ptstrName = UsersSid ;
res = pSetEntriesInAclA ( 1 , & ExplicitAccess , OldAcl , & NewAcl ) ;
ok ( res = = ERROR_SUCCESS , " SetEntriesInAclA failed: %u \n " , res ) ;
ok ( NewAcl ! = NULL , " returned acl was NULL \n " ) ;
LocalFree ( NewAcl ) ;
FreeSid ( UsersSid ) ;
FreeSid ( EveryoneSid ) ;
HeapFree ( GetProcessHeap ( ) , 0 , OldAcl ) ;
}
2013-11-08 20:01:49 +01:00
static void test_CreateDirectoryA ( void )
{
char admin_ptr [ sizeof ( SID ) + sizeof ( ULONG ) * SID_MAX_SUB_AUTHORITIES ] , * user ;
DWORD sid_size = sizeof ( admin_ptr ) , user_size ;
PSID admin_sid = ( PSID ) admin_ptr , user_sid ;
char sd [ SECURITY_DESCRIPTOR_MIN_LENGTH ] ;
PSECURITY_DESCRIPTOR pSD = & sd ;
ACL_SIZE_INFORMATION acl_size ;
ACCESS_ALLOWED_ACE * ace ;
SECURITY_ATTRIBUTES sa ;
char tmpdir [ MAX_PATH ] ;
struct _SID * owner ;
BOOL bret = TRUE ;
HANDLE token ;
DWORD error ;
PACL pDacl ;
if ( ! pGetNamedSecurityInfoA | | ! pCreateWellKnownSid )
{
win_skip ( " Required functions are not available \n " ) ;
return ;
}
if ( ! OpenThreadToken ( GetCurrentThread ( ) , TOKEN_READ , TRUE , & token ) )
{
if ( GetLastError ( ) ! = ERROR_NO_TOKEN ) bret = FALSE ;
else if ( ! OpenProcessToken ( GetCurrentProcess ( ) , TOKEN_READ , & token ) ) bret = FALSE ;
}
if ( ! bret )
{
win_skip ( " Failed to get current user token \n " ) ;
return ;
}
bret = GetTokenInformation ( token , TokenUser , NULL , 0 , & user_size ) ;
ok ( ! bret & & ( GetLastError ( ) = = ERROR_INSUFFICIENT_BUFFER ) ,
" GetTokenInformation(TokenUser) failed with error %d \n " , GetLastError ( ) ) ;
user = HeapAlloc ( GetProcessHeap ( ) , 0 , user_size ) ;
bret = GetTokenInformation ( token , TokenUser , user , user_size , & user_size ) ;
ok ( bret , " GetTokenInformation(TokenUser) failed with error %d \n " , GetLastError ( ) ) ;
CloseHandle ( token ) ;
user_sid = ( ( TOKEN_USER * ) user ) - > User . Sid ;
sa . nLength = sizeof ( sa ) ;
sa . lpSecurityDescriptor = pSD ;
sa . bInheritHandle = TRUE ;
InitializeSecurityDescriptor ( pSD , SECURITY_DESCRIPTOR_REVISION ) ;
pCreateWellKnownSid ( WinBuiltinAdministratorsSid , NULL , admin_sid , & sid_size ) ;
pDacl = HeapAlloc ( GetProcessHeap ( ) , 0 , 100 ) ;
bret = InitializeAcl ( pDacl , 100 , ACL_REVISION ) ;
ok ( bret , " Failed to initialize ACL. \n " ) ;
bret = pAddAccessAllowedAceEx ( pDacl , ACL_REVISION , OBJECT_INHERIT_ACE | CONTAINER_INHERIT_ACE ,
GENERIC_ALL , user_sid ) ;
ok ( bret , " Failed to add Current User to ACL. \n " ) ;
bret = pAddAccessAllowedAceEx ( pDacl , ACL_REVISION , OBJECT_INHERIT_ACE | CONTAINER_INHERIT_ACE ,
GENERIC_ALL , admin_sid ) ;
ok ( bret , " Failed to add Administrator Group to ACL. \n " ) ;
bret = SetSecurityDescriptorDacl ( pSD , TRUE , pDacl , FALSE ) ;
ok ( bret , " Failed to add ACL to security desciptor. \n " ) ;
GetTempPathA ( MAX_PATH , tmpdir ) ;
lstrcatA ( tmpdir , " Please Remove Me " ) ;
bret = CreateDirectoryA ( tmpdir , & sa ) ;
ok ( bret = = TRUE , " CreateDirectoryA(%s) failed err=%d \n " , tmpdir , GetLastError ( ) ) ;
HeapFree ( GetProcessHeap ( ) , 0 , pDacl ) ;
SetLastError ( 0xdeadbeef ) ;
error = pGetNamedSecurityInfoA ( tmpdir , SE_FILE_OBJECT ,
OWNER_SECURITY_INFORMATION | DACL_SECURITY_INFORMATION , ( PSID * ) & owner ,
NULL , & pDacl , NULL , & pSD ) ;
if ( error ! = ERROR_SUCCESS & & ( GetLastError ( ) = = ERROR_CALL_NOT_IMPLEMENTED ) )
{
win_skip ( " GetNamedSecurityInfoA is not implemented \n " ) ;
goto done ;
}
ok ( ! error , " GetNamedSecurityInfo failed with error %d \n " , error ) ;
bret = pGetAclInformation ( pDacl , & acl_size , sizeof ( acl_size ) , AclSizeInformation ) ;
ok ( bret , " GetAclInformation failed \n " ) ;
2013-11-08 20:04:56 +01:00
ok ( acl_size . AceCount = = 2 , " GetAclInformation returned unexpected entry count (%d != 2). \n " ,
acl_size . AceCount ) ;
2013-11-08 20:01:49 +01:00
if ( acl_size . AceCount > 0 )
{
bret = pGetAce ( pDacl , 0 , ( VOID * * ) & ace ) ;
ok ( bret , " Failed to get Current User ACE. \n " ) ;
bret = EqualSid ( & ace - > SidStart , user_sid ) ;
todo_wine ok ( bret , " Current User ACE != Current User SID. \n " ) ;
todo_wine ok ( ( ( ACE_HEADER * ) ace ) - > AceFlags = = ( OBJECT_INHERIT_ACE | CONTAINER_INHERIT_ACE ) ,
" Current User ACE has unexpected flags (0x%x != 0x03) \n " ,
( ( ACE_HEADER * ) ace ) - > AceFlags ) ;
ok ( ace - > Mask = = 0x1f01ff , " Current User ACE has unexpected mask (0x%x != 0x1f01ff) \n " ,
ace - > Mask ) ;
}
if ( acl_size . AceCount > 1 )
{
bret = pGetAce ( pDacl , 1 , ( VOID * * ) & ace ) ;
ok ( bret , " Failed to get Administators Group ACE. \n " ) ;
bret = EqualSid ( & ace - > SidStart , admin_sid ) ;
todo_wine ok ( bret , " Administators Group ACE != Administators Group SID. \n " ) ;
todo_wine ok ( ( ( ACE_HEADER * ) ace ) - > AceFlags = = ( OBJECT_INHERIT_ACE | CONTAINER_INHERIT_ACE ) ,
" Administators Group ACE has unexpected flags (0x%x != 0x03) \n " ,
( ( ACE_HEADER * ) ace ) - > AceFlags ) ;
ok ( ace - > Mask = = 0x1f01ff , " Administators Group ACE has unexpected mask (0x%x != 0x1f01ff) \n " ,
ace - > Mask ) ;
}
done :
HeapFree ( GetProcessHeap ( ) , 0 , user ) ;
bret = RemoveDirectoryA ( tmpdir ) ;
ok ( bret = = TRUE , " RemoveDirectoryA should always succeed \n " ) ;
}
2007-06-25 16:00:38 +02:00
static void test_GetNamedSecurityInfoA ( void )
{
2013-03-05 17:52:38 +01:00
char admin_ptr [ sizeof ( SID ) + sizeof ( ULONG ) * SID_MAX_SUB_AUTHORITIES ] , * user ;
char system_ptr [ sizeof ( SID ) + sizeof ( ULONG ) * SID_MAX_SUB_AUTHORITIES ] ;
2013-04-20 01:25:43 +02:00
char users_ptr [ sizeof ( SID ) + sizeof ( ULONG ) * SID_MAX_SUB_AUTHORITIES ] ;
PSID admin_sid = ( PSID ) admin_ptr , users_sid = ( PSID ) users_ptr ;
PSID system_sid = ( PSID ) system_ptr , user_sid ;
2012-12-02 23:55:21 +01:00
DWORD sid_size = sizeof ( admin_ptr ) , user_size ;
2012-11-26 20:08:57 +01:00
char invalid_path [ ] = " /an invalid file path " ;
2013-04-28 05:09:17 +02:00
int users_ace_id = - 1 , admins_ace_id = - 1 , i ;
2013-03-05 17:52:38 +01:00
char software_key [ ] = " MACHINE \\ Software " ;
2012-11-26 20:13:47 +01:00
char sd [ SECURITY_DESCRIPTOR_MIN_LENGTH ] ;
2007-06-25 16:00:38 +02:00
SECURITY_DESCRIPTOR_CONTROL control ;
2012-11-26 20:13:47 +01:00
ACL_SIZE_INFORMATION acl_size ;
CHAR windows_dir [ MAX_PATH ] ;
PSECURITY_DESCRIPTOR pSD ;
ACCESS_ALLOWED_ACE * ace ;
BOOL bret = TRUE , isNT4 ;
char tmpfile [ MAX_PATH ] ;
DWORD error , revision ;
2007-06-25 16:00:38 +02:00
BOOL owner_defaulted ;
BOOL group_defaulted ;
2013-04-20 01:25:43 +02:00
BOOL dacl_defaulted ;
2012-11-26 20:13:47 +01:00
HANDLE token , hTemp ;
PSID owner , group ;
2013-04-20 01:25:43 +02:00
BOOL dacl_present ;
2012-11-26 20:13:47 +01:00
PACL pDacl ;
2013-04-28 05:09:17 +02:00
BYTE flags ;
2012-11-26 20:13:47 +01:00
if ( ! pSetNamedSecurityInfoA | | ! pGetNamedSecurityInfoA | | ! pCreateWellKnownSid )
{
win_skip ( " Required functions are not available \n " ) ;
return ;
}
2007-06-25 16:00:38 +02:00
2012-11-26 20:13:47 +01:00
if ( ! OpenThreadToken ( GetCurrentThread ( ) , TOKEN_READ , TRUE , & token ) )
{
if ( GetLastError ( ) ! = ERROR_NO_TOKEN ) bret = FALSE ;
else if ( ! OpenProcessToken ( GetCurrentProcess ( ) , TOKEN_READ , & token ) ) bret = FALSE ;
}
if ( ! bret )
2007-08-14 11:05:04 +02:00
{
2012-11-26 20:13:47 +01:00
win_skip ( " Failed to get current user token \n " ) ;
2007-08-14 11:05:04 +02:00
return ;
}
2012-12-02 23:55:21 +01:00
bret = GetTokenInformation ( token , TokenUser , NULL , 0 , & user_size ) ;
ok ( ! bret & & ( GetLastError ( ) = = ERROR_INSUFFICIENT_BUFFER ) ,
" GetTokenInformation(TokenUser) failed with error %d \n " , GetLastError ( ) ) ;
user = HeapAlloc ( GetProcessHeap ( ) , 0 , user_size ) ;
bret = GetTokenInformation ( token , TokenUser , user , user_size , & user_size ) ;
ok ( bret , " GetTokenInformation(TokenUser) failed with error %d \n " , GetLastError ( ) ) ;
2012-11-26 20:13:47 +01:00
CloseHandle ( token ) ;
2012-12-02 23:55:21 +01:00
user_sid = ( ( TOKEN_USER * ) user ) - > User . Sid ;
2007-08-14 11:05:04 +02:00
2012-11-26 20:13:47 +01:00
bret = GetWindowsDirectoryA ( windows_dir , MAX_PATH ) ;
ok ( bret , " GetWindowsDirectory failed with error %d \n " , GetLastError ( ) ) ;
2007-06-25 16:00:38 +02:00
2007-07-05 17:22:27 +02:00
SetLastError ( 0xdeadbeef ) ;
2007-08-14 11:05:04 +02:00
error = pGetNamedSecurityInfoA ( windows_dir , SE_FILE_OBJECT ,
2007-06-25 16:00:38 +02:00
OWNER_SECURITY_INFORMATION | GROUP_SECURITY_INFORMATION | DACL_SECURITY_INFORMATION ,
2012-11-26 20:13:47 +01:00
NULL , NULL , NULL , NULL , & pSD ) ;
2007-07-05 17:22:27 +02:00
if ( error ! = ERROR_SUCCESS & & ( GetLastError ( ) = = ERROR_CALL_NOT_IMPLEMENTED ) )
{
2009-02-26 09:45:07 +01:00
win_skip ( " GetNamedSecurityInfoA is not implemented \n " ) ;
2012-12-02 23:55:21 +01:00
HeapFree ( GetProcessHeap ( ) , 0 , user ) ;
2007-07-05 17:22:27 +02:00
return ;
}
2007-06-25 16:00:38 +02:00
ok ( ! error , " GetNamedSecurityInfo failed with error %d \n " , error ) ;
2012-11-26 20:13:47 +01:00
bret = GetSecurityDescriptorControl ( pSD , & control , & revision ) ;
ok ( bret , " GetSecurityDescriptorControl failed with error %d \n " , GetLastError ( ) ) ;
2008-12-09 17:44:50 +01:00
ok ( ( control & ( SE_SELF_RELATIVE | SE_DACL_PRESENT ) ) = = ( SE_SELF_RELATIVE | SE_DACL_PRESENT ) | |
broken ( ( control & ( SE_SELF_RELATIVE | SE_DACL_PRESENT ) ) = = SE_DACL_PRESENT ) , /* NT4 */
2007-06-25 16:00:38 +02:00
" control (0x%x) doesn't have (SE_SELF_RELATIVE|SE_DACL_PRESENT) flags set \n " , control ) ;
ok ( revision = = SECURITY_DESCRIPTOR_REVISION1 , " revision was %d instead of 1 \n " , revision ) ;
2010-08-24 11:04:35 +02:00
isNT4 = ( control & ( SE_SELF_RELATIVE | SE_DACL_PRESENT ) ) = = SE_DACL_PRESENT ;
2012-11-26 20:13:47 +01:00
bret = GetSecurityDescriptorOwner ( pSD , & owner , & owner_defaulted ) ;
ok ( bret , " GetSecurityDescriptorOwner failed with error %d \n " , GetLastError ( ) ) ;
2007-06-25 16:00:38 +02:00
ok ( owner ! = NULL , " owner should not be NULL \n " ) ;
2010-08-24 11:04:35 +02:00
2012-11-26 20:13:47 +01:00
bret = GetSecurityDescriptorGroup ( pSD , & group , & group_defaulted ) ;
ok ( bret , " GetSecurityDescriptorGroup failed with error %d \n " , GetLastError ( ) ) ;
2007-06-25 16:00:38 +02:00
ok ( group ! = NULL , " group should not be NULL \n " ) ;
2012-11-26 20:13:47 +01:00
LocalFree ( pSD ) ;
2010-08-24 11:04:35 +02:00
/* NULL descriptor tests */
if ( isNT4 )
{
win_skip ( " NT4 does not support GetNamedSecutityInfo with a NULL descriptor \n " ) ;
2012-12-02 23:55:21 +01:00
HeapFree ( GetProcessHeap ( ) , 0 , user ) ;
2010-08-24 11:04:35 +02:00
return ;
}
error = pGetNamedSecurityInfoA ( windows_dir , SE_FILE_OBJECT , DACL_SECURITY_INFORMATION ,
NULL , NULL , NULL , NULL , NULL ) ;
ok ( error = = ERROR_INVALID_PARAMETER , " GetNamedSecurityInfo failed with error %d \n " , error ) ;
error = pGetNamedSecurityInfoA ( windows_dir , SE_FILE_OBJECT , DACL_SECURITY_INFORMATION ,
2012-11-26 20:13:47 +01:00
NULL , NULL , & pDacl , NULL , NULL ) ;
2010-08-24 11:04:35 +02:00
ok ( ! error , " GetNamedSecurityInfo failed with error %d \n " , error ) ;
2012-11-26 20:13:47 +01:00
ok ( pDacl ! = NULL , " DACL should not be NULL \n " ) ;
2010-08-24 11:04:35 +02:00
error = pGetNamedSecurityInfoA ( windows_dir , SE_FILE_OBJECT , OWNER_SECURITY_INFORMATION ,
2012-11-26 20:13:47 +01:00
NULL , NULL , & pDacl , NULL , NULL ) ;
2010-08-24 11:04:35 +02:00
ok ( error = = ERROR_INVALID_PARAMETER , " GetNamedSecurityInfo failed with error %d \n " , error ) ;
2012-11-26 20:08:57 +01:00
/* Test behavior of SetNamedSecurityInfo with an invalid path */
SetLastError ( 0xdeadbeef ) ;
error = pSetNamedSecurityInfoA ( invalid_path , SE_FILE_OBJECT , DACL_SECURITY_INFORMATION , NULL ,
NULL , NULL , NULL ) ;
ok ( error = = ERROR_FILE_NOT_FOUND , " Unexpected error returned: 0x%x \n " , error ) ;
ok ( GetLastError ( ) = = 0xdeadbeef , " Expected last error to remain unchanged. \n " ) ;
2012-11-26 20:13:47 +01:00
/* Create security descriptor information and test that it comes back the same */
pSD = & sd ;
2013-03-05 17:52:38 +01:00
pDacl = HeapAlloc ( GetProcessHeap ( ) , 0 , 100 ) ;
2012-11-26 20:13:47 +01:00
InitializeSecurityDescriptor ( pSD , SECURITY_DESCRIPTOR_REVISION ) ;
pCreateWellKnownSid ( WinBuiltinAdministratorsSid , NULL , admin_sid , & sid_size ) ;
2013-03-05 17:52:38 +01:00
bret = InitializeAcl ( pDacl , 100 , ACL_REVISION ) ;
2012-11-26 20:13:47 +01:00
ok ( bret , " Failed to initialize ACL. \n " ) ;
bret = pAddAccessAllowedAceEx ( pDacl , ACL_REVISION , 0 , GENERIC_ALL , user_sid ) ;
ok ( bret , " Failed to add Current User to ACL. \n " ) ;
bret = pAddAccessAllowedAceEx ( pDacl , ACL_REVISION , 0 , GENERIC_ALL , admin_sid ) ;
ok ( bret , " Failed to add Administrator Group to ACL. \n " ) ;
bret = SetSecurityDescriptorDacl ( pSD , TRUE , pDacl , FALSE ) ;
ok ( bret , " Failed to add ACL to security desciptor. \n " ) ;
GetTempFileNameA ( " . " , " foo " , 0 , tmpfile ) ;
hTemp = CreateFileA ( tmpfile , GENERIC_WRITE , FILE_SHARE_READ , NULL , OPEN_EXISTING ,
FILE_FLAG_DELETE_ON_CLOSE , NULL ) ;
SetLastError ( 0xdeadbeef ) ;
error = pSetNamedSecurityInfoA ( tmpfile , SE_FILE_OBJECT , DACL_SECURITY_INFORMATION , NULL ,
NULL , pDacl , NULL ) ;
2013-03-05 17:52:38 +01:00
HeapFree ( GetProcessHeap ( ) , 0 , pDacl ) ;
2012-11-26 20:13:47 +01:00
if ( error ! = ERROR_SUCCESS & & ( GetLastError ( ) = = ERROR_CALL_NOT_IMPLEMENTED ) )
{
win_skip ( " SetNamedSecurityInfoA is not implemented \n " ) ;
2013-01-18 19:00:58 +01:00
HeapFree ( GetProcessHeap ( ) , 0 , user ) ;
2012-11-26 20:13:47 +01:00
CloseHandle ( hTemp ) ;
return ;
}
ok ( ! error , " SetNamedSecurityInfoA failed with error %d \n " , error ) ;
SetLastError ( 0xdeadbeef ) ;
error = pGetNamedSecurityInfoA ( tmpfile , SE_FILE_OBJECT , DACL_SECURITY_INFORMATION ,
NULL , NULL , & pDacl , NULL , & pSD ) ;
if ( error ! = ERROR_SUCCESS & & ( GetLastError ( ) = = ERROR_CALL_NOT_IMPLEMENTED ) )
{
win_skip ( " GetNamedSecurityInfoA is not implemented \n " ) ;
2013-01-18 19:00:58 +01:00
HeapFree ( GetProcessHeap ( ) , 0 , user ) ;
2013-01-05 23:32:54 +01:00
CloseHandle ( hTemp ) ;
2012-11-26 20:13:47 +01:00
return ;
}
ok ( ! error , " GetNamedSecurityInfo failed with error %d \n " , error ) ;
bret = pGetAclInformation ( pDacl , & acl_size , sizeof ( acl_size ) , AclSizeInformation ) ;
ok ( bret , " GetAclInformation failed \n " ) ;
if ( acl_size . AceCount > 0 )
{
bret = pGetAce ( pDacl , 0 , ( VOID * * ) & ace ) ;
ok ( bret , " Failed to get Current User ACE. \n " ) ;
bret = EqualSid ( & ace - > SidStart , user_sid ) ;
todo_wine ok ( bret , " Current User ACE != Current User SID. \n " ) ;
ok ( ( ( ACE_HEADER * ) ace ) - > AceFlags = = 0 ,
" Current User ACE has unexpected flags (0x%x != 0x0) \n " , ( ( ACE_HEADER * ) ace ) - > AceFlags ) ;
ok ( ace - > Mask = = 0x1f01ff , " Current User ACE has unexpected mask (0x%x != 0x1f01ff) \n " ,
ace - > Mask ) ;
}
if ( acl_size . AceCount > 1 )
{
bret = pGetAce ( pDacl , 1 , ( VOID * * ) & ace ) ;
ok ( bret , " Failed to get Administators Group ACE. \n " ) ;
bret = EqualSid ( & ace - > SidStart , admin_sid ) ;
todo_wine ok ( bret | | broken ( ! bret ) /* win2k */ ,
" Administators Group ACE != Administators Group SID. \n " ) ;
ok ( ( ( ACE_HEADER * ) ace ) - > AceFlags = = 0 ,
" Administators Group ACE has unexpected flags (0x%x != 0x0) \n " , ( ( ACE_HEADER * ) ace ) - > AceFlags ) ;
ok ( ace - > Mask = = 0x1f01ff | | broken ( ace - > Mask = = GENERIC_ALL ) /* win2k */ ,
" Administators Group ACE has unexpected mask (0x%x != 0x1f01ff) \n " , ace - > Mask ) ;
}
LocalFree ( pSD ) ;
2013-01-18 19:00:58 +01:00
HeapFree ( GetProcessHeap ( ) , 0 , user ) ;
2012-11-26 20:13:47 +01:00
CloseHandle ( hTemp ) ;
2013-03-05 17:52:38 +01:00
/* Test querying the ownership of a built-in registry key */
sid_size = sizeof ( system_ptr ) ;
pCreateWellKnownSid ( WinLocalSystemSid , NULL , system_sid , & sid_size ) ;
error = pGetNamedSecurityInfoA ( software_key , SE_REGISTRY_KEY ,
OWNER_SECURITY_INFORMATION | GROUP_SECURITY_INFORMATION ,
NULL , NULL , NULL , NULL , & pSD ) ;
ok ( ! error , " GetNamedSecurityInfo failed with error %d \n " , error ) ;
bret = GetSecurityDescriptorOwner ( pSD , & owner , & owner_defaulted ) ;
ok ( bret , " GetSecurityDescriptorOwner failed with error %d \n " , GetLastError ( ) ) ;
ok ( owner ! = NULL , " owner should not be NULL \n " ) ;
ok ( EqualSid ( owner , admin_sid ) , " MACHINE \\ Software owner SID != Administrators SID. \n " ) ;
bret = GetSecurityDescriptorGroup ( pSD , & group , & group_defaulted ) ;
ok ( bret , " GetSecurityDescriptorGroup failed with error %d \n " , GetLastError ( ) ) ;
ok ( group ! = NULL , " group should not be NULL \n " ) ;
2013-04-20 01:21:02 +02:00
ok ( EqualSid ( group , admin_sid ) | | broken ( EqualSid ( group , system_sid ) ) /* before Win7 */
| | broken ( ( ( SID * ) group ) - > SubAuthority [ 0 ] = = SECURITY_NT_NON_UNIQUE ) /* Vista */ ,
2013-03-05 17:52:38 +01:00
" MACHINE \\ Software group SID != Local System SID. \n " ) ;
LocalFree ( pSD ) ;
2013-04-20 01:25:43 +02:00
/* Test querying the DACL of a built-in registry key */
sid_size = sizeof ( users_ptr ) ;
pCreateWellKnownSid ( WinBuiltinUsersSid , NULL , users_sid , & sid_size ) ;
error = pGetNamedSecurityInfoA ( software_key , SE_REGISTRY_KEY , DACL_SECURITY_INFORMATION ,
NULL , NULL , NULL , NULL , & pSD ) ;
ok ( ! error , " GetNamedSecurityInfo failed with error %d \n " , error ) ;
bret = GetSecurityDescriptorDacl ( pSD , & dacl_present , & pDacl , & dacl_defaulted ) ;
ok ( bret , " GetSecurityDescriptorDacl failed with error %d \n " , GetLastError ( ) ) ;
ok ( dacl_present , " DACL should be present \n " ) ;
ok ( pDacl & & IsValidAcl ( pDacl ) , " GetSecurityDescriptorDacl returned invalid DACL. \n " ) ;
bret = pGetAclInformation ( pDacl , & acl_size , sizeof ( acl_size ) , AclSizeInformation ) ;
ok ( bret , " GetAclInformation failed \n " ) ;
ok ( acl_size . AceCount ! = 0 , " GetAclInformation returned no ACLs \n " ) ;
for ( i = 0 ; i < acl_size . AceCount ; i + + )
{
bret = pGetAce ( pDacl , i , ( VOID * * ) & ace ) ;
ok ( bret , " Failed to get ACE %d. \n " , i ) ;
bret = EqualSid ( & ace - > SidStart , users_sid ) ;
if ( bret ) users_ace_id = i ;
2013-04-28 05:09:17 +02:00
bret = EqualSid ( & ace - > SidStart , admin_sid ) ;
if ( bret ) admins_ace_id = i ;
2013-04-20 01:25:43 +02:00
}
2013-04-28 05:09:28 +02:00
ok ( users_ace_id ! = - 1 | | broken ( users_ace_id = = - 1 ) /* win2k */ ,
" Bultin Users ACE not found. \n " ) ;
2013-04-20 01:25:43 +02:00
if ( users_ace_id ! = - 1 )
{
bret = pGetAce ( pDacl , users_ace_id , ( VOID * * ) & ace ) ;
ok ( bret , " Failed to get Builtin Users ACE. \n " ) ;
2013-04-28 05:09:28 +02:00
flags = ( ( ACE_HEADER * ) ace ) - > AceFlags ;
ok ( flags = = ( INHERIT_ONLY_ACE | CONTAINER_INHERIT_ACE )
| | broken ( flags = = ( INHERIT_ONLY_ACE | CONTAINER_INHERIT_ACE | INHERITED_ACE ) ) /* w2k8 */ ,
" Builtin Users ACE has unexpected flags (0x%x != 0x%x) \n " , flags ,
2013-04-20 01:25:43 +02:00
INHERIT_ONLY_ACE | CONTAINER_INHERIT_ACE ) ;
ok ( ace - > Mask = = GENERIC_READ , " Builtin Users ACE has unexpected mask (0x%x != 0x%x) \n " ,
ace - > Mask , GENERIC_READ ) ;
}
2013-04-28 05:09:17 +02:00
ok ( admins_ace_id ! = - 1 , " Bultin Admins ACE not found. \n " ) ;
if ( admins_ace_id ! = - 1 )
{
bret = pGetAce ( pDacl , admins_ace_id , ( VOID * * ) & ace ) ;
ok ( bret , " Failed to get Builtin Admins ACE. \n " ) ;
flags = ( ( ACE_HEADER * ) ace ) - > AceFlags ;
ok ( flags = = 0x0
| | broken ( flags = = ( INHERIT_ONLY_ACE | CONTAINER_INHERIT_ACE | INHERITED_ACE ) ) /* w2k8 */ ,
" Builtin Admins ACE has unexpected flags (0x%x != 0x0) \n " , flags ) ;
ok ( ace - > Mask = = KEY_ALL_ACCESS | | broken ( ace - > Mask = = GENERIC_ALL ) /* w2k8 */ ,
" Builtin Admins ACE has unexpected mask (0x%x != 0x%x) \n " , ace - > Mask , KEY_ALL_ACCESS ) ;
}
2013-04-20 01:25:43 +02:00
LocalFree ( pSD ) ;
2007-06-25 16:00:38 +02:00
}
2007-07-20 10:26:35 +02:00
static void test_ConvertStringSecurityDescriptor ( void )
2007-07-18 19:13:25 +02:00
{
BOOL ret ;
PSECURITY_DESCRIPTOR pSD ;
2008-10-13 23:02:06 +02:00
static const WCHAR Blank [ ] = { 0 } ;
2010-06-18 22:01:57 +02:00
unsigned int i ;
2009-10-13 13:34:34 +02:00
static const struct
{
const char * sidstring ;
DWORD revision ;
BOOL ret ;
DWORD GLE ;
2009-10-13 21:03:26 +02:00
DWORD altGLE ;
2009-10-13 13:34:34 +02:00
} cssd [ ] =
{
{ " D:(A;;GA;;;WD) " , 0xdeadbeef , FALSE , ERROR_UNKNOWN_REVISION } ,
/* test ACE string type */
{ " D:(A;;GA;;;WD) " , SDDL_REVISION_1 , TRUE } ,
{ " D:(D;;GA;;;WD) " , SDDL_REVISION_1 , TRUE } ,
{ " ERROR:(D;;GA;;;WD) " , SDDL_REVISION_1 , FALSE , ERROR_INVALID_PARAMETER } ,
2009-10-13 21:03:26 +02:00
/* test ACE string with spaces */
2009-10-13 15:40:20 +02:00
{ " D:(D;;GA;;;WD) " , SDDL_REVISION_1 , TRUE } ,
{ " D: (D;;GA;;;WD) " , SDDL_REVISION_1 , TRUE } ,
{ " D:( D;;GA;;;WD) " , SDDL_REVISION_1 , TRUE } ,
2009-10-13 21:03:26 +02:00
{ " D:(D ;;GA;;;WD) " , SDDL_REVISION_1 , FALSE , RPC_S_INVALID_STRING_UUID , ERROR_INVALID_ACL } , /* Vista+ */
2009-10-13 15:40:20 +02:00
{ " D:(D; ;GA;;;WD) " , SDDL_REVISION_1 , TRUE } ,
{ " D:(D;; GA;;;WD) " , SDDL_REVISION_1 , TRUE } ,
{ " D:(D;;GA ;;;WD) " , SDDL_REVISION_1 , FALSE , ERROR_INVALID_ACL } ,
{ " D:(D;;GA; ;;WD) " , SDDL_REVISION_1 , TRUE } ,
{ " D:(D;;GA;; ;WD) " , SDDL_REVISION_1 , TRUE } ,
{ " D:(D;;GA;;; WD) " , SDDL_REVISION_1 , TRUE } ,
{ " D:(D;;GA;;;WD ) " , SDDL_REVISION_1 , TRUE } ,
2009-10-13 13:34:34 +02:00
/* test ACE string access rights */
{ " D:(A;;GA;;;WD) " , SDDL_REVISION_1 , TRUE } ,
{ " D:(A;;GRGWGX;;;WD) " , SDDL_REVISION_1 , TRUE } ,
{ " D:(A;;RCSDWDWO;;;WD) " , SDDL_REVISION_1 , TRUE } ,
{ " D:(A;;RPWPCCDCLCSWLODTCR;;;WD) " , SDDL_REVISION_1 , TRUE } ,
{ " D:(A;;FAFRFWFX;;;WD) " , SDDL_REVISION_1 , TRUE } ,
{ " D:(A;;KAKRKWKX;;;WD) " , SDDL_REVISION_1 , TRUE } ,
{ " D:(A;;0xFFFFFFFF;;;WD) " , SDDL_REVISION_1 , TRUE } ,
{ " S:(AU;;0xFFFFFFFF;;;WD) " , SDDL_REVISION_1 , TRUE } ,
/* test ACE string access right error case */
{ " D:(A;;ROB;;;WD) " , SDDL_REVISION_1 , FALSE , ERROR_INVALID_ACL } ,
/* test behaviour with empty strings */
{ " " , SDDL_REVISION_1 , TRUE } ,
/* test ACE string SID */
2009-10-13 21:03:26 +02:00
{ " D:(D;;GA;;;S-1-0-0) " , SDDL_REVISION_1 , TRUE } ,
{ " D:(D;;GA;;;Nonexistent account) " , SDDL_REVISION_1 , FALSE , ERROR_INVALID_ACL , ERROR_INVALID_SID } /* W2K */
2009-10-13 13:34:34 +02:00
} ;
2007-07-18 19:13:25 +02:00
2007-07-20 13:53:44 +02:00
if ( ! pConvertStringSecurityDescriptorToSecurityDescriptorA )
{
2009-02-26 09:45:07 +01:00
win_skip ( " ConvertStringSecurityDescriptorToSecurityDescriptor is not available \n " ) ;
2007-07-20 13:53:44 +02:00
return ;
}
2009-10-13 13:34:34 +02:00
for ( i = 0 ; i < sizeof ( cssd ) / sizeof ( cssd [ 0 ] ) ; i + + )
{
DWORD GLE ;
2007-07-18 19:13:25 +02:00
2009-10-13 13:34:34 +02:00
SetLastError ( 0xdeadbeef ) ;
ret = pConvertStringSecurityDescriptorToSecurityDescriptorA (
cssd [ i ] . sidstring , cssd [ i ] . revision , & pSD , NULL ) ;
GLE = GetLastError ( ) ;
2010-06-18 22:01:57 +02:00
ok ( ret = = cssd [ i ] . ret , " (%02u) Expected %s (%d) \n " , i , cssd [ i ] . ret ? " success " : " failure " , GLE ) ;
2009-10-13 13:34:34 +02:00
if ( ! cssd [ i ] . ret )
2009-10-13 21:03:26 +02:00
ok ( GLE = = cssd [ i ] . GLE | |
( cssd [ i ] . altGLE & & GLE = = cssd [ i ] . altGLE ) ,
2010-06-18 22:01:57 +02:00
" (%02u) Unexpected last error %d \n " , i , GLE ) ;
2009-10-13 13:34:34 +02:00
if ( ret )
LocalFree ( pSD ) ;
}
2007-07-18 19:13:25 +02:00
2008-10-13 23:02:06 +02:00
/* test behaviour with NULL parameters */
SetLastError ( 0xdeadbeef ) ;
ret = pConvertStringSecurityDescriptorToSecurityDescriptorA (
NULL , 0xdeadbeef , & pSD , NULL ) ;
todo_wine
ok ( ! ret & & GetLastError ( ) = = ERROR_INVALID_PARAMETER ,
" ConvertStringSecurityDescriptorToSecurityDescriptor should have failed with ERROR_INVALID_PARAMETER instead of %d \n " ,
GetLastError ( ) ) ;
SetLastError ( 0xdeadbeef ) ;
ret = pConvertStringSecurityDescriptorToSecurityDescriptorW (
NULL , 0xdeadbeef , & pSD , NULL ) ;
ok ( ! ret & & GetLastError ( ) = = ERROR_INVALID_PARAMETER ,
" ConvertStringSecurityDescriptorToSecurityDescriptor should have failed with ERROR_INVALID_PARAMETER instead of %d \n " ,
GetLastError ( ) ) ;
SetLastError ( 0xdeadbeef ) ;
ret = pConvertStringSecurityDescriptorToSecurityDescriptorA (
" D:(A;;ROB;;;WD) " , 0xdeadbeef , NULL , NULL ) ;
ok ( ! ret & & GetLastError ( ) = = ERROR_INVALID_PARAMETER ,
" ConvertStringSecurityDescriptorToSecurityDescriptor should have failed with ERROR_INVALID_PARAMETER instead of %d \n " ,
GetLastError ( ) ) ;
SetLastError ( 0xdeadbeef ) ;
ret = pConvertStringSecurityDescriptorToSecurityDescriptorA (
" D:(A;;ROB;;;WD) " , SDDL_REVISION_1 , NULL , NULL ) ;
ok ( ! ret & & GetLastError ( ) = = ERROR_INVALID_PARAMETER ,
" ConvertStringSecurityDescriptorToSecurityDescriptor should have failed with ERROR_INVALID_PARAMETER instead of %d \n " ,
GetLastError ( ) ) ;
/* test behaviour with empty strings */
SetLastError ( 0xdeadbeef ) ;
ret = pConvertStringSecurityDescriptorToSecurityDescriptorW (
Blank , SDDL_REVISION_1 , & pSD , NULL ) ;
ok ( ret , " ConvertStringSecurityDescriptorToSecurityDescriptor failed with error %d \n " , GetLastError ( ) ) ;
2009-12-02 15:32:07 +01:00
LocalFree ( pSD ) ;
2007-07-18 19:13:25 +02:00
}
2009-01-25 23:27:04 +01:00
static void test_ConvertSecurityDescriptorToString ( void )
2007-09-25 22:12:50 +02:00
{
SECURITY_DESCRIPTOR desc ;
SECURITY_INFORMATION sec_info = OWNER_SECURITY_INFORMATION | GROUP_SECURITY_INFORMATION | DACL_SECURITY_INFORMATION | SACL_SECURITY_INFORMATION ;
LPSTR string ;
DWORD size ;
PSID psid , psid2 ;
PACL pacl ;
char sid_buf [ 256 ] ;
char acl_buf [ 8192 ] ;
ULONG len ;
if ( ! pConvertSecurityDescriptorToStringSecurityDescriptorA )
{
2009-02-26 09:45:07 +01:00
win_skip ( " ConvertSecurityDescriptorToStringSecurityDescriptor is not available \n " ) ;
2007-09-25 22:12:50 +02:00
return ;
}
2007-10-16 10:51:00 +02:00
if ( ! pCreateWellKnownSid )
{
2009-02-26 09:45:07 +01:00
win_skip ( " CreateWellKnownSid is not available \n " ) ;
2007-10-16 10:51:00 +02:00
return ;
}
2007-09-25 22:12:50 +02:00
2007-10-11 18:31:26 +02:00
/* It seems Windows XP adds an extra character to the length of the string for each ACE in an ACL. We
2007-09-25 22:12:50 +02:00
* don ' t replicate this feature so we only test len > = strlen + 1. */
# define CHECK_RESULT_AND_FREE(exp_str) \
ok ( strcmp ( string , ( exp_str ) ) = = 0 , " String mismatch (expected \" %s \" , got \" %s \" ) \n " , ( exp_str ) , string ) ; \
2013-10-15 10:15:45 +02:00
ok ( len > = ( strlen ( exp_str ) + 1 ) , " Length mismatch (expected %d, got %d) \n " , lstrlenA ( exp_str ) + 1 , len ) ; \
2007-09-25 22:12:50 +02:00
LocalFree ( string ) ;
2007-10-21 08:46:40 +02:00
# define CHECK_ONE_OF_AND_FREE(exp_str1, exp_str2) \
ok ( strcmp ( string , ( exp_str1 ) ) = = 0 | | strcmp ( string , ( exp_str2 ) ) = = 0 , " String mismatch (expected \n \" %s \" or \n \" %s \" , got \n \" %s \" ) \n " , ( exp_str1 ) , ( exp_str2 ) , string ) ; \
2013-10-15 10:15:45 +02:00
ok ( len > = ( strlen ( exp_str1 ) + 1 ) | | len > = ( strlen ( exp_str2 ) + 1 ) , " Length mismatch (expected %d or %d, got %d) \n " , lstrlenA ( exp_str1 ) + 1 , lstrlenA ( exp_str2 ) + 1 , len ) ; \
2007-10-21 08:46:40 +02:00
LocalFree ( string ) ;
2007-09-25 22:12:50 +02:00
InitializeSecurityDescriptor ( & desc , SECURITY_DESCRIPTOR_REVISION ) ;
2007-10-02 09:19:49 +02:00
ok ( pConvertSecurityDescriptorToStringSecurityDescriptorA ( & desc , SDDL_REVISION_1 , sec_info , & string , & len ) , " Conversion failed \n " ) ;
2007-09-25 22:12:50 +02:00
CHECK_RESULT_AND_FREE ( " " ) ;
size = 4096 ;
2007-10-16 10:51:00 +02:00
pCreateWellKnownSid ( WinLocalSid , NULL , sid_buf , & size ) ;
2009-01-13 10:57:53 +01:00
SetSecurityDescriptorOwner ( & desc , sid_buf , FALSE ) ;
2007-10-02 09:19:49 +02:00
ok ( pConvertSecurityDescriptorToStringSecurityDescriptorA ( & desc , SDDL_REVISION_1 , sec_info , & string , & len ) , " Conversion failed \n " ) ;
2007-09-25 22:12:50 +02:00
CHECK_RESULT_AND_FREE ( " O:S-1-2-0 " ) ;
2009-01-13 10:57:53 +01:00
SetSecurityDescriptorOwner ( & desc , sid_buf , TRUE ) ;
2007-10-02 09:19:49 +02:00
ok ( pConvertSecurityDescriptorToStringSecurityDescriptorA ( & desc , SDDL_REVISION_1 , sec_info , & string , & len ) , " Conversion failed \n " ) ;
2007-09-25 22:12:50 +02:00
CHECK_RESULT_AND_FREE ( " O:S-1-2-0 " ) ;
size = sizeof ( sid_buf ) ;
2007-10-16 10:51:00 +02:00
pCreateWellKnownSid ( WinLocalSystemSid , NULL , sid_buf , & size ) ;
2009-01-13 10:57:53 +01:00
SetSecurityDescriptorOwner ( & desc , sid_buf , TRUE ) ;
2007-10-02 09:19:49 +02:00
ok ( pConvertSecurityDescriptorToStringSecurityDescriptorA ( & desc , SDDL_REVISION_1 , sec_info , & string , & len ) , " Conversion failed \n " ) ;
2007-09-25 22:12:50 +02:00
CHECK_RESULT_AND_FREE ( " O:SY " ) ;
2007-11-02 11:33:36 +01:00
pConvertStringSidToSidA ( " S-1-5-21-93476-23408-4576 " , & psid ) ;
2007-09-25 22:12:50 +02:00
SetSecurityDescriptorGroup ( & desc , psid , TRUE ) ;
2007-10-02 09:19:49 +02:00
ok ( pConvertSecurityDescriptorToStringSecurityDescriptorA ( & desc , SDDL_REVISION_1 , sec_info , & string , & len ) , " Conversion failed \n " ) ;
2007-09-25 22:12:50 +02:00
CHECK_RESULT_AND_FREE ( " O:SYG:S-1-5-21-93476-23408-4576 " ) ;
2007-10-02 09:19:49 +02:00
ok ( pConvertSecurityDescriptorToStringSecurityDescriptorA ( & desc , SDDL_REVISION_1 , GROUP_SECURITY_INFORMATION , & string , & len ) , " Conversion failed \n " ) ;
2007-09-25 22:12:50 +02:00
CHECK_RESULT_AND_FREE ( " G:S-1-5-21-93476-23408-4576 " ) ;
pacl = ( PACL ) acl_buf ;
InitializeAcl ( pacl , sizeof ( acl_buf ) , ACL_REVISION ) ;
SetSecurityDescriptorDacl ( & desc , TRUE , pacl , TRUE ) ;
2007-10-02 09:19:49 +02:00
ok ( pConvertSecurityDescriptorToStringSecurityDescriptorA ( & desc , SDDL_REVISION_1 , sec_info , & string , & len ) , " Conversion failed \n " ) ;
2007-09-25 22:12:50 +02:00
CHECK_RESULT_AND_FREE ( " O:SYG:S-1-5-21-93476-23408-4576D: " ) ;
SetSecurityDescriptorDacl ( & desc , TRUE , pacl , FALSE ) ;
2007-10-02 09:19:49 +02:00
ok ( pConvertSecurityDescriptorToStringSecurityDescriptorA ( & desc , SDDL_REVISION_1 , sec_info , & string , & len ) , " Conversion failed \n " ) ;
2007-09-25 22:12:50 +02:00
CHECK_RESULT_AND_FREE ( " O:SYG:S-1-5-21-93476-23408-4576D: " ) ;
2007-11-02 11:33:36 +01:00
pConvertStringSidToSidA ( " S-1-5-6 " , & psid2 ) ;
pAddAccessAllowedAceEx ( pacl , ACL_REVISION , NO_PROPAGATE_INHERIT_ACE , 0xf0000000 , psid2 ) ;
2007-10-02 09:19:49 +02:00
ok ( pConvertSecurityDescriptorToStringSecurityDescriptorA ( & desc , SDDL_REVISION_1 , sec_info , & string , & len ) , " Conversion failed \n " ) ;
2007-09-25 22:12:50 +02:00
CHECK_RESULT_AND_FREE ( " O:SYG:S-1-5-21-93476-23408-4576D:(A;NP;GAGXGWGR;;;SU) " ) ;
2007-11-02 11:33:36 +01:00
pAddAccessAllowedAceEx ( pacl , ACL_REVISION , INHERIT_ONLY_ACE | INHERITED_ACE , 0x00000003 , psid2 ) ;
2007-10-02 09:19:49 +02:00
ok ( pConvertSecurityDescriptorToStringSecurityDescriptorA ( & desc , SDDL_REVISION_1 , sec_info , & string , & len ) , " Conversion failed \n " ) ;
2007-09-25 22:12:50 +02:00
CHECK_RESULT_AND_FREE ( " O:SYG:S-1-5-21-93476-23408-4576D:(A;NP;GAGXGWGR;;;SU)(A;IOID;CCDC;;;SU) " ) ;
2007-11-02 11:33:36 +01:00
pAddAccessDeniedAceEx ( pacl , ACL_REVISION , OBJECT_INHERIT_ACE | CONTAINER_INHERIT_ACE , 0xffffffff , psid ) ;
2007-10-02 09:19:49 +02:00
ok ( pConvertSecurityDescriptorToStringSecurityDescriptorA ( & desc , SDDL_REVISION_1 , sec_info , & string , & len ) , " Conversion failed \n " ) ;
2007-09-25 22:12:50 +02:00
CHECK_RESULT_AND_FREE ( " O:SYG:S-1-5-21-93476-23408-4576D:(A;NP;GAGXGWGR;;;SU)(A;IOID;CCDC;;;SU)(D;OICI;0xffffffff;;;S-1-5-21-93476-23408-4576) " ) ;
pacl = ( PACL ) acl_buf ;
InitializeAcl ( pacl , sizeof ( acl_buf ) , ACL_REVISION ) ;
SetSecurityDescriptorSacl ( & desc , TRUE , pacl , FALSE ) ;
2007-10-02 09:19:49 +02:00
ok ( pConvertSecurityDescriptorToStringSecurityDescriptorA ( & desc , SDDL_REVISION_1 , sec_info , & string , & len ) , " Conversion failed \n " ) ;
2007-09-25 22:12:50 +02:00
CHECK_RESULT_AND_FREE ( " O:SYG:S-1-5-21-93476-23408-4576D:S: " ) ;
2008-04-11 01:05:30 +02:00
/* fails in win2k */
2007-09-25 22:12:50 +02:00
SetSecurityDescriptorDacl ( & desc , TRUE , NULL , FALSE ) ;
2007-11-02 11:33:36 +01:00
pAddAuditAccessAceEx ( pacl , ACL_REVISION , VALID_INHERIT_FLAGS , KEY_READ | KEY_WRITE , psid2 , TRUE , TRUE ) ;
2008-04-11 01:05:30 +02:00
if ( pConvertSecurityDescriptorToStringSecurityDescriptorA ( & desc , SDDL_REVISION_1 , sec_info , & string , & len ) )
{
CHECK_ONE_OF_AND_FREE ( " O:SYG:S-1-5-21-93476-23408-4576D:S:(AU;OICINPIOIDSAFA;CCDCLCSWRPRC;;;SU) " , /* XP */
" O:SYG:S-1-5-21-93476-23408-4576D:NO_ACCESS_CONTROLS:(AU;OICINPIOIDSAFA;CCDCLCSWRPRC;;;SU) " /* Vista */ ) ;
}
2007-09-25 22:12:50 +02:00
2008-04-11 01:05:30 +02:00
/* fails in win2k */
2007-11-02 11:33:36 +01:00
pAddAuditAccessAceEx ( pacl , ACL_REVISION , NO_PROPAGATE_INHERIT_ACE , FILE_GENERIC_READ | FILE_GENERIC_WRITE , psid2 , TRUE , FALSE ) ;
2008-04-11 01:05:30 +02:00
if ( pConvertSecurityDescriptorToStringSecurityDescriptorA ( & desc , SDDL_REVISION_1 , sec_info , & string , & len ) )
{
CHECK_ONE_OF_AND_FREE ( " O:SYG:S-1-5-21-93476-23408-4576D:S:(AU;OICINPIOIDSAFA;CCDCLCSWRPRC;;;SU)(AU;NPSA;0x12019f;;;SU) " , /* XP */
" O:SYG:S-1-5-21-93476-23408-4576D:NO_ACCESS_CONTROLS:(AU;OICINPIOIDSAFA;CCDCLCSWRPRC;;;SU)(AU;NPSA;0x12019f;;;SU) " /* Vista */ ) ;
}
2009-12-02 15:32:07 +01:00
LocalFree ( psid2 ) ;
LocalFree ( psid ) ;
2007-09-27 21:01:49 +02:00
}
2008-10-17 19:44:14 +02:00
static void test_SetSecurityDescriptorControl ( PSECURITY_DESCRIPTOR sec )
{
SECURITY_DESCRIPTOR_CONTROL ref ;
SECURITY_DESCRIPTOR_CONTROL test ;
SECURITY_DESCRIPTOR_CONTROL const mutable
= SE_DACL_AUTO_INHERIT_REQ | SE_SACL_AUTO_INHERIT_REQ
| SE_DACL_AUTO_INHERITED | SE_SACL_AUTO_INHERITED
| SE_DACL_PROTECTED | SE_SACL_PROTECTED
| 0x00000040 | 0x00000080 /* not defined in winnt.h */
;
SECURITY_DESCRIPTOR_CONTROL const immutable
= SE_OWNER_DEFAULTED | SE_GROUP_DEFAULTED
| SE_DACL_PRESENT | SE_DACL_DEFAULTED
| SE_SACL_PRESENT | SE_SACL_DEFAULTED
| SE_RM_CONTROL_VALID | SE_SELF_RELATIVE
;
int bit ;
DWORD dwRevision ;
LPCSTR fmt = " Expected error %s, got %u \n " ;
GetSecurityDescriptorControl ( sec , & ref , & dwRevision ) ;
/* The mutable bits are mutable regardless of the truth of
SE_DACL_PRESENT and / or SE_SACL_PRESENT */
/* Check call barfs if any bit-of-interest is immutable */
for ( bit = 0 ; bit < 16 ; + + bit )
{
SECURITY_DESCRIPTOR_CONTROL const bitOfInterest = 1 < < bit ;
SECURITY_DESCRIPTOR_CONTROL setOrClear = ref & bitOfInterest ;
SECURITY_DESCRIPTOR_CONTROL ctrl ;
DWORD dwExpect = ( bitOfInterest & immutable )
? ERROR_INVALID_PARAMETER : 0xbebecaca ;
LPCSTR strExpect = ( bitOfInterest & immutable )
? " ERROR_INVALID_PARAMETER " : " 0xbebecaca " ;
ctrl = ( bitOfInterest & mutable ) ? ref + bitOfInterest : ref ;
setOrClear ^ = bitOfInterest ;
SetLastError ( 0xbebecaca ) ;
pSetSecurityDescriptorControl ( sec , bitOfInterest , setOrClear ) ;
ok ( GetLastError ( ) = = dwExpect , fmt , strExpect , GetLastError ( ) ) ;
GetSecurityDescriptorControl ( sec , & test , & dwRevision ) ;
expect_eq ( test , ctrl , int , " %x " ) ;
setOrClear ^ = bitOfInterest ;
SetLastError ( 0xbebecaca ) ;
pSetSecurityDescriptorControl ( sec , bitOfInterest , setOrClear ) ;
ok ( GetLastError ( ) = = dwExpect , fmt , strExpect , GetLastError ( ) ) ;
GetSecurityDescriptorControl ( sec , & test , & dwRevision ) ;
expect_eq ( test , ref , int , " %x " ) ;
}
/* Check call barfs if any bit-to-set is immutable
even when not a bit - of - interest */
for ( bit = 0 ; bit < 16 ; + + bit )
{
SECURITY_DESCRIPTOR_CONTROL const bitsOfInterest = mutable ;
SECURITY_DESCRIPTOR_CONTROL setOrClear = ref & bitsOfInterest ;
SECURITY_DESCRIPTOR_CONTROL ctrl ;
DWORD dwExpect = ( ( 1 < < bit ) & immutable )
? ERROR_INVALID_PARAMETER : 0xbebecaca ;
LPCSTR strExpect = ( ( 1 < < bit ) & immutable )
? " ERROR_INVALID_PARAMETER " : " 0xbebecaca " ;
ctrl = ( ( 1 < < bit ) & immutable ) ? test : ref | mutable ;
setOrClear ^ = bitsOfInterest ;
SetLastError ( 0xbebecaca ) ;
pSetSecurityDescriptorControl ( sec , bitsOfInterest , setOrClear | ( 1 < < bit ) ) ;
ok ( GetLastError ( ) = = dwExpect , fmt , strExpect , GetLastError ( ) ) ;
GetSecurityDescriptorControl ( sec , & test , & dwRevision ) ;
expect_eq ( test , ctrl , int , " %x " ) ;
ctrl = ( ( 1 < < bit ) & immutable ) ? test : ref | ( 1 < < bit ) ;
setOrClear ^ = bitsOfInterest ;
SetLastError ( 0xbebecaca ) ;
pSetSecurityDescriptorControl ( sec , bitsOfInterest , setOrClear | ( 1 < < bit ) ) ;
ok ( GetLastError ( ) = = dwExpect , fmt , strExpect , GetLastError ( ) ) ;
GetSecurityDescriptorControl ( sec , & test , & dwRevision ) ;
expect_eq ( test , ctrl , int , " %x " ) ;
}
}
2007-09-27 21:01:49 +02:00
static void test_PrivateObjectSecurity ( void )
{
SECURITY_INFORMATION sec_info = OWNER_SECURITY_INFORMATION | GROUP_SECURITY_INFORMATION | DACL_SECURITY_INFORMATION | SACL_SECURITY_INFORMATION ;
SECURITY_DESCRIPTOR_CONTROL ctrl ;
PSECURITY_DESCRIPTOR sec ;
DWORD dwDescSize ;
DWORD dwRevision ;
DWORD retSize ;
LPSTR string ;
ULONG len ;
PSECURITY_DESCRIPTOR buf ;
2010-12-30 19:31:54 +01:00
BOOL ret ;
2007-09-27 21:01:49 +02:00
2008-01-08 10:18:17 +01:00
if ( ! pConvertStringSecurityDescriptorToSecurityDescriptorA )
{
2009-02-26 09:45:07 +01:00
win_skip ( " ConvertStringSecurityDescriptorToSecurityDescriptor is not available \n " ) ;
2008-01-08 10:18:17 +01:00
return ;
}
2008-10-17 19:44:14 +02:00
ok ( pConvertStringSecurityDescriptorToSecurityDescriptorA (
" O:SY "
" G:S-1-5-21-93476-23408-4576 "
" D:(A;NP;GAGXGWGR;;;SU)(A;IOID;CCDC;;;SU) "
" (D;OICI;0xffffffff;;;S-1-5-21-93476-23408-4576) "
" S:(AU;OICINPIOIDSAFA;CCDCLCSWRPRC;;;SU)(AU;NPSA;0x12019f;;;SU) " ,
SDDL_REVISION_1 , & sec , & dwDescSize ) , " Creating descriptor failed \n " ) ;
test_SetSecurityDescriptorControl ( sec ) ;
LocalFree ( sec ) ;
ok ( pConvertStringSecurityDescriptorToSecurityDescriptorA (
" O:SY "
" G:S-1-5-21-93476-23408-4576 " ,
SDDL_REVISION_1 , & sec , & dwDescSize ) , " Creating descriptor failed \n " ) ;
test_SetSecurityDescriptorControl ( sec ) ;
LocalFree ( sec ) ;
2007-11-02 11:33:36 +01:00
ok ( pConvertStringSecurityDescriptorToSecurityDescriptorA (
2007-09-27 21:01:49 +02:00
" O:SY "
" G:S-1-5-21-93476-23408-4576 "
" D:(A;NP;GAGXGWGR;;;SU)(A;IOID;CCDC;;;SU)(D;OICI;0xffffffff;;;S-1-5-21-93476-23408-4576) "
" S:(AU;OICINPIOIDSAFA;CCDCLCSWRPRC;;;SU)(AU;NPSA;0x12019f;;;SU) " , SDDL_REVISION_1 , & sec , & dwDescSize ) , " Creating descriptor failed \n " ) ;
buf = HeapAlloc ( GetProcessHeap ( ) , 0 , dwDescSize ) ;
2007-11-02 11:33:36 +01:00
pSetSecurityDescriptorControl ( sec , SE_DACL_PROTECTED , SE_DACL_PROTECTED ) ;
2007-09-27 21:01:49 +02:00
GetSecurityDescriptorControl ( sec , & ctrl , & dwRevision ) ;
2008-10-17 19:44:14 +02:00
expect_eq ( ctrl , 0x9014 , int , " %x " ) ;
2007-09-27 21:01:49 +02:00
2010-12-30 19:31:54 +01:00
ret = GetPrivateObjectSecurity ( sec , GROUP_SECURITY_INFORMATION , buf , dwDescSize , & retSize ) ;
ok ( ret , " GetPrivateObjectSecurity failed (err=%u) \n " , GetLastError ( ) ) ;
2007-09-27 21:01:49 +02:00
ok ( retSize < = dwDescSize , " Buffer too small (%d vs %d) \n " , retSize , dwDescSize ) ;
2007-10-02 09:19:49 +02:00
ok ( pConvertSecurityDescriptorToStringSecurityDescriptorA ( buf , SDDL_REVISION_1 , sec_info , & string , & len ) , " Conversion failed \n " ) ;
2007-09-27 21:01:49 +02:00
CHECK_RESULT_AND_FREE ( " G:S-1-5-21-93476-23408-4576 " ) ;
GetSecurityDescriptorControl ( buf , & ctrl , & dwRevision ) ;
expect_eq ( ctrl , 0x8000 , int , " %x " ) ;
2010-12-30 19:31:54 +01:00
ret = GetPrivateObjectSecurity ( sec , GROUP_SECURITY_INFORMATION | DACL_SECURITY_INFORMATION , buf , dwDescSize , & retSize ) ;
ok ( ret , " GetPrivateObjectSecurity failed (err=%u) \n " , GetLastError ( ) ) ;
2007-09-27 21:01:49 +02:00
ok ( retSize < = dwDescSize , " Buffer too small (%d vs %d) \n " , retSize , dwDescSize ) ;
2010-12-30 19:31:54 +01:00
ret = pConvertSecurityDescriptorToStringSecurityDescriptorA ( buf , SDDL_REVISION_1 , sec_info , & string , & len ) ;
ok ( ret , " Conversion failed err=%u \n " , GetLastError ( ) ) ;
2009-08-26 12:40:29 +02:00
CHECK_ONE_OF_AND_FREE ( " G:S-1-5-21-93476-23408-4576D:(A;NP;GAGXGWGR;;;SU)(A;IOID;CCDC;;;SU)(D;OICI;0xffffffff;;;S-1-5-21-93476-23408-4576) " ,
" G:S-1-5-21-93476-23408-4576D:P(A;NP;GAGXGWGR;;;SU)(A;IOID;CCDC;;;SU)(D;OICI;0xffffffff;;;S-1-5-21-93476-23408-4576) " ) ; /* Win7 */
2007-09-27 21:01:49 +02:00
GetSecurityDescriptorControl ( buf , & ctrl , & dwRevision ) ;
2009-08-26 12:40:29 +02:00
expect_eq ( ctrl & ( ~ SE_DACL_PROTECTED ) , 0x8004 , int , " %x " ) ;
2007-09-27 21:01:49 +02:00
2010-12-30 19:31:54 +01:00
ret = GetPrivateObjectSecurity ( sec , sec_info , buf , dwDescSize , & retSize ) ;
ok ( ret , " GetPrivateObjectSecurity failed (err=%u) \n " , GetLastError ( ) ) ;
2007-09-27 21:01:49 +02:00
ok ( retSize = = dwDescSize , " Buffer too small (%d vs %d) \n " , retSize , dwDescSize ) ;
2007-10-02 09:19:49 +02:00
ok ( pConvertSecurityDescriptorToStringSecurityDescriptorA ( buf , SDDL_REVISION_1 , sec_info , & string , & len ) , " Conversion failed \n " ) ;
2009-08-26 12:40:29 +02:00
CHECK_ONE_OF_AND_FREE ( " O:SY "
2007-09-27 21:01:49 +02:00
" G:S-1-5-21-93476-23408-4576 "
" D:(A;NP;GAGXGWGR;;;SU)(A;IOID;CCDC;;;SU)(D;OICI;0xffffffff;;;S-1-5-21-93476-23408-4576) "
2009-08-26 12:40:29 +02:00
" S:(AU;OICINPIOIDSAFA;CCDCLCSWRPRC;;;SU)(AU;NPSA;0x12019f;;;SU) " ,
" O:SY "
" G:S-1-5-21-93476-23408-4576 "
" D:P(A;NP;GAGXGWGR;;;SU)(A;IOID;CCDC;;;SU)(D;OICI;0xffffffff;;;S-1-5-21-93476-23408-4576) "
" S:(AU;OICINPIOIDSAFA;CCDCLCSWRPRC;;;SU)(AU;NPSA;0x12019f;;;SU) " ) ; /* Win7 */
2007-09-27 21:01:49 +02:00
GetSecurityDescriptorControl ( buf , & ctrl , & dwRevision ) ;
2009-08-26 12:40:29 +02:00
expect_eq ( ctrl & ( ~ SE_DACL_PROTECTED ) , 0x8014 , int , " %x " ) ;
2007-09-25 22:12:50 +02:00
2007-09-27 21:01:49 +02:00
SetLastError ( 0xdeadbeef ) ;
ok ( GetPrivateObjectSecurity ( sec , sec_info , buf , 5 , & retSize ) = = FALSE , " GetPrivateObjectSecurity should have failed \n " ) ;
ok ( GetLastError ( ) = = ERROR_INSUFFICIENT_BUFFER , " Expected error ERROR_INSUFFICIENT_BUFFER, got %u \n " , GetLastError ( ) ) ;
2007-09-25 22:12:50 +02:00
2007-09-27 21:01:49 +02:00
LocalFree ( sec ) ;
2007-10-02 08:59:02 +02:00
HeapFree ( GetProcessHeap ( ) , 0 , buf ) ;
2007-09-25 22:12:50 +02:00
}
2007-09-27 21:01:49 +02:00
# undef CHECK_RESULT_AND_FREE
2007-10-21 08:46:40 +02:00
# undef CHECK_ONE_OF_AND_FREE
2007-09-25 22:12:50 +02:00
2007-10-23 14:38:47 +02:00
static void test_acls ( void )
{
char buffer [ 256 ] ;
PACL pAcl = ( PACL ) buffer ;
BOOL ret ;
SetLastError ( 0xdeadbeef ) ;
ret = InitializeAcl ( pAcl , sizeof ( ACL ) - 1 , ACL_REVISION ) ;
2008-01-08 10:18:17 +01:00
if ( ! ret & & GetLastError ( ) = = ERROR_CALL_NOT_IMPLEMENTED )
{
2009-02-26 09:45:07 +01:00
win_skip ( " InitializeAcl is not implemented \n " ) ;
2008-01-08 10:18:17 +01:00
return ;
}
2007-10-23 14:38:47 +02:00
ok ( ! ret & & GetLastError ( ) = = ERROR_INSUFFICIENT_BUFFER , " InitializeAcl with too small a buffer should have failed with ERROR_INSUFFICIENT_BUFFER instead of %d \n " , GetLastError ( ) ) ;
SetLastError ( 0xdeadbeef ) ;
ret = InitializeAcl ( pAcl , 0xffffffff , ACL_REVISION ) ;
ok ( ! ret & & GetLastError ( ) = = ERROR_INVALID_PARAMETER , " InitializeAcl with too large a buffer should have failed with ERROR_INVALID_PARAMETER instead of %d \n " , GetLastError ( ) ) ;
SetLastError ( 0xdeadbeef ) ;
ret = InitializeAcl ( pAcl , sizeof ( buffer ) , ACL_REVISION1 ) ;
ok ( ! ret & & GetLastError ( ) = = ERROR_INVALID_PARAMETER , " InitializeAcl(ACL_REVISION1) should have failed with ERROR_INVALID_PARAMETER instead of %d \n " , GetLastError ( ) ) ;
ret = InitializeAcl ( pAcl , sizeof ( buffer ) , ACL_REVISION2 ) ;
ok ( ret , " InitializeAcl(ACL_REVISION2) failed with error %d \n " , GetLastError ( ) ) ;
ret = IsValidAcl ( pAcl ) ;
ok ( ret , " IsValidAcl failed with error %d \n " , GetLastError ( ) ) ;
ret = InitializeAcl ( pAcl , sizeof ( buffer ) , ACL_REVISION3 ) ;
ok ( ret , " InitializeAcl(ACL_REVISION3) failed with error %d \n " , GetLastError ( ) ) ;
ret = IsValidAcl ( pAcl ) ;
ok ( ret , " IsValidAcl failed with error %d \n " , GetLastError ( ) ) ;
2008-12-06 12:43:55 +01:00
SetLastError ( 0xdeadbeef ) ;
2007-10-23 14:38:47 +02:00
ret = InitializeAcl ( pAcl , sizeof ( buffer ) , ACL_REVISION4 ) ;
2008-12-06 12:43:55 +01:00
if ( GetLastError ( ) ! = ERROR_INVALID_PARAMETER )
{
ok ( ret , " InitializeAcl(ACL_REVISION4) failed with error %d \n " , GetLastError ( ) ) ;
2007-10-23 14:38:47 +02:00
2008-12-06 12:43:55 +01:00
ret = IsValidAcl ( pAcl ) ;
ok ( ret , " IsValidAcl failed with error %d \n " , GetLastError ( ) ) ;
}
else
win_skip ( " ACL_REVISION4 is not implemented on NT4 \n " ) ;
2007-10-23 14:38:47 +02:00
SetLastError ( 0xdeadbeef ) ;
ret = InitializeAcl ( pAcl , sizeof ( buffer ) , - 1 ) ;
ok ( ! ret & & GetLastError ( ) = = ERROR_INVALID_PARAMETER , " InitializeAcl(-1) failed with error %d \n " , GetLastError ( ) ) ;
}
2008-08-07 21:54:58 +02:00
static void test_GetSecurityInfo ( void )
{
2012-11-15 18:16:23 +01:00
char b [ sizeof ( TOKEN_USER ) + sizeof ( SID ) + sizeof ( DWORD ) * SID_MAX_SUB_AUTHORITIES ] ;
char admin_ptr [ sizeof ( SID ) + sizeof ( ULONG ) * SID_MAX_SUB_AUTHORITIES ] , dacl [ 100 ] ;
DWORD sid_size = sizeof ( admin_ptr ) , l = sizeof ( b ) ;
PSID admin_sid = ( PSID ) admin_ptr , user_sid ;
char sd [ SECURITY_DESCRIPTOR_MIN_LENGTH ] ;
ACL_SIZE_INFORMATION acl_size ;
PSECURITY_DESCRIPTOR pSD ;
ACCESS_ALLOWED_ACE * ace ;
HANDLE token , obj ;
2008-08-07 21:54:58 +02:00
PSID owner , group ;
2012-11-15 18:16:23 +01:00
BOOL bret = TRUE ;
PACL pDacl ;
2008-08-07 21:54:58 +02:00
DWORD ret ;
2012-11-15 18:16:23 +01:00
if ( ! pGetSecurityInfo | | ! pSetSecurityInfo )
{
win_skip ( " [Get|Set]SecurityInfo is not available \n " ) ;
return ;
}
if ( ! OpenThreadToken ( GetCurrentThread ( ) , TOKEN_READ , TRUE , & token ) )
{
if ( GetLastError ( ) ! = ERROR_NO_TOKEN ) bret = FALSE ;
else if ( ! OpenProcessToken ( GetCurrentProcess ( ) , TOKEN_READ , & token ) ) bret = FALSE ;
}
if ( ! bret )
2008-08-25 14:16:25 +02:00
{
2012-11-15 18:16:23 +01:00
win_skip ( " Failed to get current user token \n " ) ;
2008-08-25 14:16:25 +02:00
return ;
}
2012-11-15 18:16:23 +01:00
GetTokenInformation ( token , TokenUser , b , l , & l ) ;
CloseHandle ( token ) ;
user_sid = ( ( TOKEN_USER * ) b ) - > User . Sid ;
2008-08-25 14:16:25 +02:00
2008-08-07 21:54:58 +02:00
/* Create something. Files have lots of associated security info. */
2013-10-15 10:15:45 +02:00
obj = CreateFileA ( myARGV [ 0 ] , GENERIC_READ | WRITE_DAC , FILE_SHARE_READ , NULL ,
OPEN_EXISTING , FILE_ATTRIBUTE_NORMAL , NULL ) ;
2008-08-18 22:31:22 +02:00
if ( obj = = INVALID_HANDLE_VALUE )
2008-08-07 21:54:58 +02:00
{
skip ( " Couldn't create an object for GetSecurityInfo test \n " ) ;
return ;
}
2008-08-25 14:16:25 +02:00
ret = pGetSecurityInfo ( obj , SE_FILE_OBJECT ,
2008-08-07 21:54:58 +02:00
OWNER_SECURITY_INFORMATION | GROUP_SECURITY_INFORMATION | DACL_SECURITY_INFORMATION ,
2012-11-15 18:16:23 +01:00
& owner , & group , & pDacl , NULL , & pSD ) ;
2008-08-25 14:16:25 +02:00
if ( ret = = ERROR_CALL_NOT_IMPLEMENTED )
{
win_skip ( " GetSecurityInfo is not implemented \n " ) ;
CloseHandle ( obj ) ;
return ;
}
2008-08-07 21:54:58 +02:00
ok ( ret = = ERROR_SUCCESS , " GetSecurityInfo returned %d \n " , ret ) ;
2012-11-15 18:16:23 +01:00
ok ( pSD ! = NULL , " GetSecurityInfo \n " ) ;
2008-08-07 21:54:58 +02:00
ok ( owner ! = NULL , " GetSecurityInfo \n " ) ;
ok ( group ! = NULL , " GetSecurityInfo \n " ) ;
2012-11-15 18:16:23 +01:00
if ( pDacl ! = NULL )
ok ( IsValidAcl ( pDacl ) , " GetSecurityInfo \n " ) ;
2009-11-18 11:52:59 +01:00
else
win_skip ( " No ACL information returned \n " ) ;
2008-08-07 21:54:58 +02:00
2012-11-15 18:16:23 +01:00
LocalFree ( pSD ) ;
2008-08-08 00:14:06 +02:00
2008-11-29 12:38:30 +01:00
if ( ! pCreateWellKnownSid )
{
win_skip ( " NULL parameter test would crash on NT4 \n " ) ;
CloseHandle ( obj ) ;
return ;
}
2008-08-08 00:14:06 +02:00
/* If we don't ask for the security descriptor, Windows will still give us
the other stuff , leaving us no way to free it . */
2008-08-25 14:16:25 +02:00
ret = pGetSecurityInfo ( obj , SE_FILE_OBJECT ,
2008-08-08 00:14:06 +02:00
OWNER_SECURITY_INFORMATION | GROUP_SECURITY_INFORMATION | DACL_SECURITY_INFORMATION ,
2012-11-15 18:16:23 +01:00
& owner , & group , & pDacl , NULL , NULL ) ;
2008-08-08 00:14:06 +02:00
ok ( ret = = ERROR_SUCCESS , " GetSecurityInfo returned %d \n " , ret ) ;
ok ( owner ! = NULL , " GetSecurityInfo \n " ) ;
ok ( group ! = NULL , " GetSecurityInfo \n " ) ;
2012-11-15 18:16:23 +01:00
if ( pDacl ! = NULL )
ok ( IsValidAcl ( pDacl ) , " GetSecurityInfo \n " ) ;
2009-11-18 11:52:59 +01:00
else
win_skip ( " No ACL information returned \n " ) ;
2008-08-08 00:14:06 +02:00
2012-11-15 18:16:23 +01:00
/* Create security descriptor information and test that it comes back the same */
pSD = & sd ;
pDacl = ( PACL ) & dacl ;
InitializeSecurityDescriptor ( pSD , SECURITY_DESCRIPTOR_REVISION ) ;
pCreateWellKnownSid ( WinBuiltinAdministratorsSid , NULL , admin_sid , & sid_size ) ;
bret = InitializeAcl ( pDacl , sizeof ( dacl ) , ACL_REVISION ) ;
ok ( bret , " Failed to initialize ACL. \n " ) ;
bret = pAddAccessAllowedAceEx ( pDacl , ACL_REVISION , 0 , GENERIC_ALL , user_sid ) ;
ok ( bret , " Failed to add Current User to ACL. \n " ) ;
bret = pAddAccessAllowedAceEx ( pDacl , ACL_REVISION , 0 , GENERIC_ALL , admin_sid ) ;
ok ( bret , " Failed to add Administrator Group to ACL. \n " ) ;
bret = SetSecurityDescriptorDacl ( pSD , TRUE , pDacl , FALSE ) ;
ok ( bret , " Failed to add ACL to security desciptor. \n " ) ;
ret = pSetSecurityInfo ( obj , SE_FILE_OBJECT , DACL_SECURITY_INFORMATION ,
NULL , NULL , pDacl , NULL ) ;
ok ( ret = = ERROR_SUCCESS , " SetSecurityInfo returned %d \n " , ret ) ;
ret = pGetSecurityInfo ( obj , SE_FILE_OBJECT , DACL_SECURITY_INFORMATION ,
NULL , NULL , & pDacl , NULL , NULL ) ;
ok ( ret = = ERROR_SUCCESS , " GetSecurityInfo returned %d \n " , ret ) ;
ok ( pDacl & & IsValidAcl ( pDacl ) , " GetSecurityInfo returned invalid DACL. \n " ) ;
bret = pGetAclInformation ( pDacl , & acl_size , sizeof ( acl_size ) , AclSizeInformation ) ;
ok ( bret , " GetAclInformation failed \n " ) ;
if ( acl_size . AceCount > 0 )
{
bret = pGetAce ( pDacl , 0 , ( VOID * * ) & ace ) ;
ok ( bret , " Failed to get Current User ACE. \n " ) ;
bret = EqualSid ( & ace - > SidStart , user_sid ) ;
todo_wine ok ( bret , " Current User ACE != Current User SID. \n " ) ;
ok ( ( ( ACE_HEADER * ) ace ) - > AceFlags = = 0 ,
" Current User ACE has unexpected flags (0x%x != 0x0) \n " , ( ( ACE_HEADER * ) ace ) - > AceFlags ) ;
ok ( ace - > Mask = = 0x1f01ff , " Current User ACE has unexpected mask (0x%x != 0x1f01ff) \n " ,
ace - > Mask ) ;
}
if ( acl_size . AceCount > 1 )
{
bret = pGetAce ( pDacl , 1 , ( VOID * * ) & ace ) ;
ok ( bret , " Failed to get Administators Group ACE. \n " ) ;
bret = EqualSid ( & ace - > SidStart , admin_sid ) ;
todo_wine ok ( bret , " Administators Group ACE != Administators Group SID. \n " ) ;
ok ( ( ( ACE_HEADER * ) ace ) - > AceFlags = = 0 ,
" Administators Group ACE has unexpected flags (0x%x != 0x0) \n " , ( ( ACE_HEADER * ) ace ) - > AceFlags ) ;
ok ( ace - > Mask = = 0x1f01ff , " Administators Group ACE has unexpected mask (0x%x != 0x1f01ff) \n " ,
ace - > Mask ) ;
}
2008-08-07 21:54:58 +02:00
CloseHandle ( obj ) ;
}
2009-06-27 12:48:46 +02:00
static void test_GetSidSubAuthority ( void )
{
PSID psid = NULL ;
if ( ! pGetSidSubAuthority | | ! pConvertStringSidToSidA | | ! pIsValidSid | | ! pGetSidSubAuthorityCount )
{
win_skip ( " Some functions not available \n " ) ;
return ;
}
/* Note: on windows passing in an invalid index like -1, lets GetSidSubAuthority return 0x05000000 but
still GetLastError returns ERROR_SUCCESS then . We don ' t test these unlikely cornercases here for now */
ok ( pConvertStringSidToSidA ( " S-1-5-21-93476-23408-4576 " , & psid ) , " ConvertStringSidToSidA failed \n " ) ;
ok ( pIsValidSid ( psid ) , " Sid is not valid \n " ) ;
SetLastError ( 0xbebecaca ) ;
ok ( * pGetSidSubAuthorityCount ( psid ) = = 4 , " GetSidSubAuthorityCount gave %d expected 4 \n " , * pGetSidSubAuthorityCount ( psid ) ) ;
ok ( GetLastError ( ) = = 0 , " GetLastError returned %d instead of 0 \n " , GetLastError ( ) ) ;
SetLastError ( 0xbebecaca ) ;
2009-06-30 10:23:04 +02:00
ok ( * pGetSidSubAuthority ( psid , 0 ) = = 21 , " GetSidSubAuthority gave %d expected 21 \n " , * pGetSidSubAuthority ( psid , 0 ) ) ;
2009-06-27 12:48:46 +02:00
ok ( GetLastError ( ) = = 0 , " GetLastError returned %d instead of 0 \n " , GetLastError ( ) ) ;
SetLastError ( 0xbebecaca ) ;
2009-06-30 10:23:04 +02:00
ok ( * pGetSidSubAuthority ( psid , 1 ) = = 93476 , " GetSidSubAuthority gave %d expected 93476 \n " , * pGetSidSubAuthority ( psid , 1 ) ) ;
2009-06-27 12:48:46 +02:00
ok ( GetLastError ( ) = = 0 , " GetLastError returned %d instead of 0 \n " , GetLastError ( ) ) ;
SetLastError ( 0xbebecaca ) ;
2009-12-02 15:22:11 +01:00
ok ( pGetSidSubAuthority ( psid , 4 ) ! = NULL , " Expected out of bounds GetSidSubAuthority to return a non-NULL pointer \n " ) ;
2009-06-27 12:48:46 +02:00
ok ( GetLastError ( ) = = 0 , " GetLastError returned %d instead of 0 \n " , GetLastError ( ) ) ;
LocalFree ( psid ) ;
}
2009-11-08 11:23:09 +01:00
static void test_CheckTokenMembership ( void )
{
PTOKEN_GROUPS token_groups ;
DWORD size ;
2009-11-11 00:01:51 +01:00
HANDLE process_token , token ;
2009-11-08 11:23:09 +01:00
BOOL is_member ;
BOOL ret ;
DWORD i ;
2009-11-10 13:04:55 +01:00
if ( ! pCheckTokenMembership )
{
win_skip ( " CheckTokenMembership is not available \n " ) ;
return ;
}
2009-11-11 00:01:51 +01:00
ret = OpenProcessToken ( GetCurrentProcess ( ) , TOKEN_DUPLICATE | TOKEN_QUERY , & process_token ) ;
2009-11-08 11:23:09 +01:00
ok ( ret , " OpenProcessToken failed with error %d \n " , GetLastError ( ) ) ;
2009-11-11 00:01:51 +01:00
ret = DuplicateToken ( process_token , SecurityImpersonation , & token ) ;
ok ( ret , " DuplicateToken failed with error %d \n " , GetLastError ( ) ) ;
2009-11-08 11:23:09 +01:00
/* groups */
ret = GetTokenInformation ( token , TokenGroups , NULL , 0 , & size ) ;
ok ( ! ret & & GetLastError ( ) = = ERROR_INSUFFICIENT_BUFFER ,
" GetTokenInformation(TokenGroups) %s with error %d \n " ,
ret ? " succeeded " : " failed " , GetLastError ( ) ) ;
token_groups = HeapAlloc ( GetProcessHeap ( ) , 0 , size ) ;
ret = GetTokenInformation ( token , TokenGroups , token_groups , size , & size ) ;
ok ( ret , " GetTokenInformation(TokenGroups) failed with error %d \n " , GetLastError ( ) ) ;
for ( i = 0 ; i < token_groups - > GroupCount ; i + + )
{
if ( token_groups - > Groups [ i ] . Attributes & SE_GROUP_ENABLED )
break ;
}
if ( i = = token_groups - > GroupCount )
{
HeapFree ( GetProcessHeap ( ) , 0 , token_groups ) ;
CloseHandle ( token ) ;
skip ( " user not a member of any group \n " ) ;
return ;
}
2011-08-02 00:12:51 +02:00
is_member = FALSE ;
2009-11-10 13:04:55 +01:00
ret = pCheckTokenMembership ( token , token_groups - > Groups [ i ] . Sid , & is_member ) ;
2009-11-08 11:23:09 +01:00
ok ( ret , " CheckTokenMembership failed with error %d \n " , GetLastError ( ) ) ;
2009-11-11 00:01:51 +01:00
ok ( is_member , " CheckTokenMembership should have detected sid as member \n " ) ;
2011-08-02 00:12:51 +02:00
is_member = FALSE ;
2009-11-11 00:03:10 +01:00
ret = pCheckTokenMembership ( NULL , token_groups - > Groups [ i ] . Sid , & is_member ) ;
ok ( ret , " CheckTokenMembership failed with error %d \n " , GetLastError ( ) ) ;
ok ( is_member , " CheckTokenMembership should have detected sid as member \n " ) ;
2011-08-02 00:12:51 +02:00
is_member = TRUE ;
SetLastError ( 0xdeadbeef ) ;
2009-11-11 00:01:51 +01:00
ret = pCheckTokenMembership ( process_token , token_groups - > Groups [ i ] . Sid , & is_member ) ;
ok ( ! ret & & GetLastError ( ) = = ERROR_NO_IMPERSONATION_TOKEN ,
" CheckTokenMembership with process token %s with error %d \n " ,
ret ? " succeeded " : " failed " , GetLastError ( ) ) ;
ok ( ! is_member , " CheckTokenMembership should have cleared is_member \n " ) ;
2009-11-08 11:23:09 +01:00
HeapFree ( GetProcessHeap ( ) , 0 , token_groups ) ;
CloseHandle ( token ) ;
2009-11-11 00:01:51 +01:00
CloseHandle ( process_token ) ;
2009-11-08 11:23:09 +01:00
}
2009-11-15 17:37:05 +01:00
static void test_EqualSid ( void )
{
PSID sid1 , sid2 ;
BOOL ret ;
SID_IDENTIFIER_AUTHORITY SIDAuthWorld = { SECURITY_WORLD_SID_AUTHORITY } ;
SID_IDENTIFIER_AUTHORITY SIDAuthNT = { SECURITY_NT_AUTHORITY } ;
SetLastError ( 0xdeadbeef ) ;
ret = AllocateAndInitializeSid ( & SIDAuthNT , 2 , SECURITY_BUILTIN_DOMAIN_RID ,
DOMAIN_ALIAS_RID_ADMINS , 0 , 0 , 0 , 0 , 0 , 0 , & sid1 ) ;
2009-11-17 08:51:02 +01:00
if ( ! ret & & GetLastError ( ) = = ERROR_CALL_NOT_IMPLEMENTED )
{
win_skip ( " AllocateAndInitializeSid is not implemented \n " ) ;
return ;
}
2009-11-15 17:37:05 +01:00
ok ( ret , " AllocateAndInitializeSid failed with error %d \n " , GetLastError ( ) ) ;
ok ( GetLastError ( ) = = 0xdeadbeef ,
" AllocateAndInitializeSid shouldn't have set last error to %d \n " ,
GetLastError ( ) ) ;
ret = AllocateAndInitializeSid ( & SIDAuthWorld , 1 , SECURITY_WORLD_RID ,
0 , 0 , 0 , 0 , 0 , 0 , 0 , & sid2 ) ;
ok ( ret , " AllocateAndInitializeSid failed with error %d \n " , GetLastError ( ) ) ;
SetLastError ( 0xdeadbeef ) ;
ret = EqualSid ( sid1 , sid2 ) ;
ok ( ! ret , " World and domain admins sids shouldn't have been equal \n " ) ;
2009-11-17 09:48:44 +01:00
ok ( GetLastError ( ) = = ERROR_SUCCESS | |
broken ( GetLastError ( ) = = 0xdeadbeef ) , /* NT4 */
2009-11-15 17:37:05 +01:00
" EqualSid should have set last error to ERROR_SUCCESS instead of %d \n " ,
GetLastError ( ) ) ;
SetLastError ( 0xdeadbeef ) ;
sid2 = FreeSid ( sid2 ) ;
ok ( ! sid2 , " FreeSid should have returned NULL instead of %p \n " , sid2 ) ;
ok ( GetLastError ( ) = = 0xdeadbeef ,
" FreeSid shouldn't have set last error to %d \n " ,
GetLastError ( ) ) ;
ret = AllocateAndInitializeSid ( & SIDAuthNT , 2 , SECURITY_BUILTIN_DOMAIN_RID ,
DOMAIN_ALIAS_RID_ADMINS , 0 , 0 , 0 , 0 , 0 , 0 , & sid2 ) ;
ok ( ret , " AllocateAndInitializeSid failed with error %d \n " , GetLastError ( ) ) ;
SetLastError ( 0xdeadbeef ) ;
ret = EqualSid ( sid1 , sid2 ) ;
ok ( ret , " Same sids should have been equal \n " ) ;
2009-11-17 09:48:44 +01:00
ok ( GetLastError ( ) = = ERROR_SUCCESS | |
broken ( GetLastError ( ) = = 0xdeadbeef ) , /* NT4 */
2009-11-15 17:37:05 +01:00
" EqualSid should have set last error to ERROR_SUCCESS instead of %d \n " ,
GetLastError ( ) ) ;
( ( SID * ) sid2 ) - > Revision = 2 ;
SetLastError ( 0xdeadbeef ) ;
ret = EqualSid ( sid1 , sid2 ) ;
ok ( ! ret , " EqualSid with invalid sid should have returned FALSE \n " ) ;
2009-11-17 09:48:44 +01:00
ok ( GetLastError ( ) = = ERROR_SUCCESS | |
broken ( GetLastError ( ) = = 0xdeadbeef ) , /* NT4 */
2009-11-15 17:37:05 +01:00
" EqualSid should have set last error to ERROR_SUCCESS instead of %d \n " ,
GetLastError ( ) ) ;
( ( SID * ) sid2 ) - > Revision = SID_REVISION ;
FreeSid ( sid1 ) ;
FreeSid ( sid2 ) ;
}
2011-05-31 18:05:25 +02:00
static void test_GetUserNameA ( void )
{
char buffer [ UNLEN + 1 ] , filler [ UNLEN + 1 ] ;
DWORD required_len , buffer_len ;
BOOL ret ;
/* Test crashes on Windows. */
if ( 0 )
{
SetLastError ( 0xdeadbeef ) ;
GetUserNameA ( NULL , NULL ) ;
}
SetLastError ( 0xdeadbeef ) ;
required_len = 0 ;
ret = GetUserNameA ( NULL , & required_len ) ;
ok ( ret = = FALSE , " GetUserNameA returned %d \n " , ret ) ;
ok ( required_len ! = 0 , " Outputted buffer length was %u \n " , required_len ) ;
ok ( GetLastError ( ) = = ERROR_INSUFFICIENT_BUFFER , " Last error was %u \n " , GetLastError ( ) ) ;
SetLastError ( 0xdeadbeef ) ;
required_len = 1 ;
ret = GetUserNameA ( NULL , & required_len ) ;
ok ( ret = = FALSE , " GetUserNameA returned %d \n " , ret ) ;
ok ( required_len ! = 0 & & required_len ! = 1 , " Outputted buffer length was %u \n " , required_len ) ;
ok ( GetLastError ( ) = = ERROR_INSUFFICIENT_BUFFER , " Last error was %u \n " , GetLastError ( ) ) ;
/* Tests crashes on Windows. */
if ( 0 )
{
SetLastError ( 0xdeadbeef ) ;
required_len = UNLEN + 1 ;
GetUserNameA ( NULL , & required_len ) ;
SetLastError ( 0xdeadbeef ) ;
GetUserNameA ( buffer , NULL ) ;
}
memset ( filler , ' x ' , sizeof ( filler ) ) ;
/* Note that GetUserNameA on XP and newer outputs the number of bytes
* required for a Unicode string , which affects a test in the next block . */
SetLastError ( 0xdeadbeef ) ;
memcpy ( buffer , filler , sizeof ( filler ) ) ;
required_len = 0 ;
ret = GetUserNameA ( buffer , & required_len ) ;
ok ( ret = = FALSE , " GetUserNameA returned %d \n " , ret ) ;
ok ( ! memcmp ( buffer , filler , sizeof ( filler ) ) , " Output buffer was altered \n " ) ;
ok ( required_len ! = 0 , " Outputted buffer length was %u \n " , required_len ) ;
ok ( GetLastError ( ) = = ERROR_INSUFFICIENT_BUFFER , " Last error was %u \n " , GetLastError ( ) ) ;
SetLastError ( 0xdeadbeef ) ;
memcpy ( buffer , filler , sizeof ( filler ) ) ;
buffer_len = required_len ;
ret = GetUserNameA ( buffer , & buffer_len ) ;
ok ( ret = = TRUE , " GetUserNameA returned %d, last error %u \n " , ret , GetLastError ( ) ) ;
ok ( memcmp ( buffer , filler , sizeof ( filler ) ) ! = 0 , " Output buffer was untouched \n " ) ;
ok ( buffer_len = = required_len | |
broken ( buffer_len = = required_len / sizeof ( WCHAR ) ) , /* XP+ */
" Outputted buffer length was %u \n " , buffer_len ) ;
/* Use the reported buffer size from the last GetUserNameA call and pass
* a length that is one less than the required value . */
SetLastError ( 0xdeadbeef ) ;
memcpy ( buffer , filler , sizeof ( filler ) ) ;
buffer_len - - ;
ret = GetUserNameA ( buffer , & buffer_len ) ;
ok ( ret = = FALSE , " GetUserNameA returned %d \n " , ret ) ;
ok ( ! memcmp ( buffer , filler , sizeof ( filler ) ) , " Output buffer was untouched \n " ) ;
ok ( buffer_len = = required_len , " Outputted buffer length was %u \n " , buffer_len ) ;
ok ( GetLastError ( ) = = ERROR_INSUFFICIENT_BUFFER , " Last error was %u \n " , GetLastError ( ) ) ;
}
static void test_GetUserNameW ( void )
{
WCHAR buffer [ UNLEN + 1 ] , filler [ UNLEN + 1 ] ;
DWORD required_len , buffer_len ;
BOOL ret ;
/* Test crashes on Windows. */
if ( 0 )
{
SetLastError ( 0xdeadbeef ) ;
GetUserNameW ( NULL , NULL ) ;
}
SetLastError ( 0xdeadbeef ) ;
required_len = 0 ;
ret = GetUserNameW ( NULL , & required_len ) ;
ok ( ret = = FALSE , " GetUserNameW returned %d \n " , ret ) ;
ok ( required_len ! = 0 , " Outputted buffer length was %u \n " , required_len ) ;
ok ( GetLastError ( ) = = ERROR_INSUFFICIENT_BUFFER , " Last error was %u \n " , GetLastError ( ) ) ;
SetLastError ( 0xdeadbeef ) ;
required_len = 1 ;
ret = GetUserNameW ( NULL , & required_len ) ;
ok ( ret = = FALSE , " GetUserNameW returned %d \n " , ret ) ;
ok ( required_len ! = 0 & & required_len ! = 1 , " Outputted buffer length was %u \n " , required_len ) ;
ok ( GetLastError ( ) = = ERROR_INSUFFICIENT_BUFFER , " Last error was %u \n " , GetLastError ( ) ) ;
/* Tests crash on Windows. */
if ( 0 )
{
SetLastError ( 0xdeadbeef ) ;
required_len = UNLEN + 1 ;
GetUserNameW ( NULL , & required_len ) ;
SetLastError ( 0xdeadbeef ) ;
GetUserNameW ( buffer , NULL ) ;
}
memset ( filler , ' x ' , sizeof ( filler ) ) ;
SetLastError ( 0xdeadbeef ) ;
memcpy ( buffer , filler , sizeof ( filler ) ) ;
required_len = 0 ;
ret = GetUserNameW ( buffer , & required_len ) ;
ok ( ret = = FALSE , " GetUserNameW returned %d \n " , ret ) ;
ok ( ! memcmp ( buffer , filler , sizeof ( filler ) ) , " Output buffer was altered \n " ) ;
ok ( required_len ! = 0 , " Outputted buffer length was %u \n " , required_len ) ;
ok ( GetLastError ( ) = = ERROR_INSUFFICIENT_BUFFER , " Last error was %u \n " , GetLastError ( ) ) ;
SetLastError ( 0xdeadbeef ) ;
memcpy ( buffer , filler , sizeof ( filler ) ) ;
buffer_len = required_len ;
ret = GetUserNameW ( buffer , & buffer_len ) ;
ok ( ret = = TRUE , " GetUserNameW returned %d, last error %u \n " , ret , GetLastError ( ) ) ;
ok ( memcmp ( buffer , filler , sizeof ( filler ) ) ! = 0 , " Output buffer was untouched \n " ) ;
ok ( buffer_len = = required_len , " Outputted buffer length was %u \n " , buffer_len ) ;
/* GetUserNameW on XP and newer writes a truncated portion of the username string to the buffer. */
SetLastError ( 0xdeadbeef ) ;
memcpy ( buffer , filler , sizeof ( filler ) ) ;
buffer_len - - ;
ret = GetUserNameW ( buffer , & buffer_len ) ;
ok ( ret = = FALSE , " GetUserNameW returned %d \n " , ret ) ;
ok ( ! memcmp ( buffer , filler , sizeof ( filler ) ) | |
broken ( memcmp ( buffer , filler , sizeof ( filler ) ) ! = 0 ) , /* XP+ */
" Output buffer was altered \n " ) ;
ok ( buffer_len = = required_len , " Outputted buffer length was %u \n " , buffer_len ) ;
ok ( GetLastError ( ) = = ERROR_INSUFFICIENT_BUFFER , " Last error was %u \n " , GetLastError ( ) ) ;
}
2011-08-02 09:09:18 +02:00
static void test_CreateRestrictedToken ( void )
{
HANDLE process_token , token , r_token ;
PTOKEN_GROUPS token_groups , groups2 ;
SID_AND_ATTRIBUTES sattr ;
2013-01-16 10:56:47 +01:00
SECURITY_IMPERSONATION_LEVEL level ;
TOKEN_TYPE type ;
2011-08-02 09:09:18 +02:00
BOOL is_member ;
DWORD size ;
BOOL ret ;
DWORD i , j ;
if ( ! pCreateRestrictedToken )
{
win_skip ( " CreateRestrictedToken is not available \n " ) ;
return ;
}
ret = OpenProcessToken ( GetCurrentProcess ( ) , TOKEN_DUPLICATE | TOKEN_QUERY , & process_token ) ;
ok ( ret , " got error %d \n " , GetLastError ( ) ) ;
ret = DuplicateTokenEx ( process_token , TOKEN_DUPLICATE | TOKEN_ADJUST_GROUPS | TOKEN_QUERY ,
NULL , SecurityImpersonation , TokenImpersonation , & token ) ;
ok ( ret , " got error %d \n " , GetLastError ( ) ) ;
/* groups */
ret = GetTokenInformation ( token , TokenGroups , NULL , 0 , & size ) ;
ok ( ! ret & & GetLastError ( ) = = ERROR_INSUFFICIENT_BUFFER ,
" got %d with error %d \n " , ret , GetLastError ( ) ) ;
token_groups = HeapAlloc ( GetProcessHeap ( ) , 0 , size ) ;
ret = GetTokenInformation ( token , TokenGroups , token_groups , size , & size ) ;
ok ( ret , " got error %d \n " , GetLastError ( ) ) ;
for ( i = 0 ; i < token_groups - > GroupCount ; i + + )
{
if ( token_groups - > Groups [ i ] . Attributes & SE_GROUP_ENABLED )
break ;
}
if ( i = = token_groups - > GroupCount )
{
HeapFree ( GetProcessHeap ( ) , 0 , token_groups ) ;
CloseHandle ( token ) ;
skip ( " User not a member of any group \n " ) ;
return ;
}
is_member = FALSE ;
ret = pCheckTokenMembership ( token , token_groups - > Groups [ i ] . Sid , & is_member ) ;
ok ( ret , " got error %d \n " , GetLastError ( ) ) ;
ok ( is_member , " not a member \n " ) ;
/* disable a SID in new token */
sattr . Sid = token_groups - > Groups [ i ] . Sid ;
sattr . Attributes = 0 ;
2011-08-06 11:33:38 +02:00
r_token = NULL ;
2011-08-02 09:09:18 +02:00
ret = pCreateRestrictedToken ( token , 0 , 1 , & sattr , 0 , NULL , 0 , NULL , & r_token ) ;
2013-01-16 10:56:47 +01:00
ok ( ret , " got error %d \n " , GetLastError ( ) ) ;
2011-08-02 09:09:18 +02:00
if ( ret )
{
/* check if a SID is enabled */
is_member = TRUE ;
ret = pCheckTokenMembership ( r_token , token_groups - > Groups [ i ] . Sid , & is_member ) ;
ok ( ret , " got error %d \n " , GetLastError ( ) ) ;
2013-01-16 10:56:47 +01:00
todo_wine ok ( ! is_member , " not a member \n " ) ;
2011-08-02 09:09:18 +02:00
ret = GetTokenInformation ( r_token , TokenGroups , NULL , 0 , & size ) ;
ok ( ! ret & & GetLastError ( ) = = ERROR_INSUFFICIENT_BUFFER , " got %d with error %d \n " ,
ret , GetLastError ( ) ) ;
groups2 = HeapAlloc ( GetProcessHeap ( ) , 0 , size ) ;
ret = GetTokenInformation ( r_token , TokenGroups , groups2 , size , & size ) ;
ok ( ret , " got error %d \n " , GetLastError ( ) ) ;
for ( j = 0 ; j < groups2 - > GroupCount ; j + + )
{
if ( EqualSid ( groups2 - > Groups [ j ] . Sid , token_groups - > Groups [ i ] . Sid ) )
break ;
}
2013-01-16 10:56:47 +01:00
todo_wine ok ( groups2 - > Groups [ j ] . Attributes & SE_GROUP_USE_FOR_DENY_ONLY ,
2011-08-02 09:09:18 +02:00
" got wrong attributes \n " ) ;
2013-01-16 10:56:47 +01:00
todo_wine ok ( ( groups2 - > Groups [ j ] . Attributes & SE_GROUP_ENABLED ) = = 0 ,
2011-08-02 09:09:18 +02:00
" got wrong attributes \n " ) ;
HeapFree ( GetProcessHeap ( ) , 0 , groups2 ) ;
2013-01-16 10:56:47 +01:00
size = sizeof ( type ) ;
ret = GetTokenInformation ( r_token , TokenType , & type , size , & size ) ;
ok ( ret , " got error %d \n " , GetLastError ( ) ) ;
ok ( type = = TokenImpersonation , " got type %u \n " , type ) ;
size = sizeof ( level ) ;
ret = GetTokenInformation ( r_token , TokenImpersonationLevel , & level , size , & size ) ;
ok ( ret , " got error %d \n " , GetLastError ( ) ) ;
ok ( level = = SecurityImpersonation , " got level %u \n " , type ) ;
2011-08-02 09:09:18 +02:00
}
HeapFree ( GetProcessHeap ( ) , 0 , token_groups ) ;
CloseHandle ( r_token ) ;
CloseHandle ( token ) ;
CloseHandle ( process_token ) ;
}
2012-03-15 09:10:42 +01:00
static void validate_default_security_descriptor ( SECURITY_DESCRIPTOR * sd )
{
BOOL ret , present , defaulted ;
ACL * acl ;
void * sid ;
2012-04-18 09:29:46 +02:00
ret = IsValidSecurityDescriptor ( sd ) ;
ok ( ret , " security descriptor is not valid \n " ) ;
2012-03-15 09:10:42 +01:00
present = - 1 ;
defaulted = - 1 ;
acl = ( void * ) 0xdeadbeef ;
SetLastError ( 0xdeadbeef ) ;
ret = GetSecurityDescriptorDacl ( sd , & present , & acl , & defaulted ) ;
ok ( ret , " GetSecurityDescriptorDacl error %d \n " , GetLastError ( ) ) ;
todo_wine
ok ( present = = 1 , " acl is not present \n " ) ;
todo_wine
ok ( acl ! = ( void * ) 0xdeadbeef & & acl ! = NULL , " acl pointer is not set \n " ) ;
ok ( defaulted = = 0 , " defaulted is set to TRUE \n " ) ;
defaulted = - 1 ;
sid = ( void * ) 0xdeadbeef ;
SetLastError ( 0xdeadbeef ) ;
ret = GetSecurityDescriptorOwner ( sd , & sid , & defaulted ) ;
ok ( ret , " GetSecurityDescriptorOwner error %d \n " , GetLastError ( ) ) ;
todo_wine
ok ( sid ! = ( void * ) 0xdeadbeef & & sid ! = NULL , " sid pointer is not set \n " ) ;
ok ( defaulted = = 0 , " defaulted is set to TRUE \n " ) ;
defaulted = - 1 ;
sid = ( void * ) 0xdeadbeef ;
SetLastError ( 0xdeadbeef ) ;
ret = GetSecurityDescriptorGroup ( sd , & sid , & defaulted ) ;
ok ( ret , " GetSecurityDescriptorGroup error %d \n " , GetLastError ( ) ) ;
todo_wine
ok ( sid ! = ( void * ) 0xdeadbeef & & sid ! = NULL , " sid pointer is not set \n " ) ;
ok ( defaulted = = 0 , " defaulted is set to TRUE \n " ) ;
}
static void test_default_handle_security ( HANDLE token , HANDLE handle , GENERIC_MAPPING * mapping )
{
DWORD ret , length , needed , granted , priv_set_len ;
BOOL status ;
PRIVILEGE_SET priv_set ;
SECURITY_DESCRIPTOR * sd ;
needed = 0xdeadbeef ;
SetLastError ( 0xdeadbeef ) ;
ret = GetKernelObjectSecurity ( handle , OWNER_SECURITY_INFORMATION | GROUP_SECURITY_INFORMATION | DACL_SECURITY_INFORMATION ,
NULL , 0 , & needed ) ;
ok ( ! ret , " GetKernelObjectSecurity should fail \n " ) ;
ok ( GetLastError ( ) = = ERROR_INSUFFICIENT_BUFFER , " expected ERROR_INSUFFICIENT_BUFFER, got %d \n " , GetLastError ( ) ) ;
ok ( needed ! = 0xdeadbeef , " GetKernelObjectSecurity should return required buffer length \n " ) ;
length = needed ;
sd = HeapAlloc ( GetProcessHeap ( ) , 0 , length ) ;
2012-04-18 09:29:46 +02:00
needed = 0xdeadbeef ;
2012-03-15 09:10:42 +01:00
SetLastError ( 0xdeadbeef ) ;
ret = GetKernelObjectSecurity ( handle , OWNER_SECURITY_INFORMATION | GROUP_SECURITY_INFORMATION | DACL_SECURITY_INFORMATION ,
sd , length , & needed ) ;
ok ( ret , " GetKernelObjectSecurity error %d \n " , GetLastError ( ) ) ;
2012-04-18 09:30:04 +02:00
ok ( needed = = length | | needed = = 0 /* file, pipe */ , " GetKernelObjectSecurity should return %u instead of %u \n " , length , needed ) ;
2012-03-15 09:10:42 +01:00
validate_default_security_descriptor ( sd ) ;
priv_set_len = sizeof ( priv_set ) ;
granted = 0xdeadbeef ;
status = 0xdeadbeef ;
SetLastError ( 0xdeadbeef ) ;
ret = AccessCheck ( sd , token , MAXIMUM_ALLOWED , mapping , & priv_set , & priv_set_len , & granted , & status ) ;
todo_wine {
ok ( ret , " AccessCheck error %d \n " , GetLastError ( ) ) ;
ok ( status = = 1 , " expected 1, got %d \n " , status ) ;
2012-04-18 09:29:46 +02:00
ok ( granted = = mapping - > GenericAll , " expected all access %#x, got %#x \n " , mapping - > GenericAll , granted ) ;
2012-03-16 11:31:11 +01:00
}
priv_set_len = sizeof ( priv_set ) ;
granted = 0xdeadbeef ;
status = 0xdeadbeef ;
SetLastError ( 0xdeadbeef ) ;
ret = AccessCheck ( sd , token , 0 , mapping , & priv_set , & priv_set_len , & granted , & status ) ;
todo_wine {
ok ( ret , " AccessCheck error %d \n " , GetLastError ( ) ) ;
ok ( status = = 0 | | broken ( status = = 1 ) /* NT4 */ , " expected 0, got %d \n " , status ) ;
ok ( granted = = 0 | | broken ( granted = = mapping - > GenericRead ) /* NT4 */ , " expected 0, got %#x \n " , granted ) ;
}
priv_set_len = sizeof ( priv_set ) ;
granted = 0xdeadbeef ;
status = 0xdeadbeef ;
SetLastError ( 0xdeadbeef ) ;
ret = AccessCheck ( sd , token , ACCESS_SYSTEM_SECURITY , mapping , & priv_set , & priv_set_len , & granted , & status ) ;
todo_wine {
ok ( ret , " AccessCheck error %d \n " , GetLastError ( ) ) ;
ok ( status = = 0 , " expected 0, got %d \n " , status ) ;
ok ( granted = = 0 , " expected 0, got %#x \n " , granted ) ;
2012-04-18 09:29:46 +02:00
}
priv_set_len = sizeof ( priv_set ) ;
granted = 0xdeadbeef ;
status = 0xdeadbeef ;
SetLastError ( 0xdeadbeef ) ;
ret = AccessCheck ( sd , token , mapping - > GenericRead , mapping , & priv_set , & priv_set_len , & granted , & status ) ;
todo_wine {
ok ( ret , " AccessCheck error %d \n " , GetLastError ( ) ) ;
ok ( status = = 1 , " expected 1, got %d \n " , status ) ;
ok ( granted = = mapping - > GenericRead , " expected read access %#x, got %#x \n " , mapping - > GenericRead , granted ) ;
}
priv_set_len = sizeof ( priv_set ) ;
granted = 0xdeadbeef ;
status = 0xdeadbeef ;
SetLastError ( 0xdeadbeef ) ;
ret = AccessCheck ( sd , token , mapping - > GenericWrite , mapping , & priv_set , & priv_set_len , & granted , & status ) ;
todo_wine {
ok ( ret , " AccessCheck error %d \n " , GetLastError ( ) ) ;
ok ( status = = 1 , " expected 1, got %d \n " , status ) ;
ok ( granted = = mapping - > GenericWrite , " expected write access %#x, got %#x \n " , mapping - > GenericWrite , granted ) ;
}
priv_set_len = sizeof ( priv_set ) ;
granted = 0xdeadbeef ;
status = 0xdeadbeef ;
SetLastError ( 0xdeadbeef ) ;
ret = AccessCheck ( sd , token , mapping - > GenericExecute , mapping , & priv_set , & priv_set_len , & granted , & status ) ;
todo_wine {
ok ( ret , " AccessCheck error %d \n " , GetLastError ( ) ) ;
ok ( status = = 1 , " expected 1, got %d \n " , status ) ;
ok ( granted = = mapping - > GenericExecute , " expected execute access %#x, got %#x \n " , mapping - > GenericExecute , granted ) ;
2012-03-15 09:10:42 +01:00
}
HeapFree ( GetProcessHeap ( ) , 0 , sd ) ;
}
2013-12-26 08:34:05 +01:00
static ACCESS_MASK get_obj_access ( HANDLE obj )
{
OBJECT_BASIC_INFORMATION info ;
NTSTATUS status ;
if ( ! pNtQueryObject ) return 0 ;
status = pNtQueryObject ( obj , ObjectBasicInformation , & info , sizeof ( info ) , NULL ) ;
ok ( ! status , " NtQueryObject error %#x \n " , status ) ;
return info . GrantedAccess ;
}
2012-03-15 09:10:42 +01:00
static void test_mutex_security ( HANDLE token )
{
2013-12-26 08:34:05 +01:00
DWORD ret , i , access ;
HANDLE mutex , dup ;
2012-04-18 09:29:46 +02:00
GENERIC_MAPPING mapping = { STANDARD_RIGHTS_READ | MUTANT_QUERY_STATE | SYNCHRONIZE ,
STANDARD_RIGHTS_WRITE | MUTEX_MODIFY_STATE | SYNCHRONIZE ,
2012-03-15 09:10:42 +01:00
STANDARD_RIGHTS_EXECUTE | SYNCHRONIZE ,
STANDARD_RIGHTS_ALL | MUTEX_ALL_ACCESS } ;
2013-12-26 08:34:05 +01:00
static const struct
{
2014-01-30 06:48:10 +01:00
int generic , mapped ;
2013-12-26 08:34:05 +01:00
} map [ ] =
{
2014-01-30 06:48:10 +01:00
{ 0 , 0 } ,
{ GENERIC_READ , STANDARD_RIGHTS_READ | MUTANT_QUERY_STATE } ,
{ GENERIC_WRITE , STANDARD_RIGHTS_WRITE } ,
{ GENERIC_EXECUTE , STANDARD_RIGHTS_EXECUTE | SYNCHRONIZE } ,
{ GENERIC_ALL , STANDARD_RIGHTS_ALL | MUTANT_QUERY_STATE }
2013-12-26 08:34:05 +01:00
} ;
2012-03-15 09:10:42 +01:00
SetLastError ( 0xdeadbeef ) ;
2013-10-15 10:15:45 +02:00
mutex = OpenMutexA ( 0 , FALSE , " WineTestMutex " ) ;
2012-03-15 09:10:42 +01:00
ok ( ! mutex , " mutex should not exist \n " ) ;
ok ( GetLastError ( ) = = ERROR_FILE_NOT_FOUND , " wrong error %u \n " , GetLastError ( ) ) ;
SetLastError ( 0xdeadbeef ) ;
2013-10-15 10:15:45 +02:00
mutex = CreateMutexA ( NULL , FALSE , " WineTestMutex " ) ;
2012-03-15 09:10:42 +01:00
ok ( mutex ! = 0 , " CreateMutex error %d \n " , GetLastError ( ) ) ;
2013-12-26 08:34:05 +01:00
access = get_obj_access ( mutex ) ;
ok ( access = = MUTANT_ALL_ACCESS , " expected MUTANT_ALL_ACCESS, got %#x \n " , access ) ;
for ( i = 0 ; i < sizeof ( map ) / sizeof ( map [ 0 ] ) ; i + + )
{
SetLastError ( 0xdeadbeef ) ;
ret = DuplicateHandle ( GetCurrentProcess ( ) , mutex , GetCurrentProcess ( ) , & dup ,
map [ i ] . generic , FALSE , 0 ) ;
ok ( ret , " DuplicateHandle error %d \n " , GetLastError ( ) ) ;
access = get_obj_access ( dup ) ;
ok ( access = = map [ i ] . mapped , " %d: expected %#x, got %#x \n " , i , map [ i ] . mapped , access ) ;
CloseHandle ( dup ) ;
2014-01-10 10:25:58 +01:00
SetLastError ( 0xdeadbeef ) ;
dup = OpenMutexA ( 0 , FALSE , " WineTestMutex " ) ;
todo_wine
ok ( ! dup , " OpenMutex should fail \n " ) ;
todo_wine
ok ( GetLastError ( ) = = ERROR_ACCESS_DENIED , " wrong error %u \n " , GetLastError ( ) ) ;
2013-12-26 08:34:05 +01:00
}
2012-03-15 09:10:42 +01:00
test_default_handle_security ( token , mutex , & mapping ) ;
CloseHandle ( mutex ) ;
}
2012-03-16 11:31:43 +01:00
static void test_event_security ( HANDLE token )
{
2013-12-26 08:34:10 +01:00
DWORD ret , i , access ;
HANDLE event , dup ;
2012-04-18 09:29:46 +02:00
GENERIC_MAPPING mapping = { STANDARD_RIGHTS_READ | EVENT_QUERY_STATE | SYNCHRONIZE ,
STANDARD_RIGHTS_WRITE | EVENT_MODIFY_STATE | SYNCHRONIZE ,
2012-03-16 11:31:43 +01:00
STANDARD_RIGHTS_EXECUTE | SYNCHRONIZE ,
STANDARD_RIGHTS_ALL | EVENT_ALL_ACCESS } ;
2013-12-26 08:34:10 +01:00
static const struct
{
2014-01-16 10:32:52 +01:00
int generic , mapped ;
2013-12-26 08:34:10 +01:00
} map [ ] =
{
2014-01-16 10:32:52 +01:00
{ 0 , 0 } ,
{ GENERIC_READ , STANDARD_RIGHTS_READ | EVENT_QUERY_STATE } ,
{ GENERIC_WRITE , STANDARD_RIGHTS_WRITE | EVENT_MODIFY_STATE } ,
{ GENERIC_EXECUTE , STANDARD_RIGHTS_EXECUTE | SYNCHRONIZE } ,
{ GENERIC_ALL , STANDARD_RIGHTS_ALL | EVENT_QUERY_STATE | EVENT_MODIFY_STATE }
2013-12-26 08:34:10 +01:00
} ;
2012-03-16 11:31:43 +01:00
SetLastError ( 0xdeadbeef ) ;
2013-10-15 10:15:45 +02:00
event = OpenEventA ( 0 , FALSE , " WineTestEvent " ) ;
2012-03-16 11:31:43 +01:00
ok ( ! event , " event should not exist \n " ) ;
ok ( GetLastError ( ) = = ERROR_FILE_NOT_FOUND , " wrong error %u \n " , GetLastError ( ) ) ;
SetLastError ( 0xdeadbeef ) ;
2013-10-15 10:15:45 +02:00
event = CreateEventA ( NULL , FALSE , FALSE , " WineTestEvent " ) ;
2012-03-16 11:31:43 +01:00
ok ( event ! = 0 , " CreateEvent error %d \n " , GetLastError ( ) ) ;
2013-12-26 08:34:10 +01:00
access = get_obj_access ( event ) ;
ok ( access = = EVENT_ALL_ACCESS , " expected EVENT_ALL_ACCESS, got %#x \n " , access ) ;
for ( i = 0 ; i < sizeof ( map ) / sizeof ( map [ 0 ] ) ; i + + )
{
SetLastError ( 0xdeadbeef ) ;
ret = DuplicateHandle ( GetCurrentProcess ( ) , event , GetCurrentProcess ( ) , & dup ,
map [ i ] . generic , FALSE , 0 ) ;
ok ( ret , " DuplicateHandle error %d \n " , GetLastError ( ) ) ;
access = get_obj_access ( dup ) ;
ok ( access = = map [ i ] . mapped , " %d: expected %#x, got %#x \n " , i , map [ i ] . mapped , access ) ;
CloseHandle ( dup ) ;
2014-01-10 10:26:02 +01:00
SetLastError ( 0xdeadbeef ) ;
dup = OpenEventA ( 0 , FALSE , " WineTestEvent " ) ;
todo_wine
ok ( ! dup , " OpenEvent should fail \n " ) ;
todo_wine
ok ( GetLastError ( ) = = ERROR_ACCESS_DENIED , " wrong error %u \n " , GetLastError ( ) ) ;
2013-12-26 08:34:10 +01:00
}
2012-03-16 11:31:43 +01:00
test_default_handle_security ( token , event , & mapping ) ;
CloseHandle ( event ) ;
}
2013-12-26 08:34:14 +01:00
static void test_semaphore_security ( HANDLE token )
{
DWORD ret , i , access ;
HANDLE sem , dup ;
GENERIC_MAPPING mapping = { STANDARD_RIGHTS_READ | SEMAPHORE_QUERY_STATE ,
STANDARD_RIGHTS_WRITE | SEMAPHORE_MODIFY_STATE ,
STANDARD_RIGHTS_EXECUTE | SYNCHRONIZE ,
STANDARD_RIGHTS_ALL | SEMAPHORE_ALL_ACCESS } ;
static const struct
{
2014-01-31 07:28:04 +01:00
int generic , mapped ;
2013-12-26 08:34:14 +01:00
} map [ ] =
{
2014-01-31 07:28:04 +01:00
{ 0 , 0 } ,
{ GENERIC_READ , STANDARD_RIGHTS_READ | SEMAPHORE_QUERY_STATE } ,
{ GENERIC_WRITE , STANDARD_RIGHTS_WRITE | SEMAPHORE_MODIFY_STATE } ,
{ GENERIC_EXECUTE , STANDARD_RIGHTS_EXECUTE | SYNCHRONIZE } ,
{ GENERIC_ALL , STANDARD_RIGHTS_ALL | SEMAPHORE_QUERY_STATE | SEMAPHORE_MODIFY_STATE }
2013-12-26 08:34:14 +01:00
} ;
SetLastError ( 0xdeadbeef ) ;
sem = OpenSemaphoreA ( 0 , FALSE , " WineTestSemaphore " ) ;
ok ( ! sem , " semaphore should not exist \n " ) ;
ok ( GetLastError ( ) = = ERROR_FILE_NOT_FOUND , " wrong error %u \n " , GetLastError ( ) ) ;
SetLastError ( 0xdeadbeef ) ;
sem = CreateSemaphoreA ( NULL , 0 , 10 , " WineTestSemaphore " ) ;
ok ( sem ! = 0 , " CreateSemaphore error %d \n " , GetLastError ( ) ) ;
access = get_obj_access ( sem ) ;
ok ( access = = SEMAPHORE_ALL_ACCESS , " expected SEMAPHORE_ALL_ACCESS, got %#x \n " , access ) ;
for ( i = 0 ; i < sizeof ( map ) / sizeof ( map [ 0 ] ) ; i + + )
{
SetLastError ( 0xdeadbeef ) ;
ret = DuplicateHandle ( GetCurrentProcess ( ) , sem , GetCurrentProcess ( ) , & dup ,
map [ i ] . generic , FALSE , 0 ) ;
ok ( ret , " DuplicateHandle error %d \n " , GetLastError ( ) ) ;
access = get_obj_access ( dup ) ;
ok ( access = = map [ i ] . mapped , " %d: expected %#x, got %#x \n " , i , map [ i ] . mapped , access ) ;
CloseHandle ( dup ) ;
}
test_default_handle_security ( token , sem , & mapping ) ;
CloseHandle ( sem ) ;
}
2012-04-18 09:30:04 +02:00
# define WINE_TEST_PIPE "\\\\.\\pipe\\WineTestPipe"
static void test_named_pipe_security ( HANDLE token )
{
2013-12-26 08:34:18 +01:00
DWORD ret , i , access ;
HANDLE pipe , file , dup ;
2012-04-18 09:30:04 +02:00
GENERIC_MAPPING mapping = { FILE_GENERIC_READ ,
FILE_GENERIC_WRITE ,
FILE_GENERIC_EXECUTE ,
STANDARD_RIGHTS_ALL | FILE_ALL_ACCESS } ;
2013-12-26 08:34:18 +01:00
static const struct
{
int todo , generic , mapped ;
} map [ ] =
{
2014-01-10 10:25:53 +01:00
{ 0 , 0 , 0 } ,
2013-12-26 08:34:18 +01:00
{ 1 , GENERIC_READ , FILE_GENERIC_READ } ,
{ 1 , GENERIC_WRITE , FILE_GENERIC_WRITE } ,
{ 1 , GENERIC_EXECUTE , FILE_GENERIC_EXECUTE } ,
{ 1 , GENERIC_ALL , STANDARD_RIGHTS_ALL | FILE_ALL_ACCESS }
} ;
2014-02-05 16:35:30 +01:00
static const struct
{
DWORD open_mode ;
DWORD access ;
} creation_access [ ] =
{
{ PIPE_ACCESS_INBOUND , FILE_GENERIC_READ } ,
{ PIPE_ACCESS_OUTBOUND , FILE_GENERIC_WRITE } ,
{ PIPE_ACCESS_DUPLEX , FILE_GENERIC_READ | FILE_GENERIC_WRITE } ,
{ PIPE_ACCESS_INBOUND | WRITE_DAC , FILE_GENERIC_READ | WRITE_DAC } ,
{ PIPE_ACCESS_INBOUND | WRITE_OWNER , FILE_GENERIC_READ | WRITE_OWNER }
/* ACCESS_SYSTEM_SECURITY is also valid, but will fail with ERROR_PRIVILEGE_NOT_HELD */
} ;
/* Test the different security access options for pipes */
for ( i = 0 ; i < sizeof ( creation_access ) / sizeof ( creation_access [ 0 ] ) ; i + + )
{
SetLastError ( 0xdeadbeef ) ;
pipe = CreateNamedPipeA ( WINE_TEST_PIPE , creation_access [ i ] . open_mode ,
PIPE_TYPE_BYTE | PIPE_NOWAIT , PIPE_UNLIMITED_INSTANCES , 0 , 0 ,
NMPWAIT_USE_DEFAULT_WAIT , NULL ) ;
ok ( pipe ! = INVALID_HANDLE_VALUE , " CreateNamedPipe(0x%x) error %d \n " ,
creation_access [ i ] . open_mode , GetLastError ( ) ) ;
access = get_obj_access ( pipe ) ;
ok ( access = = creation_access [ i ] . access ,
" CreateNamedPipeA(0x%x) pipe expected access 0x%x (got 0x%x) \n " ,
creation_access [ i ] . open_mode , creation_access [ i ] . access , access ) ;
CloseHandle ( pipe ) ;
}
2012-04-18 09:30:04 +02:00
SetLastError ( 0xdeadbeef ) ;
2013-10-15 10:15:45 +02:00
pipe = CreateNamedPipeA ( WINE_TEST_PIPE , PIPE_ACCESS_DUPLEX | FILE_FLAG_FIRST_PIPE_INSTANCE ,
PIPE_TYPE_BYTE | PIPE_NOWAIT , PIPE_UNLIMITED_INSTANCES ,
0 , 0 , NMPWAIT_USE_DEFAULT_WAIT , NULL ) ;
2012-04-18 09:30:04 +02:00
ok ( pipe ! = INVALID_HANDLE_VALUE , " CreateNamedPipe error %d \n " , GetLastError ( ) ) ;
test_default_handle_security ( token , pipe , & mapping ) ;
SetLastError ( 0xdeadbeef ) ;
2013-10-15 10:15:45 +02:00
file = CreateFileA ( WINE_TEST_PIPE , FILE_ALL_ACCESS , 0 , NULL , OPEN_EXISTING , 0 , 0 ) ;
2012-04-18 09:30:04 +02:00
ok ( file ! = INVALID_HANDLE_VALUE , " CreateFile error %d \n " , GetLastError ( ) ) ;
2013-12-26 08:34:18 +01:00
access = get_obj_access ( file ) ;
ok ( access = = FILE_ALL_ACCESS , " expected FILE_ALL_ACCESS, got %#x \n " , access ) ;
for ( i = 0 ; i < sizeof ( map ) / sizeof ( map [ 0 ] ) ; i + + )
{
SetLastError ( 0xdeadbeef ) ;
ret = DuplicateHandle ( GetCurrentProcess ( ) , file , GetCurrentProcess ( ) , & dup ,
map [ i ] . generic , FALSE , 0 ) ;
ok ( ret , " DuplicateHandle error %d \n " , GetLastError ( ) ) ;
access = get_obj_access ( dup ) ;
ok ( access = = map [ i ] . mapped , " %d: expected %#x, got %#x \n " , i , map [ i ] . mapped , access ) ;
CloseHandle ( dup ) ;
}
CloseHandle ( file ) ;
2012-04-18 09:30:04 +02:00
CloseHandle ( pipe ) ;
SetLastError ( 0xdeadbeef ) ;
2013-10-15 10:15:45 +02:00
file = CreateFileA ( " \\ \\ . \\ pipe \\ " , FILE_ALL_ACCESS , FILE_SHARE_READ | FILE_SHARE_WRITE , NULL , OPEN_EXISTING , 0 , 0 ) ;
2012-04-18 09:30:04 +02:00
ok ( file ! = INVALID_HANDLE_VALUE | | broken ( file = = INVALID_HANDLE_VALUE ) /* before Vista */ , " CreateFile error %d \n " , GetLastError ( ) ) ;
2013-12-26 08:34:18 +01:00
if ( file ! = INVALID_HANDLE_VALUE )
{
access = get_obj_access ( file ) ;
ok ( access = = FILE_ALL_ACCESS , " expected FILE_ALL_ACCESS, got %#x \n " , access ) ;
for ( i = 0 ; i < sizeof ( map ) / sizeof ( map [ 0 ] ) ; i + + )
{
SetLastError ( 0xdeadbeef ) ;
ret = DuplicateHandle ( GetCurrentProcess ( ) , file , GetCurrentProcess ( ) , & dup ,
map [ i ] . generic , FALSE , 0 ) ;
ok ( ret , " DuplicateHandle error %d \n " , GetLastError ( ) ) ;
access = get_obj_access ( dup ) ;
if ( map [ i ] . todo )
todo_wine
ok ( access = = map [ i ] . mapped , " %d: expected %#x, got %#x \n " , i , map [ i ] . mapped , access ) ;
else
ok ( access = = map [ i ] . mapped , " %d: expected %#x, got %#x \n " , i , map [ i ] . mapped , access ) ;
CloseHandle ( dup ) ;
}
}
2012-04-18 09:30:04 +02:00
CloseHandle ( file ) ;
}
2013-12-26 08:34:22 +01:00
static void test_file_security ( HANDLE token )
{
2014-01-10 10:26:06 +01:00
DWORD ret , i , access , bytes ;
2013-12-26 08:34:22 +01:00
HANDLE file , dup ;
static const struct
{
int generic , mapped ;
} map [ ] =
{
2014-01-10 10:25:53 +01:00
{ 0 , 0 } ,
2013-12-26 08:34:22 +01:00
{ GENERIC_READ , FILE_GENERIC_READ } ,
{ GENERIC_WRITE , FILE_GENERIC_WRITE } ,
{ GENERIC_EXECUTE , FILE_GENERIC_EXECUTE } ,
{ GENERIC_ALL , STANDARD_RIGHTS_ALL | FILE_ALL_ACCESS }
} ;
char temp_path [ MAX_PATH ] ;
char file_name [ MAX_PATH ] ;
2014-01-10 10:26:06 +01:00
char buf [ 16 ] ;
2013-12-26 08:34:22 +01:00
GetTempPathA ( MAX_PATH , temp_path ) ;
GetTempFileNameA ( temp_path , " tmp " , 0 , file_name ) ;
2014-01-10 10:26:06 +01:00
/* file */
2013-12-26 08:34:22 +01:00
SetLastError ( 0xdeadbeef ) ;
file = CreateFileA ( file_name , GENERIC_ALL , 0 , NULL , CREATE_ALWAYS , 0 , NULL ) ;
ok ( file ! = INVALID_HANDLE_VALUE , " CreateFile error %d \n " , GetLastError ( ) ) ;
access = get_obj_access ( file ) ;
ok ( access = = FILE_ALL_ACCESS , " expected FILE_ALL_ACCESS, got %#x \n " , access ) ;
for ( i = 0 ; i < sizeof ( map ) / sizeof ( map [ 0 ] ) ; i + + )
{
SetLastError ( 0xdeadbeef ) ;
ret = DuplicateHandle ( GetCurrentProcess ( ) , file , GetCurrentProcess ( ) , & dup ,
map [ i ] . generic , FALSE , 0 ) ;
ok ( ret , " DuplicateHandle error %d \n " , GetLastError ( ) ) ;
access = get_obj_access ( dup ) ;
ok ( access = = map [ i ] . mapped , " %d: expected %#x, got %#x \n " , i , map [ i ] . mapped , access ) ;
CloseHandle ( dup ) ;
}
2014-01-10 10:26:06 +01:00
CloseHandle ( file ) ;
SetLastError ( 0xdeadbeef ) ;
file = CreateFileA ( file_name , 0 , 0 , NULL , OPEN_EXISTING , 0 , NULL ) ;
ok ( file ! = INVALID_HANDLE_VALUE , " CreateFile error %d \n " , GetLastError ( ) ) ;
access = get_obj_access ( file ) ;
todo_wine
ok ( access = = ( FILE_READ_ATTRIBUTES | SYNCHRONIZE ) , " expected FILE_READ_ATTRIBUTES | SYNCHRONIZE, got %#x \n " , access ) ;
bytes = 0xdeadbeef ;
SetLastError ( 0xdeadbeef ) ;
ret = ReadFile ( file , buf , sizeof ( buf ) , & bytes , NULL ) ;
ok ( ! ret , " ReadFile should fail \n " ) ;
ok ( GetLastError ( ) = = ERROR_ACCESS_DENIED , " expected ERROR_ACCESS_DENIED, got %d \n " , GetLastError ( ) ) ;
ok ( bytes = = 0 , " expected 0, got %u \n " , bytes ) ;
CloseHandle ( file ) ;
SetLastError ( 0xdeadbeef ) ;
file = CreateFileA ( file_name , GENERIC_WRITE , 0 , NULL , OPEN_EXISTING , 0 , 0 ) ;
ok ( file ! = INVALID_HANDLE_VALUE , " CreateFile error %d \n " , GetLastError ( ) ) ;
access = get_obj_access ( file ) ;
todo_wine
ok ( access = = ( FILE_GENERIC_WRITE | FILE_READ_ATTRIBUTES ) , " expected FILE_GENERIC_WRITE | FILE_READ_ATTRIBUTES, got %#x \n " , access ) ;
bytes = 0xdeadbeef ;
SetLastError ( 0xdeadbeef ) ;
ret = ReadFile ( file , buf , sizeof ( buf ) , & bytes , NULL ) ;
ok ( ! ret , " ReadFile should fail \n " ) ;
ok ( GetLastError ( ) = = ERROR_ACCESS_DENIED , " expected ERROR_ACCESS_DENIED, got %d \n " , GetLastError ( ) ) ;
ok ( bytes = = 0 , " expected 0, got %u \n " , bytes ) ;
2013-12-26 08:34:22 +01:00
CloseHandle ( file ) ;
DeleteFileA ( file_name ) ;
2014-01-10 10:26:06 +01:00
/* directory */
SetLastError ( 0xdeadbeef ) ;
file = CreateFileA ( temp_path , GENERIC_ALL , 0 , NULL , OPEN_EXISTING , FILE_FLAG_BACKUP_SEMANTICS , 0 ) ;
ok ( file ! = INVALID_HANDLE_VALUE , " CreateFile error %d \n " , GetLastError ( ) ) ;
access = get_obj_access ( file ) ;
ok ( access = = FILE_ALL_ACCESS , " expected FILE_ALL_ACCESS, got %#x \n " , access ) ;
for ( i = 0 ; i < sizeof ( map ) / sizeof ( map [ 0 ] ) ; i + + )
{
SetLastError ( 0xdeadbeef ) ;
ret = DuplicateHandle ( GetCurrentProcess ( ) , file , GetCurrentProcess ( ) , & dup ,
map [ i ] . generic , FALSE , 0 ) ;
ok ( ret , " DuplicateHandle error %d \n " , GetLastError ( ) ) ;
access = get_obj_access ( dup ) ;
ok ( access = = map [ i ] . mapped , " %d: expected %#x, got %#x \n " , i , map [ i ] . mapped , access ) ;
CloseHandle ( dup ) ;
}
CloseHandle ( file ) ;
SetLastError ( 0xdeadbeef ) ;
file = CreateFileA ( temp_path , 0 , 0 , NULL , OPEN_EXISTING , FILE_FLAG_BACKUP_SEMANTICS , 0 ) ;
ok ( file ! = INVALID_HANDLE_VALUE , " CreateFile error %d \n " , GetLastError ( ) ) ;
access = get_obj_access ( file ) ;
todo_wine
ok ( access = = ( FILE_READ_ATTRIBUTES | SYNCHRONIZE ) , " expected FILE_READ_ATTRIBUTES | SYNCHRONIZE, got %#x \n " , access ) ;
CloseHandle ( file ) ;
SetLastError ( 0xdeadbeef ) ;
file = CreateFileA ( temp_path , GENERIC_WRITE , 0 , NULL , OPEN_EXISTING , FILE_FLAG_BACKUP_SEMANTICS , 0 ) ;
ok ( file ! = INVALID_HANDLE_VALUE , " CreateFile error %d \n " , GetLastError ( ) ) ;
access = get_obj_access ( file ) ;
todo_wine
ok ( access = = ( FILE_GENERIC_WRITE | FILE_READ_ATTRIBUTES ) , " expected FILE_GENERIC_WRITE | FILE_READ_ATTRIBUTES, got %#x \n " , access ) ;
CloseHandle ( file ) ;
2013-12-26 08:34:22 +01:00
}
2014-01-10 10:26:11 +01:00
static void test_filemap_security ( void )
{
2014-02-07 04:43:13 +01:00
char temp_path [ MAX_PATH ] ;
char file_name [ MAX_PATH ] ;
2014-01-10 10:26:11 +01:00
DWORD ret , i , access ;
2014-02-07 04:43:13 +01:00
HANDLE file , mapping , dup ;
2014-01-10 10:26:11 +01:00
static const struct
{
int generic , mapped ;
} map [ ] =
{
{ 0 , 0 } ,
{ GENERIC_READ , STANDARD_RIGHTS_READ | SECTION_QUERY | SECTION_MAP_READ } ,
{ GENERIC_WRITE , STANDARD_RIGHTS_WRITE | SECTION_MAP_WRITE } ,
{ GENERIC_EXECUTE , STANDARD_RIGHTS_EXECUTE | SECTION_MAP_EXECUTE } ,
{ GENERIC_ALL , STANDARD_RIGHTS_REQUIRED | SECTION_ALL_ACCESS }
} ;
2014-02-07 04:43:13 +01:00
static const struct
{
int prot , mapped ;
} prot_map [ ] =
{
{ 0 , 0 } ,
{ PAGE_NOACCESS , 0 } ,
{ PAGE_READONLY , STANDARD_RIGHTS_REQUIRED | SECTION_QUERY | SECTION_MAP_READ } ,
{ PAGE_READWRITE , STANDARD_RIGHTS_REQUIRED | SECTION_QUERY | SECTION_MAP_READ | SECTION_MAP_WRITE } ,
{ PAGE_WRITECOPY , STANDARD_RIGHTS_REQUIRED | SECTION_QUERY | SECTION_MAP_READ } ,
{ PAGE_EXECUTE , 0 } ,
{ PAGE_EXECUTE_READ , STANDARD_RIGHTS_REQUIRED | SECTION_QUERY | SECTION_MAP_READ | SECTION_MAP_EXECUTE } ,
{ PAGE_EXECUTE_READWRITE , STANDARD_RIGHTS_REQUIRED | SECTION_QUERY | SECTION_MAP_READ | SECTION_MAP_WRITE | SECTION_MAP_EXECUTE } ,
{ PAGE_EXECUTE_WRITECOPY , STANDARD_RIGHTS_REQUIRED | SECTION_QUERY | SECTION_MAP_READ | SECTION_MAP_EXECUTE }
} ;
GetTempPathA ( MAX_PATH , temp_path ) ;
GetTempFileNameA ( temp_path , " tmp " , 0 , file_name ) ;
2014-01-10 10:26:11 +01:00
SetLastError ( 0xdeadbeef ) ;
2014-02-07 04:43:13 +01:00
file = CreateFileA ( file_name , GENERIC_READ | GENERIC_WRITE | GENERIC_EXECUTE , 0 , NULL , CREATE_ALWAYS , 0 , 0 ) ;
ok ( file ! = INVALID_HANDLE_VALUE , " CreateFile error %d \n " , GetLastError ( ) ) ;
SetFilePointer ( file , 4096 , NULL , FILE_BEGIN ) ;
SetEndOfFile ( file ) ;
for ( i = 0 ; i < sizeof ( prot_map ) / sizeof ( prot_map [ 0 ] ) ; i + + )
2014-01-10 10:26:11 +01:00
{
SetLastError ( 0xdeadbeef ) ;
2014-02-07 04:43:13 +01:00
mapping = CreateFileMappingW ( file , NULL , prot_map [ i ] . prot , 0 , 4096 , NULL ) ;
if ( prot_map [ i ] . mapped )
{
if ( ! mapping )
{
if ( prot_map [ i ] . prot = = PAGE_EXECUTE_READ | | prot_map [ i ] . prot = = PAGE_EXECUTE_READWRITE | | prot_map [ i ] . prot = = PAGE_EXECUTE_WRITECOPY )
{
win_skip ( " CreateFileMapping doesn't support PAGE_EXECUTE protection \n " ) ;
continue ;
}
}
ok ( mapping ! = 0 , " CreateFileMapping(%04x) error %d \n " , prot_map [ i ] . prot , GetLastError ( ) ) ;
}
else
{
ok ( ! mapping , " CreateFileMapping(%04x) error %d \n " , prot_map [ i ] . prot , GetLastError ( ) ) ;
ok ( GetLastError ( ) = = ERROR_INVALID_PARAMETER , " expected ERROR_INVALID_PARAMETER, got %d \n " , GetLastError ( ) ) ;
continue ;
}
2014-01-10 10:26:11 +01:00
access = get_obj_access ( mapping ) ;
2014-02-07 04:43:13 +01:00
ok ( access = = prot_map [ i ] . mapped , " %d: expected %#x, got %#x \n " , i , prot_map [ i ] . mapped , access ) ;
CloseHandle ( mapping ) ;
2014-01-10 10:26:11 +01:00
}
2014-02-07 04:43:13 +01:00
SetLastError ( 0xdeadbeef ) ;
mapping = CreateFileMappingW ( file , NULL , PAGE_EXECUTE_READWRITE , 0 , 4096 , NULL ) ;
ok ( mapping ! = 0 , " CreateFileMapping error %d \n " , GetLastError ( ) ) ;
access = get_obj_access ( mapping ) ;
ok ( access = = ( STANDARD_RIGHTS_REQUIRED | SECTION_QUERY | SECTION_MAP_READ | SECTION_MAP_WRITE | SECTION_MAP_EXECUTE ) ,
" expected STANDARD_RIGHTS_REQUIRED | SECTION_QUERY | SECTION_MAP_READ | SECTION_MAP_WRITE | SECTION_MAP_EXECUTE, got %#x \n " , access ) ;
2014-01-10 10:26:11 +01:00
for ( i = 0 ; i < sizeof ( map ) / sizeof ( map [ 0 ] ) ; i + + )
{
SetLastError ( 0xdeadbeef ) ;
ret = DuplicateHandle ( GetCurrentProcess ( ) , mapping , GetCurrentProcess ( ) , & dup ,
map [ i ] . generic , FALSE , 0 ) ;
ok ( ret , " DuplicateHandle error %d \n " , GetLastError ( ) ) ;
access = get_obj_access ( dup ) ;
ok ( access = = map [ i ] . mapped , " %d: expected %#x, got %#x \n " , i , map [ i ] . mapped , access ) ;
CloseHandle ( dup ) ;
}
CloseHandle ( mapping ) ;
2014-02-07 04:43:13 +01:00
CloseHandle ( file ) ;
DeleteFileA ( file_name ) ;
2014-01-10 10:26:11 +01:00
}
2014-01-10 10:26:16 +01:00
static void test_thread_security ( void )
{
DWORD ret , i , access ;
HANDLE thread , dup ;
static const struct
{
int generic , mapped ;
} map [ ] =
{
{ 0 , 0 } ,
{ GENERIC_READ , STANDARD_RIGHTS_READ | THREAD_QUERY_INFORMATION | THREAD_GET_CONTEXT } ,
{ GENERIC_WRITE , STANDARD_RIGHTS_WRITE | THREAD_SET_INFORMATION | THREAD_SET_CONTEXT | THREAD_TERMINATE | THREAD_SUSPEND_RESUME | 0x4 } ,
{ GENERIC_EXECUTE , STANDARD_RIGHTS_EXECUTE | SYNCHRONIZE } ,
{ GENERIC_ALL , THREAD_ALL_ACCESS_NT4 }
} ;
SetLastError ( 0xdeadbeef ) ;
thread = CreateThread ( NULL , 0 , ( void * ) 0xdeadbeef , NULL , CREATE_SUSPENDED , & ret ) ;
ok ( thread ! = 0 , " CreateThread error %d \n " , GetLastError ( ) ) ;
access = get_obj_access ( thread ) ;
ok ( access = = THREAD_ALL_ACCESS_NT4 | | access = = THREAD_ALL_ACCESS_VISTA , " expected THREAD_ALL_ACCESS, got %#x \n " , access ) ;
for ( i = 0 ; i < sizeof ( map ) / sizeof ( map [ 0 ] ) ; i + + )
{
SetLastError ( 0xdeadbeef ) ;
ret = DuplicateHandle ( GetCurrentProcess ( ) , thread , GetCurrentProcess ( ) , & dup ,
map [ i ] . generic , FALSE , 0 ) ;
ok ( ret , " DuplicateHandle error %d \n " , GetLastError ( ) ) ;
access = get_obj_access ( dup ) ;
switch ( map [ i ] . generic )
{
case GENERIC_READ :
2014-02-05 08:46:55 +01:00
case GENERIC_EXECUTE :
2014-01-10 10:26:16 +01:00
ok ( access = = map [ i ] . mapped | | access = = ( map [ i ] . mapped | THREAD_QUERY_LIMITED_INFORMATION ) /* Vista+ */ ,
" %d: expected %#x, got %#x \n " , i , map [ i ] . mapped , access ) ;
break ;
case GENERIC_WRITE :
todo_wine
ok ( access = = map [ i ] . mapped | | access = = ( map [ i ] . mapped | THREAD_SET_LIMITED_INFORMATION ) /* Vista+ */ ,
" %d: expected %#x, got %#x \n " , i , map [ i ] . mapped , access ) ;
break ;
case GENERIC_ALL :
ok ( access = = map [ i ] . mapped | | access = = THREAD_ALL_ACCESS_VISTA ,
" %d: expected %#x, got %#x \n " , i , map [ i ] . mapped , access ) ;
break ;
default :
ok ( access = = map [ i ] . mapped , " %d: expected %#x, got %#x \n " , i , map [ i ] . mapped , access ) ;
break ;
}
CloseHandle ( dup ) ;
}
TerminateThread ( thread , 0 ) ;
CloseHandle ( thread ) ;
}
2014-01-10 10:26:20 +01:00
static void test_process_access ( void )
{
DWORD ret , i , access ;
HANDLE process , dup ;
STARTUPINFOA sti ;
PROCESS_INFORMATION pi ;
char cmdline [ ] = " winver.exe " ;
static const struct
{
int generic , mapped ;
} map [ ] =
{
{ 0 , 0 } ,
{ GENERIC_READ , STANDARD_RIGHTS_READ | PROCESS_QUERY_INFORMATION | PROCESS_VM_READ } ,
{ GENERIC_WRITE , STANDARD_RIGHTS_WRITE | PROCESS_SET_QUOTA | PROCESS_SET_INFORMATION | PROCESS_SUSPEND_RESUME |
PROCESS_VM_WRITE | PROCESS_DUP_HANDLE | PROCESS_CREATE_PROCESS | PROCESS_CREATE_THREAD | PROCESS_VM_OPERATION } ,
{ GENERIC_EXECUTE , STANDARD_RIGHTS_EXECUTE | SYNCHRONIZE } ,
{ GENERIC_ALL , PROCESS_ALL_ACCESS_NT4 }
} ;
memset ( & sti , 0 , sizeof ( sti ) ) ;
sti . cb = sizeof ( sti ) ;
SetLastError ( 0xdeadbeef ) ;
ret = CreateProcessA ( NULL , cmdline , NULL , NULL , FALSE , CREATE_SUSPENDED , NULL , NULL , & sti , & pi ) ;
ok ( ret , " CreateProcess() error %d \n " , GetLastError ( ) ) ;
CloseHandle ( pi . hThread ) ;
process = pi . hProcess ;
access = get_obj_access ( process ) ;
ok ( access = = PROCESS_ALL_ACCESS_NT4 | | access = = PROCESS_ALL_ACCESS_VISTA , " expected PROCESS_ALL_ACCESS, got %#x \n " , access ) ;
for ( i = 0 ; i < sizeof ( map ) / sizeof ( map [ 0 ] ) ; i + + )
{
SetLastError ( 0xdeadbeef ) ;
ret = DuplicateHandle ( GetCurrentProcess ( ) , process , GetCurrentProcess ( ) , & dup ,
map [ i ] . generic , FALSE , 0 ) ;
ok ( ret , " DuplicateHandle error %d \n " , GetLastError ( ) ) ;
access = get_obj_access ( dup ) ;
switch ( map [ i ] . generic )
{
case GENERIC_READ :
ok ( access = = map [ i ] . mapped | | access = = ( map [ i ] . mapped | PROCESS_QUERY_LIMITED_INFORMATION ) /* Vista+ */ ,
" %d: expected %#x, got %#x \n " , i , map [ i ] . mapped , access ) ;
break ;
case GENERIC_WRITE :
ok ( access = = map [ i ] . mapped | | access = = ( map [ i ] . mapped | PROCESS_TERMINATE ) /* before Vista */ ,
" %d: expected %#x, got %#x \n " , i , map [ i ] . mapped , access ) ;
break ;
case GENERIC_EXECUTE :
ok ( access = = map [ i ] . mapped | | access = = ( map [ i ] . mapped | PROCESS_QUERY_LIMITED_INFORMATION | PROCESS_TERMINATE ) /* Vista+ */ ,
" %d: expected %#x, got %#x \n " , i , map [ i ] . mapped , access ) ;
break ;
case GENERIC_ALL :
ok ( access = = map [ i ] . mapped | | access = = PROCESS_ALL_ACCESS_VISTA ,
" %d: expected %#x, got %#x \n " , i , map [ i ] . mapped , access ) ;
break ;
default :
ok ( access = = map [ i ] . mapped , " %d: expected %#x, got %#x \n " , i , map [ i ] . mapped , access ) ;
break ;
}
CloseHandle ( dup ) ;
}
TerminateProcess ( process , 0 ) ;
CloseHandle ( process ) ;
}
2012-03-15 09:10:42 +01:00
static BOOL validate_impersonation_token ( HANDLE token , DWORD * token_type )
{
DWORD ret , needed ;
TOKEN_TYPE type ;
SECURITY_IMPERSONATION_LEVEL sil ;
type = 0xdeadbeef ;
needed = 0 ;
SetLastError ( 0xdeadbeef ) ;
ret = GetTokenInformation ( token , TokenType , & type , sizeof ( type ) , & needed ) ;
ok ( ret , " GetTokenInformation error %d \n " , GetLastError ( ) ) ;
ok ( needed = = sizeof ( type ) , " GetTokenInformation should return required buffer length \n " ) ;
ok ( type = = TokenPrimary | | type = = TokenImpersonation , " expected TokenPrimary or TokenImpersonation, got %d \n " , type ) ;
* token_type = type ;
if ( type ! = TokenImpersonation ) return FALSE ;
needed = 0 ;
SetLastError ( 0xdeadbeef ) ;
ret = GetTokenInformation ( token , TokenImpersonationLevel , & sil , sizeof ( sil ) , & needed ) ;
ok ( ret , " GetTokenInformation error %d \n " , GetLastError ( ) ) ;
ok ( needed = = sizeof ( sil ) , " GetTokenInformation should return required buffer length \n " ) ;
ok ( sil = = SecurityImpersonation , " expected SecurityImpersonation, got %d \n " , sil ) ;
needed = 0xdeadbeef ;
SetLastError ( 0xdeadbeef ) ;
ret = GetTokenInformation ( token , TokenDefaultDacl , NULL , 0 , & needed ) ;
ok ( ! ret , " GetTokenInformation should fail \n " ) ;
ok ( GetLastError ( ) = = ERROR_INSUFFICIENT_BUFFER , " expected ERROR_INSUFFICIENT_BUFFER, got %d \n " , GetLastError ( ) ) ;
ok ( needed ! = 0xdeadbeef , " GetTokenInformation should return required buffer length \n " ) ;
ok ( needed > sizeof ( TOKEN_DEFAULT_DACL ) , " GetTokenInformation returned empty default DACL \n " ) ;
needed = 0xdeadbeef ;
SetLastError ( 0xdeadbeef ) ;
ret = GetTokenInformation ( token , TokenOwner , NULL , 0 , & needed ) ;
ok ( ! ret , " GetTokenInformation should fail \n " ) ;
ok ( GetLastError ( ) = = ERROR_INSUFFICIENT_BUFFER , " expected ERROR_INSUFFICIENT_BUFFER, got %d \n " , GetLastError ( ) ) ;
ok ( needed ! = 0xdeadbeef , " GetTokenInformation should return required buffer length \n " ) ;
ok ( needed > sizeof ( TOKEN_OWNER ) , " GetTokenInformation returned empty token owner \n " ) ;
needed = 0xdeadbeef ;
SetLastError ( 0xdeadbeef ) ;
ret = GetTokenInformation ( token , TokenPrimaryGroup , NULL , 0 , & needed ) ;
ok ( ! ret , " GetTokenInformation should fail \n " ) ;
ok ( GetLastError ( ) = = ERROR_INSUFFICIENT_BUFFER , " expected ERROR_INSUFFICIENT_BUFFER, got %d \n " , GetLastError ( ) ) ;
ok ( needed ! = 0xdeadbeef , " GetTokenInformation should return required buffer length \n " ) ;
ok ( needed > sizeof ( TOKEN_PRIMARY_GROUP ) , " GetTokenInformation returned empty token primary group \n " ) ;
return TRUE ;
}
static void test_kernel_objects_security ( void )
{
HANDLE token , process_token ;
DWORD ret , token_type ;
ret = OpenProcessToken ( GetCurrentProcess ( ) , TOKEN_DUPLICATE | TOKEN_QUERY , & process_token ) ;
ok ( ret , " OpenProcessToken error %d \n " , GetLastError ( ) ) ;
ret = validate_impersonation_token ( process_token , & token_type ) ;
ok ( token_type = = TokenPrimary , " expected TokenPrimary, got %d \n " , token_type ) ;
ok ( ! ret , " access token should not be an impersonation token \n " ) ;
ret = DuplicateToken ( process_token , SecurityImpersonation , & token ) ;
ok ( ret , " DuplicateToken error %d \n " , GetLastError ( ) ) ;
ret = validate_impersonation_token ( token , & token_type ) ;
ok ( ret , " access token should be a valid impersonation token \n " ) ;
ok ( token_type = = TokenImpersonation , " expected TokenImpersonation, got %d \n " , token_type ) ;
test_mutex_security ( token ) ;
2012-03-16 11:31:43 +01:00
test_event_security ( token ) ;
2012-04-18 09:30:04 +02:00
test_named_pipe_security ( token ) ;
2013-12-26 08:34:14 +01:00
test_semaphore_security ( token ) ;
2013-12-26 08:34:22 +01:00
test_file_security ( token ) ;
2014-01-10 10:26:11 +01:00
test_filemap_security ( ) ;
2014-01-10 10:26:16 +01:00
test_thread_security ( ) ;
2014-01-10 10:26:20 +01:00
test_process_access ( ) ;
2012-03-15 09:10:42 +01:00
/* FIXME: test other kernel object types */
CloseHandle ( process_token ) ;
CloseHandle ( token ) ;
}
2012-07-31 00:09:02 +02:00
static void test_TokenIntegrityLevel ( void )
{
TOKEN_MANDATORY_LABEL * tml ;
BYTE buffer [ 64 ] ; /* using max. 28 byte in win7 x64 */
HANDLE token ;
DWORD size ;
DWORD res ;
char * sidname = NULL ;
static SID medium_level = { SID_REVISION , 1 , { SECURITY_MANDATORY_LABEL_AUTHORITY } ,
{ SECURITY_MANDATORY_HIGH_RID } } ;
static SID high_level = { SID_REVISION , 1 , { SECURITY_MANDATORY_LABEL_AUTHORITY } ,
{ SECURITY_MANDATORY_MEDIUM_RID } } ;
SetLastError ( 0xdeadbeef ) ;
res = OpenProcessToken ( GetCurrentProcess ( ) , TOKEN_QUERY , & token ) ;
ok ( res , " got %d with %d (expected TRUE) \n " , res , GetLastError ( ) ) ;
SetLastError ( 0xdeadbeef ) ;
res = GetTokenInformation ( token , TokenIntegrityLevel , buffer , sizeof ( buffer ) , & size ) ;
/* not supported before Vista */
2012-11-12 05:50:13 +01:00
if ( ! res & & ( ( GetLastError ( ) = = ERROR_INVALID_PARAMETER ) | | GetLastError ( ) = = ERROR_INVALID_FUNCTION ) )
2012-07-31 00:09:02 +02:00
{
win_skip ( " TokenIntegrityLevel not supported \n " ) ;
CloseHandle ( token ) ;
return ;
}
ok ( res , " got %u with %u (expected TRUE) \n " , res , GetLastError ( ) ) ;
if ( ! res )
{
CloseHandle ( token ) ;
return ;
}
tml = ( TOKEN_MANDATORY_LABEL * ) buffer ;
ok ( tml - > Label . Attributes = = ( SE_GROUP_INTEGRITY | SE_GROUP_INTEGRITY_ENABLED ) ,
" got 0x%x (expected 0x%x) \n " , tml - > Label . Attributes , ( SE_GROUP_INTEGRITY | SE_GROUP_INTEGRITY_ENABLED ) ) ;
SetLastError ( 0xdeadbeef ) ;
res = pConvertSidToStringSidA ( tml - > Label . Sid , & sidname ) ;
ok ( res , " got %u and %u \n " , res , GetLastError ( ) ) ;
ok ( EqualSid ( tml - > Label . Sid , & medium_level ) | | EqualSid ( tml - > Label . Sid , & high_level ) ,
" got %s (expected 'S-1-16-8192' or 'S-1-16-12288') \n " , sidname ) ;
LocalFree ( sidname ) ;
CloseHandle ( token ) ;
}
2013-07-30 11:06:42 +02:00
static void test_default_dacl_owner_sid ( void )
{
HANDLE handle ;
BOOL ret , defaulted , present , found ;
DWORD size , index ;
SECURITY_DESCRIPTOR * sd ;
SECURITY_ATTRIBUTES sa ;
PSID owner ;
ACL * dacl ;
ACCESS_ALLOWED_ACE * ace ;
sd = HeapAlloc ( GetProcessHeap ( ) , 0 , SECURITY_DESCRIPTOR_MIN_LENGTH ) ;
ret = InitializeSecurityDescriptor ( sd , SECURITY_DESCRIPTOR_REVISION ) ;
ok ( ret , " error %u \n " , GetLastError ( ) ) ;
sa . nLength = sizeof ( SECURITY_ATTRIBUTES ) ;
sa . lpSecurityDescriptor = sd ;
sa . bInheritHandle = FALSE ;
2013-10-15 10:15:45 +02:00
handle = CreateEventA ( & sa , TRUE , TRUE , " test_event " ) ;
2013-07-30 11:06:42 +02:00
ok ( handle ! = NULL , " error %u \n " , GetLastError ( ) ) ;
size = 0 ;
ret = GetKernelObjectSecurity ( handle , OWNER_SECURITY_INFORMATION | DACL_SECURITY_INFORMATION , NULL , 0 , & size ) ;
ok ( ! ret & & GetLastError ( ) = = ERROR_INSUFFICIENT_BUFFER , " error %u \n " , GetLastError ( ) ) ;
sd = HeapAlloc ( GetProcessHeap ( ) , 0 , size ) ;
ret = GetKernelObjectSecurity ( handle , OWNER_SECURITY_INFORMATION | DACL_SECURITY_INFORMATION , sd , size , & size ) ;
ok ( ret , " error %u \n " , GetLastError ( ) ) ;
owner = ( void * ) 0xdeadbeef ;
defaulted = TRUE ;
ret = GetSecurityDescriptorOwner ( sd , & owner , & defaulted ) ;
ok ( ret , " error %u \n " , GetLastError ( ) ) ;
ok ( owner ! = ( void * ) 0xdeadbeef , " owner not set \n " ) ;
todo_wine ok ( ! defaulted , " owner defaulted \n " ) ;
dacl = ( void * ) 0xdeadbeef ;
present = FALSE ;
defaulted = TRUE ;
ret = GetSecurityDescriptorDacl ( sd , & present , & dacl , & defaulted ) ;
ok ( ret , " error %u \n " , GetLastError ( ) ) ;
ok ( present , " dacl not present \n " ) ;
ok ( dacl ! = ( void * ) 0xdeadbeef , " dacl not set \n " ) ;
todo_wine ok ( ! defaulted , " dacl defaulted \n " ) ;
index = 0 ;
found = FALSE ;
while ( pGetAce ( dacl , index + + , ( void * * ) & ace ) )
{
if ( EqualSid ( & ace - > SidStart , owner ) ) found = TRUE ;
}
ok ( found , " owner sid not found in dacl \n " ) ;
HeapFree ( GetProcessHeap ( ) , 0 , sa . lpSecurityDescriptor ) ;
HeapFree ( GetProcessHeap ( ) , 0 , sd ) ;
CloseHandle ( handle ) ;
}
2013-12-02 06:38:09 +01:00
static void test_AdjustTokenPrivileges ( void )
{
TOKEN_PRIVILEGES tp , prev ;
HANDLE token ;
DWORD len ;
LUID luid ;
BOOL ret ;
if ( ! OpenProcessToken ( GetCurrentProcess ( ) , TOKEN_ADJUST_PRIVILEGES , & token ) )
return ;
if ( ! LookupPrivilegeValueA ( NULL , SE_BACKUP_NAME , & luid ) )
{
CloseHandle ( token ) ;
return ;
}
tp . PrivilegeCount = 1 ;
tp . Privileges [ 0 ] . Luid = luid ;
tp . Privileges [ 0 ] . Attributes = SE_PRIVILEGE_ENABLED ;
len = 0xdeadbeef ;
ret = AdjustTokenPrivileges ( token , FALSE , & tp , sizeof ( TOKEN_PRIVILEGES ) , NULL , & len ) ;
ok ( ret , " got %d \n " , ret ) ;
ok ( len = = 0xdeadbeef , " got length %d \n " , len ) ;
/* revert */
tp . PrivilegeCount = 1 ;
tp . Privileges [ 0 ] . Luid = luid ;
tp . Privileges [ 0 ] . Attributes = 0 ;
AdjustTokenPrivileges ( token , FALSE , & tp , sizeof ( TOKEN_PRIVILEGES ) , & prev , NULL ) ;
CloseHandle ( token ) ;
}
2004-08-09 20:47:22 +02:00
START_TEST ( security )
{
2004-11-04 05:52:17 +01:00
init ( ) ;
if ( ! hmod ) return ;
2007-01-25 07:43:18 +01:00
if ( myARGC > = 3 )
{
test_process_security_child ( ) ;
return ;
}
2012-03-15 09:10:42 +01:00
test_kernel_objects_security ( ) ;
2004-08-09 20:47:22 +02:00
test_sid ( ) ;
2004-08-16 23:07:50 +02:00
test_trustee ( ) ;
2004-11-04 05:52:17 +01:00
test_luid ( ) ;
2007-10-21 09:41:54 +02:00
test_CreateWellKnownSid ( ) ;
2005-03-28 12:00:59 +02:00
test_FileSecurity ( ) ;
2005-06-09 12:03:11 +02:00
test_AccessCheck ( ) ;
2006-05-13 17:56:59 +02:00
test_token_attr ( ) ;
2006-07-06 04:53:52 +02:00
test_LookupAccountSid ( ) ;
2006-12-01 00:53:21 +01:00
test_LookupAccountName ( ) ;
2007-09-27 19:34:53 +02:00
test_security_descriptor ( ) ;
2007-01-25 07:43:18 +01:00
test_process_security ( ) ;
2007-02-15 17:25:58 +01:00
test_impersonation_level ( ) ;
2011-01-01 21:19:55 +01:00
test_SetEntriesInAclW ( ) ;
test_SetEntriesInAclA ( ) ;
2013-11-08 20:01:49 +01:00
test_CreateDirectoryA ( ) ;
2007-06-25 16:00:38 +02:00
test_GetNamedSecurityInfoA ( ) ;
2007-07-20 10:26:35 +02:00
test_ConvertStringSecurityDescriptor ( ) ;
2007-09-25 22:12:50 +02:00
test_ConvertSecurityDescriptorToString ( ) ;
2007-09-27 21:01:49 +02:00
test_PrivateObjectSecurity ( ) ;
2007-10-23 14:38:47 +02:00
test_acls ( ) ;
2008-08-07 21:54:58 +02:00
test_GetSecurityInfo ( ) ;
2009-06-27 12:48:46 +02:00
test_GetSidSubAuthority ( ) ;
2009-11-08 11:23:09 +01:00
test_CheckTokenMembership ( ) ;
2009-11-15 17:37:05 +01:00
test_EqualSid ( ) ;
2011-05-31 18:05:25 +02:00
test_GetUserNameA ( ) ;
test_GetUserNameW ( ) ;
2011-08-02 09:09:18 +02:00
test_CreateRestrictedToken ( ) ;
2012-07-31 00:09:02 +02:00
test_TokenIntegrityLevel ( ) ;
2013-07-30 11:06:42 +02:00
test_default_dacl_owner_sid ( ) ;
2013-12-02 06:38:09 +01:00
test_AdjustTokenPrivileges ( ) ;
2004-08-09 20:47:22 +02:00
}