Source code of Windows XP (NT5)
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.

2430 lines
80 KiB

  1. /*****************************************************************************\
  2. Author: Corey Morgan (coreym)
  3. Copyright (c) Microsoft Corporation. All rights reserved.
  4. \*****************************************************************************/
  5. #include <windows.h>
  6. #include <objbase.h>
  7. #include <wbemidl.h>
  8. #include <conio.h>
  9. #include <pdhp.h>
  10. #include <pdhmsg.h>
  11. #include <lmuse.h>
  12. #include "resource.h"
  13. #include <wmistr.h>
  14. #include <initguid.h>
  15. #include <evntrace.h>
  16. #include <shlwapi.h>
  17. #include "logmmsg.h"
  18. #include "varg.c"
  19. // Exclusive
  20. #define GROUP_START 0x01
  21. #define GROUP_END 0x02
  22. // Group Exclusive
  23. #define GROUP_COUNTER 0x01
  24. #define GROUP_TRACE 0x02
  25. #define GROUP_CREATE 0x04
  26. // Conditional
  27. #define GROUP_ARG 0x01
  28. #define VERB_CREATE 0x0001
  29. #define VERB_COUNTER 0x0002
  30. #define VERB_TRACE 0x0004
  31. #define VERB_START 0x0008
  32. #define VERB_STOP 0x0010
  33. #define VERB_UPDATE 0x0020
  34. #define VERB_QUERY 0x0040
  35. #define VERB_DELETE 0x0080
  36. #define VERB_PROV 0x0100
  37. VARG_DECLARE_COMMANDS
  38. VARG_DEBUG ( VARG_FLAG_OPTIONAL|VARG_FLAG_HIDDEN )
  39. VARG_HELP ( VARG_FLAG_OPTIONAL )
  40. VARG_BOOL ( IDS_PARAM_CREATE, VARG_FLAG_OPTIONAL|VARG_FLAG_VERB|VARG_FLAG_REQ_ADV, FALSE )
  41. VARG_BOOL ( IDS_PARAM_COUNTER, VARG_FLAG_ADVERB|VARG_FLAG_HIDDEN, FALSE )
  42. VARG_BOOL ( IDS_PARAM_TRACE, VARG_FLAG_ADVERB|VARG_FLAG_HIDDEN, FALSE )
  43. VARG_BOOL ( IDS_PARAM_START, VARG_FLAG_OPTIONAL|VARG_FLAG_VERB, FALSE )
  44. VARG_BOOL ( IDS_PARAM_STOP, VARG_FLAG_OPTIONAL|VARG_FLAG_VERB, FALSE )
  45. VARG_BOOL ( IDS_PARAM_DELETE, VARG_FLAG_OPTIONAL|VARG_FLAG_VERB, FALSE )
  46. VARG_BOOL ( IDS_PARAM_QUERY, VARG_FLAG_DEFAULTABLE|VARG_FLAG_VERB|VARG_FLAG_OPT_ADV, FALSE )
  47. VARG_BOOL ( IDS_PARAM_QUERYPROV, VARG_FLAG_ADVERB|VARG_FLAG_HIDDEN, FALSE )
  48. VARG_BOOL ( IDS_PARAM_UPDATE, VARG_FLAG_OPTIONAL|VARG_FLAG_VERB, FALSE )
  49. VARG_STR ( IDS_PARAM_NAME, VARG_FLAG_NOFLAG|VARG_FLAG_CHOMP, NULL )
  50. VARG_STR ( IDS_PARAM_COMPUTER, VARG_FLAG_OPTIONAL, NULL )
  51. VARG_INI ( IDS_PARAM_SETTINGS, VARG_FLAG_OPTIONAL, NULL )
  52. VARG_DATE ( IDS_PARAM_BEGIN, VARG_FLAG_OPTIONAL|VARG_FLAG_ARG_DATE )
  53. VARG_DATE ( IDS_PARAM_END, VARG_FLAG_OPTIONAL|VARG_FLAG_ARG_DATE )
  54. VARG_MSZ ( IDS_PARAM_MANUAL, VARG_FLAG_OPTIONAL|VARG_FLAG_FLATHELP|VARG_FLAG_LITERAL, NULL )
  55. VARG_BOOL ( IDS_PARAM_REPEAT, VARG_FLAG_OPTIONAL|VARG_FLAG_NEGATE, FALSE )
  56. VARG_STR ( IDS_PARAM_OUTPUT, VARG_FLAG_OPTIONAL|VARG_FLAG_RCDEFAULT|VARG_FLAG_CHOMP, IDS_DEFAULT_OUTPUT )
  57. VARG_STR ( IDS_PARAM_FORMAT, VARG_FLAG_OPTIONAL|VARG_FLAG_LITERAL, _T("bin") )
  58. VARG_BOOL ( IDS_PARAM_APPEND, VARG_FLAG_OPTIONAL|VARG_FLAG_NEGATE, FALSE )
  59. VARG_STR ( IDS_PARAM_VERSION, VARG_FLAG_OPTIONAL|VARG_FLAG_DEFAULTABLE|VARG_FLAG_NEGATE|VARG_FLAG_RCDEFAULT|VARG_FLAG_LITERAL, IDS_DEFAULT_NNNNN )
  60. VARG_STR ( IDS_PARAM_RUNCMD, VARG_FLAG_OPTIONAL|VARG_FLAG_ARG_FILENAME|VARG_FLAG_NEGATE|VARG_FLAG_CHOMP, NULL )
  61. VARG_INT ( IDS_PARAM_MAX, VARG_FLAG_OPTIONAL|VARG_FLAG_ARG_DEFAULT|VARG_FLAG_NEGATE, 0 )
  62. VARG_TIME ( IDS_PARAM_NEWFILE, VARG_FLAG_OPTIONAL|VARG_FLAG_DEFAULTABLE|VARG_FLAG_ARG_TIME|VARG_FLAG_NEGATE )
  63. VARG_MSZ ( IDS_PARAM_COUNTERS, VARG_FLAG_OPTIONAL, NULL )
  64. VARG_STR ( IDS_PARAM_COUNTERFILE, VARG_FLAG_OPTIONAL|VARG_FLAG_ARG_FILENAME|VARG_FLAG_CHOMP, NULL )
  65. VARG_TIME ( IDS_PARAM_SAMPLERATE, VARG_FLAG_OPTIONAL|VARG_FLAG_ARG_TIME )
  66. VARG_STR ( IDS_PARAM_LOGGERNAME, VARG_FLAG_OPTIONAL, NULL )
  67. VARG_BOOL ( IDS_PARAM_REALTIME, VARG_FLAG_OPTIONAL|VARG_FLAG_NEGATE, FALSE )
  68. VARG_MSZ ( IDS_PARAM_PROVIDER, VARG_FLAG_OPTIONAL|VARG_FLAG_FLATHELP, NULL )
  69. VARG_STR ( IDS_PARAM_PROVIDERFILE,VARG_FLAG_OPTIONAL|VARG_FLAG_ARG_FILENAME|VARG_FLAG_CHOMP, NULL )
  70. VARG_BOOL ( IDS_PARAM_USERMODE, VARG_FLAG_OPTIONAL|VARG_FLAG_NEGATE, FALSE )
  71. VARG_INT ( IDS_PARAM_BUFFERSIZE, VARG_FLAG_OPTIONAL|VARG_FLAG_ARG_DEFAULT, 64 )
  72. VARG_TIME ( IDS_PARAM_FLUSHTIMER, VARG_FLAG_OPTIONAL|VARG_FLAG_ARG_TIME )
  73. VARG_MSZ ( IDS_PARAM_BUFFERS, VARG_FLAG_OPTIONAL|VARG_FLAG_FLATHELP, NULL )
  74. VARG_BOOL ( IDS_PARAM_FLUSHBUFFERS,VARG_FLAG_OPTIONAL, FALSE )
  75. VARG_MSZ ( IDS_PARAM_USER, VARG_FLAG_OPTIONAL|VARG_FLAG_FLATHELP|VARG_FLAG_NEGATE|VARG_FLAG_DEFAULTABLE, _T("") )
  76. VARG_TIME ( IDS_PARAM_RUNFOR, VARG_FLAG_OPTIONAL|VARG_FLAG_ARG_TIME )
  77. VARG_BOOL ( IDS_PARAM_YES, VARG_FLAG_OPTIONAL, FALSE )
  78. VARG_BOOL ( IDS_PARAM_ETS, VARG_FLAG_OPTIONAL, FALSE )
  79. VARG_INT ( IDS_PARAM_AGE, VARG_FLAG_OPTIONAL|VARG_FLAG_HIDDEN, FALSE )
  80. VARG_MSZ ( IDS_PARAM_MODE, VARG_FLAG_OPTIONAL, NULL )
  81. VARG_DECLARE_NAMES
  82. eDebug,
  83. eHelp,
  84. eCreate,
  85. eCounter,
  86. eTrace,
  87. eStart,
  88. eStop,
  89. eDelete,
  90. eQuery,
  91. eQueryProv,
  92. eUpdate,
  93. eName,
  94. eComputer,
  95. eConfig,
  96. eBegin,
  97. eEnd,
  98. eManual,
  99. eRepeat,
  100. eOutput,
  101. eFormat,
  102. eAppend,
  103. eVersion,
  104. eRunCmd,
  105. eMax,
  106. eNewFile,
  107. eCounters,
  108. eCounterFile,
  109. eSampleInterval,
  110. eLoggerName,
  111. eRealTime,
  112. eProviders,
  113. eProviderFile,
  114. eUserMode,
  115. eBufferSize,
  116. eFlushTimer,
  117. eBuffers,
  118. eFlushBuffers,
  119. eUser,
  120. eRunFor,
  121. eYes,
  122. eEts,
  123. eAgeLimit,
  124. eMode,
  125. VARG_DECLARE_FORMAT
  126. VARG_VERB ( eCreate, VERB_CREATE )
  127. VARG_ADVERB( eCounter, VERB_CREATE, VERB_COUNTER )
  128. VARG_ADVERB( eTrace, VERB_CREATE, VERB_TRACE )
  129. VARG_VERB ( eStart, VERB_START )
  130. VARG_VERB ( eStop, VERB_STOP )
  131. VARG_VERB ( eDelete, VERB_DELETE )
  132. VARG_VERB ( eQuery, VERB_QUERY )
  133. VARG_ADVERB( eQueryProv, VERB_QUERY, VERB_PROV )
  134. VARG_VERB ( eUpdate, VERB_UPDATE )
  135. VARG_VERB ( eName, VERB_CREATE|VERB_UPDATE|VERB_START|VERB_STOP|VERB_QUERY|VERB_DELETE )
  136. VARG_VERB ( eBegin, VERB_UPDATE|VERB_CREATE )
  137. VARG_VERB ( eEnd, VERB_UPDATE|VERB_CREATE )
  138. VARG_VERB ( eManual, VERB_UPDATE|VERB_CREATE|VERB_COUNTER )
  139. VARG_VERB ( eRepeat, VERB_UPDATE|VERB_CREATE )
  140. VARG_VERB ( eOutput, VERB_UPDATE|VERB_CREATE )
  141. VARG_VERB ( eFormat, VERB_UPDATE|VERB_CREATE )
  142. VARG_VERB ( eAppend, VERB_UPDATE|VERB_CREATE )
  143. VARG_VERB ( eVersion, VERB_UPDATE|VERB_CREATE )
  144. VARG_VERB ( eRunCmd, VERB_UPDATE|VERB_CREATE )
  145. VARG_VERB ( eMax, VERB_UPDATE|VERB_CREATE|VERB_TRACE )
  146. VARG_VERB ( eNewFile, VERB_UPDATE|VERB_CREATE )
  147. VARG_VERB ( eCounters, VERB_UPDATE|VERB_CREATE|VERB_COUNTER )
  148. VARG_VERB ( eCounterFile, VERB_UPDATE|VERB_CREATE|VERB_COUNTER )
  149. VARG_VERB ( eSampleInterval,VERB_UPDATE|VERB_CREATE|VERB_COUNTER )
  150. VARG_VERB ( eLoggerName, VERB_UPDATE|VERB_CREATE|VERB_TRACE )
  151. VARG_VERB ( eRealTime, VERB_UPDATE|VERB_CREATE|VERB_TRACE )
  152. VARG_VERB ( eProviders, VERB_UPDATE|VERB_CREATE|VERB_TRACE )
  153. VARG_VERB ( eProviderFile, VERB_UPDATE|VERB_CREATE|VERB_TRACE )
  154. VARG_VERB ( eUserMode, VERB_UPDATE|VERB_CREATE|VERB_TRACE )
  155. VARG_VERB ( eBufferSize, VERB_UPDATE|VERB_CREATE|VERB_TRACE )
  156. VARG_VERB ( eFlushTimer, VERB_UPDATE|VERB_CREATE|VERB_TRACE )
  157. VARG_VERB ( eBuffers, VERB_UPDATE|VERB_CREATE|VERB_TRACE )
  158. VARG_VERB ( eFlushBuffers, VERB_UPDATE|VERB_CREATE|VERB_TRACE )
  159. VARG_VERB ( eUser, VERB_UPDATE|VERB_CREATE|VERB_TRACE|VERB_COUNTER|VERB_QUERY )
  160. VARG_VERB ( eComputer, VERB_UPDATE|VERB_CREATE|VERB_TRACE|VERB_COUNTER|VERB_QUERY|VERB_START|VERB_STOP|VERB_DELETE )
  161. VARG_VERB ( eRunFor, VERB_UPDATE|VERB_CREATE )
  162. VARG_VERB ( eEts, VERB_UPDATE|VERB_TRACE|VERB_START|VERB_STOP|VERB_QUERY )
  163. VARG_VERB ( eMode, VERB_UPDATE|VERB_CREATE|VERB_TRACE )
  164. VARG_GROUP ( eCounter, VARG_GRPX(GROUP_COUNTER,GROUP_TRACE) )
  165. VARG_GROUP ( eTrace, VARG_GRPX(GROUP_TRACE,GROUP_COUNTER) )
  166. VARG_GROUP ( eStart, VARG_EXCL(GROUP_START) )
  167. VARG_GROUP ( eStop, VARG_EXCL(GROUP_END) )
  168. VARG_GROUP ( eQuery, VARG_COND(GROUP_ARG) )
  169. VARG_GROUP ( eName, VARG_COND(GROUP_ARG) )
  170. VARG_GROUP ( eBegin, VARG_EXCL(GROUP_START) )
  171. VARG_GROUP ( eEnd, VARG_EXCL(GROUP_END) )
  172. VARG_GROUP ( eManual, VARG_EXCL(GROUP_START) )
  173. VARG_GROUP ( eCounters, VARG_GRPX(GROUP_COUNTER,GROUP_TRACE) )
  174. VARG_GROUP ( eCounterFile, VARG_GRPX(GROUP_COUNTER,GROUP_TRACE) )
  175. VARG_GROUP ( eSampleInterval,VARG_GRPX(GROUP_COUNTER,GROUP_TRACE) )
  176. VARG_GROUP ( eLoggerName, VARG_GRPX(GROUP_TRACE,GROUP_COUNTER) )
  177. VARG_GROUP ( eRealTime, VARG_GRPX(GROUP_TRACE,GROUP_COUNTER) )
  178. VARG_GROUP ( eProviders, VARG_GRPX(GROUP_TRACE,GROUP_COUNTER) )
  179. VARG_GROUP ( eProviderFile, VARG_GRPX(GROUP_TRACE,GROUP_COUNTER) )
  180. VARG_GROUP ( eUserMode, VARG_GRPX(GROUP_TRACE,GROUP_COUNTER) )
  181. VARG_GROUP ( eBufferSize, VARG_GRPX(GROUP_TRACE,GROUP_COUNTER) )
  182. VARG_GROUP ( eFlushTimer, VARG_GRPX(GROUP_TRACE,GROUP_COUNTER) )
  183. VARG_GROUP ( eBuffers, VARG_GRPX(GROUP_TRACE,GROUP_COUNTER) )
  184. VARG_GROUP ( eFlushBuffers, VARG_GRPX(GROUP_TRACE,GROUP_COUNTER) )
  185. VARG_GROUP ( eEts, VARG_GRPX(GROUP_TRACE,GROUP_COUNTER) )
  186. VARG_GROUP ( eMode, VARG_GRPX(GROUP_TRACE,GROUP_COUNTER) )
  187. VARG_EXHELP( eEts, IDS_EXAMPLE_ETS )
  188. VARG_EXHELP( eCreate, IDS_EXAMPLE_CREATE )
  189. VARG_EXHELP( eStart, IDS_EXAMPLE_START )
  190. VARG_EXHELP( eUpdate, IDS_EXAMPLE_UPDATE )
  191. VARG_DECLARE_END
  192. typedef struct _PROVIDER_REC {
  193. _PROVIDER_REC* flink;
  194. _PROVIDER_REC* blink;
  195. LPTSTR strProviderName;
  196. LPTSTR strProviderGuid;
  197. LPTSTR strFlags;
  198. LPTSTR strLevel;
  199. } PROVIDER_REC, *PPROVIDER_REC;
  200. ULONG hextoi( LPWSTR s );
  201. DWORD SetCredentials();
  202. DWORD GetCountersFromFile( LPTSTR strFile, PPDH_PLA_ITEM pItem );
  203. DWORD GetFileFormat( LPTSTR str, LPDWORD pdwFormat );
  204. DWORD SetPlaInfo( PPDH_PLA_INFO pInfo );
  205. HRESULT WbemConnect( IWbemServices** pWbemServices );
  206. HRESULT GetProviders( PPDH_PLA_ITEM pItem );
  207. HRESULT GetTraceNameToGuidMap( PPROVIDER_REC pProviders );
  208. HRESULT EventTraceSessionControl();
  209. HRESULT WbemError( HRESULT hr );
  210. PDH_STATUS QueryCollection( LPTSTR strCollection, BOOL bHeader );
  211. PDH_STATUS QuerySingleCollection( LPTSTR strCollection );
  212. PDH_STATUS ScheduleLog();
  213. void ShowValidationError( PDH_STATUS pdhStatus, PPDH_PLA_INFO pInfo );
  214. void LogmanError( DWORD dwStatus );
  215. void PdhError( PDH_STATUS pdhStatus, PPDH_PLA_INFO pInfo );
  216. #define CHECK_STATUS( hr ) if( ERROR_SUCCESS != hr ){ goto cleanup; }
  217. #define SEVERITY( s ) ((ULONG)s >> 30)
  218. #define NT_KERNEL_GUID _T("{9e814aad-3204-11d2-9a82-006008a86939}")
  219. #define NT_KERNEL_LOGGER _T("NT Kernel Logger")
  220. #define PDH_MODULE _T("PDH.DLL")
  221. TCHAR g_strUser[MAXSTR];
  222. TCHAR g_strPassword[MAXSTR];
  223. TCHAR g_strIPC[MAXSTR];
  224. int __cdecl _tmain( int argc, LPTSTR* argv )
  225. {
  226. HRESULT hr = ERROR_SUCCESS;
  227. PDH_STATUS pdhStatus = ERROR_SUCCESS;
  228. DWORD dwStatus = ERROR_SUCCESS;
  229. PDH_PLA_INFO_W info;
  230. ZeroMemory( &info, sizeof( PDH_PLA_INFO ) );
  231. ParseCmd( argc, argv );
  232. if( Commands[eUser].bDefined && !(Commands[eUser].bNegated) ){
  233. dwStatus = SetCredentials();
  234. }else{
  235. g_strIPC[0] = _T('\0');
  236. }
  237. if( dwStatus != ERROR_SUCCESS ){
  238. dwStatus = LOGMAN_ERROR_LOGON;
  239. goto cleanup;
  240. }
  241. if( Commands[eEts].bValue ){
  242. hr = EventTraceSessionControl();
  243. goto cleanup;
  244. }
  245. if( Commands[eStart].bValue ){
  246. pdhStatus = PdhPlaStart( Commands[eName].strValue, Commands[eComputer].strValue );
  247. CHECK_STATUS(pdhStatus);
  248. }else if( Commands[eStop].bValue ){
  249. pdhStatus = PdhPlaStop( Commands[eName].strValue, Commands[eComputer].strValue );
  250. CHECK_STATUS(pdhStatus);
  251. }else if( Commands[eDelete].bValue ){
  252. pdhStatus = PdhPlaDelete( Commands[eName].strValue, Commands[eComputer].strValue );
  253. CHECK_STATUS(pdhStatus);
  254. }else if( Commands[eCreate].bDefined ){
  255. DWORD dwType = 0;
  256. if( Commands[eCounter].bDefined ){
  257. dwType = PLA_COUNTER_LOG;
  258. }else if( Commands[eTrace].bDefined ){
  259. dwType = PLA_TRACE_LOG;
  260. }
  261. info.dwMask |= PLA_INFO_FLAG_TYPE;
  262. info.dwType = dwType;
  263. dwStatus = SetPlaInfo( &info );
  264. CHECK_STATUS( dwStatus );
  265. if( Commands[eYes].bValue ){
  266. PdhPlaDeleteW( Commands[eName].strValue, Commands[eComputer].strValue );
  267. }
  268. pdhStatus = PdhPlaCreate( Commands[eName].strValue, Commands[eComputer].strValue, &info );
  269. CHECK_STATUS( pdhStatus );
  270. if( Commands[eRunFor].bDefined ||
  271. Commands[eManual].bDefined ){
  272. pdhStatus = ScheduleLog();
  273. if( pdhStatus != ERROR_SUCCESS ){
  274. PdhPlaDeleteW( Commands[eName].strValue, Commands[eComputer].strValue );
  275. }
  276. CHECK_STATUS( pdhStatus );
  277. }
  278. }else if( Commands[eQuery].bDefined ){
  279. if( Commands[eQueryProv].bDefined ){
  280. hr = GetTraceNameToGuidMap( NULL );
  281. goto cleanup;
  282. }else if( Commands[eName].strValue != NULL ){
  283. pdhStatus = QuerySingleCollection( Commands[eName].strValue );
  284. }else{
  285. DWORD dwSize = 0;
  286. LPTSTR mszCollections = NULL;
  287. pdhStatus = PdhPlaEnumCollections( Commands[eComputer].strValue, &dwSize, mszCollections );
  288. if( ERROR_SUCCESS == pdhStatus || PDH_INSUFFICIENT_BUFFER == pdhStatus ){
  289. mszCollections = (LPTSTR)VARG_ALLOC( dwSize * sizeof(TCHAR) );
  290. if( mszCollections ){
  291. LPTSTR strCollection;
  292. pdhStatus = PdhPlaEnumCollections( Commands[eComputer].strValue, &dwSize, mszCollections );
  293. if( ERROR_SUCCESS == pdhStatus ){
  294. strCollection = mszCollections;
  295. while( strCollection != NULL && *strCollection != _T('\0') ){
  296. QueryCollection( strCollection, (strCollection == mszCollections) );
  297. strCollection += ( _tcslen( strCollection ) + 1 );
  298. }
  299. varg_printf( g_normal, _T("\n") );
  300. }
  301. VARG_FREE( mszCollections );
  302. }else{
  303. dwStatus = ERROR_OUTOFMEMORY;
  304. }
  305. }
  306. }
  307. }else if( Commands[eUpdate].bDefined ){
  308. dwStatus = SetPlaInfo( &info );
  309. CHECK_STATUS( dwStatus );
  310. if( info.dwMask != 0 ){
  311. // Try update without credentials
  312. pdhStatus = PdhPlaSetInfoW( Commands[eName].strValue, Commands[eComputer].strValue, &info );
  313. if( PDH_ACCESS_DENIED == pdhStatus ){
  314. // Try again with credintials
  315. dwStatus = SetCredentials();
  316. CHECK_STATUS( dwStatus );
  317. if( ERROR_SUCCESS == dwStatus ){
  318. info.dwMask |= PLA_INFO_FLAG_USER;
  319. info.strUser = g_strUser;
  320. info.strPassword = g_strPassword;
  321. pdhStatus = PdhPlaSetInfoW( Commands[eName].strValue, Commands[eComputer].strValue, &info );
  322. }
  323. }
  324. CHECK_STATUS( pdhStatus );
  325. }
  326. if( Commands[eRunFor].bDefined ||
  327. Commands[eManual].bDefined ){
  328. pdhStatus = ScheduleLog();
  329. CHECK_STATUS( pdhStatus );
  330. }
  331. }
  332. cleanup:
  333. if( ERROR_SUCCESS == dwStatus &&
  334. ERROR_SUCCESS == hr &&
  335. ERROR_SUCCESS == pdhStatus ){
  336. PrintMessage( g_normal, IDS_MESSAGE_SUCCESS );
  337. }else{
  338. if( ERROR_SUCCESS != dwStatus ){
  339. LogmanError( dwStatus );
  340. }
  341. if( ERROR_SUCCESS != hr ){
  342. WbemError( hr );
  343. dwStatus = hr;
  344. }
  345. if( ERROR_SUCCESS != pdhStatus ){
  346. PdhError( pdhStatus, &info );
  347. dwStatus = pdhStatus;
  348. }
  349. if( SEVERITY( dwStatus ) == STATUS_SEVERITY_WARNING ){
  350. PrintMessage( g_normal, IDS_MESSAGE_SUCCESS );
  351. dwStatus = ERROR_SUCCESS;
  352. }
  353. }
  354. if( info.dwMask & PLA_INFO_FLAG_COUNTERS && Commands[eCounterFile].bDefined ){
  355. VARG_FREE( info.Perf.piCounterList.strCounters );
  356. }
  357. if( info.dwMask & PLA_INFO_FLAG_PROVIDERS ){
  358. VARG_FREE( info.Trace.piProviderList.strProviders );
  359. VARG_FREE( info.Trace.piProviderList.strFlags );
  360. VARG_FREE( info.Trace.piProviderList.strLevels );
  361. }
  362. if( _tcslen( g_strIPC ) ){
  363. dwStatus = NetUseDel( NULL, g_strIPC, USE_LOTS_OF_FORCE /*luke*/ );
  364. }
  365. ZeroMemory( g_strPassword, sizeof(TCHAR)*MAXSTR );
  366. FreeCmd();
  367. CoUninitialize();
  368. return dwStatus;
  369. }
  370. DWORD
  371. SetPlaInfo( PPDH_PLA_INFO pInfo )
  372. {
  373. DWORD dwStatus = ERROR_SUCCESS;
  374. if( Commands[eCounters].bDefined && Commands[eCounters].strValue != NULL ){
  375. pInfo->dwMask |= PLA_INFO_FLAG_COUNTERS;
  376. pInfo->Perf.piCounterList.dwType = PLA_COUNTER_LOG;
  377. pInfo->Perf.piCounterList.strCounters = Commands[eCounters].strValue;
  378. }else if( Commands[eCounterFile].bDefined ){
  379. pInfo->dwMask |= PLA_INFO_FLAG_COUNTERS;
  380. dwStatus = GetCountersFromFile( Commands[eCounterFile].strValue, &(pInfo->Perf.piCounterList) );
  381. CHECK_STATUS( dwStatus );
  382. }
  383. if( Commands[eProviders].bDefined || Commands[eProviderFile].bDefined ){
  384. pInfo->dwMask |= PLA_INFO_FLAG_PROVIDERS;
  385. dwStatus = GetProviders( &(pInfo->Trace.piProviderList) );
  386. CHECK_STATUS( dwStatus );
  387. pInfo->Trace.piProviderList.dwType = PLA_TRACE_LOG;
  388. }
  389. if( Commands[eFormat].bDefined ){
  390. DWORD dwFormat;
  391. dwStatus = GetFileFormat( Commands[eFormat].strValue, &dwFormat );
  392. CHECK_STATUS( dwStatus );
  393. pInfo->dwMask |= PLA_INFO_FLAG_FORMAT;
  394. pInfo->dwFileFormat = dwFormat;
  395. }
  396. if( Commands[eAppend].bDefined ){
  397. pInfo->dwMask |= PLA_INFO_FLAG_DATASTORE;
  398. if( Commands[eAppend].bNegated ){
  399. pInfo->dwDatastoreAttributes |= PLA_DATASTORE_OVERWRITE;
  400. }else{
  401. pInfo->dwDatastoreAttributes |= PLA_DATASTORE_APPEND;
  402. }
  403. }
  404. if( Commands[eSampleInterval].bDefined ){
  405. pInfo->dwMask |= PLA_INFO_FLAG_INTERVAL;
  406. pInfo->Perf.ptSampleInterval.wDataType = PLA_TT_DTYPE_UNITS;
  407. pInfo->Perf.ptSampleInterval.dwUnitType = PLA_TT_UTYPE_SECONDS;
  408. pInfo->Perf.ptSampleInterval.wTimeType = PLA_TT_TTYPE_SAMPLE;
  409. pInfo->Perf.ptSampleInterval.dwAutoMode = PLA_AUTO_MODE_AFTER;
  410. pInfo->Perf.ptSampleInterval.dwValue = Commands[eSampleInterval].stValue.wSecond;
  411. pInfo->Perf.ptSampleInterval.dwValue += Commands[eSampleInterval].stValue.wMinute * 60;
  412. pInfo->Perf.ptSampleInterval.dwValue += Commands[eSampleInterval].stValue.wHour * 3600;
  413. }
  414. if( Commands[eBufferSize].bDefined ){
  415. pInfo->dwMask |= PLA_INFO_FLAG_BUFFERSIZE;
  416. pInfo->Trace.dwBufferSize = Commands[eBufferSize].nValue;
  417. }
  418. if( Commands[eBuffers].bDefined ){
  419. LPTSTR strMin;
  420. LPTSTR strMax;
  421. strMin = Commands[eBuffers].strValue;
  422. if( NULL != strMin ){
  423. pInfo->dwMask |= PLA_INFO_FLAG_MINBUFFERS;
  424. pInfo->Trace.dwMinimumBuffers = _ttoi( strMin );
  425. strMax = strMin + (_tcslen( strMin )+1);
  426. if( *strMax != _T('\0') ){
  427. pInfo->dwMask |= PLA_INFO_FLAG_MAXBUFFERS;
  428. pInfo->Trace.dwMaximumBuffers = _ttoi( strMax );
  429. }
  430. }
  431. }
  432. if( Commands[eFlushTimer].bDefined ){
  433. DWORD dwSeconds;
  434. dwSeconds = Commands[eFlushTimer].stValue.wSecond;
  435. dwSeconds += Commands[eFlushTimer].stValue.wMinute * 60;
  436. dwSeconds += Commands[eFlushTimer].stValue.wHour * 3600;
  437. pInfo->dwMask |= PLA_INFO_FLAG_FLUSHTIMER;
  438. pInfo->Trace.dwFlushTimer = dwSeconds;
  439. }
  440. if( Commands[eMax].bDefined ){
  441. pInfo->dwMask |= PLA_INFO_FLAG_MAXLOGSIZE;
  442. if( Commands[eMax].bNegated ){
  443. pInfo->dwMaxLogSize = PLA_DISK_MAX_SIZE;
  444. }else{
  445. pInfo->dwMaxLogSize = Commands[eMax].nValue;
  446. }
  447. }
  448. if( Commands[eRunCmd].bDefined ){
  449. pInfo->dwMask |= PLA_INFO_FLAG_RUNCOMMAND;
  450. if( Commands[eRunCmd].bNegated ){
  451. pInfo->strCommandFileName = _T("");
  452. }else{
  453. pInfo->strCommandFileName = Commands[eRunCmd].strValue;
  454. }
  455. }
  456. if( Commands[eOutput].bDefined && NULL != Commands[eOutput].strValue ){
  457. if( ((pInfo->dwMask & PLA_INFO_FLAG_FORMAT) &&
  458. pInfo->dwFileFormat == PLA_SQL_LOG ) ||
  459. !StrCmpNI( Commands[eOutput].strValue, _T("SQL:"), 4 ) ){
  460. pInfo->dwMask |= PLA_INFO_FLAG_SQLNAME;
  461. pInfo->strSqlName = Commands[eOutput].strValue;
  462. }else{
  463. if( IsEmpty( Commands[eOutput].strValue ) ){
  464. pInfo->dwMask |= (PLA_INFO_FLAG_DEFAULTDIR|PLA_INFO_FLAG_FILENAME);
  465. pInfo->strDefaultDir = _T("");
  466. pInfo->strBaseFileName = _T("");
  467. }else{
  468. LPTSTR str = NULL;
  469. TCHAR full[MAXSTR];
  470. TCHAR buffer[MAX_PATH];
  471. TCHAR drive[_MAX_DRIVE];
  472. TCHAR dir[_MAX_DIR];
  473. TCHAR fname[_MAX_FNAME];
  474. TCHAR ext[_MAX_EXT];
  475. DWORD dwFormat;
  476. _tfullpath( full, Commands[eOutput].strValue, MAXSTR );
  477. _tsplitpath( full, drive, dir, fname, ext );
  478. VARG_FREE( Commands[eOutput].strValue );
  479. Commands[eOutput].strValue = NULL;
  480. if( _tcslen( drive ) ){
  481. _stprintf( buffer, _T("%s%s"), drive, dir );
  482. }else{
  483. _tcscpy( buffer, dir );
  484. }
  485. if( _tcslen( buffer ) ){
  486. pInfo->dwMask |= PLA_INFO_FLAG_DEFAULTDIR;
  487. AddStringToMsz( &Commands[eOutput].strValue, buffer );
  488. }
  489. dwStatus = GetFileFormat( ext, &dwFormat );
  490. if( ERROR_SUCCESS == dwStatus ){
  491. _stprintf( buffer, _T("%s"), fname );
  492. }else{
  493. _stprintf( buffer, _T("%s%s"), fname, ext );
  494. dwStatus = ERROR_SUCCESS;
  495. }
  496. if( _tcslen( buffer ) ){
  497. pInfo->dwMask |= PLA_INFO_FLAG_FILENAME;
  498. AddStringToMsz( &Commands[eOutput].strValue, buffer );
  499. }
  500. str = Commands[eOutput].strValue;
  501. if( str != NULL ){
  502. if( pInfo->dwMask & PLA_INFO_FLAG_DEFAULTDIR ){
  503. pInfo->strDefaultDir = str;
  504. str += ( _tcslen( str ) + 1 );
  505. }
  506. if( pInfo->dwMask & PLA_INFO_FLAG_FILENAME ){
  507. pInfo->strBaseFileName = str;
  508. }
  509. }else{
  510. dwStatus = ERROR_OUTOFMEMORY;
  511. goto cleanup;
  512. }
  513. }
  514. }
  515. }
  516. if( Commands[eVersion].bDefined ){
  517. DWORD dwFormat = 0;
  518. pInfo->dwMask |= PLA_INFO_FLAG_AUTOFORMAT;
  519. if( Commands[eVersion].bNegated ){
  520. dwFormat = PLA_SLF_NAME_NONE;
  521. }else if( !_tcsicmp( Commands[eVersion].strValue, _T("nnnnnn") ) ){
  522. dwFormat = PLA_SLF_NAME_NNNNNN;
  523. }else if( !_tcsicmp( Commands[eVersion].strValue, _T("mmddhhmm") ) ){
  524. dwFormat = PLA_SLF_NAME_MMDDHHMM;
  525. }else{
  526. dwFormat = PLA_SLF_NAME_NNNNNN;
  527. }
  528. pInfo->dwAutoNameFormat = dwFormat;
  529. }
  530. if( Commands[eRealTime].bDefined ){
  531. pInfo->dwMask |= PLA_INFO_FLAG_MODE;
  532. if( Commands[eRealTime].bNegated ){
  533. pInfo->Trace.dwMode &= ~EVENT_TRACE_REAL_TIME_MODE;
  534. }else{
  535. pInfo->Trace.dwMode |= EVENT_TRACE_REAL_TIME_MODE;
  536. }
  537. }
  538. if( Commands[eUserMode].bDefined ){
  539. pInfo->dwMask |= PLA_INFO_FLAG_MODE;
  540. if( Commands[eUserMode].bNegated ){
  541. pInfo->Trace.dwMode &= ~EVENT_TRACE_PRIVATE_LOGGER_MODE;
  542. }else{
  543. pInfo->Trace.dwMode |= EVENT_TRACE_PRIVATE_LOGGER_MODE;
  544. }
  545. }
  546. if( Commands[eLoggerName].bDefined ){
  547. pInfo->dwMask |= PLA_INFO_FLAG_LOGGERNAME;
  548. pInfo->Trace.strLoggerName = Commands[eLoggerName].strValue;
  549. }
  550. if( Commands[eRepeat].bDefined ){
  551. pInfo->dwMask |= PLA_INFO_FLAG_REPEAT;
  552. if( Commands[eRepeat].bNegated ){
  553. pInfo->ptRepeat.dwAutoMode = PLA_AUTO_MODE_NONE;
  554. }else{
  555. pInfo->ptRepeat.wDataType = PLA_TT_DTYPE_UNITS;
  556. pInfo->ptRepeat.wTimeType = PLA_TT_TTYPE_REPEAT_SCHEDULE;
  557. pInfo->ptRepeat.dwUnitType = PLA_TT_UTYPE_DAYSOFWEEK;
  558. pInfo->ptRepeat.dwAutoMode = PLA_AUTO_MODE_CALENDAR;
  559. pInfo->ptRepeat.dwValue = 0x0000007F;
  560. }
  561. }
  562. if( Commands[eNewFile].bDefined ){
  563. pInfo->dwMask |= PLA_INFO_FLAG_CRTNEWFILE;
  564. pInfo->ptCreateNewFile.wTimeType = PLA_TT_TTYPE_CREATENEWFILE;
  565. pInfo->ptCreateNewFile.wDataType = PLA_TT_DTYPE_UNITS;
  566. if( Commands[eNewFile].bNegated ){
  567. pInfo->ptCreateNewFile.dwAutoMode = PLA_AUTO_MODE_NONE;
  568. }else{
  569. DWORD dwSeconds = Commands[eNewFile].stValue.wSecond;
  570. dwSeconds += Commands[eNewFile].stValue.wMinute * 60;
  571. dwSeconds += Commands[eNewFile].stValue.wHour * 3600;
  572. if( dwSeconds == 0 ){
  573. pInfo->ptCreateNewFile.dwAutoMode = PLA_AUTO_MODE_SIZE;
  574. }else{
  575. pInfo->ptCreateNewFile.dwAutoMode = PLA_AUTO_MODE_AFTER;
  576. pInfo->ptCreateNewFile.dwUnitType = PLA_TT_UTYPE_SECONDS;
  577. pInfo->ptCreateNewFile.dwValue = dwSeconds;
  578. }
  579. }
  580. }
  581. if( Commands[eUser].bDefined ){
  582. pInfo->dwMask |= PLA_INFO_FLAG_USER;
  583. if( Commands[eUser].bNegated ){
  584. pInfo->strUser = _T("");
  585. pInfo->strPassword = _T("");
  586. }else{
  587. pInfo->strUser = g_strUser;
  588. pInfo->strPassword = g_strPassword;
  589. }
  590. }
  591. if(Commands[eBegin].bDefined){
  592. FILETIME ft;
  593. pInfo->dwMask |= PLA_INFO_FLAG_BEGIN;
  594. SystemTimeToFileTime( &Commands[eBegin].stValue, &ft );
  595. pInfo->ptLogBeginTime.wTimeType = PLA_TT_TTYPE_START;
  596. pInfo->ptLogBeginTime.wDataType = PLA_TT_DTYPE_DATETIME;
  597. pInfo->ptLogBeginTime.dwAutoMode = PLA_AUTO_MODE_AT;
  598. pInfo->ptLogBeginTime.llDateTime = (((ULONGLONG) ft.dwHighDateTime) << 32) + ft.dwLowDateTime;
  599. }
  600. if(Commands[eEnd].bDefined){
  601. FILETIME ft;
  602. pInfo->dwMask |= PLA_INFO_FLAG_END;
  603. SystemTimeToFileTime( &Commands[eEnd].stValue, &ft );
  604. pInfo->ptLogEndTime.wTimeType = PLA_TT_TTYPE_STOP;
  605. pInfo->ptLogEndTime.wDataType = PLA_TT_DTYPE_DATETIME;
  606. pInfo->ptLogEndTime.dwAutoMode = PLA_AUTO_MODE_AT;
  607. pInfo->ptLogEndTime.llDateTime = (((ULONGLONG) ft.dwHighDateTime) << 32) + ft.dwLowDateTime;
  608. }
  609. cleanup:
  610. return dwStatus;
  611. }
  612. DWORD
  613. GetFileFormat( LPTSTR str, LPDWORD pdwFormat )
  614. {
  615. *pdwFormat = PLA_BIN_FILE;
  616. LPTSTR strCmp = str;
  617. if( strCmp != NULL ){
  618. if( *strCmp == _T('.') ){
  619. strCmp++;
  620. }
  621. if( !_tcsicmp( strCmp, _T("TSV")) ){
  622. *pdwFormat = PLA_TSV_FILE;
  623. return ERROR_SUCCESS;
  624. }else if( !_tcsicmp( strCmp, _T("CSV")) ){
  625. *pdwFormat = PLA_CSV_FILE;
  626. return ERROR_SUCCESS;
  627. }else if( !_tcsicmp( strCmp, _T("BLG")) ){
  628. *pdwFormat = PLA_BIN_FILE;
  629. return ERROR_SUCCESS;
  630. }else if( !_tcsicmp( strCmp, _T("BIN")) ){
  631. *pdwFormat = PLA_BIN_FILE;
  632. return ERROR_SUCCESS;
  633. }else if( !_tcsicmp( strCmp, _T("BINCIRC")) ){
  634. *pdwFormat = PLA_BIN_CIRC_FILE;
  635. return ERROR_SUCCESS;
  636. }else if( !_tcsicmp( strCmp, _T("SQL")) ){
  637. *pdwFormat = PLA_SQL_LOG;
  638. return ERROR_SUCCESS;
  639. }
  640. }
  641. return LOGMAN_ERROR_FILEFORMAT;
  642. }
  643. PDH_STATUS
  644. QueryCollection( LPTSTR strCollection, BOOL bHeader )
  645. {
  646. PDH_STATUS pdhStatus;
  647. PDH_PLA_INFO info;
  648. DWORD dwInfoSize = sizeof( PDH_PLA_INFO );
  649. TCHAR strType[MAXSTR];
  650. TCHAR strStatus[MAXSTR];
  651. if( bHeader ){
  652. PrintMessage( g_normal, IDS_MESSAGE_QUERY );
  653. for(int i=0;i<79;i++){ varg_printf( g_normal, _T("-") ); }
  654. varg_printf( g_normal, _T("\n") );
  655. }
  656. info.dwMask = PLA_INFO_FLAG_TYPE|PLA_INFO_FLAG_STATUS;
  657. pdhStatus = PdhPlaGetInfoW( strCollection, Commands[eComputer].strValue, &dwInfoSize, &info );
  658. if( ERROR_SUCCESS == pdhStatus ){
  659. switch( info.dwType ){
  660. case PLA_COUNTER_LOG:
  661. LoadString( NULL, IDS_MESSAGE_PERF, strType, MAXSTR );
  662. break;
  663. case PLA_TRACE_LOG:
  664. LoadString( NULL, IDS_MESSAGE_EVENTTRACE, strType, MAXSTR );
  665. break;
  666. case PLA_ALERT:
  667. LoadString( NULL, IDS_MESSAGE_ALERT, strType, MAXSTR );
  668. break;
  669. }
  670. switch( info.dwStatus ){
  671. case PLA_QUERY_STOPPED:
  672. LoadString( NULL, IDS_MESSAGE_STOPPED, strStatus, MAXSTR );
  673. break;
  674. case PLA_QUERY_RUNNING:
  675. LoadString( NULL, IDS_MESSAGE_RUNNING, strStatus, MAXSTR );
  676. break;
  677. case PLA_QUERY_START_PENDING:
  678. default:
  679. LoadString( NULL, IDS_MESSAGE_PENDING, strStatus, MAXSTR );
  680. break;
  681. }
  682. PrintMessage( g_normal, IDS_MESSAGE_QUERYF, strCollection, strType, strStatus );
  683. }
  684. return pdhStatus;
  685. }
  686. PDH_STATUS
  687. QuerySingleCollection( LPTSTR strCollection )
  688. {
  689. PDH_STATUS pdhStatus = ERROR_SUCCESS;
  690. PPDH_PLA_INFO pInfo = NULL;
  691. DWORD dwInfoSize = 0;
  692. TCHAR buffer[MAXSTR];
  693. pdhStatus = PdhPlaGetInfoW( strCollection, Commands[eComputer].strValue, &dwInfoSize, pInfo );
  694. if( ERROR_SUCCESS == pdhStatus ){
  695. pInfo = (PPDH_PLA_INFO)VARG_ALLOC(dwInfoSize);
  696. if( NULL != pInfo ){
  697. pInfo->dwMask = PLA_INFO_FLAG_ALL;
  698. pdhStatus = PdhPlaGetInfoW( strCollection, Commands[eComputer].strValue, &dwInfoSize, pInfo );
  699. if( pdhStatus == ERROR_SUCCESS ){
  700. varg_printf( g_normal, _T("\n") );
  701. PrintMessage( g_normal, IDS_MESSAGE_NAME, strCollection );
  702. switch( pInfo->dwType ){
  703. case PLA_COUNTER_LOG:
  704. LoadString( NULL, IDS_MESSAGE_PERF, buffer, MAXSTR );
  705. break;
  706. case PLA_TRACE_LOG:
  707. LoadString( NULL, IDS_MESSAGE_EVENTTRACE, buffer, MAXSTR );
  708. break;
  709. case PLA_ALERT:
  710. LoadString( NULL, IDS_MESSAGE_ALERT, buffer, MAXSTR );
  711. break;
  712. default:
  713. buffer[0] = _T('\0');
  714. }
  715. PrintMessage( g_normal, IDS_MESSAGE_TYPE, buffer );
  716. switch( pInfo->dwStatus ){
  717. case PLA_QUERY_STOPPED:
  718. LoadString( NULL, IDS_MESSAGE_STOPPED, buffer, MAXSTR );
  719. break;
  720. case PLA_QUERY_RUNNING:
  721. LoadString( NULL, IDS_MESSAGE_RUNNING, buffer, MAXSTR );
  722. break;
  723. case PLA_QUERY_START_PENDING:
  724. default:
  725. LoadString( NULL, IDS_MESSAGE_PENDING, buffer, MAXSTR );
  726. break;
  727. }
  728. PrintMessage( g_normal, IDS_MESSAGE_STATUS, buffer );
  729. DWORD dwStart;
  730. DWORD dwStop;
  731. PDH_TIME_INFO TimeInfo;
  732. pdhStatus = PdhPlaGetScheduleW( strCollection, Commands[eComputer].strValue, &dwStart, &dwStop, &TimeInfo );
  733. if( ERROR_SUCCESS == pdhStatus ){
  734. LoadString( NULL, IDS_MESSAGE_MANUAL, buffer, MAXSTR );
  735. PrintMessage( g_normal, IDS_MESSAGE_START );
  736. switch( dwStart ){
  737. case PLA_AUTO_MODE_NONE:
  738. varg_printf( g_normal, buffer );
  739. break;
  740. case PLA_AUTO_MODE_CALENDAR:
  741. case PLA_AUTO_MODE_AT:
  742. {
  743. SYSTEMTIME st;
  744. FILETIME ft;
  745. ft.dwLowDateTime = (DWORD) (TimeInfo.StartTime & 0xFFFFFFFF );
  746. ft.dwHighDateTime = (DWORD) (TimeInfo.StartTime >> 32 );
  747. FileTimeToSystemTime( &ft, &st );
  748. PrintDate( &st );
  749. if( dwStart == PLA_AUTO_MODE_CALENDAR ){
  750. PrintMessage( g_normal, IDS_MESSAGE_REPEATING );
  751. }
  752. }
  753. }
  754. varg_printf( g_normal, _T("\n") );
  755. PrintMessage( g_normal, IDS_MESSAGE_STOP );
  756. switch( dwStop ){
  757. case PLA_AUTO_MODE_NONE:
  758. varg_printf( g_normal, buffer );
  759. break;
  760. case PLA_AUTO_MODE_AT:
  761. {
  762. SYSTEMTIME st;
  763. FILETIME ft;
  764. ft.dwLowDateTime = (DWORD) (TimeInfo.EndTime & 0xFFFFFFFF );
  765. ft.dwHighDateTime = (DWORD) (TimeInfo.EndTime >> 32 );
  766. FileTimeToSystemTime( &ft, &st );
  767. PrintDate( &st );
  768. }
  769. break;
  770. case PLA_AUTO_MODE_AFTER:
  771. {
  772. SYSTEMTIME st;
  773. LONGLONG llMS;
  774. ZeroMemory( &st, sizeof(SYSTEMTIME) );
  775. PlaTimeInfoToMilliSeconds( &pInfo->ptLogEndTime, &llMS );
  776. llMS /= 1000;
  777. st.wHour = (USHORT)(llMS / 3600);
  778. st.wMinute = (USHORT)((llMS%3600) / 60);
  779. st.wSecond = (USHORT)((llMS % 60) % 3600);
  780. PrintMessage( g_normal, IDS_MESSAGE_AFTER );
  781. PrintDate( &st );
  782. }
  783. }
  784. varg_printf( g_normal, _T("\n") );
  785. }
  786. if( pInfo->dwMask & PLA_INFO_FLAG_CRTNEWFILE ){
  787. if( pInfo->ptCreateNewFile.dwAutoMode == PLA_AUTO_MODE_SIZE ){
  788. PrintMessage( g_normal, IDS_MESSAGE_NEWFILE );
  789. PrintMessage( g_normal, IDS_MESSAGE_BYSIZE );
  790. }else if( pInfo->ptCreateNewFile.dwAutoMode == PLA_AUTO_MODE_AFTER ){
  791. SYSTEMTIME st;
  792. LONGLONG llMS;
  793. ZeroMemory( &st, sizeof(SYSTEMTIME) );
  794. PlaTimeInfoToMilliSeconds( &pInfo->ptCreateNewFile, &llMS );
  795. llMS /= 1000;
  796. st.wHour = (USHORT)(llMS / 3600);
  797. st.wMinute = (USHORT)((llMS%3600) / 60);
  798. st.wSecond = (USHORT)((llMS % 60) % 3600);
  799. PrintMessage( g_normal, IDS_MESSAGE_NEWFILE );
  800. PrintMessage( g_normal, IDS_MESSAGE_AFTER );
  801. PrintDate( &st );
  802. varg_printf( g_normal, _T("\n") );
  803. }
  804. }
  805. dwInfoSize = MAXSTR;
  806. pdhStatus = PdhPlaGetLogFileNameW( strCollection, Commands[eComputer].strValue, pInfo, 0, &dwInfoSize, buffer );
  807. if( pdhStatus != ERROR_SUCCESS ){
  808. LoadString( NULL, IDS_MESSAGE_BADPARAM, buffer, MAXSTR );
  809. pdhStatus = ERROR_SUCCESS;
  810. }
  811. PrintMessage( g_normal, IDS_MESSAGE_FILE, buffer );
  812. PrintMessage( g_normal, IDS_MESSAGE_RUNAS, pInfo->strUser ? pInfo->strUser : _T("") );
  813. switch( pInfo->dwType ){
  814. case PLA_COUNTER_LOG:
  815. {
  816. LPTSTR strCounter;
  817. PrintMessage( g_normal, IDS_MESSAGE_COUNTERS );
  818. strCounter = pInfo->Perf.piCounterList.strCounters;
  819. if( NULL != strCounter ){
  820. if( PRIMARYLANGID( GetUserDefaultUILanguage()) == LANG_ENGLISH ){
  821. while( *strCounter != _T('\0') ){
  822. varg_printf( g_normal, _T(" %1!s!\n"), strCounter );
  823. strCounter += (_tcslen(strCounter)+1);
  824. }
  825. }else{
  826. LPTSTR strLocale = NULL;
  827. DWORD dwSize = MAX_PATH;
  828. strLocale = (LPTSTR)VARG_ALLOC(dwSize*sizeof(TCHAR));
  829. if( NULL != strLocale ){
  830. while( *strCounter != _T('\0') ){
  831. pdhStatus = PdhTranslateLocaleCounter( strCounter, strLocale, &dwSize );
  832. if( PDH_MORE_DATA == pdhStatus ){
  833. LPTSTR strMem = (LPTSTR)VARG_REALLOC( strLocale, (dwSize*sizeof(TCHAR)) );
  834. if( NULL != strMem ){
  835. strLocale = strMem;
  836. }else{
  837. pdhStatus = PDH_MEMORY_ALLOCATION_FAILURE;
  838. VARG_FREE(strLocale);
  839. break;
  840. }
  841. }else if( ERROR_SUCCESS == pdhStatus ){
  842. varg_printf( g_normal, _T(" %1!s!\n"), strLocale );
  843. strCounter += (_tcslen(strCounter)+1);
  844. }else{
  845. pdhStatus = ERROR_SUCCESS;
  846. varg_printf( g_normal, _T(" %1!s!\n"), strCounter );
  847. strCounter += (_tcslen(strCounter)+1);
  848. }
  849. }
  850. }else{
  851. pdhStatus = PDH_MEMORY_ALLOCATION_FAILURE;
  852. }
  853. }
  854. }
  855. }
  856. break;
  857. case PLA_TRACE_LOG:
  858. {
  859. LPTSTR strProvider;
  860. PrintMessage( g_normal, IDS_MESSAGE_LOGGERNAME, pInfo->Trace.strLoggerName );
  861. PrintMessage( g_normal, IDS_MESSAGE_BUFFERSIZE, pInfo->Trace.dwBufferSize );
  862. PrintMessage( g_normal, IDS_MESSAGE_PROVIDERS );
  863. strProvider = pInfo->Trace.piProviderList.strProviders;
  864. if( NULL != strProvider ){
  865. while( *strProvider != _T('\0') ){
  866. PrintMessage( g_normal, IDS_MESSAGE_PRVGUID, strProvider );
  867. strProvider += (_tcslen(strProvider)+1);
  868. }
  869. }else{
  870. StringFromGUID2( SystemTraceControlGuid, buffer, 128 );
  871. PrintMessage( g_normal, IDS_MESSAGE_PRVGUID, buffer );
  872. }
  873. }
  874. break;
  875. case PLA_ALERT:
  876. break;
  877. }
  878. }
  879. VARG_FREE( pInfo );
  880. }
  881. }
  882. varg_printf( g_normal, _T("\n") );
  883. return pdhStatus;
  884. }
  885. DWORD
  886. SetCredentials( )
  887. {
  888. DWORD dwStatus = ERROR_SUCCESS;
  889. LPTSTR strUser = NULL;
  890. LPTSTR strPassword = NULL;
  891. TCHAR buffer[MAXSTR];
  892. TCHAR strConnection[MAXSTR];
  893. LoadString( NULL, IDS_MESSAGE_THISCON, strConnection, MAXSTR );
  894. ZeroMemory( g_strUser, MAXSTR*sizeof(TCHAR) );
  895. ZeroMemory( g_strPassword, MAXSTR*sizeof(TCHAR) );
  896. if( Commands[eUser].strValue == NULL || !_tcslen( Commands[eUser].strValue ) ){
  897. LoadString( NULL, IDS_MESSAGE_EUSER, buffer, MAXSTR );
  898. varg_printf( g_normal,
  899. buffer,
  900. Commands[eName].bDefined ?
  901. Commands[eName].strValue :
  902. Commands[eComputer].bDefined ?
  903. Commands[eComputer].strValue :
  904. strConnection
  905. );
  906. GetUserInput( g_strUser, MAXSTR, TRUE );
  907. strUser = g_strUser;
  908. strPassword = _T("*");
  909. }else{
  910. strUser = Commands[eUser].strValue;
  911. strPassword = strUser + (_tcslen( strUser ) + 1);
  912. }
  913. if( NULL == strPassword ){
  914. strPassword = _T("");
  915. }else if( !_tcscmp( _T("*"), strPassword ) ){
  916. LoadString( NULL, IDS_MESSAGE_EPASSWORD, buffer, MAXSTR );
  917. varg_printf( g_normal, buffer,
  918. Commands[eName].bDefined ?
  919. Commands[eName].strValue :
  920. Commands[eComputer].bDefined ?
  921. Commands[eComputer].strValue :
  922. strConnection
  923. );
  924. GetUserInput( buffer, MAXSTR, FALSE );
  925. strPassword = buffer;
  926. }
  927. _tcscpy( g_strPassword, strPassword );
  928. if( strUser != NULL ){
  929. _tcscpy( g_strUser, strUser );
  930. strUser = g_strUser;
  931. }
  932. TCHAR strUserBuffer[MAXSTR];
  933. _tcscpy( strUserBuffer, strUser );
  934. LPTSTR strDomain = _tcstok( strUserBuffer, _T("\\") );
  935. strUser = _tcstok( NULL, _T("") );
  936. if( strUser == NULL ){
  937. strUser = strDomain;
  938. strDomain = NULL;
  939. }
  940. if( Commands[eComputer].bDefined ){
  941. if( _tcslen(Commands[eComputer].strValue) > 2 && Commands[eComputer].strValue[1] == _T('\\') ){
  942. _stprintf( g_strIPC, _T("%s\\ipc$"), Commands[eComputer].strValue );
  943. }else{
  944. _stprintf( g_strIPC, _T("\\\\%s\\ipc$"), Commands[eComputer].strValue );
  945. }
  946. LPTSTR pNetInfo;
  947. dwStatus = NetUseGetInfo( NULL, g_strIPC, 0, (LPBYTE*)&pNetInfo );
  948. if( dwStatus != ERROR_SUCCESS ){
  949. USE_INFO_2 info;
  950. DWORD dwError;
  951. ZeroMemory( &info, sizeof(USE_INFO_2) );
  952. info.ui2_local = NULL;
  953. info.ui2_remote = g_strIPC;
  954. info.ui2_password = g_strPassword;
  955. info.ui2_username = strUser;
  956. info.ui2_domainname = strDomain;
  957. info.ui2_asg_type = USE_IPC;
  958. dwStatus = NetUseAdd (
  959. NULL,
  960. 2,
  961. (unsigned char *)&info,
  962. &dwError
  963. );
  964. }else{
  965. ZeroMemory( g_strIPC, sizeof(TCHAR) * MAXSTR );
  966. }
  967. }
  968. return dwStatus;
  969. }
  970. DWORD GetCountersFromFile( LPTSTR strFile, PPDH_PLA_ITEM pItem )
  971. {
  972. TCHAR buffer[MAXSTR];
  973. LPTSTR strList = NULL;
  974. LPTSTR strItem = NULL;
  975. FILE* f = _tfopen( strFile, _T("r") );
  976. if( !f ){
  977. return GetLastError();
  978. }
  979. pItem->dwType = PLA_COUNTER_LOG;
  980. pItem->strCounters = NULL;
  981. while( NULL != _fgetts( buffer, MAXSTR, f ) ){
  982. if( buffer[0] == _T(';') || // comments
  983. buffer[0] == _T('#') ){
  984. continue;
  985. }
  986. Chomp(buffer);
  987. strItem = _tcstok( buffer, _T("\"\n") );
  988. if( strItem != NULL ){
  989. AddStringToMsz( &strList, strItem );
  990. }
  991. }
  992. fclose( f );
  993. pItem->strCounters = strList;
  994. return ERROR_SUCCESS;
  995. }
  996. BOOL IsStrGuid( LPTSTR str ){
  997. if( _tcslen( str ) < 38 ){
  998. return FALSE;
  999. }
  1000. if( str[0] == _T('{') &&
  1001. str[9] == _T('-') &&
  1002. str[14] == _T('-') &&
  1003. str[19] == _T('-') &&
  1004. str[24] == _T('-') &&
  1005. str[37] == _T('}')
  1006. ){
  1007. return TRUE;
  1008. }
  1009. return FALSE;
  1010. }
  1011. HRESULT GetProviders( PPDH_PLA_ITEM pItem )
  1012. {
  1013. HRESULT hr = ERROR_SUCCESS;
  1014. TCHAR buffer[MAXSTR];
  1015. LPTSTR strLine = NULL;
  1016. LPTSTR strItem = NULL;
  1017. LPTSTR strLevel;
  1018. LPTSTR strFlags;
  1019. PPROVIDER_REC pProviderHead = NULL;
  1020. PPROVIDER_REC pProvider;
  1021. FILE* f = NULL;
  1022. if( Commands[eProviderFile].bDefined ){
  1023. f = _tfopen( Commands[eProviderFile].strValue, _T("r") );
  1024. if( !f ){
  1025. return GetLastError();
  1026. }
  1027. strLine = _fgetts( buffer, MAXSTR, f );
  1028. Chomp(buffer);
  1029. }else if( Commands[eProviders].bDefined ){
  1030. strLine = Commands[eProviders].strValue;
  1031. }
  1032. while( NULL != strLine ){
  1033. strItem = NULL;
  1034. strFlags = NULL;
  1035. strLevel = NULL;
  1036. if( strLine[0] == _T(';') || // comments
  1037. strLine[0] == _T('#') ){
  1038. continue;
  1039. }
  1040. if( Commands[eProviderFile].bDefined ){
  1041. strItem = _tcstok( buffer, _T("\"\n\t ") );
  1042. strFlags = _tcstok( NULL, _T("\n\t ") );
  1043. strLevel = _tcstok( NULL, _T("\n\t ") );
  1044. }else if( Commands[eProviders].bDefined ){
  1045. strItem = strLine;
  1046. if( *strItem != _T('\0') ){
  1047. strFlags = strItem + (_tcslen(strItem)+1);
  1048. if( *strFlags != _T('\0') ){
  1049. strLevel = strFlags + (_tcslen(strFlags)+1);
  1050. if( IsEmpty( strLevel ) ){
  1051. strLevel = NULL;
  1052. }
  1053. }else{
  1054. strFlags = NULL;
  1055. }
  1056. }else{
  1057. strItem = NULL;
  1058. }
  1059. }
  1060. if( strItem != NULL ){
  1061. pProvider = (PPROVIDER_REC)VARG_ALLOC( sizeof(PROVIDER_REC) );
  1062. if( NULL != pProvider ){
  1063. LPTSTR strZero = _T("0");
  1064. ZeroMemory( pProvider, sizeof(PROVIDER_REC) );
  1065. if( pProviderHead == NULL ){
  1066. pProviderHead = pProvider;
  1067. }else{
  1068. pProviderHead->blink = pProvider;
  1069. pProvider->flink = pProviderHead;
  1070. pProviderHead = pProvider;
  1071. }
  1072. if( IsStrGuid( strItem ) ){
  1073. ASSIGN_STRING( pProvider->strProviderGuid, strItem );
  1074. }else{
  1075. ASSIGN_STRING( pProvider->strProviderName, strItem );
  1076. }
  1077. if( strFlags != NULL ){
  1078. ASSIGN_STRING( pProvider->strFlags, strFlags );
  1079. }else{
  1080. ASSIGN_STRING( pProvider->strFlags, strZero );
  1081. }
  1082. if( strLevel != NULL ){
  1083. ASSIGN_STRING( pProvider->strLevel, strLevel );
  1084. }else{
  1085. ASSIGN_STRING( pProvider->strLevel, strZero );
  1086. }
  1087. }
  1088. }
  1089. if( Commands[eProviderFile].bDefined ){
  1090. strLine = _fgetts( buffer, MAXSTR, f );
  1091. Chomp(buffer);
  1092. }else if( Commands[eProviders].bDefined ){
  1093. break;
  1094. }
  1095. }
  1096. if( NULL != f ){
  1097. fclose( f );
  1098. }
  1099. hr = GetTraceNameToGuidMap( pProviderHead );
  1100. pItem->dwType = PLA_TRACE_LOG;
  1101. pProvider = pProviderHead;
  1102. while( pProvider ){
  1103. hr = AddStringToMsz( &(pItem->strProviders), pProvider->strProviderGuid );
  1104. if( hr != ERROR_SUCCESS ){
  1105. break;
  1106. }
  1107. AddStringToMsz( &(pItem->strLevels), pProvider->strLevel );
  1108. if( hr != ERROR_SUCCESS ){
  1109. break;
  1110. }
  1111. AddStringToMsz( &(pItem->strFlags), pProvider->strFlags );
  1112. if( hr != ERROR_SUCCESS ){
  1113. break;
  1114. }
  1115. pProvider = pProvider->flink;
  1116. }
  1117. PPROVIDER_REC pDelete;
  1118. pProvider = pProviderHead;
  1119. while( pProvider ){
  1120. pDelete = pProvider;
  1121. pProvider = pProvider->flink;
  1122. VARG_FREE( pDelete->strProviderGuid );
  1123. VARG_FREE( pDelete->strProviderName );
  1124. VARG_FREE( pDelete->strFlags );
  1125. VARG_FREE( pDelete->strLevel );
  1126. VARG_FREE( pDelete );
  1127. }
  1128. return hr;
  1129. }
  1130. BOOL AllProvidersMapped( PPROVIDER_REC pProviders )
  1131. {
  1132. PPROVIDER_REC pProvider = pProviders;
  1133. while( pProvider ){
  1134. if( pProvider->strProviderGuid == NULL ){
  1135. return FALSE;
  1136. }
  1137. if( pProvider->strFlags != NULL ){
  1138. if( *(pProvider->strFlags) == _T('(') ){
  1139. return FALSE;
  1140. }
  1141. }
  1142. pProvider = pProvider->flink;
  1143. }
  1144. return TRUE;
  1145. }
  1146. HRESULT
  1147. DecodeFlags( IWbemClassObject *pClass, LPTSTR strFlags, LPDWORD pdwFlags )
  1148. {
  1149. HRESULT hr = ERROR_SUCCESS;
  1150. IWbemQualifierSet *pQualSet = NULL;
  1151. SAFEARRAY* saValues = NULL;
  1152. SAFEARRAY* saValueMap = NULL;
  1153. LONG nFlavor;
  1154. VARIANT var;
  1155. hr = pClass->GetPropertyQualifierSet( L"Flags", &pQualSet );
  1156. if( pQualSet != NULL ){
  1157. hr = pQualSet->Get( L"ValueMap", 0, &var, &nFlavor );
  1158. if( ERROR_SUCCESS == hr && (var.vt & VT_ARRAY) ){
  1159. saValueMap = var.parray;
  1160. }
  1161. hr = pQualSet->Get( L"Values", 0, &var, &nFlavor );
  1162. if( ERROR_SUCCESS == hr && (var.vt & VT_ARRAY) ){
  1163. saValues = var.parray;
  1164. }
  1165. if( saValues != NULL && saValueMap != NULL ){
  1166. BSTR HUGEP *pMapData;
  1167. BSTR HUGEP *pValuesData;
  1168. LONG uMapBound, lMapBound;
  1169. LONG uValuesBound, lValuesBound;
  1170. SafeArrayGetUBound( saValueMap, 1, &uMapBound );
  1171. SafeArrayGetLBound( saValueMap, 1, &lMapBound );
  1172. SafeArrayAccessData( saValueMap, (void HUGEP **)&pMapData );
  1173. SafeArrayGetUBound( saValues, 1, &uValuesBound );
  1174. SafeArrayGetLBound( saValues, 1, &lValuesBound );
  1175. SafeArrayAccessData( saValues, (void HUGEP **)&pValuesData );
  1176. for ( LONG i=lMapBound; i<=uMapBound; i++) {
  1177. LONG dwFlag;
  1178. if( i<lValuesBound || i>uValuesBound ){
  1179. break;
  1180. }
  1181. dwFlag = hextoi( pMapData[i] );
  1182. if( FindString( strFlags, pValuesData[i] ) ){
  1183. *pdwFlags |= dwFlag;
  1184. }
  1185. }
  1186. SafeArrayUnaccessData( saValueMap );
  1187. SafeArrayUnaccessData( saValues );
  1188. SafeArrayDestroy( saValueMap );
  1189. SafeArrayDestroy( saValues );
  1190. }
  1191. pQualSet->Release();
  1192. }
  1193. if( hr == WBEM_S_FALSE ){
  1194. hr = ERROR_SUCCESS;
  1195. }
  1196. return hr;
  1197. }
  1198. HRESULT
  1199. SetProviderGuid( PPROVIDER_REC pProviders, IWbemClassObject *pClass, LPTSTR strProvider, LPTSTR strGuid )
  1200. {
  1201. PPROVIDER_REC pProvider = pProviders;
  1202. while( pProvider ){
  1203. if( !IsEmpty(pProvider->strProviderGuid) && IsEmpty( pProvider->strProviderName ) ){
  1204. if( !_tcsicmp(pProvider->strProviderGuid, strGuid ) ){
  1205. ASSIGN_STRING( pProvider->strProviderName, strProvider );
  1206. break;
  1207. }
  1208. }else if( IsEmpty(pProvider->strProviderGuid) && !IsEmpty( pProvider->strProviderName ) ){
  1209. if( !_tcsicmp(pProvider->strProviderName, strProvider ) ){
  1210. ASSIGN_STRING( pProvider->strProviderGuid, strGuid );
  1211. break;
  1212. }
  1213. }
  1214. pProvider = pProvider->flink;
  1215. }
  1216. if( NULL != pProvider ){
  1217. if( pProvider->strFlags != NULL ){
  1218. if( *(pProvider->strFlags) == _T('(') ){
  1219. DWORD dwFlags = 0;
  1220. TCHAR buffer[MAXSTR];
  1221. DecodeFlags( pClass, pProvider->strFlags, &dwFlags );
  1222. VARG_FREE( pProvider->strFlags );
  1223. pProvider->strFlags = NULL;
  1224. _stprintf( buffer, _T("0x%08x"), dwFlags );
  1225. ASSIGN_STRING( pProvider->strFlags, buffer );
  1226. }
  1227. }
  1228. return ERROR_SUCCESS;
  1229. }
  1230. return ERROR_PATH_NOT_FOUND;
  1231. }
  1232. HRESULT
  1233. GetTraceNameToGuidMap( PPROVIDER_REC pProviders )
  1234. {
  1235. HRESULT hr;
  1236. IWbemServices* pIWbemServices = NULL;
  1237. IEnumWbemClassObject *pEnumProviders = NULL;
  1238. if( pProviders != NULL && AllProvidersMapped( pProviders ) ){
  1239. return ERROR_SUCCESS;
  1240. }
  1241. BSTR bszTraceClass = SysAllocString( L"EventTrace" );
  1242. BSTR bszDescription = SysAllocString( L"Description" );
  1243. BSTR bszGuid = SysAllocString( L"Guid" );
  1244. IWbemQualifierSet *pQualSet = NULL;
  1245. IWbemClassObject *pClass = NULL;
  1246. VARIANT vDiscription;
  1247. VARIANT vGuid;
  1248. ULONG nReturned;
  1249. hr = WbemConnect( &pIWbemServices );
  1250. CHECK_STATUS( hr );
  1251. hr = pIWbemServices->CreateClassEnum (
  1252. bszTraceClass,
  1253. WBEM_FLAG_SHALLOW|WBEM_FLAG_USE_AMENDED_QUALIFIERS,
  1254. NULL,
  1255. &pEnumProviders
  1256. );
  1257. CHECK_STATUS( hr );
  1258. if( pProviders == NULL ){
  1259. PrintMessage( g_normal, IDS_MESSAGE_QUERYP );
  1260. for( int i=0;i<79;i++){ varg_printf( g_normal, _T("-") );}
  1261. varg_printf( g_normal, _T("\n") );
  1262. }
  1263. while( ERROR_SUCCESS == hr ){
  1264. if( pProviders != NULL && AllProvidersMapped( pProviders ) ){
  1265. break;
  1266. }
  1267. hr = pEnumProviders->Next( (-1), 1, &pClass, &nReturned );
  1268. if( ERROR_SUCCESS == hr ){
  1269. pClass->GetQualifierSet ( &pQualSet );
  1270. if ( pQualSet != NULL ) {
  1271. hr = pQualSet->Get ( bszDescription, 0, &vDiscription, 0 );
  1272. if( ERROR_SUCCESS == hr ){
  1273. hr = pQualSet->Get ( bszGuid, 0, &vGuid, 0 );
  1274. if( ERROR_SUCCESS == hr ){
  1275. if( pProviders != NULL ){
  1276. SetProviderGuid( pProviders, pClass, vDiscription.bstrVal, vGuid.bstrVal );
  1277. }else{
  1278. varg_printf( g_normal, _T("%1!-40s! %2!-38s!\n"), vDiscription.bstrVal, vGuid.bstrVal );
  1279. }
  1280. }
  1281. }
  1282. }
  1283. }
  1284. }
  1285. if( NULL == pProviders ){
  1286. varg_printf( g_normal, _T("\n") );
  1287. }
  1288. if( hr == WBEM_S_FALSE ){
  1289. hr = ERROR_SUCCESS;
  1290. }
  1291. cleanup:
  1292. SysFreeString( bszTraceClass );
  1293. SysFreeString( bszDescription );
  1294. SysFreeString( bszGuid );
  1295. if (pIWbemServices){
  1296. pIWbemServices->Release();
  1297. }
  1298. return hr;
  1299. }
  1300. PDH_STATUS
  1301. ScheduleLog()
  1302. {
  1303. PDH_STATUS pdhStatus = ERROR_SUCCESS;
  1304. PDH_TIME_INFO info;
  1305. if( Commands[eRunFor].bDefined){
  1306. DWORD dwSeconds = Commands[eRunFor].stValue.wSecond;
  1307. ZeroMemory( &info, sizeof(PDH_TIME_INFO) );
  1308. dwSeconds += Commands[eRunFor].stValue.wMinute * 60;
  1309. dwSeconds += Commands[eRunFor].stValue.wHour * 3600;
  1310. info.EndTime = dwSeconds;
  1311. info.SampleCount = PLA_TT_UTYPE_SECONDS;
  1312. pdhStatus = PdhPlaSchedule(
  1313. Commands[eName].strValue,
  1314. Commands[eComputer].strValue,
  1315. PLA_AUTO_MODE_AFTER,
  1316. &info
  1317. );
  1318. }
  1319. if( ERROR_SUCCESS == pdhStatus && Commands[eManual].bDefined ){
  1320. LPTSTR strManual = Commands[eManual].strValue;
  1321. ZeroMemory( &info, sizeof(PDH_TIME_INFO) );
  1322. while( strManual != NULL && *strManual != _T('\0') ){
  1323. if( !_tcsicmp( strManual, _T("start")) ){
  1324. info.StartTime = 1;
  1325. }
  1326. if( !_tcsicmp( strManual,_T("stop")) ){
  1327. info.EndTime = 1;
  1328. }
  1329. strManual += (_tcslen( strManual )+1);
  1330. }
  1331. pdhStatus = PdhPlaSchedule(
  1332. Commands[eName].strValue,
  1333. Commands[eComputer].strValue,
  1334. PLA_AUTO_MODE_NONE,
  1335. &info
  1336. );
  1337. }
  1338. return pdhStatus;
  1339. }
  1340. HRESULT
  1341. WbemConnect( IWbemServices** pWbemServices )
  1342. {
  1343. WCHAR buffer[MAXSTR];
  1344. IWbemLocator *pLocator = NULL;
  1345. BSTR bszNamespace = NULL;
  1346. if( Commands[eComputer].bDefined ){
  1347. _stprintf( buffer, _T("\\\\%s\\%s"), Commands[eComputer].strValue, L"root\\wmi" );
  1348. bszNamespace = SysAllocString( buffer );
  1349. }else{
  1350. bszNamespace = SysAllocString( L"root\\wmi" );
  1351. }
  1352. HRESULT hr = CoInitialize(0);
  1353. hr = CoCreateInstance(
  1354. CLSID_WbemLocator,
  1355. 0,
  1356. CLSCTX_INPROC_SERVER,
  1357. IID_IWbemLocator,
  1358. (LPVOID *) &pLocator
  1359. );
  1360. CHECK_STATUS( hr );
  1361. if( Commands[eUser].bDefined ){
  1362. hr = pLocator->ConnectServer(
  1363. bszNamespace,
  1364. g_strUser,
  1365. g_strPassword,
  1366. NULL,
  1367. 0L,
  1368. NULL,
  1369. NULL,
  1370. pWbemServices
  1371. );
  1372. }else{
  1373. hr = pLocator->ConnectServer(
  1374. bszNamespace,
  1375. NULL,
  1376. NULL,
  1377. NULL,
  1378. 0L,
  1379. NULL,
  1380. NULL,
  1381. pWbemServices
  1382. );
  1383. }
  1384. CHECK_STATUS( hr );
  1385. hr = CoSetProxyBlanket(
  1386. *pWbemServices,
  1387. RPC_C_AUTHN_WINNT,
  1388. RPC_C_AUTHZ_NONE,
  1389. NULL,
  1390. RPC_C_AUTHN_LEVEL_PKT,
  1391. RPC_C_IMP_LEVEL_IMPERSONATE,
  1392. NULL,
  1393. EOAC_NONE
  1394. );
  1395. cleanup:
  1396. SysFreeString( bszNamespace );
  1397. if( pLocator ){
  1398. pLocator->Release();
  1399. }
  1400. return hr;
  1401. }
  1402. HRESULT
  1403. EtsQuerySession( IWbemServices *pWbemService, LPTSTR strSession )
  1404. {
  1405. HRESULT hr = ERROR_SUCCESS;
  1406. IEnumWbemClassObject* pEnumClass = NULL;
  1407. IWbemClassObject* pClass = NULL;
  1408. IWbemQualifierSet *pQualSet = NULL;
  1409. TCHAR buffer[MAXSTR];
  1410. BSTR bszClass = SysAllocString( L"TraceLogger" );
  1411. varg_printf( g_normal, _T("\n") );
  1412. if( NULL == strSession ){
  1413. PrintMessage( g_normal, IDS_MESSAGE_ETSQUERY );
  1414. for(int i=0;i<79;i++){ varg_printf( g_normal, _T("-") ); }
  1415. varg_printf( g_normal, _T("\n") );
  1416. }
  1417. hr = pWbemService->CreateInstanceEnum( bszClass, WBEM_FLAG_SHALLOW, NULL, &pEnumClass );
  1418. CHECK_STATUS( hr );
  1419. while ( hr == ERROR_SUCCESS ){
  1420. ULONG nObjects;
  1421. hr = pEnumClass->Next( WBEM_INFINITE, 1, &pClass, &nObjects );
  1422. if( hr == ERROR_SUCCESS ){
  1423. VARIANT vValue;
  1424. CIMTYPE vtType;
  1425. LONG nFlavor;
  1426. pClass->Get( L"Name", 0, &vValue, &vtType, &nFlavor );
  1427. if( NULL == strSession ){
  1428. VARIANT vLogger;
  1429. VARIANT vFile;
  1430. pClass->Get( L"LoggerId", 0, &vLogger, &vtType, &nFlavor );
  1431. pClass->Get( L"LogFileName", 0, &vFile, &vtType, &nFlavor );
  1432. hr = VariantChangeType( &vLogger, &vLogger, 0, VT_BSTR );
  1433. if( ERROR_SUCCESS == hr ){
  1434. PrintMessage( g_normal, IDS_MESSAGE_ETSQUERYF, vValue.bstrVal, vLogger.bstrVal, vFile.bstrVal);
  1435. }
  1436. }else{
  1437. if( _tcsicmp( strSession, vValue.bstrVal ) == 0 ){
  1438. LoadString( NULL, IDS_MESSAGE_ETSNAME, buffer, MAXSTR );
  1439. PrintMessage( g_normal, IDS_MESSAGE_ETSQUERYSF, buffer, vValue.bstrVal );
  1440. }else{
  1441. continue;
  1442. }
  1443. BSTR HUGEP *pData;
  1444. SAFEARRAY* saProperties;
  1445. LONG uBound, lBound;
  1446. vValue.boolVal = TRUE;
  1447. vValue.vt = VT_BOOL;
  1448. hr = pClass->GetNames( L"DisplayName", WBEM_FLAG_ONLY_IF_TRUE, 0, &saProperties );
  1449. if( hr == ERROR_SUCCESS && saProperties != NULL ){
  1450. SafeArrayGetUBound( saProperties, 1, &uBound );
  1451. SafeArrayGetLBound( saProperties, 1, &lBound );
  1452. SafeArrayAccessData( saProperties, (void HUGEP **)&pData );
  1453. for( LONG i=lBound;i<=uBound;i++){
  1454. VARIANT vLabel;
  1455. pClass->GetPropertyQualifierSet( pData[i], &pQualSet );
  1456. pQualSet->Get( L"DisplayName", 0, &vLabel, &nFlavor );
  1457. _stprintf( buffer, _T("%s:"), vLabel.bstrVal );
  1458. pClass->Get( pData[i], 0, &vValue, &vtType, &nFlavor );
  1459. hr = VariantChangeType( &vValue, &vValue, 0, VT_BSTR );
  1460. if( SUCCEEDED(hr) ){
  1461. PrintMessage( g_normal, IDS_MESSAGE_ETSQUERYSF, buffer, vValue.bstrVal );
  1462. }
  1463. VariantClear( &vValue );
  1464. VariantClear( &vLabel );
  1465. }
  1466. SafeArrayUnaccessData( saProperties );
  1467. SafeArrayDestroy( saProperties );
  1468. }
  1469. hr = pClass->Get( L"Guid", 0, &vValue, &vtType, &nFlavor );
  1470. if( ERROR_SUCCESS == hr && VT_NULL != vValue.vt ){
  1471. saProperties = vValue.parray;
  1472. SafeArrayGetUBound( saProperties, 1, &uBound );
  1473. SafeArrayGetLBound( saProperties, 1, &lBound );
  1474. SafeArrayAccessData( saProperties, (void HUGEP **)&pData );
  1475. PrintMessage( g_normal, IDS_MESSAGE_PROVIDERS );
  1476. for( LONG i=lBound;i<=uBound;i++){
  1477. PrintMessage( g_normal, IDS_MESSAGE_PRVGUID, pData[i] );
  1478. }
  1479. }
  1480. }
  1481. }
  1482. }
  1483. if( hr == WBEM_S_FALSE ){
  1484. hr = ERROR_SUCCESS;
  1485. }
  1486. varg_printf( g_normal, _T("\n") );
  1487. cleanup:
  1488. SysFreeString( bszClass );
  1489. return hr;
  1490. }
  1491. #define FIRST_MODE( b ) if( !b ){wcscat( buffer, L"|" );}else{b=FALSE;}
  1492. HRESULT
  1493. EtsSetSession( IWbemServices* pWbemService, IWbemClassObject* pTrace )
  1494. {
  1495. HRESULT hr = ERROR_SUCCESS;
  1496. VARIANT var;
  1497. WCHAR buffer[MAXSTR];
  1498. BOOL bFirst;
  1499. if( Commands[eOutput].bDefined ){
  1500. TCHAR full[MAXSTR];
  1501. _tfullpath( full, Commands[eOutput].strValue, MAXSTR );
  1502. var.vt = VT_BSTR;
  1503. var.bstrVal = SysAllocString( full );
  1504. hr = pTrace->Put( L"LogFileName", 0, &var, 0);
  1505. VariantClear(&var);
  1506. CHECK_STATUS( hr );
  1507. }else if( !Commands[eRealTime].bDefined ){
  1508. TCHAR full[MAXSTR];
  1509. LPTSTR strPath = (LPTSTR)VARG_ALLOC( (_tcslen( Commands[eName].strValue )+6) * sizeof(TCHAR) );
  1510. if( NULL != strPath ){
  1511. _tcscpy( strPath, Commands[eName].strValue );
  1512. _tcscat( strPath, _T(".etl") );
  1513. _tfullpath( full, strPath, MAXSTR );
  1514. var.vt = VT_BSTR;
  1515. var.bstrVal = SysAllocString( full );
  1516. hr = pTrace->Put( L"LogFileName", 0, &var, 0);
  1517. VariantClear(&var);
  1518. VARG_FREE( strPath );
  1519. CHECK_STATUS( hr );
  1520. }else{
  1521. hr = E_OUTOFMEMORY;
  1522. goto cleanup;
  1523. }
  1524. }
  1525. if( Commands[eBufferSize].bDefined ){
  1526. var.vt = VT_I4;
  1527. var.lVal = Commands[eBufferSize].nValue;
  1528. hr = pTrace->Put( L"BufferSize", 0, &var, 0);
  1529. VariantClear(&var);
  1530. CHECK_STATUS( hr );
  1531. }
  1532. if( Commands[eBuffers].bDefined ){
  1533. LPTSTR strMin;
  1534. LPTSTR strMax;
  1535. var.vt = VT_I4;
  1536. strMin = Commands[eBuffers].strValue;
  1537. if( NULL != strMin ){
  1538. var.lVal = _ttoi( strMin );
  1539. hr = pTrace->Put( L"MinimumBuffers", 0, &var, 0);
  1540. CHECK_STATUS( hr );
  1541. strMax = strMin + (_tcslen( strMin )+1);
  1542. if( *strMax != _T('\0') ){
  1543. var.lVal = _ttoi( strMax );
  1544. hr = pTrace->Put( L"MaximumBuffers", 0, &var, 0);
  1545. CHECK_STATUS( hr );
  1546. }
  1547. }
  1548. }
  1549. if( Commands[eMax].bDefined ){
  1550. var.vt = VT_I4;
  1551. var.lVal = Commands[eMax].nValue;
  1552. hr = pTrace->Put( L"MaximumFileSize", 0, &var, 0);
  1553. VariantClear(&var);
  1554. CHECK_STATUS( hr );
  1555. }
  1556. buffer[0] = L'\0';
  1557. var.vt = VT_BSTR;
  1558. bFirst = TRUE;
  1559. if( Commands[eFormat].bDefined || Commands[eAppend].bDefined ){
  1560. DWORD dwFormat = 0;
  1561. hr = GetFileFormat( Commands[eFormat].strValue, &dwFormat );
  1562. switch(dwFormat){
  1563. case PLA_BIN_CIRC_FILE:
  1564. FIRST_MODE( bFirst );
  1565. wcscpy( buffer, L"Circular" );
  1566. break;
  1567. case PLA_BIN_FILE:
  1568. default:
  1569. FIRST_MODE( bFirst );
  1570. wcscpy( buffer, L"Sequential" );
  1571. }
  1572. }
  1573. if( Commands[eAppend].bDefined ){
  1574. FIRST_MODE( bFirst );
  1575. wcscat( buffer, L"Append" );
  1576. }
  1577. if( Commands[eRealTime].bDefined ){
  1578. FIRST_MODE( bFirst );
  1579. wcscat( buffer, L"RealTime" );
  1580. }
  1581. if( Commands[eUserMode].bDefined ){
  1582. FIRST_MODE( bFirst );
  1583. wcscat( buffer, L"Private" );
  1584. }
  1585. if( Commands[eMode].bDefined && Commands[eMode].strValue != NULL ){
  1586. LPTSTR strMode = Commands[eMode].strValue;
  1587. while( *strMode != _T('\0') ){
  1588. if( (wcslen( buffer ) + wcslen( strMode ) + 2) > MAXSTR ){
  1589. break;
  1590. }
  1591. FIRST_MODE( bFirst );
  1592. wcscat( buffer, strMode );
  1593. strMode += (wcslen(strMode)+1);
  1594. }
  1595. }
  1596. var.bstrVal = SysAllocString( buffer );
  1597. hr = pTrace->Put( L"LogFileMode", 0, &var, 0);
  1598. VariantClear( &var );
  1599. CHECK_STATUS( hr );
  1600. if( Commands[eFlushTimer].bDefined ){
  1601. DWORD dwSeconds;
  1602. dwSeconds = Commands[eFlushTimer].stValue.wSecond;
  1603. dwSeconds += Commands[eFlushTimer].stValue.wMinute * 60;
  1604. dwSeconds += Commands[eFlushTimer].stValue.wHour * 3600;
  1605. var.vt = VT_I4;
  1606. var.lVal = dwSeconds;
  1607. hr = pTrace->Put( L"FlushTimer", 0, &var, 0);
  1608. VariantClear(&var);
  1609. CHECK_STATUS( hr );
  1610. }
  1611. if( Commands[eAgeLimit].bDefined ){
  1612. var.vt = VT_I4;
  1613. var.lVal = Commands[eAgeLimit].nValue;
  1614. hr = pTrace->Put( L"AgeLimit", 0, &var, 0);
  1615. VariantClear(&var);
  1616. CHECK_STATUS( hr );
  1617. }
  1618. if( !Commands[eProviders].bDefined && !Commands[eProviderFile].bDefined ){
  1619. if( _tcsicmp( Commands[eName].strValue, NT_KERNEL_LOGGER ) == 0 ){
  1620. LoadString( NULL, IDS_DEFAULT_ETSENABLE, buffer, MAXSTR );
  1621. Commands[eProviders].bDefined = TRUE;
  1622. ASSIGN_STRING( Commands[eProviders].strValue, NT_KERNEL_GUID );
  1623. AddStringToMsz( &Commands[eProviders].strValue, buffer );
  1624. }
  1625. }
  1626. if( Commands[eProviders].bDefined || Commands[eProviderFile].bDefined ){
  1627. PDH_PLA_ITEM providers;
  1628. LPTSTR strGuid;
  1629. LPTSTR strLevel;
  1630. LPTSTR strFlags;
  1631. long dwCount = 0;
  1632. ZeroMemory( &providers, sizeof(PDH_PLA_ITEM) );
  1633. hr = GetProviders( &providers );
  1634. CHECK_STATUS( hr );
  1635. strGuid = providers.strProviders;
  1636. strLevel = providers.strLevels;
  1637. strFlags = providers.strFlags;
  1638. if( strGuid != NULL ){
  1639. SAFEARRAY* saGuids;
  1640. SAFEARRAY* saLevel;
  1641. SAFEARRAY* saFlags;
  1642. while( *strGuid != _T('\0') ){
  1643. strGuid += _tcslen( strGuid )+1;
  1644. dwCount++;
  1645. }
  1646. strGuid = providers.strProviders;
  1647. saGuids = SafeArrayCreateVector( VT_BSTR, 0, dwCount );
  1648. saFlags = SafeArrayCreateVector( VT_I4, 0, dwCount );
  1649. saLevel = SafeArrayCreateVector( VT_I4, 0, dwCount );
  1650. if( saGuids == NULL || saFlags == NULL || saLevel == NULL ){
  1651. if( saGuids != NULL ){
  1652. SafeArrayDestroy( saGuids );
  1653. }
  1654. if( saFlags != NULL ){
  1655. SafeArrayDestroy( saFlags );
  1656. }
  1657. if( saLevel != NULL ){
  1658. SafeArrayDestroy( saLevel );
  1659. }
  1660. }else{
  1661. BSTR HUGEP *pGuidData;
  1662. DWORD HUGEP *pLevelData;
  1663. DWORD HUGEP *pFlagData;
  1664. SafeArrayAccessData( saGuids, (void HUGEP **)&pGuidData);
  1665. SafeArrayAccessData( saFlags, (void HUGEP **)&pFlagData);
  1666. SafeArrayAccessData( saLevel, (void HUGEP **)&pLevelData);
  1667. for (long i=dwCount-1; i >=0; i--) {
  1668. if( strGuid != NULL ){
  1669. BSTR bszGuid = SysAllocString( strGuid );
  1670. pGuidData[i] = bszGuid;
  1671. strGuid += _tcslen( strGuid )+1;
  1672. }
  1673. if( strLevel != NULL ){
  1674. pLevelData[i] = _ttoi( strLevel );
  1675. strLevel += _tcslen( strLevel )+1;
  1676. }
  1677. if( strFlags != NULL ){
  1678. pFlagData[i] = hextoi( strFlags );
  1679. strFlags += _tcslen( strFlags )+1;
  1680. }
  1681. }
  1682. SafeArrayUnaccessData( saGuids );
  1683. SafeArrayUnaccessData( saFlags );
  1684. SafeArrayUnaccessData( saLevel );
  1685. VARIANT vArray;
  1686. vArray.vt = VT_ARRAY|VT_BSTR;
  1687. vArray.parray = saGuids;
  1688. pTrace->Put( L"Guid", 0, &vArray, 0 );
  1689. vArray.vt = VT_ARRAY|VT_I4;
  1690. vArray.parray = saFlags;
  1691. pTrace->Put( L"EnableFlags", 0, &vArray, 0 );
  1692. vArray.vt = VT_ARRAY|VT_I4;
  1693. vArray.parray = saLevel;
  1694. pTrace->Put( L"Level", 0, &vArray, 0 );
  1695. SafeArrayDestroy( saGuids );
  1696. SafeArrayDestroy( saFlags );
  1697. SafeArrayDestroy( saLevel );
  1698. }
  1699. }
  1700. }
  1701. cleanup:
  1702. return ERROR_SUCCESS;
  1703. }
  1704. HRESULT
  1705. EtsCallSession( IWbemServices *pWbemService, LPWSTR strFunction )
  1706. {
  1707. HRESULT hr;
  1708. WCHAR buffer[MAXSTR];
  1709. IWbemClassObject *pOutInst = NULL;
  1710. IWbemCallResult *pCallResult = NULL;
  1711. BSTR bszFunction = SysAllocString( strFunction );
  1712. BSTR bszNamespace = NULL;
  1713. BSTR bszInstance = NULL;
  1714. wsprintf( buffer, L"TraceLogger.Name=\"%s\"", Commands[eName].strValue );
  1715. bszInstance = SysAllocString( buffer );
  1716. hr = pWbemService->ExecMethod( bszInstance, bszFunction, 0, NULL, NULL, &pOutInst, &pCallResult );
  1717. CHECK_STATUS( hr );
  1718. if( pCallResult ){
  1719. LONG lResult;
  1720. pCallResult->GetCallStatus( WBEM_INFINITE, &lResult );
  1721. hr = lResult;
  1722. }
  1723. cleanup:
  1724. SysFreeString( bszInstance );
  1725. SysFreeString( bszFunction );
  1726. if( pCallResult ){
  1727. pCallResult->Release();
  1728. }
  1729. if( pOutInst ){
  1730. pOutInst->Release();
  1731. }
  1732. return hr;
  1733. }
  1734. HRESULT
  1735. EtsStartSession(IWbemServices *pWbemService)
  1736. {
  1737. HRESULT hr = ERROR_SUCCESS;
  1738. IWbemClassObject * pClass = NULL;
  1739. IWbemClassObject* pNewTrace = NULL;
  1740. IWbemCallResult *pCallResult = NULL;
  1741. VARIANT var;
  1742. BSTR bszClass = SysAllocString( L"TraceLogger" );
  1743. hr = pWbemService->GetObject( bszClass, 0, NULL, &pClass, NULL);
  1744. CHECK_STATUS( hr );
  1745. hr = pClass->SpawnInstance( 0, &pNewTrace );
  1746. CHECK_STATUS( hr );
  1747. var.vt = VT_BSTR;
  1748. var.bstrVal = SysAllocString( Commands[eName].strValue );
  1749. hr = pNewTrace->Put( L"Name", 0, &var, 0);
  1750. VariantClear(&var);
  1751. hr = EtsSetSession( pWbemService, pNewTrace );
  1752. CHECK_STATUS( hr );
  1753. hr = pWbemService->PutInstance( pNewTrace, WBEM_FLAG_CREATE_ONLY, NULL, &pCallResult );
  1754. CHECK_STATUS( hr );
  1755. if( pCallResult ){
  1756. LONG lResult;
  1757. pCallResult->GetCallStatus( WBEM_INFINITE, &lResult );
  1758. hr = lResult;
  1759. }
  1760. CHECK_STATUS( hr );
  1761. cleanup:
  1762. SysFreeString( bszClass );
  1763. if( pCallResult ){
  1764. pCallResult->Release();
  1765. }
  1766. return hr;
  1767. }
  1768. HRESULT
  1769. EtsEnableSession(IWbemServices *pWbemService)
  1770. {
  1771. HRESULT hr;
  1772. WCHAR buffer[MAXSTR];
  1773. IWbemClassObject *pOutInst = NULL;
  1774. IWbemCallResult *pCallResult = NULL;
  1775. IWbemClassObject *pTrace = NULL;
  1776. BSTR bszNamespace = NULL;
  1777. BSTR bszInstance = NULL;
  1778. wsprintf( buffer, L"TraceLogger.Name=\"%s\"", Commands[eName].strValue );
  1779. bszInstance = SysAllocString( buffer );
  1780. hr = pWbemService->GetObject( bszInstance, 0, NULL, &pTrace, NULL);
  1781. CHECK_STATUS( hr );
  1782. hr = EtsSetSession( pWbemService, pTrace );
  1783. CHECK_STATUS( hr );
  1784. hr = pWbemService->PutInstance( pTrace, WBEM_FLAG_UPDATE_ONLY, NULL, &pCallResult );
  1785. CHECK_STATUS( hr );
  1786. if( pCallResult ){
  1787. LONG lResult;
  1788. pCallResult->GetCallStatus( WBEM_INFINITE, &lResult );
  1789. hr = lResult;
  1790. }
  1791. CHECK_STATUS( hr );
  1792. cleanup:
  1793. SysFreeString( bszInstance );
  1794. if( pCallResult ){
  1795. pCallResult->Release();
  1796. }
  1797. if( pOutInst ){
  1798. pOutInst->Release();
  1799. }
  1800. return hr;
  1801. }
  1802. HRESULT EventTraceSessionControl()
  1803. {
  1804. HRESULT hr = ERROR_SUCCESS;
  1805. IWbemServices *pWbemService = NULL;
  1806. hr = WbemConnect( &pWbemService );
  1807. CHECK_STATUS( hr );
  1808. if( Commands[eFlushBuffers].bValue ){
  1809. hr = EtsCallSession( pWbemService, L"FlushTrace" );
  1810. }else if( Commands[eQuery].bDefined ){
  1811. hr = EtsQuerySession( pWbemService, Commands[eName].strValue );
  1812. }else if( Commands[eStart].bDefined || Commands[eCreate].bDefined ){
  1813. hr = EtsStartSession( pWbemService );
  1814. if( SUCCEEDED(hr) ){
  1815. EtsQuerySession( pWbemService, Commands[eName].strValue );
  1816. }
  1817. }else if( Commands[eStop].bDefined || Commands[eDelete].bDefined ){
  1818. hr = EtsCallSession( pWbemService, L"StopTrace" );
  1819. }else if( Commands[eUpdate].bDefined ){
  1820. hr = EtsEnableSession( pWbemService );
  1821. }
  1822. cleanup:
  1823. if( pWbemService ){
  1824. pWbemService->Release();
  1825. }
  1826. return hr;
  1827. }
  1828. HRESULT WbemError( HRESULT hr )
  1829. {
  1830. WCHAR szError[MAXSTR] = { NULL };
  1831. WCHAR szFacility[MAXSTR] = { NULL };
  1832. IWbemStatusCodeText * pStatus = NULL;
  1833. SCODE sc = CoCreateInstance(CLSID_WbemStatusCodeText, 0, CLSCTX_INPROC_SERVER,
  1834. IID_IWbemStatusCodeText, (LPVOID *) &pStatus);
  1835. if(sc == S_OK){
  1836. BSTR bstr = 0;
  1837. sc = pStatus->GetErrorCodeText(hr, 0, 0, &bstr);
  1838. if(sc == S_OK){
  1839. wcsncpy(szError, bstr, MAXSTR-1);
  1840. SysFreeString(bstr);
  1841. bstr = 0;
  1842. }
  1843. sc = pStatus->GetFacilityCodeText(hr, 0, 0, &bstr);
  1844. if(sc == S_OK){
  1845. wcsncpy(szFacility, bstr, MAXSTR-1);
  1846. SysFreeString(bstr);
  1847. bstr = 0;
  1848. }
  1849. pStatus->Release();
  1850. }
  1851. if( Commands[eDebug].bDefined ){
  1852. if( _tcscmp( szFacility, L"<Null>" ) == 0 ){
  1853. LoadString( NULL, IDS_MESSAGE_SYSTEM, szFacility, MAXSTR );
  1854. }
  1855. PrintMessage( g_debug, LOGMAN_ERROR_WBEM, hr, szFacility, szError );
  1856. }else{
  1857. PrintMessage( g_debug, IDS_MESSAGE_ERROR );
  1858. varg_printf( g_debug, _T("%1!s!"), szError );
  1859. }
  1860. return ERROR_SUCCESS;
  1861. }
  1862. void
  1863. ShowValidationError( PDH_STATUS pdhStatus, PPDH_PLA_INFO pInfo )
  1864. {
  1865. DWORD dwFlag;
  1866. DWORD dwMask;
  1867. if( SEVERITY( pdhStatus ) == STATUS_SEVERITY_WARNING ){
  1868. dwMask = pInfo->dwReserved2;
  1869. }else{
  1870. dwMask = pInfo->dwMask;
  1871. }
  1872. if( 0 == dwMask ){
  1873. return;
  1874. }
  1875. for( ULONG i=1;i<0x80000000; i*=2 ){
  1876. dwFlag = (i & dwMask);
  1877. if( 0 == dwFlag ){
  1878. continue;
  1879. }
  1880. switch( SEVERITY( pdhStatus ) ){
  1881. case STATUS_SEVERITY_ERROR:
  1882. PrintMessage( g_debug, IDS_MESSAGE_ERROR );
  1883. break;
  1884. case STATUS_SEVERITY_WARNING:
  1885. PrintMessage( g_debug, IDS_MESSAGE_WARNING );
  1886. break;
  1887. }
  1888. switch( dwFlag ){
  1889. case PLA_INFO_FLAG_FORMAT:
  1890. PrintMessage( g_debug, LOGMAN_ERROR_FILEFORMAT, pInfo->dwFileFormat );
  1891. break;
  1892. case PLA_INFO_FLAG_INTERVAL:
  1893. PrintMessage( g_debug, LOGMAN_ERROR_INTERVAL );
  1894. break;
  1895. case PLA_INFO_FLAG_BUFFERSIZE:
  1896. PrintMessage( g_debug, LOGMAN_ERROR_BUFFERSIZE, pInfo->Trace.dwBufferSize );
  1897. break;
  1898. case PLA_INFO_FLAG_MINBUFFERS:
  1899. PrintMessage( g_debug, LOGMAN_ERROR_MINBUFFER, pInfo->Trace.dwMinimumBuffers );
  1900. break;
  1901. case PLA_INFO_FLAG_MAXBUFFERS:
  1902. PrintMessage( g_debug, LOGMAN_ERROR_MAXBUFFER, pInfo->Trace.dwMinimumBuffers );
  1903. break;
  1904. case PLA_INFO_FLAG_FLUSHTIMER:
  1905. PrintMessage( g_debug, LOGMAN_ERROR_FLUSHTIMER, pInfo->Trace.dwFlushTimer );
  1906. break;
  1907. case PLA_INFO_FLAG_MAXLOGSIZE:
  1908. PrintMessage( g_debug, LOGMAN_ERROR_MAXLOGSIZE, pInfo->dwMaxLogSize );
  1909. break;
  1910. case PLA_INFO_FLAG_RUNCOMMAND:
  1911. PrintMessage( g_debug, LOGMAN_ERROR_CMDFILE, pInfo->strCommandFileName );
  1912. break;
  1913. case PLA_INFO_FLAG_FILENAME:
  1914. if( Commands[eOutput].bDefined ){
  1915. PrintMessage( g_debug, LOGMAN_ERROR_FILENAME );
  1916. }else{
  1917. PrintMessage( g_debug, LOGMAN_ERROR_FILENAME_DEFAULT );
  1918. }
  1919. break;
  1920. case PLA_INFO_FLAG_AUTOFORMAT:
  1921. PrintMessage( g_debug, LOGMAN_ERROR_AUTOFORMAT );
  1922. break;
  1923. case PLA_INFO_FLAG_USER:
  1924. PrintMessage( g_debug, LOGMAN_ERROR_USER, pInfo->strUser );
  1925. break;
  1926. case PLA_INFO_FLAG_DATASTORE:
  1927. switch( pInfo->dwDatastoreAttributes & PLA_DATASTORE_APPEND_MASK ){
  1928. case PLA_DATASTORE_APPEND:
  1929. PrintMessage( g_debug, LOGMAN_ERROR_DATASTOREA );
  1930. break;
  1931. case PLA_DATASTORE_OVERWRITE:
  1932. PrintMessage( g_debug, LOGMAN_ERROR_DATASTOREO );
  1933. break;
  1934. }
  1935. break;
  1936. case PLA_INFO_FLAG_MODE:
  1937. PrintMessage( g_debug, LOGMAN_ERROR_TRACEMODE, pInfo->Trace.dwMode );
  1938. break;
  1939. case PLA_INFO_FLAG_LOGGERNAME:
  1940. PrintMessage( g_debug, LOGMAN_ERROR_LOGGERNAME, pInfo->Trace.strLoggerName );
  1941. break;
  1942. case PLA_INFO_FLAG_REPEAT:
  1943. PrintMessage( g_debug, LOGMAN_ERROR_REPEATMODE );
  1944. break;
  1945. case PLA_INFO_FLAG_TYPE:
  1946. PrintMessage( g_debug, LOGMAN_ERROR_COLLTYPE, pInfo->dwType );
  1947. break;
  1948. case PLA_INFO_FLAG_DEFAULTDIR:
  1949. case PLA_INFO_FLAG_PROVIDERS:
  1950. PrintMessage( g_debug, LOGMAN_ERROR_PROVIDER );
  1951. break;
  1952. case PLA_INFO_FLAG_COUNTERS:
  1953. {
  1954. LPTSTR strCounter = pInfo->Perf.piCounterList.strCounters;
  1955. if( strCounter != NULL ){
  1956. DWORD dwCount = 0;
  1957. while(*strCounter != _T('\0') ){
  1958. if( dwCount++ == pInfo->dwReserved1 ){
  1959. break;
  1960. }
  1961. strCounter += (_tcslen( strCounter )+1 );
  1962. }
  1963. }
  1964. PrintMessage( g_debug, LOGMAN_ERROR_COUNTERPATH, strCounter ? strCounter : _T("") );
  1965. }
  1966. break;
  1967. default:
  1968. PrintMessage( g_debug, LOGMAN_ERROR_UNKNOWN );
  1969. }
  1970. }
  1971. varg_printf( g_debug, _T("\n") );
  1972. }
  1973. void
  1974. PdhError( PDH_STATUS pdhStatus, PPDH_PLA_INFO pInfo )
  1975. {
  1976. switch( pdhStatus ){
  1977. case PDH_PLA_VALIDATION_ERROR:
  1978. case PDH_PLA_VALIDATION_WARNING:
  1979. ShowValidationError( pdhStatus, pInfo );
  1980. break;
  1981. case PDH_PLA_COLLECTION_ALREADY_RUNNING:
  1982. case PDH_PLA_COLLECTION_NOT_FOUND:
  1983. case PDH_PLA_ERROR_NOSTART:
  1984. case PDH_PLA_ERROR_ALREADY_EXISTS:
  1985. PrintErrorEx( pdhStatus, PDH_MODULE, Commands[eName].strValue );
  1986. break;
  1987. default:
  1988. PrintErrorEx( pdhStatus, PDH_MODULE );
  1989. }
  1990. }
  1991. void
  1992. LogmanError( DWORD dwStatus )
  1993. {
  1994. switch( dwStatus ){
  1995. case LOGMAN_ERROR_FILEFORMAT:
  1996. PrintMessage( g_debug, LOGMAN_ERROR_FILEFORMAT );
  1997. break;
  1998. case LOGMAN_ERROR_LOGON:
  1999. PrintMessage( g_debug, LOGMAN_ERROR_LOGON );
  2000. break;
  2001. default:
  2002. PrintError( dwStatus );
  2003. }
  2004. }
  2005. ULONG hextoi( LPWSTR s )
  2006. {
  2007. long len;
  2008. ULONG num, base, hex;
  2009. if (s == NULL || s[0] == L'\0') {
  2010. return 0;
  2011. }
  2012. len = (long) wcslen(s);
  2013. if (len == 0) {
  2014. return 0;
  2015. }
  2016. hex = 0;
  2017. base = 1;
  2018. num = 0;
  2019. while (-- len >= 0) {
  2020. if (s[len] >= L'0' && s[len] <= L'9'){
  2021. num = s[len] - L'0';
  2022. }else if (s[len] >= L'a' && s[len] <= L'f'){
  2023. num = (s[len] - L'a') + 10;
  2024. }else if (s[len] >= L'A' && s[len] <= L'F'){
  2025. num = (s[len] - L'A') + 10;
  2026. }else if( s[len] == L'x' || s[len] == L'X'){
  2027. break;
  2028. }else{
  2029. continue;
  2030. }
  2031. hex += num * base;
  2032. base = base * 16;
  2033. }
  2034. return hex;
  2035. }