windows-nt/Source/XPSP1/NT/admin/hmonitor/snapin/actionscopeitem.cpp
2020-09-26 16:20:57 +08:00

702 lines
19 KiB
C++

// ActionScopeItem.cpp: implementation of the CActionScopeItem class.
//
//////////////////////////////////////////////////////////////////////
//
// 03/04/00 v-marfin bug 59643 : Make the details page the default page.
// 04/02/00 v-marfin bug 59643b: Make General Page the first page, but set
// details page as the focus on a new data collector.
//
//
//
//
#include "stdafx.h"
#include "snapin.h"
#include "ResultsPane.h"
#include "ActionScopeItem.h"
#include "ActionResultsView.h"
#include "Action.h"
#include "ActionGeneralPage.h"
#include "ActionCmdLinePage.h"
#include "ActionEmailPage.h"
#include "ActionLogFilePage.h"
#include "ActionNtEventLogPage.h"
#include "ActionPagingPage.h"
#include "ActionScriptPage.h"
#include "ActionSchedulePage.h"
#ifdef _DEBUG
#undef THIS_FILE
static char THIS_FILE[]=__FILE__;
#define new DEBUG_NEW
#endif
// {EF423181-CA9B-11d2-BD8E-0000F87A3912}
static GUID GUID_Action =
{ 0xef423181, 0xca9b, 0x11d2, { 0xbd, 0x8e, 0x0, 0x0, 0xf8, 0x7a, 0x39, 0x12 } };
IMPLEMENT_DYNCREATE(CActionScopeItem,CHMScopeItem)
// icon table - associates state to icons
static UINT _Icons[] =
{
// 0 = DEFAULT
IDI_ICON_ACTION,
// 1 = COMMAND LINE
IDI_ICON_ACTION_CMDLINE,
// 2 = EMAIL
IDI_ICON_ACTION_EMAIL,
// 3 = LOGFILE
IDI_ICON_ACTION_LOGFILE,
// 4 = NT EVENT
IDI_ICON_ACTION_NTEVENT,
// 5 = SCRIPT
IDI_ICON_ACTION_SCRIPT,
// 6 = PAGING
IDI_ICON_ACTION_PAGER
};
//////////////////////////////////////////////////////////////////////
// Construction/Destruction
//////////////////////////////////////////////////////////////////////
CActionScopeItem::CActionScopeItem()
{
m_lpguidItemType = &GUID_Action;
}
CActionScopeItem::~CActionScopeItem()
{
Destroy();
}
//////////////////////////////////////////////////////////////////////
// Creation Members
//////////////////////////////////////////////////////////////////////
bool CActionScopeItem::Create(CScopePane* pScopePane, CScopePaneItem* pParentItem)
{
TRACEX(_T("CActionScopeItem::Create\n"));
TRACEARGn(pScopePane);
TRACEARGn(pParentItem);
// set up all the icons first
CAction* pAction = (CAction*)GetObjectPtr();
if( ! GfxCheckObjPtr(pAction,CAction) )
{
return false;
}
int iIconIndex = 0;
switch( pAction->GetType() )
{
case IDM_ACTION_CMDLINE:
{
iIconIndex = 1;
}
break;
case IDM_ACTION_EMAIL:
{
iIconIndex = 2;
}
break;
case IDM_ACTION_LOGFILE:
{
iIconIndex = 3;
}
break;
case IDM_ACTION_NTEVENT:
{
iIconIndex = 4;
}
break;
case IDM_ACTION_SCRIPT:
{
iIconIndex = 5;
}
break;
case IDM_ACTION_PAGING:
{
iIconIndex = 6;
}
break;
default:
{
ASSERT(FALSE);
}
break;
}
m_IconResIds.Add(_Icons[iIconIndex]);
m_OpenIconResIds.Add(_Icons[iIconIndex]);
//------------------------------------------------------------------------------------------------------
// v-marfin : 59492
// Only 1 icon was being loaded above. So any attempt to set a different icon (based on its state for
// example), failed since its index would be out of range.
// Other scope pane items have icons associated with each state they can be in, and they are loaded
// into their m_IconResIds array. When a state changes, the icon at the [state] index is selected.
//
// So here, when we determine the type of action this is (iIconIndex), we will load our own
// m_IconResIds with icons associated with state. This presents one small problem however, the state
// codes do not run in 0,1,2,3,4 etc order, so we have a choice of either just loading the state icons
// and converting the index at SetIconIndex time based on the state, or set just those positions represented
// by the possible states. At this late stage of the game I will choose the latter, not being intimately
// familiar with this system. Can always come back later and change to 1st choice once I am more
// comfortable with the system. For now, fix bugs.
// v-marfin 59492 : Since the icons are handled according to a state code sequence of:
// 0 = good
// 1 = collecting
// 2 = reset
// 3 = info
// 4 = disabled
// 5 = scheduled outage
// 6 = unknown
//
// Set the icon table accordingly. Note that for Actions the only used icons are
// for position 0,4 and 5 so set the other icons to the normal state.
switch( pAction->GetType() )
{
case IDM_ACTION_CMDLINE:
{
// v-marfin 59492
// Forget the preload that went on above...
// First load all the occurrences with the normal icon
for (int x=0;x<7; x++)
{
m_IconResIds.SetAtGrow(x,IDI_ICON_ACTION_CMDLINE);
m_OpenIconResIds.SetAtGrow(x,IDI_ICON_ACTION_CMDLINE);
}
m_IconResIds.SetAtGrow(HMS_DISABLED,IDI_ICON_ACTION_CMDLINE_DISABLED);
m_OpenIconResIds.SetAtGrow(HMS_DISABLED,IDI_ICON_ACTION_CMDLINE_DISABLED);
m_IconResIds.SetAtGrow(HMS_SCHEDULEDOUT,IDI_ICON_ACTION_CMDLINE_OUTAGE);
m_OpenIconResIds.SetAtGrow(HMS_SCHEDULEDOUT,IDI_ICON_ACTION_CMDLINE_OUTAGE);
}
break;
case IDM_ACTION_EMAIL:
{
// v-marfin 59492
// Forget the preload that went on above...
// First load all the occurrences with the normal icon
for (int x=0;x<7; x++)
{
m_IconResIds.SetAtGrow(x,IDI_ICON_ACTION_EMAIL);
m_OpenIconResIds.SetAtGrow(x,IDI_ICON_ACTION_EMAIL);
}
m_IconResIds.SetAtGrow(HMS_DISABLED,IDI_ICON_ACTION_EMAIL_DISABLED);
m_OpenIconResIds.SetAtGrow(HMS_DISABLED,IDI_ICON_ACTION_EMAIL_DISABLED);
m_IconResIds.SetAtGrow(HMS_SCHEDULEDOUT,IDI_ICON_ACTION_EMAIL_OUTAGE);
m_OpenIconResIds.SetAtGrow(HMS_SCHEDULEDOUT,IDI_ICON_ACTION_EMAIL_OUTAGE);
}
break;
case IDM_ACTION_LOGFILE:
{
// v-marfin 59492
// Forget the preload that went on above...
// First load all the occurrences with the normal icon
for (int x=0;x<7; x++)
{
m_IconResIds.SetAtGrow(x,IDI_ICON_ACTION_LOGFILE);
m_OpenIconResIds.SetAtGrow(x,IDI_ICON_ACTION_LOGFILE);
}
m_IconResIds.SetAtGrow(HMS_DISABLED,IDI_ICON_ACTION_LOGFILE_DISABLED);
m_OpenIconResIds.SetAtGrow(HMS_DISABLED,IDI_ICON_ACTION_LOGFILE_DISABLED);
m_IconResIds.SetAtGrow(HMS_SCHEDULEDOUT,IDI_ICON_ACTION_LOGFILE_OUTAGE);
m_OpenIconResIds.SetAtGrow(HMS_SCHEDULEDOUT,IDI_ICON_ACTION_LOGFILE_OUTAGE);
}
break;
case IDM_ACTION_NTEVENT:
{
// v-marfin 59492
// Forget the preload that went on above...
// First load all the occurrences with the normal icon
for (int x=0;x<7; x++)
{
m_IconResIds.SetAtGrow(x,IDI_ICON_ACTION_NTEVENT);
m_OpenIconResIds.SetAtGrow(x,IDI_ICON_ACTION_NTEVENT);
}
m_IconResIds.SetAtGrow(HMS_DISABLED,IDI_ICON_ACTION_NTEVENT_DISABLED);
m_OpenIconResIds.SetAtGrow(HMS_DISABLED,IDI_ICON_ACTION_NTEVENT_DISABLED);
m_IconResIds.SetAtGrow(HMS_SCHEDULEDOUT,IDI_ICON_ACTION_NTEVENT_OUTAGE);
m_OpenIconResIds.SetAtGrow(HMS_SCHEDULEDOUT,IDI_ICON_ACTION_NTEVENT_OUTAGE);
}
break;
case IDM_ACTION_SCRIPT:
{
// v-marfin 59492
// Forget the preload that went on above...
// First load all the occurrences with the normal icon
for (int x=0;x<7; x++)
{
m_IconResIds.SetAtGrow(x,IDI_ICON_ACTION_SCRIPT);
m_OpenIconResIds.SetAtGrow(x,IDI_ICON_ACTION_SCRIPT);
}
m_IconResIds.SetAtGrow(HMS_DISABLED,IDI_ICON_ACTION_SCRIPT_DISABLED);
m_OpenIconResIds.SetAtGrow(HMS_DISABLED,IDI_ICON_ACTION_SCRIPT_DISABLED);
m_IconResIds.SetAtGrow(HMS_SCHEDULEDOUT,IDI_ICON_ACTION_SCRIPT_OUTAGE);
m_OpenIconResIds.SetAtGrow(HMS_SCHEDULEDOUT,IDI_ICON_ACTION_SCRIPT_OUTAGE);
}
break;
case IDM_ACTION_PAGING:
{
// Not using
}
break;
default:
{
ASSERT(FALSE);
}
break;
}
//------------------------------------------------------------------------------------------------------
SetIconIndex(0);
SetOpenIconIndex(0);
// v-marfin: 59492 ---------------------------------------------------------------------------
// Shouldn't this be set to the current state? -------------------------------------
SetIconIndex(GetObjectPtr()->GetState());
SetOpenIconIndex(GetObjectPtr()->GetState());
//--------------------------------------------------------------------------------------------
// call base class Create method
if( ! CScopePaneItem::Create(pScopePane,pParentItem) )
{
TRACE(_T("CScopePaneItem::Create failed.\n"));
return false;
}
// set display names
CString sName;
sName.LoadString(IDS_STRING_ACTION);
SetDisplayName(0,sName);
return true;
}
//////////////////////////////////////////////////////////////////////
// Results Pane View Members
//////////////////////////////////////////////////////////////////////
CResultsPaneView* CActionScopeItem::CreateResultsPaneView()
{
TRACEX(_T("CActionScopeItem::CreateResultsPaneView\n"));
return new CActionResultsView;
}
//////////////////////////////////////////////////////////////////////
// MMC Notify Handlers
//////////////////////////////////////////////////////////////////////
HRESULT CActionScopeItem::OnAddMenuItems(LPCONTEXTMENUCALLBACK piCallback,long __RPC_FAR *pInsertionAllowed)
{
TRACEX(_T("CActionScopeItem::OnAddMenuItems\n"));
TRACEARGn(piCallback);
TRACEARGn(pInsertionAllowed);
HRESULT hr = S_OK;
// Add New Menu Items
if( CCM_INSERTIONALLOWED_NEW & *pInsertionAllowed )
{
}
// Add Task Menu Items
if( CCM_INSERTIONALLOWED_TASK & *pInsertionAllowed )
{
CONTEXTMENUITEM cmi;
CString sResString;
CString sResString2;
// clear events
sResString.LoadString(IDS_STRING_CLEAR_EVENTS);
cmi.strName = LPTSTR(LPCTSTR(sResString));
sResString2.LoadString(IDS_STRING_CLEAR_EVENTS_DESCRIPTION);
cmi.strStatusBarText = LPTSTR(LPCTSTR(sResString2));
cmi.lCommandID = IDM_CLEAR_EVENTS;
cmi.lInsertionPointID = CCM_INSERTIONPOINTID_PRIMARY_TASK;
cmi.fFlags = 0;
cmi.fSpecialFlags = 0;
hr = piCallback->AddItem(&cmi);
if( !SUCCEEDED(hr) )
{
TRACE(_T("FAILED : IContextMenuCallback::AddItem failed.\n"));
return hr;
}
// disable actions
sResString.LoadString(IDS_STRING_DISABLE_ACTIONS);
cmi.strName = LPTSTR(LPCTSTR(sResString));
sResString2.LoadString(IDS_STRING_DISABLE_ACTIONS_DESC);
cmi.strStatusBarText = LPTSTR(LPCTSTR(sResString2));
cmi.lCommandID = IDM_DISABLE_ACTIONS;
cmi.lInsertionPointID = CCM_INSERTIONPOINTID_PRIMARY_TASK;
cmi.fFlags = 0;
cmi.fSpecialFlags = 0;
// v-marfin 59492 : Indicate on menu whether is disabled or not
//------------------------------------------------------------
CHMObject* pObject = GetObjectPtr();
CHMScopeItem* pParentItem = (CHMScopeItem*)GetParent();
// disable menu item if null object ptr or parent is disabled
if( ! pObject || (pParentItem && pParentItem->GetObjectPtr()
&& !pParentItem->GetObjectPtr()->IsEnabled()) )
{
cmi.fFlags = MF_DISABLED|MF_GRAYED;
}
else
{
int iState = pObject->IsEnabled();
if( iState == -1 )
{
cmi.fFlags = MF_DISABLED|MF_GRAYED;
}
else if( iState == 0 )
{
cmi.fFlags = MF_CHECKED;
}
else if( iState == 1 )
{
cmi.fFlags = MF_UNCHECKED;
}
}
//------------------------------------------------------------
hr = piCallback->AddItem(&cmi);
if( !SUCCEEDED(hr) )
{
TRACE(_T("FAILED : IContextMenuCallback::AddItem failed.\n"));
return hr;
}
// separator
cmi.strName = NULL;
cmi.strStatusBarText = NULL;
cmi.lCommandID = NULL;
cmi.lInsertionPointID = CCM_INSERTIONPOINTID_PRIMARY_TASK;
cmi.fFlags = MF_SEPARATOR;
cmi.fSpecialFlags = 0;
hr = piCallback->AddItem(&cmi);
if( !SUCCEEDED(hr) )
{
TRACE(_T("FAILED : IContextMenuCallback::AddItem failed.\n"));
return hr;
}
}
// Add View Menu Items
if( CCM_INSERTIONALLOWED_VIEW & *pInsertionAllowed )
{
CONTEXTMENUITEM cmi;
CString sResString;
CString sResString2;
sResString.LoadString(IDS_STRING_STATUS_ONLY);
cmi.strName = LPTSTR(LPCTSTR(sResString));
sResString2.LoadString(IDS_STRING_STATUS_ONLY_DESCRIPTION);
cmi.strStatusBarText = LPTSTR(LPCTSTR(sResString2));
cmi.lCommandID = IDM_STATUS_ONLY;
cmi.lInsertionPointID = CCM_INSERTIONPOINTID_PRIMARY_VIEW;
cmi.fFlags = MF_UNCHECKED;
cmi.fSpecialFlags = 0;
hr = piCallback->AddItem(&cmi);
if( !SUCCEEDED(hr) )
{
TRACE(_T("FAILED : IContextMenuCallback::AddItem failed.\n"));
return hr;
}
sResString.LoadString(IDS_STRING_ICONS_STATUS);
cmi.strName = LPTSTR(LPCTSTR(sResString));
sResString2.LoadString(IDS_STRING_ICONS_STATUS_DESCRIPTION);
cmi.strStatusBarText = LPTSTR(LPCTSTR(sResString2));
cmi.lCommandID = IDM_ICONS_WITH_STATUS;
cmi.lInsertionPointID = CCM_INSERTIONPOINTID_PRIMARY_VIEW;
cmi.fFlags = MF_CHECKED;
cmi.fSpecialFlags = 0;
hr = piCallback->AddItem(&cmi);
if( !SUCCEEDED(hr) )
{
TRACE(_T("FAILED : IContextMenuCallback::AddItem failed.\n"));
return hr;
}
// icon legend
sResString.LoadString(IDS_STRING_ICON_LEGEND);
cmi.strName = LPTSTR(LPCTSTR(sResString));
sResString2.LoadString(IDS_STRING_ICON_LEGEND_DESCRIPTION);
cmi.strStatusBarText = LPTSTR(LPCTSTR(sResString2));
cmi.lCommandID = IDM_ICON_LEGEND;
cmi.lInsertionPointID = CCM_INSERTIONPOINTID_PRIMARY_VIEW;
cmi.fFlags = 0;
cmi.fSpecialFlags = 0;
hr = piCallback->AddItem(&cmi);
if( !SUCCEEDED(hr) )
{
TRACE(_T("FAILED : IContextMenuCallback::AddItem failed.\n"));
return hr;
}
}
return hr;
}
HRESULT CActionScopeItem::OnCommand(long lCommandID)
{
TRACEX(_T("CActionScopeItem::OnCommand\n"));
TRACEARGn(lCommandID);
HRESULT hr = S_OK;
switch(lCommandID)
{
case IDM_CLEAR_EVENTS:
{
}
break;
case IDM_DISABLE_ACTIONS:
{
CHMObject* pObject = GetObjectPtr();
if( ! pObject )
{
ASSERT(FALSE);
return E_FAIL;
}
if( pObject->IsEnabled() )
{
pObject->Disable();
}
else
{
pObject->Enable();
}
}
break;
default:
{
hr = CHMScopeItem::OnCommand(lCommandID);
}
break;
}
return hr;
}
HRESULT CActionScopeItem::OnCreatePropertyPages(LPPROPERTYSHEETCALLBACK lpProvider, INT_PTR handle)
{
TRACEX(_T("CActionScopeItem::OnCreatePropertyPages\n"));
TRACEARGn(lpProvider);
TRACEARGn(handle);
if( m_pScopePane == NULL )
{
return S_FALSE;
}
HRESULT hr = S_OK;
CAction* pAction = (CAction*)GetObjectPtr();
if( ! GfxCheckObjPtr(pAction,CAction) )
{
return E_FAIL;
}
// v-marfin bug 59643b : Make General Page the first page, but set
// details page as the focus on a new data collector.
CActionGeneralPage* pPage1 = new CActionGeneralPage;
pPage1->SetObjectPtr(pAction);
HPROPSHEETPAGE hPage1 = CreatePropertySheetPage( reinterpret_cast<LPCPROPSHEETPAGE>(&pPage1->m_psp) );
hr = lpProvider->AddPage(hPage1);
switch( pAction->GetType() )
{
case IDM_ACTION_CMDLINE:
{
CActionCmdLinePage* pPage2 = new CActionCmdLinePage;
pPage2->SetObjectPtr(pAction);
HPROPSHEETPAGE hPage2 = CreatePropertySheetPage( reinterpret_cast<LPCPROPSHEETPAGE>(&pPage2->m_psp) );
hr = lpProvider->AddPage(hPage2);
}
break;
case IDM_ACTION_EMAIL:
{
CActionEmailPage* pPage2 = new CActionEmailPage;
pPage2->SetObjectPtr(pAction);
HPROPSHEETPAGE hPage2 = CreatePropertySheetPage( reinterpret_cast<LPCPROPSHEETPAGE>(&pPage2->m_psp) );
hr = lpProvider->AddPage(hPage2);
}
break;
case IDM_ACTION_LOGFILE:
{
CActionLogFilePage* pPage2 = new CActionLogFilePage;
pPage2->SetObjectPtr(pAction);
HPROPSHEETPAGE hPage2 = CreatePropertySheetPage( reinterpret_cast<LPCPROPSHEETPAGE>(&pPage2->m_psp) );
hr = lpProvider->AddPage(hPage2);
}
break;
case IDM_ACTION_NTEVENT:
{
CActionNtEventLogPage* pPage2 = new CActionNtEventLogPage;
pPage2->SetObjectPtr(pAction);
HPROPSHEETPAGE hPage2 = CreatePropertySheetPage( reinterpret_cast<LPCPROPSHEETPAGE>(&pPage2->m_psp) );
hr = lpProvider->AddPage(hPage2);
}
break;
case IDM_ACTION_SCRIPT:
{
CActionScriptPage* pPage2 = new CActionScriptPage;
pPage2->SetObjectPtr(pAction);
HPROPSHEETPAGE hPage2 = CreatePropertySheetPage( reinterpret_cast<LPCPROPSHEETPAGE>(&pPage2->m_psp) );
hr = lpProvider->AddPage(hPage2);
}
break;
case IDM_ACTION_PAGING:
{
CActionPagingPage* pPage2 = new CActionPagingPage;
pPage2->SetObjectPtr(pAction);
HPROPSHEETPAGE hPage2 = CreatePropertySheetPage( reinterpret_cast<LPCPROPSHEETPAGE>(&pPage2->m_psp) );
hr = lpProvider->AddPage(hPage2);
}
break;
default:
{
ASSERT(FALSE);
}
break;
}
CActionSchedulePage* pPage3 = new CActionSchedulePage;
pPage3->SetObjectPtr(pAction);
HPROPSHEETPAGE hPage3 = CreatePropertySheetPage( reinterpret_cast<LPCPROPSHEETPAGE>(&pPage3->m_psp) );
hr = lpProvider->AddPage(hPage3);
return hr;
}
HRESULT CActionScopeItem::OnSelect(CResultsPane* pPane, BOOL bSelected)
{
TRACEX(_T("CActionScopeItem::OnSelect\n"));
TRACEARGn(pPane);
TRACEARGn(bSelected);
if( ! CHECKHRESULT(CHMScopeItem::OnSelect(pPane,bSelected)) )
{
TRACE(_T("FAILED : CHMScopeItem::OnSelect returns failure.\n"));
return E_FAIL;
}
if( ! bSelected ) // we are being de-selected so do not do anything
{
return S_OK;
}
LPCONSOLEVERB lpConsoleVerb = pPane->GetConsoleVerbPtr();
HRESULT hr = lpConsoleVerb->SetVerbState( MMC_VERB_PROPERTIES, ENABLED, TRUE );
if( ! CHECKHRESULT(hr) )
{
TRACE(_T("FAILED : IConsoleVerb::SetVerbState failed.\n"));
lpConsoleVerb->Release();
return hr;
}
hr = lpConsoleVerb->SetDefaultVerb( MMC_VERB_PROPERTIES );
if( ! CHECKHRESULT(hr) )
{
TRACE(_T("FAILED : IConsoleVerb::SetDefaultVerb failed.\n"));
lpConsoleVerb->Release();
return hr;
}
hr = lpConsoleVerb->SetVerbState( MMC_VERB_RENAME, ENABLED, TRUE );
if( ! CHECKHRESULT(hr) )
{
TRACE(_T("FAILED : IConsoleVerb::SetVerbState failed.\n"));
lpConsoleVerb->Release();
return hr;
}
hr = lpConsoleVerb->SetVerbState( MMC_VERB_CUT, ENABLED, TRUE );
if( ! CHECKHRESULT(hr) )
{
TRACE(_T("FAILED : IConsoleVerb::SetVerbState failed.\n"));
lpConsoleVerb->Release();
return hr;
}
hr = lpConsoleVerb->SetVerbState( MMC_VERB_COPY, ENABLED, TRUE );
if( ! CHECKHRESULT(hr) )
{
TRACE(_T("FAILED : IConsoleVerb::SetVerbState failed.\n"));
lpConsoleVerb->Release();
return hr;
}
hr = lpConsoleVerb->SetVerbState( MMC_VERB_PASTE, ENABLED, TRUE );
if( ! CHECKHRESULT(hr) )
{
TRACE(_T("FAILED : IConsoleVerb::SetVerbState failed.\n"));
lpConsoleVerb->Release();
return hr;
}
hr = lpConsoleVerb->SetVerbState( MMC_VERB_DELETE, ENABLED, TRUE );
if( ! CHECKHRESULT(hr) )
{
TRACE(_T("FAILED : IConsoleVerb::SetVerbState failed.\n"));
lpConsoleVerb->Release();
return hr;
}
lpConsoleVerb->Release();
return hr;
}