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

220 lines
5.3 KiB
C++

// System.cpp : implementation file
//
#include "stdafx.h"
#include "snapin.h"
#include "System.h"
#include "HMSystem.h"
#include "SystemGroupScopeItem.h"
#include "EventManager.h"
#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif
/////////////////////////////////////////////////////////////////////////////
// CSystem
IMPLEMENT_SERIAL(CSystem, CHMObject, 1)
CSystem::CSystem()
{
EnableAutomation();
// To keep the application running as long as an OLE automation
// object is active, the constructor calls AfxOleLockApp.
AfxOleLockApp();
m_pDGListener = NULL;
m_pCreationListener = NULL;
m_pDeletionListener = NULL;
m_pSListener = NULL;
m_sTypeName = IDS_STRING_MOF_SYSTEM;
m_nState = HMS_NODATA;
m_lTotalActiveSinkCount = 0;
SetGuid(_T("@"));
}
CSystem::~CSystem()
{
if( m_pDGListener )
{
delete m_pDGListener;
m_pDGListener = NULL;
}
if( m_pCreationListener )
{
delete m_pCreationListener;
m_pCreationListener = NULL;
}
if( m_pDeletionListener )
{
delete m_pDeletionListener;
m_pDeletionListener = NULL;
}
if( m_pSListener )
{
delete m_pSListener;
m_pSListener = NULL;
}
EvtGetEventManager()->RemoveSystemContainer(GetSystemName());
// To terminate the application when all objects created with
// with OLE automation, the destructor calls AfxOleUnlockApp.
AfxOleUnlockApp();
}
void CSystem::UpdateStatus()
{
TRACEX(_T("CSystem::UpdateStatus\n"));
CEventContainer* pContainer = NULL;
EvtGetEventManager()->GetEventContainer(GetSystemName(),GetGuid(),pContainer);
if( ! pContainer )
{
return;
}
SetState(CEvent::GetStatus(pContainer->m_iState));
for( int i = 0; i < GetScopeItemCount(); i++ )
{
CHMScopeItem* pItem = (CHMScopeItem*)GetScopeItem(i);
if( pItem )
{
CStringArray saNames;
CString sValue;
// Name of system
saNames.Add(GetSystemName());
// Status
CString sStatus;
CEvent::GetStatus(pContainer->m_iState,sStatus);
saNames.Add(sStatus);
CString sDomain;
CString sProcessor;
CString sInfo;
// GetComputerSystemInfo(sDomain,sProcessor); // v-marfin 62501
if (!GetComputerSystemInfo(sDomain,sProcessor))
{
continue;
}
GetOperatingSystemInfo(sInfo);
// Domain
saNames.Add(sDomain);
// OS
saNames.Add(sInfo);
GetWMIVersion(sInfo);
// WMI Version
saNames.Add(sInfo);
// Normal
sValue.Format(_T("%d"),pContainer->m_iNumberNormals);
saNames.Add(sValue);
// Warning
sValue.Format(_T("%d"),pContainer->m_iNumberWarnings);
saNames.Add(sValue);
// Critical
sValue.Format(_T("%d"),pContainer->m_iNumberCriticals);
saNames.Add(sValue);
// Unknown
sValue.Format(_T("%d"),pContainer->m_iNumberUnknowns);
saNames.Add(sValue);
// Last Message
CString sLastMessage = pContainer->GetLastEventDTime();
if( sLastMessage.IsEmpty() )
{
sLastMessage.LoadString(IDS_STRING_NONE);
}
saNames.Add(sLastMessage);
// Comment
saNames.Add(GetComment());
pItem->SetDisplayNames(saNames);
pItem->SetIconIndex(CEvent::GetStatus(pContainer->m_iState));
pItem->SetOpenIconIndex(CEvent::GetStatus(pContainer->m_iState));
pItem->SetItem();
CHMScopeItem* pParentItem = (CHMScopeItem*)pItem->GetParent();
if( pParentItem )
{
pParentItem->OnChangeChildState(CEvent::GetStatus(pContainer->m_iState));
}
}
}
m_lNormalCount = pContainer->m_iNumberNormals;
m_lWarningCount = pContainer->m_iNumberWarnings;
m_lCriticalCount = pContainer->m_iNumberCriticals;
m_lUnknownCount = pContainer->m_iNumberUnknowns;
}
void CSystem::OnFinalRelease()
{
// When the last reference for an automation object is released
// OnFinalRelease is called. The base class will automatically
// deletes the object. Add additional cleanup required for your
// object before calling the base class.
CHMObject::OnFinalRelease();
}
BEGIN_MESSAGE_MAP(CSystem, CHMObject)
//{{AFX_MSG_MAP(CSystem)
// NOTE - the ClassWizard will add and remove mapping macros here.
//}}AFX_MSG_MAP
END_MESSAGE_MAP()
BEGIN_DISPATCH_MAP(CSystem, CHMObject)
//{{AFX_DISPATCH_MAP(CSystem)
// NOTE - the ClassWizard will add and remove mapping macros here.
//}}AFX_DISPATCH_MAP
END_DISPATCH_MAP()
// Note: we add support for IID_ISystem to support typesafe binding
// from VBA. This IID must match the GUID that is attached to the
// dispinterface in the .ODL file.
// {D9BF4FA0-F673-11D2-BDC4-0000F87A3912}
static const IID IID_ISystem =
{ 0xd9bf4fa0, 0xf673, 0x11d2, { 0xbd, 0xc4, 0x0, 0x0, 0xf8, 0x7a, 0x39, 0x12 } };
BEGIN_INTERFACE_MAP(CSystem, CHMObject)
INTERFACE_PART(CSystem, IID_ISystem, Dispatch)
END_INTERFACE_MAP()
// {84C4D41D-BB8F-11D2-BD78-0000F87A3912}
IMPLEMENT_OLECREATE_EX(CSystem, "SnapIn.System", 0x84c4d41d, 0xbb8f, 0x11d2, 0xbd, 0x78, 0x0, 0x0, 0xf8, 0x7a, 0x39, 0x12)
BOOL CSystem::CSystemFactory::UpdateRegistry(BOOL bRegister)
{
if (bRegister)
return AfxOleRegisterServerClass(m_clsid, m_lpszProgID, m_lpszProgID, m_lpszProgID, OAT_DISPATCH_OBJECT);
else
return AfxOleUnregisterClass(m_clsid, m_lpszProgID);
}
/////////////////////////////////////////////////////////////////////////////
// CSystem message handlers