Lettura dello schema
La maggior parte dei provider supporta lo schema fornito con Active Directory. Lo schema contiene definizioni di classi e attributi. ADSI astrae lo schema in "Provider://schema". Ogni oggetto contiene la posizione dello schema in cui è definita la relativa classe. È possibile utilizzare il metodo della proprietà IADs::get_Class per ottenere queste informazioni.
Per eseguire l'associazione al contenitore dello schema in un determinato dominio, eseguire le operazioni seguenti:
Dim SchemaContainer As Object
Set SchemaContainer = GetObject("LDAP://Fabrikam/Schema")
hr = ADsGetObject(L"LDAP://Fabrikam/Schema", IID_IADsContainer, (void**) &pSchema );
Per elencare le informazioni nel contenitore dello schema, eseguire l'associazione al contenitore ed enumerare ogni oggetto nel contenitore, come illustrato di seguito:
Dim prop As Object
Dim obj As Object
Dim SchemaContainer As Object
Dim Class As Object
Set SchemaContainer = GetObject("LDAP://Fabrikam/Schema")
'Show all items in the schema container
For Each obj In SchemaContainer
Debug.Print obj.Name & " (" & obj.Class & ")"
Next
'Show the optional attributes
For Each prop In Class.OptionalProperties
Debug.Print prop
Next
IADsContainer *pSchema=NULL;
HRESULT hr;
CoInitialize(NULL);
hr = ADsGetObject(L"LDAP://Fabrikam/Schema",
IID_IADsContainer, (void**) &pSchema );
if ( !SUCCEEDED(hr) )
{
return hr;
}
// Enumerate schema objects
IEnumVARIANT *pEnum = NULL;
hr = ADsBuildEnumerator( pSchema, &pEnum );
pSchema->Release(); // This is no longer needed, since we have the enumerator already.
if ( SUCCEEDED(hr) )
{
VARIANT var;
ULONG lFetch;
IADs *pChild=NULL;
VariantInit(&var);
while( SUCCEEDED(ADsEnumerateNext( pEnum, 1, &var, &lFetch )) && lFetch == 1 )
{
hr = V_DISPATCH(&var)->QueryInterface( IID_IADs, (void**) &pChild );
if ( SUCCEEDED(hr) )
{
BSTR bstrName;
BSTR bstrClass;
// Get more information on the child classes
pChild->get_Name(&bstrName);
pChild->get_Class(&bstrClass);
printf("%S\t\t(%S)\n", bstrName, bstrClass );
// Clean-up
SysFreeString(bstrName);
SysFreeString(bstrClass);
pChild->Release();
}
VariantClear(&var);
}
}
CoUninitialize();
È anche possibile eseguire il binding a un oggetto e ottenere il percorso dello schema, come illustrato di seguito:
Dim prop As Object
Dim dom As Object
Dim Class As Object
Set dom = GetObject("LDAP://Fabrikam")
Debug.Print dom.Schema
Set Class = GetObject(dom.Schema)
'Mandatory attributes
For Each prop In Class.MandatoryProperties
Debug.Print prop
Next