Leaked source code of windows server 2003
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

3168 lines
108 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_STR ( IDS_PARAM_CLOCKTYPE, VARG_FLAG_OPTIONAL|VARG_FLAG_LITERAL, _T("system") )
  82. VARG_DECLARE_NAMES
  83. eDebug,
  84. eHelp,
  85. eCreate,
  86. eCounter,
  87. eTrace,
  88. eStart,
  89. eStop,
  90. eDelete,
  91. eQuery,
  92. eQueryProv,
  93. eUpdate,
  94. eName,
  95. eComputer,
  96. eConfig,
  97. eBegin,
  98. eEnd,
  99. eManual,
  100. eRepeat,
  101. eOutput,
  102. eFormat,
  103. eAppend,
  104. eVersion,
  105. eRunCmd,
  106. eMax,
  107. eNewFile,
  108. eCounters,
  109. eCounterFile,
  110. eSampleInterval,
  111. eLoggerName,
  112. eRealTime,
  113. eProviders,
  114. eProviderFile,
  115. eUserMode,
  116. eBufferSize,
  117. eFlushTimer,
  118. eBuffers,
  119. eFlushBuffers,
  120. eUser,
  121. eRunFor,
  122. eYes,
  123. eEts,
  124. eAgeLimit,
  125. eMode,
  126. eClockType,
  127. VARG_DECLARE_FORMAT
  128. VARG_VERB ( eCreate, VERB_CREATE )
  129. VARG_ADVERB( eCounter, VERB_CREATE, VERB_COUNTER )
  130. VARG_ADVERB( eTrace, VERB_CREATE, VERB_TRACE )
  131. VARG_VERB ( eStart, VERB_START )
  132. VARG_VERB ( eStop, VERB_STOP )
  133. VARG_VERB ( eDelete, VERB_DELETE )
  134. VARG_VERB ( eQuery, VERB_QUERY )
  135. VARG_ADVERB( eQueryProv, VERB_QUERY, VERB_PROV )
  136. VARG_VERB ( eUpdate, VERB_UPDATE )
  137. VARG_VERB ( eName, VERB_CREATE|VERB_UPDATE|VERB_START|VERB_STOP|VERB_QUERY|VERB_DELETE )
  138. VARG_VERB ( eBegin, VERB_UPDATE|VERB_CREATE )
  139. VARG_VERB ( eEnd, VERB_UPDATE|VERB_CREATE )
  140. VARG_VERB ( eManual, VERB_UPDATE|VERB_CREATE|VERB_COUNTER )
  141. VARG_VERB ( eRepeat, VERB_UPDATE|VERB_CREATE )
  142. VARG_VERB ( eOutput, VERB_UPDATE|VERB_CREATE )
  143. VARG_VERB ( eFormat, VERB_UPDATE|VERB_CREATE )
  144. VARG_VERB ( eAppend, VERB_UPDATE|VERB_CREATE )
  145. VARG_VERB ( eVersion, VERB_UPDATE|VERB_CREATE )
  146. VARG_VERB ( eRunCmd, VERB_UPDATE|VERB_CREATE )
  147. VARG_VERB ( eMax, VERB_UPDATE|VERB_CREATE|VERB_TRACE )
  148. VARG_VERB ( eNewFile, VERB_UPDATE|VERB_CREATE )
  149. VARG_VERB ( eCounters, VERB_UPDATE|VERB_CREATE|VERB_COUNTER )
  150. VARG_VERB ( eCounterFile, VERB_UPDATE|VERB_CREATE|VERB_COUNTER )
  151. VARG_VERB ( eSampleInterval,VERB_UPDATE|VERB_CREATE|VERB_COUNTER )
  152. VARG_VERB ( eLoggerName, VERB_UPDATE|VERB_CREATE|VERB_TRACE )
  153. VARG_VERB ( eRealTime, VERB_UPDATE|VERB_CREATE|VERB_TRACE )
  154. VARG_VERB ( eProviders, VERB_UPDATE|VERB_CREATE|VERB_TRACE )
  155. VARG_VERB ( eProviderFile, VERB_UPDATE|VERB_CREATE|VERB_TRACE )
  156. VARG_VERB ( eUserMode, VERB_UPDATE|VERB_CREATE|VERB_TRACE )
  157. VARG_VERB ( eBufferSize, VERB_UPDATE|VERB_CREATE|VERB_TRACE )
  158. VARG_VERB ( eFlushTimer, VERB_UPDATE|VERB_CREATE|VERB_TRACE )
  159. VARG_VERB ( eBuffers, VERB_UPDATE|VERB_CREATE|VERB_TRACE )
  160. VARG_VERB ( eFlushBuffers, VERB_UPDATE|VERB_CREATE|VERB_TRACE )
  161. VARG_VERB ( eUser, VERB_UPDATE|VERB_CREATE|VERB_TRACE|VERB_COUNTER|VERB_QUERY )
  162. VARG_VERB ( eComputer, VERB_UPDATE|VERB_CREATE|VERB_TRACE|VERB_COUNTER|VERB_QUERY|VERB_START|VERB_STOP|VERB_DELETE )
  163. VARG_VERB ( eRunFor, VERB_UPDATE|VERB_CREATE )
  164. VARG_VERB ( eEts, VERB_UPDATE|VERB_TRACE|VERB_START|VERB_STOP|VERB_QUERY )
  165. VARG_VERB ( eMode, VERB_UPDATE|VERB_CREATE|VERB_TRACE )
  166. VARG_VERB ( eClockType, VERB_CREATE|VERB_TRACE )
  167. VARG_GROUP ( eCounter, VARG_GRPX(GROUP_COUNTER,GROUP_TRACE) )
  168. VARG_GROUP ( eTrace, VARG_GRPX(GROUP_TRACE,GROUP_COUNTER) )
  169. VARG_GROUP ( eStart, VARG_EXCL(GROUP_START) )
  170. VARG_GROUP ( eStop, VARG_EXCL(GROUP_END) )
  171. VARG_GROUP ( eQuery, VARG_COND(GROUP_ARG) )
  172. VARG_GROUP ( eName, VARG_COND(GROUP_ARG) )
  173. VARG_GROUP ( eBegin, VARG_EXCL(GROUP_START) )
  174. VARG_GROUP ( eEnd, VARG_EXCL(GROUP_END) )
  175. VARG_GROUP ( eManual, VARG_EXCL(GROUP_START) )
  176. VARG_GROUP ( eCounters, VARG_GRPX(GROUP_COUNTER,GROUP_TRACE) )
  177. VARG_GROUP ( eCounterFile, VARG_GRPX(GROUP_COUNTER,GROUP_TRACE) )
  178. VARG_GROUP ( eSampleInterval,VARG_GRPX(GROUP_COUNTER,GROUP_TRACE) )
  179. VARG_GROUP ( eLoggerName, VARG_GRPX(GROUP_TRACE,GROUP_COUNTER) )
  180. VARG_GROUP ( eRealTime, VARG_GRPX(GROUP_TRACE,GROUP_COUNTER) )
  181. VARG_GROUP ( eProviders, VARG_GRPX(GROUP_TRACE,GROUP_COUNTER) )
  182. VARG_GROUP ( eProviderFile, VARG_GRPX(GROUP_TRACE,GROUP_COUNTER) )
  183. VARG_GROUP ( eUserMode, VARG_GRPX(GROUP_TRACE,GROUP_COUNTER) )
  184. VARG_GROUP ( eBufferSize, VARG_GRPX(GROUP_TRACE,GROUP_COUNTER) )
  185. VARG_GROUP ( eFlushTimer, VARG_GRPX(GROUP_TRACE,GROUP_COUNTER) )
  186. VARG_GROUP ( eBuffers, VARG_GRPX(GROUP_TRACE,GROUP_COUNTER) )
  187. VARG_GROUP ( eFlushBuffers, VARG_GRPX(GROUP_TRACE,GROUP_COUNTER) )
  188. VARG_GROUP ( eEts, VARG_GRPX(GROUP_TRACE,GROUP_COUNTER) )
  189. VARG_GROUP ( eMode, VARG_GRPX(GROUP_TRACE,GROUP_COUNTER) )
  190. VARG_GROUP ( eClockType, VARG_GRPX(GROUP_TRACE,GROUP_COUNTER) )
  191. VARG_EXHELP( eEts, IDS_EXAMPLE_ETS )
  192. VARG_EXHELP( eCreate, IDS_EXAMPLE_CREATE )
  193. VARG_EXHELP( eStart, IDS_EXAMPLE_START )
  194. VARG_EXHELP( eUpdate, IDS_EXAMPLE_UPDATE )
  195. VARG_DECLARE_END
  196. #define PROVIDER_NAME 0x0001
  197. #define PROVIDER_GUID 0x0002
  198. #define PROVIDER_FLAG 0x0004
  199. #define PROVIDER_LEVEL 0x0008
  200. #define PROVIDER_FLAGSTR 0x0010
  201. #define PROVIDER_LEVELSTR 0x0020
  202. #define PROVIDER_ALLSET 0x003F
  203. typedef struct _PROVIDER_REC {
  204. _PROVIDER_REC* flink;
  205. _PROVIDER_REC* blink;
  206. DWORD dwMask;
  207. LPTSTR strProviderName;
  208. LPTSTR strProviderGuid;
  209. LPTSTR strFlags;
  210. DWORD dwFlags;
  211. LPTSTR strLevel;
  212. DWORD dwLevel;
  213. } PROVIDER_REC, *PPROVIDER_REC;
  214. ULONG hextoi( LPWSTR s );
  215. DWORD SetCredentials();
  216. DWORD GetCountersFromFile( LPTSTR strFile, PPDH_PLA_ITEM pItem );
  217. DWORD GetFileFormat( LPTSTR str, LPDWORD pdwFormat );
  218. DWORD SetPlaInfo( PPDH_PLA_INFO pInfo );
  219. HRESULT WbemConnect( IWbemServices** pWbemServices );
  220. HRESULT GetProviders( PPDH_PLA_ITEM pItem );
  221. HRESULT GetTraceNameToGuidMap( PPROVIDER_REC* pProviders, BOOL bQuery );
  222. HRESULT EventTraceSessionControl();
  223. HRESULT WbemError( HRESULT hr );
  224. PDH_STATUS QueryCollection( LPTSTR strCollection, BOOL bHeader );
  225. PDH_STATUS QuerySingleCollection( LPTSTR strCollection );
  226. HRESULT QueryProviders( );
  227. PDH_STATUS ScheduleLog();
  228. void ShowValidationError( PDH_STATUS pdhStatus, PPDH_PLA_INFO pInfo );
  229. void LogmanError( DWORD dwStatus );
  230. void PdhError( PDH_STATUS pdhStatus, PPDH_PLA_INFO pInfo );
  231. DWORD AdjustPrivilegeForKernel();
  232. void DeleteProviderList( PPROVIDER_REC pProviderHead );
  233. #define CHECK_STATUS( hr ) if( ERROR_SUCCESS != hr ){ goto cleanup; }
  234. #define SEVERITY( s ) ((ULONG)s >> 30)
  235. #define VALUETYPE_INDEX 1
  236. #define VALUETYPE_FLAG 2
  237. #define PDH_MODULE _T("PDH.DLL")
  238. LPCWSTR PRIVATE_GUID = L"{dc945bc4-34e5-4bc4-ab8d-cc4e9de1c2bb}";
  239. TCHAR NT_KERNEL_GUID[48];
  240. TCHAR g_strUser[MAXSTR];
  241. TCHAR g_strPassword[MAXSTR];
  242. TCHAR g_strIPC[MAXSTR];
  243. int __cdecl _tmain( int argc, LPTSTR* argv )
  244. {
  245. HRESULT hr = ERROR_SUCCESS;
  246. PDH_STATUS pdhStatus = ERROR_SUCCESS;
  247. DWORD dwStatus = ERROR_SUCCESS;
  248. PDH_PLA_INFO_W info;
  249. StringFromGUID2( SystemTraceControlGuid, NT_KERNEL_GUID, 48 );
  250. ZeroMemory( &info, sizeof( PDH_PLA_INFO ) );
  251. ParseCmd( argc, argv );
  252. if( ! IsEmpty( Commands[eName].strValue) ){
  253. if( !_tcsicmp( Commands[eName].strValue, KERNEL_LOGGER_NAME ) ){
  254. //
  255. // Logger Name is case sensitive, delete the user input and
  256. // replace it with the correct case name
  257. //
  258. varg_cmdStringAssign( eName, KERNEL_LOGGER_NAME );
  259. if(NULL == Commands[eName].strValue){
  260. PrintError( E_OUTOFMEMORY );
  261. FreeCmd();
  262. exit(ERROR_OUTOFMEMORY);
  263. }
  264. if( Commands[eEts].bDefined && ! Commands[eComputer].bDefined ){
  265. dwStatus = AdjustPrivilegeForKernel();
  266. CHECK_STATUS( dwStatus );
  267. }
  268. }
  269. }
  270. if( Commands[eUser].bDefined && !(Commands[eUser].bNegated) ){
  271. dwStatus = SetCredentials();
  272. }else{
  273. g_strIPC[0] = _T('\0');
  274. }
  275. if( dwStatus != ERROR_SUCCESS ){
  276. dwStatus = LOGMAN_ERROR_LOGON;
  277. goto cleanup;
  278. }
  279. if( Commands[eEts].bValue ){
  280. DWORD dwFormat;
  281. dwStatus = GetFileFormat( Commands[eFormat].strValue, &dwFormat );
  282. CHECK_STATUS( dwStatus );
  283. switch( dwFormat ){
  284. case PLA_BIN_FILE:
  285. case PLA_BIN_CIRC_FILE:
  286. case PLA_CIRC_TRACE_FILE:
  287. case PLA_SEQ_TRACE_FILE:
  288. break;
  289. default:
  290. dwStatus = LOGMAN_ERROR_FILEFORMAT;
  291. }
  292. CHECK_STATUS( dwStatus );
  293. hr = EventTraceSessionControl();
  294. goto cleanup;
  295. }
  296. PLA_VERSION plaVersion;
  297. pdhStatus = PdhiPlaGetVersion( Commands[eComputer].strValue, &plaVersion );
  298. if( ERROR_SUCCESS == pdhStatus ){
  299. if( plaVersion.dwBuild < 2195 ){
  300. pdhStatus = PDH_OS_EARLIER_VERSION;
  301. }
  302. }
  303. CHECK_STATUS(pdhStatus);
  304. if( Commands[eStart].bValue ){
  305. pdhStatus = PdhPlaStart( Commands[eName].strValue, Commands[eComputer].strValue );
  306. CHECK_STATUS(pdhStatus);
  307. }else if( Commands[eStop].bValue ){
  308. pdhStatus = PdhPlaStop( Commands[eName].strValue, Commands[eComputer].strValue );
  309. CHECK_STATUS(pdhStatus);
  310. }else if( Commands[eDelete].bValue ){
  311. pdhStatus = PdhPlaDelete( Commands[eName].strValue, Commands[eComputer].strValue );
  312. CHECK_STATUS(pdhStatus);
  313. }else if( Commands[eCreate].bDefined ){
  314. DWORD dwType = 0;
  315. PDH_STATUS pdhWarning;
  316. if( Commands[eCounter].bDefined ){
  317. dwType = PLA_COUNTER_LOG;
  318. }else if( Commands[eTrace].bDefined ){
  319. dwType = PLA_TRACE_LOG;
  320. }
  321. info.dwMask |= PLA_INFO_FLAG_TYPE;
  322. info.dwType = dwType;
  323. dwStatus = SetPlaInfo( &info );
  324. CHECK_STATUS( dwStatus );
  325. if( Commands[eYes].bValue ){
  326. PdhPlaDeleteW( Commands[eName].strValue, Commands[eComputer].strValue );
  327. }
  328. pdhStatus = PdhPlaCreate( Commands[eName].strValue, Commands[eComputer].strValue, &info );
  329. if( SEVERITY(pdhStatus) == STATUS_SEVERITY_ERROR ){
  330. goto cleanup;
  331. }else{
  332. pdhWarning = pdhStatus;
  333. }
  334. if( Commands[eRunFor].bDefined ||
  335. Commands[eManual].bDefined ){
  336. pdhStatus = ScheduleLog();
  337. if( FAILED( pdhStatus ) ){
  338. PdhPlaDeleteW( Commands[eName].strValue, Commands[eComputer].strValue );
  339. goto cleanup;
  340. }
  341. }
  342. pdhStatus = pdhWarning;
  343. }else if( Commands[eQuery].bDefined ){
  344. if( Commands[eQueryProv].bDefined ){
  345. hr = QueryProviders();
  346. goto cleanup;
  347. }else if( Commands[eName].strValue != NULL ){
  348. pdhStatus = QuerySingleCollection( Commands[eName].strValue );
  349. }else{
  350. DWORD dwSize = 0;
  351. LPTSTR mszCollections = NULL;
  352. pdhStatus = PdhPlaEnumCollections( Commands[eComputer].strValue, &dwSize, mszCollections );
  353. if( ERROR_SUCCESS == pdhStatus || PDH_INSUFFICIENT_BUFFER == pdhStatus ){
  354. mszCollections = (LPTSTR)VARG_ALLOC( dwSize * sizeof(TCHAR) );
  355. if( mszCollections ){
  356. LPTSTR strCollection;
  357. pdhStatus = PdhPlaEnumCollections( Commands[eComputer].strValue, &dwSize, mszCollections );
  358. if( ERROR_SUCCESS == pdhStatus ){
  359. strCollection = mszCollections;
  360. while( strCollection != NULL && *strCollection != _T('\0') ){
  361. QueryCollection( strCollection, (strCollection == mszCollections) );
  362. strCollection += ( _tcslen( strCollection ) + 1 );
  363. }
  364. varg_printf( g_normal, _T("\n") );
  365. }
  366. VARG_FREE( mszCollections );
  367. }else{
  368. dwStatus = ERROR_OUTOFMEMORY;
  369. }
  370. }
  371. }
  372. }else if( Commands[eUpdate].bDefined ){
  373. dwStatus = SetPlaInfo( &info );
  374. CHECK_STATUS( dwStatus );
  375. if( info.dwMask != 0 ){
  376. // Try update without credentials
  377. pdhStatus = PdhPlaSetInfoW( Commands[eName].strValue, Commands[eComputer].strValue, &info );
  378. if( PDH_ACCESS_DENIED == pdhStatus ){
  379. // Try again with credintials
  380. dwStatus = SetCredentials();
  381. CHECK_STATUS( dwStatus );
  382. if( ERROR_SUCCESS == dwStatus ){
  383. info.dwMask |= PLA_INFO_FLAG_USER;
  384. info.strUser = g_strUser;
  385. info.strPassword = g_strPassword;
  386. pdhStatus = PdhPlaSetInfoW( Commands[eName].strValue, Commands[eComputer].strValue, &info );
  387. }
  388. }
  389. CHECK_STATUS( pdhStatus );
  390. }
  391. if( Commands[eRunFor].bDefined ||
  392. Commands[eManual].bDefined ){
  393. pdhStatus = ScheduleLog();
  394. CHECK_STATUS( pdhStatus );
  395. }
  396. }
  397. cleanup:
  398. ZeroMemory( g_strPassword, sizeof(TCHAR)*MAXSTR );
  399. if( Commands[eUser].bDefined ){
  400. //
  401. // AddStringToMsz will zero out the old memory to remove the password
  402. //
  403. varg_cmdStringAddMsz( eUser, _T("-") );
  404. }
  405. if( ERROR_SUCCESS == dwStatus &&
  406. ERROR_SUCCESS == hr &&
  407. ERROR_SUCCESS == pdhStatus ){
  408. PrintMessage( g_normal, IDS_MESSAGE_SUCCESS );
  409. }else{
  410. if( ERROR_SUCCESS != dwStatus ){
  411. LogmanError( dwStatus );
  412. }
  413. if( ERROR_SUCCESS != hr ){
  414. WbemError( hr );
  415. dwStatus = hr;
  416. }
  417. if( ERROR_SUCCESS != pdhStatus ){
  418. PdhError( pdhStatus, &info );
  419. dwStatus = pdhStatus;
  420. }
  421. if( SEVERITY( dwStatus ) == STATUS_SEVERITY_WARNING &&
  422. ERROR_SUCCESS == hr ){
  423. PrintMessage( g_normal, IDS_MESSAGE_SUCCESS );
  424. dwStatus = ERROR_SUCCESS;
  425. }
  426. }
  427. if( info.dwMask & PLA_INFO_FLAG_COUNTERS && Commands[eCounterFile].bDefined ){
  428. VARG_FREE( info.Perf.piCounterList.strCounters );
  429. }
  430. if( info.dwMask & PLA_INFO_FLAG_PROVIDERS ){
  431. VARG_FREE( info.Trace.piProviderList.strProviders );
  432. VARG_FREE( info.Trace.piProviderList.strFlags );
  433. VARG_FREE( info.Trace.piProviderList.strLevels );
  434. }
  435. if( _tcslen( g_strIPC ) ){
  436. dwStatus = NetUseDel( NULL, g_strIPC, USE_LOTS_OF_FORCE /*luke*/ );
  437. }
  438. FreeCmd();
  439. CoUninitialize();
  440. return dwStatus;
  441. }
  442. DWORD
  443. SetPlaInfo( PPDH_PLA_INFO pInfo )
  444. {
  445. DWORD dwStatus = ERROR_SUCCESS;
  446. HRESULT hr;
  447. if( Commands[eCounters].bDefined && Commands[eCounters].strValue != NULL ){
  448. pInfo->dwMask |= PLA_INFO_FLAG_COUNTERS;
  449. pInfo->Perf.piCounterList.dwType = PLA_COUNTER_LOG;
  450. pInfo->Perf.piCounterList.strCounters = Commands[eCounters].strValue;
  451. }else if( Commands[eCounterFile].bDefined ){
  452. pInfo->dwMask |= PLA_INFO_FLAG_COUNTERS;
  453. dwStatus = GetCountersFromFile( Commands[eCounterFile].strValue, &(pInfo->Perf.piCounterList) );
  454. CHECK_STATUS( dwStatus );
  455. }
  456. if( Commands[eProviders].bDefined || Commands[eProviderFile].bDefined ){
  457. pInfo->dwMask |= PLA_INFO_FLAG_PROVIDERS;
  458. dwStatus = GetProviders( &(pInfo->Trace.piProviderList) );
  459. CHECK_STATUS( dwStatus );
  460. pInfo->Trace.piProviderList.dwType = PLA_TRACE_LOG;
  461. }
  462. if( Commands[eFormat].bDefined ){
  463. DWORD dwFormat;
  464. dwStatus = GetFileFormat( Commands[eFormat].strValue, &dwFormat );
  465. CHECK_STATUS( dwStatus );
  466. pInfo->dwMask |= PLA_INFO_FLAG_FORMAT;
  467. pInfo->dwFileFormat = dwFormat;
  468. }
  469. if( Commands[eAppend].bDefined ){
  470. pInfo->dwMask |= PLA_INFO_FLAG_DATASTORE;
  471. if( Commands[eAppend].bNegated ){
  472. pInfo->dwDatastoreAttributes |= PLA_DATASTORE_OVERWRITE;
  473. }else{
  474. pInfo->dwDatastoreAttributes |= PLA_DATASTORE_APPEND;
  475. }
  476. }
  477. if( Commands[eSampleInterval].bDefined ){
  478. pInfo->dwMask |= PLA_INFO_FLAG_INTERVAL;
  479. pInfo->Perf.ptSampleInterval.wDataType = PLA_TT_DTYPE_UNITS;
  480. pInfo->Perf.ptSampleInterval.dwUnitType = PLA_TT_UTYPE_SECONDS;
  481. pInfo->Perf.ptSampleInterval.wTimeType = PLA_TT_TTYPE_SAMPLE;
  482. pInfo->Perf.ptSampleInterval.dwAutoMode = PLA_AUTO_MODE_AFTER;
  483. pInfo->Perf.ptSampleInterval.dwValue = Commands[eSampleInterval].stValue.wSecond;
  484. pInfo->Perf.ptSampleInterval.dwValue += Commands[eSampleInterval].stValue.wMinute * 60;
  485. pInfo->Perf.ptSampleInterval.dwValue += Commands[eSampleInterval].stValue.wHour * 3600;
  486. }
  487. if( Commands[eBufferSize].bDefined ){
  488. pInfo->dwMask |= PLA_INFO_FLAG_BUFFERSIZE;
  489. pInfo->Trace.dwBufferSize = Commands[eBufferSize].nValue;
  490. }
  491. if( Commands[eBuffers].bDefined ){
  492. LPTSTR strMin;
  493. LPTSTR strMax;
  494. strMin = Commands[eBuffers].strValue;
  495. if( NULL != strMin ){
  496. pInfo->dwMask |= PLA_INFO_FLAG_MINBUFFERS;
  497. pInfo->Trace.dwMinimumBuffers = _ttoi( strMin );
  498. strMax = strMin + (_tcslen( strMin )+1);
  499. if( *strMax != _T('\0') ){
  500. pInfo->dwMask |= PLA_INFO_FLAG_MAXBUFFERS;
  501. pInfo->Trace.dwMaximumBuffers = _ttoi( strMax );
  502. }
  503. }
  504. }
  505. if( Commands[eFlushTimer].bDefined ){
  506. DWORD dwSeconds;
  507. dwSeconds = Commands[eFlushTimer].stValue.wSecond;
  508. dwSeconds += Commands[eFlushTimer].stValue.wMinute * 60;
  509. dwSeconds += Commands[eFlushTimer].stValue.wHour * 3600;
  510. pInfo->dwMask |= PLA_INFO_FLAG_FLUSHTIMER;
  511. pInfo->Trace.dwFlushTimer = dwSeconds;
  512. }
  513. if( Commands[eMax].bDefined ){
  514. pInfo->dwMask |= PLA_INFO_FLAG_MAXLOGSIZE;
  515. if( Commands[eMax].bNegated ){
  516. pInfo->dwMaxLogSize = PLA_DISK_MAX_SIZE;
  517. }else{
  518. pInfo->dwMaxLogSize = Commands[eMax].nValue;
  519. }
  520. }
  521. if( Commands[eRunCmd].bDefined ){
  522. pInfo->dwMask |= PLA_INFO_FLAG_RUNCOMMAND;
  523. if( Commands[eRunCmd].bNegated ){
  524. pInfo->strCommandFileName = _T("");
  525. }else{
  526. pInfo->strCommandFileName = Commands[eRunCmd].strValue;
  527. }
  528. }
  529. if( Commands[eOutput].bDefined && NULL != Commands[eOutput].strValue ){
  530. if( ((pInfo->dwMask & PLA_INFO_FLAG_FORMAT) &&
  531. pInfo->dwFileFormat == PLA_SQL_LOG ) ||
  532. !StrCmpNI( Commands[eOutput].strValue, _T("SQL:"), 4 ) ){
  533. pInfo->dwMask |= PLA_INFO_FLAG_SQLNAME;
  534. pInfo->strSqlName = Commands[eOutput].strValue;
  535. }else{
  536. if( IsEmpty( Commands[eOutput].strValue ) ){
  537. pInfo->dwMask |= (PLA_INFO_FLAG_DEFAULTDIR|PLA_INFO_FLAG_FILENAME);
  538. pInfo->strDefaultDir = _T("");
  539. pInfo->strBaseFileName = _T("");
  540. }else{
  541. LPTSTR str = NULL;
  542. TCHAR full[MAXSTR];
  543. TCHAR buffer[MAX_PATH];
  544. TCHAR drive[_MAX_DRIVE];
  545. TCHAR dir[_MAX_DIR];
  546. TCHAR fname[_MAX_FNAME];
  547. TCHAR ext[_MAX_EXT];
  548. DWORD dwFormat;
  549. if( Commands[eComputer].bDefined ){
  550. hr = StringCchCopy( full, MAXSTR, Commands[eOutput].strValue );
  551. }else{
  552. _tfullpath( full, Commands[eOutput].strValue, MAXSTR );
  553. }
  554. _tsplitpath( full, drive, dir, fname, ext );
  555. varg_cmdStringFree( eOutput );
  556. if( _tcslen( drive ) ){
  557. hr = StringCchPrintf( buffer, MAX_PATH, _T("%s%s"), drive, dir );
  558. }else{
  559. hr = StringCchCopy( buffer, MAX_PATH, dir );
  560. }
  561. if( _tcslen( buffer ) ){
  562. pInfo->dwMask |= PLA_INFO_FLAG_DEFAULTDIR;
  563. varg_cmdStringAddMsz( eOutput, buffer );
  564. }
  565. dwStatus = GetFileFormat( ext, &dwFormat );
  566. if( ERROR_SUCCESS == dwStatus ){
  567. hr = StringCchCopy( buffer, MAX_PATH, fname );
  568. }else{
  569. StringCchPrintf( buffer, MAX_PATH, _T("%s%s"), fname, ext );
  570. dwStatus = ERROR_SUCCESS;
  571. }
  572. if( _tcslen( buffer ) ){
  573. pInfo->dwMask |= PLA_INFO_FLAG_FILENAME;
  574. varg_cmdStringAddMsz(eOutput, buffer );
  575. }
  576. str = Commands[eOutput].strValue;
  577. if( str != NULL ){
  578. if( pInfo->dwMask & PLA_INFO_FLAG_DEFAULTDIR ){
  579. pInfo->strDefaultDir = str;
  580. str += ( _tcslen( str ) + 1 );
  581. }
  582. if( pInfo->dwMask & PLA_INFO_FLAG_FILENAME ){
  583. pInfo->strBaseFileName = str;
  584. }
  585. }else{
  586. dwStatus = ERROR_OUTOFMEMORY;
  587. goto cleanup;
  588. }
  589. }
  590. }
  591. }
  592. if( Commands[eVersion].bDefined ){
  593. DWORD dwFormat = 0;
  594. pInfo->dwMask |= PLA_INFO_FLAG_AUTOFORMAT;
  595. if( Commands[eVersion].bNegated ){
  596. dwFormat = PLA_SLF_NAME_NONE;
  597. }else if( !_tcsicmp( Commands[eVersion].strValue, _T("nnnnnn") ) ){
  598. dwFormat = PLA_SLF_NAME_NNNNNN;
  599. }else if( !_tcsicmp( Commands[eVersion].strValue, _T("mmddhhmm") ) ){
  600. dwFormat = PLA_SLF_NAME_MMDDHHMM;
  601. }else{
  602. dwFormat = PLA_SLF_NAME_NNNNNN;
  603. }
  604. pInfo->dwAutoNameFormat = dwFormat;
  605. }
  606. if( Commands[eRealTime].bDefined ){
  607. pInfo->dwMask |= PLA_INFO_FLAG_MODE;
  608. if( Commands[eRealTime].bNegated ){
  609. pInfo->Trace.dwMode &= ~EVENT_TRACE_REAL_TIME_MODE;
  610. }else{
  611. pInfo->Trace.dwMode |= EVENT_TRACE_REAL_TIME_MODE;
  612. }
  613. }
  614. if( Commands[eUserMode].bDefined ){
  615. pInfo->dwMask |= PLA_INFO_FLAG_MODE;
  616. if( Commands[eUserMode].bNegated ){
  617. pInfo->Trace.dwMode &= ~EVENT_TRACE_PRIVATE_LOGGER_MODE;
  618. }else{
  619. pInfo->Trace.dwMode |= EVENT_TRACE_PRIVATE_LOGGER_MODE;
  620. }
  621. }
  622. if( Commands[eLoggerName].bDefined ){
  623. pInfo->dwMask |= PLA_INFO_FLAG_LOGGERNAME;
  624. pInfo->Trace.strLoggerName = Commands[eLoggerName].strValue;
  625. }
  626. if( Commands[eRepeat].bDefined ){
  627. pInfo->dwMask |= PLA_INFO_FLAG_REPEAT;
  628. if( Commands[eRepeat].bNegated ){
  629. pInfo->ptRepeat.dwAutoMode = PLA_AUTO_MODE_NONE;
  630. }else{
  631. pInfo->ptRepeat.wDataType = PLA_TT_DTYPE_UNITS;
  632. pInfo->ptRepeat.wTimeType = PLA_TT_TTYPE_REPEAT_SCHEDULE;
  633. pInfo->ptRepeat.dwUnitType = PLA_TT_UTYPE_DAYSOFWEEK;
  634. pInfo->ptRepeat.dwAutoMode = PLA_AUTO_MODE_CALENDAR;
  635. pInfo->ptRepeat.dwValue = 0x0000007F;
  636. }
  637. }
  638. if( Commands[eNewFile].bDefined ){
  639. pInfo->dwMask |= PLA_INFO_FLAG_CRTNEWFILE;
  640. pInfo->ptCreateNewFile.wTimeType = PLA_TT_TTYPE_CREATENEWFILE;
  641. pInfo->ptCreateNewFile.wDataType = PLA_TT_DTYPE_UNITS;
  642. if( Commands[eNewFile].bNegated ){
  643. pInfo->ptCreateNewFile.dwAutoMode = PLA_AUTO_MODE_NONE;
  644. }else{
  645. DWORD dwSeconds = Commands[eNewFile].stValue.wSecond;
  646. dwSeconds += Commands[eNewFile].stValue.wMinute * 60;
  647. dwSeconds += Commands[eNewFile].stValue.wHour * 3600;
  648. if( dwSeconds == 0 ){
  649. pInfo->ptCreateNewFile.dwAutoMode = PLA_AUTO_MODE_SIZE;
  650. }else{
  651. pInfo->ptCreateNewFile.dwAutoMode = PLA_AUTO_MODE_AFTER;
  652. pInfo->ptCreateNewFile.dwUnitType = PLA_TT_UTYPE_SECONDS;
  653. pInfo->ptCreateNewFile.dwValue = dwSeconds;
  654. }
  655. }
  656. }
  657. if( Commands[eUser].bDefined ){
  658. pInfo->dwMask |= PLA_INFO_FLAG_USER;
  659. if( Commands[eUser].bNegated ){
  660. pInfo->strUser = _T("");
  661. pInfo->strPassword = _T("");
  662. }else{
  663. pInfo->strUser = g_strUser;
  664. pInfo->strPassword = g_strPassword;
  665. }
  666. }
  667. if(Commands[eBegin].bDefined){
  668. FILETIME ft;
  669. if( SystemTimeToFileTime( &Commands[eBegin].stValue, &ft ) ){
  670. pInfo->dwMask |= PLA_INFO_FLAG_BEGIN;
  671. pInfo->ptLogBeginTime.wTimeType = PLA_TT_TTYPE_START;
  672. pInfo->ptLogBeginTime.wDataType = PLA_TT_DTYPE_DATETIME;
  673. pInfo->ptLogBeginTime.dwAutoMode = PLA_AUTO_MODE_AT;
  674. pInfo->ptLogBeginTime.llDateTime = (((ULONGLONG) ft.dwHighDateTime) << 32) + ft.dwLowDateTime;
  675. }
  676. }
  677. if(Commands[eEnd].bDefined){
  678. FILETIME ft;
  679. if( SystemTimeToFileTime( &Commands[eEnd].stValue, &ft ) ){
  680. pInfo->dwMask |= PLA_INFO_FLAG_END;
  681. pInfo->ptLogEndTime.wTimeType = PLA_TT_TTYPE_STOP;
  682. pInfo->ptLogEndTime.wDataType = PLA_TT_DTYPE_DATETIME;
  683. pInfo->ptLogEndTime.dwAutoMode = PLA_AUTO_MODE_AT;
  684. pInfo->ptLogEndTime.llDateTime = (((ULONGLONG) ft.dwHighDateTime) << 32) + ft.dwLowDateTime;
  685. }
  686. }
  687. cleanup:
  688. return dwStatus;
  689. }
  690. DWORD
  691. GetFileFormat( LPTSTR str, LPDWORD pdwFormat )
  692. {
  693. *pdwFormat = PLA_BIN_FILE;
  694. LPTSTR strCmp = str;
  695. if( strCmp != NULL ){
  696. if( *strCmp == _T('.') ){
  697. strCmp++;
  698. }
  699. if( !_tcsicmp( strCmp, _T("TSV")) ){
  700. *pdwFormat = PLA_TSV_FILE;
  701. return ERROR_SUCCESS;
  702. }else if( !_tcsicmp( strCmp, _T("CSV")) ){
  703. *pdwFormat = PLA_CSV_FILE;
  704. return ERROR_SUCCESS;
  705. }else if( !_tcsicmp( strCmp, _T("BLG")) ){
  706. *pdwFormat = PLA_BIN_FILE;
  707. return ERROR_SUCCESS;
  708. }else if( !_tcsicmp( strCmp, _T("BIN")) ){
  709. *pdwFormat = PLA_BIN_FILE;
  710. return ERROR_SUCCESS;
  711. }else if( !_tcsicmp( strCmp, _T("BINCIRC")) ){
  712. *pdwFormat = PLA_BIN_CIRC_FILE;
  713. return ERROR_SUCCESS;
  714. }else if( !_tcsicmp( strCmp, _T("SQL")) ){
  715. *pdwFormat = PLA_SQL_LOG;
  716. return ERROR_SUCCESS;
  717. }
  718. }
  719. return LOGMAN_ERROR_FILEFORMAT;
  720. }
  721. PDH_STATUS
  722. QueryCollection( LPTSTR strCollection, BOOL bHeader )
  723. {
  724. PDH_STATUS pdhStatus;
  725. PDH_PLA_INFO info;
  726. DWORD dwInfoSize = sizeof( PDH_PLA_INFO );
  727. TCHAR strType[256] = _T("");
  728. TCHAR strStatus[256];
  729. TCHAR buffer[MAXSTR];
  730. if( bHeader ){
  731. PrintMessage( g_normal, IDS_MESSAGE_QUERY );
  732. for(int i=0;i<79;i++){ varg_printf( g_normal, _T("-") ); }
  733. varg_printf( g_normal, _T("\n") );
  734. }
  735. info.dwMask = PLA_INFO_FLAG_TYPE|PLA_INFO_FLAG_STATUS;
  736. pdhStatus = PdhPlaGetInfoW( strCollection, Commands[eComputer].strValue, &dwInfoSize, &info );
  737. if( ERROR_SUCCESS == pdhStatus ){
  738. switch( info.dwType ){
  739. case PLA_COUNTER_LOG:
  740. LoadString( NULL, IDS_MESSAGE_PERF, strType, 256 );
  741. break;
  742. case PLA_TRACE_LOG:
  743. LoadString( NULL, IDS_MESSAGE_EVENTTRACE, strType, 256 );
  744. break;
  745. case PLA_ALERT:
  746. LoadString( NULL, IDS_MESSAGE_ALERT, strType, 256 );
  747. break;
  748. default:
  749. LoadString( NULL, IDS_MESSAGE_UNKNOWN, strType, 256 );
  750. }
  751. switch( info.dwStatus ){
  752. case PLA_QUERY_STOPPED:
  753. LoadString( NULL, IDS_MESSAGE_STOPPED, strStatus, 256 );
  754. break;
  755. case PLA_QUERY_RUNNING:
  756. LoadString( NULL, IDS_MESSAGE_RUNNING, strStatus, 256 );
  757. break;
  758. case PLA_QUERY_START_PENDING:
  759. default:
  760. LoadString( NULL, IDS_MESSAGE_PENDING, strStatus, 256 );
  761. break;
  762. }
  763. PrintMessage( g_normal, IDS_MESSAGE_QUERYF, PaddedString( strCollection, buffer, MAXSTR, 39 ), strType, strStatus );
  764. }
  765. return pdhStatus;
  766. }
  767. PDH_STATUS
  768. QuerySingleCollection( LPTSTR strCollection )
  769. {
  770. PDH_STATUS pdhStatus = ERROR_SUCCESS;
  771. PPDH_PLA_INFO pInfo = NULL;
  772. DWORD dwInfoSize = 0;
  773. TCHAR buffer[MAXSTR];
  774. pdhStatus = PdhPlaGetInfoW( strCollection, Commands[eComputer].strValue, &dwInfoSize, pInfo );
  775. if( ERROR_SUCCESS == pdhStatus ){
  776. pInfo = (PPDH_PLA_INFO)VARG_ALLOC(dwInfoSize);
  777. if( NULL != pInfo ){
  778. pInfo->dwMask = PLA_INFO_FLAG_ALL;
  779. pdhStatus = PdhPlaGetInfoW( strCollection, Commands[eComputer].strValue, &dwInfoSize, pInfo );
  780. if( pdhStatus == ERROR_SUCCESS ){
  781. varg_printf( g_normal, _T("\n") );
  782. PrintMessage( g_normal, IDS_MESSAGE_NAME, strCollection );
  783. switch( pInfo->dwType ){
  784. case PLA_COUNTER_LOG:
  785. LoadString( NULL, IDS_MESSAGE_PERF, buffer, MAXSTR );
  786. break;
  787. case PLA_TRACE_LOG:
  788. LoadString( NULL, IDS_MESSAGE_EVENTTRACE, buffer, MAXSTR );
  789. break;
  790. case PLA_ALERT:
  791. LoadString( NULL, IDS_MESSAGE_ALERT, buffer, MAXSTR );
  792. break;
  793. default:
  794. buffer[0] = _T('\0');
  795. }
  796. PrintMessage( g_normal, IDS_MESSAGE_TYPE, buffer );
  797. switch( pInfo->dwStatus ){
  798. case PLA_QUERY_STOPPED:
  799. LoadString( NULL, IDS_MESSAGE_STOPPED, buffer, MAXSTR );
  800. break;
  801. case PLA_QUERY_RUNNING:
  802. LoadString( NULL, IDS_MESSAGE_RUNNING, buffer, MAXSTR );
  803. break;
  804. case PLA_QUERY_START_PENDING:
  805. default:
  806. LoadString( NULL, IDS_MESSAGE_PENDING, buffer, MAXSTR );
  807. break;
  808. }
  809. PrintMessage( g_normal, IDS_MESSAGE_STATUS, buffer );
  810. DWORD dwStart;
  811. DWORD dwStop;
  812. PDH_TIME_INFO TimeInfo;
  813. pdhStatus = PdhPlaGetScheduleW( strCollection, Commands[eComputer].strValue, &dwStart, &dwStop, &TimeInfo );
  814. if( ERROR_SUCCESS == pdhStatus ){
  815. LoadString( NULL, IDS_MESSAGE_MANUAL, buffer, MAXSTR );
  816. PrintMessage( g_normal, IDS_MESSAGE_START );
  817. switch( dwStart ){
  818. case PLA_AUTO_MODE_NONE:
  819. varg_printf( g_normal, buffer );
  820. break;
  821. case PLA_AUTO_MODE_CALENDAR:
  822. case PLA_AUTO_MODE_AT:
  823. {
  824. SYSTEMTIME st;
  825. FILETIME ft;
  826. ft.dwLowDateTime = (DWORD) (TimeInfo.StartTime & 0xFFFFFFFF );
  827. ft.dwHighDateTime = (DWORD) (TimeInfo.StartTime >> 32 );
  828. FileTimeToSystemTime( &ft, &st );
  829. PrintDate( &st );
  830. if( dwStart == PLA_AUTO_MODE_CALENDAR ){
  831. PrintMessage( g_normal, IDS_MESSAGE_REPEATING );
  832. }
  833. }
  834. }
  835. varg_printf( g_normal, _T("\n") );
  836. PrintMessage( g_normal, IDS_MESSAGE_STOP );
  837. switch( dwStop ){
  838. case PLA_AUTO_MODE_NONE:
  839. varg_printf( g_normal, buffer );
  840. break;
  841. case PLA_AUTO_MODE_AT:
  842. {
  843. SYSTEMTIME st;
  844. FILETIME ft;
  845. ft.dwLowDateTime = (DWORD) (TimeInfo.EndTime & 0xFFFFFFFF );
  846. ft.dwHighDateTime = (DWORD) (TimeInfo.EndTime >> 32 );
  847. FileTimeToSystemTime( &ft, &st );
  848. PrintDate( &st );
  849. }
  850. break;
  851. case PLA_AUTO_MODE_AFTER:
  852. {
  853. SYSTEMTIME st;
  854. LONGLONG llMS;
  855. ZeroMemory( &st, sizeof(SYSTEMTIME) );
  856. PlaTimeInfoToMilliSeconds( &pInfo->ptLogEndTime, &llMS );
  857. llMS /= 1000;
  858. st.wHour = (USHORT)(llMS / 3600);
  859. st.wMinute = (USHORT)((llMS%3600) / 60);
  860. st.wSecond = (USHORT)((llMS % 60) % 3600);
  861. PrintMessage( g_normal, IDS_MESSAGE_AFTER );
  862. PrintDate( &st );
  863. }
  864. }
  865. varg_printf( g_normal, _T("\n") );
  866. }
  867. if( pInfo->dwMask & PLA_INFO_FLAG_CRTNEWFILE ){
  868. if( pInfo->ptCreateNewFile.dwAutoMode == PLA_AUTO_MODE_SIZE ){
  869. PrintMessage( g_normal, IDS_MESSAGE_NEWFILE );
  870. PrintMessage( g_normal, IDS_MESSAGE_BYSIZE );
  871. }else if( pInfo->ptCreateNewFile.dwAutoMode == PLA_AUTO_MODE_AFTER ){
  872. SYSTEMTIME st;
  873. LONGLONG llMS;
  874. ZeroMemory( &st, sizeof(SYSTEMTIME) );
  875. PlaTimeInfoToMilliSeconds( &pInfo->ptCreateNewFile, &llMS );
  876. llMS /= 1000;
  877. st.wHour = (USHORT)(llMS / 3600);
  878. st.wMinute = (USHORT)((llMS%3600) / 60);
  879. st.wSecond = (USHORT)((llMS % 60) % 3600);
  880. PrintMessage( g_normal, IDS_MESSAGE_NEWFILE );
  881. PrintMessage( g_normal, IDS_MESSAGE_AFTER );
  882. PrintDate( &st );
  883. varg_printf( g_normal, _T("\n") );
  884. }
  885. }
  886. dwInfoSize = MAXSTR;
  887. pdhStatus = PdhPlaGetLogFileNameW( strCollection, Commands[eComputer].strValue, pInfo, 0, &dwInfoSize, buffer );
  888. if( pdhStatus != ERROR_SUCCESS ){
  889. LoadString( NULL, IDS_MESSAGE_BADPARAM, buffer, MAXSTR );
  890. pdhStatus = ERROR_SUCCESS;
  891. }
  892. PrintMessage( g_normal, IDS_MESSAGE_FILE, buffer );
  893. PrintMessage( g_normal, IDS_MESSAGE_RUNAS, pInfo->strUser ? pInfo->strUser : _T("") );
  894. switch( pInfo->dwType ){
  895. case PLA_COUNTER_LOG:
  896. {
  897. LPTSTR strCounter;
  898. PrintMessage( g_normal, IDS_MESSAGE_COUNTERS );
  899. strCounter = pInfo->Perf.piCounterList.strCounters;
  900. if( NULL != strCounter ){
  901. if( PRIMARYLANGID( GetUserDefaultUILanguage()) == LANG_ENGLISH ){
  902. while( *strCounter != _T('\0') ){
  903. varg_printf( g_normal, _T(" %1!s!\n"), strCounter );
  904. strCounter += (_tcslen(strCounter)+1);
  905. }
  906. }else{
  907. LPTSTR strLocale = NULL;
  908. DWORD dwSize = MAX_PATH;
  909. strLocale = (LPTSTR)VARG_ALLOC(dwSize*sizeof(TCHAR));
  910. if( NULL != strLocale ){
  911. while( *strCounter != _T('\0') ){
  912. pdhStatus = PdhTranslateLocaleCounter( strCounter, strLocale, &dwSize );
  913. if( PDH_MORE_DATA == pdhStatus ){
  914. LPTSTR strMem = (LPTSTR)VARG_REALLOC( strLocale, (dwSize*sizeof(TCHAR)) );
  915. if( NULL != strMem ){
  916. strLocale = strMem;
  917. }else{
  918. pdhStatus = PDH_MEMORY_ALLOCATION_FAILURE;
  919. VARG_FREE(strLocale);
  920. break;
  921. }
  922. }else if( ERROR_SUCCESS == pdhStatus ){
  923. varg_printf( g_normal, _T(" %1!s!\n"), strLocale );
  924. strCounter += (_tcslen(strCounter)+1);
  925. }else{
  926. pdhStatus = ERROR_SUCCESS;
  927. varg_printf( g_normal, _T(" %1!s!\n"), strCounter );
  928. strCounter += (_tcslen(strCounter)+1);
  929. }
  930. }
  931. }else{
  932. pdhStatus = PDH_MEMORY_ALLOCATION_FAILURE;
  933. }
  934. }
  935. }
  936. }
  937. break;
  938. case PLA_TRACE_LOG:
  939. {
  940. LPTSTR strProvider;
  941. PrintMessage( g_normal, IDS_MESSAGE_LOGGERNAME, pInfo->Trace.strLoggerName );
  942. PrintMessage( g_normal, IDS_MESSAGE_BUFFERSIZE, pInfo->Trace.dwBufferSize );
  943. PrintMessage( g_normal, IDS_MESSAGE_PROVIDERS );
  944. strProvider = pInfo->Trace.piProviderList.strProviders;
  945. if( NULL != strProvider ){
  946. while( *strProvider != _T('\0') ){
  947. PrintMessage( g_normal, IDS_MESSAGE_PRVGUID, strProvider );
  948. strProvider += (_tcslen(strProvider)+1);
  949. }
  950. }else{
  951. StringFromGUID2( SystemTraceControlGuid, buffer, 128 );
  952. PrintMessage( g_normal, IDS_MESSAGE_PRVGUID, buffer );
  953. }
  954. }
  955. break;
  956. case PLA_ALERT:
  957. break;
  958. }
  959. }
  960. VARG_FREE( pInfo );
  961. }
  962. }
  963. varg_printf( g_normal, _T("\n") );
  964. return pdhStatus;
  965. }
  966. DWORD
  967. SetCredentials( )
  968. {
  969. DWORD dwStatus = ERROR_SUCCESS;
  970. LPTSTR strUser = NULL;
  971. LPTSTR strPassword = NULL;
  972. TCHAR buffer[MAXSTR];
  973. TCHAR strConnection[MAXSTR];
  974. LoadString( NULL, IDS_MESSAGE_THISCON, strConnection, MAXSTR );
  975. ZeroMemory( g_strUser, MAXSTR*sizeof(TCHAR) );
  976. ZeroMemory( g_strPassword, MAXSTR*sizeof(TCHAR) );
  977. if( Commands[eUser].strValue == NULL || !_tcslen( Commands[eUser].strValue ) ){
  978. LoadString( NULL, IDS_MESSAGE_EUSER, buffer, MAXSTR );
  979. varg_printf( g_normal,
  980. buffer,
  981. Commands[eName].bDefined ?
  982. Commands[eName].strValue :
  983. Commands[eComputer].bDefined ?
  984. Commands[eComputer].strValue :
  985. strConnection
  986. );
  987. GetUserInput( g_strUser, MAXSTR, TRUE );
  988. strUser = g_strUser;
  989. strPassword = _T("*");
  990. }else{
  991. strUser = Commands[eUser].strValue;
  992. strPassword = strUser + (_tcslen( strUser ) + 1);
  993. }
  994. if( NULL == strPassword ){
  995. strPassword = _T("");
  996. }else if( !_tcscmp( _T("*"), strPassword ) ){
  997. LoadString( NULL, IDS_MESSAGE_EPASSWORD, buffer, MAXSTR );
  998. varg_printf( g_normal, buffer,
  999. Commands[eName].bDefined ?
  1000. Commands[eName].strValue :
  1001. Commands[eComputer].bDefined ?
  1002. Commands[eComputer].strValue :
  1003. strConnection
  1004. );
  1005. GetUserInput( buffer, MAXSTR, FALSE );
  1006. strPassword = buffer;
  1007. }
  1008. StringCchCopy( g_strPassword, MAXSTR, strPassword );
  1009. ZeroMemory( buffer, MAXSTR * sizeof(TCHAR) );
  1010. if( strUser != NULL ){
  1011. StringCchCopy( g_strUser, MAXSTR, strUser );
  1012. strUser = g_strUser;
  1013. }
  1014. TCHAR strUserBuffer[MAXSTR];
  1015. StringCchCopy( strUserBuffer, MAXSTR, strUser );
  1016. LPTSTR strDomain = _tcstok( strUserBuffer, _T("\\") );
  1017. strUser = _tcstok( NULL, _T("") );
  1018. if( strUser == NULL ){
  1019. strUser = strDomain;
  1020. strDomain = NULL;
  1021. }
  1022. if( Commands[eComputer].bDefined ){
  1023. if( _tcslen(Commands[eComputer].strValue) > 2 && Commands[eComputer].strValue[1] == _T('\\') ){
  1024. StringCchPrintf( g_strIPC, MAXSTR, _T("%s\\ipc$"), Commands[eComputer].strValue );
  1025. }else{
  1026. StringCchPrintf( g_strIPC, MAXSTR, _T("\\\\%s\\ipc$"), Commands[eComputer].strValue );
  1027. }
  1028. LPTSTR pNetInfo;
  1029. dwStatus = NetUseGetInfo( NULL, g_strIPC, 0, (LPBYTE*)&pNetInfo );
  1030. if( dwStatus != ERROR_SUCCESS ){
  1031. USE_INFO_2 info;
  1032. DWORD dwError;
  1033. ZeroMemory( &info, sizeof(USE_INFO_2) );
  1034. info.ui2_local = NULL;
  1035. info.ui2_remote = g_strIPC;
  1036. info.ui2_password = g_strPassword;
  1037. info.ui2_username = strUser;
  1038. info.ui2_domainname = strDomain;
  1039. info.ui2_asg_type = USE_IPC;
  1040. dwStatus = NetUseAdd (
  1041. NULL,
  1042. 2,
  1043. (unsigned char *)&info,
  1044. &dwError
  1045. );
  1046. }else{
  1047. ZeroMemory( g_strIPC, sizeof(TCHAR) * MAXSTR );
  1048. }
  1049. }
  1050. return dwStatus;
  1051. }
  1052. DWORD GetCountersFromFile( LPTSTR strFile, PPDH_PLA_ITEM pItem )
  1053. {
  1054. TCHAR buffer[MAXSTR];
  1055. LPTSTR strList = NULL;
  1056. LPTSTR strItem = NULL;
  1057. FILE* f = _tfopen( strFile, _T("r") );
  1058. if( !f ){
  1059. return GetLastError();
  1060. }
  1061. pItem->dwType = PLA_COUNTER_LOG;
  1062. pItem->strCounters = NULL;
  1063. while( NULL != _fgetts( buffer, MAXSTR, f ) ){
  1064. if( buffer[0] == _T(';') || // comments
  1065. buffer[0] == _T('#') ){
  1066. continue;
  1067. }
  1068. Chomp(buffer);
  1069. strItem = _tcstok( buffer, _T("\"\n") );
  1070. if( strItem != NULL ){
  1071. AddStringToMsz( &strList, strItem );
  1072. }
  1073. }
  1074. fclose( f );
  1075. pItem->strCounters = strList;
  1076. return ERROR_SUCCESS;
  1077. }
  1078. BOOL IsStrGuid( LPTSTR str ){
  1079. if( _tcslen( str ) < 38 ){
  1080. return FALSE;
  1081. }
  1082. if( str[0] == _T('{') &&
  1083. str[9] == _T('-') &&
  1084. str[14] == _T('-') &&
  1085. str[19] == _T('-') &&
  1086. str[24] == _T('-') &&
  1087. str[37] == _T('}')
  1088. ){
  1089. return TRUE;
  1090. }
  1091. return FALSE;
  1092. }
  1093. HRESULT GetProviders( PPDH_PLA_ITEM pItem )
  1094. {
  1095. HRESULT hr = ERROR_SUCCESS;
  1096. TCHAR buffer[MAXSTR];
  1097. LPTSTR strLine = NULL;
  1098. LPTSTR strItem = NULL;
  1099. LPTSTR strLevel;
  1100. LPTSTR strFlags;
  1101. PPROVIDER_REC pProviderHead = NULL;
  1102. PPROVIDER_REC pProvider;
  1103. FILE* f = NULL;
  1104. if( Commands[eProviderFile].bDefined ){
  1105. f = _tfopen( Commands[eProviderFile].strValue, _T("r") );
  1106. if( !f ){
  1107. return GetLastError();
  1108. }
  1109. strLine = _fgetts( buffer, MAXSTR, f );
  1110. Chomp(buffer);
  1111. }else if( Commands[eProviders].bDefined ){
  1112. strLine = Commands[eProviders].strValue;
  1113. }
  1114. while( NULL != strLine ){
  1115. strItem = NULL;
  1116. strFlags = NULL;
  1117. strLevel = NULL;
  1118. if( Commands[eProviderFile].bDefined ){
  1119. switch( strLine[0] ){
  1120. case _T(';'):
  1121. case _T('#'):
  1122. case _T('*'):
  1123. strLine = _fgetts( buffer, MAXSTR, f );
  1124. Chomp(buffer);
  1125. continue;
  1126. }
  1127. }
  1128. if( Commands[eProviderFile].bDefined ){
  1129. LPTSTR strBegin = _tcsstr( strLine, _T("\"") );
  1130. LPTSTR strEnd;
  1131. if( NULL != strBegin ){
  1132. strBegin++;
  1133. strEnd = strBegin;
  1134. strEnd = _tcsstr( strEnd, _T("\"") );
  1135. strItem = strBegin;
  1136. if( NULL != strEnd ){
  1137. *strEnd = _T('\0');
  1138. strEnd++;
  1139. strFlags = _tcstok( strEnd, _T("\n\t ") );
  1140. strLevel = _tcstok( NULL, _T("\n\t ") );
  1141. }
  1142. }else{
  1143. strItem = _tcstok( buffer, _T("\n\t ") );
  1144. strFlags = _tcstok( NULL, _T("\n\t ") );
  1145. strLevel = _tcstok( NULL, _T("\n\t ") );
  1146. }
  1147. }else if( Commands[eProviders].bDefined ){
  1148. strItem = strLine;
  1149. if( *strItem != _T('\0') ){
  1150. strFlags = strItem + (_tcslen(strItem)+1);
  1151. if( *strFlags != _T('\0') ){
  1152. strLevel = strFlags + (_tcslen(strFlags)+1);
  1153. if( IsEmpty( strLevel ) ){
  1154. strLevel = NULL;
  1155. }
  1156. }else{
  1157. strFlags = NULL;
  1158. }
  1159. }else{
  1160. strItem = NULL;
  1161. }
  1162. }
  1163. if( strItem != NULL ){
  1164. pProvider = (PPROVIDER_REC)VARG_ALLOC( sizeof(PROVIDER_REC) );
  1165. if( NULL != pProvider ){
  1166. ZeroMemory( pProvider, sizeof(PROVIDER_REC) );
  1167. if( pProviderHead == NULL ){
  1168. pProviderHead = pProvider;
  1169. }else{
  1170. pProviderHead->blink = pProvider;
  1171. pProvider->flink = pProviderHead;
  1172. pProviderHead = pProvider;
  1173. }
  1174. if( IsStrGuid( strItem ) ){
  1175. ASSIGN_STRING( pProvider->strProviderGuid, strItem );
  1176. pProvider->dwMask |= PROVIDER_GUID;
  1177. }else{
  1178. ASSIGN_STRING( pProvider->strProviderName, strItem );
  1179. pProvider->dwMask |= PROVIDER_NAME;
  1180. }
  1181. if( strFlags != NULL ){
  1182. ASSIGN_STRING( pProvider->strFlags, strFlags );
  1183. pProvider->dwMask |= PROVIDER_FLAGSTR;
  1184. }else{
  1185. pProvider->dwFlags = 0;
  1186. pProvider->dwMask |= PROVIDER_FLAG;
  1187. }
  1188. if( strLevel != NULL ){
  1189. ASSIGN_STRING( pProvider->strLevel, strLevel );
  1190. pProvider->dwMask |= PROVIDER_LEVELSTR;
  1191. }else{
  1192. pProvider->dwLevel = 0;
  1193. pProvider->dwMask |= PROVIDER_LEVEL;
  1194. }
  1195. }
  1196. }
  1197. if( Commands[eProviderFile].bDefined ){
  1198. strLine = _fgetts( buffer, MAXSTR, f );
  1199. Chomp(buffer);
  1200. }else if( Commands[eProviders].bDefined ){
  1201. break;
  1202. }
  1203. }
  1204. if( NULL != f ){
  1205. fclose( f );
  1206. }
  1207. hr = GetTraceNameToGuidMap( &pProviderHead, FALSE );
  1208. pItem->dwType = PLA_TRACE_LOG;
  1209. pProvider = pProviderHead;
  1210. while( pProvider ){
  1211. if( NULL == pProvider->strProviderGuid ){
  1212. PrintMessage( g_debug, IDS_MESSAGE_WARNING );
  1213. PrintMessage( g_debug, LOGMAN_WARNING_BAD_CODE, pProvider->strProviderName );
  1214. }else{
  1215. hr = AddStringToMsz( &(pItem->strProviders), pProvider->strProviderGuid );
  1216. CHECK_STATUS(hr);
  1217. if( pProvider->dwMask & PROVIDER_LEVEL ){
  1218. StringCchPrintf( buffer, MAXSTR, _T("0x%x"), pProvider->dwLevel );
  1219. hr = AddStringToMsz( &(pItem->strLevels), buffer );
  1220. CHECK_STATUS(hr);
  1221. }else if( pProvider->dwMask & PROVIDER_LEVELSTR ){
  1222. hr = AddStringToMsz( &(pItem->strLevels), pProvider->strLevel );
  1223. CHECK_STATUS(hr);
  1224. }else{
  1225. hr = AddStringToMsz( &(pItem->strLevels), _T("0") );
  1226. CHECK_STATUS(hr);
  1227. }
  1228. if( pProvider->dwMask & PROVIDER_FLAG ){
  1229. StringCchPrintf( buffer, MAXSTR, _T("0x%x"), pProvider->dwFlags );
  1230. hr = AddStringToMsz( &(pItem->strFlags), buffer );
  1231. CHECK_STATUS(hr);
  1232. }else if( pProvider->dwMask & PROVIDER_FLAGSTR ){
  1233. hr = AddStringToMsz( &(pItem->strFlags), pProvider->strFlags );
  1234. CHECK_STATUS(hr);
  1235. }else{
  1236. hr = AddStringToMsz( &(pItem->strFlags), _T("0") );
  1237. CHECK_STATUS(hr);
  1238. }
  1239. }
  1240. pProvider = pProvider->flink;
  1241. }
  1242. cleanup:
  1243. DeleteProviderList( pProviderHead );
  1244. return hr;
  1245. }
  1246. void
  1247. DeleteProviderList( PPROVIDER_REC pProviderHead )
  1248. {
  1249. PPROVIDER_REC pDelete;
  1250. PPROVIDER_REC pProvider = pProviderHead;
  1251. while( pProvider ){
  1252. pDelete = pProvider;
  1253. pProvider = pProvider->flink;
  1254. VARG_FREE( pDelete->strProviderGuid );
  1255. VARG_FREE( pDelete->strProviderName );
  1256. VARG_FREE( pDelete->strFlags );
  1257. VARG_FREE( pDelete->strLevel );
  1258. VARG_FREE( pDelete );
  1259. }
  1260. }
  1261. BOOL
  1262. AllProvidersMapped( PPROVIDER_REC pProviders )
  1263. {
  1264. if( NULL == pProviders ){
  1265. return FALSE;
  1266. }
  1267. PPROVIDER_REC pProvider = pProviders;
  1268. while( pProvider ){
  1269. if( pProvider->dwMask < (PROVIDER_ALLSET) ){
  1270. return FALSE;
  1271. }
  1272. pProvider = pProvider->flink;
  1273. }
  1274. return TRUE;
  1275. }
  1276. HRESULT
  1277. DecodeFlags( IWbemClassObject *pClass, LPTSTR strKey, LPTSTR* pstrValue, LPDWORD pdwValue )
  1278. {
  1279. HRESULT hr = ERROR_SUCCESS;
  1280. IWbemQualifierSet *pQualSet = NULL;
  1281. TCHAR buffer[MAXSTR];
  1282. SAFEARRAY* saValues = NULL;
  1283. SAFEARRAY* saValueMap = NULL;
  1284. LONG nFlavor;
  1285. VARIANT var;
  1286. BOOL bMakeString = FALSE;
  1287. BOOL bQuery = FALSE;
  1288. ULONG nDecoded = 0;
  1289. DWORD dwValueType = VALUETYPE_FLAG;
  1290. if( NULL == pstrValue && NULL == pdwValue ){
  1291. bQuery = TRUE;
  1292. }else if( NULL != pstrValue && NULL == *pstrValue ){
  1293. bMakeString = TRUE;
  1294. StringCchCopy( buffer, MAXSTR, _T("(") );
  1295. }else if( NULL != pstrValue ){
  1296. if( _tcslen( *pstrValue) < MAXSTR ){
  1297. StringCchCopy( buffer, MAXSTR, *pstrValue );
  1298. }else{
  1299. return E_OUTOFMEMORY;
  1300. }
  1301. }else{
  1302. return E_OUTOFMEMORY;
  1303. }
  1304. hr = pClass->GetPropertyQualifierSet( strKey, &pQualSet );
  1305. if( pQualSet != NULL ){
  1306. hr = pQualSet->Get( L"ValueMap", 0, &var, &nFlavor );
  1307. if( ERROR_SUCCESS == hr && (var.vt & VT_ARRAY) ){
  1308. saValueMap = var.parray;
  1309. }
  1310. hr = pQualSet->Get( L"Values", 0, &var, &nFlavor );
  1311. if( ERROR_SUCCESS == hr && (var.vt & VT_ARRAY) ){
  1312. saValues = var.parray;
  1313. }else{
  1314. dwValueType = VALUETYPE_INDEX;
  1315. }
  1316. hr = pQualSet->Get( L"ValueType", 0, &var, &nFlavor );
  1317. if( SUCCEEDED(hr) ){
  1318. if( _wcsicmp( var.bstrVal, L"index" ) == 0 ){
  1319. dwValueType = VALUETYPE_INDEX;
  1320. }
  1321. if( _wcsicmp( var.bstrVal, L"flag") == 0 ){
  1322. dwValueType = VALUETYPE_FLAG;
  1323. }
  1324. }
  1325. if( saValues != NULL ){
  1326. BSTR HUGEP *pMapData;
  1327. BSTR HUGEP *pValuesData;
  1328. LONG uMapBound, lMapBound;
  1329. LONG uValuesBound, lValuesBound;
  1330. if( NULL != saValueMap ){
  1331. SafeArrayGetUBound( saValueMap, 1, &uMapBound );
  1332. SafeArrayGetLBound( saValueMap, 1, &lMapBound );
  1333. SafeArrayAccessData( saValueMap, (void HUGEP **)&pMapData );
  1334. }
  1335. SafeArrayGetUBound( saValues, 1, &uValuesBound );
  1336. SafeArrayGetLBound( saValues, 1, &lValuesBound );
  1337. SafeArrayAccessData( saValues, (void HUGEP **)&pValuesData );
  1338. if( bMakeString ){
  1339. //
  1340. // DWORD => LPTSTR
  1341. //
  1342. for ( LONG i=lValuesBound; i<=uValuesBound; i++) {
  1343. ULONG dwFlag;
  1344. if( NULL == saValueMap ){
  1345. dwFlag = i;
  1346. }else{
  1347. if( i<lMapBound || i>uMapBound ){
  1348. break;
  1349. }
  1350. dwFlag = hextoi( pMapData[i] );
  1351. }
  1352. if( dwValueType == VALUETYPE_FLAG ){
  1353. if( (*pdwValue & dwFlag) == dwFlag ){
  1354. if( nDecoded > 0 ){
  1355. StringCchCat( buffer, MAXSTR, _T(",") );
  1356. }
  1357. StringCchCat( buffer, MAXSTR, pValuesData[i] );
  1358. nDecoded++;
  1359. }
  1360. }else{
  1361. if( *pdwValue == dwFlag ){
  1362. if( _tcslen(pValuesData[i]) + sizeof(TCHAR)*2 < MAXSTR ){
  1363. StringCchCopy( buffer, MAXSTR, pValuesData[i] );
  1364. nDecoded++;
  1365. break;
  1366. }
  1367. }
  1368. }
  1369. }
  1370. }else if(bQuery){
  1371. //
  1372. // Display for query providers X
  1373. //
  1374. SAFEARRAY* saDescription = NULL;
  1375. LONG uDescBound, lDescBound;
  1376. BSTR HUGEP *pDescData;
  1377. LONG i;
  1378. hr = pQualSet->Get( L"ValueDescriptions", 0, &var, NULL );
  1379. if( ERROR_SUCCESS == hr && (var.vt & VT_ARRAY) ){
  1380. saDescription = var.parray;
  1381. if( NULL != saDescription ){
  1382. SafeArrayGetUBound( saDescription, 1, &uDescBound );
  1383. SafeArrayGetLBound( saDescription, 1, &lDescBound );
  1384. SafeArrayAccessData( saDescription, (void HUGEP **)&pDescData );
  1385. }
  1386. }
  1387. PrintMessage( g_normal, IDS_MESSAGE_QUERYFL, strKey );
  1388. for( i=0;i<79;i++){ varg_printf( g_normal, _T("-") ); }
  1389. varg_printf( g_normal, _T("\n") );
  1390. for ( i=lValuesBound; i<=uValuesBound; i++) {
  1391. LPTSTR strMap = _T("");
  1392. LPTSTR strDesc = _T("");
  1393. if( NULL != saValueMap ){
  1394. if( i>=lMapBound && i<=uMapBound ){
  1395. strMap = pMapData[i];
  1396. }
  1397. }
  1398. if( NULL != saDescription ){
  1399. if( i>=lDescBound && i<=uDescBound ){
  1400. strDesc = pDescData[i];
  1401. }
  1402. }
  1403. varg_printf( g_normal, _T("%1!-20s! %2!-18s! %3!s!\n"), pValuesData[i], strMap, strDesc );
  1404. }
  1405. varg_printf( g_normal, _T("\n") );
  1406. if( NULL != saDescription ){
  1407. SafeArrayUnaccessData( saDescription );
  1408. SafeArrayDestroy( saDescription );
  1409. }
  1410. }else{
  1411. //
  1412. // LPTSTR => DWORD
  1413. //
  1414. if( _tcsstr( buffer, _T("(") ) ){
  1415. LPWSTR strFlag = _tcstok( buffer, _T("(,)") );
  1416. while( NULL != strFlag ){
  1417. BOOL bDecoded = FALSE;
  1418. for ( LONG i=lValuesBound; i<=uValuesBound; i++) {
  1419. LONG dwFlag = 0;
  1420. if( NULL == saValueMap ){
  1421. dwFlag = i;
  1422. }else{
  1423. if( i>=lMapBound && i<=uMapBound ){
  1424. dwFlag = hextoi( pMapData[i] );
  1425. }
  1426. }
  1427. if( 0 == _wcsicmp( strFlag, pValuesData[i] ) ){
  1428. if( VALUETYPE_FLAG == dwValueType ){
  1429. *pdwValue |= dwFlag;
  1430. }else{
  1431. *pdwValue = dwFlag;
  1432. }
  1433. nDecoded++;
  1434. bDecoded = TRUE;
  1435. }
  1436. }
  1437. if( ! bDecoded ){
  1438. PrintMessage( g_debug, IDS_MESSAGE_WARNING );
  1439. PrintMessage( g_debug, LOGMAN_WARNING_BAD_CODE, strFlag );
  1440. }
  1441. strFlag = _tcstok( NULL, _T("(,)") );
  1442. }
  1443. }else{
  1444. *pdwValue = hextoi( buffer );
  1445. }
  1446. }
  1447. if( NULL != saValueMap ){
  1448. SafeArrayUnaccessData( saValueMap );
  1449. SafeArrayDestroy( saValueMap );
  1450. }
  1451. SafeArrayUnaccessData( saValues );
  1452. SafeArrayDestroy( saValues );
  1453. }
  1454. pQualSet->Release();
  1455. }
  1456. if( bMakeString ){
  1457. if( 0 == nDecoded ){
  1458. StringCchPrintf( buffer, MAXSTR, _T("0x%x"), *pdwValue );
  1459. }else{
  1460. StringCchCat( buffer, MAXSTR, _T(")") );
  1461. }
  1462. *pstrValue = varg_strdup(buffer);
  1463. }else if( !bQuery ){
  1464. if( 0 == nDecoded ){
  1465. if( NULL != pdwValue ){
  1466. *pdwValue = hextoi( buffer );
  1467. }
  1468. }
  1469. }
  1470. if( (DWORD)hr == WBEM_S_FALSE ){
  1471. hr = ERROR_SUCCESS;
  1472. }
  1473. return hr;
  1474. }
  1475. HRESULT
  1476. SetProviderGuid( PPROVIDER_REC pProvider, IWbemClassObject *pClass, LPTSTR strProvider, LPTSTR strGuid )
  1477. {
  1478. if( NULL != pProvider ){
  1479. if( !(pProvider->dwMask & PROVIDER_NAME ) ){
  1480. pProvider->strProviderName = varg_strdup( strProvider );
  1481. pProvider->dwMask |= PROVIDER_NAME;
  1482. }
  1483. if( !(pProvider->dwMask & PROVIDER_GUID ) ){
  1484. pProvider->strProviderGuid = varg_strdup( strGuid );
  1485. pProvider->dwMask |= PROVIDER_GUID;
  1486. }
  1487. if( !(pProvider->dwMask & PROVIDER_FLAG) ){
  1488. DecodeFlags( pClass, L"Flags", &pProvider->strFlags, &pProvider->dwFlags );
  1489. pProvider->dwMask |= PROVIDER_FLAG;
  1490. }
  1491. if( !(pProvider->dwMask & PROVIDER_FLAGSTR ) ){
  1492. DecodeFlags( pClass, L"Flags", &pProvider->strFlags, &pProvider->dwFlags );
  1493. pProvider->dwMask |= PROVIDER_FLAGSTR;
  1494. }
  1495. if( !(pProvider->dwMask & PROVIDER_LEVEL) ){
  1496. DecodeFlags( pClass, L"Level", &pProvider->strLevel, &pProvider->dwLevel );
  1497. pProvider->dwMask |= PROVIDER_LEVEL;
  1498. }
  1499. if( !(pProvider->dwMask & PROVIDER_LEVELSTR) ){
  1500. DecodeFlags( pClass, L"Level", &pProvider->strLevel, &pProvider->dwLevel );
  1501. pProvider->dwMask |= PROVIDER_LEVELSTR;
  1502. }
  1503. return ERROR_SUCCESS;
  1504. }
  1505. return ERROR_PATH_NOT_FOUND;
  1506. }
  1507. HRESULT
  1508. QuerySingleProvider(IWbemClassObject *pClass, LPTSTR strProvider, LPTSTR strGuid )
  1509. {
  1510. HRESULT hr;
  1511. PrintMessage( g_normal, IDS_MESSAGE_QUERYP );
  1512. for( int i=0;i<79;i++){ varg_printf( g_normal, _T("-") );}
  1513. varg_printf( g_normal, _T("\n") );
  1514. varg_printf( g_normal, _T("%1!-40s! %2!-38s!\n\n"), strProvider, strGuid );
  1515. hr = DecodeFlags( pClass, L"Flags", NULL, NULL );
  1516. hr = DecodeFlags( pClass, L"Level", NULL, NULL );
  1517. return ERROR_SUCCESS;
  1518. }
  1519. HRESULT
  1520. QueryProviders()
  1521. {
  1522. HRESULT hr;
  1523. PPROVIDER_REC pProviderList = NULL;
  1524. PPROVIDER_REC pProvider;
  1525. if( Commands[eName].bDefined ){
  1526. pProvider = (PPROVIDER_REC)VARG_ALLOC( sizeof(PROVIDER_REC) );
  1527. if( NULL != pProvider ){
  1528. ZeroMemory( pProvider, sizeof(PROVIDER_REC) );
  1529. if( IsStrGuid( Commands[eName].strValue ) ){
  1530. pProvider->strProviderGuid = varg_strdup( Commands[eName].strValue );
  1531. pProvider->dwMask |= PROVIDER_GUID;
  1532. }else{
  1533. pProvider->strProviderName = varg_strdup( Commands[eName].strValue );
  1534. pProvider->dwMask |= PROVIDER_NAME;
  1535. }
  1536. }else{
  1537. hr = E_OUTOFMEMORY;
  1538. goto cleanup;
  1539. }
  1540. pProviderList = pProvider;
  1541. hr = GetTraceNameToGuidMap( &pProviderList, TRUE );
  1542. CHECK_STATUS(hr);
  1543. if( (pProviderList->dwMask & (PROVIDER_GUID|PROVIDER_NAME)) != (PROVIDER_GUID|PROVIDER_NAME) ){
  1544. hr = ERROR_WMI_INSTANCE_NOT_FOUND;
  1545. }
  1546. }else{
  1547. TCHAR buffer[MAXSTR];
  1548. hr = GetTraceNameToGuidMap( &pProviderList, FALSE );
  1549. CHECK_STATUS(hr);
  1550. PrintMessage( g_normal, IDS_MESSAGE_QUERYP );
  1551. for( int i=0;i<79;i++){ varg_printf( g_normal, _T("-") );}
  1552. varg_printf( g_normal, _T("\n") );
  1553. pProvider = pProviderList;
  1554. while( NULL != pProvider ){
  1555. varg_printf( g_normal, _T("%1!s! %2!-38s!\n"),
  1556. PaddedString( pProvider->strProviderName, buffer, MAXSTR, 40 ),
  1557. pProvider->strProviderGuid );
  1558. pProvider = pProvider->flink;
  1559. }
  1560. varg_printf( g_normal, _T("\n") );
  1561. }
  1562. cleanup:
  1563. DeleteProviderList( pProviderList );
  1564. return hr;
  1565. }
  1566. PPROVIDER_REC
  1567. FindProvider( PPROVIDER_REC pProviders, LPTSTR strProvider, LPTSTR strGuid )
  1568. {
  1569. PPROVIDER_REC pProvider = pProviders;
  1570. while( pProvider ){
  1571. if( !IsEmpty(pProvider->strProviderGuid) && !IsEmpty(strGuid) ){
  1572. if( !_tcsicmp(pProvider->strProviderGuid, strGuid ) ){
  1573. return pProvider;
  1574. }
  1575. }else if( !IsEmpty(pProvider->strProviderName) && !IsEmpty(strProvider) ){
  1576. if( !_tcsicmp(pProvider->strProviderName, strProvider ) ){
  1577. return pProvider;
  1578. }
  1579. }
  1580. pProvider = pProvider->flink;
  1581. }
  1582. return NULL;
  1583. }
  1584. HRESULT
  1585. GetTraceNameToGuidMap( PPROVIDER_REC* pProviders, BOOL bQuery )
  1586. {
  1587. HRESULT hr;
  1588. IWbemServices* pIWbemServices = NULL;
  1589. IEnumWbemClassObject *pEnumProviders = NULL;
  1590. BOOL bRetrieve = FALSE;
  1591. PPROVIDER_REC pProvider;
  1592. if( pProviders == NULL ){
  1593. return E_FAIL;
  1594. }
  1595. if( NULL == *pProviders ){
  1596. bRetrieve = TRUE;
  1597. }
  1598. if( !bRetrieve && AllProvidersMapped( *pProviders ) ){
  1599. return ERROR_SUCCESS;
  1600. }
  1601. BSTR bszTraceClass = SysAllocString( L"EventTrace" );
  1602. BSTR bszDescription = SysAllocString( L"Description" );
  1603. BSTR bszGuid = SysAllocString( L"Guid" );
  1604. IWbemQualifierSet *pQualSet = NULL;
  1605. IWbemClassObject *pClass = NULL;
  1606. VARIANT vDescription;
  1607. VARIANT vGuid;
  1608. ULONG nReturned;
  1609. hr = WbemConnect( &pIWbemServices );
  1610. CHECK_STATUS( hr );
  1611. hr = pIWbemServices->CreateClassEnum (
  1612. bszTraceClass,
  1613. WBEM_FLAG_SHALLOW|WBEM_FLAG_USE_AMENDED_QUALIFIERS,
  1614. NULL,
  1615. &pEnumProviders
  1616. );
  1617. CHECK_STATUS( hr );
  1618. while( ERROR_SUCCESS == hr ){
  1619. if( !bRetrieve && AllProvidersMapped( *pProviders ) ){
  1620. break;
  1621. }
  1622. hr = pEnumProviders->Next( (-1), 1, &pClass, &nReturned );
  1623. if( ERROR_SUCCESS == hr ){
  1624. pClass->GetQualifierSet ( &pQualSet );
  1625. if ( pQualSet != NULL ) {
  1626. hr = pQualSet->Get ( bszDescription, 0, &vDescription, 0 );
  1627. if( ERROR_SUCCESS == hr ){
  1628. hr = pQualSet->Get ( bszGuid, 0, &vGuid, 0 );
  1629. if( ERROR_SUCCESS == hr ){
  1630. if( bRetrieve ){
  1631. pProvider = (PPROVIDER_REC)VARG_ALLOC( sizeof(PROVIDER_REC) );
  1632. if( NULL != pProvider ){
  1633. ZeroMemory( pProvider, sizeof(PROVIDER_REC) );
  1634. if( *pProviders == NULL ){
  1635. *pProviders = pProvider;
  1636. }else{
  1637. (*pProviders)->blink = pProvider;
  1638. pProvider->flink = (*pProviders);
  1639. (*pProviders) = pProvider;
  1640. }
  1641. }
  1642. }else{
  1643. pProvider = FindProvider( *pProviders, vDescription.bstrVal, vGuid.bstrVal );
  1644. }
  1645. if( NULL != pProvider ){
  1646. SetProviderGuid( pProvider, pClass, vDescription.bstrVal, vGuid.bstrVal );
  1647. if( bQuery ){
  1648. hr = QuerySingleProvider( pClass, vDescription.bstrVal, vGuid.bstrVal );
  1649. CHECK_STATUS( hr );
  1650. hr = (HRESULT)WBEM_S_FALSE;
  1651. }
  1652. }
  1653. }
  1654. }
  1655. }
  1656. }
  1657. }
  1658. if( (DWORD)hr == WBEM_S_FALSE ){
  1659. hr = ERROR_SUCCESS;
  1660. }
  1661. cleanup:
  1662. SysFreeString( bszTraceClass );
  1663. SysFreeString( bszDescription );
  1664. SysFreeString( bszGuid );
  1665. if (pIWbemServices){
  1666. pIWbemServices->Release();
  1667. }
  1668. return hr;
  1669. }
  1670. PDH_STATUS
  1671. ScheduleLog()
  1672. {
  1673. PDH_STATUS pdhStatus = ERROR_SUCCESS;
  1674. PDH_TIME_INFO info;
  1675. if( Commands[eRunFor].bDefined){
  1676. DWORD dwSeconds = Commands[eRunFor].stValue.wSecond;
  1677. ZeroMemory( &info, sizeof(PDH_TIME_INFO) );
  1678. dwSeconds += Commands[eRunFor].stValue.wMinute * 60;
  1679. dwSeconds += Commands[eRunFor].stValue.wHour * 3600;
  1680. info.EndTime = dwSeconds;
  1681. info.SampleCount = PLA_TT_UTYPE_SECONDS;
  1682. pdhStatus = PdhPlaSchedule(
  1683. Commands[eName].strValue,
  1684. Commands[eComputer].strValue,
  1685. PLA_AUTO_MODE_AFTER,
  1686. &info
  1687. );
  1688. }
  1689. if( ERROR_SUCCESS == pdhStatus && Commands[eManual].bDefined ){
  1690. LPTSTR strManual = Commands[eManual].strValue;
  1691. ZeroMemory( &info, sizeof(PDH_TIME_INFO) );
  1692. while( strManual != NULL && *strManual != _T('\0') ){
  1693. if( !_tcsicmp( strManual, _T("start")) ){
  1694. info.StartTime = 1;
  1695. }
  1696. if( !_tcsicmp( strManual,_T("stop")) ){
  1697. info.EndTime = 1;
  1698. }
  1699. strManual += (_tcslen( strManual )+1);
  1700. }
  1701. pdhStatus = PdhPlaSchedule(
  1702. Commands[eName].strValue,
  1703. Commands[eComputer].strValue,
  1704. PLA_AUTO_MODE_NONE,
  1705. &info
  1706. );
  1707. }
  1708. return pdhStatus;
  1709. }
  1710. HRESULT
  1711. WbemConnect( IWbemServices** pWbemServices )
  1712. {
  1713. WCHAR buffer[MAXSTR];
  1714. IWbemLocator *pLocator = NULL;
  1715. BSTR bszNamespace = NULL;
  1716. if( Commands[eComputer].bDefined ){
  1717. StringCchPrintf( buffer, MAXSTR, _T("\\\\%s\\%s"), Commands[eComputer].strValue, L"root\\wmi" );
  1718. bszNamespace = SysAllocString( buffer );
  1719. }else{
  1720. bszNamespace = SysAllocString( L"root\\wmi" );
  1721. }
  1722. HRESULT hr = CoInitialize(0);
  1723. hr = CoCreateInstance(
  1724. CLSID_WbemLocator,
  1725. 0,
  1726. CLSCTX_INPROC_SERVER,
  1727. IID_IWbemLocator,
  1728. (LPVOID *) &pLocator
  1729. );
  1730. CHECK_STATUS( hr );
  1731. if( Commands[eUser].bDefined ){
  1732. BSTR bszUser = SysAllocString( g_strUser );
  1733. BSTR bszPassword = NULL;
  1734. if( IsEmpty( g_strPassword ) ){
  1735. bszPassword = SysAllocString( L"" );
  1736. }else{
  1737. bszPassword = SysAllocString( g_strPassword );
  1738. }
  1739. if( NULL != bszUser && NULL != bszPassword ){
  1740. hr = pLocator->ConnectServer(
  1741. bszNamespace,
  1742. bszUser,
  1743. bszPassword,
  1744. NULL,
  1745. 0L,
  1746. NULL,
  1747. NULL,
  1748. pWbemServices
  1749. );
  1750. ZeroMemory( bszPassword, sizeof(WCHAR) * wcslen( bszPassword ) );
  1751. }else{
  1752. hr = E_OUTOFMEMORY;
  1753. }
  1754. SysFreeString( bszUser );
  1755. SysFreeString( bszPassword );
  1756. }else{
  1757. hr = pLocator->ConnectServer(
  1758. bszNamespace,
  1759. NULL,
  1760. NULL,
  1761. NULL,
  1762. 0L,
  1763. NULL,
  1764. NULL,
  1765. pWbemServices
  1766. );
  1767. }
  1768. CHECK_STATUS( hr );
  1769. hr = CoSetProxyBlanket(
  1770. *pWbemServices,
  1771. RPC_C_AUTHN_WINNT,
  1772. RPC_C_AUTHZ_NONE,
  1773. NULL,
  1774. RPC_C_AUTHN_LEVEL_PKT,
  1775. RPC_C_IMP_LEVEL_IMPERSONATE,
  1776. NULL,
  1777. EOAC_NONE
  1778. );
  1779. cleanup:
  1780. SysFreeString( bszNamespace );
  1781. if( pLocator ){
  1782. pLocator->Release();
  1783. }
  1784. return hr;
  1785. }
  1786. HRESULT
  1787. EtsQuerySession( IWbemServices *pWbemService, LPTSTR strSession )
  1788. {
  1789. HRESULT hr = ERROR_SUCCESS;
  1790. IEnumWbemClassObject* pEnumClass = NULL;
  1791. IWbemClassObject* pClass = NULL;
  1792. IWbemQualifierSet *pQualSet = NULL;
  1793. TCHAR buffer[MAXSTR];
  1794. BOOL bFound;
  1795. BSTR bszClass = SysAllocString( L"TraceLogger" );
  1796. varg_printf( g_normal, _T("\n") );
  1797. if( NULL == strSession ){
  1798. PrintMessage( g_normal, IDS_MESSAGE_ETSQUERY );
  1799. for(int i=0;i<79;i++){ varg_printf( g_normal, _T("-") ); }
  1800. varg_printf( g_normal, _T("\n") );
  1801. }
  1802. hr = pWbemService->CreateInstanceEnum( bszClass, WBEM_FLAG_SHALLOW, NULL, &pEnumClass );
  1803. CHECK_STATUS( hr );
  1804. bFound = (NULL==strSession);
  1805. while ( hr == ERROR_SUCCESS ){
  1806. ULONG nObjects;
  1807. hr = pEnumClass->Next( WBEM_INFINITE, 1, &pClass, &nObjects );
  1808. if( hr == ERROR_SUCCESS ){
  1809. VARIANT vValue;
  1810. CIMTYPE vtType;
  1811. LONG nFlavor;
  1812. pClass->Get( L"Name", 0, &vValue, &vtType, &nFlavor );
  1813. if( NULL == strSession ){
  1814. VARIANT vLogger;
  1815. VARIANT vFile;
  1816. pClass->Get( L"LoggerId", 0, &vLogger, &vtType, &nFlavor );
  1817. pClass->Get( L"LogFileName", 0, &vFile, &vtType, &nFlavor );
  1818. hr = VariantChangeType( &vLogger, &vLogger, 0, VT_BSTR );
  1819. if( ERROR_SUCCESS == hr ){
  1820. PrintMessage( g_normal,
  1821. IDS_MESSAGE_ETSQUERYF,
  1822. PaddedString( vValue.bstrVal, buffer, MAXSTR, 26 ),
  1823. vLogger.bstrVal,
  1824. vFile.bstrVal );
  1825. }
  1826. }else{
  1827. BSTR HUGEP *pData;
  1828. SAFEARRAY* saProperties;
  1829. LONG uBound, lBound;
  1830. if( _tcsicmp( strSession, vValue.bstrVal ) == 0 ){
  1831. LoadString( NULL, IDS_MESSAGE_ETSNAME, buffer, MAXSTR );
  1832. PrintMessage( g_normal, IDS_MESSAGE_ETSQUERYSF, buffer, vValue.bstrVal );
  1833. }else{
  1834. continue;
  1835. }
  1836. bFound = TRUE;
  1837. vValue.boolVal = TRUE;
  1838. vValue.vt = VT_BOOL;
  1839. hr = pClass->GetNames( L"DisplayName", WBEM_FLAG_ONLY_IF_TRUE, 0, &saProperties );
  1840. if( hr == ERROR_SUCCESS && saProperties != NULL ){
  1841. SafeArrayGetUBound( saProperties, 1, &uBound );
  1842. SafeArrayGetLBound( saProperties, 1, &lBound );
  1843. SafeArrayAccessData( saProperties, (void HUGEP **)&pData );
  1844. for( LONG i=lBound;i<=uBound;i++){
  1845. VARIANT vLabel;
  1846. pClass->GetPropertyQualifierSet( pData[i], &pQualSet );
  1847. pQualSet->Get( L"DisplayName", 0, &vLabel, &nFlavor );
  1848. StringCchPrintf( buffer, MAXSTR, _T("%s:"), vLabel.bstrVal );
  1849. pClass->Get( pData[i], 0, &vValue, &vtType, &nFlavor );
  1850. hr = VariantChangeType( &vValue, &vValue, 0, VT_BSTR );
  1851. if( SUCCEEDED(hr) ){
  1852. PrintMessage( g_normal, IDS_MESSAGE_ETSQUERYSF, buffer, vValue.bstrVal );
  1853. }
  1854. VariantClear( &vValue );
  1855. VariantClear( &vLabel );
  1856. }
  1857. SafeArrayUnaccessData( saProperties );
  1858. SafeArrayDestroy( saProperties );
  1859. }
  1860. hr = pClass->Get( L"Guid", 0, &vValue, &vtType, &nFlavor );
  1861. if( ERROR_SUCCESS == hr && VT_NULL != vValue.vt ){
  1862. LONG HUGEP *pFlagData;
  1863. SAFEARRAY* saFlags = NULL;
  1864. LONG uFlagBound, lFlagBound;
  1865. LONG HUGEP *pLevelData;
  1866. SAFEARRAY* saLevels = NULL;
  1867. LONG uLevelBound, lLevelBound;
  1868. saProperties = vValue.parray;
  1869. SafeArrayGetUBound( saProperties, 1, &uBound );
  1870. SafeArrayGetLBound( saProperties, 1, &lBound );
  1871. SafeArrayAccessData( saProperties, (void HUGEP **)&pData );
  1872. hr = pClass->Get( L"EnableFlags", 0, &vValue, NULL, NULL );
  1873. if( ERROR_SUCCESS == hr && VT_NULL != vValue.vt ){
  1874. saFlags = vValue.parray;
  1875. SafeArrayGetUBound( saFlags, 1, &uFlagBound );
  1876. SafeArrayGetLBound( saFlags, 1, &lFlagBound );
  1877. SafeArrayAccessData( saFlags, (void HUGEP **)&pFlagData );
  1878. }
  1879. hr = pClass->Get( L"Level", 0, &vValue, NULL, NULL );
  1880. if( ERROR_SUCCESS == hr && VT_NULL != vValue.vt ){
  1881. saLevels = vValue.parray;
  1882. SafeArrayGetUBound( saLevels, 1, &uLevelBound );
  1883. SafeArrayGetLBound( saLevels, 1, &lLevelBound );
  1884. SafeArrayAccessData( saLevels, (void HUGEP **)&pLevelData );
  1885. }
  1886. PPROVIDER_REC pProviderList = NULL;
  1887. PPROVIDER_REC pProvider;
  1888. for( LONG i=lBound;i<=uBound;i++){
  1889. pProvider = (PPROVIDER_REC)VARG_ALLOC(sizeof(PROVIDER_REC) );
  1890. if( NULL != pProvider ){
  1891. ZeroMemory( pProvider, sizeof(PROVIDER_REC) );
  1892. pProvider->strProviderGuid = varg_strdup( pData[i] );
  1893. pProvider->dwMask |= PROVIDER_GUID;
  1894. if( i >= lFlagBound && i <= uFlagBound ){
  1895. pProvider->dwFlags = pFlagData[i];
  1896. pProvider->dwMask |= PROVIDER_FLAG;
  1897. }
  1898. if( i >= lLevelBound && i <= uLevelBound ){
  1899. pProvider->dwLevel = pLevelData[i];
  1900. pProvider->dwMask |= PROVIDER_LEVEL;
  1901. }
  1902. if( NULL == pProviderList ){
  1903. pProviderList = pProvider;
  1904. }else{
  1905. pProvider->flink = pProviderList;
  1906. pProviderList->blink = pProvider;
  1907. pProviderList = pProvider;
  1908. }
  1909. }
  1910. }
  1911. hr = GetTraceNameToGuidMap( &pProviderList, FALSE );
  1912. if( NULL != pProviderList ){
  1913. varg_printf( g_normal, _T("\n") );
  1914. PrintMessage( g_normal, IDS_MESSAGE_ETSQUERYP );
  1915. for(int i=0;i<79;i++){ varg_printf( g_normal, _T("-") ); }
  1916. varg_printf( g_normal, _T("\n") );
  1917. pProvider = pProviderList;
  1918. while( pProvider ){
  1919. if( (pProvider->dwMask & PROVIDER_NAME) && !IsEmpty(pProvider->strProviderName ) ){
  1920. if( _tcslen( pProvider->strProviderName ) + 3*sizeof(TCHAR) < MAXSTR ){
  1921. LPTSTR strValue;
  1922. StringCchPrintf( buffer, MAXSTR, _T("\"%s\""), pProvider->strProviderName );
  1923. varg_printf( g_normal, _T("* %1!-38s! "), buffer );
  1924. strValue = NULL;
  1925. if( (pProvider->dwMask & PROVIDER_FLAGSTR) &&
  1926. !IsEmpty(pProvider->strFlags ) ){
  1927. if( _tcsstr( pProvider->strFlags, _T("(") ) ){
  1928. strValue = pProvider->strFlags;
  1929. }
  1930. }
  1931. if( NULL == strValue ){
  1932. StringCchPrintf( buffer, MAXSTR, _T("0x%08x"), pProvider->dwFlags );
  1933. strValue = buffer;
  1934. }
  1935. varg_printf( g_normal, _T("%1!-24s! "), strValue );
  1936. strValue = NULL;
  1937. if( (pProvider->dwMask & PROVIDER_LEVELSTR) &&
  1938. !IsEmpty( pProvider->strLevel ) ){
  1939. if( _tcsstr( pProvider->strLevel, _T("(") ) ){
  1940. strValue = pProvider->strLevel;
  1941. }
  1942. }
  1943. if( NULL == strValue ){
  1944. StringCchPrintf( buffer, MAXSTR, _T("0x%02x"), pProvider->dwLevel );
  1945. strValue = buffer;
  1946. }
  1947. varg_printf( g_normal, _T("%1!s!\n"), strValue );
  1948. }
  1949. }
  1950. if( (pProvider->dwMask & PROVIDER_GUID) && !IsEmpty(pProvider->strProviderGuid ) ){
  1951. varg_printf( g_normal, _T(" %1!-38s! 0x%2!08x! 0x%3!02x!\n\n"),
  1952. pProvider->strProviderGuid,
  1953. pProvider->dwFlags,
  1954. pProvider->dwLevel );
  1955. }
  1956. pProvider = pProvider->flink;
  1957. }
  1958. DeleteProviderList( pProviderList );
  1959. }
  1960. }
  1961. }
  1962. }
  1963. }
  1964. if( (DWORD)hr == WBEM_S_FALSE ){
  1965. hr = ERROR_SUCCESS;
  1966. }
  1967. if( SUCCEEDED(hr) && !bFound ){
  1968. hr = ERROR_WMI_INSTANCE_NOT_FOUND;
  1969. }
  1970. if( SUCCEEDED(hr) ){
  1971. varg_printf( g_normal, _T("\n") );
  1972. }
  1973. cleanup:
  1974. SysFreeString( bszClass );
  1975. return hr;
  1976. }
  1977. #define FIRST_MODE( b ) if( !b ){ StringCchCat( buffer, MAXSTR, L"|" );}else{b=FALSE;}
  1978. HRESULT
  1979. EtsSetSession( IWbemServices* pWbemService, IWbemClassObject* pTrace )
  1980. {
  1981. HRESULT hr = ERROR_SUCCESS;
  1982. VARIANT var;
  1983. WCHAR buffer[MAXSTR];
  1984. BOOL bFirst;
  1985. VariantInit( &var );
  1986. if( Commands[eOutput].bDefined ){
  1987. TCHAR full[MAXSTR];
  1988. _tfullpath( full, Commands[eOutput].strValue, MAXSTR );
  1989. var.vt = VT_BSTR;
  1990. var.bstrVal = SysAllocString( full );
  1991. hr = pTrace->Put( L"LogFileName", 0, &var, 0);
  1992. VariantClear(&var);
  1993. CHECK_STATUS( hr );
  1994. }else if( !Commands[eRealTime].bDefined && !Commands[eUpdate].bDefined ){
  1995. TCHAR full[MAXSTR];
  1996. size_t cbPathSize = (_tcslen( Commands[eName].strValue )+6) * sizeof(TCHAR);
  1997. LPTSTR strPath = (LPTSTR)VARG_ALLOC( cbPathSize );
  1998. if( NULL != strPath ){
  1999. StringCbCopy( strPath, cbPathSize, Commands[eName].strValue );
  2000. StringCbCat( strPath, cbPathSize, _T(".etl") );
  2001. _tfullpath( full, strPath, MAXSTR );
  2002. var.vt = VT_BSTR;
  2003. var.bstrVal = SysAllocString( full );
  2004. hr = pTrace->Put( L"LogFileName", 0, &var, 0);
  2005. VariantClear(&var);
  2006. VARG_FREE( strPath );
  2007. CHECK_STATUS( hr );
  2008. }else{
  2009. hr = E_OUTOFMEMORY;
  2010. goto cleanup;
  2011. }
  2012. }else if( Commands[eUpdate].bDefined ){
  2013. var.vt = VT_BSTR;
  2014. var.bstrVal = SysAllocString( L"" );
  2015. hr = pTrace->Put( L"LogFileName", 0, &var, 0);
  2016. VariantClear( &var );
  2017. }
  2018. if( Commands[eClockType].bDefined ){
  2019. var.vt = VT_BSTR;
  2020. var.bstrVal = SysAllocString( Commands[eClockType].strValue );
  2021. hr = pTrace->Put( L"ClockType", 0, &var, 0);
  2022. VariantClear( &var );
  2023. }
  2024. if( Commands[eBufferSize].bDefined ){
  2025. var.vt = VT_I4;
  2026. var.lVal = Commands[eBufferSize].nValue;
  2027. hr = pTrace->Put( L"BufferSize", 0, &var, 0);
  2028. VariantClear(&var);
  2029. CHECK_STATUS( hr );
  2030. }
  2031. if( Commands[eBuffers].bDefined ){
  2032. LPTSTR strMin;
  2033. LPTSTR strMax;
  2034. var.vt = VT_I4;
  2035. strMin = Commands[eBuffers].strValue;
  2036. if( NULL != strMin ){
  2037. var.lVal = _ttoi( strMin );
  2038. hr = pTrace->Put( L"MinimumBuffers", 0, &var, 0);
  2039. CHECK_STATUS( hr );
  2040. strMax = strMin + (_tcslen( strMin )+1);
  2041. if( *strMax != _T('\0') ){
  2042. var.lVal = _ttoi( strMax );
  2043. hr = pTrace->Put( L"MaximumBuffers", 0, &var, 0);
  2044. CHECK_STATUS( hr );
  2045. }
  2046. }
  2047. }
  2048. if( Commands[eMax].bDefined ){
  2049. var.vt = VT_I4;
  2050. var.lVal = Commands[eMax].nValue;
  2051. hr = pTrace->Put( L"MaximumFileSize", 0, &var, 0);
  2052. VariantClear(&var);
  2053. CHECK_STATUS( hr );
  2054. }
  2055. buffer[0] = L'\0';
  2056. var.vt = VT_BSTR;
  2057. bFirst = TRUE;
  2058. if( Commands[eFormat].bDefined || Commands[eAppend].bDefined ){
  2059. DWORD dwFormat = 0;
  2060. hr = GetFileFormat( Commands[eFormat].strValue, &dwFormat );
  2061. switch(dwFormat){
  2062. case PLA_BIN_CIRC_FILE:
  2063. FIRST_MODE( bFirst );
  2064. StringCchCopy( buffer, MAXSTR, L"Circular" );
  2065. break;
  2066. case PLA_BIN_FILE:
  2067. default:
  2068. FIRST_MODE( bFirst );
  2069. StringCchCopy( buffer, MAXSTR, L"Sequential" );
  2070. }
  2071. }
  2072. if( Commands[eAppend].bDefined ){
  2073. FIRST_MODE( bFirst );
  2074. StringCchCat( buffer, MAXSTR, L"Append" );
  2075. }
  2076. if( Commands[eRealTime].bDefined ){
  2077. FIRST_MODE( bFirst );
  2078. StringCchCat( buffer, MAXSTR, L"RealTime" );
  2079. }
  2080. if( Commands[eUserMode].bDefined ){
  2081. FIRST_MODE( bFirst );
  2082. StringCchCat( buffer, MAXSTR, L"Private" );
  2083. }
  2084. if( Commands[eMode].bDefined && Commands[eMode].strValue != NULL ){
  2085. LPTSTR strMode = Commands[eMode].strValue;
  2086. while( *strMode != _T('\0') ){
  2087. if( (wcslen( buffer ) + wcslen( strMode ) + 2) > MAXSTR ){
  2088. break;
  2089. }
  2090. FIRST_MODE( bFirst );
  2091. StringCchCat( buffer, MAXSTR, strMode );
  2092. strMode += (wcslen(strMode)+1);
  2093. }
  2094. }
  2095. var.bstrVal = SysAllocString( buffer );
  2096. hr = pTrace->Put( L"LogFileMode", 0, &var, 0);
  2097. VariantClear( &var );
  2098. CHECK_STATUS( hr );
  2099. if( Commands[eFlushTimer].bDefined ){
  2100. DWORD dwSeconds;
  2101. dwSeconds = Commands[eFlushTimer].stValue.wSecond;
  2102. dwSeconds += Commands[eFlushTimer].stValue.wMinute * 60;
  2103. dwSeconds += Commands[eFlushTimer].stValue.wHour * 3600;
  2104. var.vt = VT_I4;
  2105. var.lVal = dwSeconds;
  2106. hr = pTrace->Put( L"FlushTimer", 0, &var, 0);
  2107. VariantClear(&var);
  2108. CHECK_STATUS( hr );
  2109. }
  2110. if( Commands[eAgeLimit].bDefined ){
  2111. var.vt = VT_I4;
  2112. var.lVal = Commands[eAgeLimit].nValue;
  2113. hr = pTrace->Put( L"AgeLimit", 0, &var, 0);
  2114. VariantClear(&var);
  2115. CHECK_STATUS( hr );
  2116. }
  2117. if( !Commands[eProviders].bDefined && !Commands[eProviderFile].bDefined ){
  2118. if( _tcsicmp( Commands[eName].strValue, KERNEL_LOGGER_NAME ) == 0 ){
  2119. LoadString( NULL, IDS_DEFAULT_ETSENABLE, buffer, MAXSTR );
  2120. Commands[eProviders].bDefined = TRUE;
  2121. varg_cmdStringAssign( eProviders, NT_KERNEL_GUID );
  2122. varg_cmdStringAddMsz( eProviders, buffer );
  2123. }
  2124. }
  2125. if( Commands[eProviders].bDefined || Commands[eProviderFile].bDefined ){
  2126. PDH_PLA_ITEM providers;
  2127. LPTSTR strGuid;
  2128. LPTSTR strLevel;
  2129. LPTSTR strFlags;
  2130. long dwCount = 0;
  2131. ZeroMemory( &providers, sizeof(PDH_PLA_ITEM) );
  2132. hr = GetProviders( &providers );
  2133. CHECK_STATUS( hr );
  2134. strGuid = providers.strProviders;
  2135. strLevel = providers.strLevels;
  2136. strFlags = providers.strFlags;
  2137. if( strGuid != NULL ){
  2138. SAFEARRAY* saGuids;
  2139. SAFEARRAY* saLevel;
  2140. SAFEARRAY* saFlags;
  2141. while( *strGuid != _T('\0') ){
  2142. strGuid += _tcslen( strGuid )+1;
  2143. dwCount++;
  2144. }
  2145. strGuid = providers.strProviders;
  2146. saGuids = SafeArrayCreateVector( VT_BSTR, 0, dwCount );
  2147. saFlags = SafeArrayCreateVector( VT_I4, 0, dwCount );
  2148. saLevel = SafeArrayCreateVector( VT_I4, 0, dwCount );
  2149. if( saGuids == NULL || saFlags == NULL || saLevel == NULL ){
  2150. if( saGuids != NULL ){
  2151. SafeArrayDestroy( saGuids );
  2152. }
  2153. if( saFlags != NULL ){
  2154. SafeArrayDestroy( saFlags );
  2155. }
  2156. if( saLevel != NULL ){
  2157. SafeArrayDestroy( saLevel );
  2158. }
  2159. }else{
  2160. BSTR HUGEP *pGuidData;
  2161. DWORD HUGEP *pLevelData;
  2162. DWORD HUGEP *pFlagData;
  2163. SafeArrayAccessData( saGuids, (void HUGEP **)&pGuidData);
  2164. SafeArrayAccessData( saFlags, (void HUGEP **)&pFlagData);
  2165. SafeArrayAccessData( saLevel, (void HUGEP **)&pLevelData);
  2166. for (long i=dwCount-1; i >=0; i--) {
  2167. if( strGuid != NULL ){
  2168. BSTR bszGuid = SysAllocString( strGuid );
  2169. pGuidData[i] = bszGuid;
  2170. strGuid += _tcslen( strGuid )+1;
  2171. }
  2172. if( strLevel != NULL ){
  2173. pLevelData[i] = hextoi( strLevel );
  2174. strLevel += _tcslen( strLevel )+1;
  2175. }
  2176. if( strFlags != NULL ){
  2177. pFlagData[i] = hextoi( strFlags );
  2178. strFlags += _tcslen( strFlags )+1;
  2179. }
  2180. }
  2181. SafeArrayUnaccessData( saGuids );
  2182. SafeArrayUnaccessData( saFlags );
  2183. SafeArrayUnaccessData( saLevel );
  2184. VARIANT vArray;
  2185. vArray.vt = VT_ARRAY|VT_BSTR;
  2186. vArray.parray = saGuids;
  2187. pTrace->Put( L"Guid", 0, &vArray, 0 );
  2188. vArray.vt = VT_ARRAY|VT_I4;
  2189. vArray.parray = saFlags;
  2190. pTrace->Put( L"EnableFlags", 0, &vArray, 0 );
  2191. vArray.vt = VT_ARRAY|VT_I4;
  2192. vArray.parray = saLevel;
  2193. pTrace->Put( L"Level", 0, &vArray, 0 );
  2194. SafeArrayDestroy( saGuids );
  2195. SafeArrayDestroy( saFlags );
  2196. SafeArrayDestroy( saLevel );
  2197. }
  2198. }
  2199. }
  2200. cleanup:
  2201. return hr;
  2202. }
  2203. HRESULT
  2204. EtsCallSession( IWbemServices *pWbemService, LPWSTR strFunction )
  2205. {
  2206. HRESULT hr;
  2207. WCHAR buffer[MAXSTR];
  2208. IWbemClassObject *pOutInst = NULL;
  2209. BSTR bszFunction = SysAllocString( strFunction );
  2210. BSTR bszNamespace = NULL;
  2211. BSTR bszInstance = NULL;
  2212. if( Commands[eUserMode].bDefined ){
  2213. PDH_PLA_ITEM providers;
  2214. ZeroMemory( &providers, sizeof(PDH_PLA_ITEM) );
  2215. hr = GetProviders( &providers );
  2216. if( ERROR_SUCCESS == hr ){
  2217. hr = StringCchPrintfW( buffer, MAXSTR, L"TraceLogger.Name=\"%s:%s\"", PRIVATE_GUID, providers.strProviders );
  2218. }
  2219. }else{
  2220. hr = StringCchPrintfW( buffer, MAXSTR, L"TraceLogger.Name=\"%s\"", Commands[eName].strValue );
  2221. }
  2222. bszInstance = SysAllocString( buffer );
  2223. hr = pWbemService->ExecMethod( bszInstance, bszFunction, 0, NULL, NULL, &pOutInst, NULL );
  2224. CHECK_STATUS( hr );
  2225. if( pOutInst ){
  2226. VARIANT var;
  2227. VariantInit( &var );
  2228. pOutInst->Get( L"ReturnValue", 0, &var, NULL, NULL );
  2229. hr = var.lVal;
  2230. }
  2231. cleanup:
  2232. SysFreeString( bszInstance );
  2233. SysFreeString( bszFunction );
  2234. if( pOutInst ){
  2235. pOutInst->Release();
  2236. }
  2237. return hr;
  2238. }
  2239. HRESULT
  2240. EtsStartSession(IWbemServices *pWbemService)
  2241. {
  2242. HRESULT hr = ERROR_SUCCESS;
  2243. IWbemClassObject * pClass = NULL;
  2244. IWbemClassObject* pNewTrace = NULL;
  2245. IWbemCallResult *pCallResult = NULL;
  2246. VARIANT var;
  2247. BSTR bszClass = SysAllocString( L"TraceLogger" );
  2248. hr = pWbemService->GetObject( bszClass, 0, NULL, &pClass, NULL);
  2249. CHECK_STATUS( hr );
  2250. hr = pClass->SpawnInstance( 0, &pNewTrace );
  2251. CHECK_STATUS( hr );
  2252. var.vt = VT_BSTR;
  2253. var.bstrVal = SysAllocString( Commands[eName].strValue );
  2254. hr = pNewTrace->Put( L"Name", 0, &var, 0);
  2255. VariantClear(&var);
  2256. hr = EtsSetSession( pWbemService, pNewTrace );
  2257. CHECK_STATUS( hr );
  2258. hr = pWbemService->PutInstance( pNewTrace, WBEM_FLAG_CREATE_ONLY, NULL, &pCallResult );
  2259. CHECK_STATUS( hr );
  2260. if( pCallResult ){
  2261. LONG lResult;
  2262. pCallResult->GetCallStatus( WBEM_INFINITE, &lResult );
  2263. hr = lResult;
  2264. }
  2265. CHECK_STATUS( hr );
  2266. cleanup:
  2267. SysFreeString( bszClass );
  2268. if( pCallResult ){
  2269. pCallResult->Release();
  2270. }
  2271. return hr;
  2272. }
  2273. HRESULT
  2274. EtsEnableSession(IWbemServices *pWbemService)
  2275. {
  2276. HRESULT hr;
  2277. WCHAR buffer[MAXSTR];
  2278. IWbemClassObject *pOutInst = NULL;
  2279. IWbemCallResult *pCallResult = NULL;
  2280. IWbemClassObject *pTrace = NULL;
  2281. BSTR bszNamespace = NULL;
  2282. BSTR bszInstance = NULL;
  2283. StringCchPrintfW( buffer, MAXSTR, L"TraceLogger.Name=\"%s\"", Commands[eName].strValue );
  2284. bszInstance = SysAllocString( buffer );
  2285. hr = pWbemService->GetObject( bszInstance, 0, NULL, &pTrace, NULL);
  2286. CHECK_STATUS( hr );
  2287. hr = EtsSetSession( pWbemService, pTrace );
  2288. CHECK_STATUS( hr );
  2289. hr = pWbemService->PutInstance( pTrace, WBEM_FLAG_UPDATE_ONLY, NULL, &pCallResult );
  2290. CHECK_STATUS( hr );
  2291. if( pCallResult ){
  2292. LONG lResult;
  2293. pCallResult->GetCallStatus( WBEM_INFINITE, &lResult );
  2294. hr = lResult;
  2295. }
  2296. CHECK_STATUS( hr );
  2297. cleanup:
  2298. SysFreeString( bszInstance );
  2299. if( pCallResult ){
  2300. pCallResult->Release();
  2301. }
  2302. if( pOutInst ){
  2303. pOutInst->Release();
  2304. }
  2305. return hr;
  2306. }
  2307. HRESULT EventTraceSessionControl()
  2308. {
  2309. HRESULT hr = ERROR_SUCCESS;
  2310. IWbemServices *pWbemService = NULL;
  2311. hr = WbemConnect( &pWbemService );
  2312. CHECK_STATUS( hr );
  2313. if( Commands[eFlushBuffers].bValue ){
  2314. hr = EtsCallSession( pWbemService, L"FlushTrace" );
  2315. }else if( Commands[eQuery].bDefined ){
  2316. hr = EtsQuerySession( pWbemService, Commands[eName].strValue );
  2317. }else if( Commands[eStart].bDefined || Commands[eCreate].bDefined ){
  2318. hr = EtsStartSession( pWbemService );
  2319. if( SUCCEEDED(hr) ){
  2320. EtsQuerySession( pWbemService, Commands[eName].strValue );
  2321. }
  2322. }else if( Commands[eStop].bDefined || Commands[eDelete].bDefined ){
  2323. hr = EtsCallSession( pWbemService, L"StopTrace" );
  2324. }else if( Commands[eUpdate].bDefined ){
  2325. hr = EtsEnableSession( pWbemService );
  2326. }
  2327. cleanup:
  2328. if( pWbemService ){
  2329. pWbemService->Release();
  2330. }
  2331. return hr;
  2332. }
  2333. HRESULT WbemError( HRESULT hr )
  2334. {
  2335. WCHAR szError[MAXSTR] = { NULL };
  2336. WCHAR szFacility[MAXSTR] = { NULL };
  2337. IWbemStatusCodeText * pStatus = NULL;
  2338. SCODE sc = CoCreateInstance(CLSID_WbemStatusCodeText, 0, CLSCTX_INPROC_SERVER,
  2339. IID_IWbemStatusCodeText, (LPVOID *) &pStatus);
  2340. if(sc == S_OK){
  2341. BSTR bstr = 0;
  2342. sc = pStatus->GetErrorCodeText(hr, 0, 0, &bstr);
  2343. if(sc == S_OK){
  2344. wcsncpy(szError, bstr, MAXSTR-1);
  2345. SysFreeString(bstr);
  2346. bstr = 0;
  2347. }
  2348. sc = pStatus->GetFacilityCodeText(hr, 0, 0, &bstr);
  2349. if(sc == S_OK){
  2350. wcsncpy(szFacility, bstr, MAXSTR-1);
  2351. SysFreeString(bstr);
  2352. bstr = 0;
  2353. }
  2354. pStatus->Release();
  2355. }
  2356. if( Commands[eDebug].bDefined ){
  2357. if( _tcscmp( szFacility, L"<Null>" ) == 0 ){
  2358. LoadString( NULL, IDS_MESSAGE_SYSTEM, szFacility, MAXSTR );
  2359. }
  2360. PrintMessage( g_debug, LOGMAN_ERROR_WBEM, hr, szFacility, szError );
  2361. }else{
  2362. PrintMessage( g_debug, IDS_MESSAGE_ERROR );
  2363. varg_printf( g_debug, _T("%1!s!"), szError );
  2364. }
  2365. return ERROR_SUCCESS;
  2366. }
  2367. void
  2368. ShowValidationError( PDH_STATUS pdhStatus, PPDH_PLA_INFO pInfo )
  2369. {
  2370. DWORD dwFlag;
  2371. DWORD dwMask;
  2372. if( SEVERITY( pdhStatus ) == STATUS_SEVERITY_WARNING ){
  2373. dwMask = pInfo->dwReserved2;
  2374. }else{
  2375. dwMask = pInfo->dwMask;
  2376. }
  2377. if( 0 == dwMask ){
  2378. return;
  2379. }
  2380. for( ULONG i=1;i<0x80000000; i*=2 ){
  2381. dwFlag = (i & dwMask);
  2382. if( 0 == dwFlag ){
  2383. continue;
  2384. }
  2385. switch( SEVERITY( pdhStatus ) ){
  2386. case STATUS_SEVERITY_ERROR:
  2387. PrintMessage( g_debug, IDS_MESSAGE_ERROR );
  2388. break;
  2389. case STATUS_SEVERITY_WARNING:
  2390. PrintMessage( g_debug, IDS_MESSAGE_WARNING );
  2391. break;
  2392. }
  2393. switch( dwFlag ){
  2394. case PLA_INFO_FLAG_FORMAT:
  2395. PrintMessage( g_debug, LOGMAN_ERROR_FILEFORMAT, pInfo->dwFileFormat );
  2396. break;
  2397. case PLA_INFO_FLAG_INTERVAL:
  2398. PrintMessage( g_debug, LOGMAN_ERROR_INTERVAL );
  2399. break;
  2400. case PLA_INFO_FLAG_BUFFERSIZE:
  2401. PrintMessage( g_debug, LOGMAN_ERROR_BUFFERSIZE, pInfo->Trace.dwBufferSize );
  2402. break;
  2403. case PLA_INFO_FLAG_MINBUFFERS:
  2404. PrintMessage( g_debug, LOGMAN_ERROR_MINBUFFER, pInfo->Trace.dwMinimumBuffers );
  2405. break;
  2406. case PLA_INFO_FLAG_MAXBUFFERS:
  2407. PrintMessage( g_debug, LOGMAN_ERROR_MAXBUFFER, pInfo->Trace.dwMinimumBuffers );
  2408. break;
  2409. case PLA_INFO_FLAG_FLUSHTIMER:
  2410. PrintMessage( g_debug, LOGMAN_ERROR_FLUSHTIMER, pInfo->Trace.dwFlushTimer );
  2411. break;
  2412. case PLA_INFO_FLAG_MAXLOGSIZE:
  2413. PrintMessage( g_debug, LOGMAN_ERROR_MAXLOGSIZE, pInfo->dwMaxLogSize );
  2414. break;
  2415. case PLA_INFO_FLAG_RUNCOMMAND:
  2416. PrintMessage( g_debug, LOGMAN_ERROR_CMDFILE, pInfo->strCommandFileName );
  2417. break;
  2418. case PLA_INFO_FLAG_FILENAME:
  2419. if( Commands[eOutput].bDefined ){
  2420. PrintMessage( g_debug, LOGMAN_ERROR_FILENAME );
  2421. }else{
  2422. PrintMessage( g_debug, LOGMAN_ERROR_FILENAME_DEFAULT );
  2423. }
  2424. break;
  2425. case PLA_INFO_FLAG_AUTOFORMAT:
  2426. PrintMessage( g_debug, LOGMAN_ERROR_AUTOFORMAT );
  2427. break;
  2428. case PLA_INFO_FLAG_USER:
  2429. PrintMessage( g_debug, LOGMAN_ERROR_USER, pInfo->strUser );
  2430. break;
  2431. case PLA_INFO_FLAG_DATASTORE:
  2432. switch( pInfo->dwDatastoreAttributes & PLA_DATASTORE_APPEND_MASK ){
  2433. case PLA_DATASTORE_APPEND:
  2434. PrintMessage( g_debug, LOGMAN_ERROR_DATASTOREA );
  2435. break;
  2436. case PLA_DATASTORE_OVERWRITE:
  2437. PrintMessage( g_debug, LOGMAN_ERROR_DATASTOREO );
  2438. break;
  2439. }
  2440. break;
  2441. case PLA_INFO_FLAG_MODE:
  2442. PrintMessage( g_debug, LOGMAN_ERROR_TRACEMODE, pInfo->Trace.dwMode );
  2443. break;
  2444. case PLA_INFO_FLAG_LOGGERNAME:
  2445. PrintMessage( g_debug, LOGMAN_ERROR_LOGGERNAME, pInfo->Trace.strLoggerName );
  2446. break;
  2447. case PLA_INFO_FLAG_REPEAT:
  2448. PrintMessage( g_debug, LOGMAN_ERROR_REPEATMODE );
  2449. break;
  2450. case PLA_INFO_FLAG_TYPE:
  2451. PrintMessage( g_debug, LOGMAN_ERROR_COLLTYPE, pInfo->dwType );
  2452. break;
  2453. case PLA_INFO_FLAG_DEFAULTDIR:
  2454. case PLA_INFO_FLAG_PROVIDERS:
  2455. PrintMessage( g_debug, LOGMAN_ERROR_PROVIDER );
  2456. break;
  2457. case PLA_INFO_FLAG_COUNTERS:
  2458. {
  2459. LPTSTR strCounter = pInfo->Perf.piCounterList.strCounters;
  2460. if( strCounter != NULL ){
  2461. DWORD dwCount = 0;
  2462. while(*strCounter != _T('\0') ){
  2463. if( dwCount++ == pInfo->dwReserved1 ){
  2464. break;
  2465. }
  2466. strCounter += (_tcslen( strCounter )+1 );
  2467. }
  2468. }
  2469. PrintMessage( g_debug, LOGMAN_ERROR_COUNTERPATH, strCounter ? strCounter : _T("") );
  2470. }
  2471. break;
  2472. default:
  2473. PrintMessage( g_debug, LOGMAN_ERROR_UNKNOWN );
  2474. }
  2475. }
  2476. varg_printf( g_debug, _T("\n") );
  2477. }
  2478. void
  2479. PdhError( PDH_STATUS pdhStatus, PPDH_PLA_INFO pInfo )
  2480. {
  2481. switch( pdhStatus ){
  2482. case PDH_PLA_VALIDATION_ERROR:
  2483. case PDH_PLA_VALIDATION_WARNING:
  2484. ShowValidationError( pdhStatus, pInfo );
  2485. break;
  2486. case PDH_PLA_COLLECTION_ALREADY_RUNNING:
  2487. case PDH_PLA_COLLECTION_NOT_FOUND:
  2488. case PDH_PLA_ERROR_NOSTART:
  2489. case PDH_PLA_ERROR_ALREADY_EXISTS:
  2490. PrintErrorEx( pdhStatus, PDH_MODULE, Commands[eName].strValue );
  2491. break;
  2492. case PDH_OS_EARLIER_VERSION:
  2493. {
  2494. const size_t cchSize = 128;
  2495. TCHAR szLogman[cchSize];
  2496. TCHAR szWin2000[cchSize];
  2497. TCHAR szComputer[cchSize];
  2498. if( Commands[eComputer].strValue == NULL ){
  2499. DWORD dwSize = cchSize;
  2500. GetComputerName( szComputer, &dwSize );
  2501. }else{
  2502. StringCchCopy( szComputer, cchSize, Commands[eComputer].strValue );
  2503. }
  2504. LoadString( NULL, IDS_MESSAGE_LOGMAN, szLogman, cchSize );
  2505. LoadString( NULL, IDS_MESSAGE_WIN2000, szWin2000, cchSize );
  2506. PrintErrorEx( pdhStatus, PDH_MODULE, szLogman, szWin2000, szComputer );
  2507. break;
  2508. }
  2509. default:
  2510. PrintErrorEx( pdhStatus, PDH_MODULE );
  2511. }
  2512. }
  2513. void
  2514. LogmanError( DWORD dwStatus )
  2515. {
  2516. switch( dwStatus ){
  2517. case LOGMAN_ERROR_FILEFORMAT:
  2518. PrintMessage( g_debug, IDS_MESSAGE_ERROR );
  2519. PrintMessage( g_debug, LOGMAN_ERROR_FILEFORMAT );
  2520. break;
  2521. case LOGMAN_ERROR_LOGON:
  2522. PrintMessage( g_debug, LOGMAN_ERROR_LOGON );
  2523. break;
  2524. default:
  2525. PrintError( dwStatus );
  2526. }
  2527. }
  2528. ULONG hextoi( LPWSTR s )
  2529. {
  2530. long len;
  2531. ULONG num, base, hex;
  2532. if (s == NULL || s[0] == L'\0') {
  2533. return 0;
  2534. }
  2535. if( wcsstr( s, L"x") || wcsstr( s, L"X" ) ){
  2536. len = (long) wcslen(s);
  2537. if (len == 0) {
  2538. return 0;
  2539. }
  2540. hex = 0;
  2541. base = 1;
  2542. num = 0;
  2543. while (-- len >= 0) {
  2544. if (s[len] >= L'0' && s[len] <= L'9'){
  2545. num = s[len] - L'0';
  2546. }else if (s[len] >= L'a' && s[len] <= L'f'){
  2547. num = (s[len] - L'a') + 10;
  2548. }else if (s[len] >= L'A' && s[len] <= L'F'){
  2549. num = (s[len] - L'A') + 10;
  2550. }else if( s[len] == L'x' || s[len] == L'X'){
  2551. break;
  2552. }else{
  2553. continue;
  2554. }
  2555. hex += num * base;
  2556. base = base * 16;
  2557. }
  2558. }else{
  2559. hex = _ttoi( s );
  2560. }
  2561. return hex;
  2562. }
  2563. #define SE_DEBUG_PRIVILEGE (20L)
  2564. #define SE_SYSTEM_PROFILE_PRIVILEGE (11L)
  2565. DWORD
  2566. AdjustPrivilegeForKernel()
  2567. {
  2568. BOOL bResult = TRUE;
  2569. HANDLE hToken = NULL;
  2570. TOKEN_PRIVILEGES* tkp = NULL;
  2571. tkp = (TOKEN_PRIVILEGES*)VARG_ALLOC(
  2572. sizeof(TOKEN_PRIVILEGES) +
  2573. sizeof(LUID_AND_ATTRIBUTES)
  2574. );
  2575. if( NULL == tkp ){
  2576. goto cleanup;
  2577. }
  2578. bResult = OpenProcessToken(
  2579. GetCurrentProcess(),
  2580. TOKEN_ADJUST_PRIVILEGES,
  2581. &hToken
  2582. );
  2583. if( !bResult ){
  2584. goto cleanup;
  2585. }
  2586. tkp->PrivilegeCount = 2;
  2587. tkp->Privileges[0].Attributes = SE_PRIVILEGE_ENABLED;
  2588. tkp->Privileges[0].Luid.LowPart = SE_DEBUG_PRIVILEGE;
  2589. tkp->Privileges[0].Luid.HighPart = 0;
  2590. tkp->Privileges[1].Attributes = SE_PRIVILEGE_ENABLED;
  2591. tkp->Privileges[1].Luid.LowPart = SE_SYSTEM_PROFILE_PRIVILEGE;
  2592. tkp->Privileges[1].Luid.HighPart = 0;
  2593. bResult = AdjustTokenPrivileges(
  2594. hToken,
  2595. FALSE,
  2596. tkp,
  2597. 0,
  2598. (PTOKEN_PRIVILEGES)NULL,
  2599. NULL
  2600. );
  2601. if( INVALID_HANDLE_VALUE != hToken ){
  2602. CloseHandle( hToken );
  2603. }
  2604. cleanup:
  2605. VARG_FREE(tkp);
  2606. if( !bResult ){
  2607. return GetLastError();
  2608. }
  2609. return ERROR_SUCCESS;
  2610. }