windows-nt/Source/XPSP1/NT/ds/adsi/nwnds/cenumusr.cxx

426 lines
8.5 KiB
C++
Raw Normal View History

2020-09-26 03:20:57 -05:00
//---------------------------------------------------------------------------
//
// Microsoft Windows
// Copyright (C) Microsoft Corporation, 1992 - 1995
//
// File: cenumUserCollection.cxx
//
// Contents: Windows NT 3.5 UserCollection Enumeration Code
//
// CNDSUserCollectionEnum::CNDSUserCollectionEnum()
// CNDSUserCollectionEnum::CNDSUserCollectionEnum
// CNDSUserCollectionEnum::EnumObjects
// CNDSUserCollectionEnum::EnumObjects
//
// History:
//----------------------------------------------------------------------------
#include "NDS.hxx"
#pragma hdrstop
//+---------------------------------------------------------------------------
//
// Function: CNDSEnumVariant::Create
//
// Synopsis:
//
// Arguments: [pCollection]
// [ppEnumVariant]
//
// Returns: HRESULT
//
// Modifies:
//
// History: 01-30-95 krishnag Created.
//
//----------------------------------------------------------------------------
HRESULT
CNDSUserCollectionEnum::Create(
BSTR bstrUserName,
CNDSUserCollectionEnum FAR* FAR* ppenumvariant,
VARIANT var,
CCredentials& Credentials
)
{
HRESULT hr = NOERROR;
CNDSUserCollectionEnum FAR* penumvariant = NULL;
DWORD dwSLBound = 0;
DWORD dwSUBound = 0;
*ppenumvariant = NULL;
penumvariant = new CNDSUserCollectionEnum();
if (!penumvariant) {
hr = E_OUTOFMEMORY;
BAIL_ON_FAILURE(hr);
}
hr = ADsAllocString(bstrUserName, &(penumvariant->_bstrUserName));
BAIL_ON_FAILURE(hr);
hr = penumvariant->ValidateVariant(
var
);
BAIL_ON_FAILURE(hr);
penumvariant->_Credentials = Credentials;
*ppenumvariant = penumvariant;
RRETURN(hr);
error:
delete penumvariant;
RRETURN(hr);
}
CNDSUserCollectionEnum::CNDSUserCollectionEnum():
_dwSLBound(0),
_dwSUBound(0),
_dwIndex(0),
_bstrUserName(0),
_dwMultiple(0)
{
VariantInit(&_vMembers);
}
CNDSUserCollectionEnum::~CNDSUserCollectionEnum()
{
VariantClear(&_vMembers);
}
HRESULT
CNDSUserCollectionEnum::EnumUserMembers(
ULONG cElements,
VARIANT FAR* pvar,
ULONG FAR* pcElementFetched
)
{
HRESULT hr = S_OK;
IDispatch *pDispatch = NULL;
DWORD i = 0;
while (i < cElements) {
if (_dwMultiple == MULTIPLE) {
hr = GetUserMultipleMemberObject(&pDispatch);
}else if (_dwMultiple == SINGLE){
hr = GetUserSingleMemberObject(&pDispatch);
}else {
hr = S_FALSE;
}
if (hr == S_FALSE) {
break;
}
VariantInit(&pvar[i]);
pvar[i].vt = VT_DISPATCH;
pvar[i].pdispVal = pDispatch;
(*pcElementFetched)++;
i++;
}
RRETURN(hr);
}
HRESULT
CNDSUserCollectionEnum::GetUserMultipleMemberObject(
IDispatch ** ppDispatch
)
{
VARIANT v;
HRESULT hr = S_OK;
LPWSTR szADsPathName = NULL;
LPWSTR pszNDSTreeName = NULL, pszNDSDn = NULL;
*ppDispatch = NULL;
if (_dwIndex > _dwSUBound) {
RRETURN(S_FALSE);
}
VariantInit(&v);
hr = SafeArrayGetElement(
V_ARRAY(&_vMembers),
(long FAR *)&_dwIndex,
&v
);
BAIL_ON_FAILURE(hr);
hr = BuildNDSPathFromADsPath2(
_bstrUserName,
&pszNDSTreeName,
&pszNDSDn
);
BAIL_ON_FAILURE(hr);
hr = BuildADsPathFromNDSPath(
pszNDSTreeName,
v.bstrVal,
&szADsPathName
);
BAIL_ON_FAILURE(hr);
hr = CNDSGenObject::CreateGenericObject(
szADsPathName,
L"group",
_Credentials,
ADS_OBJECT_BOUND,
IID_IDispatch,
(void **)ppDispatch
);
BAIL_ON_FAILURE(hr);
_dwIndex++;
error:
VariantClear(&v);
if (FAILED(hr)) {
hr = S_FALSE;
}
if (szADsPathName) {
FreeADsMem(szADsPathName);
}
if (pszNDSDn) {
FreeADsMem(pszNDSDn);
}
if (pszNDSTreeName) {
FreeADsMem(pszNDSTreeName);
}
RRETURN(hr);
}
HRESULT
CNDSUserCollectionEnum::GetUserSingleMemberObject(
IDispatch ** ppDispatch
)
{
HRESULT hr = S_OK;
LPWSTR szADsPathName = NULL;
LPWSTR pszNDSTreeName = NULL, pszNDSDn = NULL;
*ppDispatch = NULL;
if (_dwIndex == 1) {
RRETURN(S_FALSE);
}
hr = BuildNDSPathFromADsPath2(
_bstrUserName,
&pszNDSTreeName,
&pszNDSDn
);
BAIL_ON_FAILURE(hr);
hr = BuildADsPathFromNDSPath(
pszNDSTreeName,
_vMembers.bstrVal,
&szADsPathName
);
BAIL_ON_FAILURE(hr);
hr = CNDSGenObject::CreateGenericObject(
szADsPathName,
L"group",
_Credentials,
ADS_OBJECT_BOUND,
IID_IDispatch,
(void **)ppDispatch
);
BAIL_ON_FAILURE(hr);
_dwIndex++;
error:
if (FAILED(hr)) {
hr = S_FALSE;
}
if (szADsPathName) {
FreeADsMem(szADsPathName);
}
if (pszNDSDn) {
FreeADsMem(pszNDSDn);
}
if (pszNDSTreeName) {
FreeADsMem(pszNDSTreeName);
}
RRETURN(hr);
}
//+---------------------------------------------------------------------------
//
// Function: CNDSUserCollectionEnum::Next
//
// Synopsis: Returns cElements number of requested NetOle objects in the
// array supplied in pvar.
//
// Arguments: [cElements] -- The number of elements requested by client
// [pvar] -- ptr to array of VARIANTs to for return objects
// [pcElementFetched] -- if non-NULL, then number of elements
// -- actually returned is placed here
//
// Returns: HRESULT -- S_OK if number of elements requested are returned
// -- S_FALSE if number of elements is < requested
//
// Modifies:
//
// History: 11-3-95 krishnag Created.
//
//----------------------------------------------------------------------------
STDMETHODIMP
CNDSUserCollectionEnum::Next(
ULONG cElements,
VARIANT FAR* pvar,
ULONG FAR* pcElementFetched
)
{
ULONG cElementFetched = 0;
HRESULT hr = S_OK;
hr = EnumUserMembers(
cElements,
pvar,
&cElementFetched
);
if (pcElementFetched) {
*pcElementFetched = cElementFetched;
}
RRETURN(hr);
}
HRESULT
CNDSUserCollectionEnum::ValidateVariant(
VARIANT var
)
{
if (V_VT(&var) == (VT_VARIANT|VT_ARRAY)) {
_dwMultiple = MULTIPLE;
RRETURN(ValidateMultipleVariant(var));
}else if (V_VT(&var) == VT_BSTR){
_dwMultiple = SINGLE;
RRETURN(ValidateSingleVariant(var));
}else if (V_VT(&var) == VT_EMPTY){
_dwMultiple = EMPTY;
RRETURN(S_OK);
}
RRETURN(E_FAIL);
}
HRESULT
CNDSUserCollectionEnum::ValidateMultipleVariant(
VARIANT var
)
{
HRESULT hr = S_OK;
DWORD dwSLBound = 0;
DWORD dwSUBound = 0;
if (!(V_VT(&var) == (VT_VARIANT|VT_ARRAY))) {
return(E_FAIL);
}
//
// Check that there is only one dimension in this array
//
if ((V_ARRAY(&var))->cDims != 1) {
hr = E_FAIL;
BAIL_ON_FAILURE(hr);
}
//
// Check that there is atleast one element in this array
//
if ((V_ARRAY(&var))->rgsabound[0].cElements == 0){
hr = E_FAIL;
BAIL_ON_FAILURE(hr);
}
//
// We know that this is a valid single dimension array
//
hr = SafeArrayGetLBound(
V_ARRAY(&var),
1,
(long FAR *)&dwSLBound
);
BAIL_ON_FAILURE(hr);
hr = SafeArrayGetUBound(
V_ARRAY(&var),
1,
(long FAR *)&dwSUBound
);
BAIL_ON_FAILURE(hr);
hr = VariantCopy(&_vMembers, &var);
BAIL_ON_FAILURE(hr);
_dwSUBound = dwSUBound;
_dwSLBound = dwSLBound;
_dwIndex = dwSLBound;
error:
RRETURN(hr);
}
HRESULT
CNDSUserCollectionEnum::ValidateSingleVariant(
VARIANT var
)
{
HRESULT hr = S_OK;
if(!( V_VT(&var) == VT_BSTR)){
return(E_FAIL);
}
hr = VariantCopy(&_vMembers, &var);
BAIL_ON_FAILURE(hr);
_dwIndex = 0;
error:
RRETURN(hr);
}