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

151 lines
4.9 KiB

//////////////////////////////////////////////////////////////////////////////
//
// Copyright (c) 2000 Microsoft Corporation
//
// Module Name:
// StartupNotify.h
//
// Description:
// This file contains the declaration of the CStartupNotify
// class. This class is used to notify StartupListeners
// when the cluster service starts.
//
// Documentation:
// TODO: fill in pointer to external documentation
//
// Implementation Files:
// StartupNotify.cpp
//
// Maintained By:
// Vij Vasu (VVasu) 04-AUG-2000
//
//////////////////////////////////////////////////////////////////////////////
// Make sure that this file is included only once per compile path.
#pragma once
//////////////////////////////////////////////////////////////////////////////
// Include Files
//////////////////////////////////////////////////////////////////////////////
// For IUnknown
#include <unknwn.h>
// For IClusCfgStartupNotify
#include <ClusCfgServer.h>
// For ILogger
#include <ClusCfgClient.h>
//////////////////////////////////////////////////////////////////////////////
//++
//
// class CStartupNotify
//
// Description:
// This class is used to notify StartupListeners
// when the cluster service starts.
//
//--
//////////////////////////////////////////////////////////////////////////////
class CStartupNotify
: public IClusCfgStartupNotify
, public IClusCfgCallback
{
public:
//////////////////////////////////////////////////////////////////////////
// IUnknown methods
//////////////////////////////////////////////////////////////////////////
STDMETHOD( QueryInterface )( REFIID riid, void ** ppvObject );
STDMETHOD_( ULONG, AddRef )( void );
STDMETHOD_( ULONG, Release )( void );
//////////////////////////////////////////////////////////////////////////
// IClusCfgStartupNotify methods
//////////////////////////////////////////////////////////////////////////
// Send out notification of cluster service startup to interested listeners
STDMETHOD( SendNotifications )( void );
//////////////////////////////////////////////////////////////////////////
// IClusCfgCallback methods
//////////////////////////////////////////////////////////////////////////
STDMETHOD( SendStatusReport )(
LPCWSTR pcszNodeNameIn
, CLSID clsidTaskMajorIn
, CLSID clsidTaskMinorIn
, ULONG ulMinIn
, ULONG ulMaxIn
, ULONG ulCurrentIn
, HRESULT hrStatusIn
, LPCWSTR pcszDescriptionIn
, FILETIME * pftTimeIn
, LPCWSTR pcszReference
);
//////////////////////////////////////////////////////////////////////////
// Other public methods
//////////////////////////////////////////////////////////////////////////
// Create an instance of this class.
static HRESULT S_HrCreateInstance( IUnknown ** ppunkOut );
private:
//////////////////////////////////////////////////////////////////////////
// Private member functions
//////////////////////////////////////////////////////////////////////////
// Second phase of a two phase constructor.
HRESULT HrInit( void );
// Enumerate all components on the local computer registered for cluster
// startup notification.
HRESULT HrNotifyListeners( void );
// Instantiate a cluster startup listener component and call the
// appropriate methods.
HRESULT HrProcessListener(
const CLSID & rclsidListenerCLSIDIn
, IUnknown * punkResTypeServicesIn
);
//
// Private constructors, destructor and assignment operator.
// All of these methods are private for two reasons:
// 1. Lifetimes of objects of this class are controlled by S_HrCreateInstance and Release.
// 2. Copying of an object of this class is prohibited.
//
// Default constructor.
CStartupNotify( void );
// Destructor.
~CStartupNotify( void );
// Copy constructor.
CStartupNotify( const CStartupNotify & );
// Assignment operator.
CStartupNotify & operator =( const CStartupNotify & );
//////////////////////////////////////////////////////////////////////////
// Private data
//////////////////////////////////////////////////////////////////////////
// Reference count for this object.
LONG m_cRef;
// IClusCfgCallback
BSTR m_bstrNodeName; // Name of the local node.
ILogger * m_plLogger; // ILogger for doing logging.
}; //*** class CStartupNotify