Leaked source code of windows server 2003
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.
 
 
 
 
 
 

257 lines
6.6 KiB

/*****************************************************************************\
Author: Corey Morgan (coreym)
Copyright (c) Microsoft Corporation. All rights reserved.
\*****************************************************************************/
#include <FWcommon.h>
#include <objbase.h>
#include <initguid.h>
#include <strsafe.h>
HMODULE ghModule;
WCHAR *EVENTTRACE_GUIDSTRING = L"{9a5dd473-d410-11d1-b829-00c04f94c7c3}";
WCHAR *SYSMONLOG_GUIDSTRING = L"{f95e1664-7979-44f2-a040-496e7f500043}";
CLSID CLSID_CIM_EVENTTRACE;
CLSID CLSID_CIM_SYSMONLOG;
long g_cLock=0;
EXTERN_C BOOL LibMain32(HINSTANCE hInstance, ULONG ulReason
, LPVOID pvReserved)
{
if (DLL_PROCESS_ATTACH==ulReason)
ghModule = hInstance;
return TRUE;
}
STDAPI DllGetClassObject(REFCLSID rclsid, REFIID riid, PPVOID ppv)
{
HRESULT hr;
CWbemGlueFactory *pObj;
CLSIDFromString(EVENTTRACE_GUIDSTRING, &CLSID_CIM_EVENTTRACE );
CLSIDFromString(SYSMONLOG_GUIDSTRING, &CLSID_CIM_SYSMONLOG );
if( CLSID_CIM_EVENTTRACE != rclsid && CLSID_CIM_SYSMONLOG != rclsid ){
return E_FAIL;
}
pObj= new CWbemGlueFactory();
if( NULL==pObj ){
return E_OUTOFMEMORY;
}
hr=pObj->QueryInterface(riid, ppv);
if( FAILED(hr) ){
delete pObj;
}
return hr;
}
STDAPI DllCanUnloadNow(void)
{
SCODE sc;
if( (0L==g_cLock) &&
CWbemProviderGlue::FrameworkLogoffDLL(L"EventTraceProv") &&
CWbemProviderGlue::FrameworkLogoffDLL(L"SmonLogProv")){
sc = S_OK;
}else{
sc = S_FALSE;
}
return sc;
}
BOOL Is4OrMore(void)
{
OSVERSIONINFO os;
os.dwOSVersionInfoSize = sizeof(OSVERSIONINFO);
if(!GetVersionEx(&os)){
return FALSE;
}
return os.dwMajorVersion >= 4;
}
STDAPI DllRegisterServer(void)
{
HRESULT hr;
DWORD dwStatus = ERROR_SUCCESS;
const size_t cchCLSID = 512;
WCHAR szCLSID[cchCLSID];
LPCWSTR szModule = L"%systemroot%\\system32\\wbem\\evntrprv.dll";
LPWSTR pName;
LPWSTR pModel = L"Both";
HKEY hKey1 = NULL;
HKEY hKey2 = NULL;
// Event Trace Provider
pName = L"Event Trace Logger Provider";
hr = StringCchCopy( szCLSID, cchCLSID, L"SOFTWARE\\CLASSES\\CLSID\\" );
if( FAILED(hr) ){ goto cleanup; }
hr = StringCchCat( szCLSID, cchCLSID, EVENTTRACE_GUIDSTRING );
if( FAILED(hr) ){ goto cleanup; }
dwStatus = RegCreateKeyW(HKEY_LOCAL_MACHINE, szCLSID, &hKey1);
if( ERROR_SUCCESS != dwStatus ){
goto cleanup;
}
RegSetValueExW(hKey1, NULL, 0, REG_SZ, (BYTE *)pName, (wcslen(pName)+1)*sizeof(WCHAR));
dwStatus = RegCreateKeyW(hKey1, L"InprocServer32", &hKey2 );
if( ERROR_SUCCESS != dwStatus ){
goto cleanup;
}
RegSetValueExW(hKey2, NULL, 0, REG_EXPAND_SZ, (BYTE *)szModule, (wcslen(szModule)+1)*sizeof(WCHAR));
RegSetValueExW(hKey2, L"ThreadingModel", 0, REG_SZ, (BYTE *)pModel, (wcslen(pModel)+1)*sizeof(WCHAR));
if( NULL != hKey1 ){
RegCloseKey(hKey1);
hKey1 = NULL;
}
if( NULL != hKey2 ){
RegCloseKey(hKey2);
hKey2 = NULL;
}
// Sysmon Log Provider
pName = L"System Log Provider";
hr = StringCchCopy( szCLSID, cchCLSID, L"SOFTWARE\\CLASSES\\CLSID\\" );
if( FAILED(hr) ){ goto cleanup; }
hr = StringCchCat( szCLSID, cchCLSID, SYSMONLOG_GUIDSTRING );
if( FAILED(hr) ){ goto cleanup; }
dwStatus = RegCreateKeyW(HKEY_LOCAL_MACHINE, szCLSID, &hKey1);
if( ERROR_SUCCESS != dwStatus ){
goto cleanup;
}
RegSetValueExW(hKey1, NULL, 0, REG_SZ, (BYTE *)pName, (wcslen(pName)+1)*sizeof(WCHAR));
dwStatus = RegCreateKeyW(hKey1, L"InprocServer32", &hKey2 );
if( ERROR_SUCCESS != dwStatus ){
goto cleanup;
}
RegSetValueExW(hKey2, NULL, 0, REG_EXPAND_SZ, (BYTE *)szModule, (wcslen(szModule)+1)*sizeof(WCHAR));
RegSetValueExW(hKey2, L"ThreadingModel", 0, REG_SZ, (BYTE *)pModel, (wcslen(pModel)+1)*sizeof(WCHAR));
cleanup:
if( NULL != hKey1 ){
RegCloseKey(hKey1);
}
if( NULL != hKey2 ){
RegCloseKey(hKey2);
}
if( FAILED(hr) ){
dwStatus = hr;
}
return dwStatus;
}
STDAPI DllUnregisterServer(void)
{
HRESULT hr;
const size_t cchSize = 128;
WCHAR wcID[cchSize];
WCHAR szCLSID[cchSize];
HKEY hKey;
// Event Trace Provider
CLSIDFromString(EVENTTRACE_GUIDSTRING, &CLSID_CIM_EVENTTRACE);
StringFromGUID2(CLSID_CIM_EVENTTRACE, wcID, cchSize);
hr = StringCchCopy( szCLSID, cchSize, L"SOFTWARE\\CLASSES\\CLSID\\");
if( FAILED(hr) ){ goto cleanup; }
hr = StringCchCat( szCLSID, cchSize, wcID);
if( FAILED(hr) ){ goto cleanup; }
DWORD dwRet = RegOpenKeyW(HKEY_LOCAL_MACHINE, szCLSID, &hKey);
if( dwRet == NO_ERROR ){
RegDeleteKeyW(hKey, L"InProcServer32" );
RegCloseKey(hKey);
}
dwRet = RegOpenKeyW(HKEY_LOCAL_MACHINE, L"SOFTWARE\\CLASSES\\CLSID\\", &hKey);
if(dwRet == NO_ERROR){
RegDeleteKeyW(hKey,wcID);
RegCloseKey(hKey);
}
// System Log Provider
CLSIDFromString(SYSMONLOG_GUIDSTRING, &CLSID_CIM_SYSMONLOG);
StringFromGUID2(CLSID_CIM_SYSMONLOG, wcID, cchSize);
hr = StringCchCopy( szCLSID, cchSize, L"SOFTWARE\\CLASSES\\CLSID\\");
if( FAILED(hr) ){ goto cleanup; }
hr = StringCchCat( szCLSID, cchSize, wcID);
if( FAILED(hr) ){ goto cleanup; }
dwRet = RegOpenKeyW(HKEY_LOCAL_MACHINE, szCLSID, &hKey);
if( dwRet == NO_ERROR ){
RegDeleteKeyW(hKey, L"InProcServer32" );
RegCloseKey(hKey);
}
dwRet = RegOpenKeyW(HKEY_LOCAL_MACHINE, L"SOFTWARE\\CLASSES\\CLSID\\", &hKey);
if(dwRet == NO_ERROR){
RegDeleteKeyW(hKey,wcID);
RegCloseKey(hKey);
}
cleanup:
return NOERROR;
}
BOOL APIENTRY DllMain ( HINSTANCE hInstDLL,
DWORD fdwReason,
LPVOID lpReserved )
{
BOOL bRet = TRUE;
switch( fdwReason ){
case DLL_PROCESS_ATTACH:
DisableThreadLibraryCalls(hInstDLL);
ghModule = hInstDLL;
bRet = CWbemProviderGlue::FrameworkLoginDLL(L"EventTraceProv");
break;
case DLL_THREAD_ATTACH:
// Do thread-specific initialization.
break;
case DLL_THREAD_DETACH:
// Do thread-specific cleanup.
break;
case DLL_PROCESS_DETACH:
// Perform any necessary cleanup.
break;
}
return bRet;
}