Condividi tramite


enumerazione ADS_SYSTEMFLAG_ENUM (iads.h)

L'enumerazione ADS_SYSTEMFLAG_ENUM definisce alcuni dei valori che possono essere assegnati all'attributo systemFlags. Alcuni dei valori dell'enumerazione sono specifici degli oggetti attributeSchema ; altri valori possono essere impostati su oggetti di qualsiasi classe.

Sintassi

typedef enum __MIDL___MIDL_itf_ads_0001_0017_0001 {
  ADS_SYSTEMFLAG_DISALLOW_DELETE = 0x80000000,
  ADS_SYSTEMFLAG_CONFIG_ALLOW_RENAME = 0x40000000,
  ADS_SYSTEMFLAG_CONFIG_ALLOW_MOVE = 0x20000000,
  ADS_SYSTEMFLAG_CONFIG_ALLOW_LIMITED_MOVE = 0x10000000,
  ADS_SYSTEMFLAG_DOMAIN_DISALLOW_RENAME = 0x8000000,
  ADS_SYSTEMFLAG_DOMAIN_DISALLOW_MOVE = 0x4000000,
  ADS_SYSTEMFLAG_CR_NTDS_NC = 0x1,
  ADS_SYSTEMFLAG_CR_NTDS_DOMAIN = 0x2,
  ADS_SYSTEMFLAG_ATTR_NOT_REPLICATED = 0x1,
  ADS_SYSTEMFLAG_ATTR_IS_CONSTRUCTED = 0x4
} ADS_SYSTEMFLAG_ENUM;

Costanti

 
ADS_SYSTEMFLAG_DISALLOW_DELETE
Valore: 0x80000000
Identifica un oggetto che non può essere eliminato.
ADS_SYSTEMFLAG_CONFIG_ALLOW_RENAME
Valore: 0x40000000
Per gli oggetti nella partizione di configurazione, se questo flag è impostato, l'oggetto può essere rinominato; in caso contrario, l'oggetto non può essere rinominato. Per impostazione predefinita, questo flag non è impostato su nuovi oggetti creati nella partizione di configurazione e è possibile impostare questo flag solo durante la creazione di oggetti.
ADS_SYSTEMFLAG_CONFIG_ALLOW_MOVE
Valore: 0x20000000
Per gli oggetti nella partizione di configurazione, se questo flag è impostato, l'oggetto può essere spostato; in caso contrario, l'oggetto non può essere spostato. Per impostazione predefinita, questo flag non è impostato su nuovi oggetti creati nella partizione di configurazione e è possibile impostare questo flag solo durante la creazione di oggetti.
ADS_SYSTEMFLAG_CONFIG_ALLOW_LIMITED_MOVE
Valore: 0x10000000
Per gli oggetti nella partizione di configurazione, se questo flag è impostato, l'oggetto può essere spostato con restrizioni; in caso contrario, l'oggetto non può essere spostato. Per impostazione predefinita, questo flag non è impostato su nuovi oggetti creati nella partizione di configurazione e è possibile impostare questo flag solo durante la creazione di oggetti.
ADS_SYSTEMFLAG_DOMAIN_DISALLOW_RENAME
Valore: 0x8000000
Identifica un oggetto di dominio che non può essere rinominato.
ADS_SYSTEMFLAG_DOMAIN_DISALLOW_MOVE
Valore: 0x4000000
Identifica un oggetto di dominio che non può essere spostato.
ADS_SYSTEMFLAG_CR_NTDS_NC
Valore: 0x1
Il contesto di denominazione è in NTDS.
ADS_SYSTEMFLAG_CR_NTDS_DOMAIN
Valore: 0x2
Il contesto di denominazione è un dominio.
ADS_SYSTEMFLAG_ATTR_NOT_REPLICATED
Valore: 0x1
Se questo flag è impostato nell'attributo systemFlags di un oggetto attributeSchema , l'attributo non deve essere replicato.
ADS_SYSTEMFLAG_ATTR_IS_CONSTRUCTED
Valore: 0x4
Se questo flag è impostato nell'attributo systemFlags di un oggetto attributeSchema , l'attributo è una proprietà costruita.

Commenti

Per gli oggetti classSchema e attributeSchema , il bit 0x10 dell'attributosystemFlags indica un oggetto che fa parte dello schema di base incluso in Active Directory. Questo bit non può essere impostato su nuovi oggetti classSchema e attributeSchema . L'enumerazione ADS_SYSTEMFLAG_ENUM non include una costante per questo bit.

Nota Poiché VBScript non riesce a leggere i dati da una libreria di tipi, le applicazioni VBScript non riconoscono le costanti simboliche definite in precedenza. Usare invece le costanti numeriche per impostare i flag appropriati nelle applicazioni VBScript. Per usare le costanti simboliche come una buona pratica di programmazione, è consigliabile rendere dichiarazioni esplicite di tali costanti, come fatto qui, nelle applicazioni VBScript.
 

Esempio

