///////////////////////////////////////////////////////////////////////////// // // Copyright (c) 1996-2000 Microsoft Corporation // // Module Name: // IISClEx3.cpp // // Abstract: // Implementation of the CIISCluExApp class and DLL initialization // routines. // // Author: // David Potter (davidp) June 28, 1996 // // Revision History: // // Notes: // ///////////////////////////////////////////////////////////////////////////// #include "stdafx.h" #include "resource.h" #include #include #include "IISClEx3.h" #include "ExtObj.h" #include "RegExt.h" #ifdef _DEBUG #define new DEBUG_NEW #undef THIS_FILE static char THIS_FILE[] = __FILE__; #endif #define IID_DEFINED #include "ExtObjID_i.c" CComModule _Module; #pragma warning(disable : 4701) // local variable may be used without having been initialized #include #pragma warning(default : 4701) BEGIN_OBJECT_MAP(ObjectMap) OBJECT_ENTRY(CLSID_CoIISClEx3, CExtObject) END_OBJECT_MAP() ///////////////////////////////////////////////////////////////////////////// // Global Function Prototypes ///////////////////////////////////////////////////////////////////////////// STDAPI DllGetClassObject(REFCLSID rclsid, REFIID riid, LPVOID * ppv); STDAPI DllCanUnloadNow(void); STDAPI DllRegisterServer(void); STDAPI DllUnregisterServer(void); STDAPI DllRegisterCluAdminExtension(IN HCLUSTER hcluster); STDAPI DllUnregisterCluAdminExtension(IN HCLUSTER hcluster); ///////////////////////////////////////////////////////////////////////////// // class CIISCluExApp ///////////////////////////////////////////////////////////////////////////// class CIISCluExApp : public CWinApp { public: virtual BOOL InitInstance(); virtual int ExitInstance(); }; CIISCluExApp theApp; ///////////////////////////////////////////////////////////////////////////// //++ // // CIISCluExApp::InitInstance // // Routine Description: // Initialize this instance of the application. // // Arguments: // None. // // Return Value: // TRUE Application initialized successfully. // FALSE Error initializing application. // //-- ///////////////////////////////////////////////////////////////////////////// BOOL CIISCluExApp::InitInstance(void) { _Module.Init(ObjectMap, m_hInstance); // Construct the help path. // This is only necessary if the name of the help file is different // than the name of this DLL. Remove this code if the name of the // help file becomes the same as the name of the DLL. { TCHAR szPath[_MAX_PATH]; TCHAR szDrive[_MAX_PATH]; TCHAR szDir[_MAX_DIR]; int cchPath; VERIFY(::GetSystemWindowsDirectory(szPath, _MAX_PATH)); cchPath = lstrlen(szPath); if (szPath[cchPath - 1] != _T('\\')) { szPath[cchPath++] = _T('\\'); szPath[cchPath] = _T('\0'); } // if: no backslash on the end of the path lstrcpy(&szPath[cchPath], _T("Help\\")); _tsplitpath(szPath, szDrive, szDir, NULL, NULL); _tmakepath(szPath, szDrive, szDir, _T("cluadmin"), _T(".hlp")); free((void *) m_pszHelpFilePath); BOOL bEnable; bEnable = AfxEnableMemoryTracking(FALSE); m_pszHelpFilePath = _tcsdup(szPath); AfxEnableMemoryTracking(bEnable); } // Construct the help path return CWinApp::InitInstance(); } //*** CIISCluExApp::InitInstance() ///////////////////////////////////////////////////////////////////////////// //++ // // CIISCluExApp::ExitInstance // // Routine Description: // Cleans up this instance of the application. // // Arguments: // None. // // Return Value: // Application's exit code. 0 indicates no errors. // //-- ///////////////////////////////////////////////////////////////////////////// int CIISCluExApp::ExitInstance(void) { _Module.Term(); return CWinApp::ExitInstance(); } //*** CIISCluExApp::ExitInstance() ///////////////////////////////////////////////////////////////////////////// // Used to determine whether the DLL can be unloaded by OLE STDAPI DllCanUnloadNow(void) { AFX_MANAGE_STATE(AfxGetStaticModuleState()); return (AfxDllCanUnloadNow() && _Module.GetLockCount()==0) ? S_OK : S_FALSE; } ///////////////////////////////////////////////////////////////////////////// // Returns a class factory to create an object of the requested type STDAPI DllGetClassObject(REFCLSID rclsid, REFIID riid, LPVOID* ppv) { return _Module.GetClassObject(rclsid, riid, ppv); } ///////////////////////////////////////////////////////////////////////////// // DllRegisterServer - Adds entries to the system registry STDAPI DllRegisterServer(void) { // registers object, typelib and all interfaces in typelib return _Module.RegisterServer(FALSE /*bRegTypeLib*/); } ///////////////////////////////////////////////////////////////////////////// // DllUnregisterServer - Adds entries to the system registry STDAPI DllUnregisterServer(void) { _Module.UnregisterServer(); return S_OK; } ///////////////////////////////////////////////////////////////////////////// //++ // // FormatError // // Routine Description: // Format an error. // // Arguments: // rstrError [OUT] String in which to return the error message. // dwError [IN] Error code to format. // // Return Value: // None. // //-- ///////////////////////////////////////////////////////////////////////////// void FormatError(CString & rstrError, DWORD dwError) { DWORD _cch; TCHAR _szError[512]; _cch = FormatMessage( FORMAT_MESSAGE_FROM_SYSTEM, NULL, dwError, MAKELANGID(LANG_NEUTRAL, SUBLANG_NEUTRAL), _szError, sizeof(_szError) / sizeof(TCHAR), 0 ); if (_cch == 0) { // Format the NT status code from NTDLL since this hasn't been // integrated into the system yet. _cch = FormatMessage( FORMAT_MESSAGE_FROM_HMODULE | FORMAT_MESSAGE_IGNORE_INSERTS, ::GetModuleHandle(_T("NTDLL.DLL")), dwError, MAKELANGID(LANG_NEUTRAL, SUBLANG_NEUTRAL), _szError, sizeof(_szError) / sizeof(TCHAR), 0 ); } // if: error formatting status code from system if (_cch > 0) { rstrError = _szError; } // if: no error else { #ifdef _DEBUG DWORD _sc = GetLastError(); TRACE(_T("FormatError() - Error 0x%08.8x formatting string for error code 0x%08.8x\n"), _sc, dwError); #endif rstrError.Format(_T("Error 0x%08.8x"), dwError); } // else: error formatting the message } //*** FormatError() ///////////////////////////////////////////////////////////////////////////// //++ // // DllRegisterCluAdminExtension // // Routine Description: // Register the extension with the cluster database. // // Arguments: // hCluster [IN] Handle to the cluster to modify. // // Return Value: // S_OK Extension registered successfully. // Win32 error code if another failure occurred. // //-- ///////////////////////////////////////////////////////////////////////////// STDAPI DllRegisterCluAdminExtension(IN HCLUSTER hCluster) { HRESULT hr = S_OK; LPCWSTR pwszResTypes = g_wszResourceTypeNames; while (*pwszResTypes != L'\0') { wprintf(L" %s\n", pwszResTypes); hr = RegisterCluAdminResourceTypeExtension( hCluster, pwszResTypes, &CLSID_CoIISClEx3 ); if (hr != S_OK) break; pwszResTypes += lstrlenW(pwszResTypes) + 1; } // while: more resource types return hr; } //*** DllRegisterCluAdminExtension() ///////////////////////////////////////////////////////////////////////////// //++ // // DllUnregisterCluAdminExtension // // Routine Description: // Unregister the extension with the cluster database. // // Arguments: // hCluster [IN] Handle to the cluster to modify. // // Return Value: // S_OK Extension unregistered successfully. // Win32 error code if another failure occurred. // //-- ///////////////////////////////////////////////////////////////////////////// STDAPI DllUnregisterCluAdminExtension(IN HCLUSTER hCluster) { HRESULT hr = S_OK; LPCWSTR pwszResTypes = g_wszResourceTypeNames; while (*pwszResTypes != L'\0') { wprintf(L" %s\n", pwszResTypes); hr = UnregisterCluAdminResourceTypeExtension( hCluster, pwszResTypes, &CLSID_CoIISClEx3 ); if (hr != S_OK) break; pwszResTypes += lstrlenW(pwszResTypes) + 1; } // while: more resource types return hr; } //*** DllUnregisterCluAdminExtension()