mirror of https://github.com/tongzx/nt5src
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
237 lines
5.1 KiB
237 lines
5.1 KiB
//
|
|
|
|
// Copyright (c) 1997-2001 Microsoft Corporation, All Rights Reserved
|
|
//
|
|
|
|
#include "precomp.h"
|
|
|
|
|
|
CNamesList :: CNamesList()
|
|
{
|
|
m_pListOfClassNames = NULL;
|
|
m_dwElementCount = 0;
|
|
InitializeCriticalSection(&m_AccessibleClassesSection);
|
|
}
|
|
|
|
CNamesList :: ~CNamesList()
|
|
{
|
|
EnterCriticalSection(&m_AccessibleClassesSection);
|
|
CLPWSTR *pTemp1 = m_pListOfClassNames;
|
|
CLPWSTR *pNext = m_pListOfClassNames;
|
|
while(pTemp1)
|
|
{
|
|
pNext = pTemp1->pNext;
|
|
delete pTemp1;
|
|
pTemp1 = pNext;
|
|
}
|
|
LeaveCriticalSection(&m_AccessibleClassesSection);
|
|
DeleteCriticalSection(&m_AccessibleClassesSection);
|
|
}
|
|
|
|
BOOLEAN CNamesList :: IsNamePresent(LPCWSTR pszClassName)
|
|
{
|
|
// Get the current impersonation level
|
|
DWORD dwCurrentImpersonationLevel = 0;
|
|
if(FAILED(GetImpersonationLevel(&dwCurrentImpersonationLevel)))
|
|
return FALSE;
|
|
|
|
// Look for a name in the list that has an impersonation level of current or greater
|
|
BOOLEAN bRetVal = FALSE;
|
|
EnterCriticalSection(&m_AccessibleClassesSection);
|
|
CLPWSTR *pCurrent = m_pListOfClassNames;
|
|
while(pCurrent)
|
|
{
|
|
if(_wcsicmp(pCurrent->pszVal, pszClassName) == 0 && pCurrent->dwImpersonationLevel <= dwCurrentImpersonationLevel)
|
|
{
|
|
bRetVal = TRUE;
|
|
break;
|
|
}
|
|
pCurrent = pCurrent->pNext;
|
|
}
|
|
LeaveCriticalSection(&m_AccessibleClassesSection);
|
|
|
|
return bRetVal;
|
|
}
|
|
|
|
BOOLEAN CNamesList :: RemoveName(LPCWSTR pszClassName)
|
|
{
|
|
#ifdef NO_WBEM_CACHE
|
|
return FALSE;
|
|
#else
|
|
BOOLEAN bRetVal = FALSE;
|
|
EnterCriticalSection(&m_AccessibleClassesSection);
|
|
if(m_pListOfClassNames)
|
|
{
|
|
// Is it the first node ?
|
|
if(_wcsicmp(m_pListOfClassNames->pszVal, pszClassName) == 0)
|
|
{
|
|
bRetVal = TRUE;
|
|
CLPWSTR *pTemp = m_pListOfClassNames->pNext;
|
|
delete m_pListOfClassNames;
|
|
m_pListOfClassNames = pTemp;
|
|
m_dwElementCount--;
|
|
}
|
|
else
|
|
{
|
|
CLPWSTR *pPrev = m_pListOfClassNames;
|
|
CLPWSTR *pCurrent = m_pListOfClassNames->pNext;
|
|
|
|
while(pCurrent)
|
|
{
|
|
if(_wcsicmp(pCurrent->pszVal, pszClassName) == 0)
|
|
{
|
|
bRetVal = TRUE;
|
|
pPrev->pNext = pCurrent->pNext;
|
|
delete pCurrent;
|
|
m_dwElementCount --;
|
|
break;
|
|
}
|
|
pPrev = pCurrent;
|
|
pCurrent = pCurrent->pNext;
|
|
}
|
|
}
|
|
}
|
|
LeaveCriticalSection(&m_AccessibleClassesSection);
|
|
|
|
return bRetVal;
|
|
#endif
|
|
}
|
|
|
|
BOOLEAN CNamesList :: AddName(LPCWSTR pszClassName)
|
|
{
|
|
#ifdef NO_WBEM_CACHE
|
|
return FALSE;
|
|
#else
|
|
|
|
// Get the current impersonation level
|
|
DWORD dwCurrentImpersonationLevel = 0;
|
|
if(!SUCCEEDED(GetImpersonationLevel(&dwCurrentImpersonationLevel)))
|
|
return FALSE;
|
|
|
|
|
|
// Add it only if it doesnt already exist in the list
|
|
BOOLEAN bFound = FALSE;
|
|
EnterCriticalSection(&m_AccessibleClassesSection);
|
|
CLPWSTR *pCurrent = m_pListOfClassNames;
|
|
while(pCurrent)
|
|
{
|
|
if(_wcsicmp(pCurrent->pszVal, pszClassName) == 0)
|
|
{
|
|
bFound = TRUE;
|
|
break;
|
|
}
|
|
pCurrent = pCurrent->pNext;
|
|
}
|
|
|
|
// Add it at the head
|
|
if(!bFound)
|
|
{
|
|
pCurrent = m_pListOfClassNames;
|
|
m_pListOfClassNames = new CLPWSTR;
|
|
m_pListOfClassNames->pszVal = new WCHAR[wcslen(pszClassName) + 1];
|
|
m_pListOfClassNames->dwImpersonationLevel = dwCurrentImpersonationLevel;
|
|
wcscpy(m_pListOfClassNames->pszVal, pszClassName);
|
|
m_pListOfClassNames->pNext = pCurrent;
|
|
m_dwElementCount ++;
|
|
}
|
|
else // update the impersonation level if necessary
|
|
{
|
|
if(pCurrent->dwImpersonationLevel < dwCurrentImpersonationLevel)
|
|
pCurrent->dwImpersonationLevel = dwCurrentImpersonationLevel;
|
|
}
|
|
LeaveCriticalSection(&m_AccessibleClassesSection);
|
|
|
|
return !bFound;
|
|
#endif
|
|
}
|
|
|
|
DWORD CNamesList :: GetAllNames(LPWSTR **pppszNames)
|
|
{
|
|
EnterCriticalSection(&m_AccessibleClassesSection);
|
|
DWORD retVal = m_dwElementCount;
|
|
*pppszNames = NULL;
|
|
if(m_dwElementCount)
|
|
{
|
|
if(*pppszNames = new LPWSTR[m_dwElementCount])
|
|
{
|
|
CLPWSTR *pCurrent = m_pListOfClassNames;
|
|
bool bError = false;
|
|
for(DWORD i=0; !bError && (i<m_dwElementCount); i++)
|
|
{
|
|
(*pppszNames)[i] = NULL;
|
|
if((*pppszNames)[i] = new WCHAR[wcslen(pCurrent->pszVal) + 1])
|
|
{
|
|
wcscpy((*pppszNames)[i], pCurrent->pszVal);
|
|
pCurrent = pCurrent->pNext;
|
|
}
|
|
else
|
|
bError = true;
|
|
}
|
|
|
|
if(bError)
|
|
{
|
|
retVal = 0;
|
|
delete [] (*pppszNames);
|
|
*pppszNames = NULL;
|
|
}
|
|
}
|
|
else
|
|
retVal = 0;
|
|
}
|
|
LeaveCriticalSection(&m_AccessibleClassesSection);
|
|
|
|
return retVal;
|
|
}
|
|
|
|
HRESULT CNamesList :: GetImpersonationLevel(DWORD *pdwImpLevel)
|
|
{
|
|
//get implevel...
|
|
HANDLE hThreadTok = NULL;
|
|
HRESULT hr = E_FAIL;
|
|
|
|
if (OpenThreadToken(GetCurrentThread(), TOKEN_QUERY, TRUE, &hThreadTok) )
|
|
{
|
|
DWORD dwBytesReturned = 0;
|
|
DWORD dwThreadImpLevel = 0;
|
|
|
|
if (GetTokenInformation(hThreadTok, TokenImpersonationLevel, &dwThreadImpLevel,
|
|
sizeof(DWORD), &dwBytesReturned))
|
|
{
|
|
hr = S_OK;
|
|
|
|
switch(dwThreadImpLevel)
|
|
{
|
|
case SecurityAnonymous:
|
|
{
|
|
*pdwImpLevel = RPC_C_IMP_LEVEL_ANONYMOUS;
|
|
}
|
|
break;
|
|
|
|
case SecurityIdentification:
|
|
{
|
|
*pdwImpLevel = RPC_C_IMP_LEVEL_IDENTIFY;
|
|
}
|
|
break;
|
|
|
|
case SecurityImpersonation:
|
|
{
|
|
*pdwImpLevel = RPC_C_IMP_LEVEL_IMPERSONATE;
|
|
}
|
|
break;
|
|
|
|
case SecurityDelegation:
|
|
{
|
|
*pdwImpLevel = RPC_C_IMP_LEVEL_DELEGATE;
|
|
}
|
|
break;
|
|
|
|
default:
|
|
{
|
|
hr = E_FAIL;
|
|
}
|
|
}
|
|
}
|
|
CloseHandle(hThreadTok);
|
|
}
|
|
return hr;
|
|
}
|