Nell'esempio di codice seguente viene illustrato come gli elementi dell'enumerazione ADS_SYSTEMFLAG_ENUM , insieme all'interfaccia IDirectorySearch , vengono usati per cercare proprietà non replicate.

#include <wchar.h>
#include <activeds.h>
#include <atlbase.h>
 
HRESULT hr = E_FAIL;
LPWSTR szPrefix = L"LDAP://%s";
LPWSTR szPath = NULL;
IDirectorySearch *pSchemaNC = NULL;
IADs *pObject = NULL;
size_t nLength = 0;
LPWSTR pszSearchFilterTemplate = L"(&(objectCategory=attributeSchema)(systemFlags:1.2.840.113556.1.4.804:=%d))";
LPWSTR pszSearchFilter = NULL;
 
CoInitialize(NULL);     // Initialize COM

// Get rootDSE and the schema container distinguished name.
// Bind to current user's domain using current user's security context.
hr = ADsOpenObject(L"LDAP://rootDSE",
                NULL,
                NULL,
                ADS_SECURE_AUTHENTICATION, // Use Secure Authentication.
                IID_IADs,
                (void**)&pObject);
if (SUCCEEDED(hr))
{
    CComVarinat svar;
    hr = pObject->Get(CComBSTR("schemaNamingContext"), &svar);
    if (SUCCEEDED(hr))
    {
        nLength = wcslen(szPrefix) + wcslen(svar.bstrVal) + 1;
        szPath = new WCHAR[nLength];
        swprintf_s(szPath, szPrefix, svar.bstrVal);

        hr = ADsOpenObject(szPath,
            NULL,
            NULL,
            ADS_SECURE_AUTHENTICATION, 
            IID_IDirectorySearch,
            (void**)&pSchemaNC);

        delete [] szPath;

        if (SUCCEEDED(hr))
        {
            wprintf(L"Find non-replicated attributes\n");
 
            // Create search filter to find attributes with systemFlags that 
            // match ADS_SYSTEMFLAG_ATTR_NOT_REPLICATED
            nLength = wcslen(pszSearchFilterTemplate) + 25 + 1;
            pszSearchFilter = new WCHAR[nLength];
            swprintf_s(pszSearchFilter, pszSearchFilterTemplate, ADS_SYSTEMFLAG_ATTR_NOT_REPLICATED);
     
            // Attributes are one-level deep in the schema container 
            // so only need to search one level.
            ADS_SEARCHPREF_INFO SearchPrefs;
            SearchPrefs.dwSearchPref = ADS_SEARCHPREF_SEARCH_SCOPE;
            SearchPrefs.vValue.dwType = ADSTYPE_INTEGER;
            SearchPrefs.vValue.Integer = ADS_SCOPE_ONELEVEL;
            DWORD dwNumPrefs = 1;
     
            // COL for iterations.
            ADS_SEARCH_COLUMN    col;
     
            // Handle used for searching.
            ADS_SEARCH_HANDLE hSearch;
     
            IADs    *pObj = NULL;
            IADs    * pIADs = NULL;
 
            // Set the search preference.
            hr = pSchemaNC->SetSearchPreference( &SearchPrefs, dwNumPrefs);
            if (FAILED(hr)) 
            {
                return hr;
            }
 
            CONST DWORD dwAttrNameSize = 1;
            LPOLESTR pszAttribute[dwAttrNameSize];
            pszAttribute[0] = L"cn";

            // Execute the search.
            hr = pSchemaNC->ExecuteSearch(pszSearchFilter,
                                          pszAttribute,
                                          dwAttrNameSize,
                                          &hSearch );

            delete [] pszSearchFilter;
            if ( SUCCEEDED(hr) ) 
            { 
                // Call IDirectorySearch::GetNextRow() to retrieve 
                // the next row of data.
                while( pSchemaNC->GetNextRow( hSearch) != S_ADS_NOMORE_ROWS) 
                {
                    // Loop through the array of passed column names,
                    // print the data for each column.
                    for (DWORD x = 0; x < dwAttrNameSize; x++) 
                    {
                        // Get the data for this column.
                        hr = pSchemaNC->GetColumn( hSearch, 
                                           pszAttribute[x], 
                                           &col );
                        if ( SUCCEEDED(hr) ) 
                        {
                            // Print the data for the column and 
                            // free the column.
                            if (col.dwADsType == ADSTYPE_CASE_IGNORE_STRING)
                            {
                                wprintf(L"%s: %s\r\n", 
                                pszAttribute[x], 
                                col.pADsValues->CaseIgnoreString); 
                            }
                            else
                            {
                                wprintf(L"<%s property is not a string>", pszAttribute[x]);
                            }

                            pSchemaNC->FreeColumn( &col );
                        }
                    }
                }

                // Close the search handle to clean up.
                pSchemaNC->CloseSearchHandle(hSearch);
            } 
        }
    } 

    pObject->Release();
}

CoUninitialize();    // uninitialize COM.

Requisiti

   
Client minimo supportato Windows Vista
Server minimo supportato Windows Server 2008
Intestazione iads.h

Vedi anche

Enumerazioni ADSI

IDirectorySearch