Source code of Windows XP (NT5)
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.
 
 
 
 
 
 

519 lines
13 KiB

/////////////////////////////////////////////////////////////////////////////
//
// Copyright(C) 1997-1998 Microsoft Corporation all rights reserved.
//
// Module: sdocomponent.cpp
//
// Project: Everest
//
// Description: IAS Server Data Object - IAS Component Class Implementation
//
// Author: TLP 6/18/98
//
/////////////////////////////////////////////////////////////////////////////
#include "stdafx.h"
#include <ias.h>
#include <iascomp.h>
#include <portparser.h>
#include "sdocomponent.h"
#include "sdohelperfuncs.h"
///////////////////////////////
// CComponentCfg Implementation
///////////////////////////////
//////////////////////////////////////////////////////////////////////////////
CComponentCfg::CComponentCfg(LONG lComponentId)
: m_lComponentId(lComponentId),
m_pComponentCfg(NULL)
{
// create letter object
//
switch( lComponentId )
{
case IAS_PROVIDER_MICROSOFT_NTSAM_AUTH:
m_pComponentCfg = (CComponentCfg*) new CComponentCfgAuth(lComponentId);
break;
case IAS_PROVIDER_MICROSOFT_ACCOUNTING:
m_pComponentCfg = (CComponentCfg*) new CComponentCfgAccounting(lComponentId);
break;
case IAS_PROTOCOL_MICROSOFT_RADIUS:
m_pComponentCfg = (CComponentCfg*) new CComponentCfgRADIUS(lComponentId);
break;
default:
m_pComponentCfg = (CComponentCfg*) new CComponentCfgNoOp(lComponentId);
break;
}
}
//////////////////////////////////////////////////////////////////////////////
HRESULT CComponentCfgAuth::Load(CSdoComponent* pSdoComponent)
{
HRESULT hr = S_OK;
do
{
// Determine if were attached to the local machine
//
BSTR bstrMachine = NULL;
hr = (pSdoComponent->GetMachineSdo())->GetAttachedComputer(&bstrMachine);
if ( FAILED(hr) )
break;
wchar_t computerName[MAX_COMPUTERNAME_LENGTH + 1];
DWORD size = MAX_COMPUTERNAME_LENGTH;
GetComputerName(computerName, &size);
LONG lResult = ERROR_SUCCESS;
HKEY hKeyRemote = HKEY_LOCAL_MACHINE;
if ( lstrcmpi(computerName, bstrMachine ) )
{
// We're not attached to the local machine so connect to the
// registry of the remote machine
//
lResult = RegConnectRegistry(
bstrMachine,
HKEY_LOCAL_MACHINE,
&hKeyRemote
);
}
SysFreeString(bstrMachine);
if ( ERROR_SUCCESS != lResult )
{
IASTracePrintf("Error in NT SAM Authentication SDO - Could not attach to the remote registry..");
hr = HRESULT_FROM_WIN32(GetLastError());
break;
}
// Open the IAS key
//
CRegKey IASKey;
lResult = IASKey.Open(
hKeyRemote,
IAS_POLICY_REG_KEY,
KEY_READ
);
if ( lResult != ERROR_SUCCESS )
{
IASTracePrintf("Error in NT SAM Authentication SDO - Could not open IAS registry key..");
hr = HRESULT_FROM_WIN32(GetLastError());
break;
}
// Get the value of the Allow LAN Manager Authentication key.
// Note that this key may not even be present. In this case
// the property object will just use the schema defined default.
//
VARIANT vt;
DWORD dwValue;
lResult = IASKey.QueryValue(
dwValue,
(LPCTSTR) IAS_NTSAM_AUTH_ALLOW_LM
);
if ( lResult == ERROR_SUCCESS )
{
V_VT(&vt) = VT_BOOL;
V_BOOL(&vt) = (dwValue ? VARIANT_TRUE : VARIANT_FALSE);
hr = pSdoComponent->PutComponentProperty(
PROPERTY_NTSAM_ALLOW_LM_AUTHENTICATION,
&vt
);
if ( FAILED(hr) )
{
IASTracePrintf("Error in NT SAM Authentication SDO - Could not store the Allow LM property..");
break;
}
}
} while ( FALSE );
return hr;
}
//////////////////////////////////////////////////////////////////////////////
HRESULT CComponentCfgRADIUS::Initialize(CSdoComponent* pSdoComponent)
{
HRESULT hr = E_FAIL;
do
{
CComPtr<IDataStoreContainer> pDSContainer;
hr = (pSdoComponent->GetComponentDataStore())->QueryInterface(IID_IDataStoreContainer, (void**)&pDSContainer);
if ( FAILED(hr) )
{
IASTracePrintf("Error in SDO Component - RADIUS::Initialize() - QueryInterface() failed...");
break;
}
CComBSTR bstrClientsName(DS_OBJECT_CLIENTS);
if (!bstrClientsName)
{
hr = E_OUTOFMEMORY;
break;
}
CComPtr<IDataStoreObject> pDSObject;
hr = pDSContainer->Item(
bstrClientsName,
&pDSObject
);
if ( FAILED(hr) )
{
IASTracePrintf("Error in SDO Component - RADIUS::Initialize() - IDataStoreContainer::Item(Clients) failed...");
break;
}
CComPtr<IDataStoreContainer> pDSContainer2;
hr = pDSObject->QueryInterface(
IID_IDataStoreContainer,
(void**)&pDSContainer2
);
if ( FAILED(hr) )
{
IASTracePrintf("Error in SDO Component - RADIUS::Initialize() - QueryInterface() failed...");
break;
}
hr = pSdoComponent->InitializeComponentCollection(
PROPERTY_RADIUS_CLIENTS_COLLECTION,
SDO_PROG_ID_CLIENT,
pDSContainer2
);
if ( FAILED(hr) )
break;
pDSObject.Release();
pDSContainer2.Release();
CComBSTR bstrVendorsName(DS_OBJECT_VENDORS);
if (!bstrVendorsName)
{
hr = E_OUTOFMEMORY;
break;
}
hr = pDSContainer->Item(
bstrVendorsName,
&pDSObject
);
if ( FAILED(hr) )
{
IASTracePrintf("Error in SDO Component - RADIUS::Initialize() - IDataStoreContainer::Item(Vendors) failed...");
break;
}
hr = pDSObject->QueryInterface(
IID_IDataStoreContainer,
(void**)&pDSContainer2
);
if ( FAILED(hr) )
{
IASTracePrintf("Error in SDO Component - RADIUS::Initialize() - QueryInterface() failed...");
break;
}
hr = pSdoComponent->InitializeComponentCollection(
PROPERTY_RADIUS_VENDORS_COLLECTION,
SDO_PROG_ID_VENDOR,
pDSContainer2
);
} while ( FALSE );
return hr;
}
//////////////////////////////////////////////////////////////////////////////
HRESULT CComponentCfgRADIUS::Validate (CSdoComponent* pSdoComponent)
{
HRESULT hr = S_OK;
do
{
// get the RADIUS authentication port value now
_variant_t varAuthValue;
hr = pSdoComponent->GetProperty (
PROPERTY_RADIUS_AUTHENTICATION_PORT,
&varAuthValue
);
if (FAILED (hr))
{
IASTracePrintf ("Error in SDO Component - RADIUS::Validate - GetProperty () failed...");
break;
}
// validate the authentication port now
hr = ValidatePort (V_BSTR (&varAuthValue));
if (FAILED (hr))
{
IASTracePrintf ("Error in SDO Component - RADIUS::Validate - Invalid IP Address or UDP port value specified...");
break;
}
// get the RADIUS accounting port format now
_variant_t varAcctValue;
hr = pSdoComponent->GetProperty (
PROPERTY_RADIUS_ACCOUNTING_PORT,
&varAcctValue
);
if (FAILED (hr))
{
IASTracePrintf ("Error in SDO Component - RADIUS::Validate - GetProperty () failed...");
break;
}
// validate the accounting port now
hr = ValidatePort (V_BSTR (&varAcctValue));
if (FAILED (hr))
{
IASTracePrintf ("Error in SDO Component - RADIUS::Validate - Invalid IP Address or UDP port value specified...");
break;
}
}
while (FALSE);
return (hr);
}
// validating the port value provided
HRESULT CComponentCfgRADIUS::ValidatePort (PWCHAR pwszPortInfo)
{
_ASSERT (pwszPortInfo);
HRESULT hr = S_OK;
CPortParser parser (pwszPortInfo);
do
{
//
// get the IP address
//
DWORD dwIPAddress = 0;
hr = parser.GetIPAddress(&dwIPAddress);
if (S_FALSE == hr)
{
break;
}
else if (S_OK == hr)
{
//
// get the ports associated with this IP address
//
do
{
WORD wPort = 0;
hr = parser.GetNextPort (&wPort);
}
while (S_OK == hr);
}
}
while (SUCCEEDED (hr));
return (hr);
} // end of CPorts::CollectPortInfo method
//////////////////////////////////////////////////////////////////////////////
HRESULT CComponentCfgAccounting::Initialize(CSdoComponent* pSdoComponent)
{
HRESULT hr = E_FAIL;
do
{
BSTR bstrMachineName = NULL;
hr = (pSdoComponent->GetMachineSdo())->GetAttachedComputer(&bstrMachineName);
if ( FAILED(hr) )
{
IASTracePrintf("Error in Accounting SDO - Could not get the name of the attached computer...");
break;
}
wchar_t szLogFileDir[MAX_PATH+1];
hr = ::SDOGetLogFileDirectory(
bstrMachineName,
MAX_PATH,
szLogFileDir
);
if ( FAILED(hr) )
{
SysFreeString(bstrMachineName);
IASTracePrintf("Error in Accounting SDO - Could not get the default log file directory..");
break;
}
_variant_t vtLogFileDir = szLogFileDir;
SysFreeString(bstrMachineName);
hr = pSdoComponent->ChangePropertyDefault(
PROPERTY_ACCOUNTING_LOG_FILE_DIRECTORY,
&vtLogFileDir
);
if ( FAILED(hr) )
{
IASTracePrintf("Error in Accounting SDO - Could not store the default log file directory property..");
break;
}
} while ( FALSE );
return hr;
}
///////////////////////////////
// CSdoComponent Implementation
///////////////////////////////
////////////////////////////////////////////////////////////////////////////////
CSdoComponent::CSdoComponent()
: m_pComponentCfg(NULL),
m_pAttachedMachine(NULL)
{
}
////////////////////////////////////////////////////////////////////////////////
CSdoComponent::~CSdoComponent()
{
if ( m_pComponentCfg )
delete m_pComponentCfg;
if ( m_pAttachedMachine )
m_pAttachedMachine->Release();
}
////////////////////////////////////////////////////////////////////////
HRESULT CSdoComponent::InitializeComponentCollection(
/*[in]*/ LONG CollectionPropertyId,
/*[in]*/ LPWSTR lpszCreateClassId,
/*[in]*/ IDataStoreContainer* pDSContainer
)
{
_ASSERT ( m_pAttachedMachine );
return InitializeCollection(
CollectionPropertyId,
lpszCreateClassId,
m_pAttachedMachine,
pDSContainer
);
}
////////////////////////////////////////////////////////////////////////
HRESULT CSdoComponent::ChangePropertyDefault(
/*[in]*/ LONG Id,
/*[in]*/ VARIANT* pValue
)
{
return ChangePropertyDefaultInternal(Id, pValue);
}
////////////////////////////////////////////////////////////////////////
HRESULT CSdoComponent::PutComponentProperty(
/*[in]*/ LONG Id,
/*[in]*/ VARIANT* pValue
)
{
return PutPropertyInternal(Id, pValue);
}
//////////////////////////////////////////////////////////////////////////////
HRESULT CSdoComponent::FinalInitialize(
/*[in]*/ bool fInitNew,
/*[in]*/ ISdoMachine* pAttachedMachine
)
{
_ASSERT ( ! fInitNew );
HRESULT hr;
do
{
hr = Load();
if ( FAILED(hr) )
{
IASTracePrintf("Error in Component SDO - FinalInitialize() - Could not load component properties...");
break;
}
_variant_t vtComponentId;
hr = GetPropertyInternal(PROPERTY_COMPONENT_ID, &vtComponentId);
if ( FAILED(hr) )
{
IASTracePrintf("Error in Component SDO - FinalInitialize() - Could not get the component Id...");
break;
}
auto_ptr<CComponentCfg> pComponentCfg (new CComponentCfg(V_I4(&vtComponentId)));
if ( NULL == pComponentCfg.get() )
{
IASTracePrintf("Error in Component SDO - FinalInitialize() - Could not create component: %lx...",V_I4(&vtComponentId));
hr = E_FAIL;
break;
}
(m_pAttachedMachine = pAttachedMachine)->AddRef();
hr = pComponentCfg->Initialize(this);
if ( FAILED(hr) )
{
IASTracePrintf("Error in Component SDO - FinalInitialize() - Could not initialize component: %lx...",V_I4(&vtComponentId));
break;
}
m_pComponentCfg = pComponentCfg.release();
hr = Load();
if ( FAILED(hr) )
{
IASTracePrintf("Error in Component SDO - FinalInitialize() - Could not configure component: %lx...",V_I4(&vtComponentId));
break;
}
} while ( FALSE );
return hr;
}
//////////////////////////////////////////////////////////////////////////////
HRESULT CSdoComponent::Load()
{
HRESULT hr = CSdo::Load();
if ( SUCCEEDED(hr) )
{
if ( m_pComponentCfg )
hr = m_pComponentCfg->Load(this);
}
return hr;
}
//////////////////////////////////////////////////////////////////////////////
HRESULT CSdoComponent::Save()
{
HRESULT hr = CSdo::Save();
if ( SUCCEEDED(hr) )
{
if ( m_pComponentCfg )
{
hr = m_pComponentCfg->Validate (this);
if (SUCCEEDED (hr))
{
hr = m_pComponentCfg->Save(this);
}
}
}
return hr;
}