Funções auxiliares de enumeração
Há três funções auxiliares do enumerador que podem ser usadas a partir de C/C++ para ajudar na navegação de objetos do Active Directory. Eles são ADsBuildEnumerator, ADsEnumerateNext e ADsFreeEnumerator.
ADsBuildEnumerator
A função auxiliar ADsBuildEnumerator encapsula o código necessário para criar um objeto enumerador. Ele chama o método IADsContainer::get__NewEnum para criar um objeto enumerador e, em seguida, chama o método QueryInterface de IUnknown para obter um ponteiro para a interface IEnumVARIANT para esse objeto. O objeto de enumeração é o mecanismo de automação para enumerar sobre contêineres. Use a função ADsFreeEnumerator para liberar esse objeto enumerador.
ADsEnumerateNext
A função auxiliar ADsEnumerateNext preenche uma matriz VARIANT com elementos obtidos de um objeto enumerador. O número de elementos recuperados pode ser menor do que o número solicitado.
ADsFreeEnumerator
Libera um objeto enumerador criado anteriormente por meio da função ADsBuildEnumerator.
O exemplo de código a seguir mostra uma função que usa funções auxiliares do enumerador em C++.
/*****************************************************************************
Function: TestEnumObject
Arguments: pszADsPath - ADsPath of the container to be enumerated (WCHAR*).
Return: S_OK if successful, an error code otherwise.
Purpose: Example using ADsBuildEnumerator, ADsEnumerateNext and
ADsFreeEnumerator.
******************************************************************************/
#define MAX_ENUM 100
HRESULT
TestEnumObject( LPWSTR pszADsPath )
{
ULONG cElementFetched = 0L;
IEnumVARIANT * pEnumVariant = NULL;
VARIANT VariantArray[MAX_ENUM];
HRESULT hr = S_OK;
IADsContainer * pADsContainer = NULL;
DWORD dwObjects = 0, dwEnumCount = 0, i = 0;
BOOL fContinue = TRUE;
hr = ADsGetObject(
pszADsPath,
IID_IADsContainer,
(void **)&pADsContainer
);
if (FAILED(hr)) {
printf("\"%S\" is not a valid container object.\n", pszADsPath) ;
goto exitpoint ;
}
hr = ADsBuildEnumerator(
pADsContainer,
&pEnumVariant
);
if( FAILED( hr ) )
{
printf("ADsBuildEnumerator failed with %lx\n", hr ) ;
goto exitpoint ;
}
fContinue = TRUE;
while (fContinue) {
IADs *pObject ;
hr = ADsEnumerateNext(
pEnumVariant,
MAX_ENUM,
VariantArray,
&cElementFetched
);
if ( FAILED( hr ) )
{
printf("ADsEnumerateNext failed with %lx\n",hr);
goto exitpoint;
}
if (hr == S_FALSE) {
fContinue = FALSE;
}
dwEnumCount++;
for (i = 0; i < cElementFetched; i++ ) {
IDispatch *pDispatch = NULL;
BSTR bstrADsPath = NULL;
pDispatch = VariantArray[i].pdispVal;
hr = V_DISPATCH( VariantArray + i )->QueryInterface(IID_IADs, (void **) &pObject) ;
if( SUCCEEDED( hr ) )
{
pObject->get_ADsPath( &bstrADsPath );
printf( "%S\n", bstrADsPath );
}
pObject->Release();
VariantClear( VariantArray + i );
SysFreeString( bstrADsPath );
}
dwObjects += cElementFetched;
}
printf("Total Number of Objects enumerated is %d\n", dwObjects);
exitpoint:
if (pEnumVariant) {
ADsFreeEnumerator( pEnumVariant );
}
if (pADsContainer) {
pADsContainer->Release();
}
return(hr);
}