windows-nt/Source/XPSP1/NT/sdktools/trace/logman/logman.cpp

2431 lines
80 KiB
C++
Raw Permalink Normal View History

2020-09-26 03:20:57 -05:00
/*****************************************************************************\
Author: Corey Morgan (coreym)
Copyright (c) Microsoft Corporation. All rights reserved.
\*****************************************************************************/
#include <windows.h>
#include <objbase.h>
#include <wbemidl.h>
#include <conio.h>
#include <pdhp.h>
#include <pdhmsg.h>
#include <lmuse.h>
#include "resource.h"
#include <wmistr.h>
#include <initguid.h>
#include <evntrace.h>
#include <shlwapi.h>
#include "logmmsg.h"
#include "varg.c"
// Exclusive
#define GROUP_START 0x01
#define GROUP_END 0x02
// Group Exclusive
#define GROUP_COUNTER 0x01
#define GROUP_TRACE 0x02
#define GROUP_CREATE 0x04
// Conditional
#define GROUP_ARG 0x01
#define VERB_CREATE 0x0001
#define VERB_COUNTER 0x0002
#define VERB_TRACE 0x0004
#define VERB_START 0x0008
#define VERB_STOP 0x0010
#define VERB_UPDATE 0x0020
#define VERB_QUERY 0x0040
#define VERB_DELETE 0x0080
#define VERB_PROV 0x0100
VARG_DECLARE_COMMANDS
VARG_DEBUG ( VARG_FLAG_OPTIONAL|VARG_FLAG_HIDDEN )
VARG_HELP ( VARG_FLAG_OPTIONAL )
VARG_BOOL ( IDS_PARAM_CREATE, VARG_FLAG_OPTIONAL|VARG_FLAG_VERB|VARG_FLAG_REQ_ADV, FALSE )
VARG_BOOL ( IDS_PARAM_COUNTER, VARG_FLAG_ADVERB|VARG_FLAG_HIDDEN, FALSE )
VARG_BOOL ( IDS_PARAM_TRACE, VARG_FLAG_ADVERB|VARG_FLAG_HIDDEN, FALSE )
VARG_BOOL ( IDS_PARAM_START, VARG_FLAG_OPTIONAL|VARG_FLAG_VERB, FALSE )
VARG_BOOL ( IDS_PARAM_STOP, VARG_FLAG_OPTIONAL|VARG_FLAG_VERB, FALSE )
VARG_BOOL ( IDS_PARAM_DELETE, VARG_FLAG_OPTIONAL|VARG_FLAG_VERB, FALSE )
VARG_BOOL ( IDS_PARAM_QUERY, VARG_FLAG_DEFAULTABLE|VARG_FLAG_VERB|VARG_FLAG_OPT_ADV, FALSE )
VARG_BOOL ( IDS_PARAM_QUERYPROV, VARG_FLAG_ADVERB|VARG_FLAG_HIDDEN, FALSE )
VARG_BOOL ( IDS_PARAM_UPDATE, VARG_FLAG_OPTIONAL|VARG_FLAG_VERB, FALSE )
VARG_STR ( IDS_PARAM_NAME, VARG_FLAG_NOFLAG|VARG_FLAG_CHOMP, NULL )
VARG_STR ( IDS_PARAM_COMPUTER, VARG_FLAG_OPTIONAL, NULL )
VARG_INI ( IDS_PARAM_SETTINGS, VARG_FLAG_OPTIONAL, NULL )
VARG_DATE ( IDS_PARAM_BEGIN, VARG_FLAG_OPTIONAL|VARG_FLAG_ARG_DATE )
VARG_DATE ( IDS_PARAM_END, VARG_FLAG_OPTIONAL|VARG_FLAG_ARG_DATE )
VARG_MSZ ( IDS_PARAM_MANUAL, VARG_FLAG_OPTIONAL|VARG_FLAG_FLATHELP|VARG_FLAG_LITERAL, NULL )
VARG_BOOL ( IDS_PARAM_REPEAT, VARG_FLAG_OPTIONAL|VARG_FLAG_NEGATE, FALSE )
VARG_STR ( IDS_PARAM_OUTPUT, VARG_FLAG_OPTIONAL|VARG_FLAG_RCDEFAULT|VARG_FLAG_CHOMP, IDS_DEFAULT_OUTPUT )
VARG_STR ( IDS_PARAM_FORMAT, VARG_FLAG_OPTIONAL|VARG_FLAG_LITERAL, _T("bin") )
VARG_BOOL ( IDS_PARAM_APPEND, VARG_FLAG_OPTIONAL|VARG_FLAG_NEGATE, FALSE )
VARG_STR ( IDS_PARAM_VERSION, VARG_FLAG_OPTIONAL|VARG_FLAG_DEFAULTABLE|VARG_FLAG_NEGATE|VARG_FLAG_RCDEFAULT|VARG_FLAG_LITERAL, IDS_DEFAULT_NNNNN )
VARG_STR ( IDS_PARAM_RUNCMD, VARG_FLAG_OPTIONAL|VARG_FLAG_ARG_FILENAME|VARG_FLAG_NEGATE|VARG_FLAG_CHOMP, NULL )
VARG_INT ( IDS_PARAM_MAX, VARG_FLAG_OPTIONAL|VARG_FLAG_ARG_DEFAULT|VARG_FLAG_NEGATE, 0 )
VARG_TIME ( IDS_PARAM_NEWFILE, VARG_FLAG_OPTIONAL|VARG_FLAG_DEFAULTABLE|VARG_FLAG_ARG_TIME|VARG_FLAG_NEGATE )
VARG_MSZ ( IDS_PARAM_COUNTERS, VARG_FLAG_OPTIONAL, NULL )
VARG_STR ( IDS_PARAM_COUNTERFILE, VARG_FLAG_OPTIONAL|VARG_FLAG_ARG_FILENAME|VARG_FLAG_CHOMP, NULL )
VARG_TIME ( IDS_PARAM_SAMPLERATE, VARG_FLAG_OPTIONAL|VARG_FLAG_ARG_TIME )
VARG_STR ( IDS_PARAM_LOGGERNAME, VARG_FLAG_OPTIONAL, NULL )
VARG_BOOL ( IDS_PARAM_REALTIME, VARG_FLAG_OPTIONAL|VARG_FLAG_NEGATE, FALSE )
VARG_MSZ ( IDS_PARAM_PROVIDER, VARG_FLAG_OPTIONAL|VARG_FLAG_FLATHELP, NULL )
VARG_STR ( IDS_PARAM_PROVIDERFILE,VARG_FLAG_OPTIONAL|VARG_FLAG_ARG_FILENAME|VARG_FLAG_CHOMP, NULL )
VARG_BOOL ( IDS_PARAM_USERMODE, VARG_FLAG_OPTIONAL|VARG_FLAG_NEGATE, FALSE )
VARG_INT ( IDS_PARAM_BUFFERSIZE, VARG_FLAG_OPTIONAL|VARG_FLAG_ARG_DEFAULT, 64 )
VARG_TIME ( IDS_PARAM_FLUSHTIMER, VARG_FLAG_OPTIONAL|VARG_FLAG_ARG_TIME )
VARG_MSZ ( IDS_PARAM_BUFFERS, VARG_FLAG_OPTIONAL|VARG_FLAG_FLATHELP, NULL )
VARG_BOOL ( IDS_PARAM_FLUSHBUFFERS,VARG_FLAG_OPTIONAL, FALSE )
VARG_MSZ ( IDS_PARAM_USER, VARG_FLAG_OPTIONAL|VARG_FLAG_FLATHELP|VARG_FLAG_NEGATE|VARG_FLAG_DEFAULTABLE, _T("") )
VARG_TIME ( IDS_PARAM_RUNFOR, VARG_FLAG_OPTIONAL|VARG_FLAG_ARG_TIME )
VARG_BOOL ( IDS_PARAM_YES, VARG_FLAG_OPTIONAL, FALSE )
VARG_BOOL ( IDS_PARAM_ETS, VARG_FLAG_OPTIONAL, FALSE )
VARG_INT ( IDS_PARAM_AGE, VARG_FLAG_OPTIONAL|VARG_FLAG_HIDDEN, FALSE )
VARG_MSZ ( IDS_PARAM_MODE, VARG_FLAG_OPTIONAL, NULL )
VARG_DECLARE_NAMES
eDebug,
eHelp,
eCreate,
eCounter,
eTrace,
eStart,
eStop,
eDelete,
eQuery,
eQueryProv,
eUpdate,
eName,
eComputer,
eConfig,
eBegin,
eEnd,
eManual,
eRepeat,
eOutput,
eFormat,
eAppend,
eVersion,
eRunCmd,
eMax,
eNewFile,
eCounters,
eCounterFile,
eSampleInterval,
eLoggerName,
eRealTime,
eProviders,
eProviderFile,
eUserMode,
eBufferSize,
eFlushTimer,
eBuffers,
eFlushBuffers,
eUser,
eRunFor,
eYes,
eEts,
eAgeLimit,
eMode,
VARG_DECLARE_FORMAT
VARG_VERB ( eCreate, VERB_CREATE )
VARG_ADVERB( eCounter, VERB_CREATE, VERB_COUNTER )
VARG_ADVERB( eTrace, VERB_CREATE, VERB_TRACE )
VARG_VERB ( eStart, VERB_START )
VARG_VERB ( eStop, VERB_STOP )
VARG_VERB ( eDelete, VERB_DELETE )
VARG_VERB ( eQuery, VERB_QUERY )
VARG_ADVERB( eQueryProv, VERB_QUERY, VERB_PROV )
VARG_VERB ( eUpdate, VERB_UPDATE )
VARG_VERB ( eName, VERB_CREATE|VERB_UPDATE|VERB_START|VERB_STOP|VERB_QUERY|VERB_DELETE )
VARG_VERB ( eBegin, VERB_UPDATE|VERB_CREATE )
VARG_VERB ( eEnd, VERB_UPDATE|VERB_CREATE )
VARG_VERB ( eManual, VERB_UPDATE|VERB_CREATE|VERB_COUNTER )
VARG_VERB ( eRepeat, VERB_UPDATE|VERB_CREATE )
VARG_VERB ( eOutput, VERB_UPDATE|VERB_CREATE )
VARG_VERB ( eFormat, VERB_UPDATE|VERB_CREATE )
VARG_VERB ( eAppend, VERB_UPDATE|VERB_CREATE )
VARG_VERB ( eVersion, VERB_UPDATE|VERB_CREATE )
VARG_VERB ( eRunCmd, VERB_UPDATE|VERB_CREATE )
VARG_VERB ( eMax, VERB_UPDATE|VERB_CREATE|VERB_TRACE )
VARG_VERB ( eNewFile, VERB_UPDATE|VERB_CREATE )
VARG_VERB ( eCounters, VERB_UPDATE|VERB_CREATE|VERB_COUNTER )
VARG_VERB ( eCounterFile, VERB_UPDATE|VERB_CREATE|VERB_COUNTER )
VARG_VERB ( eSampleInterval,VERB_UPDATE|VERB_CREATE|VERB_COUNTER )
VARG_VERB ( eLoggerName, VERB_UPDATE|VERB_CREATE|VERB_TRACE )
VARG_VERB ( eRealTime, VERB_UPDATE|VERB_CREATE|VERB_TRACE )
VARG_VERB ( eProviders, VERB_UPDATE|VERB_CREATE|VERB_TRACE )
VARG_VERB ( eProviderFile, VERB_UPDATE|VERB_CREATE|VERB_TRACE )
VARG_VERB ( eUserMode, VERB_UPDATE|VERB_CREATE|VERB_TRACE )
VARG_VERB ( eBufferSize, VERB_UPDATE|VERB_CREATE|VERB_TRACE )
VARG_VERB ( eFlushTimer, VERB_UPDATE|VERB_CREATE|VERB_TRACE )
VARG_VERB ( eBuffers, VERB_UPDATE|VERB_CREATE|VERB_TRACE )
VARG_VERB ( eFlushBuffers, VERB_UPDATE|VERB_CREATE|VERB_TRACE )
VARG_VERB ( eUser, VERB_UPDATE|VERB_CREATE|VERB_TRACE|VERB_COUNTER|VERB_QUERY )
VARG_VERB ( eComputer, VERB_UPDATE|VERB_CREATE|VERB_TRACE|VERB_COUNTER|VERB_QUERY|VERB_START|VERB_STOP|VERB_DELETE )
VARG_VERB ( eRunFor, VERB_UPDATE|VERB_CREATE )
VARG_VERB ( eEts, VERB_UPDATE|VERB_TRACE|VERB_START|VERB_STOP|VERB_QUERY )
VARG_VERB ( eMode, VERB_UPDATE|VERB_CREATE|VERB_TRACE )
VARG_GROUP ( eCounter, VARG_GRPX(GROUP_COUNTER,GROUP_TRACE) )
VARG_GROUP ( eTrace, VARG_GRPX(GROUP_TRACE,GROUP_COUNTER) )
VARG_GROUP ( eStart, VARG_EXCL(GROUP_START) )
VARG_GROUP ( eStop, VARG_EXCL(GROUP_END) )
VARG_GROUP ( eQuery, VARG_COND(GROUP_ARG) )
VARG_GROUP ( eName, VARG_COND(GROUP_ARG) )
VARG_GROUP ( eBegin, VARG_EXCL(GROUP_START) )
VARG_GROUP ( eEnd, VARG_EXCL(GROUP_END) )
VARG_GROUP ( eManual, VARG_EXCL(GROUP_START) )
VARG_GROUP ( eCounters, VARG_GRPX(GROUP_COUNTER,GROUP_TRACE) )
VARG_GROUP ( eCounterFile, VARG_GRPX(GROUP_COUNTER,GROUP_TRACE) )
VARG_GROUP ( eSampleInterval,VARG_GRPX(GROUP_COUNTER,GROUP_TRACE) )
VARG_GROUP ( eLoggerName, VARG_GRPX(GROUP_TRACE,GROUP_COUNTER) )
VARG_GROUP ( eRealTime, VARG_GRPX(GROUP_TRACE,GROUP_COUNTER) )
VARG_GROUP ( eProviders, VARG_GRPX(GROUP_TRACE,GROUP_COUNTER) )
VARG_GROUP ( eProviderFile, VARG_GRPX(GROUP_TRACE,GROUP_COUNTER) )
VARG_GROUP ( eUserMode, VARG_GRPX(GROUP_TRACE,GROUP_COUNTER) )
VARG_GROUP ( eBufferSize, VARG_GRPX(GROUP_TRACE,GROUP_COUNTER) )
VARG_GROUP ( eFlushTimer, VARG_GRPX(GROUP_TRACE,GROUP_COUNTER) )
VARG_GROUP ( eBuffers, VARG_GRPX(GROUP_TRACE,GROUP_COUNTER) )
VARG_GROUP ( eFlushBuffers, VARG_GRPX(GROUP_TRACE,GROUP_COUNTER) )
VARG_GROUP ( eEts, VARG_GRPX(GROUP_TRACE,GROUP_COUNTER) )
VARG_GROUP ( eMode, VARG_GRPX(GROUP_TRACE,GROUP_COUNTER) )
VARG_EXHELP( eEts, IDS_EXAMPLE_ETS )
VARG_EXHELP( eCreate, IDS_EXAMPLE_CREATE )
VARG_EXHELP( eStart, IDS_EXAMPLE_START )
VARG_EXHELP( eUpdate, IDS_EXAMPLE_UPDATE )
VARG_DECLARE_END
typedef struct _PROVIDER_REC {
_PROVIDER_REC* flink;
_PROVIDER_REC* blink;
LPTSTR strProviderName;
LPTSTR strProviderGuid;
LPTSTR strFlags;
LPTSTR strLevel;
} PROVIDER_REC, *PPROVIDER_REC;
ULONG hextoi( LPWSTR s );
DWORD SetCredentials();
DWORD GetCountersFromFile( LPTSTR strFile, PPDH_PLA_ITEM pItem );
DWORD GetFileFormat( LPTSTR str, LPDWORD pdwFormat );
DWORD SetPlaInfo( PPDH_PLA_INFO pInfo );
HRESULT WbemConnect( IWbemServices** pWbemServices );
HRESULT GetProviders( PPDH_PLA_ITEM pItem );
HRESULT GetTraceNameToGuidMap( PPROVIDER_REC pProviders );
HRESULT EventTraceSessionControl();
HRESULT WbemError( HRESULT hr );
PDH_STATUS QueryCollection( LPTSTR strCollection, BOOL bHeader );
PDH_STATUS QuerySingleCollection( LPTSTR strCollection );
PDH_STATUS ScheduleLog();
void ShowValidationError( PDH_STATUS pdhStatus, PPDH_PLA_INFO pInfo );
void LogmanError( DWORD dwStatus );
void PdhError( PDH_STATUS pdhStatus, PPDH_PLA_INFO pInfo );
#define CHECK_STATUS( hr ) if( ERROR_SUCCESS != hr ){ goto cleanup; }
#define SEVERITY( s ) ((ULONG)s >> 30)
#define NT_KERNEL_GUID _T("{9e814aad-3204-11d2-9a82-006008a86939}")
#define NT_KERNEL_LOGGER _T("NT Kernel Logger")
#define PDH_MODULE _T("PDH.DLL")
TCHAR g_strUser[MAXSTR];
TCHAR g_strPassword[MAXSTR];
TCHAR g_strIPC[MAXSTR];
int __cdecl _tmain( int argc, LPTSTR* argv )
{
HRESULT hr = ERROR_SUCCESS;
PDH_STATUS pdhStatus = ERROR_SUCCESS;
DWORD dwStatus = ERROR_SUCCESS;
PDH_PLA_INFO_W info;
ZeroMemory( &info, sizeof( PDH_PLA_INFO ) );
ParseCmd( argc, argv );
if( Commands[eUser].bDefined && !(Commands[eUser].bNegated) ){
dwStatus = SetCredentials();
}else{
g_strIPC[0] = _T('\0');
}
if( dwStatus != ERROR_SUCCESS ){
dwStatus = LOGMAN_ERROR_LOGON;
goto cleanup;
}
if( Commands[eEts].bValue ){
hr = EventTraceSessionControl();
goto cleanup;
}
if( Commands[eStart].bValue ){
pdhStatus = PdhPlaStart( Commands[eName].strValue, Commands[eComputer].strValue );
CHECK_STATUS(pdhStatus);
}else if( Commands[eStop].bValue ){
pdhStatus = PdhPlaStop( Commands[eName].strValue, Commands[eComputer].strValue );
CHECK_STATUS(pdhStatus);
}else if( Commands[eDelete].bValue ){
pdhStatus = PdhPlaDelete( Commands[eName].strValue, Commands[eComputer].strValue );
CHECK_STATUS(pdhStatus);
}else if( Commands[eCreate].bDefined ){
DWORD dwType = 0;
if( Commands[eCounter].bDefined ){
dwType = PLA_COUNTER_LOG;
}else if( Commands[eTrace].bDefined ){
dwType = PLA_TRACE_LOG;
}
info.dwMask |= PLA_INFO_FLAG_TYPE;
info.dwType = dwType;
dwStatus = SetPlaInfo( &info );
CHECK_STATUS( dwStatus );
if( Commands[eYes].bValue ){
PdhPlaDeleteW( Commands[eName].strValue, Commands[eComputer].strValue );
}
pdhStatus = PdhPlaCreate( Commands[eName].strValue, Commands[eComputer].strValue, &info );
CHECK_STATUS( pdhStatus );
if( Commands[eRunFor].bDefined ||
Commands[eManual].bDefined ){
pdhStatus = ScheduleLog();
if( pdhStatus != ERROR_SUCCESS ){
PdhPlaDeleteW( Commands[eName].strValue, Commands[eComputer].strValue );
}
CHECK_STATUS( pdhStatus );
}
}else if( Commands[eQuery].bDefined ){
if( Commands[eQueryProv].bDefined ){
hr = GetTraceNameToGuidMap( NULL );
goto cleanup;
}else if( Commands[eName].strValue != NULL ){
pdhStatus = QuerySingleCollection( Commands[eName].strValue );
}else{
DWORD dwSize = 0;
LPTSTR mszCollections = NULL;
pdhStatus = PdhPlaEnumCollections( Commands[eComputer].strValue, &dwSize, mszCollections );
if( ERROR_SUCCESS == pdhStatus || PDH_INSUFFICIENT_BUFFER == pdhStatus ){
mszCollections = (LPTSTR)VARG_ALLOC( dwSize * sizeof(TCHAR) );
if( mszCollections ){
LPTSTR strCollection;
pdhStatus = PdhPlaEnumCollections( Commands[eComputer].strValue, &dwSize, mszCollections );
if( ERROR_SUCCESS == pdhStatus ){
strCollection = mszCollections;
while( strCollection != NULL && *strCollection != _T('\0') ){
QueryCollection( strCollection, (strCollection == mszCollections) );
strCollection += ( _tcslen( strCollection ) + 1 );
}
varg_printf( g_normal, _T("\n") );
}
VARG_FREE( mszCollections );
}else{
dwStatus = ERROR_OUTOFMEMORY;
}
}
}
}else if( Commands[eUpdate].bDefined ){
dwStatus = SetPlaInfo( &info );
CHECK_STATUS( dwStatus );
if( info.dwMask != 0 ){
// Try update without credentials
pdhStatus = PdhPlaSetInfoW( Commands[eName].strValue, Commands[eComputer].strValue, &info );
if( PDH_ACCESS_DENIED == pdhStatus ){
// Try again with credintials
dwStatus = SetCredentials();
CHECK_STATUS( dwStatus );
if( ERROR_SUCCESS == dwStatus ){
info.dwMask |= PLA_INFO_FLAG_USER;
info.strUser = g_strUser;
info.strPassword = g_strPassword;
pdhStatus = PdhPlaSetInfoW( Commands[eName].strValue, Commands[eComputer].strValue, &info );
}
}
CHECK_STATUS( pdhStatus );
}
if( Commands[eRunFor].bDefined ||
Commands[eManual].bDefined ){
pdhStatus = ScheduleLog();
CHECK_STATUS( pdhStatus );
}
}
cleanup:
if( ERROR_SUCCESS == dwStatus &&
ERROR_SUCCESS == hr &&
ERROR_SUCCESS == pdhStatus ){
PrintMessage( g_normal, IDS_MESSAGE_SUCCESS );
}else{
if( ERROR_SUCCESS != dwStatus ){
LogmanError( dwStatus );
}
if( ERROR_SUCCESS != hr ){
WbemError( hr );
dwStatus = hr;
}
if( ERROR_SUCCESS != pdhStatus ){
PdhError( pdhStatus, &info );
dwStatus = pdhStatus;
}
if( SEVERITY( dwStatus ) == STATUS_SEVERITY_WARNING ){
PrintMessage( g_normal, IDS_MESSAGE_SUCCESS );
dwStatus = ERROR_SUCCESS;
}
}
if( info.dwMask & PLA_INFO_FLAG_COUNTERS && Commands[eCounterFile].bDefined ){
VARG_FREE( info.Perf.piCounterList.strCounters );
}
if( info.dwMask & PLA_INFO_FLAG_PROVIDERS ){
VARG_FREE( info.Trace.piProviderList.strProviders );
VARG_FREE( info.Trace.piProviderList.strFlags );
VARG_FREE( info.Trace.piProviderList.strLevels );
}
if( _tcslen( g_strIPC ) ){
dwStatus = NetUseDel( NULL, g_strIPC, USE_LOTS_OF_FORCE /*luke*/ );
}
ZeroMemory( g_strPassword, sizeof(TCHAR)*MAXSTR );
FreeCmd();
CoUninitialize();
return dwStatus;
}
DWORD
SetPlaInfo( PPDH_PLA_INFO pInfo )
{
DWORD dwStatus = ERROR_SUCCESS;
if( Commands[eCounters].bDefined && Commands[eCounters].strValue != NULL ){
pInfo->dwMask |= PLA_INFO_FLAG_COUNTERS;
pInfo->Perf.piCounterList.dwType = PLA_COUNTER_LOG;
pInfo->Perf.piCounterList.strCounters = Commands[eCounters].strValue;
}else if( Commands[eCounterFile].bDefined ){
pInfo->dwMask |= PLA_INFO_FLAG_COUNTERS;
dwStatus = GetCountersFromFile( Commands[eCounterFile].strValue, &(pInfo->Perf.piCounterList) );
CHECK_STATUS( dwStatus );
}
if( Commands[eProviders].bDefined || Commands[eProviderFile].bDefined ){
pInfo->dwMask |= PLA_INFO_FLAG_PROVIDERS;
dwStatus = GetProviders( &(pInfo->Trace.piProviderList) );
CHECK_STATUS( dwStatus );
pInfo->Trace.piProviderList.dwType = PLA_TRACE_LOG;
}
if( Commands[eFormat].bDefined ){
DWORD dwFormat;
dwStatus = GetFileFormat( Commands[eFormat].strValue, &dwFormat );
CHECK_STATUS( dwStatus );
pInfo->dwMask |= PLA_INFO_FLAG_FORMAT;
pInfo->dwFileFormat = dwFormat;
}
if( Commands[eAppend].bDefined ){
pInfo->dwMask |= PLA_INFO_FLAG_DATASTORE;
if( Commands[eAppend].bNegated ){
pInfo->dwDatastoreAttributes |= PLA_DATASTORE_OVERWRITE;
}else{
pInfo->dwDatastoreAttributes |= PLA_DATASTORE_APPEND;
}
}
if( Commands[eSampleInterval].bDefined ){
pInfo->dwMask |= PLA_INFO_FLAG_INTERVAL;
pInfo->Perf.ptSampleInterval.wDataType = PLA_TT_DTYPE_UNITS;
pInfo->Perf.ptSampleInterval.dwUnitType = PLA_TT_UTYPE_SECONDS;
pInfo->Perf.ptSampleInterval.wTimeType = PLA_TT_TTYPE_SAMPLE;
pInfo->Perf.ptSampleInterval.dwAutoMode = PLA_AUTO_MODE_AFTER;
pInfo->Perf.ptSampleInterval.dwValue = Commands[eSampleInterval].stValue.wSecond;
pInfo->Perf.ptSampleInterval.dwValue += Commands[eSampleInterval].stValue.wMinute * 60;
pInfo->Perf.ptSampleInterval.dwValue += Commands[eSampleInterval].stValue.wHour * 3600;
}
if( Commands[eBufferSize].bDefined ){
pInfo->dwMask |= PLA_INFO_FLAG_BUFFERSIZE;
pInfo->Trace.dwBufferSize = Commands[eBufferSize].nValue;
}
if( Commands[eBuffers].bDefined ){
LPTSTR strMin;
LPTSTR strMax;
strMin = Commands[eBuffers].strValue;
if( NULL != strMin ){
pInfo->dwMask |= PLA_INFO_FLAG_MINBUFFERS;
pInfo->Trace.dwMinimumBuffers = _ttoi( strMin );
strMax = strMin + (_tcslen( strMin )+1);
if( *strMax != _T('\0') ){
pInfo->dwMask |= PLA_INFO_FLAG_MAXBUFFERS;
pInfo->Trace.dwMaximumBuffers = _ttoi( strMax );
}
}
}
if( Commands[eFlushTimer].bDefined ){
DWORD dwSeconds;
dwSeconds = Commands[eFlushTimer].stValue.wSecond;
dwSeconds += Commands[eFlushTimer].stValue.wMinute * 60;
dwSeconds += Commands[eFlushTimer].stValue.wHour * 3600;
pInfo->dwMask |= PLA_INFO_FLAG_FLUSHTIMER;
pInfo->Trace.dwFlushTimer = dwSeconds;
}
if( Commands[eMax].bDefined ){
pInfo->dwMask |= PLA_INFO_FLAG_MAXLOGSIZE;
if( Commands[eMax].bNegated ){
pInfo->dwMaxLogSize = PLA_DISK_MAX_SIZE;
}else{
pInfo->dwMaxLogSize = Commands[eMax].nValue;
}
}
if( Commands[eRunCmd].bDefined ){
pInfo->dwMask |= PLA_INFO_FLAG_RUNCOMMAND;
if( Commands[eRunCmd].bNegated ){
pInfo->strCommandFileName = _T("");
}else{
pInfo->strCommandFileName = Commands[eRunCmd].strValue;
}
}
if( Commands[eOutput].bDefined && NULL != Commands[eOutput].strValue ){
if( ((pInfo->dwMask & PLA_INFO_FLAG_FORMAT) &&
pInfo->dwFileFormat == PLA_SQL_LOG ) ||
!StrCmpNI( Commands[eOutput].strValue, _T("SQL:"), 4 ) ){
pInfo->dwMask |= PLA_INFO_FLAG_SQLNAME;
pInfo->strSqlName = Commands[eOutput].strValue;
}else{
if( IsEmpty( Commands[eOutput].strValue ) ){
pInfo->dwMask |= (PLA_INFO_FLAG_DEFAULTDIR|PLA_INFO_FLAG_FILENAME);
pInfo->strDefaultDir = _T("");
pInfo->strBaseFileName = _T("");
}else{
LPTSTR str = NULL;
TCHAR full[MAXSTR];
TCHAR buffer[MAX_PATH];
TCHAR drive[_MAX_DRIVE];
TCHAR dir[_MAX_DIR];
TCHAR fname[_MAX_FNAME];
TCHAR ext[_MAX_EXT];
DWORD dwFormat;
_tfullpath( full, Commands[eOutput].strValue, MAXSTR );
_tsplitpath( full, drive, dir, fname, ext );
VARG_FREE( Commands[eOutput].strValue );
Commands[eOutput].strValue = NULL;
if( _tcslen( drive ) ){
_stprintf( buffer, _T("%s%s"), drive, dir );
}else{
_tcscpy( buffer, dir );
}
if( _tcslen( buffer ) ){
pInfo->dwMask |= PLA_INFO_FLAG_DEFAULTDIR;
AddStringToMsz( &Commands[eOutput].strValue, buffer );
}
dwStatus = GetFileFormat( ext, &dwFormat );
if( ERROR_SUCCESS == dwStatus ){
_stprintf( buffer, _T("%s"), fname );
}else{
_stprintf( buffer, _T("%s%s"), fname, ext );
dwStatus = ERROR_SUCCESS;
}
if( _tcslen( buffer ) ){
pInfo->dwMask |= PLA_INFO_FLAG_FILENAME;
AddStringToMsz( &Commands[eOutput].strValue, buffer );
}
str = Commands[eOutput].strValue;
if( str != NULL ){
if( pInfo->dwMask & PLA_INFO_FLAG_DEFAULTDIR ){
pInfo->strDefaultDir = str;
str += ( _tcslen( str ) + 1 );
}
if( pInfo->dwMask & PLA_INFO_FLAG_FILENAME ){
pInfo->strBaseFileName = str;
}
}else{
dwStatus = ERROR_OUTOFMEMORY;
goto cleanup;
}
}
}
}
if( Commands[eVersion].bDefined ){
DWORD dwFormat = 0;
pInfo->dwMask |= PLA_INFO_FLAG_AUTOFORMAT;
if( Commands[eVersion].bNegated ){
dwFormat = PLA_SLF_NAME_NONE;
}else if( !_tcsicmp( Commands[eVersion].strValue, _T("nnnnnn") ) ){
dwFormat = PLA_SLF_NAME_NNNNNN;
}else if( !_tcsicmp( Commands[eVersion].strValue, _T("mmddhhmm") ) ){
dwFormat = PLA_SLF_NAME_MMDDHHMM;
}else{
dwFormat = PLA_SLF_NAME_NNNNNN;
}
pInfo->dwAutoNameFormat = dwFormat;
}
if( Commands[eRealTime].bDefined ){
pInfo->dwMask |= PLA_INFO_FLAG_MODE;
if( Commands[eRealTime].bNegated ){
pInfo->Trace.dwMode &= ~EVENT_TRACE_REAL_TIME_MODE;
}else{
pInfo->Trace.dwMode |= EVENT_TRACE_REAL_TIME_MODE;
}
}
if( Commands[eUserMode].bDefined ){
pInfo->dwMask |= PLA_INFO_FLAG_MODE;
if( Commands[eUserMode].bNegated ){
pInfo->Trace.dwMode &= ~EVENT_TRACE_PRIVATE_LOGGER_MODE;
}else{
pInfo->Trace.dwMode |= EVENT_TRACE_PRIVATE_LOGGER_MODE;
}
}
if( Commands[eLoggerName].bDefined ){
pInfo->dwMask |= PLA_INFO_FLAG_LOGGERNAME;
pInfo->Trace.strLoggerName = Commands[eLoggerName].strValue;
}
if( Commands[eRepeat].bDefined ){
pInfo->dwMask |= PLA_INFO_FLAG_REPEAT;
if( Commands[eRepeat].bNegated ){
pInfo->ptRepeat.dwAutoMode = PLA_AUTO_MODE_NONE;
}else{
pInfo->ptRepeat.wDataType = PLA_TT_DTYPE_UNITS;
pInfo->ptRepeat.wTimeType = PLA_TT_TTYPE_REPEAT_SCHEDULE;
pInfo->ptRepeat.dwUnitType = PLA_TT_UTYPE_DAYSOFWEEK;
pInfo->ptRepeat.dwAutoMode = PLA_AUTO_MODE_CALENDAR;
pInfo->ptRepeat.dwValue = 0x0000007F;
}
}
if( Commands[eNewFile].bDefined ){
pInfo->dwMask |= PLA_INFO_FLAG_CRTNEWFILE;
pInfo->ptCreateNewFile.wTimeType = PLA_TT_TTYPE_CREATENEWFILE;
pInfo->ptCreateNewFile.wDataType = PLA_TT_DTYPE_UNITS;
if( Commands[eNewFile].bNegated ){
pInfo->ptCreateNewFile.dwAutoMode = PLA_AUTO_MODE_NONE;
}else{
DWORD dwSeconds = Commands[eNewFile].stValue.wSecond;
dwSeconds += Commands[eNewFile].stValue.wMinute * 60;
dwSeconds += Commands[eNewFile].stValue.wHour * 3600;
if( dwSeconds == 0 ){
pInfo->ptCreateNewFile.dwAutoMode = PLA_AUTO_MODE_SIZE;
}else{
pInfo->ptCreateNewFile.dwAutoMode = PLA_AUTO_MODE_AFTER;
pInfo->ptCreateNewFile.dwUnitType = PLA_TT_UTYPE_SECONDS;
pInfo->ptCreateNewFile.dwValue = dwSeconds;
}
}
}
if( Commands[eUser].bDefined ){
pInfo->dwMask |= PLA_INFO_FLAG_USER;
if( Commands[eUser].bNegated ){
pInfo->strUser = _T("");
pInfo->strPassword = _T("");
}else{
pInfo->strUser = g_strUser;
pInfo->strPassword = g_strPassword;
}
}
if(Commands[eBegin].bDefined){
FILETIME ft;
pInfo->dwMask |= PLA_INFO_FLAG_BEGIN;
SystemTimeToFileTime( &Commands[eBegin].stValue, &ft );
pInfo->ptLogBeginTime.wTimeType = PLA_TT_TTYPE_START;
pInfo->ptLogBeginTime.wDataType = PLA_TT_DTYPE_DATETIME;
pInfo->ptLogBeginTime.dwAutoMode = PLA_AUTO_MODE_AT;
pInfo->ptLogBeginTime.llDateTime = (((ULONGLONG) ft.dwHighDateTime) << 32) + ft.dwLowDateTime;
}
if(Commands[eEnd].bDefined){
FILETIME ft;
pInfo->dwMask |= PLA_INFO_FLAG_END;
SystemTimeToFileTime( &Commands[eEnd].stValue, &ft );
pInfo->ptLogEndTime.wTimeType = PLA_TT_TTYPE_STOP;
pInfo->ptLogEndTime.wDataType = PLA_TT_DTYPE_DATETIME;
pInfo->ptLogEndTime.dwAutoMode = PLA_AUTO_MODE_AT;
pInfo->ptLogEndTime.llDateTime = (((ULONGLONG) ft.dwHighDateTime) << 32) + ft.dwLowDateTime;
}
cleanup:
return dwStatus;
}
DWORD
GetFileFormat( LPTSTR str, LPDWORD pdwFormat )
{
*pdwFormat = PLA_BIN_FILE;
LPTSTR strCmp = str;
if( strCmp != NULL ){
if( *strCmp == _T('.') ){
strCmp++;
}
if( !_tcsicmp( strCmp, _T("TSV")) ){
*pdwFormat = PLA_TSV_FILE;
return ERROR_SUCCESS;
}else if( !_tcsicmp( strCmp, _T("CSV")) ){
*pdwFormat = PLA_CSV_FILE;
return ERROR_SUCCESS;
}else if( !_tcsicmp( strCmp, _T("BLG")) ){
*pdwFormat = PLA_BIN_FILE;
return ERROR_SUCCESS;
}else if( !_tcsicmp( strCmp, _T("BIN")) ){
*pdwFormat = PLA_BIN_FILE;
return ERROR_SUCCESS;
}else if( !_tcsicmp( strCmp, _T("BINCIRC")) ){
*pdwFormat = PLA_BIN_CIRC_FILE;
return ERROR_SUCCESS;
}else if( !_tcsicmp( strCmp, _T("SQL")) ){
*pdwFormat = PLA_SQL_LOG;
return ERROR_SUCCESS;
}
}
return LOGMAN_ERROR_FILEFORMAT;
}
PDH_STATUS
QueryCollection( LPTSTR strCollection, BOOL bHeader )
{
PDH_STATUS pdhStatus;
PDH_PLA_INFO info;
DWORD dwInfoSize = sizeof( PDH_PLA_INFO );
TCHAR strType[MAXSTR];
TCHAR strStatus[MAXSTR];
if( bHeader ){
PrintMessage( g_normal, IDS_MESSAGE_QUERY );
for(int i=0;i<79;i++){ varg_printf( g_normal, _T("-") ); }
varg_printf( g_normal, _T("\n") );
}
info.dwMask = PLA_INFO_FLAG_TYPE|PLA_INFO_FLAG_STATUS;
pdhStatus = PdhPlaGetInfoW( strCollection, Commands[eComputer].strValue, &dwInfoSize, &info );
if( ERROR_SUCCESS == pdhStatus ){
switch( info.dwType ){
case PLA_COUNTER_LOG:
LoadString( NULL, IDS_MESSAGE_PERF, strType, MAXSTR );
break;
case PLA_TRACE_LOG:
LoadString( NULL, IDS_MESSAGE_EVENTTRACE, strType, MAXSTR );
break;
case PLA_ALERT:
LoadString( NULL, IDS_MESSAGE_ALERT, strType, MAXSTR );
break;
}
switch( info.dwStatus ){
case PLA_QUERY_STOPPED:
LoadString( NULL, IDS_MESSAGE_STOPPED, strStatus, MAXSTR );
break;
case PLA_QUERY_RUNNING:
LoadString( NULL, IDS_MESSAGE_RUNNING, strStatus, MAXSTR );
break;
case PLA_QUERY_START_PENDING:
default:
LoadString( NULL, IDS_MESSAGE_PENDING, strStatus, MAXSTR );
break;
}
PrintMessage( g_normal, IDS_MESSAGE_QUERYF, strCollection, strType, strStatus );
}
return pdhStatus;
}
PDH_STATUS
QuerySingleCollection( LPTSTR strCollection )
{
PDH_STATUS pdhStatus = ERROR_SUCCESS;
PPDH_PLA_INFO pInfo = NULL;
DWORD dwInfoSize = 0;
TCHAR buffer[MAXSTR];
pdhStatus = PdhPlaGetInfoW( strCollection, Commands[eComputer].strValue, &dwInfoSize, pInfo );
if( ERROR_SUCCESS == pdhStatus ){
pInfo = (PPDH_PLA_INFO)VARG_ALLOC(dwInfoSize);
if( NULL != pInfo ){
pInfo->dwMask = PLA_INFO_FLAG_ALL;
pdhStatus = PdhPlaGetInfoW( strCollection, Commands[eComputer].strValue, &dwInfoSize, pInfo );
if( pdhStatus == ERROR_SUCCESS ){
varg_printf( g_normal, _T("\n") );
PrintMessage( g_normal, IDS_MESSAGE_NAME, strCollection );
switch( pInfo->dwType ){
case PLA_COUNTER_LOG:
LoadString( NULL, IDS_MESSAGE_PERF, buffer, MAXSTR );
break;
case PLA_TRACE_LOG:
LoadString( NULL, IDS_MESSAGE_EVENTTRACE, buffer, MAXSTR );
break;
case PLA_ALERT:
LoadString( NULL, IDS_MESSAGE_ALERT, buffer, MAXSTR );
break;
default:
buffer[0] = _T('\0');
}
PrintMessage( g_normal, IDS_MESSAGE_TYPE, buffer );
switch( pInfo->dwStatus ){
case PLA_QUERY_STOPPED:
LoadString( NULL, IDS_MESSAGE_STOPPED, buffer, MAXSTR );
break;
case PLA_QUERY_RUNNING:
LoadString( NULL, IDS_MESSAGE_RUNNING, buffer, MAXSTR );
break;
case PLA_QUERY_START_PENDING:
default:
LoadString( NULL, IDS_MESSAGE_PENDING, buffer, MAXSTR );
break;
}
PrintMessage( g_normal, IDS_MESSAGE_STATUS, buffer );
DWORD dwStart;
DWORD dwStop;
PDH_TIME_INFO TimeInfo;
pdhStatus = PdhPlaGetScheduleW( strCollection, Commands[eComputer].strValue, &dwStart, &dwStop, &TimeInfo );
if( ERROR_SUCCESS == pdhStatus ){
LoadString( NULL, IDS_MESSAGE_MANUAL, buffer, MAXSTR );
PrintMessage( g_normal, IDS_MESSAGE_START );
switch( dwStart ){
case PLA_AUTO_MODE_NONE:
varg_printf( g_normal, buffer );
break;
case PLA_AUTO_MODE_CALENDAR:
case PLA_AUTO_MODE_AT:
{
SYSTEMTIME st;
FILETIME ft;
ft.dwLowDateTime = (DWORD) (TimeInfo.StartTime & 0xFFFFFFFF );
ft.dwHighDateTime = (DWORD) (TimeInfo.StartTime >> 32 );
FileTimeToSystemTime( &ft, &st );
PrintDate( &st );
if( dwStart == PLA_AUTO_MODE_CALENDAR ){
PrintMessage( g_normal, IDS_MESSAGE_REPEATING );
}
}
}
varg_printf( g_normal, _T("\n") );
PrintMessage( g_normal, IDS_MESSAGE_STOP );
switch( dwStop ){
case PLA_AUTO_MODE_NONE:
varg_printf( g_normal, buffer );
break;
case PLA_AUTO_MODE_AT:
{
SYSTEMTIME st;
FILETIME ft;
ft.dwLowDateTime = (DWORD) (TimeInfo.EndTime & 0xFFFFFFFF );
ft.dwHighDateTime = (DWORD) (TimeInfo.EndTime >> 32 );
FileTimeToSystemTime( &ft, &st );
PrintDate( &st );
}
break;
case PLA_AUTO_MODE_AFTER:
{
SYSTEMTIME st;
LONGLONG llMS;
ZeroMemory( &st, sizeof(SYSTEMTIME) );
PlaTimeInfoToMilliSeconds( &pInfo->ptLogEndTime, &llMS );
llMS /= 1000;
st.wHour = (USHORT)(llMS / 3600);
st.wMinute = (USHORT)((llMS%3600) / 60);
st.wSecond = (USHORT)((llMS % 60) % 3600);
PrintMessage( g_normal, IDS_MESSAGE_AFTER );
PrintDate( &st );
}
}
varg_printf( g_normal, _T("\n") );
}
if( pInfo->dwMask & PLA_INFO_FLAG_CRTNEWFILE ){
if( pInfo->ptCreateNewFile.dwAutoMode == PLA_AUTO_MODE_SIZE ){
PrintMessage( g_normal, IDS_MESSAGE_NEWFILE );
PrintMessage( g_normal, IDS_MESSAGE_BYSIZE );
}else if( pInfo->ptCreateNewFile.dwAutoMode == PLA_AUTO_MODE_AFTER ){
SYSTEMTIME st;
LONGLONG llMS;
ZeroMemory( &st, sizeof(SYSTEMTIME) );
PlaTimeInfoToMilliSeconds( &pInfo->ptCreateNewFile, &llMS );
llMS /= 1000;
st.wHour = (USHORT)(llMS / 3600);
st.wMinute = (USHORT)((llMS%3600) / 60);
st.wSecond = (USHORT)((llMS % 60) % 3600);
PrintMessage( g_normal, IDS_MESSAGE_NEWFILE );
PrintMessage( g_normal, IDS_MESSAGE_AFTER );
PrintDate( &st );
varg_printf( g_normal, _T("\n") );
}
}
dwInfoSize = MAXSTR;
pdhStatus = PdhPlaGetLogFileNameW( strCollection, Commands[eComputer].strValue, pInfo, 0, &dwInfoSize, buffer );
if( pdhStatus != ERROR_SUCCESS ){
LoadString( NULL, IDS_MESSAGE_BADPARAM, buffer, MAXSTR );
pdhStatus = ERROR_SUCCESS;
}
PrintMessage( g_normal, IDS_MESSAGE_FILE, buffer );
PrintMessage( g_normal, IDS_MESSAGE_RUNAS, pInfo->strUser ? pInfo->strUser : _T("") );
switch( pInfo->dwType ){
case PLA_COUNTER_LOG:
{
LPTSTR strCounter;
PrintMessage( g_normal, IDS_MESSAGE_COUNTERS );
strCounter = pInfo->Perf.piCounterList.strCounters;
if( NULL != strCounter ){
if( PRIMARYLANGID( GetUserDefaultUILanguage()) == LANG_ENGLISH ){
while( *strCounter != _T('\0') ){
varg_printf( g_normal, _T(" %1!s!\n"), strCounter );
strCounter += (_tcslen(strCounter)+1);
}
}else{
LPTSTR strLocale = NULL;
DWORD dwSize = MAX_PATH;
strLocale = (LPTSTR)VARG_ALLOC(dwSize*sizeof(TCHAR));
if( NULL != strLocale ){
while( *strCounter != _T('\0') ){
pdhStatus = PdhTranslateLocaleCounter( strCounter, strLocale, &dwSize );
if( PDH_MORE_DATA == pdhStatus ){
LPTSTR strMem = (LPTSTR)VARG_REALLOC( strLocale, (dwSize*sizeof(TCHAR)) );
if( NULL != strMem ){
strLocale = strMem;
}else{
pdhStatus = PDH_MEMORY_ALLOCATION_FAILURE;
VARG_FREE(strLocale);
break;
}
}else if( ERROR_SUCCESS == pdhStatus ){
varg_printf( g_normal, _T(" %1!s!\n"), strLocale );
strCounter += (_tcslen(strCounter)+1);
}else{
pdhStatus = ERROR_SUCCESS;
varg_printf( g_normal, _T(" %1!s!\n"), strCounter );
strCounter += (_tcslen(strCounter)+1);
}
}
}else{
pdhStatus = PDH_MEMORY_ALLOCATION_FAILURE;
}
}
}
}
break;
case PLA_TRACE_LOG:
{
LPTSTR strProvider;
PrintMessage( g_normal, IDS_MESSAGE_LOGGERNAME, pInfo->Trace.strLoggerName );
PrintMessage( g_normal, IDS_MESSAGE_BUFFERSIZE, pInfo->Trace.dwBufferSize );
PrintMessage( g_normal, IDS_MESSAGE_PROVIDERS );
strProvider = pInfo->Trace.piProviderList.strProviders;
if( NULL != strProvider ){
while( *strProvider != _T('\0') ){
PrintMessage( g_normal, IDS_MESSAGE_PRVGUID, strProvider );
strProvider += (_tcslen(strProvider)+1);
}
}else{
StringFromGUID2( SystemTraceControlGuid, buffer, 128 );
PrintMessage( g_normal, IDS_MESSAGE_PRVGUID, buffer );
}
}
break;
case PLA_ALERT:
break;
}
}
VARG_FREE( pInfo );
}
}
varg_printf( g_normal, _T("\n") );
return pdhStatus;
}
DWORD
SetCredentials( )
{
DWORD dwStatus = ERROR_SUCCESS;
LPTSTR strUser = NULL;
LPTSTR strPassword = NULL;
TCHAR buffer[MAXSTR];
TCHAR strConnection[MAXSTR];
LoadString( NULL, IDS_MESSAGE_THISCON, strConnection, MAXSTR );
ZeroMemory( g_strUser, MAXSTR*sizeof(TCHAR) );
ZeroMemory( g_strPassword, MAXSTR*sizeof(TCHAR) );
if( Commands[eUser].strValue == NULL || !_tcslen( Commands[eUser].strValue ) ){
LoadString( NULL, IDS_MESSAGE_EUSER, buffer, MAXSTR );
varg_printf( g_normal,
buffer,
Commands[eName].bDefined ?
Commands[eName].strValue :
Commands[eComputer].bDefined ?
Commands[eComputer].strValue :
strConnection
);
GetUserInput( g_strUser, MAXSTR, TRUE );
strUser = g_strUser;
strPassword = _T("*");
}else{
strUser = Commands[eUser].strValue;
strPassword = strUser + (_tcslen( strUser ) + 1);
}
if( NULL == strPassword ){
strPassword = _T("");
}else if( !_tcscmp( _T("*"), strPassword ) ){
LoadString( NULL, IDS_MESSAGE_EPASSWORD, buffer, MAXSTR );
varg_printf( g_normal, buffer,
Commands[eName].bDefined ?
Commands[eName].strValue :
Commands[eComputer].bDefined ?
Commands[eComputer].strValue :
strConnection
);
GetUserInput( buffer, MAXSTR, FALSE );
strPassword = buffer;
}
_tcscpy( g_strPassword, strPassword );
if( strUser != NULL ){
_tcscpy( g_strUser, strUser );
strUser = g_strUser;
}
TCHAR strUserBuffer[MAXSTR];
_tcscpy( strUserBuffer, strUser );
LPTSTR strDomain = _tcstok( strUserBuffer, _T("\\") );
strUser = _tcstok( NULL, _T("") );
if( strUser == NULL ){
strUser = strDomain;
strDomain = NULL;
}
if( Commands[eComputer].bDefined ){
if( _tcslen(Commands[eComputer].strValue) > 2 && Commands[eComputer].strValue[1] == _T('\\') ){
_stprintf( g_strIPC, _T("%s\\ipc$"), Commands[eComputer].strValue );
}else{
_stprintf( g_strIPC, _T("\\\\%s\\ipc$"), Commands[eComputer].strValue );
}
LPTSTR pNetInfo;
dwStatus = NetUseGetInfo( NULL, g_strIPC, 0, (LPBYTE*)&pNetInfo );
if( dwStatus != ERROR_SUCCESS ){
USE_INFO_2 info;
DWORD dwError;
ZeroMemory( &info, sizeof(USE_INFO_2) );
info.ui2_local = NULL;
info.ui2_remote = g_strIPC;
info.ui2_password = g_strPassword;
info.ui2_username = strUser;
info.ui2_domainname = strDomain;
info.ui2_asg_type = USE_IPC;
dwStatus = NetUseAdd (
NULL,
2,
(unsigned char *)&info,
&dwError
);
}else{
ZeroMemory( g_strIPC, sizeof(TCHAR) * MAXSTR );
}
}
return dwStatus;
}
DWORD GetCountersFromFile( LPTSTR strFile, PPDH_PLA_ITEM pItem )
{
TCHAR buffer[MAXSTR];
LPTSTR strList = NULL;
LPTSTR strItem = NULL;
FILE* f = _tfopen( strFile, _T("r") );
if( !f ){
return GetLastError();
}
pItem->dwType = PLA_COUNTER_LOG;
pItem->strCounters = NULL;
while( NULL != _fgetts( buffer, MAXSTR, f ) ){
if( buffer[0] == _T(';') || // comments
buffer[0] == _T('#') ){
continue;
}
Chomp(buffer);
strItem = _tcstok( buffer, _T("\"\n") );
if( strItem != NULL ){
AddStringToMsz( &strList, strItem );
}
}
fclose( f );
pItem->strCounters = strList;
return ERROR_SUCCESS;
}
BOOL IsStrGuid( LPTSTR str ){
if( _tcslen( str ) < 38 ){
return FALSE;
}
if( str[0] == _T('{') &&
str[9] == _T('-') &&
str[14] == _T('-') &&
str[19] == _T('-') &&
str[24] == _T('-') &&
str[37] == _T('}')
){
return TRUE;
}
return FALSE;
}
HRESULT GetProviders( PPDH_PLA_ITEM pItem )
{
HRESULT hr = ERROR_SUCCESS;
TCHAR buffer[MAXSTR];
LPTSTR strLine = NULL;
LPTSTR strItem = NULL;
LPTSTR strLevel;
LPTSTR strFlags;
PPROVIDER_REC pProviderHead = NULL;
PPROVIDER_REC pProvider;
FILE* f = NULL;
if( Commands[eProviderFile].bDefined ){
f = _tfopen( Commands[eProviderFile].strValue, _T("r") );
if( !f ){
return GetLastError();
}
strLine = _fgetts( buffer, MAXSTR, f );
Chomp(buffer);
}else if( Commands[eProviders].bDefined ){
strLine = Commands[eProviders].strValue;
}
while( NULL != strLine ){
strItem = NULL;
strFlags = NULL;
strLevel = NULL;
if( strLine[0] == _T(';') || // comments
strLine[0] == _T('#') ){
continue;
}
if( Commands[eProviderFile].bDefined ){
strItem = _tcstok( buffer, _T("\"\n\t ") );
strFlags = _tcstok( NULL, _T("\n\t ") );
strLevel = _tcstok( NULL, _T("\n\t ") );
}else if( Commands[eProviders].bDefined ){
strItem = strLine;
if( *strItem != _T('\0') ){
strFlags = strItem + (_tcslen(strItem)+1);
if( *strFlags != _T('\0') ){
strLevel = strFlags + (_tcslen(strFlags)+1);
if( IsEmpty( strLevel ) ){
strLevel = NULL;
}
}else{
strFlags = NULL;
}
}else{
strItem = NULL;
}
}
if( strItem != NULL ){
pProvider = (PPROVIDER_REC)VARG_ALLOC( sizeof(PROVIDER_REC) );
if( NULL != pProvider ){
LPTSTR strZero = _T("0");
ZeroMemory( pProvider, sizeof(PROVIDER_REC) );
if( pProviderHead == NULL ){
pProviderHead = pProvider;
}else{
pProviderHead->blink = pProvider;
pProvider->flink = pProviderHead;
pProviderHead = pProvider;
}
if( IsStrGuid( strItem ) ){
ASSIGN_STRING( pProvider->strProviderGuid, strItem );
}else{
ASSIGN_STRING( pProvider->strProviderName, strItem );
}
if( strFlags != NULL ){
ASSIGN_STRING( pProvider->strFlags, strFlags );
}else{
ASSIGN_STRING( pProvider->strFlags, strZero );
}
if( strLevel != NULL ){
ASSIGN_STRING( pProvider->strLevel, strLevel );
}else{
ASSIGN_STRING( pProvider->strLevel, strZero );
}
}
}
if( Commands[eProviderFile].bDefined ){
strLine = _fgetts( buffer, MAXSTR, f );
Chomp(buffer);
}else if( Commands[eProviders].bDefined ){
break;
}
}
if( NULL != f ){
fclose( f );
}
hr = GetTraceNameToGuidMap( pProviderHead );
pItem->dwType = PLA_TRACE_LOG;
pProvider = pProviderHead;
while( pProvider ){
hr = AddStringToMsz( &(pItem->strProviders), pProvider->strProviderGuid );
if( hr != ERROR_SUCCESS ){
break;
}
AddStringToMsz( &(pItem->strLevels), pProvider->strLevel );
if( hr != ERROR_SUCCESS ){
break;
}
AddStringToMsz( &(pItem->strFlags), pProvider->strFlags );
if( hr != ERROR_SUCCESS ){
break;
}
pProvider = pProvider->flink;
}
PPROVIDER_REC pDelete;
pProvider = pProviderHead;
while( pProvider ){
pDelete = pProvider;
pProvider = pProvider->flink;
VARG_FREE( pDelete->strProviderGuid );
VARG_FREE( pDelete->strProviderName );
VARG_FREE( pDelete->strFlags );
VARG_FREE( pDelete->strLevel );
VARG_FREE( pDelete );
}
return hr;
}
BOOL AllProvidersMapped( PPROVIDER_REC pProviders )
{
PPROVIDER_REC pProvider = pProviders;
while( pProvider ){
if( pProvider->strProviderGuid == NULL ){
return FALSE;
}
if( pProvider->strFlags != NULL ){
if( *(pProvider->strFlags) == _T('(') ){
return FALSE;
}
}
pProvider = pProvider->flink;
}
return TRUE;
}
HRESULT
DecodeFlags( IWbemClassObject *pClass, LPTSTR strFlags, LPDWORD pdwFlags )
{
HRESULT hr = ERROR_SUCCESS;
IWbemQualifierSet *pQualSet = NULL;
SAFEARRAY* saValues = NULL;
SAFEARRAY* saValueMap = NULL;
LONG nFlavor;
VARIANT var;
hr = pClass->GetPropertyQualifierSet( L"Flags", &pQualSet );
if( pQualSet != NULL ){
hr = pQualSet->Get( L"ValueMap", 0, &var, &nFlavor );
if( ERROR_SUCCESS == hr && (var.vt & VT_ARRAY) ){
saValueMap = var.parray;
}
hr = pQualSet->Get( L"Values", 0, &var, &nFlavor );
if( ERROR_SUCCESS == hr && (var.vt & VT_ARRAY) ){
saValues = var.parray;
}
if( saValues != NULL && saValueMap != NULL ){
BSTR HUGEP *pMapData;
BSTR HUGEP *pValuesData;
LONG uMapBound, lMapBound;
LONG uValuesBound, lValuesBound;
SafeArrayGetUBound( saValueMap, 1, &uMapBound );
SafeArrayGetLBound( saValueMap, 1, &lMapBound );
SafeArrayAccessData( saValueMap, (void HUGEP **)&pMapData );
SafeArrayGetUBound( saValues, 1, &uValuesBound );
SafeArrayGetLBound( saValues, 1, &lValuesBound );
SafeArrayAccessData( saValues, (void HUGEP **)&pValuesData );
for ( LONG i=lMapBound; i<=uMapBound; i++) {
LONG dwFlag;
if( i<lValuesBound || i>uValuesBound ){
break;
}
dwFlag = hextoi( pMapData[i] );
if( FindString( strFlags, pValuesData[i] ) ){
*pdwFlags |= dwFlag;
}
}
SafeArrayUnaccessData( saValueMap );
SafeArrayUnaccessData( saValues );
SafeArrayDestroy( saValueMap );
SafeArrayDestroy( saValues );
}
pQualSet->Release();
}
if( hr == WBEM_S_FALSE ){
hr = ERROR_SUCCESS;
}
return hr;
}
HRESULT
SetProviderGuid( PPROVIDER_REC pProviders, IWbemClassObject *pClass, LPTSTR strProvider, LPTSTR strGuid )
{
PPROVIDER_REC pProvider = pProviders;
while( pProvider ){
if( !IsEmpty(pProvider->strProviderGuid) && IsEmpty( pProvider->strProviderName ) ){
if( !_tcsicmp(pProvider->strProviderGuid, strGuid ) ){
ASSIGN_STRING( pProvider->strProviderName, strProvider );
break;
}
}else if( IsEmpty(pProvider->strProviderGuid) && !IsEmpty( pProvider->strProviderName ) ){
if( !_tcsicmp(pProvider->strProviderName, strProvider ) ){
ASSIGN_STRING( pProvider->strProviderGuid, strGuid );
break;
}
}
pProvider = pProvider->flink;
}
if( NULL != pProvider ){
if( pProvider->strFlags != NULL ){
if( *(pProvider->strFlags) == _T('(') ){
DWORD dwFlags = 0;
TCHAR buffer[MAXSTR];
DecodeFlags( pClass, pProvider->strFlags, &dwFlags );
VARG_FREE( pProvider->strFlags );
pProvider->strFlags = NULL;
_stprintf( buffer, _T("0x%08x"), dwFlags );
ASSIGN_STRING( pProvider->strFlags, buffer );
}
}
return ERROR_SUCCESS;
}
return ERROR_PATH_NOT_FOUND;
}
HRESULT
GetTraceNameToGuidMap( PPROVIDER_REC pProviders )
{
HRESULT hr;
IWbemServices* pIWbemServices = NULL;
IEnumWbemClassObject *pEnumProviders = NULL;
if( pProviders != NULL && AllProvidersMapped( pProviders ) ){
return ERROR_SUCCESS;
}
BSTR bszTraceClass = SysAllocString( L"EventTrace" );
BSTR bszDescription = SysAllocString( L"Description" );
BSTR bszGuid = SysAllocString( L"Guid" );
IWbemQualifierSet *pQualSet = NULL;
IWbemClassObject *pClass = NULL;
VARIANT vDiscription;
VARIANT vGuid;
ULONG nReturned;
hr = WbemConnect( &pIWbemServices );
CHECK_STATUS( hr );
hr = pIWbemServices->CreateClassEnum (
bszTraceClass,
WBEM_FLAG_SHALLOW|WBEM_FLAG_USE_AMENDED_QUALIFIERS,
NULL,
&pEnumProviders
);
CHECK_STATUS( hr );
if( pProviders == NULL ){
PrintMessage( g_normal, IDS_MESSAGE_QUERYP );
for( int i=0;i<79;i++){ varg_printf( g_normal, _T("-") );}
varg_printf( g_normal, _T("\n") );
}
while( ERROR_SUCCESS == hr ){
if( pProviders != NULL && AllProvidersMapped( pProviders ) ){
break;
}
hr = pEnumProviders->Next( (-1), 1, &pClass, &nReturned );
if( ERROR_SUCCESS == hr ){
pClass->GetQualifierSet ( &pQualSet );
if ( pQualSet != NULL ) {
hr = pQualSet->Get ( bszDescription, 0, &vDiscription, 0 );
if( ERROR_SUCCESS == hr ){
hr = pQualSet->Get ( bszGuid, 0, &vGuid, 0 );
if( ERROR_SUCCESS == hr ){
if( pProviders != NULL ){
SetProviderGuid( pProviders, pClass, vDiscription.bstrVal, vGuid.bstrVal );
}else{
varg_printf( g_normal, _T("%1!-40s! %2!-38s!\n"), vDiscription.bstrVal, vGuid.bstrVal );
}
}
}
}
}
}
if( NULL == pProviders ){
varg_printf( g_normal, _T("\n") );
}
if( hr == WBEM_S_FALSE ){
hr = ERROR_SUCCESS;
}
cleanup:
SysFreeString( bszTraceClass );
SysFreeString( bszDescription );
SysFreeString( bszGuid );
if (pIWbemServices){
pIWbemServices->Release();
}
return hr;
}
PDH_STATUS
ScheduleLog()
{
PDH_STATUS pdhStatus = ERROR_SUCCESS;
PDH_TIME_INFO info;
if( Commands[eRunFor].bDefined){
DWORD dwSeconds = Commands[eRunFor].stValue.wSecond;
ZeroMemory( &info, sizeof(PDH_TIME_INFO) );
dwSeconds += Commands[eRunFor].stValue.wMinute * 60;
dwSeconds += Commands[eRunFor].stValue.wHour * 3600;
info.EndTime = dwSeconds;
info.SampleCount = PLA_TT_UTYPE_SECONDS;
pdhStatus = PdhPlaSchedule(
Commands[eName].strValue,
Commands[eComputer].strValue,
PLA_AUTO_MODE_AFTER,
&info
);
}
if( ERROR_SUCCESS == pdhStatus && Commands[eManual].bDefined ){
LPTSTR strManual = Commands[eManual].strValue;
ZeroMemory( &info, sizeof(PDH_TIME_INFO) );
while( strManual != NULL && *strManual != _T('\0') ){
if( !_tcsicmp( strManual, _T("start")) ){
info.StartTime = 1;
}
if( !_tcsicmp( strManual,_T("stop")) ){
info.EndTime = 1;
}
strManual += (_tcslen( strManual )+1);
}
pdhStatus = PdhPlaSchedule(
Commands[eName].strValue,
Commands[eComputer].strValue,
PLA_AUTO_MODE_NONE,
&info
);
}
return pdhStatus;
}
HRESULT
WbemConnect( IWbemServices** pWbemServices )
{
WCHAR buffer[MAXSTR];
IWbemLocator *pLocator = NULL;
BSTR bszNamespace = NULL;
if( Commands[eComputer].bDefined ){
_stprintf( buffer, _T("\\\\%s\\%s"), Commands[eComputer].strValue, L"root\\wmi" );
bszNamespace = SysAllocString( buffer );
}else{
bszNamespace = SysAllocString( L"root\\wmi" );
}
HRESULT hr = CoInitialize(0);
hr = CoCreateInstance(
CLSID_WbemLocator,
0,
CLSCTX_INPROC_SERVER,
IID_IWbemLocator,
(LPVOID *) &pLocator
);
CHECK_STATUS( hr );
if( Commands[eUser].bDefined ){
hr = pLocator->ConnectServer(
bszNamespace,
g_strUser,
g_strPassword,
NULL,
0L,
NULL,
NULL,
pWbemServices
);
}else{
hr = pLocator->ConnectServer(
bszNamespace,
NULL,
NULL,
NULL,
0L,
NULL,
NULL,
pWbemServices
);
}
CHECK_STATUS( hr );
hr = CoSetProxyBlanket(
*pWbemServices,
RPC_C_AUTHN_WINNT,
RPC_C_AUTHZ_NONE,
NULL,
RPC_C_AUTHN_LEVEL_PKT,
RPC_C_IMP_LEVEL_IMPERSONATE,
NULL,
EOAC_NONE
);
cleanup:
SysFreeString( bszNamespace );
if( pLocator ){
pLocator->Release();
}
return hr;
}
HRESULT
EtsQuerySession( IWbemServices *pWbemService, LPTSTR strSession )
{
HRESULT hr = ERROR_SUCCESS;
IEnumWbemClassObject* pEnumClass = NULL;
IWbemClassObject* pClass = NULL;
IWbemQualifierSet *pQualSet = NULL;
TCHAR buffer[MAXSTR];
BSTR bszClass = SysAllocString( L"TraceLogger" );
varg_printf( g_normal, _T("\n") );
if( NULL == strSession ){
PrintMessage( g_normal, IDS_MESSAGE_ETSQUERY );
for(int i=0;i<79;i++){ varg_printf( g_normal, _T("-") ); }
varg_printf( g_normal, _T("\n") );
}
hr = pWbemService->CreateInstanceEnum( bszClass, WBEM_FLAG_SHALLOW, NULL, &pEnumClass );
CHECK_STATUS( hr );
while ( hr == ERROR_SUCCESS ){
ULONG nObjects;
hr = pEnumClass->Next( WBEM_INFINITE, 1, &pClass, &nObjects );
if( hr == ERROR_SUCCESS ){
VARIANT vValue;
CIMTYPE vtType;
LONG nFlavor;
pClass->Get( L"Name", 0, &vValue, &vtType, &nFlavor );
if( NULL == strSession ){
VARIANT vLogger;
VARIANT vFile;
pClass->Get( L"LoggerId", 0, &vLogger, &vtType, &nFlavor );
pClass->Get( L"LogFileName", 0, &vFile, &vtType, &nFlavor );
hr = VariantChangeType( &vLogger, &vLogger, 0, VT_BSTR );
if( ERROR_SUCCESS == hr ){
PrintMessage( g_normal, IDS_MESSAGE_ETSQUERYF, vValue.bstrVal, vLogger.bstrVal, vFile.bstrVal);
}
}else{
if( _tcsicmp( strSession, vValue.bstrVal ) == 0 ){
LoadString( NULL, IDS_MESSAGE_ETSNAME, buffer, MAXSTR );
PrintMessage( g_normal, IDS_MESSAGE_ETSQUERYSF, buffer, vValue.bstrVal );
}else{
continue;
}
BSTR HUGEP *pData;
SAFEARRAY* saProperties;
LONG uBound, lBound;
vValue.boolVal = TRUE;
vValue.vt = VT_BOOL;
hr = pClass->GetNames( L"DisplayName", WBEM_FLAG_ONLY_IF_TRUE, 0, &saProperties );
if( hr == ERROR_SUCCESS && saProperties != NULL ){
SafeArrayGetUBound( saProperties, 1, &uBound );
SafeArrayGetLBound( saProperties, 1, &lBound );
SafeArrayAccessData( saProperties, (void HUGEP **)&pData );
for( LONG i=lBound;i<=uBound;i++){
VARIANT vLabel;
pClass->GetPropertyQualifierSet( pData[i], &pQualSet );
pQualSet->Get( L"DisplayName", 0, &vLabel, &nFlavor );
_stprintf( buffer, _T("%s:"), vLabel.bstrVal );
pClass->Get( pData[i], 0, &vValue, &vtType, &nFlavor );
hr = VariantChangeType( &vValue, &vValue, 0, VT_BSTR );
if( SUCCEEDED(hr) ){
PrintMessage( g_normal, IDS_MESSAGE_ETSQUERYSF, buffer, vValue.bstrVal );
}
VariantClear( &vValue );
VariantClear( &vLabel );
}
SafeArrayUnaccessData( saProperties );
SafeArrayDestroy( saProperties );
}
hr = pClass->Get( L"Guid", 0, &vValue, &vtType, &nFlavor );
if( ERROR_SUCCESS == hr && VT_NULL != vValue.vt ){
saProperties = vValue.parray;
SafeArrayGetUBound( saProperties, 1, &uBound );
SafeArrayGetLBound( saProperties, 1, &lBound );
SafeArrayAccessData( saProperties, (void HUGEP **)&pData );
PrintMessage( g_normal, IDS_MESSAGE_PROVIDERS );
for( LONG i=lBound;i<=uBound;i++){
PrintMessage( g_normal, IDS_MESSAGE_PRVGUID, pData[i] );
}
}
}
}
}
if( hr == WBEM_S_FALSE ){
hr = ERROR_SUCCESS;
}
varg_printf( g_normal, _T("\n") );
cleanup:
SysFreeString( bszClass );
return hr;
}
#define FIRST_MODE( b ) if( !b ){wcscat( buffer, L"|" );}else{b=FALSE;}
HRESULT
EtsSetSession( IWbemServices* pWbemService, IWbemClassObject* pTrace )
{
HRESULT hr = ERROR_SUCCESS;
VARIANT var;
WCHAR buffer[MAXSTR];
BOOL bFirst;
if( Commands[eOutput].bDefined ){
TCHAR full[MAXSTR];
_tfullpath( full, Commands[eOutput].strValue, MAXSTR );
var.vt = VT_BSTR;
var.bstrVal = SysAllocString( full );
hr = pTrace->Put( L"LogFileName", 0, &var, 0);
VariantClear(&var);
CHECK_STATUS( hr );
}else if( !Commands[eRealTime].bDefined ){
TCHAR full[MAXSTR];
LPTSTR strPath = (LPTSTR)VARG_ALLOC( (_tcslen( Commands[eName].strValue )+6) * sizeof(TCHAR) );
if( NULL != strPath ){
_tcscpy( strPath, Commands[eName].strValue );
_tcscat( strPath, _T(".etl") );
_tfullpath( full, strPath, MAXSTR );
var.vt = VT_BSTR;
var.bstrVal = SysAllocString( full );
hr = pTrace->Put( L"LogFileName", 0, &var, 0);
VariantClear(&var);
VARG_FREE( strPath );
CHECK_STATUS( hr );
}else{
hr = E_OUTOFMEMORY;
goto cleanup;
}
}
if( Commands[eBufferSize].bDefined ){
var.vt = VT_I4;
var.lVal = Commands[eBufferSize].nValue;
hr = pTrace->Put( L"BufferSize", 0, &var, 0);
VariantClear(&var);
CHECK_STATUS( hr );
}
if( Commands[eBuffers].bDefined ){
LPTSTR strMin;
LPTSTR strMax;
var.vt = VT_I4;
strMin = Commands[eBuffers].strValue;
if( NULL != strMin ){
var.lVal = _ttoi( strMin );
hr = pTrace->Put( L"MinimumBuffers", 0, &var, 0);
CHECK_STATUS( hr );
strMax = strMin + (_tcslen( strMin )+1);
if( *strMax != _T('\0') ){
var.lVal = _ttoi( strMax );
hr = pTrace->Put( L"MaximumBuffers", 0, &var, 0);
CHECK_STATUS( hr );
}
}
}
if( Commands[eMax].bDefined ){
var.vt = VT_I4;
var.lVal = Commands[eMax].nValue;
hr = pTrace->Put( L"MaximumFileSize", 0, &var, 0);
VariantClear(&var);
CHECK_STATUS( hr );
}
buffer[0] = L'\0';
var.vt = VT_BSTR;
bFirst = TRUE;
if( Commands[eFormat].bDefined || Commands[eAppend].bDefined ){
DWORD dwFormat = 0;
hr = GetFileFormat( Commands[eFormat].strValue, &dwFormat );
switch(dwFormat){
case PLA_BIN_CIRC_FILE:
FIRST_MODE( bFirst );
wcscpy( buffer, L"Circular" );
break;
case PLA_BIN_FILE:
default:
FIRST_MODE( bFirst );
wcscpy( buffer, L"Sequential" );
}
}
if( Commands[eAppend].bDefined ){
FIRST_MODE( bFirst );
wcscat( buffer, L"Append" );
}
if( Commands[eRealTime].bDefined ){
FIRST_MODE( bFirst );
wcscat( buffer, L"RealTime" );
}
if( Commands[eUserMode].bDefined ){
FIRST_MODE( bFirst );
wcscat( buffer, L"Private" );
}
if( Commands[eMode].bDefined && Commands[eMode].strValue != NULL ){
LPTSTR strMode = Commands[eMode].strValue;
while( *strMode != _T('\0') ){
if( (wcslen( buffer ) + wcslen( strMode ) + 2) > MAXSTR ){
break;
}
FIRST_MODE( bFirst );
wcscat( buffer, strMode );
strMode += (wcslen(strMode)+1);
}
}
var.bstrVal = SysAllocString( buffer );
hr = pTrace->Put( L"LogFileMode", 0, &var, 0);
VariantClear( &var );
CHECK_STATUS( hr );
if( Commands[eFlushTimer].bDefined ){
DWORD dwSeconds;
dwSeconds = Commands[eFlushTimer].stValue.wSecond;
dwSeconds += Commands[eFlushTimer].stValue.wMinute * 60;
dwSeconds += Commands[eFlushTimer].stValue.wHour * 3600;
var.vt = VT_I4;
var.lVal = dwSeconds;
hr = pTrace->Put( L"FlushTimer", 0, &var, 0);
VariantClear(&var);
CHECK_STATUS( hr );
}
if( Commands[eAgeLimit].bDefined ){
var.vt = VT_I4;
var.lVal = Commands[eAgeLimit].nValue;
hr = pTrace->Put( L"AgeLimit", 0, &var, 0);
VariantClear(&var);
CHECK_STATUS( hr );
}
if( !Commands[eProviders].bDefined && !Commands[eProviderFile].bDefined ){
if( _tcsicmp( Commands[eName].strValue, NT_KERNEL_LOGGER ) == 0 ){
LoadString( NULL, IDS_DEFAULT_ETSENABLE, buffer, MAXSTR );
Commands[eProviders].bDefined = TRUE;
ASSIGN_STRING( Commands[eProviders].strValue, NT_KERNEL_GUID );
AddStringToMsz( &Commands[eProviders].strValue, buffer );
}
}
if( Commands[eProviders].bDefined || Commands[eProviderFile].bDefined ){
PDH_PLA_ITEM providers;
LPTSTR strGuid;
LPTSTR strLevel;
LPTSTR strFlags;
long dwCount = 0;
ZeroMemory( &providers, sizeof(PDH_PLA_ITEM) );
hr = GetProviders( &providers );
CHECK_STATUS( hr );
strGuid = providers.strProviders;
strLevel = providers.strLevels;
strFlags = providers.strFlags;
if( strGuid != NULL ){
SAFEARRAY* saGuids;
SAFEARRAY* saLevel;
SAFEARRAY* saFlags;
while( *strGuid != _T('\0') ){
strGuid += _tcslen( strGuid )+1;
dwCount++;
}
strGuid = providers.strProviders;
saGuids = SafeArrayCreateVector( VT_BSTR, 0, dwCount );
saFlags = SafeArrayCreateVector( VT_I4, 0, dwCount );
saLevel = SafeArrayCreateVector( VT_I4, 0, dwCount );
if( saGuids == NULL || saFlags == NULL || saLevel == NULL ){
if( saGuids != NULL ){
SafeArrayDestroy( saGuids );
}
if( saFlags != NULL ){
SafeArrayDestroy( saFlags );
}
if( saLevel != NULL ){
SafeArrayDestroy( saLevel );
}
}else{
BSTR HUGEP *pGuidData;
DWORD HUGEP *pLevelData;
DWORD HUGEP *pFlagData;
SafeArrayAccessData( saGuids, (void HUGEP **)&pGuidData);
SafeArrayAccessData( saFlags, (void HUGEP **)&pFlagData);
SafeArrayAccessData( saLevel, (void HUGEP **)&pLevelData);
for (long i=dwCount-1; i >=0; i--) {
if( strGuid != NULL ){
BSTR bszGuid = SysAllocString( strGuid );
pGuidData[i] = bszGuid;
strGuid += _tcslen( strGuid )+1;
}
if( strLevel != NULL ){
pLevelData[i] = _ttoi( strLevel );
strLevel += _tcslen( strLevel )+1;
}
if( strFlags != NULL ){
pFlagData[i] = hextoi( strFlags );
strFlags += _tcslen( strFlags )+1;
}
}
SafeArrayUnaccessData( saGuids );
SafeArrayUnaccessData( saFlags );
SafeArrayUnaccessData( saLevel );
VARIANT vArray;
vArray.vt = VT_ARRAY|VT_BSTR;
vArray.parray = saGuids;
pTrace->Put( L"Guid", 0, &vArray, 0 );
vArray.vt = VT_ARRAY|VT_I4;
vArray.parray = saFlags;
pTrace->Put( L"EnableFlags", 0, &vArray, 0 );
vArray.vt = VT_ARRAY|VT_I4;
vArray.parray = saLevel;
pTrace->Put( L"Level", 0, &vArray, 0 );
SafeArrayDestroy( saGuids );
SafeArrayDestroy( saFlags );
SafeArrayDestroy( saLevel );
}
}
}
cleanup:
return ERROR_SUCCESS;
}
HRESULT
EtsCallSession( IWbemServices *pWbemService, LPWSTR strFunction )
{
HRESULT hr;
WCHAR buffer[MAXSTR];
IWbemClassObject *pOutInst = NULL;
IWbemCallResult *pCallResult = NULL;
BSTR bszFunction = SysAllocString( strFunction );
BSTR bszNamespace = NULL;
BSTR bszInstance = NULL;
wsprintf( buffer, L"TraceLogger.Name=\"%s\"", Commands[eName].strValue );
bszInstance = SysAllocString( buffer );
hr = pWbemService->ExecMethod( bszInstance, bszFunction, 0, NULL, NULL, &pOutInst, &pCallResult );
CHECK_STATUS( hr );
if( pCallResult ){
LONG lResult;
pCallResult->GetCallStatus( WBEM_INFINITE, &lResult );
hr = lResult;
}
cleanup:
SysFreeString( bszInstance );
SysFreeString( bszFunction );
if( pCallResult ){
pCallResult->Release();
}
if( pOutInst ){
pOutInst->Release();
}
return hr;
}
HRESULT
EtsStartSession(IWbemServices *pWbemService)
{
HRESULT hr = ERROR_SUCCESS;
IWbemClassObject * pClass = NULL;
IWbemClassObject* pNewTrace = NULL;
IWbemCallResult *pCallResult = NULL;
VARIANT var;
BSTR bszClass = SysAllocString( L"TraceLogger" );
hr = pWbemService->GetObject( bszClass, 0, NULL, &pClass, NULL);
CHECK_STATUS( hr );
hr = pClass->SpawnInstance( 0, &pNewTrace );
CHECK_STATUS( hr );
var.vt = VT_BSTR;
var.bstrVal = SysAllocString( Commands[eName].strValue );
hr = pNewTrace->Put( L"Name", 0, &var, 0);
VariantClear(&var);
hr = EtsSetSession( pWbemService, pNewTrace );
CHECK_STATUS( hr );
hr = pWbemService->PutInstance( pNewTrace, WBEM_FLAG_CREATE_ONLY, NULL, &pCallResult );
CHECK_STATUS( hr );
if( pCallResult ){
LONG lResult;
pCallResult->GetCallStatus( WBEM_INFINITE, &lResult );
hr = lResult;
}
CHECK_STATUS( hr );
cleanup:
SysFreeString( bszClass );
if( pCallResult ){
pCallResult->Release();
}
return hr;
}
HRESULT
EtsEnableSession(IWbemServices *pWbemService)
{
HRESULT hr;
WCHAR buffer[MAXSTR];
IWbemClassObject *pOutInst = NULL;
IWbemCallResult *pCallResult = NULL;
IWbemClassObject *pTrace = NULL;
BSTR bszNamespace = NULL;
BSTR bszInstance = NULL;
wsprintf( buffer, L"TraceLogger.Name=\"%s\"", Commands[eName].strValue );
bszInstance = SysAllocString( buffer );
hr = pWbemService->GetObject( bszInstance, 0, NULL, &pTrace, NULL);
CHECK_STATUS( hr );
hr = EtsSetSession( pWbemService, pTrace );
CHECK_STATUS( hr );
hr = pWbemService->PutInstance( pTrace, WBEM_FLAG_UPDATE_ONLY, NULL, &pCallResult );
CHECK_STATUS( hr );
if( pCallResult ){
LONG lResult;
pCallResult->GetCallStatus( WBEM_INFINITE, &lResult );
hr = lResult;
}
CHECK_STATUS( hr );
cleanup:
SysFreeString( bszInstance );
if( pCallResult ){
pCallResult->Release();
}
if( pOutInst ){
pOutInst->Release();
}
return hr;
}
HRESULT EventTraceSessionControl()
{
HRESULT hr = ERROR_SUCCESS;
IWbemServices *pWbemService = NULL;
hr = WbemConnect( &pWbemService );
CHECK_STATUS( hr );
if( Commands[eFlushBuffers].bValue ){
hr = EtsCallSession( pWbemService, L"FlushTrace" );
}else if( Commands[eQuery].bDefined ){
hr = EtsQuerySession( pWbemService, Commands[eName].strValue );
}else if( Commands[eStart].bDefined || Commands[eCreate].bDefined ){
hr = EtsStartSession( pWbemService );
if( SUCCEEDED(hr) ){
EtsQuerySession( pWbemService, Commands[eName].strValue );
}
}else if( Commands[eStop].bDefined || Commands[eDelete].bDefined ){
hr = EtsCallSession( pWbemService, L"StopTrace" );
}else if( Commands[eUpdate].bDefined ){
hr = EtsEnableSession( pWbemService );
}
cleanup:
if( pWbemService ){
pWbemService->Release();
}
return hr;
}
HRESULT WbemError( HRESULT hr )
{
WCHAR szError[MAXSTR] = { NULL };
WCHAR szFacility[MAXSTR] = { NULL };
IWbemStatusCodeText * pStatus = NULL;
SCODE sc = CoCreateInstance(CLSID_WbemStatusCodeText, 0, CLSCTX_INPROC_SERVER,
IID_IWbemStatusCodeText, (LPVOID *) &pStatus);
if(sc == S_OK){
BSTR bstr = 0;
sc = pStatus->GetErrorCodeText(hr, 0, 0, &bstr);
if(sc == S_OK){
wcsncpy(szError, bstr, MAXSTR-1);
SysFreeString(bstr);
bstr = 0;
}
sc = pStatus->GetFacilityCodeText(hr, 0, 0, &bstr);
if(sc == S_OK){
wcsncpy(szFacility, bstr, MAXSTR-1);
SysFreeString(bstr);
bstr = 0;
}
pStatus->Release();
}
if( Commands[eDebug].bDefined ){
if( _tcscmp( szFacility, L"<Null>" ) == 0 ){
LoadString( NULL, IDS_MESSAGE_SYSTEM, szFacility, MAXSTR );
}
PrintMessage( g_debug, LOGMAN_ERROR_WBEM, hr, szFacility, szError );
}else{
PrintMessage( g_debug, IDS_MESSAGE_ERROR );
varg_printf( g_debug, _T("%1!s!"), szError );
}
return ERROR_SUCCESS;
}
void
ShowValidationError( PDH_STATUS pdhStatus, PPDH_PLA_INFO pInfo )
{
DWORD dwFlag;
DWORD dwMask;
if( SEVERITY( pdhStatus ) == STATUS_SEVERITY_WARNING ){
dwMask = pInfo->dwReserved2;
}else{
dwMask = pInfo->dwMask;
}
if( 0 == dwMask ){
return;
}
for( ULONG i=1;i<0x80000000; i*=2 ){
dwFlag = (i & dwMask);
if( 0 == dwFlag ){
continue;
}
switch( SEVERITY( pdhStatus ) ){
case STATUS_SEVERITY_ERROR:
PrintMessage( g_debug, IDS_MESSAGE_ERROR );
break;
case STATUS_SEVERITY_WARNING:
PrintMessage( g_debug, IDS_MESSAGE_WARNING );
break;
}
switch( dwFlag ){
case PLA_INFO_FLAG_FORMAT:
PrintMessage( g_debug, LOGMAN_ERROR_FILEFORMAT, pInfo->dwFileFormat );
break;
case PLA_INFO_FLAG_INTERVAL:
PrintMessage( g_debug, LOGMAN_ERROR_INTERVAL );
break;
case PLA_INFO_FLAG_BUFFERSIZE:
PrintMessage( g_debug, LOGMAN_ERROR_BUFFERSIZE, pInfo->Trace.dwBufferSize );
break;
case PLA_INFO_FLAG_MINBUFFERS:
PrintMessage( g_debug, LOGMAN_ERROR_MINBUFFER, pInfo->Trace.dwMinimumBuffers );
break;
case PLA_INFO_FLAG_MAXBUFFERS:
PrintMessage( g_debug, LOGMAN_ERROR_MAXBUFFER, pInfo->Trace.dwMinimumBuffers );
break;
case PLA_INFO_FLAG_FLUSHTIMER:
PrintMessage( g_debug, LOGMAN_ERROR_FLUSHTIMER, pInfo->Trace.dwFlushTimer );
break;
case PLA_INFO_FLAG_MAXLOGSIZE:
PrintMessage( g_debug, LOGMAN_ERROR_MAXLOGSIZE, pInfo->dwMaxLogSize );
break;
case PLA_INFO_FLAG_RUNCOMMAND:
PrintMessage( g_debug, LOGMAN_ERROR_CMDFILE, pInfo->strCommandFileName );
break;
case PLA_INFO_FLAG_FILENAME:
if( Commands[eOutput].bDefined ){
PrintMessage( g_debug, LOGMAN_ERROR_FILENAME );
}else{
PrintMessage( g_debug, LOGMAN_ERROR_FILENAME_DEFAULT );
}
break;
case PLA_INFO_FLAG_AUTOFORMAT:
PrintMessage( g_debug, LOGMAN_ERROR_AUTOFORMAT );
break;
case PLA_INFO_FLAG_USER:
PrintMessage( g_debug, LOGMAN_ERROR_USER, pInfo->strUser );
break;
case PLA_INFO_FLAG_DATASTORE:
switch( pInfo->dwDatastoreAttributes & PLA_DATASTORE_APPEND_MASK ){
case PLA_DATASTORE_APPEND:
PrintMessage( g_debug, LOGMAN_ERROR_DATASTOREA );
break;
case PLA_DATASTORE_OVERWRITE:
PrintMessage( g_debug, LOGMAN_ERROR_DATASTOREO );
break;
}
break;
case PLA_INFO_FLAG_MODE:
PrintMessage( g_debug, LOGMAN_ERROR_TRACEMODE, pInfo->Trace.dwMode );
break;
case PLA_INFO_FLAG_LOGGERNAME:
PrintMessage( g_debug, LOGMAN_ERROR_LOGGERNAME, pInfo->Trace.strLoggerName );
break;
case PLA_INFO_FLAG_REPEAT:
PrintMessage( g_debug, LOGMAN_ERROR_REPEATMODE );
break;
case PLA_INFO_FLAG_TYPE:
PrintMessage( g_debug, LOGMAN_ERROR_COLLTYPE, pInfo->dwType );
break;
case PLA_INFO_FLAG_DEFAULTDIR:
case PLA_INFO_FLAG_PROVIDERS:
PrintMessage( g_debug, LOGMAN_ERROR_PROVIDER );
break;
case PLA_INFO_FLAG_COUNTERS:
{
LPTSTR strCounter = pInfo->Perf.piCounterList.strCounters;
if( strCounter != NULL ){
DWORD dwCount = 0;
while(*strCounter != _T('\0') ){
if( dwCount++ == pInfo->dwReserved1 ){
break;
}
strCounter += (_tcslen( strCounter )+1 );
}
}
PrintMessage( g_debug, LOGMAN_ERROR_COUNTERPATH, strCounter ? strCounter : _T("") );
}
break;
default:
PrintMessage( g_debug, LOGMAN_ERROR_UNKNOWN );
}
}
varg_printf( g_debug, _T("\n") );
}
void
PdhError( PDH_STATUS pdhStatus, PPDH_PLA_INFO pInfo )
{
switch( pdhStatus ){
case PDH_PLA_VALIDATION_ERROR:
case PDH_PLA_VALIDATION_WARNING:
ShowValidationError( pdhStatus, pInfo );
break;
case PDH_PLA_COLLECTION_ALREADY_RUNNING:
case PDH_PLA_COLLECTION_NOT_FOUND:
case PDH_PLA_ERROR_NOSTART:
case PDH_PLA_ERROR_ALREADY_EXISTS:
PrintErrorEx( pdhStatus, PDH_MODULE, Commands[eName].strValue );
break;
default:
PrintErrorEx( pdhStatus, PDH_MODULE );
}
}
void
LogmanError( DWORD dwStatus )
{
switch( dwStatus ){
case LOGMAN_ERROR_FILEFORMAT:
PrintMessage( g_debug, LOGMAN_ERROR_FILEFORMAT );
break;
case LOGMAN_ERROR_LOGON:
PrintMessage( g_debug, LOGMAN_ERROR_LOGON );
break;
default:
PrintError( dwStatus );
}
}
ULONG hextoi( LPWSTR s )
{
long len;
ULONG num, base, hex;
if (s == NULL || s[0] == L'\0') {
return 0;
}
len = (long) wcslen(s);
if (len == 0) {
return 0;
}
hex = 0;
base = 1;
num = 0;
while (-- len >= 0) {
if (s[len] >= L'0' && s[len] <= L'9'){
num = s[len] - L'0';
}else if (s[len] >= L'a' && s[len] <= L'f'){
num = (s[len] - L'a') + 10;
}else if (s[len] >= L'A' && s[len] <= L'F'){
num = (s[len] - L'A') + 10;
}else if( s[len] == L'x' || s[len] == L'X'){
break;
}else{
continue;
}
hex += num * base;
base = base * 16;
}
return hex;
}