📄 ntdsapi.pas
字号:
DS_NAME_RESULT = DS_NAME_RESULTA;
{$EXTERNALSYM DS_NAME_RESULT}
PDS_NAME_RESULT = PDS_NAME_RESULTA;
{$EXTERNALSYM PDS_NAME_RESULT}
DS_NAME_RESULT_ITEM = DS_NAME_RESULT_ITEMA;
{$EXTERNALSYM DS_NAME_RESULT_ITEM}
PDS_NAME_RESULT_ITEM = PDS_NAME_RESULT_ITEMA;
{$EXTERNALSYM PDS_NAME_RESULT_ITEM}
TDsNameResult = TDsNameResultA;
PDsNameResult = PDsNameResultA;
TDsNameResultItem = TDsNameResultItemA;
PDsNameResultItem = PDsNameResultItemA;
{$ENDIF}
// Public replication option flags
// ********************
// Replica Sync flags
// ********************
// Perform this operation asynchronously.
// Required when using DS_REPSYNC_ALL_SOURCES
const
DS_REPSYNC_ASYNCHRONOUS_OPERATION = $00000001;
{$EXTERNALSYM DS_REPSYNC_ASYNCHRONOUS_OPERATION}
// Writeable replica. Otherwise, read-only.
DS_REPSYNC_WRITEABLE = $00000002;
{$EXTERNALSYM DS_REPSYNC_WRITEABLE}
// This is a periodic sync request as scheduled by the admin.
DS_REPSYNC_PERIODIC = $00000004;
{$EXTERNALSYM DS_REPSYNC_PERIODIC}
// Use inter-site messaging
DS_REPSYNC_INTERSITE_MESSAGING = $00000008;
{$EXTERNALSYM DS_REPSYNC_INTERSITE_MESSAGING}
// Sync from all sources.
DS_REPSYNC_ALL_SOURCES = $00000010;
{$EXTERNALSYM DS_REPSYNC_ALL_SOURCES}
// Sync starting from scratch (i.e., at the first USN).
DS_REPSYNC_FULL = $00000020;
{$EXTERNALSYM DS_REPSYNC_FULL}
// This is a notification of an update that was marked urgent.
DS_REPSYNC_URGENT = $00000040;
{$EXTERNALSYM DS_REPSYNC_URGENT}
// Don't discard this synchronization request, even if a similar
// sync is pending.
DS_REPSYNC_NO_DISCARD = $00000080;
{$EXTERNALSYM DS_REPSYNC_NO_DISCARD}
// Sync even if link is currently disabled.
DS_REPSYNC_FORCE = $00000100;
{$EXTERNALSYM DS_REPSYNC_FORCE}
// Causes the source DSA to check if a reps-to is present for the local DSA
// (aka the destination). If not, one is added. This ensures that
// source sends change notifications.
DS_REPSYNC_ADD_REFERENCE = $00000200;
{$EXTERNALSYM DS_REPSYNC_ADD_REFERENCE}
// A sync from this source has never completed (e.g., a new source).
DS_REPSYNC_NEVER_COMPLETED = $00000400;
{$EXTERNALSYM DS_REPSYNC_NEVER_COMPLETED}
// When this sync is complete, requests a sync in the opposite direction.
DS_REPSYNC_TWO_WAY = $00000800;
{$EXTERNALSYM DS_REPSYNC_TWO_WAY}
// ********************
// Replica Add flags
// ********************
// Perform this operation asynchronously.
DS_REPADD_ASYNCHRONOUS_OPERATION = $00000001;
{$EXTERNALSYM DS_REPADD_ASYNCHRONOUS_OPERATION}
// Create a writeable replica. Otherwise, read-only.
DS_REPADD_WRITEABLE = $00000002;
{$EXTERNALSYM DS_REPADD_WRITEABLE}
// Sync the NC from this source when the DSA is started.
DS_REPADD_INITIAL = $00000004;
{$EXTERNALSYM DS_REPADD_INITIAL}
// Sync the NC from this source periodically, as defined by the
// schedule passed in the preptimesSync argument.
DS_REPADD_PERIODIC = $00000008;
{$EXTERNALSYM DS_REPADD_PERIODIC}
// Sync from the source DSA via an Intersite Messaging Service (ISM) transport
// (e.g., SMTP) rather than native DS RPC.
DS_REPADD_INTERSITE_MESSAGING = $00000010;
{$EXTERNALSYM DS_REPADD_INTERSITE_MESSAGING}
// Don't replicate the NC now -- just save enough state such that we
// know to replicate it later.
DS_REPADD_ASYNCHRONOUS_REPLICA = $00000020;
{$EXTERNALSYM DS_REPADD_ASYNCHRONOUS_REPLICA}
// Disable notification-based synchronization for the NC from this source.
// This is expected to be a temporary state; the similar flag
// DS_REPADD_NEVER_NOTIFY should be used if the disable is to be more permanent.
DS_REPADD_DISABLE_NOTIFICATION = $00000040;
{$EXTERNALSYM DS_REPADD_DISABLE_NOTIFICATION}
// Disable periodic synchronization for the NC from this source
DS_REPADD_DISABLE_PERIODIC = $00000080;
{$EXTERNALSYM DS_REPADD_DISABLE_PERIODIC}
// Use compression when replicating. Saves message size (e.g., network
// bandwidth) at the expense of extra CPU overhead at both the source and
// destination servers.
DS_REPADD_USE_COMPRESSION = $00000100;
{$EXTERNALSYM DS_REPADD_USE_COMPRESSION}
// Do not request change notifications from this source. When this flag is
// set, the source will not notify the destination when changes occur.
// Recommended for all intersite replication, which may occur over WAN links.
// This is expected to be a more or less permanent state; the similar flag
// DS_REPADD_DISABLE_NOTIFICATION should be used if notifications are to be
// disabled only temporarily.
DS_REPADD_NEVER_NOTIFY = $00000200;
{$EXTERNALSYM DS_REPADD_NEVER_NOTIFY}
// ********************
// Replica Delete flags
// ********************
// Perform this operation asynchronously.
DS_REPDEL_ASYNCHRONOUS_OPERATION = $00000001;
{$EXTERNALSYM DS_REPDEL_ASYNCHRONOUS_OPERATION}
// The replica being deleted is writeable.
DS_REPDEL_WRITEABLE = $00000002;
{$EXTERNALSYM DS_REPDEL_WRITEABLE}
// Replica is a mail-based replica
DS_REPDEL_INTERSITE_MESSAGING = $00000004;
{$EXTERNALSYM DS_REPDEL_INTERSITE_MESSAGING}
// Ignore any error generated by contacting the source to tell it to scratch
// this server from its Reps-To for this NC.
DS_REPDEL_IGNORE_ERRORS = $00000008;
{$EXTERNALSYM DS_REPDEL_IGNORE_ERRORS}
// Do not contact the source telling it to scratch this server from its
// Rep-To for this NC. Otherwise, if the link is RPC-based, the source will
// be contacted.
DS_REPDEL_LOCAL_ONLY = $00000010;
{$EXTERNALSYM DS_REPDEL_LOCAL_ONLY}
// Delete all the objects in the NC
// "No source" is incompatible with (and rejected for) writeable NCs. This is
// valid only for read-only NCs, and then only if the NC has no source. This
// can occur when the NC has been partially deleted (in which case the KCC
// periodically calls the delete API with the "no source" flag set).
DS_REPDEL_NO_SOURCE = $00000020;
{$EXTERNALSYM DS_REPDEL_NO_SOURCE}
// Allow deletion of read-only replica even if it sources
// other read-only replicas.
DS_REPDEL_REF_OK = $00000040;
{$EXTERNALSYM DS_REPDEL_REF_OK}
// ********************
// Replica Modify flags
// ********************
// Perform this operation asynchronously.
DS_REPMOD_ASYNCHRONOUS_OPERATION = $00000001;
{$EXTERNALSYM DS_REPMOD_ASYNCHRONOUS_OPERATION}
// The replica is writeable.
DS_REPMOD_WRITEABLE = $00000002;
{$EXTERNALSYM DS_REPMOD_WRITEABLE}
// ********************
// Replica Modify fields
// ********************
DS_REPMOD_UPDATE_FLAGS = $00000001;
{$EXTERNALSYM DS_REPMOD_UPDATE_FLAGS}
DS_REPMOD_UPDATE_ADDRESS = $00000002;
{$EXTERNALSYM DS_REPMOD_UPDATE_ADDRESS}
DS_REPMOD_UPDATE_SCHEDULE = $00000004;
{$EXTERNALSYM DS_REPMOD_UPDATE_SCHEDULE}
DS_REPMOD_UPDATE_RESULT = $00000008;
{$EXTERNALSYM DS_REPMOD_UPDATE_RESULT}
DS_REPMOD_UPDATE_TRANSPORT = $00000010;
{$EXTERNALSYM DS_REPMOD_UPDATE_TRANSPORT}
// ********************
// Update Refs fields
// ********************
// Perform this operation asynchronously.
DS_REPUPD_ASYNCHRONOUS_OPERATION = $00000001;
{$EXTERNALSYM DS_REPUPD_ASYNCHRONOUS_OPERATION}
// The replica being deleted is writeable.
DS_REPUPD_WRITEABLE = $00000002;
{$EXTERNALSYM DS_REPUPD_WRITEABLE}
// Add a reference
DS_REPUPD_ADD_REFERENCE = $00000004;
{$EXTERNALSYM DS_REPUPD_ADD_REFERENCE}
// Remove a reference
DS_REPUPD_DELETE_REFERENCE = $00000008;
{$EXTERNALSYM DS_REPUPD_DELETE_REFERENCE}
// ***********************
// Well Known Object Guids
// ***********************
GUID_USERS_CONTAINER_A = 'a9d1ca15768811d1aded00c04fd8d5cd';
{$EXTERNALSYM GUID_USERS_CONTAINER_A}
GUID_COMPUTRS_CONTAINER_A = 'aa312825768811d1aded00c04fd8d5cd';
{$EXTERNALSYM GUID_COMPUTRS_CONTAINER_A}
GUID_SYSTEMS_CONTAINER_A = 'ab1d30f3768811d1aded00c04fd8d5cd';
{$EXTERNALSYM GUID_SYSTEMS_CONTAINER_A}
GUID_DOMAIN_CONTROLLERS_CONTAINER_A = 'a361b2ffffd211d1aa4b00c04fd7d83a';
{$EXTERNALSYM GUID_DOMAIN_CONTROLLERS_CONTAINER_A}
GUID_INFRASTRUCTURE_CONTAINER_A = '2fbac1870ade11d297c400c04fd8d5cd';
{$EXTERNALSYM GUID_INFRASTRUCTURE_CONTAINER_A}
GUID_DELETED_OBJECTS_CONTAINER_A = '18e2ea80684f11d2b9aa00c04f79f805';
{$EXTERNALSYM GUID_DELETED_OBJECTS_CONTAINER_A}
GUID_LOSTANDFOUND_CONTAINER_A = 'ab8153b7768811d1aded00c04fd8d5cd';
{$EXTERNALSYM GUID_LOSTANDFOUND_CONTAINER_A}
GUID_USERS_CONTAINER_W = WideString('a9d1ca15768811d1aded00c04fd8d5cd');
{$EXTERNALSYM GUID_USERS_CONTAINER_W}
GUID_COMPUTRS_CONTAINER_W = WideString('aa312825768811d1aded00c04fd8d5cd');
{$EXTERNALSYM GUID_COMPUTRS_CONTAINER_W}
GUID_SYSTEMS_CONTAINER_W = WideString('ab1d30f3768811d1aded00c04fd8d5cd');
{$EXTERNALSYM GUID_SYSTEMS_CONTAINER_W}
GUID_DOMAIN_CONTROLLERS_CONTAINER_W = WideString('a361b2ffffd211d1aa4b00c04fd7d83a');
{$EXTERNALSYM GUID_DOMAIN_CONTROLLERS_CONTAINER_W}
GUID_INFRASTRUCTURE_CONTAINER_W = WideString('2fbac1870ade11d297c400c04fd8d5cd');
{$EXTERNALSYM GUID_INFRASTRUCTURE_CONTAINER_W}
GUID_DELETED_OBJECTS_CONTAINER_W = WideString('18e2ea80684f11d2b9aa00c04f79f805');
{$EXTERNALSYM GUID_DELETED_OBJECTS_CONTAINER_W}
GUID_LOSTANDFOUND_CONTAINER_W = WideString('ab8153b7768811d1aded00c04fd8d5cd');
{$EXTERNALSYM GUID_LOSTANDFOUND_CONTAINER_W}
GUID_USERS_CONTAINER_BYTE = '\xa9\xd1\xca\x15\x76\x88\x11\xd1\xad\xed\x00\xc0\x4f\xd8\xd5\xcd';
{$EXTERNALSYM GUID_USERS_CONTAINER_BYTE}
GUID_COMPUTRS_CONTAINER_BYTE = '\xaa\x31\x28\x25\x76\x88\x11\xd1\xad\xed\x00\xc0\x4f\xd8\xd5\xcd';
{$EXTERNALSYM GUID_COMPUTRS_CONTAINER_BYTE}
GUID_SYSTEMS_CONTAINER_BYTE = '\xab\x1d\x30\xf3\x76\x88\x11\xd1\xad\xed\x00\xc0\x4f\xd8\xd5\xcd';
{$EXTERNALSYM GUID_SYSTEMS_CONTAINER_BYTE}
GUID_DOMAIN_CONTROLLERS_CONTAINER_BYTE = '\xa3\x61\xb2\xff\xff\xd2\x11\xd1\xaa\x4b\x00\xc0\x4f\xd7\xd8\x3a';
{$EXTERNALSYM GUID_DOMAIN_CONTROLLERS_CONTAINER_BYTE}
GUID_INFRASTRUCTURE_CONTAINER_BYTE = '\x2f\xba\xc1\x87\x0a\xde\x11\xd2\x97\xc4\x00\xc0\x4f\xd8\xd5\xcd';
{$EXTERNALSYM GUID_INFRASTRUCTURE_CONTAINER_BYTE}
GUID_DELETED_OBJECTS_CONTAINER_BYTE = '\x18\xe2\xea\x80\x68\x4f\x11\xd2\xb9\xaa\x00\xc0\x4f\x79\xf8\x05';
{$EXTERNALSYM GUID_DELETED_OBJECTS_CONTAINER_BYTE}
GUID_LOSTANDFOUND_CONTAINER_BYTE = '\xab\x81\x53\xb7\x76\x88\x11\xd1\xad\xed\x00\xc0\x4f\xd8\xd5\xcd';
{$EXTERNALSYM GUID_LOSTANDFOUND_CONTAINER_BYTE}
//////////////////////////////////////////////////////////////////////////
// //
// Prototypes //
// //
//////////////////////////////////////////////////////////////////////////
// DSBind takes two optional input parameters which identify whether the
// caller found a domain controller themselves via DsGetDcName or whether
// a domain controller should be found using default parameters.
// Behavior of the possible combinations are outlined below.
//
// DomainControllerName(value), DnsDomainName(NULL)
//
// The value for DomainControllerName is assumed to have been
// obtained via DsGetDcName (i.e. Field with the same name in a
// DOMAIN_CONTROLLER_INFO struct on return from DsGetDcName call.)
// The client is bound to the domain controller at this name.
//
// Mutual authentication will be performed using an SPN of
// LDAP/DomainControllerName provided DomainControllerName
// is not a NETBIOS name or IP address - i.e. it must be a
// DNS host name.
//
// DomainControllerName(value), DnsDomainName(value)
//
// DsBind will connect to the server identified by DomainControllerName.
//
// Mutual authentication will be performed using an SPN of
// LDAP/DomainControllerName/DnsDomainName provided neither value
// is a NETBIOS names or IP address - i.e. they must be
// valid DNS names.
//
// DomainControllerName(NULL), DnsDomainName(NULL)
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -