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.
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 |