// DPNtEventPage.cpp : implementation file // // 03/05/00 v-marfin bug 59643 : Make this the default starting page. // 03/29/00 v-marfin bug 62585 : Set new Data collector's ENABLED to TRUE if user presses OK. // 03/30/00 v-marfin bug 59237 : If user does not change the default name of the data // collector when they first create it, change it for // them to a more meaningful name based on the data // they select in the property pages. #include "stdafx.h" #include "snapin.h" #include "DPNtEventPage.h" #include "HMObject.h" #include "DataElement.h" #include "DataGroupScopeItem.h" #ifdef _DEBUG #define new DEBUG_NEW #undef THIS_FILE static char THIS_FILE[] = __FILE__; #endif ///////////////////////////////////////////////////////////////////////////// // CDPNtEventPage property page IMPLEMENT_DYNCREATE(CDPNtEventPage, CHMPropertyPage) CDPNtEventPage::CDPNtEventPage() : CHMPropertyPage(CDPNtEventPage::IDD) { //{{AFX_DATA_INIT(CDPNtEventPage) m_bCategory = FALSE; m_bError = FALSE; m_bEventID = FALSE; m_bFailure = FALSE; m_bInformation = FALSE; m_bRequireReset = TRUE; m_bSource = FALSE; m_bSuccess = FALSE; m_bUser = FALSE; m_bWarning = FALSE; m_sCategory = _T(""); m_sEventID = _T(""); m_sSource = _T(""); m_sUser = _T(""); m_sLogFile = _T(""); //}}AFX_DATA_INIT m_sHelpTopic = _T("HMon21.chm::/dDEntev.htm"); } CDPNtEventPage::~CDPNtEventPage() { } void CDPNtEventPage::DoDataExchange(CDataExchange* pDX) { CHMPropertyPage::DoDataExchange(pDX); //{{AFX_DATA_MAP(CDPNtEventPage) DDX_Control(pDX, IDC_COMBO_LOG_FILE, m_LogFile); DDX_Check(pDX, IDC_CHECK_CATEGORY, m_bCategory); DDX_Check(pDX, IDC_CHECK_ERROR, m_bError); DDX_Check(pDX, IDC_CHECK_EVENTID, m_bEventID); DDX_Check(pDX, IDC_CHECK_FAILURE, m_bFailure); DDX_Check(pDX, IDC_CHECK_INFORMATION, m_bInformation); DDX_Check(pDX, IDC_CHECK_REQUIRE_RESET, m_bRequireReset); DDX_Check(pDX, IDC_CHECK_SOURCE, m_bSource); DDX_Check(pDX, IDC_CHECK_SUCCESS, m_bSuccess); DDX_Check(pDX, IDC_CHECK_USER, m_bUser); DDX_Check(pDX, IDC_CHECK_WARNING, m_bWarning); DDX_Text(pDX, IDC_EDIT_CATEGORY, m_sCategory); DDX_Text(pDX, IDC_EDIT_EVENTID, m_sEventID); DDX_Text(pDX, IDC_EDIT_SOURCE, m_sSource); DDX_Text(pDX, IDC_EDIT_USER, m_sUser); DDX_CBString(pDX, IDC_COMBO_LOG_FILE, m_sLogFile); //}}AFX_DATA_MAP GetDlgItem(IDC_EDIT_CATEGORY)->EnableWindow(m_bCategory); GetDlgItem(IDC_EDIT_EVENTID)->EnableWindow(m_bEventID); GetDlgItem(IDC_EDIT_SOURCE)->EnableWindow(m_bSource); GetDlgItem(IDC_EDIT_USER)->EnableWindow(m_bUser); } BEGIN_MESSAGE_MAP(CDPNtEventPage, CHMPropertyPage) //{{AFX_MSG_MAP(CDPNtEventPage) ON_WM_DESTROY() ON_BN_CLICKED(IDC_BUTTON_TEST, OnButtonTest) ON_BN_CLICKED(IDC_CHECK_CATEGORY, OnCheckCategory) ON_BN_CLICKED(IDC_CHECK_EVENTID, OnCheckEventid) ON_BN_CLICKED(IDC_CHECK_SOURCE, OnCheckSource) ON_BN_CLICKED(IDC_CHECK_USER, OnCheckUser) ON_BN_CLICKED(IDC_CHECK_ERROR, OnCheckError) ON_BN_CLICKED(IDC_CHECK_FAILURE, OnCheckFailure) ON_BN_CLICKED(IDC_CHECK_INFORMATION, OnCheckInformation) ON_BN_CLICKED(IDC_CHECK_REQUIRE_RESET, OnCheckRequireReset) ON_BN_CLICKED(IDC_CHECK_SUCCESS, OnCheckSuccess) ON_BN_CLICKED(IDC_CHECK_WARNING, OnCheckWarning) ON_CBN_EDITCHANGE(IDC_COMBO_LOG_FILE, OnEditchangeComboLogFile) ON_EN_CHANGE(IDC_EDIT_CATEGORY, OnChangeEditCategory) ON_EN_CHANGE(IDC_EDIT_EVENTID, OnChangeEditEventid) ON_EN_CHANGE(IDC_EDIT_SOURCE, OnChangeEditSource) ON_EN_CHANGE(IDC_EDIT_USER, OnChangeEditUser) //}}AFX_MSG_MAP END_MESSAGE_MAP() ///////////////////////////////////////////////////////////////////////////// // CDPNtEventPage message handlers BOOL CDPNtEventPage::OnInitDialog() { // v-marfin : bug 59643 : This will be the default starting page for the property // sheet so call CnxPropertyPageCreate() to unmarshal the // connection for this thread. This function must be called // by the first page of the property sheet. It used to // be called by the "General" page and its call still remains // there as well in case the general page is loaded by a // different code path that does not also load this page. // The CnxPropertyPageCreate function has been safeguarded // to simply return if the required call has already been made. // CnxPropertyPageDestory() must be called from this page's // OnDestroy function. // unmarshal connmgr CnxPropertyPageCreate(); CHMPropertyPage::OnInitDialog(); CWbemClassObject* pClassObject = GetObjectPtr()->GetClassObject(); if( ! GfxCheckObjPtr(pClassObject,CWbemClassObject) ) { return TRUE; } //------------------------------------------------------------------------- // v-marfin 59237 : Store original name in case this data collector is // just being created. When they save, we will modify the // name if they haven't. pClassObject->GetProperty(IDS_STRING_MOF_NAME,m_sOriginalName); //------------------------------------------------------------------------- CString sQuery; pClassObject->GetProperty(IDS_STRING_MOF_QUERY,sQuery); if( ! sQuery.IsEmpty() ) { // parse out the Type phrases CString sTemp = IDS_STRING_MOF_TYPE; if( sQuery.Find(sTemp + _T("=\"error\"")) != -1 ) { m_bError = TRUE; } if( sQuery.Find(sTemp + _T("=\"warning\"")) != -1 ) { m_bWarning = TRUE; } if( sQuery.Find(sTemp + _T("=\"information\"")) != -1 ) { m_bInformation = TRUE; } if( sQuery.Find(sTemp + _T("=\"audit success\"")) != -1 ) { m_bSuccess = TRUE; } if( sQuery.Find(sTemp + _T("=\"audit failure\"")) != -1 ) { m_bFailure = TRUE; } // parse out the LogFile CWbemClassObject::GetPropertyValueFromString(sQuery,_T("Logfile"),m_sLogFile); // parse out the EventIdentifier phrase if( CWbemClassObject::GetPropertyValueFromString(sQuery,IDS_STRING_MOF_EVENTID,m_sEventID) ) { m_bEventID = TRUE; } // parse out the SourceName if( CWbemClassObject::GetPropertyValueFromString(sQuery,IDS_STRING_MOF_SOURCENAME,m_sSource) ) { m_bSource = TRUE; } // parse out the CategoryString if( CWbemClassObject::GetPropertyValueFromString(sQuery,IDS_STRING_MOF_CATEGORYSTRING,m_sCategory) ) { m_bCategory = TRUE; } // parse out the User if( CWbemClassObject::GetPropertyValueFromString(sQuery,IDS_STRING_MOF_USER,m_sUser) ) { m_bUser = TRUE; } } // Get require reset bool bReset; pClassObject->GetProperty(IDS_STRING_MOF_REQUIRERESET,bReset); m_bRequireReset = bReset; UpdateData(FALSE); delete pClassObject; return TRUE; // return TRUE unless you set the focus to a control // EXCEPTION: OCX Property Pages should return FALSE } void CDPNtEventPage::OnOK() { CHMPropertyPage::OnOK(); } void CDPNtEventPage::OnDestroy() { // v-marfin 62585 : For this new data collector, set its Enabled property to TRUE, but // only if the user is not cancelling these property pages. if (m_bOnApplyUsed) { ClearStatistics(); // 62548 CDataElement* pElement = (CDataElement*)GetObjectPtr(); if (pElement && pElement->IsStateSetToEnabledOnOK()) { TRACE(_T("CDPNtEventPage::OnDestroy - New Perfmon Collector: Setting to Enabled\n")); pElement->SetStateToEnabledOnOK(FALSE); // don't do this again CWbemClassObject* pClassObject = GetObjectPtr()->GetClassObject(); if( ! GfxCheckObjPtr(pClassObject,CWbemClassObject) ) { TRACE(_T("ERROR: CDPNtEventPage::OnDestroy - Failed to GetClassObject()\n")); return; } // Set the new collector to enabled. BOOL bEnabled=TRUE; HRESULT hr = pClassObject->GetProperty(IDS_STRING_MOF_ENABLE,bEnabled); hr = pClassObject->SetProperty(IDS_STRING_MOF_ENABLE,TRUE); if (!CHECKHRESULT(hr)) { TRACE(_T("ERROR: CDPNtEventPage::OnDestroy - Failed to set ENABLED property on new collector\n")); } //------------------------------------------------------------------- // v-marfin 59237 : If the user has not changed the original default // name, do so for them. Compare against original // name we fetched during OnInitDialog. CString sName; pClassObject->GetProperty(IDS_STRING_MOF_NAME,sName); // Did the user change the default name? if (m_sOriginalName.CompareNoCase(sName)==0) { /* m_bCategory = FALSE; m_bError = FALSE; m_bEventID = FALSE; m_bFailure = FALSE; m_bInformation = FALSE; m_bRequireReset = TRUE; m_bSource = FALSE; m_bSuccess = FALSE; m_bUser = FALSE; m_bWarning = FALSE; m_sCategory = _T(""); m_sEventID = _T(""); m_sSource = _T(""); m_sUser = _T(""); m_sLogFile = _T(""); */ CString sType; CString sNewName; // Format the name //------------------------ if ((m_bError) && ((!m_bWarning) && (!m_bInformation) && (!m_bSuccess) && (!m_bFailure))) { sType.LoadString(IDS_NTEVENT_TYPE_ERRORS); } else if (((m_bError) && (m_bWarning)) && ((!m_bInformation) && (!m_bSuccess) && (!m_bFailure))) { sType.LoadString(IDS_NTEVENT_TYPE_ERRORS_AND_WARNINGS); } else { sType.LoadString(IDS_NTEVENT_TYPE_EVENTS); } if ((!m_bError) && (!m_bWarning) && (!m_bInformation) && (!m_bSuccess) && (!m_bFailure)) { sNewName.Format(IDS_NTEVENT_NEWNAME_EVENTLOG,m_sLogFile); } else if ((!m_sSource.IsEmpty()) && (m_sEventID.IsEmpty())) { sNewName.Format(IDS_NTEVENT_NEWNAME,m_sSource,sType,m_sLogFile); } else if (!m_sEventID.IsEmpty()) { sNewName.Format(IDS_NTEVENT_NEWNAME_EVENTID,m_sEventID,m_sLogFile); } else { sNewName.Format(IDS_NTEVENT_NEWNAME_LOGNAME,m_sLogFile,sType); } if (!sNewName.IsEmpty()) { // Use parent to ensure name is unique //CDataGroup* pParent = (CDataGroup*) pElement->GetCollectorsParentClassObject(); if(pElement->GetScopeItemCount()) { CDataElementScopeItem* pItem = (CDataElementScopeItem*)pElement->GetScopeItem(0); if( pItem ) { CDataGroupScopeItem* pDGItem = (CDataGroupScopeItem*)pItem->GetParent(); sName = pDGItem->GetUniqueDisplayName(sNewName); } } // Set the local element's object data pElement->SetName(sName); // Set its WMI property pClassObject->SetProperty(IDS_STRING_MOF_NAME,sName); // Refresh to show the new name in the IU //pElement->Refresh(); // 63005 pElement->UpdateStatus(); // 63005 } } //------------------------------------------------------------------- pClassObject->SaveAllProperties(); delete pClassObject; } // if (pElement && pElement->IsStateSetToEnabledOnOK()) } // if (m_bOnApplyUsed) CHMPropertyPage::OnDestroy(); // v-marfin : bug 59643 : CnxPropertyPageDestory() must be called from this page's // OnDestroy function. CnxPropertyPageDestroy(); } void CDPNtEventPage::OnButtonTest() { // TODO: Add your control notification handler code here } void CDPNtEventPage::OnCheckCategory() { UpdateData(); SetModified(); } void CDPNtEventPage::OnCheckEventid() { UpdateData(); SetModified(); } void CDPNtEventPage::OnCheckSource() { UpdateData(); SetModified(); } void CDPNtEventPage::OnCheckUser() { UpdateData(); SetModified(); } BOOL CDPNtEventPage::OnApply() { if( ! CHMPropertyPage::OnApply() ) { return FALSE; } // v-marfin 62585 : So we can set the collector's state to enabled when OK pressed. m_bOnApplyUsed=TRUE; UpdateData(); CString sQuery = IDS_STRING_MOF_EVENT_LOG_QUERY; CString sTemp; // parse out the LogFile sTemp.Format(_T(" AND TargetInstance.Logfile=\"%s\""), m_sLogFile); sQuery += sTemp; // parse out the Type phrases bool bAppendOr = false; if( m_bError ) { sTemp = _T(" AND (TargetInstance.Type=\"error\""); bAppendOr = true; sQuery += sTemp; } if( m_bWarning ) { sTemp = bAppendOr ? _T(" OR TargetInstance.Type=\"warning\"") : _T(" AND (TargetInstance.Type=\"warning\""); bAppendOr = true; sQuery += sTemp; } if( m_bInformation ) { sTemp = bAppendOr ? _T(" OR TargetInstance.Type=\"information\"") : _T(" AND (TargetInstance.Type=\"information\""); bAppendOr = true; sQuery += sTemp; } if( m_bSuccess ) { sTemp = bAppendOr ? _T(" OR TargetInstance.Type=\"audit success\"") : _T(" AND (TargetInstance.Type=\"audit success\""); bAppendOr = true; sQuery += sTemp; } if( m_bFailure ) { sTemp = bAppendOr ? _T(" OR TargetInstance.Type=\"audit failure\"") : _T(" AND (TargetInstance.Type=\"audit failure\""); bAppendOr = true; sQuery += sTemp; } if (bAppendOr) sQuery += _T(")"); // parse out the EventIdentifier phrase if( m_bEventID ) { sTemp.Format(_T(" AND TargetInstance.EventIdentifier=%s"), m_sEventID); sQuery += sTemp; } // parse out the SourceName if( m_bSource ) { sTemp.Format(_T(" AND TargetInstance.SourceName=\"%s\""), m_sSource); sQuery += sTemp; } // parse out the CategoryString if( m_bCategory ) { sTemp.Format(_T(" AND TargetInstance.CategoryString=\"%s\""), m_sCategory); sQuery += sTemp; } // parse out the User if( m_bUser ) { sTemp.Format(_T(" AND TargetInstance.User=\"%s\""), m_sUser); sQuery += sTemp; } CWbemClassObject* pClassObject = GetObjectPtr()->GetClassObject(); if( ! GfxCheckObjPtr(pClassObject,CWbemClassObject) ) { return FALSE; } pClassObject->SetProperty(IDS_STRING_MOF_QUERY,sQuery); /* 63128 CStringArray saPropertyNames; saPropertyNames.Add(_T("EventIdentifier")); saPropertyNames.Add(_T("SourceName")); saPropertyNames.Add(_T("Type")); saPropertyNames.Add(_T("CategoryString")); saPropertyNames.Add(_T("User")); saPropertyNames.Add(_T("LogFile")); pClassObject->SetProperty(IDS_STRING_MOF_STATISTICSPROPERTYNAMES,saPropertyNames);*/ CString sNamespace = _T("root\\cimv2"); pClassObject->SetProperty(IDS_STRING_MOF_TARGETNAMESPACE,sNamespace); bool bReset = m_bRequireReset ? true : false; pClassObject->SetProperty(IDS_STRING_MOF_REQUIRERESET,bReset); pClassObject->SaveAllProperties(); delete pClassObject; SetModified(FALSE); return TRUE; } void CDPNtEventPage::OnCheckError() { UpdateData(); SetModified(); } void CDPNtEventPage::OnCheckFailure() { UpdateData(); SetModified(); } void CDPNtEventPage::OnCheckInformation() { UpdateData(); SetModified(); } void CDPNtEventPage::OnCheckRequireReset() { UpdateData(); SetModified(); } void CDPNtEventPage::OnCheckSuccess() { UpdateData(); SetModified(); } void CDPNtEventPage::OnCheckWarning() { UpdateData(); SetModified(); } void CDPNtEventPage::OnEditchangeComboLogFile() { UpdateData(); SetModified(); } void CDPNtEventPage::OnChangeEditCategory() { // TODO: If this is a RICHEDIT control, the control will not // send this notification unless you override the CHMPropertyPage::OnInitDialog() // function and call CRichEditCtrl().SetEventMask() // with the ENM_CHANGE flag ORed into the mask. UpdateData(); SetModified(); } void CDPNtEventPage::OnChangeEditEventid() { // TODO: If this is a RICHEDIT control, the control will not // send this notification unless you override the CHMPropertyPage::OnInitDialog() // function and call CRichEditCtrl().SetEventMask() // with the ENM_CHANGE flag ORed into the mask. UpdateData(); SetModified(); } void CDPNtEventPage::OnChangeEditSource() { // TODO: If this is a RICHEDIT control, the control will not // send this notification unless you override the CHMPropertyPage::OnInitDialog() // function and call CRichEditCtrl().SetEventMask() // with the ENM_CHANGE flag ORed into the mask. UpdateData(); SetModified(); } void CDPNtEventPage::OnChangeEditUser() { // TODO: If this is a RICHEDIT control, the control will not // send this notification unless you override the CHMPropertyPage::OnInitDialog() // function and call CRichEditCtrl().SetEventMask() // with the ENM_CHANGE flag ORed into the mask. UpdateData(); SetModified(); }