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.
 
 
 
 
 
 

440 lines
9.6 KiB

//////////////////////////////////////////////////////////////////////////////
//
// Copyright (c) 2000 Microsoft Corporation
//
// Module Name:
// main.cpp
//
// Description:
// The entry point for the application that launches unattended
// installation of the cluster. This application parses input parameters,
// CoCreates the Configuration Wizard Component, passes the parsed
// parameters and invokes the Wizard. The Wizard may or may not show any
// UI depending on swithes and the (in)availability of information.
//
// Maintained By:
// Galen Barbee (GalenB) 22-JAN-2000
// David Potter (DavidP) 22-JAN-2000
//
//////////////////////////////////////////////////////////////////////////////
#include "pch.h"
#include <initguid.h>
#include <guids.h>
#include <ClusRtl.h>
#include "Callback.h"
DEFINE_MODULE( "CLUSCFGSERVERTEST" )
//
// Declarations
//
typedef HRESULT (* PDLLREGISTERSERVER)( void );
//
// Globals
//
HINSTANCE g_hInstance = NULL;
LONG g_cObjects = 0;
IClusCfgServer * g_pccs = NULL;
//
// Register the DLL
//
HRESULT
HrRegisterTheDll( void )
{
TraceFunc( "" );
HRESULT hr;
PDLLREGISTERSERVER pDllRegisterServer;
HMODULE hLib = NULL;
//
// Make sure the DLL is properly registered.
//
hLib = LoadLibrary( L"..\\..\\..\\..\\dll\\obj\\i386\\ClusCfgServer.dll" );
if ( hLib == NULL )
goto Win32Error;
pDllRegisterServer = reinterpret_cast< PDLLREGISTERSERVER >( GetProcAddress( hLib, "DllRegisterServer" ) );
if ( pDllRegisterServer == NULL )
goto Win32Error;
hr = THR( pDllRegisterServer() );
if ( FAILED( hr ) )
goto Cleanup;
Cleanup:
if ( hLib != NULL )
{
FreeLibrary( hLib );
}
HRETURN( hr );
Win32Error:
hr = THR( HRESULT_FROM_WIN32( GetLastError() ) );
goto Cleanup;
}
//
// This tests the Storage device enumeration.
//
HRESULT
HrTestManagedResourceEnum( void )
{
TraceFunc( "" );
HRESULT hr;
IEnumClusCfgManagedResources * pesd = NULL;
ULONG cReceived = 0;
IClusCfgManagedResourceInfo * rgDevices[ 10 ];
hr = g_pccs->GetManagedResourcesEnum( &pesd );
if ( FAILED( hr ) )
{
goto Cleanup;
} // if:
while ( hr == S_OK )
{
hr = pesd->Next( sizeof( rgDevices ) / sizeof( rgDevices[ 0 ] ), &rgDevices[ 0 ], &cReceived );
if ( FAILED( hr ) )
{
goto Cleanup;
} // if:
DebugMsg( "cReceived = %u", cReceived );
for ( ULONG idx = 0; idx < cReceived; idx++ )
{
BSTR bstr;
THR( rgDevices[ idx ]->GetUID( &bstr ) );
DebugMsg( "Device %u, UID = %ws", idx, bstr );
SysFreeString( bstr );
rgDevices[ idx ]->Release();
} // for:
} // while:
if ( hr == S_FALSE )
{
hr = S_OK;
} // if:
Cleanup:
if ( pesd != NULL )
{
pesd->Release();
}
HRETURN( hr );
} //*** HrTestManagedResourceEnum()
//
// This tests the Storage device enumeration.
//
HRESULT
HrTestNetworksEnum( void )
{
TraceFunc( "" );
HRESULT hr;
IEnumClusCfgNetworks * pens = NULL;
ULONG cReceived = 0;
IClusCfgNetworkInfo * rdNetworks[ 10 ];
BSTR bstrUID;
LPWSTR lpsz = NULL;
ULONG ulDottedQuad;
IClusCfgIPAddressInfo * piccipai = NULL;
hr = g_pccs->GetNetworksEnum( &pens );
if ( FAILED( hr ) )
{
goto Cleanup;
} // if:
while ( hr == S_OK )
{
hr = STHR( pens->Next( sizeof( rdNetworks ) / sizeof( rdNetworks[ 0 ] ), &rdNetworks[ 0 ], &cReceived ) );
if ( FAILED( hr ) )
{
goto Cleanup;
} // if:
for ( ULONG idx = 0; idx < cReceived; idx++ )
{
hr = THR( rdNetworks[ idx ]->GetPrimaryNetworkAddress( &piccipai ) );
if ( SUCCEEDED( hr ) )
{
hr = THR( piccipai->GetIPAddress( &ulDottedQuad ) );
if ( SUCCEEDED( hr ) )
{
DWORD sc;
sc = ClRtlTcpipAddressToString( ulDottedQuad, &lpsz );
if ( sc == ERROR_SUCCESS )
{
LocalFree( lpsz );
lpsz = NULL;
} // if:
} // if:
piccipai->Release();
} // if:
hr = THR( rdNetworks[ idx ]->GetUID( &bstrUID ) );
if ( SUCCEEDED( hr ) )
{
SysFreeString( bstrUID );
} // if:
rdNetworks[ idx ]->Release();
} // for:
} // while:
if ( hr == S_FALSE )
{
hr = S_OK;
} // if:
Cleanup:
if ( pens != NULL )
{
pens->Release();
}
if ( lpsz != NULL )
{
LocalFree( lpsz );
} // if:
HRETURN( hr );
} //*** HrTestNetworksEnum()
//
// This tests the node information
//
HRESULT
HrTestNodeInfo( void )
{
TraceFunc( "" );
HRESULT hr;
IClusCfgNodeInfo * pccni = NULL;
DWORD dwNodeHighestVersion;
DWORD dwNodeLowestVersion;
SDriveLetterMapping dlmDriveLetterUsage;
IClusCfgClusterInfo * pccci = NULL;
DWORD dwMajorVersion;
DWORD dwMinorVersion;
WORD wSuiteMask;
BYTE bProductType;
BSTR bstrCSDVersion = NULL;
hr = g_pccs->GetClusterNodeInfo( &pccni );
if ( FAILED( hr ) )
{
goto Cleanup;
} // if:
hr = pccni->GetClusterVersion( &dwNodeHighestVersion, &dwNodeLowestVersion );
if ( FAILED( hr ) )
{
goto Cleanup;
} // if:
hr = pccni->GetOSVersion( &dwMajorVersion, &dwMinorVersion, &wSuiteMask, &bProductType, &bstrCSDVersion );
if ( FAILED( hr ) )
{
goto Cleanup;
} // if:
hr = pccni->GetDriveLetterMappings( &dlmDriveLetterUsage );
if ( FAILED( hr ) )
{
goto Cleanup;
} // if:
hr = pccni->GetClusterConfigInfo( &pccci );
if ( FAILED( hr ) )
{
goto Cleanup;
} // if:
Cleanup:
if ( pccci != NULL )
{
pccci->Release();
}
if ( pccni != NULL )
{
pccni->Release();
}
SysFreeString( bstrCSDVersion );
HRETURN( hr );
} //*** HrTestNodeInfo()
//////////////////////////////////////////////////////////////////////////////
//
// int
// _cdecl
// main( void )
//
// Description:
// Program entrance.
//
// Arguments:
// None.
//
// Return Value:
// S_OK (0) - Success.
// other HRESULTs - Error.
//
//////////////////////////////////////////////////////////////////////////////
int _cdecl
main( void )
{
HRESULT hr;
IClusCfgInitialize * pgcci = NULL;
IClusCfgCapabilities * piccc = NULL;
IUnknown * punkCallback = NULL;
TraceInitializeProcess();
#if 0
hr = THR( HrRegisterTheDll() );
if ( FAILED( hr ) )
{
goto Cleanup;
} // if:
#endif
//
// Start up the Cluster configuration server
//
hr = THR( CoInitialize( NULL ) );
if ( FAILED( hr ) )
{
goto Cleanup;
} // if:
hr = THR( CoInitializeSecurity(
NULL,
-1,
NULL,
NULL,
RPC_C_AUTHN_LEVEL_PKT_PRIVACY,
RPC_C_IMP_LEVEL_IMPERSONATE,
NULL,
EOAC_NONE,
0
) );
if ( FAILED( hr ) )
{
goto Cleanup;
} // if:
hr = THR( CoCreateInstance( CLSID_ClusCfgServer, NULL, CLSCTX_SERVER, TypeSafeParams( IClusCfgServer, &g_pccs ) ) );
if ( FAILED( hr ) )
{
goto Cleanup;
} // if:
hr = THR( g_pccs->TypeSafeQI( IClusCfgInitialize, &pgcci ) );
if ( FAILED( hr ) )
{
goto Cleanup;
} // if:
hr = THR( Callback::S_HrCreateInstance( &punkCallback ) );
if ( FAILED( hr ) )
{
goto Cleanup;
} // if:
hr = pgcci->Initialize( punkCallback, GetUserDefaultLCID() );
if ( FAILED( hr ) )
{
goto Cleanup;
} // if:
hr = THR( g_pccs->TypeSafeQI( IClusCfgCapabilities, &piccc ) );
if ( FAILED( hr ) )
{
goto Cleanup;
} // if:
hr = THR( piccc->CanNodeBeClustered() );
if ( FAILED( hr ) || ( hr == S_FALSE ) )
{
goto Cleanup;
} // if:
hr = THR( HrTestNodeInfo() );
if ( FAILED( hr ) )
{
goto Cleanup;
} // if:
hr = THR( HrTestManagedResourceEnum() );
if ( FAILED( hr ) )
{
goto Cleanup;
} // if:
hr = THR( HrTestNetworksEnum() );
if ( FAILED( hr ) )
{
goto Cleanup;
} // if:
Cleanup:
if ( punkCallback != NULL )
{
punkCallback->Release();
} // if:
if ( piccc != NULL )
{
piccc->Release();
} // if:
if ( pgcci != NULL )
{
pgcci->Release();
} // if:
if ( g_pccs != NULL )
{
g_pccs->Release();
}
CoUninitialize();
TraceTerminateProcess();
return 0;
}