windows-nt/Source/XPSP1/NT/base/cluster/admin/iisclex3/iisclex3.cpp
2020-09-26 16:20:57 +08:00

325 lines
8 KiB
C++

/////////////////////////////////////////////////////////////////////////////
//
// 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 <initguid.h>
#include <CluAdmEx.h>
#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 <atlimpl.cpp>
#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()