3454 lines
94 KiB
C++
3454 lines
94 KiB
C++
/*++
|
|
|
|
Copyright (C) 1998-1999 Microsoft Corporation
|
|
|
|
Module Name:
|
|
|
|
smlogqry.cpp
|
|
|
|
Abstract:
|
|
|
|
Implementation of the CSmLogQuery base class. This object
|
|
is used to represent performance data log queries (a.k.a.
|
|
sysmon log queries).
|
|
|
|
--*/
|
|
|
|
#include "Stdafx.h"
|
|
#include <pdh.h> // for MIN_TIME_VALUE, MAX_TIME_VALUE
|
|
#include <pdhmsg.h> // for PDH status values
|
|
#include <pdhp.h> // for PLA methods
|
|
#include "ipropbag.h"
|
|
#include "smlogs.h"
|
|
#include "smcfgmsg.h"
|
|
#include "smproppg.h"
|
|
#include "smlogqry.h"
|
|
|
|
USE_HANDLE_MACROS("SMLOGCFG(smlogqry.cpp)");
|
|
|
|
#define DEFAULT_LOG_FILE_SERIAL_NUMBER ((DWORD)0x00000001)
|
|
#define DEFAULT_LOG_FILE_MAX_SIZE ((DWORD)-1)
|
|
#define DEFAULT_CTR_LOG_FILE_TYPE (SLF_BIN_FILE)
|
|
#define DEFAULT_TRACE_LOG_FILE_TYPE (SLF_SEQ_TRACE_FILE)
|
|
#define DEFAULT_LOG_FILE_AUTO_FORMAT SLF_NAME_NNNNNN
|
|
#define DEFAULT_CURRENT_STATE SLQ_QUERY_STOPPED
|
|
#define DEFAULT_EXECUTE_ONLY 0
|
|
#define DEFAULT_EOF_COMMAND_FILE L""
|
|
#define DEFAULT_RESTART_VALUE ((DWORD)0)
|
|
|
|
#define DEFAULT_COMMENT L""
|
|
#define DEFAULT_SQL_LOG_BASE_NAME L""
|
|
|
|
#pragma warning ( disable : 4201)
|
|
|
|
typedef union {
|
|
struct {
|
|
SHORT iMajor;
|
|
SHORT iMinor;
|
|
};
|
|
DWORD dwVersion;
|
|
} SMONCTRL_VERSION_DATA;
|
|
|
|
#pragma warning ( default : 4201 )
|
|
|
|
|
|
#define SMONCTRL_MAJ_VERSION 3
|
|
#define SMONCTRL_MIN_VERSION 3
|
|
|
|
DWORD g_dwRealTimeQuery = DATA_SOURCE_REGISTRY;
|
|
const CString CSmLogQuery::cstrEmpty;
|
|
|
|
//
|
|
// Constructor
|
|
CSmLogQuery::CSmLogQuery( CSmLogService* pLogService )
|
|
: m_pLogService ( pLogService ),
|
|
m_bReadOnly ( FALSE ),
|
|
m_bIsModified ( FALSE ),
|
|
m_bIsNew ( FALSE ),
|
|
m_bExecuteOnly ( FALSE ),
|
|
m_pActivePropPage ( NULL ),
|
|
mr_dwCurrentState ( SLQ_QUERY_STOPPED ),
|
|
mr_dwMaxSize ( 0 ),
|
|
mr_dwFileSizeUnits ( 0 ),
|
|
mr_dwAppendMode ( 0 ),
|
|
mr_dwLogAutoFormat ( 0 ),
|
|
mr_dwLogFileType ( 0 )
|
|
{
|
|
// initialize member variables
|
|
memset (&mr_stiStart, 0, sizeof(mr_stiStart));
|
|
memset (&mr_stiStop, 0, sizeof(mr_stiStop));
|
|
memset (&m_PropData.stiSampleTime, 0, sizeof(m_PropData.stiSampleTime));
|
|
m_PropData.dwMaxFileSize = 0;
|
|
m_PropData.dwLogFileType = 0;
|
|
m_PropData.dwSuffix = 0;
|
|
m_PropData.dwSerialNumber = 0;
|
|
mr_dwRealTimeQuery = g_dwRealTimeQuery;
|
|
m_fDirtyPassword = PASSWORD_CLEAN;
|
|
|
|
// All CString variables are empty on construction
|
|
|
|
return;
|
|
}
|
|
|
|
//
|
|
// Destructor
|
|
CSmLogQuery::~CSmLogQuery()
|
|
{
|
|
// make sure Close method was called first!
|
|
ASSERT ( NULL == m_hKeyQuery );
|
|
ASSERT ( m_strName.IsEmpty() );
|
|
ASSERT ( mr_strComment.IsEmpty() );
|
|
ASSERT ( mr_strCommentIndirect.IsEmpty() );
|
|
ASSERT ( mr_strBaseFileName.IsEmpty() );
|
|
ASSERT ( mr_strBaseFileNameIndirect.IsEmpty() );
|
|
ASSERT ( mr_strSqlName.IsEmpty() );
|
|
ASSERT ( mr_strDefaultDirectory.IsEmpty() );
|
|
return;
|
|
}
|
|
//
|
|
// helper functions
|
|
//
|
|
LONG
|
|
CSmLogQuery::WriteRegistryStringValue (
|
|
HKEY hKey,
|
|
UINT uiValueName,
|
|
DWORD dwType,
|
|
LPCTSTR pszBuffer,
|
|
LPDWORD pdwBufSize
|
|
)
|
|
// writes the contents of pszBuffer to szValue under hKey
|
|
{
|
|
LONG dwStatus = ERROR_SUCCESS;
|
|
DWORD dwLclSize;
|
|
CONST BYTE *pLclBuffer = NULL;
|
|
CString strValueName;
|
|
|
|
ResourceStateManager rsm;
|
|
|
|
if ( NULL != hKey ) {
|
|
|
|
MFC_TRY
|
|
strValueName.LoadString ( uiValueName );
|
|
MFC_CATCH_DWSTATUS;
|
|
|
|
if ( ERROR_SUCCESS == dwStatus ) {
|
|
|
|
ASSERT ((dwType == REG_SZ) ||
|
|
(dwType == REG_MULTI_SZ) ||
|
|
(dwType == REG_EXPAND_SZ));
|
|
|
|
if ( NULL == pszBuffer ) {
|
|
// substitute an empty string
|
|
pLclBuffer = (CONST BYTE *)L"\0";
|
|
dwLclSize = sizeof(WCHAR);
|
|
} else {
|
|
// use args passed in
|
|
pLclBuffer = (CONST BYTE *)pszBuffer;
|
|
|
|
if ( NULL != pdwBufSize ) {
|
|
if( 0 == *pdwBufSize ){
|
|
dwLclSize = lstrlen( pszBuffer );
|
|
if ( 0 < dwLclSize ) {
|
|
dwLclSize *= sizeof(WCHAR);
|
|
} else {
|
|
dwLclSize = sizeof(WCHAR);
|
|
}
|
|
} else {
|
|
dwLclSize = *pdwBufSize;
|
|
}
|
|
} else {
|
|
dwLclSize = lstrlen( pszBuffer );
|
|
dwLclSize *= sizeof(WCHAR);
|
|
}
|
|
}
|
|
|
|
dwStatus = RegSetValueEx (hKey,
|
|
strValueName,
|
|
0L,
|
|
dwType,
|
|
(CONST BYTE *)pLclBuffer,
|
|
dwLclSize);
|
|
}
|
|
} else {
|
|
dwStatus = ERROR_INVALID_PARAMETER;
|
|
}
|
|
|
|
return dwStatus;
|
|
}
|
|
|
|
LONG
|
|
CSmLogQuery::WriteRegistryDwordValue (
|
|
HKEY hKey,
|
|
UINT uiValueName,
|
|
LPDWORD pdwValue,
|
|
DWORD dwType
|
|
)
|
|
{
|
|
LONG dwStatus = ERROR_SUCCESS;
|
|
DWORD dwSize = sizeof(DWORD);
|
|
CString strValueName;
|
|
ResourceStateManager rsm;
|
|
|
|
if ( NULL != pdwValue && NULL != hKey ) {
|
|
|
|
MFC_TRY
|
|
strValueName.LoadString ( uiValueName );
|
|
MFC_CATCH_DWSTATUS;
|
|
|
|
if ( ERROR_SUCCESS == dwStatus ) {
|
|
|
|
ASSERT ((dwType == REG_DWORD) ||
|
|
(dwType == REG_BINARY));
|
|
|
|
dwStatus = RegSetValueEx (
|
|
hKey, strValueName, 0L,
|
|
dwType,
|
|
(CONST BYTE *)pdwValue,
|
|
dwSize);
|
|
}
|
|
} else {
|
|
ASSERT ( FALSE );
|
|
dwStatus = ERROR_INVALID_PARAMETER;
|
|
}
|
|
|
|
return dwStatus;
|
|
}
|
|
|
|
LONG
|
|
CSmLogQuery::WriteRegistrySlqTime (
|
|
HKEY hKey,
|
|
UINT uiValueName,
|
|
PSLQ_TIME_INFO pSlqTime
|
|
)
|
|
{
|
|
LONG dwStatus = ERROR_SUCCESS;
|
|
DWORD dwValue = sizeof(SLQ_TIME_INFO);
|
|
CString strValueName;
|
|
|
|
ResourceStateManager rsm;
|
|
|
|
if ( NULL != pSlqTime && NULL != hKey ) {
|
|
|
|
MFC_TRY
|
|
strValueName.LoadString ( uiValueName );
|
|
MFC_CATCH_DWSTATUS;
|
|
|
|
if ( ERROR_SUCCESS == dwStatus ) {
|
|
|
|
dwStatus = RegSetValueEx (
|
|
hKey, strValueName, 0L,
|
|
REG_BINARY,
|
|
(CONST BYTE *)pSlqTime,
|
|
dwValue);
|
|
}
|
|
} else {
|
|
ASSERT ( FALSE );
|
|
dwStatus = ERROR_INVALID_PARAMETER;
|
|
}
|
|
|
|
return dwStatus;
|
|
}
|
|
|
|
|
|
LONG
|
|
CSmLogQuery::ReadRegistryStringValue (
|
|
HKEY hKey,
|
|
UINT uiValueName,
|
|
LPCTSTR szDefault,
|
|
LPTSTR *pszBuffer,
|
|
LPDWORD pdwBufferSize
|
|
)
|
|
//
|
|
// reads the string value from key (name based on resource
|
|
// uiValueName) under hKey and
|
|
// frees any existing buffer referenced by szInBuffer,
|
|
// then allocates a new buffer returning it with the
|
|
// string value read from the registry and the size of the
|
|
// buffer (in bytes)
|
|
//
|
|
{
|
|
DWORD dwStatus = ERROR_SUCCESS;
|
|
DWORD dwType = 0;
|
|
DWORD dwBufferSize = 0;
|
|
TCHAR* szNewStringBuffer = NULL;
|
|
CString strValueName;
|
|
|
|
ResourceStateManager rsm;
|
|
|
|
if ( NULL != hKey ) {
|
|
|
|
MFC_TRY
|
|
strValueName.LoadString ( uiValueName );
|
|
MFC_CATCH_DWSTATUS;
|
|
|
|
ASSERT (!strValueName.IsEmpty());
|
|
|
|
if ( ERROR_SUCCESS == dwStatus && hKey != NULL) {
|
|
// then there should be something to read
|
|
// find out the size of the required buffer
|
|
dwStatus = RegQueryValueExW (
|
|
hKey,
|
|
strValueName,
|
|
NULL,
|
|
&dwType,
|
|
NULL,
|
|
&dwBufferSize);
|
|
if (dwStatus == ERROR_SUCCESS) {
|
|
// NULL character size is 2 bytes
|
|
if (dwBufferSize > 2) {
|
|
// then there's something to read
|
|
MFC_TRY
|
|
szNewStringBuffer = new TCHAR[dwBufferSize/sizeof(TCHAR)];
|
|
dwType = 0;
|
|
dwStatus = RegQueryValueExW (
|
|
hKey,
|
|
strValueName,
|
|
NULL,
|
|
&dwType,
|
|
(LPBYTE)szNewStringBuffer,
|
|
&dwBufferSize);
|
|
MFC_CATCH_DWSTATUS
|
|
} else {
|
|
// nothing to read
|
|
dwStatus = ERROR_NO_DATA;
|
|
}
|
|
} else {
|
|
// unable to read buffer
|
|
// dwStatus has error
|
|
}
|
|
} else {
|
|
// null key
|
|
dwStatus = ERROR_BADKEY;
|
|
}
|
|
|
|
if (dwStatus != ERROR_SUCCESS) {
|
|
if (szNewStringBuffer != NULL) {
|
|
delete (szNewStringBuffer);
|
|
szNewStringBuffer = NULL;
|
|
}
|
|
// apply default
|
|
if (szDefault != NULL) {
|
|
dwBufferSize = lstrlen(szDefault) + 1;
|
|
dwBufferSize *= sizeof (TCHAR);
|
|
MFC_TRY
|
|
szNewStringBuffer = new TCHAR[dwBufferSize];
|
|
lstrcpy (
|
|
szNewStringBuffer,
|
|
szDefault);
|
|
dwStatus = ERROR_SUCCESS;
|
|
MFC_CATCH_DWSTATUS
|
|
} else {
|
|
// no default so no data returned
|
|
}
|
|
}
|
|
|
|
if (dwStatus == ERROR_SUCCESS) {
|
|
// then delete the old buffer and replace it with
|
|
// the new one
|
|
if ( NULL != *pszBuffer ) {
|
|
delete (*pszBuffer );
|
|
}
|
|
*pszBuffer = szNewStringBuffer;
|
|
if ( NULL != pdwBufferSize ) {
|
|
*pdwBufferSize = dwBufferSize;
|
|
}
|
|
} else {
|
|
// if error then delete the buffer
|
|
if (szNewStringBuffer != NULL) {
|
|
delete (szNewStringBuffer);
|
|
}
|
|
}
|
|
} else {
|
|
ASSERT ( FALSE );
|
|
dwStatus = ERROR_INVALID_PARAMETER;
|
|
}
|
|
|
|
return dwStatus;
|
|
}
|
|
|
|
LONG
|
|
CSmLogQuery::ReadRegistrySlqTime (
|
|
HKEY hKey,
|
|
UINT uiValueName,
|
|
PSLQ_TIME_INFO pstiDefault,
|
|
PSLQ_TIME_INFO pSlqValue
|
|
)
|
|
//
|
|
// reads the time value "szValueName" from under hKey and
|
|
// returns it in the Value buffer
|
|
//
|
|
{
|
|
DWORD dwStatus = ERROR_SUCCESS;
|
|
DWORD dwType = 0;
|
|
DWORD dwBufferSize = 0;
|
|
|
|
SLQ_TIME_INFO slqLocal;
|
|
CString strValueName;
|
|
|
|
ResourceStateManager rsm;
|
|
|
|
if ( NULL != pSlqValue && NULL != hKey ) {
|
|
|
|
MFC_TRY
|
|
strValueName.LoadString ( uiValueName );
|
|
MFC_CATCH_DWSTATUS;
|
|
|
|
ASSERT (!strValueName.IsEmpty());
|
|
|
|
if ( ERROR_SUCCESS == dwStatus ) {
|
|
|
|
memset (&slqLocal, 0, sizeof(SLQ_TIME_INFO));
|
|
|
|
if (hKey != NULL) {
|
|
// then there should be something to read
|
|
// find out the size of the required buffer
|
|
dwStatus = RegQueryValueExW (
|
|
hKey,
|
|
strValueName,
|
|
NULL,
|
|
&dwType,
|
|
NULL,
|
|
&dwBufferSize);
|
|
if (dwStatus == ERROR_SUCCESS) {
|
|
if ((dwBufferSize == sizeof(SLQ_TIME_INFO)) && (dwType == REG_BINARY)) {
|
|
// then there's something to read
|
|
dwType = 0;
|
|
dwStatus = RegQueryValueExW (
|
|
hKey,
|
|
strValueName,
|
|
NULL,
|
|
&dwType,
|
|
(LPBYTE)&slqLocal,
|
|
&dwBufferSize);
|
|
} else {
|
|
// nothing to read
|
|
dwStatus = ERROR_NO_DATA;
|
|
}
|
|
} else {
|
|
// unable to read buffer
|
|
// dwStatus has error
|
|
}
|
|
} else {
|
|
// null key
|
|
dwStatus = ERROR_BADKEY;
|
|
}
|
|
|
|
if (dwStatus == ERROR_SUCCESS) {
|
|
*pSlqValue = slqLocal;
|
|
} else {
|
|
// apply default if it exists
|
|
if (pstiDefault != NULL) {
|
|
*pSlqValue = *pstiDefault;
|
|
dwStatus = ERROR_SUCCESS;
|
|
}
|
|
}
|
|
}
|
|
} else {
|
|
ASSERT ( FALSE );
|
|
dwStatus = ERROR_INVALID_PARAMETER;
|
|
}
|
|
|
|
return dwStatus;
|
|
}
|
|
|
|
LONG
|
|
CSmLogQuery::ReadRegistryDwordValue (
|
|
HKEY hKey,
|
|
UINT uiValueName,
|
|
DWORD dwDefault,
|
|
LPDWORD pdwValue
|
|
)
|
|
//
|
|
// reads the DWORD value "szValueName" from under hKey and
|
|
// returns it in the Value buffer
|
|
//
|
|
{
|
|
DWORD dwStatus = ERROR_SUCCESS;
|
|
DWORD dwType = 0;
|
|
DWORD dwBufferSize = 0;
|
|
DWORD dwRegValue = 0;
|
|
CString strValueName;
|
|
|
|
ResourceStateManager rsm;
|
|
|
|
if ( NULL != pdwValue && NULL != hKey ) {
|
|
|
|
MFC_TRY
|
|
strValueName.LoadString ( uiValueName );
|
|
MFC_CATCH_DWSTATUS;
|
|
|
|
ASSERT (!strValueName.IsEmpty());
|
|
|
|
if ( ERROR_SUCCESS == dwStatus ) {
|
|
if (hKey != NULL) {
|
|
// then there should be something to read
|
|
// find out the size of the required buffer
|
|
dwStatus = RegQueryValueExW (
|
|
hKey,
|
|
strValueName,
|
|
NULL,
|
|
&dwType,
|
|
NULL,
|
|
&dwBufferSize);
|
|
if (dwStatus == ERROR_SUCCESS) {
|
|
if ( (dwBufferSize == sizeof(DWORD))
|
|
&& ( (REG_DWORD == dwType) || ( REG_BINARY == dwType) ) ) {
|
|
// then there's something to read
|
|
dwType = 0;
|
|
dwStatus = RegQueryValueExW (
|
|
hKey,
|
|
strValueName,
|
|
NULL,
|
|
&dwType,
|
|
(LPBYTE)&dwRegValue,
|
|
&dwBufferSize);
|
|
} else {
|
|
// nothing to read
|
|
dwStatus = ERROR_NO_DATA;
|
|
}
|
|
} else {
|
|
// unable to read buffer
|
|
// dwStatus has error
|
|
}
|
|
} else {
|
|
// null key
|
|
dwStatus = ERROR_BADKEY;
|
|
}
|
|
|
|
if (dwStatus == ERROR_SUCCESS) {
|
|
*pdwValue = dwRegValue;
|
|
} else {
|
|
*pdwValue = dwDefault;
|
|
dwStatus = ERROR_SUCCESS;
|
|
}
|
|
}
|
|
} else {
|
|
ASSERT ( FALSE );
|
|
dwStatus = ERROR_INVALID_PARAMETER;
|
|
}
|
|
|
|
return dwStatus;
|
|
}
|
|
|
|
|
|
HRESULT
|
|
CSmLogQuery::StringToPropertyBag (
|
|
IPropertyBag* pPropBag,
|
|
UINT uiPropName,
|
|
const CString& rstrData )
|
|
{
|
|
HRESULT hr = NOERROR;
|
|
CString strPropName;
|
|
|
|
ResourceStateManager rsm;
|
|
|
|
MFC_TRY
|
|
strPropName.LoadString ( uiPropName );
|
|
hr = StringToPropertyBag ( pPropBag, strPropName, rstrData );
|
|
MFC_CATCH_HR
|
|
|
|
return hr;
|
|
}
|
|
|
|
typedef struct _HTML_ENTITIES {
|
|
LPTSTR szHTML;
|
|
LPTSTR szEntity;
|
|
} HTML_ENTITIES;
|
|
|
|
HTML_ENTITIES g_htmlentities[] = {
|
|
_T("&"), _T("&"),
|
|
_T("\""), _T("""),
|
|
_T("<"), _T("<"),
|
|
_T(">"), _T(">"),
|
|
NULL, NULL
|
|
};
|
|
|
|
HRESULT
|
|
CSmLogQuery::StringToPropertyBag (
|
|
IPropertyBag* pIPropBag,
|
|
const CString& rstrPropName,
|
|
const CString& rstrData )
|
|
{
|
|
VARIANT vValue;
|
|
HRESULT hr = NOERROR;
|
|
LPTSTR szTrans = NULL;
|
|
BOOL bAllocated = FALSE;
|
|
int i;
|
|
ULONG lSize = 0;
|
|
LPTSTR szScan = NULL;
|
|
|
|
|
|
if ( NULL != pIPropBag ) {
|
|
VariantInit( &vValue );
|
|
vValue.vt = VT_BSTR;
|
|
vValue.bstrVal = NULL;
|
|
|
|
if ( !rstrData.IsEmpty() ) {
|
|
MFC_TRY
|
|
for( i=0 ;g_htmlentities[i].szHTML != NULL; i++ ){
|
|
// rstrData is const
|
|
szScan = ((CString)rstrData).GetBuffer ( rstrData.GetLength() );
|
|
while( *szScan != _T('\0') ){
|
|
if( *szScan == *g_htmlentities[i].szHTML ){
|
|
lSize += (6*sizeof(TCHAR));
|
|
}
|
|
szScan++;
|
|
}
|
|
((CString)rstrData).ReleaseBuffer();
|
|
}
|
|
if( lSize > 0 ){
|
|
szTrans = (LPTSTR)malloc(lSize);
|
|
if( szTrans != NULL ){
|
|
bAllocated = TRUE;
|
|
ZeroMemory( szTrans, lSize );
|
|
szScan = ((CString)rstrData).GetBuffer ( rstrData.GetLength() );
|
|
while( *szScan != _T('\0') ){
|
|
BOOL bEntity = FALSE;
|
|
for( i=0; g_htmlentities[i].szHTML != NULL; i++ ){
|
|
if( *szScan == *g_htmlentities[i].szHTML ){
|
|
bEntity = TRUE;
|
|
_tcscat( szTrans, g_htmlentities[i].szEntity );
|
|
break;
|
|
}
|
|
}
|
|
if( !bEntity ){
|
|
_tcsncat( szTrans, szScan, 1 );
|
|
}
|
|
szScan++;
|
|
}
|
|
}
|
|
}else{
|
|
szTrans = ((CString)rstrData).GetBuffer ( rstrData.GetLength() );
|
|
}
|
|
|
|
vValue.bstrVal = ::SysAllocString ( T2W( szTrans ) );
|
|
hr = pIPropBag->Write ( rstrPropName, &vValue );
|
|
VariantClear ( &vValue );
|
|
((CString)rstrData).ReleaseBuffer();
|
|
MFC_CATCH_HR
|
|
} else {
|
|
hr = pIPropBag->Write(rstrPropName, &vValue );
|
|
}
|
|
}
|
|
if( NULL != szTrans && bAllocated ){
|
|
free( szTrans );
|
|
}
|
|
return hr;
|
|
}
|
|
|
|
HRESULT
|
|
CSmLogQuery::DwordToPropertyBag (
|
|
IPropertyBag* pPropBag,
|
|
UINT uiPropName,
|
|
DWORD dwData )
|
|
{
|
|
HRESULT hr;
|
|
CString strPropName;
|
|
|
|
ResourceStateManager rsm;
|
|
|
|
strPropName.LoadString ( uiPropName );
|
|
|
|
hr = DwordToPropertyBag (
|
|
pPropBag,
|
|
strPropName,
|
|
dwData );
|
|
|
|
return hr;
|
|
}
|
|
|
|
HRESULT
|
|
CSmLogQuery::DwordToPropertyBag (
|
|
IPropertyBag* pPropBag,
|
|
const CString& rstrPropName,
|
|
DWORD dwData )
|
|
{
|
|
VARIANT vValue;
|
|
HRESULT hr;
|
|
|
|
VariantInit( &vValue );
|
|
vValue.vt = VT_I4;
|
|
vValue.lVal = (INT)dwData;
|
|
|
|
hr = pPropBag->Write(rstrPropName, &vValue );
|
|
|
|
VariantClear ( &vValue );
|
|
|
|
return hr;
|
|
}
|
|
|
|
HRESULT
|
|
CSmLogQuery::DoubleToPropertyBag (
|
|
IPropertyBag* pPropBag,
|
|
UINT uiPropName,
|
|
DOUBLE dData )
|
|
{
|
|
HRESULT hr;
|
|
CString strPropName;
|
|
|
|
ResourceStateManager rsm;
|
|
|
|
MFC_TRY
|
|
strPropName.LoadString ( uiPropName );
|
|
|
|
hr = DoubleToPropertyBag (
|
|
pPropBag,
|
|
strPropName,
|
|
dData );
|
|
MFC_CATCH_HR
|
|
|
|
return hr;
|
|
}
|
|
|
|
HRESULT
|
|
CSmLogQuery::DoubleToPropertyBag (
|
|
IPropertyBag* pPropBag,
|
|
const CString& rstrPropName,
|
|
DOUBLE dData )
|
|
{
|
|
VARIANT vValue;
|
|
HRESULT hr;
|
|
|
|
VariantInit( &vValue );
|
|
vValue.vt = VT_R8;
|
|
vValue.dblVal = dData;
|
|
|
|
hr = pPropBag->Write(rstrPropName, &vValue );
|
|
|
|
VariantClear ( &vValue );
|
|
|
|
return hr;
|
|
}
|
|
|
|
HRESULT
|
|
CSmLogQuery::FloatToPropertyBag (
|
|
IPropertyBag* pPropBag,
|
|
UINT uiPropName,
|
|
FLOAT fData )
|
|
{
|
|
HRESULT hr;
|
|
CString strPropName;
|
|
|
|
ResourceStateManager rsm;
|
|
|
|
MFC_TRY
|
|
strPropName.LoadString ( uiPropName );
|
|
|
|
hr = FloatToPropertyBag (
|
|
pPropBag,
|
|
strPropName,
|
|
fData );
|
|
MFC_CATCH_HR
|
|
|
|
return hr;
|
|
}
|
|
|
|
HRESULT
|
|
CSmLogQuery::FloatToPropertyBag (
|
|
IPropertyBag* pPropBag,
|
|
const CString& rstrPropName,
|
|
FLOAT fData )
|
|
{
|
|
VARIANT vValue;
|
|
HRESULT hr;
|
|
|
|
VariantInit( &vValue );
|
|
vValue.vt = VT_R4;
|
|
vValue.fltVal = fData;
|
|
|
|
hr = pPropBag->Write(rstrPropName, &vValue );
|
|
|
|
VariantClear ( &vValue );
|
|
|
|
return hr;
|
|
}
|
|
|
|
HRESULT
|
|
CSmLogQuery::LLTimeToPropertyBag (
|
|
IPropertyBag* pIPropBag,
|
|
UINT uiPropName,
|
|
LONGLONG& rllData )
|
|
{
|
|
HRESULT hr;
|
|
VARIANT vValue;
|
|
CString strPropName;
|
|
|
|
ResourceStateManager rsm;
|
|
|
|
MFC_TRY
|
|
strPropName.LoadString ( uiPropName );
|
|
|
|
VariantInit( &vValue );
|
|
vValue.vt = VT_DATE;
|
|
|
|
if ( LLTimeToVariantDate ( rllData, &vValue.date ) ) {
|
|
|
|
hr = pIPropBag->Write(strPropName, &vValue );
|
|
|
|
VariantClear ( &vValue );
|
|
|
|
} else {
|
|
hr = E_FAIL;
|
|
}
|
|
MFC_CATCH_HR
|
|
|
|
return hr;
|
|
}
|
|
|
|
HRESULT
|
|
CSmLogQuery::SlqTimeToPropertyBag (
|
|
IPropertyBag* pPropBag,
|
|
DWORD dwFlags,
|
|
PSLQ_TIME_INFO pSlqData )
|
|
{
|
|
HRESULT hr = NOERROR;
|
|
|
|
ASSERT ( NULL != pSlqData );
|
|
|
|
switch (dwFlags) {
|
|
case SLQ_TT_TTYPE_START:
|
|
ASSERT ( SLQ_TT_TTYPE_START == pSlqData->wTimeType );
|
|
|
|
hr = DwordToPropertyBag ( pPropBag, IDS_HTML_START_MODE, pSlqData->dwAutoMode );
|
|
if ( SLQ_AUTO_MODE_AT == pSlqData->dwAutoMode ) {
|
|
ASSERT ( SLQ_TT_DTYPE_DATETIME == pSlqData->wDataType );
|
|
hr = LLTimeToPropertyBag ( pPropBag, IDS_HTML_START_AT_TIME, pSlqData->llDateTime );
|
|
}
|
|
|
|
break;
|
|
|
|
case SLQ_TT_TTYPE_STOP:
|
|
ASSERT ( SLQ_TT_TTYPE_STOP == pSlqData->wTimeType );
|
|
|
|
hr = DwordToPropertyBag ( pPropBag, IDS_HTML_STOP_MODE, pSlqData->dwAutoMode );
|
|
if ( SLQ_AUTO_MODE_AT == pSlqData->dwAutoMode ) {
|
|
ASSERT ( SLQ_TT_DTYPE_DATETIME == pSlqData->wDataType );
|
|
hr = LLTimeToPropertyBag ( pPropBag, IDS_HTML_STOP_AT_TIME, pSlqData->llDateTime );
|
|
} else if ( SLQ_AUTO_MODE_AFTER == pSlqData->dwAutoMode ) {
|
|
ASSERT ( SLQ_TT_DTYPE_UNITS == pSlqData->wDataType );
|
|
hr = DwordToPropertyBag (
|
|
pPropBag,
|
|
IDS_HTML_STOP_AFTER_UNIT_TYPE,
|
|
pSlqData->dwUnitType );
|
|
hr = DwordToPropertyBag (
|
|
pPropBag,
|
|
IDS_HTML_STOP_AFTER_VALUE,
|
|
pSlqData->dwValue );
|
|
}
|
|
|
|
break;
|
|
|
|
case SLQ_TT_TTYPE_SAMPLE:
|
|
{
|
|
LONGLONG llMillisecondSampleInt;
|
|
FLOAT fSampleIntSeconds;
|
|
|
|
ASSERT ( SLQ_TT_TTYPE_SAMPLE == pSlqData->wTimeType );
|
|
ASSERT ( SLQ_TT_DTYPE_UNITS == pSlqData->wDataType );
|
|
// ASSERT ( SLQ_AUTO_MODE_AFTER == pSlqData->dwAutoMode );
|
|
|
|
// Write best approximation of sample time to Sysmon property.
|
|
TimeInfoToMilliseconds ( pSlqData, &llMillisecondSampleInt );
|
|
|
|
// Ensure that the millisecond sample interval fits in a DWORD.
|
|
ASSERT ( llMillisecondSampleInt < ULONG_MAX );
|
|
|
|
fSampleIntSeconds = (FLOAT)(llMillisecondSampleInt / 1000);
|
|
hr = FloatToPropertyBag (
|
|
pPropBag,
|
|
IDS_HTML_SYSMON_UPDATEINTERVAL,
|
|
fSampleIntSeconds );
|
|
|
|
hr = DwordToPropertyBag ( pPropBag, IDS_HTML_SAMPLE_INT_UNIT_TYPE, pSlqData->dwUnitType );
|
|
hr = DwordToPropertyBag ( pPropBag, IDS_HTML_SAMPLE_INT_VALUE, pSlqData->dwValue );
|
|
break;
|
|
}
|
|
// Restart mode stored as a single DWORD
|
|
case SLQ_TT_TTYPE_RESTART:
|
|
default:
|
|
hr = E_INVALIDARG;
|
|
break;
|
|
}
|
|
|
|
return hr;
|
|
}
|
|
|
|
HRESULT
|
|
CSmLogQuery::StringFromPropertyBag (
|
|
IPropertyBag* pPropBag,
|
|
IErrorLog* pIErrorLog,
|
|
UINT uiPropName,
|
|
const CString& rstrDefault,
|
|
LPTSTR *pszBuffer,
|
|
LPDWORD pdwLength )
|
|
{
|
|
HRESULT hr;
|
|
CString strPropName;
|
|
ResourceStateManager rsm;
|
|
|
|
//
|
|
// reads the string value from property bag and
|
|
// frees any existing buffer referenced by szData,
|
|
// then allocates a new buffer returning it with the
|
|
// string value read from the property bag and the size of the
|
|
// buffer (in bytes)
|
|
//
|
|
|
|
MFC_TRY
|
|
strPropName.LoadString ( uiPropName );
|
|
|
|
hr = StringFromPropertyBag (
|
|
pPropBag,
|
|
pIErrorLog,
|
|
strPropName,
|
|
rstrDefault,
|
|
pszBuffer,
|
|
pdwLength );
|
|
MFC_CATCH_HR
|
|
return hr;
|
|
}
|
|
|
|
HRESULT
|
|
CSmLogQuery::StringFromPropertyBag (
|
|
IPropertyBag* pPropBag,
|
|
IErrorLog* pIErrorLog,
|
|
const CString& rstrPropName,
|
|
const CString& rstrDefault,
|
|
LPTSTR *pszBuffer,
|
|
LPDWORD pdwLength )
|
|
{
|
|
VARIANT vValue;
|
|
HRESULT hr;
|
|
DWORD dwNewBufSize = 0;
|
|
LPTSTR szNewStringBuffer = NULL;
|
|
LPTSTR szTrans = NULL;
|
|
LPTSTR szScan = NULL;
|
|
|
|
//
|
|
// Reads the string value from property bag and
|
|
// frees any existing buffer referenced by szData,
|
|
// then allocates a new buffer returning it with the
|
|
// string value read from the property bag and the size of the
|
|
// buffer (in bytes)
|
|
//
|
|
|
|
ASSERT (pdwLength!= NULL);
|
|
ASSERT (pszBuffer != NULL);
|
|
|
|
*pdwLength = 0;
|
|
|
|
VariantInit( &vValue );
|
|
vValue.vt = VT_BSTR;
|
|
vValue.bstrVal = NULL;
|
|
|
|
MFC_TRY
|
|
hr = pPropBag->Read(rstrPropName, &vValue, pIErrorLog );
|
|
|
|
if ( SUCCEEDED(hr) && NULL != vValue.bstrVal ) {
|
|
dwNewBufSize = SysStringLen(vValue.bstrVal) + sizeof(TCHAR);
|
|
if ( dwNewBufSize > sizeof(TCHAR) ) {
|
|
// then there's something to read
|
|
szTrans = new TCHAR[dwNewBufSize];
|
|
szNewStringBuffer = new TCHAR[dwNewBufSize];
|
|
lstrcpy ( szNewStringBuffer, W2T( vValue.bstrVal) );
|
|
for( int i=0;g_htmlentities[i].szHTML != NULL;i++ ){
|
|
LPTSTR szScan = NULL;
|
|
while( szScan = _tcsstr( szNewStringBuffer, g_htmlentities[i].szEntity ) ){
|
|
*szScan = _T('\0');
|
|
_tcscpy( szTrans, szNewStringBuffer );
|
|
_tcscat( szTrans, g_htmlentities[i].szHTML );
|
|
szScan += _tcslen( g_htmlentities[i].szEntity);
|
|
_tcscat( szTrans, szScan );
|
|
_tcscpy( szNewStringBuffer, szTrans );
|
|
}
|
|
}
|
|
delete szTrans;
|
|
szTrans = NULL;
|
|
} else if ( 0 != rstrDefault.GetLength() ) {
|
|
// Missing data in the property bag, so apply the default.
|
|
dwNewBufSize = rstrDefault.GetLength() + sizeof(TCHAR);
|
|
|
|
szNewStringBuffer = new TCHAR[dwNewBufSize];
|
|
lstrcpy ( szNewStringBuffer, rstrDefault );
|
|
hr = S_OK;
|
|
} else {
|
|
// Property not found, no default provided.
|
|
hr = E_INVALIDARG;
|
|
}
|
|
} else if ( 0 != rstrDefault.GetLength() ) {
|
|
// Missing data in the property bag, so apply the default.
|
|
dwNewBufSize = rstrDefault.GetLength() + sizeof(TCHAR);
|
|
|
|
szNewStringBuffer = new TCHAR[dwNewBufSize];
|
|
lstrcpy ( szNewStringBuffer, rstrDefault );
|
|
hr = S_OK;
|
|
}
|
|
MFC_CATCH_HR
|
|
|
|
if ( SUCCEEDED(hr)) {
|
|
// then delete the old buffer and replace it with
|
|
// the new one
|
|
if (*pszBuffer != NULL) {
|
|
delete (*pszBuffer );
|
|
}
|
|
*pszBuffer = (LPTSTR)szNewStringBuffer;
|
|
*pdwLength = dwNewBufSize;
|
|
} else {
|
|
// if error then delete the buffer
|
|
if ( NULL != szNewStringBuffer ) {
|
|
delete szNewStringBuffer;
|
|
}
|
|
}
|
|
if ( NULL != szTrans ) {
|
|
delete szTrans;
|
|
}
|
|
return hr;
|
|
}
|
|
|
|
HRESULT
|
|
CSmLogQuery::DwordFromPropertyBag (
|
|
IPropertyBag* pPropBag,
|
|
IErrorLog* pIErrorLog,
|
|
UINT uiPropName,
|
|
DWORD dwDefault,
|
|
DWORD& rdwData )
|
|
{
|
|
HRESULT hr;
|
|
CString strPropName;
|
|
|
|
ResourceStateManager rsm;
|
|
|
|
MFC_TRY
|
|
strPropName.LoadString ( uiPropName );
|
|
|
|
hr = DwordFromPropertyBag (
|
|
pPropBag,
|
|
pIErrorLog,
|
|
strPropName,
|
|
dwDefault,
|
|
rdwData );
|
|
MFC_CATCH_HR
|
|
return hr;
|
|
}
|
|
|
|
HRESULT
|
|
CSmLogQuery::DwordFromPropertyBag (
|
|
IPropertyBag* pPropBag,
|
|
IErrorLog* pIErrorLog,
|
|
const CString& rstrPropName,
|
|
DWORD dwDefault,
|
|
DWORD& rdwData )
|
|
{
|
|
VARIANT vValue;
|
|
HRESULT hr;
|
|
|
|
rdwData = dwDefault;
|
|
|
|
VariantInit( &vValue );
|
|
vValue.vt = VT_I4;
|
|
vValue.lVal = 0;
|
|
|
|
hr = pPropBag->Read(rstrPropName, &vValue, pIErrorLog );
|
|
|
|
if ( E_INVALIDARG != hr ) {
|
|
rdwData = (DWORD)vValue.lVal;
|
|
} else {
|
|
hr = S_OK;
|
|
}
|
|
|
|
return hr;
|
|
}
|
|
|
|
HRESULT
|
|
CSmLogQuery::DoubleFromPropertyBag (
|
|
IPropertyBag* pPropBag,
|
|
IErrorLog* pIErrorLog,
|
|
UINT uiPropName,
|
|
DOUBLE dDefault,
|
|
DOUBLE& rdData )
|
|
{
|
|
HRESULT hr;
|
|
CString strPropName;
|
|
|
|
ResourceStateManager rsm;
|
|
|
|
MFC_TRY
|
|
strPropName.LoadString ( uiPropName );
|
|
|
|
hr = DoubleFromPropertyBag (
|
|
pPropBag,
|
|
pIErrorLog,
|
|
strPropName,
|
|
dDefault,
|
|
rdData );
|
|
MFC_CATCH_HR
|
|
|
|
return hr;
|
|
}
|
|
|
|
HRESULT
|
|
CSmLogQuery::DoubleFromPropertyBag (
|
|
IPropertyBag* pPropBag,
|
|
IErrorLog* pIErrorLog,
|
|
const CString& rstrPropName,
|
|
DOUBLE dDefault,
|
|
DOUBLE& rdData )
|
|
{
|
|
VARIANT vValue;
|
|
HRESULT hr;
|
|
|
|
rdData = dDefault;
|
|
|
|
VariantInit( &vValue );
|
|
vValue.vt = VT_R8;
|
|
vValue.dblVal = 0;
|
|
|
|
hr = pPropBag->Read(rstrPropName, &vValue, pIErrorLog );
|
|
|
|
if ( E_INVALIDARG != hr ) {
|
|
rdData = vValue.dblVal;
|
|
} else {
|
|
hr = S_OK;
|
|
}
|
|
|
|
return hr;
|
|
}
|
|
|
|
HRESULT
|
|
CSmLogQuery::FloatFromPropertyBag (
|
|
IPropertyBag* pPropBag,
|
|
IErrorLog* pIErrorLog,
|
|
UINT uiPropName,
|
|
FLOAT fDefault,
|
|
FLOAT& rfData )
|
|
{
|
|
HRESULT hr;
|
|
CString strPropName;
|
|
|
|
ResourceStateManager rsm;
|
|
|
|
strPropName.LoadString ( uiPropName );
|
|
|
|
hr = FloatFromPropertyBag (
|
|
pPropBag,
|
|
pIErrorLog,
|
|
strPropName,
|
|
fDefault,
|
|
rfData );
|
|
|
|
return hr;
|
|
}
|
|
|
|
HRESULT
|
|
CSmLogQuery::FloatFromPropertyBag (
|
|
IPropertyBag* pPropBag,
|
|
IErrorLog* pIErrorLog,
|
|
const CString& rstrPropName,
|
|
FLOAT fDefault,
|
|
FLOAT& rfData )
|
|
{
|
|
VARIANT vValue;
|
|
HRESULT hr;
|
|
|
|
rfData = fDefault;
|
|
|
|
VariantInit( &vValue );
|
|
vValue.vt = VT_R4;
|
|
vValue.fltVal = 0;
|
|
|
|
hr = pPropBag->Read(rstrPropName, &vValue, pIErrorLog );
|
|
|
|
if ( E_INVALIDARG != hr ) {
|
|
rfData = vValue.fltVal;
|
|
} else {
|
|
hr = S_OK;
|
|
}
|
|
|
|
return hr;
|
|
}
|
|
|
|
HRESULT
|
|
CSmLogQuery::LLTimeFromPropertyBag (
|
|
IPropertyBag* pIPropBag,
|
|
IErrorLog* pIErrorLog,
|
|
UINT uiPropName,
|
|
LONGLONG& rllDefault,
|
|
LONGLONG& rllData )
|
|
{
|
|
HRESULT hr = NOERROR;
|
|
CString strPropName;
|
|
VARIANT vValue;
|
|
ResourceStateManager rsm;
|
|
|
|
strPropName.LoadString ( uiPropName );
|
|
|
|
rllData = rllDefault;
|
|
|
|
VariantInit( &vValue );
|
|
vValue.vt = VT_DATE;
|
|
|
|
hr = pIPropBag->Read(strPropName, &vValue, pIErrorLog );
|
|
|
|
// If parameter not missing, translate and return. Otherwise,
|
|
// return the default.
|
|
if ( E_INVALIDARG != hr ) {
|
|
if ( !VariantDateToLLTime ( vValue.date, &rllData ) ) {
|
|
hr = E_FAIL;
|
|
}
|
|
VariantClear( &vValue );
|
|
} else {
|
|
hr = S_OK;
|
|
}
|
|
|
|
return hr;
|
|
}
|
|
|
|
HRESULT
|
|
CSmLogQuery::SlqTimeFromPropertyBag (
|
|
IPropertyBag* pPropBag,
|
|
IErrorLog* pIErrorLog,
|
|
DWORD dwFlags,
|
|
PSLQ_TIME_INFO pSlqDefault,
|
|
PSLQ_TIME_INFO pSlqData )
|
|
{
|
|
HRESULT hr = NOERROR;
|
|
|
|
ASSERT ( NULL != pSlqData );
|
|
|
|
switch (dwFlags) {
|
|
case SLQ_TT_TTYPE_START:
|
|
|
|
pSlqData->wTimeType = SLQ_TT_TTYPE_START;
|
|
pSlqData->wDataType = SLQ_TT_DTYPE_DATETIME;
|
|
|
|
hr = DwordFromPropertyBag (
|
|
pPropBag,
|
|
pIErrorLog,
|
|
IDS_HTML_START_MODE,
|
|
pSlqDefault->dwAutoMode,
|
|
pSlqData->dwAutoMode );
|
|
|
|
if ( SLQ_AUTO_MODE_AT == pSlqData->dwAutoMode ) {
|
|
hr = LLTimeFromPropertyBag (
|
|
pPropBag,
|
|
pIErrorLog,
|
|
IDS_HTML_START_AT_TIME,
|
|
pSlqDefault->llDateTime,
|
|
pSlqData->llDateTime );
|
|
|
|
} else {
|
|
// Original state is stopped.
|
|
ASSERT ( SLQ_AUTO_MODE_NONE == pSlqData->dwAutoMode );
|
|
pSlqData->llDateTime = MAX_TIME_VALUE;
|
|
}
|
|
|
|
break;
|
|
|
|
case SLQ_TT_TTYPE_STOP:
|
|
pSlqData->wTimeType = SLQ_TT_TTYPE_STOP;
|
|
|
|
hr = DwordFromPropertyBag (
|
|
pPropBag,
|
|
pIErrorLog,
|
|
IDS_HTML_STOP_MODE,
|
|
pSlqDefault->dwAutoMode,
|
|
pSlqData->dwAutoMode );
|
|
|
|
if ( SLQ_AUTO_MODE_AT == pSlqData->dwAutoMode ) {
|
|
pSlqData->wDataType = SLQ_TT_DTYPE_DATETIME;
|
|
hr = LLTimeFromPropertyBag (
|
|
pPropBag,
|
|
pIErrorLog,
|
|
IDS_HTML_STOP_AT_TIME,
|
|
pSlqDefault->llDateTime,
|
|
pSlqData->llDateTime );
|
|
|
|
} else if ( SLQ_AUTO_MODE_AFTER == pSlqData->dwAutoMode ) {
|
|
pSlqData->wDataType = SLQ_TT_DTYPE_UNITS;
|
|
|
|
hr = DwordFromPropertyBag (
|
|
pPropBag,
|
|
pIErrorLog,
|
|
IDS_HTML_STOP_AFTER_UNIT_TYPE,
|
|
pSlqDefault->dwUnitType,
|
|
pSlqData->dwUnitType );
|
|
|
|
hr = DwordFromPropertyBag (
|
|
pPropBag,
|
|
pIErrorLog,
|
|
IDS_HTML_STOP_AFTER_VALUE,
|
|
pSlqDefault->dwValue,
|
|
pSlqData->dwValue );
|
|
} else {
|
|
// Original state is stopped.
|
|
ASSERT ( SLQ_AUTO_MODE_NONE == pSlqData->dwAutoMode );
|
|
pSlqData->wDataType = SLQ_TT_DTYPE_DATETIME;
|
|
pSlqData->llDateTime = MIN_TIME_VALUE;
|
|
}
|
|
|
|
break;
|
|
|
|
case SLQ_TT_TTYPE_SAMPLE:
|
|
{
|
|
DWORD dwNullDefault = (DWORD)(-1);
|
|
BOOL bUnitTypeMissing = FALSE;
|
|
BOOL bUnitValueMissing = FALSE;
|
|
|
|
hr = DwordFromPropertyBag (
|
|
pPropBag,
|
|
pIErrorLog,
|
|
IDS_HTML_SAMPLE_INT_UNIT_TYPE,
|
|
dwNullDefault,
|
|
pSlqData->dwUnitType );
|
|
|
|
if ( (DWORD)(-1) == pSlqData->dwUnitType ) {
|
|
pSlqData->dwUnitType = pSlqDefault->dwUnitType;
|
|
bUnitTypeMissing = TRUE;
|
|
}
|
|
|
|
hr = DwordFromPropertyBag (
|
|
pPropBag,
|
|
pIErrorLog,
|
|
IDS_HTML_SAMPLE_INT_VALUE,
|
|
dwNullDefault,
|
|
pSlqData->dwValue );
|
|
|
|
if ( (DWORD)(-1) == pSlqData->dwValue ) {
|
|
pSlqData->dwValue = pSlqDefault->dwValue;
|
|
bUnitValueMissing = TRUE;
|
|
}
|
|
|
|
if ( bUnitTypeMissing || bUnitValueMissing ) {
|
|
FLOAT fDefaultUpdateInterval;
|
|
FLOAT fUpdateInterval;
|
|
|
|
// If unit type or unit count missing from the property bag,
|
|
// look for "UpdateInterval" value, from the Sysmon control object,
|
|
// and use it to approximate the sample time.
|
|
fDefaultUpdateInterval = (FLOAT)(pSlqDefault->dwValue);
|
|
|
|
hr = FloatFromPropertyBag (
|
|
pPropBag,
|
|
pIErrorLog,
|
|
IDS_HTML_SYSMON_UPDATEINTERVAL,
|
|
fDefaultUpdateInterval,
|
|
fUpdateInterval );
|
|
|
|
if ( SUCCEEDED ( hr ) ) {
|
|
pSlqData->dwValue = (DWORD)(fUpdateInterval);
|
|
pSlqData->dwUnitType = SLQ_TT_UTYPE_SECONDS;
|
|
}
|
|
}
|
|
break;
|
|
}
|
|
|
|
// Restart mode stored as a single DWORD
|
|
case SLQ_TT_TTYPE_RESTART:
|
|
default:
|
|
hr = E_INVALIDARG;
|
|
break;
|
|
}
|
|
|
|
return hr;
|
|
}
|
|
|
|
|
|
|
|
|
|
//
|
|
// Open function. either opens an existing log query entry
|
|
// or creates a new one
|
|
//
|
|
DWORD
|
|
CSmLogQuery::Open ( const CString& rstrName, HKEY hKeyQuery, BOOL bReadOnly )
|
|
{
|
|
DWORD dwStatus = ERROR_SUCCESS;
|
|
|
|
//open the subkey for this log query
|
|
m_hKeyQuery = hKeyQuery;
|
|
m_bReadOnly = bReadOnly;
|
|
m_bIsModified = FALSE;
|
|
|
|
MFC_TRY
|
|
m_strName = rstrName;
|
|
dwStatus = SyncWithRegistry();
|
|
|
|
MFC_CATCH_DWSTATUS
|
|
return dwStatus;
|
|
}
|
|
|
|
//
|
|
// Close Function
|
|
// closes registry handles and frees allocated memory
|
|
//
|
|
DWORD
|
|
CSmLogQuery::Close ()
|
|
{
|
|
LOCALTRACE (L"Closing Query\n");
|
|
|
|
m_strName.Empty();
|
|
mr_strComment.Empty();
|
|
mr_strCommentIndirect.Empty();
|
|
mr_strBaseFileName.Empty();
|
|
mr_strBaseFileNameIndirect.Empty();
|
|
mr_strDefaultDirectory.Empty();
|
|
mr_strSqlName.Empty();
|
|
|
|
// close any open registry keys
|
|
if (m_hKeyQuery != NULL) {
|
|
RegCloseKey (m_hKeyQuery);
|
|
m_hKeyQuery = NULL;
|
|
}
|
|
|
|
return ERROR_SUCCESS;
|
|
}
|
|
|
|
//
|
|
// ManualStart function.
|
|
// Sets the start mode to manual and starts the query.
|
|
//
|
|
DWORD
|
|
CSmLogQuery::ManualStart ()
|
|
{
|
|
DWORD dwStatus = ERROR_SUCCESS;
|
|
SLQ_TIME_INFO slqTime;
|
|
BOOL bSetStopToMax;
|
|
BOOL bStarted = FALSE;
|
|
DWORD dwTimeout = 10;
|
|
BOOL bRegistryUpdated;
|
|
|
|
memset (&slqTime, 0, sizeof(slqTime));
|
|
slqTime.wTimeType = SLQ_TT_TTYPE_START;
|
|
slqTime.wDataType = SLQ_TT_DTYPE_DATETIME;
|
|
slqTime.dwAutoMode = SLQ_AUTO_MODE_NONE;
|
|
slqTime.llDateTime = MIN_TIME_VALUE;
|
|
|
|
SetLogTime ( &slqTime, SLQ_TT_TTYPE_START );
|
|
|
|
// If stop time mode set to manual, or StopAt with time before Now,
|
|
// set the mode to Manual, value to MAX_TIME_VALUE
|
|
bSetStopToMax = FALSE;
|
|
GetLogTime ( &slqTime, SLQ_TT_TTYPE_STOP );
|
|
if ( SLQ_AUTO_MODE_NONE == slqTime.dwAutoMode ) {
|
|
bSetStopToMax = TRUE;
|
|
} else if ( SLQ_AUTO_MODE_AT == slqTime.dwAutoMode ) {
|
|
SYSTEMTIME stLocalTime;
|
|
FILETIME ftLocalTime;
|
|
LONGLONG llLocalTime;
|
|
|
|
// get local time
|
|
// Milliseconds set to 0 for Schedule times
|
|
GetLocalTime (&stLocalTime);
|
|
stLocalTime.wMilliseconds = 0;
|
|
SystemTimeToFileTime (&stLocalTime, &ftLocalTime);
|
|
|
|
llLocalTime = *(LONGLONG*)&ftLocalTime;
|
|
|
|
if ( llLocalTime >= slqTime.llDateTime ) {
|
|
bSetStopToMax = TRUE;
|
|
}
|
|
}
|
|
|
|
if ( bSetStopToMax ) {
|
|
ASSERT( SLQ_TT_DTYPE_DATETIME == slqTime.wDataType );
|
|
slqTime.dwAutoMode = SLQ_AUTO_MODE_NONE;
|
|
slqTime.llDateTime = MAX_TIME_VALUE;
|
|
SetLogTime ( &slqTime, SLQ_TT_TTYPE_STOP );
|
|
}
|
|
|
|
// Service needs to distinguish between Running and Start Pending
|
|
// at service startup, so always set state to start pending.
|
|
SetState ( SLQ_QUERY_START_PENDING );
|
|
|
|
dwStatus = UpdateServiceSchedule( bRegistryUpdated );
|
|
|
|
if ( bRegistryUpdated ) {
|
|
|
|
while (--dwTimeout && !bStarted ) {
|
|
bStarted = IsRunning();
|
|
}
|
|
|
|
if ( !bStarted ) {
|
|
dwStatus = SMCFG_START_TIMED_OUT;
|
|
}
|
|
}
|
|
|
|
SyncPropPageSharedData(); // Sync the start time and stop auto mode
|
|
|
|
return dwStatus;
|
|
}
|
|
|
|
//
|
|
// ManualStop function.
|
|
//
|
|
// Clears the restart bit, sets the stop mode to manual and stops the query.
|
|
//
|
|
DWORD
|
|
CSmLogQuery::ManualStop ( )
|
|
{
|
|
DWORD dwStatus = ERROR_SUCCESS;
|
|
SLQ_TIME_INFO slqTime;
|
|
BOOL bRegistryUpdated;
|
|
|
|
if ( IsAutoRestart() ) {
|
|
mr_dwAutoRestartMode = SLQ_AUTO_MODE_NONE;
|
|
}
|
|
|
|
memset (&slqTime, 0, sizeof(slqTime));
|
|
slqTime.wTimeType = SLQ_TT_TTYPE_STOP;
|
|
slqTime.wDataType = SLQ_TT_DTYPE_DATETIME;
|
|
slqTime.dwAutoMode = SLQ_AUTO_MODE_NONE;
|
|
slqTime.llDateTime = MIN_TIME_VALUE;
|
|
|
|
SetLogTime ( &slqTime, SLQ_TT_TTYPE_STOP );
|
|
|
|
// If start time mode set to manual, set the value to MAX_TIME_VALUE
|
|
GetLogTime ( &slqTime, SLQ_TT_TTYPE_START );
|
|
if ( SLQ_AUTO_MODE_NONE == slqTime.dwAutoMode ) {
|
|
ASSERT( SLQ_TT_DTYPE_DATETIME == slqTime.wDataType );
|
|
slqTime.llDateTime = MAX_TIME_VALUE;
|
|
SetLogTime ( &slqTime, SLQ_TT_TTYPE_START );
|
|
}
|
|
|
|
dwStatus = UpdateServiceSchedule ( bRegistryUpdated );
|
|
|
|
if ( bRegistryUpdated ) {
|
|
DWORD dwTimeout = 25;
|
|
BOOL bStopped = FALSE;
|
|
|
|
while ( dwTimeout-- && !bStopped ) {
|
|
// IsRunning implements no delay if the current state is not
|
|
// SLQ_QUERY_START_PENDING, so add a delay for the registry
|
|
// change to be written.
|
|
bStopped = !IsRunning();
|
|
Sleep ( 200 );
|
|
}
|
|
|
|
if ( !bStopped ) {
|
|
dwStatus = SMCFG_STOP_TIMED_OUT;
|
|
}
|
|
}
|
|
|
|
SyncPropPageSharedData(); // Sync the start time and stop auto mode
|
|
|
|
return dwStatus;
|
|
}
|
|
|
|
//
|
|
// SaveAs function.
|
|
// Saves the query properties as a System Monitor ActiveX object
|
|
// in an HTML file.
|
|
//
|
|
DWORD
|
|
CSmLogQuery::SaveAs ( const CString& rstrPathName )
|
|
{
|
|
DWORD dwStatus = ERROR_SUCCESS;
|
|
CString strNonConstPathName = rstrPathName;
|
|
ResourceStateManager rsm;
|
|
|
|
// Create a file.
|
|
HANDLE hFile;
|
|
hFile = CreateFile (
|
|
strNonConstPathName,
|
|
GENERIC_READ | GENERIC_WRITE,
|
|
0, // Not shared
|
|
NULL, // Security attributes
|
|
CREATE_ALWAYS, // The user has already decided to override any existing file.
|
|
FILE_ATTRIBUTE_NORMAL,
|
|
NULL );
|
|
|
|
if ( INVALID_HANDLE_VALUE != hFile ) {
|
|
// Save the current configuration to the file.
|
|
CString strTemp;
|
|
DWORD dwTempLength;
|
|
BOOL bStatus;
|
|
WCHAR szByteOrderMark[2];
|
|
|
|
szByteOrderMark[0] = 0xFEFF;
|
|
szByteOrderMark[1] = 0;
|
|
bStatus = FileWrite ( hFile, szByteOrderMark, sizeof(WCHAR) );
|
|
|
|
if ( bStatus ) {
|
|
strTemp.LoadString( IDS_HTML_FILE_HEADER1 );
|
|
dwTempLength = strTemp.GetLength() * sizeof(TCHAR);
|
|
bStatus = FileWrite ( hFile, (void *)(LPCTSTR)strTemp, dwTempLength );
|
|
}
|
|
|
|
if ( bStatus ) {
|
|
strTemp.LoadString( IDS_HTML_FILE_HEADER2 );
|
|
dwTempLength = strTemp.GetLength() * sizeof(TCHAR);
|
|
bStatus = FileWrite ( hFile, (void *)(LPCTSTR)strTemp, dwTempLength );
|
|
}
|
|
|
|
if ( bStatus ) {
|
|
DWORD dwByteCount;
|
|
LPTSTR pszData = NULL;
|
|
|
|
HRESULT hr = CopyToBuffer ( pszData, dwByteCount );
|
|
|
|
if ( SUCCEEDED ( hr ) ) {
|
|
ASSERT ( NULL != pszData );
|
|
ASSERT ( 0 != dwByteCount );
|
|
bStatus = FileWrite ( hFile, pszData, dwByteCount );
|
|
delete pszData;
|
|
} else {
|
|
bStatus = FALSE;
|
|
}
|
|
}
|
|
|
|
if ( bStatus ) {
|
|
strTemp.LoadString( IDS_HTML_FILE_FOOTER );
|
|
dwTempLength = strTemp.GetLength() * sizeof(TCHAR);
|
|
bStatus = FileWrite ( hFile, (void *)(LPCTSTR)strTemp, dwTempLength );
|
|
}
|
|
|
|
bStatus = CloseHandle ( hFile );
|
|
|
|
}
|
|
|
|
return dwStatus;
|
|
}
|
|
|
|
DWORD
|
|
CSmLogQuery::UpdateService( BOOL& rbRegistryUpdated ) {
|
|
|
|
DWORD dwStatus;
|
|
|
|
rbRegistryUpdated = FALSE;
|
|
|
|
dwStatus = UpdateRegistry();
|
|
|
|
if ( ERROR_SUCCESS == dwStatus ) {
|
|
rbRegistryUpdated = TRUE;
|
|
dwStatus = m_pLogService->Synchronize();
|
|
}
|
|
|
|
if ( ERROR_SUCCESS == dwStatus ) {
|
|
m_bIsModified = TRUE;
|
|
}
|
|
|
|
return dwStatus;
|
|
}
|
|
|
|
//
|
|
// UpdateServiceSchedule function.
|
|
// copies the current schedule settings to the registry
|
|
// and synchs the log service
|
|
//
|
|
DWORD
|
|
CSmLogQuery::UpdateServiceSchedule( BOOL& rbRegistryUpdated ) {
|
|
|
|
LONG dwStatus = ERROR_SUCCESS;
|
|
|
|
rbRegistryUpdated = FALSE;
|
|
|
|
if (!m_bReadOnly) {
|
|
|
|
dwStatus = UpdateRegistryScheduleValues();
|
|
|
|
if ( ERROR_SUCCESS == dwStatus ) {
|
|
dwStatus = UpdateRegistryLastModified();
|
|
}
|
|
|
|
if ( ERROR_SUCCESS == dwStatus ) {
|
|
rbRegistryUpdated = TRUE;
|
|
dwStatus = m_pLogService->Synchronize();
|
|
}
|
|
|
|
if ( ERROR_SUCCESS == dwStatus ) {
|
|
m_bIsModified = TRUE;
|
|
}
|
|
} else {
|
|
dwStatus = ERROR_ACCESS_DENIED;
|
|
}
|
|
return dwStatus;
|
|
}
|
|
|
|
//
|
|
// UpdateRegistryLastModified function.
|
|
// Copies the current "last modified date" to the registry where
|
|
// it is read by the log service
|
|
//
|
|
DWORD
|
|
CSmLogQuery::UpdateRegistryLastModified()
|
|
{
|
|
LONG dwStatus = ERROR_SUCCESS;
|
|
|
|
if (!m_bReadOnly) {
|
|
SLQ_TIME_INFO plqLastModified;
|
|
FILETIME ftModified;
|
|
SYSTEMTIME stLocalTime;
|
|
|
|
RegFlushKey( m_hKeyQuery );
|
|
|
|
dwStatus = RegQueryInfoKey (
|
|
m_hKeyQuery,
|
|
NULL, // Class buffer
|
|
NULL, // Size of class buffer
|
|
NULL, // Reserved
|
|
NULL, // Subkey count
|
|
NULL, // Length of longest subkey name
|
|
NULL, // Longest subkey class
|
|
NULL, // Value count
|
|
NULL, // Length of longest value name
|
|
NULL, // Length of longest value
|
|
NULL, // Security descriptor
|
|
&ftModified );
|
|
if (ERROR_SUCCESS != dwStatus ) {
|
|
// Get local time for last modified value, if the
|
|
// registry doesn't return the last written time.
|
|
GetLocalTime (&stLocalTime);
|
|
SystemTimeToFileTime (&stLocalTime, &ftModified);
|
|
}
|
|
|
|
plqLastModified.wDataType = SLQ_TT_DTYPE_DATETIME;
|
|
plqLastModified.wTimeType = SLQ_TT_TTYPE_LAST_MODIFIED;
|
|
plqLastModified.dwAutoMode = SLQ_AUTO_MODE_NONE; // not used.
|
|
plqLastModified.llDateTime = *(LONGLONG *)&ftModified;
|
|
|
|
dwStatus = WriteRegistrySlqTime (
|
|
m_hKeyQuery,
|
|
IDS_REG_LAST_MODIFIED,
|
|
&plqLastModified);
|
|
} else {
|
|
dwStatus = ERROR_ACCESS_DENIED;
|
|
}
|
|
|
|
return dwStatus;
|
|
}
|
|
|
|
//
|
|
// UpdateRegistryScheduleValues function.
|
|
// copies the current schedule settings to the registry where they
|
|
// are read by the log service
|
|
//
|
|
DWORD
|
|
CSmLogQuery::UpdateRegistryScheduleValues()
|
|
{
|
|
LONG dwStatus = ERROR_SUCCESS;
|
|
|
|
if (!m_bReadOnly) {
|
|
|
|
// Stop and start times
|
|
|
|
if ( ERROR_SUCCESS == dwStatus ) {
|
|
ASSERT (mr_stiStart.wTimeType == SLQ_TT_TTYPE_START);
|
|
dwStatus = WriteRegistrySlqTime (
|
|
m_hKeyQuery,
|
|
IDS_REG_START_TIME,
|
|
&mr_stiStart);
|
|
}
|
|
|
|
if ( ERROR_SUCCESS == dwStatus ) {
|
|
ASSERT (mr_stiStop.wTimeType == SLQ_TT_TTYPE_STOP);
|
|
dwStatus = WriteRegistrySlqTime (
|
|
m_hKeyQuery,
|
|
IDS_REG_STOP_TIME,
|
|
&mr_stiStop);
|
|
}
|
|
|
|
// Auto restart value is "immediately on log file close" only.
|
|
// Use binary for future enhancements.
|
|
if ( ERROR_SUCCESS == dwStatus ) {
|
|
dwStatus = WriteRegistryDwordValue (
|
|
m_hKeyQuery,
|
|
IDS_REG_RESTART,
|
|
&mr_dwAutoRestartMode,
|
|
REG_BINARY);
|
|
}
|
|
|
|
// Only write the state when requesting the service to
|
|
// start a query.
|
|
if ( SLQ_QUERY_START_PENDING == mr_dwCurrentState ) {
|
|
|
|
dwStatus = WriteRegistryDwordValue (
|
|
m_hKeyQuery,
|
|
IDS_REG_CURRENT_STATE,
|
|
&mr_dwCurrentState);
|
|
}
|
|
|
|
} else {
|
|
dwStatus = ERROR_ACCESS_DENIED;
|
|
}
|
|
|
|
return dwStatus;
|
|
}
|
|
//
|
|
// UpdateRegistry function.
|
|
// copies the current settings to the registry where they
|
|
// are read by the log service
|
|
//
|
|
DWORD
|
|
CSmLogQuery::UpdateRegistry()
|
|
{
|
|
LONG dwStatus = ERROR_SUCCESS;
|
|
DWORD dwBufferSize = 0;
|
|
DWORD dwLogType;
|
|
DWORD dwLogFileType = 0;
|
|
DWORD dwTempFileSizeUnits;
|
|
DWORD dwTempDataStoreAttributes = 0;
|
|
DWORD dwTempMaxFileSize;
|
|
DWORD dwTempAppendMode;
|
|
|
|
if ( IsModifiable() ) {
|
|
|
|
if ( !mr_strComment.IsEmpty() ) {
|
|
dwBufferSize = mr_strComment.GetLength() + 1;
|
|
dwBufferSize *= sizeof(TCHAR);
|
|
} else {
|
|
dwBufferSize = 0;
|
|
}
|
|
|
|
dwStatus = WriteRegistryStringValue (
|
|
m_hKeyQuery,
|
|
IDS_REG_COMMENT,
|
|
REG_SZ,
|
|
(LPCTSTR)mr_strComment,
|
|
&dwBufferSize);
|
|
|
|
if ( ERROR_SUCCESS == dwStatus && !mr_strCommentIndirect.IsEmpty() ) {
|
|
dwBufferSize = mr_strCommentIndirect.GetLength() + 1;
|
|
dwBufferSize *= sizeof(TCHAR);
|
|
|
|
dwStatus = WriteRegistryStringValue (
|
|
m_hKeyQuery,
|
|
IDS_REG_COMMENT_INDIRECT,
|
|
REG_SZ,
|
|
(LPCTSTR)mr_strCommentIndirect,
|
|
&dwBufferSize);
|
|
}
|
|
|
|
if ( ERROR_SUCCESS == dwStatus ) {
|
|
dwLogType = GetLogType();
|
|
dwStatus = WriteRegistryDwordValue (
|
|
m_hKeyQuery,
|
|
IDS_REG_LOG_TYPE,
|
|
&dwLogType);
|
|
}
|
|
|
|
if ( ERROR_SUCCESS == dwStatus ) {
|
|
dwStatus = WriteRegistryDwordValue (
|
|
m_hKeyQuery,
|
|
IDS_REG_REALTIME_DATASOURCE,
|
|
& mr_dwRealTimeQuery);
|
|
}
|
|
|
|
// Files
|
|
|
|
if ( ERROR_SUCCESS == dwStatus ) {
|
|
// Within the app, counter data store size units are in MB.
|
|
// Translate to back to KB when write to registry
|
|
dwTempFileSizeUnits = GetDataStoreSizeUnits();
|
|
dwTempMaxFileSize = mr_dwMaxSize;
|
|
GetLogFileType ( dwLogFileType );
|
|
if ( SLQ_COUNTER_LOG == GetLogType()
|
|
&& SLF_SQL_LOG != dwLogFileType )
|
|
{
|
|
if ( ONE_MB == dwTempFileSizeUnits ) {
|
|
dwTempFileSizeUnits = ONE_KB;
|
|
// Round up to next MB
|
|
if ( SLQ_DISK_MAX_SIZE != mr_dwMaxSize ) {
|
|
dwTempMaxFileSize *= dwTempFileSizeUnits;
|
|
}
|
|
}
|
|
}
|
|
|
|
dwStatus = WriteRegistryDwordValue (
|
|
m_hKeyQuery,
|
|
IDS_REG_LOG_FILE_MAX_SIZE,
|
|
&dwTempMaxFileSize);
|
|
}
|
|
|
|
if ( ERROR_SUCCESS == dwStatus ) {
|
|
// Data store size units
|
|
if ( ONE_MB == dwTempFileSizeUnits ) {
|
|
dwTempDataStoreAttributes = SLF_DATA_STORE_SIZE_ONE_MB;
|
|
} else if ( ONE_KB == dwTempFileSizeUnits ) {
|
|
dwTempDataStoreAttributes = SLF_DATA_STORE_SIZE_ONE_KB;
|
|
} else if ( ONE_RECORD == dwTempFileSizeUnits ) {
|
|
dwTempDataStoreAttributes = SLF_DATA_STORE_SIZE_ONE_RECORD;
|
|
}
|
|
|
|
// Data store append mode
|
|
GetDataStoreAppendMode( dwTempAppendMode );
|
|
dwTempDataStoreAttributes |= dwTempAppendMode;
|
|
|
|
dwStatus = WriteRegistryDwordValue (
|
|
m_hKeyQuery,
|
|
IDS_REG_DATA_STORE_ATTRIBUTES,
|
|
&dwTempDataStoreAttributes);
|
|
}
|
|
|
|
if ( !mr_strBaseFileName.IsEmpty() ) {
|
|
dwBufferSize = mr_strBaseFileName.GetLength() + 1;
|
|
dwBufferSize *= sizeof(TCHAR);
|
|
} else {
|
|
dwBufferSize = 0;
|
|
}
|
|
|
|
if ( ERROR_SUCCESS == dwStatus ) {
|
|
dwStatus = WriteRegistryStringValue (
|
|
m_hKeyQuery,
|
|
IDS_REG_LOG_FILE_BASE_NAME,
|
|
REG_SZ,
|
|
(LPCTSTR)mr_strBaseFileName,
|
|
&dwBufferSize);
|
|
}
|
|
|
|
if ( ERROR_SUCCESS == dwStatus && !mr_strBaseFileNameIndirect.IsEmpty() ) {
|
|
dwBufferSize = mr_strBaseFileNameIndirect.GetLength() + 1;
|
|
dwBufferSize *= sizeof(TCHAR);
|
|
|
|
dwStatus = WriteRegistryStringValue (
|
|
m_hKeyQuery,
|
|
IDS_REG_LOG_FILE_BASE_NAME_IND,
|
|
REG_SZ,
|
|
(LPCTSTR)mr_strBaseFileNameIndirect,
|
|
&dwBufferSize);
|
|
}
|
|
|
|
if ( !mr_strSqlName.IsEmpty() ) {
|
|
dwBufferSize = mr_strSqlName.GetLength() + 1;
|
|
dwBufferSize *= sizeof(TCHAR);
|
|
} else {
|
|
dwBufferSize = 0;
|
|
}
|
|
|
|
if ( ERROR_SUCCESS == dwStatus ) {
|
|
dwStatus = WriteRegistryStringValue (
|
|
m_hKeyQuery,
|
|
IDS_REG_SQL_LOG_BASE_NAME,
|
|
REG_SZ,
|
|
(LPCTSTR)mr_strSqlName,
|
|
&dwBufferSize);
|
|
}
|
|
|
|
if ( ERROR_SUCCESS == dwStatus ) {
|
|
dwStatus = WriteRegistryDwordValue (
|
|
m_hKeyQuery,
|
|
IDS_REG_LOG_FILE_SERIAL_NUMBER,
|
|
&mr_dwCurrentSerialNumber );
|
|
}
|
|
|
|
if ( !mr_strDefaultDirectory.IsEmpty() ) {
|
|
dwBufferSize = mr_strDefaultDirectory.GetLength() + 1;
|
|
dwBufferSize *= sizeof(TCHAR);
|
|
} else {
|
|
dwBufferSize = 0;
|
|
}
|
|
|
|
if ( ERROR_SUCCESS == dwStatus ) {
|
|
dwStatus = WriteRegistryStringValue (
|
|
m_hKeyQuery,
|
|
IDS_REG_LOG_FILE_FOLDER,
|
|
REG_SZ,
|
|
(LPCTSTR)mr_strDefaultDirectory,
|
|
&dwBufferSize);
|
|
}
|
|
|
|
if ( ERROR_SUCCESS == dwStatus ) {
|
|
dwStatus = WriteRegistryDwordValue (
|
|
m_hKeyQuery,
|
|
IDS_REG_LOG_FILE_AUTO_FORMAT,
|
|
&mr_dwLogAutoFormat);
|
|
}
|
|
|
|
if ( ERROR_SUCCESS == dwStatus ) {
|
|
dwStatus = WriteRegistryDwordValue (
|
|
m_hKeyQuery,
|
|
IDS_REG_LOG_FILE_TYPE,
|
|
&mr_dwLogFileType);
|
|
}
|
|
|
|
// Schedule
|
|
|
|
// Eof command is used for counter and trace logs only.
|
|
if ( ERROR_SUCCESS == dwStatus ) {
|
|
if ( SLQ_COUNTER_LOG == GetLogType()
|
|
|| SLQ_TRACE_LOG == GetLogType() ) {
|
|
dwBufferSize = mr_strEofCmdFile.GetLength() + 1;
|
|
dwBufferSize *= sizeof(TCHAR);
|
|
dwStatus = WriteRegistryStringValue (
|
|
m_hKeyQuery,
|
|
IDS_REG_EOF_COMMAND_FILE,
|
|
REG_SZ,
|
|
(LPCWSTR)mr_strEofCmdFile,
|
|
&dwBufferSize);
|
|
}
|
|
}
|
|
|
|
if ( ERROR_SUCCESS == dwStatus ) {
|
|
dwStatus = UpdateRegistryScheduleValues();
|
|
}
|
|
|
|
// This must be the last registry value updated.
|
|
if ( ERROR_SUCCESS == dwStatus ) {
|
|
dwStatus = UpdateRegistryLastModified();
|
|
}
|
|
} else {
|
|
dwStatus = ERROR_ACCESS_DENIED;
|
|
}
|
|
|
|
return dwStatus;
|
|
}
|
|
|
|
//
|
|
// SyncSerialNumberWithRegistry()
|
|
// reads the current value for the serial number
|
|
// from the registry and reloads the internal value
|
|
// to match
|
|
//
|
|
DWORD
|
|
CSmLogQuery::SyncSerialNumberWithRegistry()
|
|
{
|
|
DWORD dwStatus = ERROR_SUCCESS;
|
|
|
|
ASSERT (m_hKeyQuery != NULL);
|
|
|
|
// Get starting serial number for serial suffix.
|
|
|
|
dwStatus = ReadRegistryDwordValue (
|
|
m_hKeyQuery,
|
|
IDS_REG_LOG_FILE_SERIAL_NUMBER,
|
|
DEFAULT_LOG_FILE_SERIAL_NUMBER,
|
|
&mr_dwCurrentSerialNumber );
|
|
ASSERT (dwStatus == ERROR_SUCCESS);
|
|
|
|
return dwStatus;
|
|
}
|
|
|
|
//
|
|
// SyncWithRegistry()
|
|
// reads the current values for this query from the registry
|
|
// and reloads the internal values to match
|
|
//
|
|
DWORD
|
|
CSmLogQuery::SyncWithRegistry()
|
|
{
|
|
DWORD dwBufferSize = 0;
|
|
DWORD dwStatus = ERROR_SUCCESS;
|
|
SLQ_TIME_INFO stiDefault;
|
|
WCHAR szDefault[MAX_PATH + 1];
|
|
LPTSTR szTemp = NULL;
|
|
DWORD dwDefault;
|
|
DWORD dwTemp;
|
|
LPWSTR szIndTemp = NULL;
|
|
UINT uiBufferLen = 0;
|
|
CString strValueName;
|
|
LPTSTR szEofCmd = NULL;
|
|
|
|
ResourceStateManager rsm;
|
|
|
|
ASSERT (m_hKeyQuery != NULL);
|
|
|
|
MFC_TRY
|
|
// Modify bit
|
|
dwTemp = DEFAULT_EXECUTE_ONLY;
|
|
dwStatus = ReadRegistryDwordValue (
|
|
m_hKeyQuery,
|
|
IDS_REG_EXECUTE_ONLY,
|
|
DEFAULT_EXECUTE_ONLY,
|
|
&dwTemp);
|
|
ASSERT ( ERROR_SUCCESS == dwStatus );
|
|
|
|
if ( 0 == dwTemp ) {
|
|
m_bExecuteOnly = FALSE;
|
|
} else {
|
|
m_bExecuteOnly = TRUE;
|
|
}
|
|
|
|
// File attributes
|
|
|
|
// Comment field can be indirect
|
|
strValueName.LoadString ( IDS_REG_COMMENT );
|
|
|
|
dwStatus = SmReadRegistryIndirectStringValue (
|
|
m_hKeyQuery,
|
|
strValueName,
|
|
DEFAULT_COMMENT,
|
|
&szIndTemp,
|
|
&uiBufferLen );
|
|
|
|
mr_strComment.Empty();
|
|
|
|
if ( NULL != szIndTemp ) {
|
|
if ( _T('\0') != *szIndTemp ) {
|
|
mr_strComment = szIndTemp;
|
|
}
|
|
}
|
|
|
|
if ( NULL != szIndTemp ) {
|
|
G_FREE ( szIndTemp );
|
|
szIndTemp = NULL;
|
|
}
|
|
uiBufferLen = 0;
|
|
|
|
dwStatus = ReadRegistryDwordValue (
|
|
m_hKeyQuery,
|
|
IDS_REG_LOG_FILE_MAX_SIZE,
|
|
DEFAULT_LOG_FILE_MAX_SIZE,
|
|
&mr_dwMaxSize );
|
|
|
|
ASSERT ( ERROR_SUCCESS == dwStatus );
|
|
|
|
if ( SLQ_TRACE_LOG == GetLogType() ) {
|
|
|
|
dwStatus = ReadRegistryDwordValue (
|
|
m_hKeyQuery,
|
|
IDS_REG_LOG_FILE_TYPE,
|
|
DEFAULT_TRACE_LOG_FILE_TYPE,
|
|
&mr_dwLogFileType);
|
|
ASSERT ( ERROR_SUCCESS == dwStatus );
|
|
|
|
} else {
|
|
|
|
dwStatus = ReadRegistryDwordValue (
|
|
m_hKeyQuery,
|
|
IDS_REG_LOG_FILE_TYPE,
|
|
DEFAULT_CTR_LOG_FILE_TYPE,
|
|
&mr_dwLogFileType);
|
|
ASSERT ( ERROR_SUCCESS == dwStatus );
|
|
|
|
}
|
|
|
|
// Data store attributes must be read after log file type and log file max size.
|
|
|
|
dwDefault = 0; // Eliminate PREFIX warning
|
|
InitDataStoreAttributesDefault ( mr_dwLogFileType, dwDefault );
|
|
|
|
dwStatus = ReadRegistryDwordValue (
|
|
m_hKeyQuery,
|
|
IDS_REG_DATA_STORE_ATTRIBUTES,
|
|
dwDefault,
|
|
&dwTemp );
|
|
|
|
ProcessLoadedDataStoreAttributes ( dwTemp );
|
|
|
|
//
|
|
// Default to query name.
|
|
// Log file base name field can be indirect.
|
|
//
|
|
lstrcpynW ( szDefault, m_strName , min ( MAX_PATH + 1, m_strName.GetLength() + 1 ) );
|
|
szDefault[MAX_PATH] = L'\0';
|
|
|
|
strValueName.LoadString ( IDS_REG_LOG_FILE_BASE_NAME );
|
|
dwStatus = SmReadRegistryIndirectStringValue (
|
|
m_hKeyQuery,
|
|
strValueName,
|
|
szDefault,
|
|
&szIndTemp,
|
|
&uiBufferLen );
|
|
|
|
ASSERT ( ERROR_SUCCESS == dwStatus );
|
|
|
|
mr_strBaseFileName.Empty();
|
|
|
|
if ( NULL != szIndTemp ) {
|
|
if ( _T('\0') != *szIndTemp ) {
|
|
ReplaceBlanksWithUnderscores ( szIndTemp );
|
|
mr_strBaseFileName = szIndTemp;
|
|
}
|
|
}
|
|
|
|
if ( NULL != szIndTemp ) {
|
|
G_FREE ( szIndTemp );
|
|
szIndTemp = NULL;
|
|
}
|
|
uiBufferLen = 0;
|
|
|
|
dwStatus = ReadRegistryStringValue (
|
|
m_hKeyQuery,
|
|
IDS_REG_LOG_FILE_FOLDER,
|
|
m_pLogService->GetDefaultLogFileFolder(),
|
|
&szTemp,
|
|
&dwBufferSize);
|
|
ASSERT ( ERROR_SUCCESS == dwStatus );
|
|
mr_strDefaultDirectory.Empty();
|
|
if ( dwBufferSize > sizeof(TCHAR) ) {
|
|
ASSERT ( NULL != szTemp );
|
|
ASSERT ( 0 != *szTemp );
|
|
mr_strDefaultDirectory = szTemp;
|
|
}
|
|
|
|
delete ( szTemp );
|
|
szTemp = NULL;
|
|
dwBufferSize = 0;
|
|
|
|
// Default log set name to log name
|
|
if ( MAX_PATH + 1 > m_strName.GetLength() + 5 ) {
|
|
swprintf ( szDefault, L"SQL:!%s", m_strName );
|
|
} else {
|
|
lstrcpyW ( szDefault, L"SQL:!" );
|
|
}
|
|
|
|
dwStatus = ReadRegistryStringValue (
|
|
m_hKeyQuery,
|
|
IDS_REG_SQL_LOG_BASE_NAME,
|
|
szDefault,
|
|
&szTemp,
|
|
&dwBufferSize);
|
|
ASSERT ( ERROR_SUCCESS == dwStatus );
|
|
mr_strSqlName.Empty();
|
|
if ( dwBufferSize > sizeof(TCHAR) ) {
|
|
ASSERT ( NULL != szTemp );
|
|
ASSERT ( 0 != *szTemp );
|
|
mr_strSqlName = szTemp;
|
|
}
|
|
|
|
delete ( szTemp );
|
|
szTemp = NULL;
|
|
dwBufferSize = 0;
|
|
|
|
dwStatus = ReadRegistryDwordValue(
|
|
m_hKeyQuery,
|
|
IDS_REG_REALTIME_DATASOURCE,
|
|
g_dwRealTimeQuery,
|
|
& mr_dwRealTimeQuery);
|
|
ASSERT ( ERROR_SUCCESS == dwStatus );
|
|
|
|
dwStatus = ReadRegistryDwordValue (
|
|
m_hKeyQuery,
|
|
IDS_REG_LOG_FILE_AUTO_FORMAT,
|
|
DEFAULT_LOG_FILE_AUTO_FORMAT,
|
|
&mr_dwLogAutoFormat);
|
|
ASSERT ( ERROR_SUCCESS == dwStatus );
|
|
|
|
// Get starting serial number for serial suffix.
|
|
dwStatus = SyncSerialNumberWithRegistry ();
|
|
ASSERT ( ERROR_SUCCESS == dwStatus );
|
|
|
|
dwStatus = ReadRegistryDwordValue (
|
|
m_hKeyQuery,
|
|
IDS_REG_CURRENT_STATE,
|
|
DEFAULT_CURRENT_STATE,
|
|
&mr_dwCurrentState);
|
|
ASSERT ( ERROR_SUCCESS == dwStatus );
|
|
|
|
// Start, stop and restart values
|
|
|
|
VERIFY ( GetDefaultLogTime (stiDefault, SLQ_TT_TTYPE_START ) );
|
|
|
|
dwStatus = ReadRegistrySlqTime (
|
|
m_hKeyQuery, IDS_REG_START_TIME,
|
|
&stiDefault, &mr_stiStart);
|
|
ASSERT ( ERROR_SUCCESS == dwStatus );
|
|
ASSERT (mr_stiStart.wTimeType == SLQ_TT_TTYPE_START);
|
|
|
|
VERIFY ( GetDefaultLogTime (stiDefault, SLQ_TT_TTYPE_STOP ) );
|
|
|
|
dwStatus = ReadRegistrySlqTime (
|
|
m_hKeyQuery, IDS_REG_STOP_TIME,
|
|
&stiDefault, &mr_stiStop);
|
|
ASSERT ( ERROR_SUCCESS == dwStatus );
|
|
ASSERT (mr_stiStop.wTimeType == SLQ_TT_TTYPE_STOP);
|
|
|
|
dwStatus = ReadRegistryDwordValue (
|
|
m_hKeyQuery,
|
|
IDS_REG_RESTART,
|
|
DEFAULT_RESTART_VALUE,
|
|
&mr_dwAutoRestartMode);
|
|
ASSERT ( ERROR_SUCCESS == dwStatus );
|
|
|
|
// Eof command is used by Counter and Trace logs only.
|
|
if ( SLQ_COUNTER_LOG == GetLogType()
|
|
|| SLQ_TRACE_LOG == GetLogType() ) {
|
|
|
|
dwStatus = ReadRegistryStringValue (
|
|
m_hKeyQuery,
|
|
IDS_REG_EOF_COMMAND_FILE,
|
|
DEFAULT_EOF_COMMAND_FILE,
|
|
&szEofCmd,
|
|
&dwBufferSize);
|
|
ASSERT ( ERROR_SUCCESS == dwStatus );
|
|
if (dwBufferSize > sizeof(TCHAR)) {
|
|
mr_strEofCmdFile = szEofCmd;
|
|
} else {
|
|
mr_strEofCmdFile.Empty();
|
|
}
|
|
}
|
|
|
|
MFC_CATCH_DWSTATUS;
|
|
if ( NULL != szTemp ) {
|
|
delete szTemp;
|
|
}
|
|
|
|
if ( NULL != szIndTemp ) {
|
|
G_FREE ( szIndTemp );
|
|
}
|
|
|
|
if ( NULL != szEofCmd ) {
|
|
delete szEofCmd;
|
|
}
|
|
SyncPropPageSharedData();
|
|
|
|
return dwStatus;
|
|
}
|
|
|
|
CSmLogService*
|
|
CSmLogQuery::GetLogService ( void )
|
|
{
|
|
return m_pLogService;
|
|
}
|
|
|
|
DWORD
|
|
CSmLogQuery::GetMachineDisplayName ( CString& rstrMachineName )
|
|
{
|
|
DWORD dwStatus = ERROR_SUCCESS;
|
|
|
|
// rstrMachineName is writable. CString copy-on-write
|
|
// semantics will support a writable string created from read-only.
|
|
// A new string data buffer is allocated the first time that
|
|
// it is modified.
|
|
|
|
MFC_TRY
|
|
rstrMachineName = m_pLogService->GetMachineDisplayName();
|
|
MFC_CATCH_DWSTATUS
|
|
|
|
return dwStatus;
|
|
}
|
|
|
|
//
|
|
// Get log file type and return as a string
|
|
//
|
|
//
|
|
const CString&
|
|
CSmLogQuery::GetLogFileType( void )
|
|
{
|
|
int nStringIdx;
|
|
|
|
ResourceStateManager rsm;
|
|
|
|
m_strLogFileType.Empty();
|
|
|
|
switch (LOWORD(mr_dwLogFileType)) {
|
|
case SLF_CSV_FILE:
|
|
nStringIdx = IDS_FT_CSV;
|
|
break;
|
|
|
|
case SLF_TSV_FILE:
|
|
nStringIdx = IDS_FT_TSV;
|
|
break;
|
|
|
|
case SLF_BIN_FILE:
|
|
nStringIdx = IDS_FT_BINARY;
|
|
break;
|
|
|
|
case SLF_BIN_CIRC_FILE:
|
|
nStringIdx = IDS_FT_BINARY_CIRCULAR;
|
|
break;
|
|
|
|
case SLF_SEQ_TRACE_FILE:
|
|
nStringIdx = IDS_FT_SEQUENTIAL_TRACE;
|
|
break;
|
|
|
|
case SLF_CIRC_TRACE_FILE:
|
|
nStringIdx = IDS_FT_CIRCULAR_TRACE;
|
|
break;
|
|
|
|
case SLF_SQL_LOG:
|
|
nStringIdx = IDS_FT_SQL;
|
|
break;
|
|
|
|
default:
|
|
nStringIdx = IDS_FT_UNKNOWN;
|
|
break;
|
|
}
|
|
|
|
MFC_TRY
|
|
m_strLogFileType.LoadString ( nStringIdx );
|
|
MFC_CATCH_MINIMUM
|
|
|
|
return m_strLogFileType;
|
|
}
|
|
|
|
void
|
|
CSmLogQuery::GetLogFileType ( DWORD& rdwFileType )
|
|
{
|
|
rdwFileType = LOWORD(mr_dwLogFileType);
|
|
return;
|
|
}
|
|
|
|
void
|
|
CSmLogQuery::GetDataStoreAppendMode(DWORD &rdwAppend)
|
|
{
|
|
rdwAppend = mr_dwAppendMode;
|
|
|
|
return;
|
|
}
|
|
|
|
void
|
|
CSmLogQuery::SetDataStoreAppendMode(DWORD dwAppend)
|
|
{
|
|
mr_dwAppendMode = dwAppend;
|
|
|
|
return;
|
|
}
|
|
//
|
|
// Get log file name currently in use
|
|
//
|
|
//
|
|
const CString&
|
|
CSmLogQuery::GetLogFileName ( BOOL bLatestRunning )
|
|
{
|
|
HRESULT hr = NOERROR;
|
|
PPDH_PLA_INFO pInfo = NULL;
|
|
DWORD dwStrBufLen = 0;
|
|
DWORD dwFlags = 0;
|
|
CString strMachineName;
|
|
|
|
m_strFileName.Empty();
|
|
|
|
MFC_TRY
|
|
strMachineName = m_pLogService->GetMachineName();
|
|
MFC_CATCH_HR;
|
|
|
|
// Todo: dwStatus or hr?
|
|
|
|
if ( SUCCEEDED ( hr ) ) {
|
|
if ( bLatestRunning ) {
|
|
dwFlags = PLA_FILENAME_CURRENTLOG; // Latest running log
|
|
}
|
|
|
|
hr = PdhPlaGetLogFileName (
|
|
(LPTSTR)(LPCTSTR)GetLogName(),
|
|
(LPTSTR)(LPCTSTR)strMachineName,
|
|
NULL,
|
|
dwFlags,
|
|
&dwStrBufLen,
|
|
NULL );
|
|
|
|
if ( SUCCEEDED ( hr ) || PDH_INSUFFICIENT_BUFFER == hr ) {
|
|
if ( bLatestRunning ) {
|
|
dwFlags = PLA_FILENAME_CURRENTLOG; // Latest running log
|
|
}
|
|
hr = PdhPlaGetLogFileName (
|
|
(LPTSTR)(LPCTSTR)GetLogName(),
|
|
(LPTSTR)(LPCTSTR)strMachineName,
|
|
NULL,
|
|
dwFlags,
|
|
&dwStrBufLen,
|
|
m_strFileName.GetBufferSetLength ( dwStrBufLen ) );
|
|
m_strFileName.ReleaseBuffer();
|
|
}
|
|
}
|
|
|
|
SetLastError ( hr );
|
|
|
|
return m_strFileName;
|
|
}
|
|
|
|
//
|
|
// Get log file name currently in use
|
|
//
|
|
//
|
|
DWORD
|
|
CSmLogQuery::GetLogFileName ( CString& rstrLogFileName )
|
|
{
|
|
DWORD dwStatus = ERROR_SUCCESS;
|
|
|
|
MFC_TRY
|
|
rstrLogFileName = GetLogFileName();
|
|
MFC_CATCH_DWSTATUS
|
|
|
|
return dwStatus;
|
|
}
|
|
|
|
DWORD
|
|
CSmLogQuery::GetLogType ( void )
|
|
{
|
|
// Subclass must override
|
|
ASSERT ( FALSE );
|
|
|
|
return ((DWORD)-1);
|
|
}
|
|
|
|
BOOL
|
|
CSmLogQuery::SetLogFileType ( const DWORD dwType )
|
|
{
|
|
DWORD dwLogFileType = LOWORD(dwType);
|
|
if (dwLogFileType < (SLF_FIRST_FILE_TYPE + SLF_NUM_FILE_TYPES)) {
|
|
mr_dwLogFileType = dwLogFileType;
|
|
return TRUE;
|
|
} else {
|
|
return FALSE;
|
|
}
|
|
}
|
|
|
|
const CString&
|
|
CSmLogQuery::GetLogName()
|
|
{
|
|
return m_strName;
|
|
}
|
|
|
|
DWORD
|
|
CSmLogQuery::GetLogName ( CString& rstrLogName )
|
|
{
|
|
DWORD dwStatus = ERROR_SUCCESS;
|
|
|
|
MFC_TRY
|
|
rstrLogName = GetLogName();
|
|
MFC_CATCH_DWSTATUS
|
|
|
|
return dwStatus;
|
|
}
|
|
|
|
DWORD
|
|
CSmLogQuery::SetLogName ( const CString& rstrLogName )
|
|
{
|
|
DWORD dwStatus = ERROR_SUCCESS;
|
|
|
|
MFC_TRY
|
|
m_strName = rstrLogName;
|
|
MFC_CATCH_DWSTATUS
|
|
|
|
return dwStatus;
|
|
}
|
|
|
|
const CString&
|
|
CSmLogQuery::GetLogKeyName()
|
|
{
|
|
return mr_strLogKeyName;
|
|
}
|
|
|
|
DWORD
|
|
CSmLogQuery::GetLogKeyName ( CString& rstrLogKeyName )
|
|
{
|
|
DWORD dwStatus = ERROR_SUCCESS;
|
|
|
|
MFC_TRY
|
|
rstrLogKeyName = GetLogKeyName();
|
|
MFC_CATCH_DWSTATUS
|
|
|
|
return dwStatus;
|
|
}
|
|
|
|
DWORD
|
|
CSmLogQuery::SetLogKeyName ( const CString& rstrLogKeyName )
|
|
{
|
|
DWORD dwStatus = ERROR_SUCCESS;
|
|
|
|
MFC_TRY
|
|
mr_strLogKeyName = rstrLogKeyName;
|
|
MFC_CATCH_DWSTATUS
|
|
|
|
return dwStatus;
|
|
}
|
|
|
|
DWORD
|
|
CSmLogQuery::GetEofCommand ( CString& rstrCmdString)
|
|
{
|
|
DWORD dwStatus = ERROR_SUCCESS;
|
|
|
|
MFC_TRY
|
|
rstrCmdString = mr_strEofCmdFile;
|
|
MFC_CATCH_DWSTATUS
|
|
|
|
return dwStatus;
|
|
}
|
|
|
|
DWORD
|
|
CSmLogQuery::SetEofCommand ( const CString& rstrCmdString )
|
|
{
|
|
DWORD dwStatus = ERROR_SUCCESS;
|
|
|
|
MFC_TRY
|
|
mr_strEofCmdFile = rstrCmdString;
|
|
MFC_CATCH_DWSTATUS
|
|
|
|
return dwStatus;
|
|
}
|
|
|
|
const CString&
|
|
CSmLogQuery::GetLogComment()
|
|
{
|
|
return mr_strComment;
|
|
}
|
|
|
|
DWORD
|
|
CSmLogQuery::GetLogComment ( CString& rstrLogComment )
|
|
{
|
|
DWORD dwStatus = ERROR_SUCCESS;
|
|
|
|
MFC_TRY
|
|
rstrLogComment = GetLogComment();
|
|
MFC_CATCH_DWSTATUS
|
|
|
|
return dwStatus;
|
|
}
|
|
|
|
DWORD
|
|
CSmLogQuery::SetLogComment ( const CString& rstrComment )
|
|
{
|
|
DWORD dwStatus = ERROR_SUCCESS;
|
|
|
|
MFC_TRY
|
|
mr_strComment = rstrComment;
|
|
MFC_CATCH_DWSTATUS
|
|
|
|
return dwStatus;
|
|
}
|
|
|
|
DWORD
|
|
CSmLogQuery::SetLogCommentIndirect ( const CString& rstrComment )
|
|
{
|
|
DWORD dwStatus = ERROR_SUCCESS;
|
|
|
|
MFC_TRY
|
|
mr_strCommentIndirect = rstrComment;
|
|
MFC_CATCH_DWSTATUS
|
|
|
|
return dwStatus;
|
|
}
|
|
|
|
DWORD
|
|
CSmLogQuery::SetLogFileName ( const CString& rstrFileName )
|
|
{
|
|
DWORD dwStatus = ERROR_SUCCESS;
|
|
|
|
MFC_TRY
|
|
mr_strBaseFileName = rstrFileName;
|
|
MFC_CATCH_DWSTATUS
|
|
|
|
return dwStatus;
|
|
}
|
|
|
|
DWORD
|
|
CSmLogQuery::SetLogFileNameIndirect ( const CString& rstrFileName )
|
|
{
|
|
DWORD dwStatus = ERROR_SUCCESS;
|
|
|
|
MFC_TRY
|
|
mr_strBaseFileNameIndirect = rstrFileName;
|
|
MFC_CATCH_DWSTATUS
|
|
|
|
return dwStatus;
|
|
}
|
|
|
|
DWORD
|
|
CSmLogQuery::SetFileNameParts ( const CString& rstrFolder, const CString& rstrName )
|
|
{
|
|
DWORD dwStatus = ERROR_SUCCESS;
|
|
|
|
MFC_TRY
|
|
mr_strBaseFileName = rstrFolder;
|
|
mr_strDefaultDirectory = rstrName;
|
|
MFC_CATCH_DWSTATUS
|
|
|
|
return dwStatus;
|
|
}
|
|
|
|
DWORD
|
|
CSmLogQuery::GetMaxSize()
|
|
{
|
|
return mr_dwMaxSize;
|
|
}
|
|
|
|
BOOL
|
|
CSmLogQuery::SetMaxSize ( const DWORD dwMaxSize )
|
|
{
|
|
mr_dwMaxSize = dwMaxSize;
|
|
return TRUE;
|
|
}
|
|
|
|
HKEY
|
|
CSmLogQuery::GetQueryKey ( void )
|
|
{
|
|
return m_hKeyQuery;
|
|
}
|
|
|
|
const CString&
|
|
CSmLogQuery::GetSqlName()
|
|
{
|
|
return mr_strSqlName;
|
|
}
|
|
|
|
DWORD
|
|
CSmLogQuery::GetSqlName ( CString& rstrSqlName )
|
|
{
|
|
DWORD dwStatus = ERROR_SUCCESS;
|
|
|
|
MFC_TRY
|
|
rstrSqlName = GetSqlName();
|
|
MFC_CATCH_DWSTATUS
|
|
|
|
return dwStatus;
|
|
}
|
|
|
|
DWORD
|
|
CSmLogQuery::SetSqlName ( const CString& rstrSqlName )
|
|
{
|
|
DWORD dwStatus = ERROR_SUCCESS;
|
|
|
|
MFC_TRY
|
|
mr_strSqlName = rstrSqlName;
|
|
MFC_CATCH_DWSTATUS
|
|
|
|
return dwStatus;
|
|
}
|
|
|
|
//
|
|
// return: 1 if the log is currently active or
|
|
// 0 if the log is not running
|
|
//
|
|
BOOL
|
|
CSmLogQuery::IsRunning()
|
|
{
|
|
DWORD dwCurrentState = SLQ_QUERY_START_PENDING;
|
|
DWORD dwTimeout = 20;
|
|
|
|
while (--dwTimeout) {
|
|
dwCurrentState = GetState();
|
|
if ( SLQ_QUERY_START_PENDING == dwCurrentState ) {
|
|
Sleep(100);
|
|
} else {
|
|
break;
|
|
}
|
|
}
|
|
|
|
return ( SLQ_QUERY_RUNNING == dwCurrentState );
|
|
}
|
|
|
|
BOOL
|
|
CSmLogQuery::IsAutoStart()
|
|
{
|
|
return ( SLQ_AUTO_MODE_NONE != mr_stiStart.dwAutoMode );
|
|
}
|
|
|
|
BOOL
|
|
CSmLogQuery::IsAutoRestart()
|
|
{
|
|
return ( SLQ_AUTO_MODE_AFTER == mr_dwAutoRestartMode );
|
|
}
|
|
|
|
DWORD
|
|
CSmLogQuery::GetFileNameParts( CString& rstrFolder, CString& rstrName)
|
|
{
|
|
DWORD dwStatus = ERROR_SUCCESS;
|
|
|
|
MFC_TRY
|
|
rstrFolder = mr_strDefaultDirectory;
|
|
rstrName = mr_strBaseFileName;
|
|
MFC_CATCH_DWSTATUS
|
|
|
|
return dwStatus;
|
|
}
|
|
|
|
DWORD
|
|
CSmLogQuery::GetFileNameAutoFormat()
|
|
{
|
|
return mr_dwLogAutoFormat;
|
|
}
|
|
|
|
BOOL
|
|
CSmLogQuery::SetFileNameAutoFormat ( const DWORD dwFileSuffix )
|
|
{
|
|
if ((dwFileSuffix < ( SLF_NAME_FIRST_AUTO + SLF_NUM_AUTO_NAME_TYPES)) ||
|
|
(dwFileSuffix == SLF_NAME_NONE)) {
|
|
mr_dwLogAutoFormat = dwFileSuffix;
|
|
return TRUE;
|
|
}
|
|
|
|
return FALSE;
|
|
}
|
|
|
|
DWORD
|
|
CSmLogQuery::GetFileSerialNumber( void )
|
|
{
|
|
SyncSerialNumberWithRegistry();
|
|
return mr_dwCurrentSerialNumber;
|
|
}
|
|
|
|
BOOL
|
|
CSmLogQuery::SetFileSerialNumber ( const DWORD dwSerial )
|
|
{
|
|
mr_dwCurrentSerialNumber = dwSerial;
|
|
return TRUE;
|
|
}
|
|
|
|
|
|
DWORD
|
|
CSmLogQuery::GetState()
|
|
{
|
|
DWORD dwCurrentState = SLQ_QUERY_STOPPED;
|
|
|
|
// If the service is running, get the value from the registry.
|
|
if ( m_pLogService->IsRunning() ) {
|
|
|
|
DWORD dwStatus;
|
|
dwStatus = ReadRegistryDwordValue (
|
|
m_hKeyQuery,
|
|
IDS_REG_CURRENT_STATE,
|
|
SLQ_QUERY_STOPPED,
|
|
&mr_dwCurrentState);
|
|
ASSERT (dwStatus == ERROR_SUCCESS);
|
|
dwCurrentState = mr_dwCurrentState;
|
|
|
|
}
|
|
|
|
return dwCurrentState;
|
|
}
|
|
|
|
|
|
BOOL
|
|
CSmLogQuery::SetState ( const DWORD dwNewState )
|
|
{
|
|
// Only use this to set the start state. This is necessary
|
|
// so that the service, at service startup, can differentiate
|
|
// between previously running queries and newly requested query starts.
|
|
ASSERT ( SLQ_QUERY_START_PENDING == dwNewState );
|
|
|
|
// Set the local variable if it is different.
|
|
if ( mr_dwCurrentState != dwNewState ) {
|
|
mr_dwCurrentState = dwNewState;
|
|
}
|
|
return TRUE;
|
|
}
|
|
|
|
|
|
BOOL
|
|
CSmLogQuery::GetLogTime(PSLQ_TIME_INFO pTimeInfo, DWORD dwFlags)
|
|
{
|
|
switch (dwFlags) {
|
|
case SLQ_TT_TTYPE_START:
|
|
*pTimeInfo = mr_stiStart;
|
|
return TRUE;
|
|
|
|
case SLQ_TT_TTYPE_STOP:
|
|
*pTimeInfo = mr_stiStop;
|
|
return TRUE;
|
|
|
|
case SLQ_TT_TTYPE_RESTART:
|
|
pTimeInfo->wTimeType = SLQ_TT_TTYPE_RESTART;
|
|
pTimeInfo->dwAutoMode = mr_dwAutoRestartMode;
|
|
pTimeInfo->wDataType = SLQ_TT_DTYPE_UNITS; // not used
|
|
pTimeInfo->dwUnitType = SLQ_TT_UTYPE_MINUTES; // not used
|
|
pTimeInfo->dwValue = 0; // not used
|
|
return TRUE;
|
|
|
|
case SLQ_TT_TTYPE_SAMPLE:
|
|
*pTimeInfo = mr_stiSampleInterval;
|
|
return TRUE;
|
|
|
|
default:
|
|
return FALSE;
|
|
}
|
|
}
|
|
|
|
BOOL
|
|
CSmLogQuery::SetLogTime(PSLQ_TIME_INFO pTimeInfo, const DWORD dwFlags)
|
|
{
|
|
ASSERT (pTimeInfo->wTimeType == dwFlags);
|
|
|
|
switch (dwFlags) {
|
|
case SLQ_TT_TTYPE_START:
|
|
mr_stiStart = *pTimeInfo ;
|
|
return TRUE;
|
|
|
|
case SLQ_TT_TTYPE_STOP:
|
|
mr_stiStop = *pTimeInfo;
|
|
return TRUE;
|
|
|
|
case SLQ_TT_TTYPE_RESTART:
|
|
mr_dwAutoRestartMode = pTimeInfo->dwAutoMode;
|
|
return TRUE;
|
|
|
|
case SLQ_TT_TTYPE_SAMPLE:
|
|
mr_stiSampleInterval = *pTimeInfo;
|
|
return TRUE;
|
|
|
|
default:
|
|
return FALSE;
|
|
}
|
|
}
|
|
|
|
BOOL
|
|
CSmLogQuery::GetDefaultLogTime(SLQ_TIME_INFO& /*rTimeInfo*/, DWORD /*dwFlags*/)
|
|
{
|
|
// Subclass must override
|
|
ASSERT( FALSE );
|
|
return FALSE;
|
|
}
|
|
|
|
void
|
|
CSmLogQuery::SyncPropPageSharedData ( void )
|
|
{
|
|
// Sync the data shared between property pages
|
|
// from registry values.
|
|
MFC_TRY
|
|
m_PropData.dwMaxFileSize = mr_dwMaxSize;
|
|
m_PropData.dwLogFileType = LOWORD(mr_dwLogFileType);
|
|
m_PropData.strFolderName = mr_strDefaultDirectory;
|
|
|
|
m_PropData.strFileBaseName = mr_strBaseFileName;
|
|
m_PropData.strSqlName = mr_strSqlName;
|
|
m_PropData.dwSuffix = mr_dwLogAutoFormat;
|
|
SyncSerialNumberWithRegistry();
|
|
m_PropData.dwSerialNumber = mr_dwCurrentSerialNumber;
|
|
m_PropData.stiStartTime = mr_stiStart;
|
|
m_PropData.stiStopTime = mr_stiStop;
|
|
m_PropData.stiSampleTime = mr_stiSampleInterval;
|
|
MFC_CATCH_MINIMUM
|
|
// Todo: Return and use status
|
|
}
|
|
|
|
void
|
|
CSmLogQuery::UpdatePropPageSharedData ( void )
|
|
{
|
|
// Update the registry values for data shared between property pages.
|
|
// Note: This is called by the property page OnApply code. It is assumed
|
|
// that OnApply is called for all property pages, so the shared data is valid.
|
|
|
|
// This method handles the problem where default Start mode and time was
|
|
// written to the registry by the counter page OnApply before the
|
|
// schedule page OnApply modified the value.
|
|
MFC_TRY
|
|
mr_dwMaxSize = m_PropData.dwMaxFileSize;
|
|
mr_dwLogFileType = m_PropData.dwLogFileType;
|
|
|
|
mr_dwLogAutoFormat = m_PropData.dwSuffix;
|
|
mr_dwCurrentSerialNumber = m_PropData.dwSerialNumber;
|
|
mr_stiStart = m_PropData.stiStartTime;
|
|
mr_stiStop = m_PropData.stiStopTime;
|
|
mr_stiSampleInterval = m_PropData.stiSampleTime;
|
|
|
|
mr_strBaseFileName = m_PropData.strFileBaseName;
|
|
mr_strDefaultDirectory = m_PropData.strFolderName;
|
|
mr_strSqlName = m_PropData.strSqlName;
|
|
MFC_CATCH_MINIMUM
|
|
// Todo: Return and use status
|
|
}
|
|
|
|
BOOL
|
|
CSmLogQuery::GetPropPageSharedData (PSLQ_PROP_PAGE_SHARED pData)
|
|
{
|
|
BOOL bReturn = FALSE;
|
|
|
|
if ( NULL != pData ) {
|
|
MFC_TRY
|
|
pData->dwLogFileType = m_PropData.dwLogFileType;
|
|
pData->dwMaxFileSize = m_PropData.dwMaxFileSize;
|
|
pData->strFileBaseName = m_PropData.strFileBaseName;
|
|
pData->strFolderName = m_PropData.strFolderName;
|
|
pData->strSqlName = m_PropData.strSqlName;
|
|
pData->dwLogFileType = m_PropData.dwLogFileType;
|
|
pData->dwSuffix = m_PropData.dwSuffix;
|
|
pData->dwSerialNumber = m_PropData.dwSerialNumber;
|
|
pData->stiStartTime = m_PropData.stiStartTime;
|
|
pData->stiStopTime = m_PropData.stiStopTime;
|
|
pData->stiSampleTime = m_PropData.stiSampleTime;
|
|
bReturn = TRUE;
|
|
MFC_CATCH_MINIMUM
|
|
}
|
|
// Todo: Return and use status
|
|
return bReturn;
|
|
}
|
|
|
|
BOOL
|
|
CSmLogQuery::SetPropPageSharedData (PSLQ_PROP_PAGE_SHARED pData)
|
|
{
|
|
BOOL bReturn = FALSE;
|
|
|
|
if ( NULL != pData ) {
|
|
MFC_TRY
|
|
m_PropData.dwLogFileType = pData->dwLogFileType;
|
|
m_PropData.dwMaxFileSize = pData->dwMaxFileSize;
|
|
m_PropData.strFileBaseName = pData->strFileBaseName;
|
|
m_PropData.strFolderName = pData->strFolderName;
|
|
m_PropData.strSqlName = pData->strSqlName;
|
|
m_PropData.dwLogFileType = pData->dwLogFileType;
|
|
m_PropData.dwSuffix = pData->dwSuffix;
|
|
m_PropData.dwSerialNumber = pData->dwSerialNumber;
|
|
m_PropData.stiStartTime = pData->stiStartTime;
|
|
m_PropData.stiStopTime = pData->stiStopTime;
|
|
m_PropData.stiSampleTime = pData->stiSampleTime;
|
|
MFC_CATCH_MINIMUM
|
|
}
|
|
// Todo: Return and use status
|
|
return bReturn;
|
|
}
|
|
|
|
void
|
|
CSmLogQuery::InitDataStoreAttributesDefault (
|
|
const DWORD dwRegLogFileType,
|
|
DWORD& rdwDefault )
|
|
{
|
|
DWORD dwBeta1AppendFlags;
|
|
DWORD dwLogFileType;
|
|
|
|
// Append vs. Overwrite
|
|
// Win2000 files defaulted to OVERWRITE.
|
|
// The Append mode flags did not exist.
|
|
// Convert the settings to use new flags.
|
|
// Whistler Beta 1 append mode was stored in high word of log file type
|
|
|
|
dwBeta1AppendFlags = dwRegLogFileType & 0x00FF0000;
|
|
rdwDefault = 0;
|
|
|
|
GetLogFileType ( dwLogFileType );
|
|
|
|
if ( SLF_FILE_APPEND == dwBeta1AppendFlags ) {
|
|
mr_dwAppendMode = SLF_DATA_STORE_APPEND;
|
|
rdwDefault = SLF_DATA_STORE_APPEND;
|
|
} else if ( SLF_FILE_OVERWRITE == dwBeta1AppendFlags ) {
|
|
mr_dwAppendMode = SLF_DATA_STORE_OVERWRITE;
|
|
rdwDefault = SLF_DATA_STORE_OVERWRITE;
|
|
} else if ( 0 == dwBeta1AppendFlags ) {
|
|
if ( SLF_SQL_LOG == dwLogFileType ) {
|
|
mr_dwAppendMode = SLF_DATA_STORE_APPEND;
|
|
} else {
|
|
// Default for Win2K is overwrite.
|
|
// For Whistler, mode is stored in Data Store Attributes
|
|
mr_dwAppendMode = SLF_DATA_STORE_OVERWRITE;
|
|
}
|
|
}
|
|
|
|
// Append vs. overwrite flag
|
|
|
|
if ( 0 == rdwDefault ) {
|
|
if ( SLF_BIN_FILE == dwLogFileType
|
|
|| SLF_SEQ_TRACE_FILE == dwLogFileType
|
|
|| SLF_SQL_LOG == dwLogFileType )
|
|
{
|
|
rdwDefault = SLF_DATA_STORE_APPEND;
|
|
} else {
|
|
rdwDefault = SLF_DATA_STORE_OVERWRITE;
|
|
}
|
|
}
|
|
|
|
// File size units flag
|
|
|
|
if ( SLQ_COUNTER_LOG == GetLogType() ) {
|
|
if ( SLF_SQL_LOG != dwLogFileType ) {
|
|
rdwDefault |= SLF_DATA_STORE_SIZE_ONE_KB;
|
|
} else {
|
|
rdwDefault |= SLF_DATA_STORE_SIZE_ONE_RECORD;
|
|
}
|
|
} else if ( SLQ_TRACE_LOG == GetLogType() ){
|
|
rdwDefault |= SLF_DATA_STORE_SIZE_ONE_MB;
|
|
}
|
|
}
|
|
|
|
void
|
|
CSmLogQuery::ProcessLoadedDataStoreAttributes (
|
|
DWORD dwDataStoreAttributes )
|
|
{
|
|
DWORD dwLogFileType = 0;
|
|
|
|
if ( dwDataStoreAttributes & SLF_DATA_STORE_SIZE_ONE_MB ) {
|
|
mr_dwFileSizeUnits = ONE_MB;
|
|
} else if ( dwDataStoreAttributes & SLF_DATA_STORE_SIZE_ONE_KB ) {
|
|
mr_dwFileSizeUnits = ONE_KB;
|
|
} else if ( dwDataStoreAttributes & SLF_DATA_STORE_SIZE_ONE_RECORD ) {
|
|
mr_dwFileSizeUnits = ONE_RECORD;
|
|
}
|
|
// Within the app, counter data store size units are in MB.
|
|
// Translate to MB here, back to KB when write to registry.
|
|
GetLogFileType( dwLogFileType );
|
|
|
|
if ( SLQ_COUNTER_LOG == GetLogType()
|
|
&& SLF_SQL_LOG != dwLogFileType )
|
|
{
|
|
ASSERT ( ONE_KB == GetDataStoreSizeUnits() );
|
|
if ( ONE_KB == GetDataStoreSizeUnits() ) {
|
|
mr_dwFileSizeUnits = ONE_MB;
|
|
if ( SLQ_DISK_MAX_SIZE != mr_dwMaxSize ) {
|
|
// Round up to next MB
|
|
mr_dwMaxSize = ( mr_dwMaxSize + (ONE_KB - 1) ) / ONE_KB;
|
|
}
|
|
}
|
|
}
|
|
|
|
// Data store append mode
|
|
|
|
ASSERT ( dwDataStoreAttributes & SLF_DATA_STORE_APPEND_MASK );
|
|
// Todo: Does defalt value setting overwrite the Whistler Beta 1 setting?
|
|
|
|
if ( dwDataStoreAttributes & SLF_DATA_STORE_APPEND ) {
|
|
mr_dwAppendMode = SLF_DATA_STORE_APPEND;
|
|
} else if ( dwDataStoreAttributes & SLF_DATA_STORE_OVERWRITE ) {
|
|
mr_dwAppendMode = SLF_DATA_STORE_OVERWRITE;
|
|
}
|
|
}
|
|
|
|
HRESULT
|
|
CSmLogQuery::LoadFromPropertyBag (
|
|
IPropertyBag* pPropBag,
|
|
IErrorLog* pIErrorLog )
|
|
{
|
|
HRESULT hr = S_OK;
|
|
DWORD dwBufSize;
|
|
SLQ_TIME_INFO stiDefault;
|
|
LPTSTR pszTemp = NULL;
|
|
DWORD dwTemp;
|
|
DWORD dwDefault;
|
|
TCHAR szDefault[MAX_PATH + 1];
|
|
LPTSTR szEofCmd = NULL;
|
|
|
|
// Subclass must call this method at the end of their override, to sync the
|
|
// property page shared data.
|
|
|
|
// Continue even if error, using defaults for missing values.
|
|
mr_strComment.Empty();
|
|
dwBufSize = 0;
|
|
hr = StringFromPropertyBag ( pPropBag, pIErrorLog, IDS_HTML_COMMENT, DEFAULT_COMMENT, &pszTemp, &dwBufSize );
|
|
if ( sizeof(TCHAR) < dwBufSize ) {
|
|
ASSERT ( NULL != pszTemp );
|
|
ASSERT ( 0 != *pszTemp );
|
|
mr_strComment = pszTemp;
|
|
}
|
|
delete ( pszTemp );
|
|
pszTemp = NULL;
|
|
|
|
lstrcpynW ( szDefault, m_strName , min ( MAX_PATH + 1, m_strName.GetLength() + 1 ) );
|
|
szDefault[MAX_PATH] = L'\0';
|
|
ReplaceBlanksWithUnderscores ( szDefault );
|
|
|
|
mr_strBaseFileName.Empty();
|
|
dwBufSize = 0;
|
|
hr = StringFromPropertyBag (
|
|
pPropBag,
|
|
pIErrorLog,
|
|
IDS_HTML_LOG_FILE_BASE_NAME,
|
|
szDefault,
|
|
&pszTemp,
|
|
&dwBufSize );
|
|
if ( sizeof(TCHAR) < dwBufSize ) {
|
|
ASSERT ( NULL != pszTemp );
|
|
ASSERT ( 0 != *pszTemp );
|
|
mr_strBaseFileName = pszTemp;
|
|
}
|
|
delete ( pszTemp );
|
|
pszTemp = NULL;
|
|
|
|
mr_strDefaultDirectory.Empty();
|
|
dwBufSize = 0;
|
|
hr = StringFromPropertyBag (
|
|
pPropBag,
|
|
pIErrorLog,
|
|
IDS_HTML_LOG_FILE_FOLDER,
|
|
m_pLogService->GetDefaultLogFileFolder(),
|
|
&pszTemp,
|
|
&dwBufSize );
|
|
|
|
if ( sizeof(TCHAR) < dwBufSize ) {
|
|
ASSERT ( NULL != pszTemp );
|
|
ASSERT ( 0 != *pszTemp );
|
|
mr_strDefaultDirectory = pszTemp;
|
|
}
|
|
delete ( pszTemp );
|
|
pszTemp = NULL;
|
|
|
|
mr_strSqlName.Empty();
|
|
dwBufSize = 0;
|
|
hr = StringFromPropertyBag (
|
|
pPropBag,
|
|
pIErrorLog,
|
|
IDS_HTML_SQL_LOG_BASE_NAME,
|
|
DEFAULT_SQL_LOG_BASE_NAME,
|
|
&pszTemp,
|
|
&dwBufSize );
|
|
if ( sizeof(TCHAR) < dwBufSize ) {
|
|
ASSERT ( NULL != pszTemp );
|
|
ASSERT ( 0 != *pszTemp );
|
|
mr_strSqlName = pszTemp;
|
|
}
|
|
delete ( pszTemp );
|
|
pszTemp = NULL;
|
|
|
|
|
|
hr = DwordFromPropertyBag ( pPropBag, pIErrorLog, IDS_HTML_REALTIME_DATASOURCE, g_dwRealTimeQuery, mr_dwRealTimeQuery );
|
|
|
|
hr = DwordFromPropertyBag ( pPropBag, pIErrorLog, IDS_HTML_LOG_FILE_MAX_SIZE, DEFAULT_LOG_FILE_MAX_SIZE, mr_dwMaxSize );
|
|
|
|
if ( SLQ_COUNTER_LOG == GetLogType() ) {
|
|
hr = DwordFromPropertyBag ( pPropBag, pIErrorLog, IDS_HTML_LOG_FILE_TYPE, DEFAULT_CTR_LOG_FILE_TYPE, dwTemp );
|
|
} else {
|
|
// Read only for counter and trace logs, not for alerts?
|
|
hr = DwordFromPropertyBag ( pPropBag, pIErrorLog, IDS_HTML_LOG_FILE_TYPE, DEFAULT_TRACE_LOG_FILE_TYPE, dwTemp );
|
|
}
|
|
|
|
SetLogFileType ( dwTemp );
|
|
|
|
// Data store attributes must be read after log file type and log file max size.
|
|
InitDataStoreAttributesDefault ( dwTemp, dwDefault );
|
|
|
|
// If file size unit value is missing, default to Win2000 values
|
|
hr = DwordFromPropertyBag ( pPropBag, pIErrorLog, IDS_HTML_DATA_STORE_ATTRIBUTES, dwDefault, dwTemp );
|
|
|
|
ProcessLoadedDataStoreAttributes ( dwTemp );
|
|
|
|
hr = DwordFromPropertyBag ( pPropBag, pIErrorLog, IDS_HTML_LOG_FILE_AUTO_FORMAT, DEFAULT_LOG_FILE_AUTO_FORMAT, mr_dwLogAutoFormat );
|
|
hr = DwordFromPropertyBag ( pPropBag, pIErrorLog, IDS_HTML_LOG_FILE_SERIAL_NUMBER, DEFAULT_LOG_FILE_SERIAL_NUMBER, mr_dwCurrentSerialNumber );
|
|
|
|
// Do not load "Current State", since a new query is always stopped when created.
|
|
|
|
// Start and Stop values.
|
|
VERIFY ( GetDefaultLogTime (stiDefault, SLQ_TT_TTYPE_START ) );
|
|
hr = SlqTimeFromPropertyBag ( pPropBag, pIErrorLog, SLQ_TT_TTYPE_START, &stiDefault, &mr_stiStart );
|
|
VERIFY ( GetDefaultLogTime (stiDefault, SLQ_TT_TTYPE_STOP ) );
|
|
hr = SlqTimeFromPropertyBag ( pPropBag, pIErrorLog, SLQ_TT_TTYPE_STOP, &stiDefault, &mr_stiStop );
|
|
hr = DwordFromPropertyBag ( pPropBag, pIErrorLog, IDS_HTML_RESTART_MODE, DEFAULT_RESTART_VALUE, mr_dwAutoRestartMode);
|
|
|
|
// Eof command file for counter and trace logs only.
|
|
if ( SLQ_COUNTER_LOG == GetLogType()
|
|
|| SLQ_TRACE_LOG == GetLogType() ) {
|
|
|
|
mr_strEofCmdFile.Empty();
|
|
dwBufSize = 0;
|
|
|
|
hr = StringFromPropertyBag (
|
|
pPropBag,
|
|
pIErrorLog,
|
|
IDS_HTML_EOF_COMMAND_FILE,
|
|
DEFAULT_EOF_COMMAND_FILE,
|
|
&szEofCmd,
|
|
&dwBufSize );
|
|
|
|
if ( sizeof(TCHAR) < dwBufSize ) {
|
|
ASSERT ( NULL != szEofCmd );
|
|
MFC_TRY
|
|
mr_strEofCmdFile = szEofCmd;
|
|
MFC_CATCH_MINIMUM
|
|
}
|
|
|
|
if ( NULL != szEofCmd ) {
|
|
delete (szEofCmd);
|
|
}
|
|
}
|
|
|
|
SyncPropPageSharedData();
|
|
|
|
return hr;
|
|
}
|
|
|
|
HRESULT
|
|
CSmLogQuery::SaveToPropertyBag (
|
|
IPropertyBag* pPropBag,
|
|
BOOL /* fSaveAllProps */ )
|
|
{
|
|
HRESULT hr = NOERROR;
|
|
SMONCTRL_VERSION_DATA VersData;
|
|
DWORD dwTemp;
|
|
DWORD dwTempFileSizeUnits;
|
|
DWORD dwTempDataStoreAttributes = 0;
|
|
DWORD dwTempMaxFileSize;
|
|
DWORD dwTempAppendMode;
|
|
DWORD dwLogFileType = 0;
|
|
|
|
VersData.iMajor = SMONCTRL_MAJ_VERSION;
|
|
VersData.iMinor = SMONCTRL_MIN_VERSION;
|
|
|
|
hr = DwordToPropertyBag ( pPropBag, IDS_HTML_SYSMON_VERSION, VersData.dwVersion );
|
|
|
|
if ( SLQ_ALERT == GetLogType() ) {
|
|
hr = StringToPropertyBag ( pPropBag, IDS_HTML_ALERT_NAME, m_strName );
|
|
} else {
|
|
hr = StringToPropertyBag ( pPropBag, IDS_HTML_LOG_NAME, m_strName );
|
|
}
|
|
hr = StringToPropertyBag ( pPropBag, IDS_HTML_COMMENT, mr_strComment );
|
|
hr = DwordToPropertyBag ( pPropBag, IDS_HTML_LOG_TYPE, GetLogType() );
|
|
// Save current state. It can be used to determine the validity of the logfilename.
|
|
hr = DwordToPropertyBag ( pPropBag, IDS_HTML_CURRENT_STATE, mr_dwCurrentState );
|
|
|
|
hr = DwordToPropertyBag ( pPropBag, IDS_HTML_REALTIME_DATASOURCE, mr_dwRealTimeQuery );
|
|
|
|
// Within the app, counter data store size units are in MB.
|
|
// Translate to back to KB when write to registry
|
|
dwTempFileSizeUnits = GetDataStoreSizeUnits();
|
|
dwTempMaxFileSize = mr_dwMaxSize;
|
|
GetLogFileType ( dwLogFileType );
|
|
if ( SLQ_COUNTER_LOG == GetLogType()
|
|
&& SLF_SQL_LOG != dwLogFileType )
|
|
{
|
|
if ( ONE_MB == dwTempFileSizeUnits ) {
|
|
dwTempFileSizeUnits = ONE_KB;
|
|
// Round up to next MB
|
|
if ( SLQ_DISK_MAX_SIZE != mr_dwMaxSize ) {
|
|
dwTempMaxFileSize *= dwTempFileSizeUnits;
|
|
}
|
|
}
|
|
}
|
|
|
|
hr = DwordToPropertyBag ( pPropBag, IDS_HTML_LOG_FILE_MAX_SIZE, dwTempMaxFileSize );
|
|
|
|
// Data store size units
|
|
if ( ONE_MB == dwTempFileSizeUnits ) {
|
|
dwTempDataStoreAttributes = SLF_DATA_STORE_SIZE_ONE_MB;
|
|
} else if ( ONE_KB == dwTempFileSizeUnits ) {
|
|
dwTempDataStoreAttributes = SLF_DATA_STORE_SIZE_ONE_KB;
|
|
} else if ( ONE_RECORD == dwTempFileSizeUnits ) {
|
|
dwTempDataStoreAttributes = SLF_DATA_STORE_SIZE_ONE_RECORD;
|
|
}
|
|
|
|
// Data store append mode
|
|
GetDataStoreAppendMode( dwTempAppendMode );
|
|
dwTempDataStoreAttributes |= dwTempAppendMode;
|
|
|
|
hr = DwordToPropertyBag ( pPropBag, IDS_HTML_DATA_STORE_ATTRIBUTES, dwTempDataStoreAttributes );
|
|
|
|
hr = StringToPropertyBag ( pPropBag, IDS_HTML_LOG_FILE_BASE_NAME, mr_strBaseFileName );
|
|
hr = DwordToPropertyBag ( pPropBag, IDS_HTML_LOG_FILE_SERIAL_NUMBER, mr_dwCurrentSerialNumber );
|
|
hr = StringToPropertyBag ( pPropBag, IDS_HTML_LOG_FILE_FOLDER, mr_strDefaultDirectory );
|
|
hr = StringToPropertyBag ( pPropBag, IDS_HTML_SQL_LOG_BASE_NAME, mr_strSqlName );
|
|
hr = DwordToPropertyBag ( pPropBag, IDS_HTML_LOG_FILE_AUTO_FORMAT, mr_dwLogAutoFormat );
|
|
|
|
// Write only for counter and trace logs, not for alerts?
|
|
// Log file type for Alerts is -1, so the new query will keep its default value.
|
|
GetLogFileType ( dwTemp );
|
|
hr = DwordToPropertyBag ( pPropBag, IDS_HTML_LOG_FILE_TYPE, dwTemp );
|
|
hr = SlqTimeToPropertyBag ( pPropBag, SLQ_TT_TTYPE_START, &mr_stiStart );
|
|
hr = SlqTimeToPropertyBag ( pPropBag, SLQ_TT_TTYPE_STOP, &mr_stiStop );
|
|
hr = DwordToPropertyBag ( pPropBag, IDS_HTML_RESTART_MODE, mr_dwAutoRestartMode );
|
|
|
|
hr = StringToPropertyBag ( pPropBag, IDS_HTML_SYSMON_LOGFILENAME, GetLogFileName(TRUE) );
|
|
|
|
// Eof command file for counter and trace logs only.
|
|
if ( SLQ_COUNTER_LOG == GetLogType()
|
|
|| SLQ_TRACE_LOG == GetLogType() ) {
|
|
hr = StringToPropertyBag ( pPropBag, IDS_HTML_EOF_COMMAND_FILE, mr_strEofCmdFile );
|
|
}
|
|
return hr;
|
|
}
|
|
|
|
HRESULT
|
|
CSmLogQuery::CopyToBuffer ( LPTSTR& rpszData, DWORD& rdwBufferSize )
|
|
{
|
|
HRESULT hr;
|
|
CString strHeader;
|
|
CString strFooter;
|
|
CImpIPropertyBag IPropBag;
|
|
DWORD dwBufferLength = 0;
|
|
LPTSTR pszConfig = NULL;
|
|
|
|
ResourceStateManager rsm;
|
|
|
|
ASSERT ( NULL == rpszData );
|
|
rdwBufferSize = 0;
|
|
|
|
hr = SaveToPropertyBag (&IPropBag, TRUE );
|
|
|
|
if ( SUCCEEDED ( hr ) ) {
|
|
MFC_TRY
|
|
pszConfig = IPropBag.GetData();
|
|
if ( NULL != pszConfig ) {
|
|
strHeader.LoadString ( IDS_HTML_OBJECT_HEADER );
|
|
strFooter.LoadString ( IDS_HTML_OBJECT_FOOTER );
|
|
|
|
dwBufferLength = strHeader.GetLength() + strFooter.GetLength() + lstrlen ( pszConfig ) + 1;
|
|
|
|
rpszData = new TCHAR[dwBufferLength];
|
|
} else {
|
|
hr = E_UNEXPECTED;
|
|
}
|
|
MFC_CATCH_HR
|
|
|
|
if ( SUCCEEDED ( hr ) ) {
|
|
rdwBufferSize = dwBufferLength * sizeof(TCHAR);
|
|
|
|
lstrcpy ( rpszData, strHeader );
|
|
lstrcat ( rpszData, pszConfig );
|
|
lstrcat ( rpszData, strFooter );
|
|
}
|
|
}
|
|
|
|
return hr;
|
|
}
|
|
|
|
BOOL
|
|
CSmLogQuery::LLTimeToVariantDate (
|
|
IN LONGLONG llTime,
|
|
OUT DATE *pdate
|
|
)
|
|
{
|
|
SYSTEMTIME SystemTime;
|
|
|
|
if (!FileTimeToSystemTime((FILETIME*)&llTime, &SystemTime))
|
|
return FALSE;
|
|
|
|
if (FAILED(SystemTimeToVariantTime(&SystemTime, pdate)))
|
|
return FALSE;
|
|
|
|
return TRUE;
|
|
}
|
|
|
|
|
|
BOOL
|
|
CSmLogQuery::VariantDateToLLTime (
|
|
IN DATE date,
|
|
OUT LONGLONG *pllTime
|
|
)
|
|
{
|
|
SYSTEMTIME SystemTime;
|
|
|
|
if (FAILED(VariantTimeToSystemTime(date, &SystemTime)))
|
|
return FALSE;
|
|
|
|
if (!SystemTimeToFileTime(&SystemTime,(FILETIME*)pllTime))
|
|
return FALSE;
|
|
|
|
return TRUE;
|
|
}
|
|
|
|
DWORD
|
|
CSmLogQuery::UpdateExecuteOnly( void )
|
|
{
|
|
DWORD dwStatus = ERROR_SUCCESS;
|
|
|
|
if (!m_bReadOnly) {
|
|
|
|
DWORD dwExecuteOnly;
|
|
|
|
dwExecuteOnly = 1; // TRUE
|
|
|
|
dwStatus = WriteRegistryDwordValue (
|
|
m_hKeyQuery,
|
|
IDS_REG_EXECUTE_ONLY,
|
|
&dwExecuteOnly);
|
|
|
|
ASSERT ( ERROR_SUCCESS == dwStatus );
|
|
|
|
if ( ERROR_SUCCESS == dwStatus ) {
|
|
dwStatus = m_pLogService->Synchronize();
|
|
}
|
|
} else {
|
|
dwStatus = ERROR_ACCESS_DENIED;
|
|
}
|
|
|
|
return dwStatus;
|
|
}
|
|
|
|
CWnd*
|
|
CSmLogQuery::GetActivePropertySheet( void )
|
|
{
|
|
CWnd* pwndReturn = NULL;
|
|
|
|
if ( NULL != m_pActivePropPage ) {
|
|
pwndReturn = m_pActivePropPage->GetParentOwner();
|
|
}
|
|
return pwndReturn;
|
|
}
|
|
|
|
void
|
|
CSmLogQuery::SetActivePropertyPage( CSmPropertyPage* pPage)
|
|
{
|
|
// The first property page of each property sheet sets
|
|
// and clears this member variable.
|
|
// It is assumed that the first page is always created.
|
|
m_pActivePropPage = pPage;
|
|
|
|
return;
|
|
}
|
|
|
|
BOOL
|
|
CSmLogQuery::IsFirstModification( void )
|
|
{
|
|
BOOL bIsFirstModification = FALSE;
|
|
bIsFirstModification = ( m_bIsModified && m_bIsNew );
|
|
|
|
if ( bIsFirstModification ) {
|
|
m_bIsNew = FALSE;
|
|
}
|
|
|
|
return bIsFirstModification;
|
|
}
|