///////////////////////////////////////////////////////////////////////////// // // Copyright (c) 1997-1999 Microsoft Corporation // // Module Name: // MSClus.cpp // // Description: // Implementation of the DLL Exports for the MSCLUS automation classes. // // Author: // Charles Stacy Harris (stacyh) 28-Feb-1997 // Galen Barbee (galenb) July 1998 // // Revision History: // July 1998 GalenB Maaaaaajjjjjjjjjoooooorrrr clean up // // Notes: // ///////////////////////////////////////////////////////////////////////////// #include "stdafx.h" #include <atlimpl.cpp> #include <initguid.h> #include <ClusRtl.h> #include "ClusterObject.h" #include "property.h" #include "ClusNeti.h" #include "ClusNetw.h" #include "ClusRes.h" #include "ClusRest.h" #include "ClusResg.h" #include "ClusNode.h" #include "Version.h" #include "ClusApp.h" #include "Cluster.h" #define IID_DEFINED #include "msclus_i.c" #undef IID_DEFINED CComModule _Module; BEGIN_OBJECT_MAP(ObjectMap) OBJECT_ENTRY(CLSID_ClusApplication, CClusApplication) OBJECT_ENTRY(CLSID_Cluster, CCluster) OBJECT_ENTRY(CLSID_ClusVersion, CClusVersion) OBJECT_ENTRY(CLSID_DomainNames, CDomainNames) OBJECT_ENTRY(CLSID_ClusResGroupPreferredOwnerNodes, CClusResGroupPreferredOwnerNodes) OBJECT_ENTRY(CLSID_ClusterNames, CClusterNames) OBJECT_ENTRY(CLSID_ClusNetInterface, CClusNetInterface) OBJECT_ENTRY(CLSID_ClusNetInterfaces, CClusNetInterfaces) OBJECT_ENTRY(CLSID_ClusNetwork, CClusNetwork) OBJECT_ENTRY(CLSID_ClusNetworks, CClusNetworks) OBJECT_ENTRY(CLSID_ClusNetworkNetInterfaces, CClusNetworkNetInterfaces) OBJECT_ENTRY(CLSID_ClusNode, CClusNode) OBJECT_ENTRY(CLSID_ClusNodes, CClusNodes) OBJECT_ENTRY(CLSID_ClusNodeNetInterfaces, CClusNodeNetInterfaces) OBJECT_ENTRY(CLSID_ClusProperty, CClusProperty) OBJECT_ENTRY(CLSID_ClusProperties, CClusProperties) OBJECT_ENTRY(CLSID_ClusRefObject, CClusRefObject) OBJECT_ENTRY(CLSID_ClusResDependencies, CClusResDependencies) OBJECT_ENTRY(CLSID_ClusResGroup, CClusResGroup) OBJECT_ENTRY(CLSID_ClusResGroups, CClusResGroups) OBJECT_ENTRY(CLSID_ClusResource, CClusResource) OBJECT_ENTRY(CLSID_ClusResources, CClusResources) OBJECT_ENTRY(CLSID_ClusResPossibleOwnerNodes, CClusResPossibleOwnerNodes) OBJECT_ENTRY(CLSID_ClusResType, CClusResType) OBJECT_ENTRY(CLSID_ClusResTypes, CClusResTypes) OBJECT_ENTRY(CLSID_ClusResTypeResources, CClusResTypeResources) OBJECT_ENTRY(CLSID_ClusResGroupResources, CClusResGroupResources) #if CLUSAPI_VERSION >= 0x0500 OBJECT_ENTRY(CLSID_ClusResTypePossibleOwnerNodes, CClusResTypePossibleOwnerNodes) #endif // CLUSAPI_VERSION >= 0x0500 OBJECT_ENTRY(CLSID_ClusPropertyValue, CClusPropertyValue) OBJECT_ENTRY(CLSID_ClusPropertyValues, CClusPropertyValues) OBJECT_ENTRY(CLSID_ClusPropertyValueData, CClusPropertyValueData) OBJECT_ENTRY(CLSID_ClusPartition, CClusPartition) OBJECT_ENTRY(CLSID_ClusPartitions, CClusPartitions) OBJECT_ENTRY(CLSID_ClusDisk, CClusDisk) OBJECT_ENTRY(CLSID_ClusDisks, CClusDisks) OBJECT_ENTRY(CLSID_ClusScsiAddress, CClusScsiAddress) OBJECT_ENTRY(CLSID_ClusRegistryKeys, CClusResourceRegistryKeys) #if CLUSAPI_VERSION >= 0x0500 OBJECT_ENTRY(CLSID_ClusCryptoKeys, CClusResourceCryptoKeys) #endif // CLUSAPI_VERSION >= 0x0500 END_OBJECT_MAP() ///////////////////////////////////////////////////////////////////////////// // Forward function declarations ///////////////////////////////////////////////////////////////////////////// static void RegisterRegistryCleanUp( void ); static void UnregisterRegistryCleanUp( void ); static const LPWSTR g_ptszRegisterRegistryNodesToDelete[] = { _T( "software\\classes\\MSCluster.Application" ), _T( "software\\classes\\MSCluster.Application.2" ), _T( "software\\classes\\MSCluster.Cluster.2" ), _T( "software\\classes\\MSCluster.ClusGroupResources" ), _T( "software\\classes\\MSCluster.ClusGroupResources.1" ), _T( "software\\classes\\MSCluster.ClusGroupOwners" ), _T( "software\\classes\\MSCluster.ClusGroupOwners.1" ), _T( "software\\classes\\MSCluster.ClusResOwners" ), _T( "software\\classes\\MSCluster.ClusResOwners.1" ), _T( "software\\classes\\CLSID\\{f2e60717-2631-11d1-89f1-00a0c90d061e}" ), _T( "software\\classes\\interface\\{f2e60718-2631-11d1-89f1-00a0c90d061e}" ), _T( "software\\classes\\CLSID\\{f2e60719-2631-11d1-89f1-00a0c90d061e}" ), _T( "software\\classes\\interface\\{f2e6071a-2631-11d1-89f1-00a0c90d061e}" ), _T( "software\\classes\\interface\\{f2e606e0-2631-11d1-89f1-00a0c90d061e}" ), _T( "software\\classes\\interface\\{f2e606e1-2631-11d1-89f1-00a0c90d061e}" ), _T( "software\\classes\\interface\\{f2e606e3-2631-11d1-89f1-00a0c90d061e}" ), _T( "software\\classes\\interface\\{f2e606e5-2631-11d1-89f1-00a0c90d061e}" ), _T( "software\\classes\\interface\\{f2e606e7-2631-11d1-89f1-00a0c90d061e}" ), _T( "software\\classes\\interface\\{f2e606e9-2631-11d1-89f1-00a0c90d061e}" ), _T( "software\\classes\\interface\\{f2e606eb-2631-11d1-89f1-00a0c90d061e}" ), _T( "software\\classes\\interface\\{f2e606ed-2631-11d1-89f1-00a0c90d061e}" ), _T( "software\\classes\\interface\\{f2e606ef-2631-11d1-89f1-00a0c90d061e}" ), _T( "software\\classes\\interface\\{f2e606f3-2631-11d1-89f1-00a0c90d061e}" ), _T( "software\\classes\\interface\\{f2e606f5-2631-11d1-89f1-00a0c90d061e}" ), _T( "software\\classes\\interface\\{f2e606f7-2631-11d1-89f1-00a0c90d061e}" ), _T( "software\\classes\\interface\\{f2e606f9-2631-11d1-89f1-00a0c90d061e}" ), _T( "software\\classes\\interface\\{f2e606fb-2631-11d1-89f1-00a0c90d061e}" ), _T( "software\\classes\\interface\\{f2e606fd-2631-11d1-89f1-00a0c90d061e}" ), _T( "software\\classes\\interface\\{f2e606fe-2631-11d1-89f1-00a0c90d061e}" ), _T( "software\\classes\\interface\\{f2e606ff-2631-11d1-89f1-00a0c90d061e}" ), _T( "software\\classes\\interface\\{f2e60700-2631-11d1-89f1-00a0c90d061e}" ), _T( "software\\classes\\interface\\{f2e60702-2631-11d1-89f1-00a0c90d061e}" ), _T( "software\\classes\\interface\\{f2e60704-2631-11d1-89f1-00a0c90d061e}" ), _T( "software\\classes\\CLSID\\{f2e606f2-2631-11d1-89f1-00a0c90d061e}" ), NULL }; /* static const LPWSTR g_ptszUnregisterRegistryNodesToDelete[] = { // _T( "software\\classes\\typelib\\{f2e606e0-2631-11d1-89f1-00a0c90d061e}" ), _T( "software\\classes\\interface\\{f2e606e2-2631-11d1-89f1-00a0c90d061e}" ), _T( "software\\classes\\interface\\{f2e606e4-2631-11d1-89f1-00a0c90d061e}" ), _T( "software\\classes\\interface\\{f2e606e6-2631-11d1-89f1-00a0c90d061e}" ), _T( "software\\classes\\interface\\{f2e606e8-2631-11d1-89f1-00a0c90d061e}" ), _T( "software\\classes\\interface\\{f2e606ea-2631-11d1-89f1-00a0c90d061e}" ), _T( "software\\classes\\interface\\{f2e606ec-2631-11d1-89f1-00a0c90d061e}" ), _T( "software\\classes\\interface\\{f2e606ee-2631-11d1-89f1-00a0c90d061e}" ), _T( "software\\classes\\interface\\{f2e606f0-2631-11d1-89f1-00a0c90d061e}" ), _T( "software\\classes\\interface\\{f2e606f2-2631-11d1-89f1-00a0c90d061e}" ), _T( "software\\classes\\interface\\{f2e606f4-2631-11d1-89f1-00a0c90d061e}" ), _T( "software\\classes\\interface\\{f2e606f6-2631-11d1-89f1-00a0c90d061e}" ), _T( "software\\classes\\interface\\{f2e606f8-2631-11d1-89f1-00a0c90d061e}" ), _T( "software\\classes\\interface\\{f2e606fa-2631-11d1-89f1-00a0c90d061e}" ), _T( "software\\classes\\interface\\{f2e606fc-2631-11d1-89f1-00a0c90d061e}" ), _T( "software\\classes\\interface\\{f2e606fe-2631-11d1-89f1-00a0c90d061e}" ), _T( "software\\classes\\interface\\{f2e60700-2631-11d1-89f1-00a0c90d061e}" ), _T( "software\\classes\\interface\\{f2e60702-2631-11d1-89f1-00a0c90d061e}" ), _T( "software\\classes\\interface\\{f2e60704-2631-11d1-89f1-00a0c90d061e}" ), _T( "software\\classes\\interface\\{f2e60706-2631-11d1-89f1-00a0c90d061e}" ), _T( "software\\classes\\interface\\{f2e60708-2631-11d1-89f1-00a0c90d061e}" ), _T( "software\\classes\\interface\\{f2e6070a-2631-11d1-89f1-00a0c90d061e}" ), _T( "software\\classes\\interface\\{f2e6070c-2631-11d1-89f1-00a0c90d061e}" ), _T( "software\\classes\\interface\\{f2e6070e-2631-11d1-89f1-00a0c90d061e}" ), _T( "software\\classes\\interface\\{f2e60710-2631-11d1-89f1-00a0c90d061e}" ), _T( "software\\classes\\interface\\{f2e60712-2631-11d1-89f1-00a0c90d061e}" ), _T( "software\\classes\\interface\\{f2e60714-2631-11d1-89f1-00a0c90d061e}" ), _T( "software\\classes\\interface\\{f2e60716-2631-11d1-89f1-00a0c90d061e}" ), NULL }; */ ///////////////////////////////////////////////////////////////////////////// //++ // // DllMain // // Description: // DLL Entry Point. // // Arguments: // hInstance [IN] - Out instance handle. // dwReason [IN] - The reason we are being called. // lpReserved [IN] - Don't rightly know what this is... // // Return Value: // TRUE if successful, FALSE if not. // //-- ///////////////////////////////////////////////////////////////////////////// extern "C" BOOL WINAPI DllMain( IN HINSTANCE hInstance, IN DWORD dwReason, IN LPVOID //lpReserved ) { if ( dwReason == DLL_PROCESS_ATTACH ) { #ifdef _DEBUG _CrtSetDbgFlag( _CRTDBG_ALLOC_MEM_DF | _CRTDBG_LEAK_CHECK_DF ); _CrtSetReportMode( _CRT_ERROR, _CRTDBG_MODE_DEBUG ); #endif _Module.Init( ObjectMap, hInstance ); DisableThreadLibraryCalls( hInstance ); } else if ( dwReason == DLL_PROCESS_DETACH ) { _Module.Term(); } return TRUE; // ok } //*** DllMain() ///////////////////////////////////////////////////////////////////////////// //++ // // DllCanUnloadNow // // Description: // Used to determine whether the DLL can be unloaded by OLE. // // Arguments: // None. // // Return Value: // S_OK if we can unload, S_FALSE if we cannot. // //-- ///////////////////////////////////////////////////////////////////////////// STDAPI DllCanUnloadNow( void ) { return ( _Module.GetLockCount() == 0 ) ? S_OK : S_FALSE; } //*** DllCanUnloadNow() ///////////////////////////////////////////////////////////////////////////// //++ // // DllGetClassObject // // Description: // Retrieves the class object from a DLL object handler or object // application. DllGetClassObject is called from within the // CoGetClassObject function when the class context is a DLL. // // Arguments: // rclsid [IN] - CLSID that will associate the correct data and code. // riid [IN] - Reference to the identifier of the interface that the // caller is to use to communicate with the class object. // Usually, this is IID_IClassFactory (defined in the OLE // headers as the interface identifier for IClassFactory). // ppv [OUT] - Address of pointer variable that receives the interface // pointer requested in riid. Upon successful return, *ppv // contains the requested interface pointer. If an error // occurs, the interface pointer is NULL. // // Return Value: // S_OK if successful, or CLASS_E_CLASSNOTAVAILABLE if not. // //-- ///////////////////////////////////////////////////////////////////////////// STDAPI DllGetClassObject( IN REFCLSID rclsid, IN REFIID riid, OUT LPVOID * ppv ) { return _Module.GetClassObject( rclsid, riid, ppv ); } //*** DllGetClassObject() ///////////////////////////////////////////////////////////////////////////// //++ // // DllRegisterServer // // Description: // Add entries to the system registry. // // Arguments: // None. // // Return Value: // S_OK if successful, or other HRESULT error if not. // //-- ///////////////////////////////////////////////////////////////////////////// STDAPI DllRegisterServer( void ) { RegisterRegistryCleanUp(); // // Registers object, typelib and all interfaces in typelib // return _Module.RegisterServer( TRUE ); } //*** DllRegisterServer() ///////////////////////////////////////////////////////////////////////////// //++ // // DllUnregisterServer // // Description: // Removes entries from the system registry. // // Arguments: // None. // // Return Value: // S_OK if successful, or other HRESULT error if not. // //-- ///////////////////////////////////////////////////////////////////////////// STDAPI DllUnregisterServer( void ) { HRESULT _hr = S_FALSE; UnregisterRegistryCleanUp(); // // Unregisters object, typelib and all interfaces in typelib // _hr = _Module.UnregisterServer(); if ( SUCCEEDED( _hr ) ) { #if _WIN32_WINNT >= 0x0400 _hr = UnRegisterTypeLib( LIBID_MSClusterLib, 1, 0, LOCALE_NEUTRAL, SYS_WIN32 ); #endif } //if: server was unregistered return _hr; } //*** DllUnregisterServer() ///////////////////////////////////////////////////////////////////////////// //++ // // HrGetCluster // // Description: // Common implementation of creating a new cluster object. // // Arguments: // ppCluster [OUT] - Catches the newly created object. // pClusRefObject [IN] - Object that wraps the cluster handle. // // Return Value: // S_OK for success // //-- ///////////////////////////////////////////////////////////////////////////// HRESULT HrGetCluster( OUT ISCluster ** ppCluster, IN ISClusRefObject * pClusRefObject ) { //ASSERT( ppCluster != NULL ); ASSERT( pClusRefObject != NULL ); HRESULT _hr = E_POINTER; if ( ( ppCluster != NULL ) && ( pClusRefObject != NULL ) ) { HCLUSTER hCluster = NULL; _hr = pClusRefObject->get_Handle( (ULONG_PTR *) &hCluster ); if ( SUCCEEDED( _hr ) ) { CComObject< CCluster > * pCluster = NULL; _hr = CComObject< CCluster >::CreateInstance( &pCluster ); if ( SUCCEEDED( _hr ) ) { pCluster->ClusRefObject( pClusRefObject ); pCluster->Hcluster( hCluster ); _hr = pCluster->QueryInterface( IID_ISCluster, (void **) ppCluster ); } } } return _hr; } //*** HrGetCluster() ///////////////////////////////////////////////////////////////////////////// //++ // // RegisterRegistryCleanUp // // Description: // Clean up the registry during registration // // Arguments: // None. // // Return Value: // None. // //-- ///////////////////////////////////////////////////////////////////////////// static void RegisterRegistryCleanUp( void ) { int nIndex;; for ( nIndex = 0; ; nIndex++ ) { if ( g_ptszRegisterRegistryNodesToDelete[ nIndex ] == NULL ) { break; } // if: RegDelnode( HKEY_LOCAL_MACHINE, g_ptszRegisterRegistryNodesToDelete[ nIndex ] ); } // for: } //*** RegisterRegistryCleanUp() ///////////////////////////////////////////////////////////////////////////// //++ // // UnregisterRegistryCleanUp // // Description: // Clean up the registry during unregistration // // Arguments: // None. // // Return Value: // None. // //-- ///////////////////////////////////////////////////////////////////////////// static void UnregisterRegistryCleanUp( void ) { return; } //*** UnregisterRegistryCleanUp() ///////////////////////////////////////////////////////////////////////////// //++ // // ClearIDispatchEnum // // Description: // Cleans up an Enum of IDispatch pointers. // // Arguments: // ppVarVect [IN OUT] - The enum to clean up. // // Return Value: // None. // //-- ///////////////////////////////////////////////////////////////////////////// void ClearIDispatchEnum( IN OUT CComVariant ** ppvarVect ) { if ( ppvarVect != NULL ) { size_t cCount = ARRAYSIZE( *ppvarVect ); size_t iIndex; for ( iIndex = 0; iIndex < cCount; iIndex++ ) { (*ppvarVect[iIndex]).pdispVal->Release(); } // for: delete [] *ppvarVect; *ppvarVect = NULL; } } //*** ClearIDispatchEnum() ///////////////////////////////////////////////////////////////////////////// //++ // // ClearVariantEnum // // Description: // Cleans up an Enum of variant values. // // Arguments: // ppVarVect [IN OUT] - The enum to clean up. // // Return Value: // None. // //-- ///////////////////////////////////////////////////////////////////////////// void ClearVariantEnum( IN OUT CComVariant ** ppvarVect ) { if ( ppvarVect != NULL ) { delete [] *ppvarVect; *ppvarVect = NULL; } } //*** ClearVariantEnum()