s4/net: Make pwsettings a net subcommand.
[Samba/eduardoll.git] / librpc / idl / drsuapi.idl
blob3038863e1c379d0fe6705ccc14362fb7d4d4a8b2
1 #include "idl_types.h"
3 import "security.idl", "misc.idl", "samr.idl";
6 uuid("e3514235-4b06-11d1-ab04-00c04fc2dcd2"),
7 version(4.0),
8 endpoint("ncacn_np:[\\pipe\\lsass]","ncacn_np:[\\pipe\\protected_storage]", "ncacn_ip_tcp:", "ncalrpc:"),
9 authservice("ldap"),
10 helpstring("Active Directory Replication"),
11 helper("../librpc/ndr/ndr_drsuapi.h"),
12 pointer_default(unique)
14 interface drsuapi
16 typedef bitmap samr_GroupAttrs samr_GroupAttrs;
18 /* see MS-DRSR section 5.37 */
19 typedef [public,bitmap32bit] bitmap {
20 DRSUAPI_DRS_ASYNC_OP = 0x00000001,
21 DRSUAPI_DRS_GETCHG_CHECK = 0x00000002,
22 DRSUAPI_DRS_ADD_REF = 0x00000004,
23 DRSUAPI_DRS_SYNC_ALL = 0x00000008,
24 DRSUAPI_DRS_DEL_REF = 0x00000008,
25 DRSUAPI_DRS_WRIT_REP = 0x00000010,
26 DRSUAPI_DRS_INIT_SYNC = 0x00000020,
27 DRSUAPI_DRS_PER_SYNC = 0x00000040,
28 DRSUAPI_DRS_MAIL_REP = 0x00000080,
29 DRSUAPI_DRS_ASYNC_REP = 0x00000100,
30 DRSUAPI_DRS_IGNORE_ERROR = 0x00000100,
31 DRSUAPI_DRS_TWOWAY_SYNC = 0x00000200,
32 DRSUAPI_DRS_CRITICAL_ONLY = 0x00000400,
33 DRSUAPI_DRS_GET_ANC = 0x00000800,
34 DRSUAPI_DRS_GET_NC_SIZE = 0x00001000,
35 DRSUAPI_DRS_LOCAL_ONLY = 0x00001000,
36 DRSUAPI_DRS_SYNC_BYNAME = 0x00004000,
37 DRSUAPI_DRS_REF_OK = 0x00004000,
38 DRSUAPI_DRS_FULL_SYNC_NOW = 0x00008000,
39 DRSUAPI_DRS_NO_SOURCE = 0x00008000,
40 DRSUAPI_DRS_FULL_SYNC_PACKET = 0x00020000,
41 DRSUAPI_DRS_REF_GCSPN = 0x00100000,
42 DRSUAPI_DRS_SPECIAL_SECRET_PROCESSING = 0x00800000,
43 DRSUAPI_DRS_SYNC_FORCED = 0x02000000,
44 DRSUAPI_DRS_DISABLE_AUTO_SYNC = 0x04000000,
45 DRSUAPI_DRS_DISABLE_PERIODIC_SYNC = 0x08000000,
46 DRSUAPI_DRS_USE_COMPRESSION = 0x10000000,
47 DRSUAPI_DRS_NEVER_NOTIFY = 0x20000000,
48 DRSUAPI_DRS_SYNC_PAS = 0x40000000,
49 DRSUAPI_DRS_GET_ALL_GROUP_MEMBERSHIP = 0x80000000
50 } drsuapi_DrsOptions;
52 /*****************/
53 /* Function 0x00 */
54 typedef [bitmap32bit] bitmap {
55 DRSUAPI_SUPPORTED_EXTENSION_BASE = 0x00000001,
56 DRSUAPI_SUPPORTED_EXTENSION_ASYNC_REPLICATION = 0x00000002,
57 DRSUAPI_SUPPORTED_EXTENSION_REMOVEAPI = 0x00000004,
58 DRSUAPI_SUPPORTED_EXTENSION_MOVEREQ_V2 = 0x00000008,
59 DRSUAPI_SUPPORTED_EXTENSION_GETCHG_COMPRESS = 0x00000010,
60 DRSUAPI_SUPPORTED_EXTENSION_DCINFO_V1 = 0x00000020,
61 DRSUAPI_SUPPORTED_EXTENSION_RESTORE_USN_OPTIMIZATION = 0x00000040,
62 DRSUAPI_SUPPORTED_EXTENSION_00000080 = 0x00000080,
63 DRSUAPI_SUPPORTED_EXTENSION_KCC_EXECUTE = 0x00000100,
64 DRSUAPI_SUPPORTED_EXTENSION_ADDENTRY_V2 = 0x00000200,
65 DRSUAPI_SUPPORTED_EXTENSION_LINKED_VALUE_REPLICATION = 0x00000400,
66 DRSUAPI_SUPPORTED_EXTENSION_DCINFO_V2 = 0x00000800,
67 DRSUAPI_SUPPORTED_EXTENSION_INSTANCE_TYPE_NOT_REQ_ON_MOD= 0x00001000,
68 DRSUAPI_SUPPORTED_EXTENSION_CRYPTO_BIND = 0x00002000,
69 DRSUAPI_SUPPORTED_EXTENSION_GET_REPL_INFO = 0x00004000,
70 DRSUAPI_SUPPORTED_EXTENSION_STRONG_ENCRYPTION = 0x00008000,
71 DRSUAPI_SUPPORTED_EXTENSION_DCINFO_V01 = 0x00010000,
72 DRSUAPI_SUPPORTED_EXTENSION_TRANSITIVE_MEMBERSHIP = 0x00020000,
73 DRSUAPI_SUPPORTED_EXTENSION_ADD_SID_HISTORY = 0x00040000,
74 DRSUAPI_SUPPORTED_EXTENSION_POST_BETA3 = 0x00080000,
75 DRSUAPI_SUPPORTED_EXTENSION_00100000 = 0x00100000,
76 DRSUAPI_SUPPORTED_EXTENSION_GET_MEMBERSHIPS2 = 0x00200000,
77 DRSUAPI_SUPPORTED_EXTENSION_GETCHGREQ_V6 = 0x00400000,
78 DRSUAPI_SUPPORTED_EXTENSION_NONDOMAIN_NCS = 0x00800000,
79 DRSUAPI_SUPPORTED_EXTENSION_GETCHGREQ_V8 = 0x01000000,
80 DRSUAPI_SUPPORTED_EXTENSION_GETCHGREPLY_V5 = 0x02000000,
81 DRSUAPI_SUPPORTED_EXTENSION_GETCHGREPLY_V6 = 0x04000000,
83 * the following 3 have the same value
84 * repadmin.exe /bind says that
86 DRSUAPI_SUPPORTED_EXTENSION_ADDENTRYREPLY_V3 = 0x08000000,
87 DRSUAPI_SUPPORTED_EXTENSION_GETCHGREPLY_V7 = 0x08000000,
88 DRSUAPI_SUPPORTED_EXTENSION_VERIFY_OBJECT = 0x08000000,
89 DRSUAPI_SUPPORTED_EXTENSION_XPRESS_COMPRESS = 0x10000000,
90 DRSUAPI_SUPPORTED_EXTENSION_20000000 = 0x20000000,
91 DRSUAPI_SUPPORTED_EXTENSION_40000000 = 0x40000000,
92 DRSUAPI_SUPPORTED_EXTENSION_80000000 = 0x80000000
93 } drsuapi_SupportedExtensions;
95 typedef [bitmap32bit] bitmap {
96 DRSUAPI_SUPPORTED_EXTENSION_ADAM = 0x00000001,
97 DRSUAPI_SUPPORTED_EXTENSION_LH_BETA2 = 0x00000002
98 } drsuapi_SupportedExtensionsExt;
100 /* this is used by w2k */
101 typedef struct {
102 drsuapi_SupportedExtensions supported_extensions;
103 GUID site_guid;
104 uint32 pid;
105 } drsuapi_DsBindInfo24;
107 /* this is used by w2k3 */
108 typedef struct {
109 drsuapi_SupportedExtensions supported_extensions;
110 GUID site_guid;
111 uint32 pid;
112 uint32 repl_epoch;
113 } drsuapi_DsBindInfo28;
115 /* this is used by w2k8 */
116 typedef struct {
117 drsuapi_SupportedExtensions supported_extensions;
118 GUID site_guid;
119 uint32 pid;
120 uint32 repl_epoch;
121 drsuapi_SupportedExtensionsExt supported_extensions_ext;
122 GUID config_dn_guid;
123 } drsuapi_DsBindInfo48;
125 typedef struct {
126 [flag(NDR_REMAINING)] DATA_BLOB info;
127 } drsuapi_DsBindInfoFallBack;
129 typedef [nodiscriminant] union {
130 [case(24)][subcontext(4)] drsuapi_DsBindInfo24 info24;
131 [case(28)][subcontext(4)] drsuapi_DsBindInfo28 info28;
132 [case(48)][subcontext(4)] drsuapi_DsBindInfo48 info48;
133 [default][subcontext(4)] drsuapi_DsBindInfoFallBack FallBack;
134 } drsuapi_DsBindInfo;
136 /* the drsuapi_DsBindInfoCtr was this before
137 * typedef [flag(NDR_PAHEX)] struct {
138 * [range(1,10000)] uint32 length;
139 * [size_is(length)] uint8 data[];
140 * } drsuapi_DsBindInfo;
142 * but we don't want the caller to manually decode this blob,
143 * so we're doing it here
146 typedef struct {
147 [range(1,10000)] uint32 length;
148 [switch_is(length)] drsuapi_DsBindInfo info;
149 } drsuapi_DsBindInfoCtr;
151 /* this is a magic guid you need to pass to DsBind to make drsuapi_DsWriteAccountSpn() work
153 * maybe the bind_guid could also be the invocation_id see drsuapi_DsReplicaConnection04
155 const char *DRSUAPI_DS_BIND_GUID = "e24d201a-4fd6-11d1-a3da-0000f875ae0d";
157 * this magic guid are needed to fetch the whole tree with drsuapi_DsGetNCChanges()
158 * as administrator and this values are also used in the destination_dsa_guid field
159 * of drsuapi_DsGetNCChangesReq5/8 and the source_dsa_guid is zero.
161 const char *DRSUAPI_DS_BIND_GUID_W2K = "6abec3d1-3054-41c8-a362-5a0c5b7d5d71";
162 const char *DRSUAPI_DS_BIND_GUID_W2K3 = "6afab99c-6e26-464a-975f-f58f105218bc";
164 [public] WERROR drsuapi_DsBind(
165 [in,unique] GUID *bind_guid,
166 [in,out,unique] drsuapi_DsBindInfoCtr *bind_info,
167 [out] policy_handle *bind_handle
170 /*****************/
171 /* Function 0x01 */
172 WERROR drsuapi_DsUnbind(
173 [in,out] policy_handle *bind_handle
176 /*****************/
177 /* Function 0x02 */
178 typedef [public,gensize] struct {
179 [value(ndr_size_drsuapi_DsReplicaObjectIdentifier(r, ndr->iconv_convenience, ndr->flags)-4)] uint32 __ndr_size;
180 [value(ndr_size_dom_sid28(&sid, ndr->flags))] uint32 __ndr_size_sid;
181 GUID guid;
182 dom_sid28 sid;
183 [value(strlen_m(dn))] uint32 __ndr_size_dn;
184 [charset(UTF16),size_is(__ndr_size_dn+1)] uint16 dn[];
185 } drsuapi_DsReplicaObjectIdentifier;
187 typedef [public] bitmap {
188 DRSUAPI_DS_REPLICA_SYNC_ASYNCHRONOUS_OPERATION = 0x00000001,
189 DRSUAPI_DS_REPLICA_SYNC_WRITEABLE = 0x00000002,
190 DRSUAPI_DS_REPLICA_SYNC_PERIODIC = 0x00000004,
191 DRSUAPI_DS_REPLICA_SYNC_INTERSITE_MESSAGING = 0x00000008,
192 DRSUAPI_DS_REPLICA_SYNC_ALL_SOURCES = 0x00000010,
193 DRSUAPI_DS_REPLICA_SYNC_FULL = 0x00000020,
194 DRSUAPI_DS_REPLICA_SYNC_URGENT = 0x00000040,
195 DRSUAPI_DS_REPLICA_SYNC_NO_DISCARD = 0x00000080,
196 DRSUAPI_DS_REPLICA_SYNC_FORCE = 0x00000100,
197 DRSUAPI_DS_REPLICA_SYNC_ADD_REFERENCE = 0x00000200,
198 DRSUAPI_DS_REPLICA_SYNC_NEVER_COMPLETED = 0x00000400,
199 DRSUAPI_DS_REPLICA_SYNC_TWO_WAY = 0x00000800,
200 DRSUAPI_DS_REPLICA_SYNC_NEVER_NOTIFY = 0x00001000,
201 DRSUAPI_DS_REPLICA_SYNC_INITIAL = 0x00002000,
202 DRSUAPI_DS_REPLICA_SYNC_USE_COMPRESSION = 0x00004000,
203 DRSUAPI_DS_REPLICA_SYNC_ABANDONED = 0x00008000,
204 DRSUAPI_DS_REPLICA_SYNC_INITIAL_IN_PROGRESS = 0x00010000,
205 DRSUAPI_DS_REPLICA_SYNC_PARTIAL_ATTRIBUTE_SET = 0x00020000,
206 DRSUAPI_DS_REPLICA_SYNC_REQUEUE = 0x00040000,
207 DRSUAPI_DS_REPLICA_SYNC_NOTIFICATION = 0x00080000,
208 DRSUAPI_DS_REPLICA_SYNC_ASYNCHRONOUS_REPLICA = 0x00100000,
209 DRSUAPI_DS_REPLICA_SYNC_CRITICAL = 0x00200000,
210 DRSUAPI_DS_REPLICA_SYNC_FULL_IN_PROGRESS = 0x00400000,
211 DRSUAPI_DS_REPLICA_SYNC_PREEMPTED = 0x00800000
212 } drsuapi_DsReplicaSyncOptions;
214 typedef struct {
215 drsuapi_DsReplicaObjectIdentifier *naming_context;
216 GUID source_dsa_guid;
217 astring *other_info; /* I assume this is related to the repsFromTo1OtherInfo dns_name */
218 drsuapi_DsReplicaSyncOptions options;
219 } drsuapi_DsReplicaSyncRequest1;
221 typedef [switch_type(int32)] union {
222 [case(1)] drsuapi_DsReplicaSyncRequest1 req1;
223 } drsuapi_DsReplicaSyncRequest;
225 WERROR drsuapi_DsReplicaSync(
226 [in] policy_handle *bind_handle,
227 [in] int32 level,
228 [in,switch_is(level)] drsuapi_DsReplicaSyncRequest req
231 /*****************/
232 /* Function 0x03 */
233 typedef [public] struct {
234 hyper tmp_highest_usn; /* updated after each object update */
235 hyper reserved_usn;
236 hyper highest_usn; /* updated after a full replication cycle */
237 } drsuapi_DsReplicaHighWaterMark;
239 typedef [public] struct {
240 GUID source_dsa_invocation_id; /* the 'invocationId' field of the CN=NTDS Settings object */
241 hyper highest_usn; /* updated after a full replication cycle */
242 } drsuapi_DsReplicaCursor;
244 typedef struct {
245 [value(1)] uint32 version;
246 [value(0)] uint32 reserved1;
247 [range(0,0x100000)] uint32 count;
248 [value(0)] uint32 reserved2;
249 [size_is(count)] drsuapi_DsReplicaCursor cursors[];
250 } drsuapi_DsReplicaCursorCtrEx;
252 typedef [public] bitmap {
253 /* the _WRITEABLE flag indicates a replication with all attributes
255 * --metze
257 * See drsuapi_DrsOptions for the WSPP bit names
259 DRSUAPI_DS_REPLICA_NEIGHBOUR_WRITEABLE = 0x00000010,
260 DRSUAPI_DS_REPLICA_NEIGHBOUR_SYNC_ON_STARTUP = 0x00000020,
261 DRSUAPI_DS_REPLICA_NEIGHBOUR_DO_SCHEDULED_SYNCS = 0x00000040,
262 DRSUAPI_DS_REPLICA_NEIGHBOUR_USE_ASYNC_INTERSIDE_TRANSPORT = 0x00000080,
263 DRSUAPI_DS_REPLICA_NEIGHBOUR_ASYNC_REP = 0x00000100,
264 DRSUAPI_DS_REPLICA_NEIGHBOUR_IGNORE_ERROR = 0x00000100,
265 DRSUAPI_DS_REPLICA_NEIGHBOUR_TWO_WAY_SYNC = 0x00000200,
266 DRSUAPI_DS_REPLICA_NEIGHBOUR_CRITICAL_ONLY = 0x00000400,
267 DRSUAPI_DS_REPLICA_NEIGHBOUR_RETURN_OBJECT_PARENTS = 0x00000800,/*Include updates to ancestor objects before updates to their descendants*/
268 DRSUAPI_DS_REPLICA_NEIGHBOUR_FULL_IN_PROGRESS = 0x00010000,
269 DRSUAPI_DS_REPLICA_NEIGHBOUR_FULL_SYNC_PACKET = 0x00020000,
270 DRSUAPI_DS_REPLICA_NEIGHBOUR_NEVER_SYNCED = 0x00200000,
271 DRSUAPI_DS_REPLICA_NEIGHBOUR_SPECIAL_SECRET_PROCESSING = 0x00800000,
272 DRSUAPI_DS_REPLICA_NEIGHBOUR_PREEMPTED = 0x01000000,
273 DRSUAPI_DS_REPLICA_NEIGHBOUR_IGNORE_CHANGE_NOTIFICATIONS = 0x04000000,
274 DRSUAPI_DS_REPLICA_NEIGHBOUR_DISABLE_SCHEDULED_SYNC = 0x08000000,
276 * the following NOTE applies to DsGetNCChangesRequest5:
277 * - the data is only compressed when 10 or more objects are replicated
278 * - but there could also be a size limit of 35 KBytes or something like that
279 * - the reply is DsGetNCChangesCtr2
280 * - maybe the same applies to DsGetNCChangesRequest8...
282 * --metze
284 DRSUAPI_DS_REPLICA_NEIGHBOUR_COMPRESS_CHANGES = 0x10000000,
285 DRSUAPI_DS_REPLICA_NEIGHBOUR_NO_CHANGE_NOTIFICATIONS = 0x20000000,
286 DRSUAPI_DS_REPLICA_NEIGHBOUR_PARTIAL_ATTRIBUTE_SET = 0x40000000
287 } drsuapi_DsReplicaNeighbourFlags;
289 typedef [flag(NDR_PAHEX),v1_enum] enum {
290 DRSUAPI_EXOP_NONE = 0x00000000,
291 DRSUAPI_EXOP_FSMO_REQ_ROLE = 0x00000001,
292 DRSUAPI_EXOP_FSMO_RID_ALLOC = 0x00000002,
293 DRSUAPI_EXOP_FSMO_RID_REQ_ROLE = 0x00000003,
294 DRSUAPI_EXOP_FSMO_REQ_PDC = 0x00000004,
295 DRSUAPI_EXOP_FSMO_ABANDON_ROLE = 0x00000005,
296 DRSUAPI_EXOP_REPL_OBJ = 0x00000006,
297 DRSUAPI_EXOP_REPL_SECRET = 0x00000007
298 } drsuapi_DsExtendedOperation;
300 typedef [flag(NDR_PAHEX),v1_enum] enum {
301 DRSUAPI_EXOP_ERR_NONE = 0x00000000,
302 DRSUAPI_EXOP_ERR_SUCCESS = 0x00000001,
303 DRSUAPI_EXOP_ERR_UNKNOWN_OP = 0x00000002,
304 DRSUAPI_EXOP_ERR_FSMO_NOT_OWNER = 0x00000003,
305 DRSUAPI_EXOP_ERR_UPDATE_ERR = 0x00000004,
306 DRSUAPI_EXOP_ERR_EXCEPTION = 0x00000005,
307 DRSUAPI_EXOP_ERR_UNKNOWN_CALLER = 0x00000006,
308 DRSUAPI_EXOP_ERR_RID_ALLOC = 0x00000007,
309 DRSUAPI_EXOP_ERR_FSMO_OWNER_DELETED = 0x00000008,
310 DRSUAPI_EXOP_ERR_FMSO_PENDING_OP = 0x00000009,
311 DRSUAPI_EXOP_ERR_MISMATCH = 0x0000000A,
312 DRSUAPI_EXOP_ERR_COULDNT_CONTACT = 0x0000000B,
313 DRSUAPI_EXOP_ERR_FSMO_REFUSING_ROLES = 0x0000000C,
314 DRSUAPI_EXOP_ERR_DIR_ERROR = 0x0000000D,
315 DRSUAPI_EXOP_ERR_FSMO_MISSING_SETTINGS = 0x0000000E,
316 DRSUAPI_EXOP_ERR_ACCESS_DENIED = 0x0000000F,
317 DRSUAPI_EXOP_ERR_PARAM_ERROR = 0x00000010
318 } drsuapi_DsExtendedError;
320 typedef struct {
321 GUID destination_dsa_guid;
322 GUID source_dsa_invocation_id; /* the 'invocationId' field of the CN=NTDS Settings object */
323 [ref] drsuapi_DsReplicaObjectIdentifier *naming_context;
324 drsuapi_DsReplicaHighWaterMark highwatermark;
325 drsuapi_DsReplicaCursorCtrEx *uptodateness_vector;
326 drsuapi_DsReplicaNeighbourFlags replica_flags;
327 uint32 max_object_count; /* w2k3 uses min(133,max(100,max_object_count)) */
328 uint32 max_ndr_size; /* w2k3 seems to ignore this */
329 drsuapi_DsExtendedOperation extended_op;
330 hyper fsmo_info;
331 } drsuapi_DsGetNCChangesRequest5;
334 * In DRSUAPI all attributes with syntax 2.5.5.2
335 * are identified by uint32 values
337 * the following table shows the mapping used between the two representations
338 * e.g. - objectClass 'nTDSDSA' has governsID: 1.2.840.113556.1.5.7000.47
339 * and a UINT32-ID of '0x0017002F'.
340 * - so the OID 1.2.840.113556.1.5.7000.47 is splitted into a
341 * OID-prefix: 1.2.840.113556.1.5.7000
342 * and a value: 47 => 0x2F
343 * - the mapping table gives a UINT32-prefix: 0x00170000
344 * - and the UINT32-ID is 0x0017002F = 0x00170000 | 0x2F
346 * This prefix mapping table is replied in the drsuapi_DsReplicaOIDMapping_Ctr
347 * array. The following are the default mappings of w2k3
349 * OID-prefix => UINT32-Id prefix
351 * 2.5.4.* => 0x00000000 (standard attributes RFC2256 core.schema)
352 * 2.5.6.* => 0x00010000 (standard object classes RFC2256 core.schema)
353 * 1.2.840.113556.1.2.* => 0x00020000
354 * 1.2.840.113556.1.3.* => 0x00030000
355 * 2.5.5.* => 0x00080000 (attributeSyntax OID's)
356 * 1.2.840.113556.1.4.* => 0x00090000
357 * 1.2.840.113556.1.5.* => 0x000A0000
358 * 2.16.840.1.113730.3.* => 0x00140000
359 * 0.9.2342.19200300.100.1.* => 0x00150000
360 * 2.16.840.1.113730.3.1.* => 0x00160000
361 * 1.2.840.113556.1.5.7000.* => 0x00170000
362 * 2.5.21.* => 0x00180000 (attrs for SubSchema)
363 * 2.5.18.* => 0x00190000 (createTimeStamp,modifyTimeStamp, SubSchema)
364 * 2.5.20.* => 0x001A0000
365 * 1.3.6.1.4.1.1466.101.119.* => 0x001B0000 (dynamicObject, entryTTL)
366 * 2.16.840.1.113730.3.2.* => 0x001C0000
367 * 1.3.6.1.4.1.250.1.* => 0x001D0000
368 * 1.2.840.113549.1.9.* => 0x001E0000 (unstructuredAddress,unstructuredName)
369 * 0.9.2342.19200300.100.4.* => 0x001F0000
371 * Here's a list of used 'attributeSyntax' OID's
373 * 2.5.5.1 => Object(DS-DN) string
374 * struct drsuapi_DsObjectIdentifier3
376 * 2.5.5.2 => OID-string
377 * => all values are represented as uint32 values in drsuapi
378 * => governsID, attributeID and attributeSyntax returned as OID-Strings in LDAP
379 * => mayContain, mustContain and all other attributes with 2.5.5.2 syntax
380 * are returned as attribute names
382 * 2.5.5.4 => String(Teletex) case-insensitive string with teletex charset
384 * 2.5.5.5 => String(IA5) case-sensitive string
386 * 2.5.5.6 => String(Numeric)
387 * => eg. internationalISDNNumber
389 * 2.5.5.7 => Object(DN-Binary) B:<byte count>:<bytes>:<object DN>
390 * => e.g. wellKnownObjects
392 * 2.5.5.8 => BOOL
394 * 2.5.5.9 => int32
396 * 2.5.5.10 => DATA_BLOB
397 * => struct GUID
399 * 2.5.5.11 => LDAP timestring
400 * => NTTIME_1sec
402 * 2.5.5.12 => String(Unicode) case-insensitive string
403 * => 'standard strings'
405 * 2.5.5.13 => Object(Presentation-Address) string
406 * => used in objectClass applicationEntity
408 * 2.5.5.14 => Object(DN-String) S:<char count>:<string>:<object DN>
409 * => not used
411 * 2.5.5.15 => ntSecurityDescriptor
413 * 2.5.5.16 => int64
415 * 2.5.5.17 => dom_sid
417 typedef [noprint] struct {
418 [range(0,10000)] uint32 length;
419 [size_is(length)] uint8 *binary_oid; /* partial-binary-OID encoded with asn1_write_partial_OID_String() */
420 } drsuapi_DsReplicaOID;
422 typedef struct {
423 uint32 id_prefix;
424 drsuapi_DsReplicaOID oid;
425 } drsuapi_DsReplicaOIDMapping;
427 typedef [public] struct {
428 [range(0,0x100000)] uint32 num_mappings;
429 [size_is(num_mappings)] drsuapi_DsReplicaOIDMapping *mappings;
430 } drsuapi_DsReplicaOIDMapping_Ctr;
432 typedef [flag(NDR_PAHEX),v1_enum] enum {
433 DRSUAPI_OBJECTCLASS_top = 0x00010000,
434 DRSUAPI_OBJECTCLASS_classSchema = 0x0003000d,
435 DRSUAPI_OBJECTCLASS_attributeSchema = 0x0003000e
436 } drsuapi_DsObjectClassId;
438 typedef [flag(NDR_PAHEX),v1_enum,public] enum {
439 DRSUAPI_ATTRIBUTE_objectClass = 0x00000000,
440 DRSUAPI_ATTRIBUTE_description = 0x0000000d,
441 DRSUAPI_ATTRIBUTE_member = 0x0000001f,
442 DRSUAPI_ATTRIBUTE_instanceType = 0x00020001,
443 DRSUAPI_ATTRIBUTE_whenCreated = 0x00020002,
444 DRSUAPI_ATTRIBUTE_possSuperiors = 0x00020008,
445 DRSUAPI_ATTRIBUTE_hasMasterNCs = 0x0002000e,
446 DRSUAPI_ATTRIBUTE_subClassOf = 0x00020015,
447 DRSUAPI_ATTRIBUTE_governsID = 0x00020016,
448 DRSUAPI_ATTRIBUTE_mustContain = 0x00020018,
449 DRSUAPI_ATTRIBUTE_mayContain = 0x00020019,
450 DRSUAPI_ATTRIBUTE_attributeID = 0x0002001e,
451 DRSUAPI_ATTRIBUTE_attributeSyntax = 0x00020020,
452 DRSUAPI_ATTRIBUTE_isSingleValued = 0x00020021,
453 DRSUAPI_ATTRIBUTE_rangeLower = 0x00020022,
454 DRSUAPI_ATTRIBUTE_rangeUpper = 0x00020023,
455 DRSUAPI_ATTRIBUTE_dMDLocation = 0x00020024,
456 DRSUAPI_ATTRIBUTE_objectVersion = 0x0002004c,
457 DRSUAPI_ATTRIBUTE_invocationId = 0x00020073,
458 DRSUAPI_ATTRIBUTE_showInAdvancedViewOnly = 0x000200a9,
459 DRSUAPI_ATTRIBUTE_adminDisplayName = 0x000200c2,
460 DRSUAPI_ATTRIBUTE_adminDescription = 0x000200e2,
461 DRSUAPI_ATTRIBUTE_oMSyntax = 0x000200e7,
462 DRSUAPI_ATTRIBUTE_ntSecurityDescriptor = 0x00020119,
463 DRSUAPI_ATTRIBUTE_searchFlags = 0x0002014e,
464 DRSUAPI_ATTRIBUTE_auxiliaryClass = 0x0002015f,
465 DRSUAPI_ATTRIBUTE_lDAPDisplayName = 0x000201cc,
466 DRSUAPI_ATTRIBUTE_name = 0x00090001,
467 DRSUAPI_ATTRIBUTE_userAccountControl = 0x00090008,
468 DRSUAPI_ATTRIBUTE_currentValue = 0x0009001b,
469 DRSUAPI_ATTRIBUTE_homeDirectory = 0x0009002c,
470 DRSUAPI_ATTRIBUTE_homeDrive = 0x0009002d,
471 DRSUAPI_ATTRIBUTE_scriptPath = 0x0009003e,
472 DRSUAPI_ATTRIBUTE_profilePath = 0x0009008b,
473 DRSUAPI_ATTRIBUTE_objectSid = 0x00090092,
474 DRSUAPI_ATTRIBUTE_schemaIDGUID = 0x00090094,
475 DRSUAPI_ATTRIBUTE_dBCSPwd = 0x00090037,/* lmPwdHash */
476 DRSUAPI_ATTRIBUTE_logonHours = 0x00090040,
477 DRSUAPI_ATTRIBUTE_userWorkstations = 0x00090056,
478 DRSUAPI_ATTRIBUTE_unicodePwd = 0x0009005a,/* ntPwdHash */
479 DRSUAPI_ATTRIBUTE_ntPwdHistory = 0x0009005e,
480 DRSUAPI_ATTRIBUTE_priorValue = 0x00090064,
481 DRSUAPI_ATTRIBUTE_supplementalCredentials = 0x0009007d,
482 DRSUAPI_ATTRIBUTE_trustAuthIncoming = 0x00090081,
483 DRSUAPI_ATTRIBUTE_trustAuthOutgoing = 0x00090087,
484 DRSUAPI_ATTRIBUTE_lmPwdHistory = 0x000900a0,
485 DRSUAPI_ATTRIBUTE_systemPossSuperiors = 0x000900c3,
486 DRSUAPI_ATTRIBUTE_systemMayContain = 0x000900c4,
487 DRSUAPI_ATTRIBUTE_systemMustContain = 0x000900c5,
488 DRSUAPI_ATTRIBUTE_sAMAccountName = 0x000900dd,
489 DRSUAPI_ATTRIBUTE_sAMAccountType = 0x0009012e,
490 DRSUAPI_ATTRIBUTE_fSMORoleOwner = 0x00090171,
491 DRSUAPI_ATTRIBUTE_systemFlags = 0x00090177,
492 DRSUAPI_ATTRIBUTE_serverReference = 0x00090203,
493 DRSUAPI_ATTRIBUTE_serverReferenceBL = 0x00090204,
494 DRSUAPI_ATTRIBUTE_initialAuthIncoming = 0x0009021b,
495 DRSUAPI_ATTRIBUTE_initialAuthOutgoing = 0x0009021c,
496 DRSUAPI_ATTRIBUTE_wellKnownObjects = 0x0009026a,
497 DRSUAPI_ATTRIBUTE_dNSHostName = 0x0009026b,
498 DRSUAPI_ATTRIBUTE_isMemberOfPartialAttributeSet = 0x0009027f,
499 DRSUAPI_ATTRIBUTE_userPrincipalName = 0x00090290,
500 DRSUAPI_ATTRIBUTE_groupType = 0x000902ee,
501 DRSUAPI_ATTRIBUTE_servicePrincipalName = 0x00090303,
502 DRSUAPI_ATTRIBUTE_objectCategory = 0x0009030e,
503 DRSUAPI_ATTRIBUTE_gPLink = 0x0009037b,
504 DRSUAPI_ATTRIBUTE_msDS_Behavior_Version = 0x000905b3,
505 DRSUAPI_ATTRIBUTE_msDS_KeyVersionNumber = 0x000906f6,
506 DRSUAPI_ATTRIBUTE_msDS_HasDomainNCs = 0x0009071c,
507 DRSUAPI_ATTRIBUTE_msDS_hasMasterNCs = 0x0009072c
508 } drsuapi_DsAttributeId;
510 typedef struct {
511 [value(1)] uint32 version;
512 [value(0)] uint32 reserved1;
513 [range(1,0x100000)] uint32 num_attids;
514 [size_is(num_attids)] drsuapi_DsAttributeId attids[];
515 } drsuapi_DsPartialAttributeSet;
517 typedef struct {
518 GUID destination_dsa_guid;
519 GUID source_dsa_invocation_id; /* the 'invocationId' field of the CN=NTDS Settings object */
520 [ref] drsuapi_DsReplicaObjectIdentifier *naming_context;
521 drsuapi_DsReplicaHighWaterMark highwatermark;
522 drsuapi_DsReplicaCursorCtrEx *uptodateness_vector;
523 drsuapi_DsReplicaNeighbourFlags replica_flags;
524 uint32 max_object_count; /* w2k3 uses min(133,max(100,max_object_count)) */
525 uint32 max_ndr_size; /* w2k3 seems to ignore this */
526 drsuapi_DsExtendedOperation extended_op;
527 hyper fsmo_info;
528 drsuapi_DsPartialAttributeSet *partial_attribute_set;
529 drsuapi_DsPartialAttributeSet *partial_attribute_set_ex;
530 drsuapi_DsReplicaOIDMapping_Ctr mapping_ctr;
531 } drsuapi_DsGetNCChangesRequest8;
533 typedef struct {
534 GUID destination_dsa_guid;
535 GUID source_dsa_invocation_id; /* the 'invocationId' field of the CN=NTDS Settings object */
536 [ref] drsuapi_DsReplicaObjectIdentifier *naming_context;
537 drsuapi_DsReplicaHighWaterMark highwatermark;
538 drsuapi_DsReplicaCursorCtrEx *uptodateness_vector;
539 drsuapi_DsReplicaNeighbourFlags replica_flags;
540 uint32 max_object_count; /* w2k3 uses min(133,max(100,max_object_count)) */
541 uint32 max_ndr_size; /* w2k3 seems to ignore this */
542 drsuapi_DsExtendedOperation extended_op;
543 hyper fsmo_info;
544 drsuapi_DsPartialAttributeSet *partial_attribute_set;
545 drsuapi_DsPartialAttributeSet *partial_attribute_set_ex;
546 drsuapi_DsReplicaOIDMapping_Ctr mapping_ctr;
547 uint32 more_flags;
548 } drsuapi_DsGetNCChangesRequest10;
550 typedef [switch_type(int32)] union {
551 [case(5)] drsuapi_DsGetNCChangesRequest5 req5;
552 [case(8)] drsuapi_DsGetNCChangesRequest8 req8;
553 [case(10)] drsuapi_DsGetNCChangesRequest10 req10;
554 } drsuapi_DsGetNCChangesRequest;
556 typedef [public] struct {
557 GUID source_dsa_invocation_id; /* the 'invocationId' field of the CN=NTDS Settings object */
558 hyper highest_usn; /* updated after a full replication cycle */
559 NTTIME last_sync_success;
560 } drsuapi_DsReplicaCursor2;
562 typedef struct {
563 [value(2)] uint32 version;
564 [value(0)] uint32 reserved1;
565 [range(0,0x100000)] uint32 count;
566 [value(0)] uint32 reserved2;
567 [size_is(count)] drsuapi_DsReplicaCursor2 cursors[];
568 } drsuapi_DsReplicaCursor2CtrEx;
570 /* Generic DATA_BLOB values */
571 typedef struct {
572 [range(0,10485760),value(ndr_size_DATA_BLOB(0,blob,0))] uint32 __ndr_size;
573 DATA_BLOB *blob;
574 } drsuapi_DsAttributeValue;
576 typedef struct {
577 [range(0,10485760)] uint32 num_values;
578 [size_is(num_values)] drsuapi_DsAttributeValue *values;
579 } drsuapi_DsAttributeValueCtr;
581 /* DN String values */
582 typedef [public,gensize] struct {
583 [value(ndr_size_drsuapi_DsReplicaObjectIdentifier3(r, ndr->iconv_convenience, ndr->flags))] uint32 __ndr_size;
584 [value(ndr_size_dom_sid28(&sid,ndr->flags))] uint32 __ndr_size_sid;
585 GUID guid;
586 dom_sid28 sid;
587 [value(strlen_m(dn))] uint32 __ndr_size_dn;
588 [charset(UTF16)] uint16 dn[__ndr_size_dn+1];
589 } drsuapi_DsReplicaObjectIdentifier3;
591 typedef [public] struct {
592 [value(ndr_size_drsuapi_DsReplicaObjectIdentifier3Binary_without_Binary(r, ndr->iconv_convenience, ndr->flags))] uint32 __ndr_size;
593 [value(ndr_size_dom_sid28(&sid,ndr->flags))] uint32 __ndr_size_sid;
594 GUID guid;
595 dom_sid28 sid;
596 [value(strlen_m(dn))] uint32 __ndr_size_dn;
597 [charset(UTF16)] uint16 dn[__ndr_size_dn+1];
598 [value(binary.length + 4)] uint32 __ndr_size_binary;
599 [flag(NDR_REMAINING)] DATA_BLOB binary;
600 } drsuapi_DsReplicaObjectIdentifier3Binary;
602 typedef [public] struct {
603 drsuapi_DsAttributeId attid;
604 drsuapi_DsAttributeValueCtr value_ctr;
605 } drsuapi_DsReplicaAttribute;
607 typedef struct {
608 [range(0,1048576)] uint32 num_attributes;
609 [size_is(num_attributes)] drsuapi_DsReplicaAttribute *attributes;
610 } drsuapi_DsReplicaAttributeCtr;
612 typedef [public] bitmap {
613 DRSUAPI_DS_REPLICA_OBJECT_FROM_MASTER = 0x00000001,
614 DRSUAPI_DS_REPLICA_OBJECT_DYNAMIC = 0x00000002,
615 DRSUAPI_DS_REPLICA_OBJECT_REMOTE_MODIFY = 0x00010000
616 } drsuapi_DsReplicaObjectFlags;
618 typedef [public] struct {
619 drsuapi_DsReplicaObjectIdentifier *identifier;
620 drsuapi_DsReplicaObjectFlags flags;
621 drsuapi_DsReplicaAttributeCtr attribute_ctr;
622 } drsuapi_DsReplicaObject;
624 typedef struct {
625 uint32 version;
626 NTTIME_1sec originating_change_time;
627 GUID originating_invocation_id;
628 hyper originating_usn;
629 } drsuapi_DsReplicaMetaData;
631 typedef [public] struct {
632 [range(0,1048576)] uint32 count;
633 [size_is(count)] drsuapi_DsReplicaMetaData meta_data[];
634 } drsuapi_DsReplicaMetaDataCtr;
636 typedef [public,noprint] struct {
637 drsuapi_DsReplicaObjectListItemEx *next_object;
638 drsuapi_DsReplicaObject object;
639 boolean32 is_nc_prefix;
640 GUID *parent_object_guid;
641 drsuapi_DsReplicaMetaDataCtr *meta_data_ctr;
642 } drsuapi_DsReplicaObjectListItemEx;
644 typedef [public,gensize] struct {
645 GUID source_dsa_guid; /* the 'objectGUID' field of the CN=NTDS Settings object */
646 GUID source_dsa_invocation_id; /* the 'invocationId' field of the CN=NTDS Settings object */
647 drsuapi_DsReplicaObjectIdentifier *naming_context;
648 drsuapi_DsReplicaHighWaterMark old_highwatermark;
649 drsuapi_DsReplicaHighWaterMark new_highwatermark;
650 drsuapi_DsReplicaCursorCtrEx *uptodateness_vector;
651 drsuapi_DsReplicaOIDMapping_Ctr mapping_ctr;
652 drsuapi_DsExtendedError extended_ret; /* w2k sends the nc_object_count value here */
653 uint32 object_count;
654 /* this +55 is sometimes +56, so I don't know where this comes from... --metze */
655 [value(ndr_size_drsuapi_DsGetNCChangesCtr1(r,ndr->iconv_convenience,ndr->flags)+55)] uint32 __ndr_size;
656 drsuapi_DsReplicaObjectListItemEx *first_object;
657 boolean32 more_data;
658 } drsuapi_DsGetNCChangesCtr1;
661 * if the DRSUAPI_DS_LINKED_ATTRIBUTE_FLAG_ACTIVE flag
662 * isn't there it means the value is deleted
664 typedef [public] bitmap {
665 DRSUAPI_DS_LINKED_ATTRIBUTE_FLAG_ACTIVE = 0x00000001
666 } drsuapi_DsLinkedAttributeFlags;
668 typedef [public] struct {
669 drsuapi_DsReplicaObjectIdentifier *identifier;
670 drsuapi_DsAttributeId attid;
671 drsuapi_DsAttributeValue value;
672 drsuapi_DsLinkedAttributeFlags flags;
673 NTTIME_1sec originating_add_time;
674 drsuapi_DsReplicaMetaData meta_data;
675 } drsuapi_DsReplicaLinkedAttribute;
677 /* [MS-DRSR] section 4.1.10.2.11 DRS_MSG_GETCHGREPLY_V6 */
678 typedef [public,gensize] struct {
679 GUID source_dsa_guid; /* the 'objectGUID' field of the CN=NTDS Settings object */
680 GUID source_dsa_invocation_id; /* the 'invocationId' field of the CN=NTDS Settings object */
681 drsuapi_DsReplicaObjectIdentifier *naming_context;
682 drsuapi_DsReplicaHighWaterMark old_highwatermark;
683 drsuapi_DsReplicaHighWaterMark new_highwatermark;
684 drsuapi_DsReplicaCursor2CtrEx *uptodateness_vector;
685 drsuapi_DsReplicaOIDMapping_Ctr mapping_ctr;
686 drsuapi_DsExtendedError extended_ret;
687 uint32 object_count;
688 /* this +55 is sometimes +56, so I don't know where this comes from... --metze */
689 [value(ndr_size_drsuapi_DsGetNCChangesCtr6(r,ndr->iconv_convenience,ndr->flags)+55)] uint32 __ndr_size;
690 drsuapi_DsReplicaObjectListItemEx *first_object;
691 boolean32 more_data;
692 uint32 nc_object_count; /* estimated amount of objects in the whole NC */
693 uint32 nc_linked_attributes_count; /* estimated amount of linked values in the whole NC */
694 [range(0,1048576)] uint32 linked_attributes_count;
695 [size_is(linked_attributes_count)] drsuapi_DsReplicaLinkedAttribute *linked_attributes;
696 WERROR drs_error;
697 } drsuapi_DsGetNCChangesCtr6;
699 typedef [public] struct {
700 [subcontext(0xFFFFFC01)] drsuapi_DsGetNCChangesCtr1 ctr1;
701 } drsuapi_DsGetNCChangesCtr1TS;
703 typedef [public] struct {
704 [subcontext(0xFFFFFC01)] drsuapi_DsGetNCChangesCtr6 ctr6;
705 } drsuapi_DsGetNCChangesCtr6TS;
707 typedef [nopush] struct {
708 uint32 decompressed_length;
709 uint32 compressed_length;
710 [subcontext(4),subcontext_size(compressed_length),
711 compression(NDR_COMPRESSION_MSZIP,compressed_length,decompressed_length)]
712 drsuapi_DsGetNCChangesCtr1TS *ts;
713 } drsuapi_DsGetNCChangesMSZIPCtr1;
715 typedef [nopush] struct {
716 uint32 decompressed_length;
717 uint32 compressed_length;
718 [subcontext(4),subcontext_size(compressed_length),
719 compression(NDR_COMPRESSION_MSZIP,compressed_length,decompressed_length)]
720 drsuapi_DsGetNCChangesCtr6TS *ts;
721 } drsuapi_DsGetNCChangesMSZIPCtr6;
723 typedef [nopush] struct {
724 uint32 decompressed_length;
725 uint32 compressed_length;
726 [subcontext(4),subcontext_size(compressed_length),
727 compression(NDR_COMPRESSION_XPRESS,compressed_length,decompressed_length)]
728 drsuapi_DsGetNCChangesCtr1TS *ts;
729 } drsuapi_DsGetNCChangesXPRESSCtr1;
731 typedef [nopush] struct {
732 uint32 decompressed_length;
733 uint32 compressed_length;
734 [subcontext(4),subcontext_size(compressed_length),
735 compression(NDR_COMPRESSION_XPRESS,compressed_length,decompressed_length)]
736 drsuapi_DsGetNCChangesCtr6TS *ts;
737 } drsuapi_DsGetNCChangesXPRESSCtr6;
739 typedef [enum16bit] enum {
740 DRSUAPI_COMPRESSION_TYPE_MSZIP = 2,
741 DRSUAPI_COMPRESSION_TYPE_XPRESS = 3
742 } drsuapi_DsGetNCChangesCompressionType;
744 typedef [nodiscriminant,flag(NDR_PAHEX)] union {
745 [case(1|(DRSUAPI_COMPRESSION_TYPE_MSZIP<<16))] drsuapi_DsGetNCChangesMSZIPCtr1 mszip1;
746 [case(6|(DRSUAPI_COMPRESSION_TYPE_MSZIP<<16))] drsuapi_DsGetNCChangesMSZIPCtr6 mszip6;
747 [case(1|(DRSUAPI_COMPRESSION_TYPE_XPRESS<<16))] drsuapi_DsGetNCChangesXPRESSCtr1 xpress1;
748 [case(6|(DRSUAPI_COMPRESSION_TYPE_XPRESS<<16))] drsuapi_DsGetNCChangesXPRESSCtr6 xpress6;
749 } drsuapi_DsGetNCChangesCompressedCtr;
751 typedef struct {
752 drsuapi_DsGetNCChangesMSZIPCtr1 mszip1;
753 } drsuapi_DsGetNCChangesCtr2;
755 typedef struct {
756 [range(0,6)] int32 level;
757 [range(2,3)] drsuapi_DsGetNCChangesCompressionType type;
758 [switch_is(level | (type<<16))] drsuapi_DsGetNCChangesCompressedCtr ctr;
759 } drsuapi_DsGetNCChangesCtr7;
761 typedef [switch_type(int32)] union {
762 [case(1)] drsuapi_DsGetNCChangesCtr1 ctr1;
763 [case(2)] drsuapi_DsGetNCChangesCtr2 ctr2;
764 [case(6)] drsuapi_DsGetNCChangesCtr6 ctr6;
765 [case(7)] drsuapi_DsGetNCChangesCtr7 ctr7;
766 } drsuapi_DsGetNCChangesCtr;
768 WERROR drsuapi_DsGetNCChanges(
769 [in] policy_handle *bind_handle,
770 [in] int32 level,
771 [in,ref,switch_is(level)] drsuapi_DsGetNCChangesRequest *req,
772 [out,ref] int32 *level_out,
773 [out,ref,switch_is(*level_out)] drsuapi_DsGetNCChangesCtr *ctr
776 /*****************/
777 /* Function 0x04 */
778 /* [MS-DRSR] 4.1.26 */
779 typedef bitmap {
780 DRSUAPI_DS_REPLICA_UPDATE_ASYNCHRONOUS_OPERATION = 0x00000001,
781 DRSUAPI_DS_REPLICA_UPDATE_GETCHG_CHECK = 0x00000002,
782 DRSUAPI_DS_REPLICA_UPDATE_ADD_REFERENCE = 0x00000004,
783 DRSUAPI_DS_REPLICA_UPDATE_DELETE_REFERENCE = 0x00000008,
784 DRSUAPI_DS_REPLICA_UPDATE_WRITEABLE = 0x00000010
785 } drsuapi_DsReplicaUpdateRefsOptions;
787 typedef struct {
788 [ref] drsuapi_DsReplicaObjectIdentifier *naming_context;
789 [ref,charset(DOS),string] uint8 *dest_dsa_dns_name;
790 GUID dest_dsa_guid;
791 drsuapi_DsReplicaUpdateRefsOptions options;
792 } drsuapi_DsReplicaUpdateRefsRequest1;
794 typedef [switch_type(int32)] union {
795 [case(1)] drsuapi_DsReplicaUpdateRefsRequest1 req1;
796 } drsuapi_DsReplicaUpdateRefsRequest;
798 WERROR drsuapi_DsReplicaUpdateRefs(
799 [in] policy_handle *bind_handle,
800 [in] int32 level,
801 [in,switch_is(level)] drsuapi_DsReplicaUpdateRefsRequest req
804 /*****************/
805 /* Function 0x05 */
806 typedef bitmap {
807 DRSUAPI_DS_REPLICA_ADD_ASYNCHRONOUS_OPERATION = 0x00000001,
808 DRSUAPI_DS_REPLICA_ADD_WRITEABLE = 0x00000002
809 /* TODO ... */
810 } drsuapi_DsReplicaAddOptions;
813 typedef struct {
814 [ref] drsuapi_DsReplicaObjectIdentifier *naming_context;
815 [charset(UTF16),string] uint16 *source_dsa_address;
816 uint8 schedule[84];
817 drsuapi_DsReplicaAddOptions options;
818 } drsuapi_DsReplicaAddRequest1;
820 typedef struct {
821 [ref] drsuapi_DsReplicaObjectIdentifier *naming_context;
822 drsuapi_DsReplicaObjectIdentifier *source_dsa_dn;
823 drsuapi_DsReplicaObjectIdentifier *transport_dn;
824 [charset(UTF16),string] uint16 *source_dsa_address;
825 uint8 schedule[84];
826 drsuapi_DsReplicaAddOptions options;
827 } drsuapi_DsReplicaAddRequest2;
829 typedef [switch_type(int32)] union {
830 [case(1)] drsuapi_DsReplicaAddRequest1 req1;
831 [case(2)] drsuapi_DsReplicaAddRequest2 req2;
832 } drsuapi_DsReplicaAddRequest;
834 WERROR drsuapi_DsReplicaAdd(
835 [in] policy_handle *bind_handle,
836 [in] int32 level,
837 [in,switch_is(level)] drsuapi_DsReplicaAddRequest req
841 /*****************/
842 /* Function 0x06 */
843 typedef bitmap {
844 DRSUAPI_DS_REPLICA_ADD_ASYNCHRONOUS_OPERATION = 0x00000001,
845 DRSUAPI_DS_REPLICA_ADD_WRITEABLE = 0x00000002
846 /* TODO ... */
847 } drsuapi_DsReplicaDeleteOptions;
850 typedef struct {
851 [ref] drsuapi_DsReplicaObjectIdentifier *naming_context;
852 [charset(UTF16),string] uint16 *source_dsa_address;
853 drsuapi_DsReplicaDeleteOptions options;
854 } drsuapi_DsReplicaDelRequest1;
856 typedef [switch_type(int32)] union {
857 [case(1)] drsuapi_DsReplicaDelRequest1 req1;
858 } drsuapi_DsReplicaDelRequest;
860 WERROR drsuapi_DsReplicaDel(
861 [in] policy_handle *bind_handle,
862 [in] int32 level,
863 [in,switch_is(level)] drsuapi_DsReplicaDelRequest req
866 /*****************/
867 /* Function 0x07 */
868 typedef bitmap {
869 DRSUAPI_DS_REPLICA_ADD_ASYNCHRONOUS_OPERATION = 0x00000001,
870 DRSUAPI_DS_REPLICA_ADD_WRITEABLE = 0x00000002
871 /* TODO ... */
872 } drsuapi_DsReplicaModifyOptions;
875 typedef struct {
876 [ref] drsuapi_DsReplicaObjectIdentifier *naming_context;
877 GUID source_dra;
878 [charset(UTF16),string] uint16 *source_dra_address;
879 uint8 schedule[84];
880 uint32 replica_flags;
881 uint32 modify_fields;
882 drsuapi_DsReplicaModifyOptions options;
883 } drsuapi_DsReplicaModRequest1;
885 typedef [switch_type(int32)] union {
886 [case(1)] drsuapi_DsReplicaModRequest1 req1;
887 } drsuapi_DsReplicaModRequest;
889 WERROR drsuapi_DsReplicaMod(
890 [in] policy_handle *bind_handle,
891 [in] int32 level,
892 [in,switch_is(level)] drsuapi_DsReplicaModRequest req
895 /*****************/
896 /* Function 0x08 */
897 [todo] WERROR DRSUAPI_VERIFY_NAMES();
899 /*****************/
900 /* Function 0x09 */
902 /* how are type 4 and 7 different from 2 and 3 ? */
903 typedef [v1_enum] enum {
904 DRSUAPI_DS_MEMBERSHIP_TYPE_UNIVERSAL_AND_DOMAIN_GROUPS = 1,
905 DRSUAPI_DS_MEMBERSHIP_TYPE_DOMAIN_LOCAL_GROUPS = 2,
906 DRSUAPI_DS_MEMBERSHIP_TYPE_DOMAIN_GROUPS = 3,
907 DRSUAPI_DS_MEMBERSHIP_TYPE_DOMAIN_LOCAL_GROUPS2 = 4,
908 DRSUAPI_DS_MEMBERSHIP_TYPE_UNIVERSAL_GROUPS = 5,
909 DRSUAPI_DS_MEMBERSHIP_TYPE_GROUPMEMBERS = 6,
910 DRSUAPI_DS_MEMBERSHIP_TYPE_DOMAIN_GROUPS2 = 7
911 } drsuapi_DsMembershipType;
913 typedef struct {
914 NTSTATUS status;
915 [range(0,10000)] uint32 num_memberships;
916 [range(0,10000)] uint32 num_sids;
917 [size_is(num_memberships)] drsuapi_DsReplicaObjectIdentifier **info_array;
918 [size_is(num_memberships)] samr_GroupAttrs *group_attrs;
919 [size_is(num_sids)] dom_sid28 **sids;
920 } drsuapi_DsGetMembershipsCtr1;
922 typedef [switch_type(int32)] union {
923 [case(1)] drsuapi_DsGetMembershipsCtr1 ctr1;
924 } drsuapi_DsGetMembershipsCtr;
926 const int DRSUAPI_DS_MEMBERSHIP_FLAG_GROUP_ATTR = 0x1;
928 typedef struct {
929 [range(1,10000)] uint32 count;
930 [size_is(count)] drsuapi_DsReplicaObjectIdentifier **info_array;
931 uint32 flags;
932 drsuapi_DsMembershipType type;
933 drsuapi_DsReplicaObjectIdentifier *domain;
934 } drsuapi_DsGetMembershipsRequest1;
936 typedef [switch_type(int32)] union {
937 [case(1)] drsuapi_DsGetMembershipsRequest1 req1;
938 } drsuapi_DsGetMembershipsRequest;
940 [todo] WERROR drsuapi_DsGetMemberships(
941 [in] policy_handle *bind_handle,
942 [in] int32 level,
943 [in,ref] [switch_is(level)] drsuapi_DsGetMembershipsRequest *req,
944 [out,ref] int32 *level_out,
945 [out,ref] [switch_is(*level_out)] drsuapi_DsGetMembershipsCtr *ctr
948 /*****************/
949 /* Function 0x0a */
950 [todo] WERROR DRSUAPI_INTER_DOMAIN_MOVE();
952 /*****************/
953 /* Function 0x0b */
954 typedef struct {
955 uint32 unknown1;
956 uint32 unknown2;
957 [range(0,0x00A00000)] uint32 length;
958 [size_is(length)] uint8 *data;
959 } drsuapi_DsGetNT4ChangeLogRequest1;
961 typedef [switch_type(uint32)] union {
962 [case(1)] drsuapi_DsGetNT4ChangeLogRequest1 req1;
963 } drsuapi_DsGetNT4ChangeLogRequest;
965 typedef struct {
966 [range(0,0x00A00000)] uint32 length1;
967 [range(0,0x00A00000)] uint32 length2;
968 hyper unknown1;
969 NTTIME time2;
970 hyper unknown3;
971 NTTIME time4;
972 hyper unknown5;
973 NTTIME time6;
974 NTSTATUS status;
975 [size_is(length1)] uint8 *data1;
976 [size_is(length2)] uint8 *data2;
977 } drsuapi_DsGetNT4ChangeLogInfo1;
979 typedef [switch_type(uint32)] union {
980 [case(1)] drsuapi_DsGetNT4ChangeLogInfo1 info1;
981 } drsuapi_DsGetNT4ChangeLogInfo;
983 [todo] WERROR drsuapi_DsGetNT4ChangeLog(
984 [in] policy_handle *bind_handle,
985 [in] uint32 level,
986 [in,ref] [switch_is(level)] drsuapi_DsGetNT4ChangeLogRequest *req,
987 [out,ref] uint32 *level_out,
988 [out,ref] [switch_is(*level_out)] drsuapi_DsGetNT4ChangeLogInfo *info
991 /*****************/
992 /* Function 0x0c */
993 typedef [v1_enum] enum {
994 DRSUAPI_DS_NAME_STATUS_OK = 0,
995 DRSUAPI_DS_NAME_STATUS_RESOLVE_ERROR = 1,
996 DRSUAPI_DS_NAME_STATUS_NOT_FOUND = 2,
997 DRSUAPI_DS_NAME_STATUS_NOT_UNIQUE = 3,
998 DRSUAPI_DS_NAME_STATUS_NO_MAPPING = 4,
999 DRSUAPI_DS_NAME_STATUS_DOMAIN_ONLY = 5,
1000 DRSUAPI_DS_NAME_STATUS_NO_SYNTACTICAL_MAPPING = 6,
1001 DRSUAPI_DS_NAME_STATUS_TRUST_REFERRAL = 7
1002 } drsuapi_DsNameStatus;
1004 typedef [v1_enum] enum {
1005 DRSUAPI_DS_NAME_FLAG_NO_FLAGS = 0x0,
1006 DRSUAPI_DS_NAME_FLAG_SYNTACTICAL_ONLY = 0x1,
1007 DRSUAPI_DS_NAME_FLAG_EVAL_AT_DC = 0x2,
1008 DRSUAPI_DS_NAME_FLAG_GCVERIFY = 0x4,
1009 DRSUAPI_DS_NAME_FLAG_TRUST_REFERRAL = 0x8
1010 } drsuapi_DsNameFlags;
1012 typedef [v1_enum] enum {
1013 DRSUAPI_DS_NAME_FORMAT_UNKNOWN = 0,
1014 DRSUAPI_DS_NAME_FORMAT_FQDN_1779 = 1,
1015 DRSUAPI_DS_NAME_FORMAT_NT4_ACCOUNT = 2,
1016 DRSUAPI_DS_NAME_FORMAT_DISPLAY = 3,
1017 DRSUAPI_DS_NAME_FORMAT_GUID = 6,
1018 DRSUAPI_DS_NAME_FORMAT_CANONICAL = 7,
1019 DRSUAPI_DS_NAME_FORMAT_USER_PRINCIPAL = 8,
1020 DRSUAPI_DS_NAME_FORMAT_CANONICAL_EX = 9,
1021 DRSUAPI_DS_NAME_FORMAT_SERVICE_PRINCIPAL = 10,
1022 DRSUAPI_DS_NAME_FORMAT_SID_OR_SID_HISTORY = 11,
1023 DRSUAPI_DS_NAME_FORMAT_DNS_DOMAIN = 12
1024 } drsuapi_DsNameFormat;
1026 typedef struct {
1027 [string,charset(UTF16)] uint16 *str;
1028 } drsuapi_DsNameString;
1030 typedef struct {
1031 uint32 codepage; /* 0x000004e4 - 1252 is german codepage*/
1032 uint32 language; /* 0x00000407 - german language ID*/
1033 drsuapi_DsNameFlags format_flags;
1034 drsuapi_DsNameFormat format_offered;
1035 drsuapi_DsNameFormat format_desired;
1036 [range(1,10000)] uint32 count;
1037 [size_is(count)] drsuapi_DsNameString *names;
1038 } drsuapi_DsNameRequest1;
1040 typedef [switch_type(int32)] union {
1041 [case(1)] drsuapi_DsNameRequest1 req1;
1042 } drsuapi_DsNameRequest;
1044 typedef struct {
1045 drsuapi_DsNameStatus status;
1046 [charset(UTF16),string] uint16 *dns_domain_name;
1047 [charset(UTF16),string] uint16 *result_name;
1048 } drsuapi_DsNameInfo1;
1050 typedef struct {
1051 uint32 count;
1052 [size_is(count)] drsuapi_DsNameInfo1 *array;
1053 } drsuapi_DsNameCtr1;
1055 typedef [switch_type(int32)] union {
1056 [case(1)] drsuapi_DsNameCtr1 *ctr1;
1057 } drsuapi_DsNameCtr;
1059 WERROR drsuapi_DsCrackNames(
1060 [in] policy_handle *bind_handle,
1061 [in] int32 level,
1062 [in,ref,switch_is(level)] drsuapi_DsNameRequest *req,
1063 [out,ref] int32 *level_out,
1064 [out,ref,switch_is(*level_out)] drsuapi_DsNameCtr *ctr
1067 /*****************/
1068 /* Function 0x0d */
1069 typedef [v1_enum] enum {
1070 DRSUAPI_DS_SPN_OPERATION_ADD = 0,
1071 DRSUAPI_DS_SPN_OPERATION_REPLACE= 1,
1072 DRSUAPI_DS_SPN_OPERATION_DELETE = 2
1073 } drsuapi_DsSpnOperation;
1075 typedef struct {
1076 drsuapi_DsSpnOperation operation;
1077 uint32 unknown1;
1078 [charset(UTF16),string] uint16 *object_dn;
1079 [range(0,10000)] uint32 count;
1080 [size_is(count)] drsuapi_DsNameString *spn_names;
1081 } drsuapi_DsWriteAccountSpnRequest1;
1083 typedef [switch_type(int32)] union {
1084 [case(1)] drsuapi_DsWriteAccountSpnRequest1 req1;
1085 } drsuapi_DsWriteAccountSpnRequest;
1087 typedef struct {
1088 WERROR status;
1089 } drsuapi_DsWriteAccountSpnResult1;
1091 typedef [switch_type(int32)] union {
1092 [case(1)] drsuapi_DsWriteAccountSpnResult1 res1;
1093 } drsuapi_DsWriteAccountSpnResult;
1095 WERROR drsuapi_DsWriteAccountSpn(
1096 [in] policy_handle *bind_handle,
1097 [in] int32 level,
1098 [in,ref,switch_is(level)] drsuapi_DsWriteAccountSpnRequest *req,
1099 [out,ref] int32 *level_out,
1100 [out,ref,switch_is(*level_out)] drsuapi_DsWriteAccountSpnResult *res
1103 /*****************/
1104 /* Function 0x0e */
1105 typedef struct {
1106 [charset(UTF16),string] uint16 *server_dn;
1107 [charset(UTF16),string] uint16 *domain_dn;
1108 boolean32 commit;
1109 } drsuapi_DsRemoveDSServerRequest1;
1111 typedef [switch_type(int32)] union {
1112 [case(1)] drsuapi_DsRemoveDSServerRequest1 req1;
1113 } drsuapi_DsRemoveDSServerRequest;
1115 typedef struct {
1116 boolean32 last_dc_in_domain;
1117 } drsuapi_DsRemoveDSServerResult1;
1119 typedef [switch_type(int32)] union {
1120 [case(1)] drsuapi_DsRemoveDSServerResult1 res1;
1121 } drsuapi_DsRemoveDSServerResult;
1123 WERROR drsuapi_DsRemoveDSServer(
1124 [in] policy_handle *bind_handle,
1125 [in] int32 level,
1126 [in,ref,switch_is(level)] drsuapi_DsRemoveDSServerRequest *req,
1127 [out,ref] int32 *level_out,
1128 [out,ref,switch_is(*level_out)] drsuapi_DsRemoveDSServerResult *res
1131 /*****************/
1132 /* Function 0x0f */
1133 [todo] WERROR DRSUAPI_REMOVE_DS_DOMAIN();
1135 /*****************/
1136 /* Function 0x10 */
1137 typedef struct {
1138 [charset(UTF16),string] uint16 *domain_name; /* netbios or dns */
1139 int32 level; /* specifies the switch level for the request */
1140 } drsuapi_DsGetDCInfoRequest1;
1142 typedef [switch_type(int32)] union {
1143 [case(1)] drsuapi_DsGetDCInfoRequest1 req1;
1144 } drsuapi_DsGetDCInfoRequest;
1146 typedef struct {
1147 [charset(UTF16),string] uint16 *netbios_name;
1148 [charset(UTF16),string] uint16 *dns_name;
1149 [charset(UTF16),string] uint16 *site_name;
1150 [charset(UTF16),string] uint16 *computer_dn;
1151 [charset(UTF16),string] uint16 *server_dn;
1152 uint32 is_pdc;
1153 uint32 is_enabled;
1154 } drsuapi_DsGetDCInfo1;
1156 typedef struct {
1157 [range(0,10000)] uint32 count;
1158 [size_is(count)] drsuapi_DsGetDCInfo1 *array;
1159 } drsuapi_DsGetDCInfoCtr1;
1161 typedef struct {
1162 [charset(UTF16),string] uint16 *netbios_name;
1163 [charset(UTF16),string] uint16 *dns_name;
1164 [charset(UTF16),string] uint16 *site_name;
1165 [charset(UTF16),string] uint16 *site_dn;
1166 [charset(UTF16),string] uint16 *computer_dn;
1167 [charset(UTF16),string] uint16 *server_dn;
1168 [charset(UTF16),string] uint16 *ntds_dn;
1169 uint32 is_pdc;
1170 uint32 is_enabled;
1171 uint32 is_gc;
1172 GUID site_guid;
1173 GUID computer_guid;
1174 GUID server_guid;
1175 GUID ntds_guid;
1176 } drsuapi_DsGetDCInfo2;
1178 typedef struct {
1179 [range(0,10000)] uint32 count;
1180 [size_is(count)] drsuapi_DsGetDCInfo2 *array;
1181 } drsuapi_DsGetDCInfoCtr2;
1183 typedef struct {
1184 [charset(UTF16),string] uint16 *netbios_name;
1185 [charset(UTF16),string] uint16 *dns_name;
1186 [charset(UTF16),string] uint16 *site_name;
1187 [charset(UTF16),string] uint16 *site_dn;
1188 [charset(UTF16),string] uint16 *computer_dn;
1189 [charset(UTF16),string] uint16 *server_dn;
1190 [charset(UTF16),string] uint16 *ntds_dn;
1191 uint32 is_pdc;
1192 uint32 is_enabled;
1193 uint32 is_gc;
1194 uint32 is_rodc;
1195 GUID site_guid;
1196 GUID computer_guid;
1197 GUID server_guid;
1198 GUID ntds_guid;
1199 } drsuapi_DsGetDCInfo3;
1201 typedef struct {
1202 [range(0,10000)] uint32 count;
1203 [size_is(count)] drsuapi_DsGetDCInfo3 *array;
1204 } drsuapi_DsGetDCInfoCtr3;
1207 * this represents an active connection to the
1208 * Directory System Agent (DSA)
1209 * this can be via LDAP or DRSUAPI
1211 typedef struct {
1212 [flag(NDR_BIG_ENDIAN)] ipv4address client_ip_address;
1213 uint32 unknown2;
1214 uint32 connection_time; /* in seconds */
1215 uint32 unknown4;
1216 uint32 unknown5;
1217 uint32 unknown6;
1219 * client_account can be the following:
1220 * "W2K3\Administrator"
1221 * "Administrator@W2K3"
1222 * "cn=Administrator,cn=Users,DC=w2k3,DC=vmnet1,DC=vm,DC=base"
1223 * ""
1224 * or NULL
1226 [charset(UTF16),string] uint16 *client_account;
1227 } drsuapi_DsGetDCConnection01;
1229 typedef struct {
1230 [range(0,10000)] uint32 count;
1231 [size_is(count)] drsuapi_DsGetDCConnection01 *array;
1232 } drsuapi_DsGetDCConnectionCtr01;
1234 typedef [v1_enum] enum {
1235 DRSUAPI_DC_INFO_CTR_1 = 1,
1236 DRSUAPI_DC_INFO_CTR_2 = 2,
1237 DRSUAPI_DC_INFO_CTR_3 = 3,
1238 DRSUAPI_DC_CONNECTION_CTR_01 = -1
1239 } drsuapi_DsGetDCInfoCtrLevels;
1241 typedef [switch_type(int32)] union {
1242 [case(DRSUAPI_DC_INFO_CTR_1)] drsuapi_DsGetDCInfoCtr1 ctr1;
1243 [case(DRSUAPI_DC_INFO_CTR_2)] drsuapi_DsGetDCInfoCtr2 ctr2;
1244 [case(DRSUAPI_DC_INFO_CTR_3)] drsuapi_DsGetDCInfoCtr3 ctr3;
1245 [case(DRSUAPI_DC_CONNECTION_CTR_01)] drsuapi_DsGetDCConnectionCtr01 ctr01;
1246 } drsuapi_DsGetDCInfoCtr;
1248 WERROR drsuapi_DsGetDomainControllerInfo(
1249 [in] policy_handle *bind_handle,
1250 [in] int32 level,
1251 [in,ref,switch_is(level)] drsuapi_DsGetDCInfoRequest *req,
1252 [out,ref] int32 *level_out,
1253 [out,ref,switch_is(*level_out)] drsuapi_DsGetDCInfoCtr *ctr
1256 /*****************/
1257 /* Function 0x11 */
1258 typedef [public,noprint] struct {
1259 drsuapi_DsReplicaObjectListItem *next_object;
1260 drsuapi_DsReplicaObject object;
1261 } drsuapi_DsReplicaObjectListItem;
1264 * The DsAddEntry() call which creates a nTDSDSA object,
1265 * also adds a servicePrincipalName in the following form
1266 * to the computer account of the new domain controller
1267 * referenced by the "serverReferenece" attribute.
1269 * E3514235-4B06-11D1-AB04-00C04FC2DCD2/<new-ntdsdsa-object-guid-as-string>/<domain-dns-name>
1271 * also note that the "serverReference" isn't added to the new object!
1273 const char *DRSUAPI_NTDSDSA_KRB5_SERVICE_GUID = "E3514235-4B06-11D1-AB04-00C04FC2DCD2";
1276 * please note the the current idl
1277 * for DsAddEntry does only parse
1278 * what I saw between 2 w2k3 boxes
1279 * in my dssync experiments I got some other replies
1280 * so all I want to say is that this is very incomplete yet...
1281 * --metze
1283 typedef struct {
1284 drsuapi_DsReplicaObjectListItem first_object;
1285 } drsuapi_DsAddEntryRequest2;
1287 typedef [switch_type(int32)] union {
1288 [case(2)] drsuapi_DsAddEntryRequest2 req2;
1289 } drsuapi_DsAddEntryRequest;
1291 typedef struct {
1292 uint32 unknown1;
1293 WERROR status;
1294 uint32 unknown2;
1295 uint16 unknown3;
1296 } drsuapi_DsAddEntryErrorInfoX;
1298 typedef struct {
1299 [range(0,10485760)] uint32 size;
1300 [size_is(size)] uint8 *data;
1301 } drsuapi_DsAddEntryExtraErrorBuffer;
1303 typedef struct {
1304 drsuapi_DsAddEntryErrorInfoX error;
1305 drsuapi_DsAttributeId attid;
1306 uint32 unknown2;
1307 drsuapi_DsAddEntryExtraErrorBuffer buffer;
1308 } drsuapi_DsAddEntryExtraError1;
1310 typedef /*[noprint]*/ struct {
1311 drsuapi_DsAddEntryErrorListItem1 *next;
1312 drsuapi_DsAddEntryExtraError1 error;
1313 } drsuapi_DsAddEntryErrorListItem1;
1315 typedef struct {
1316 drsuapi_DsReplicaObjectIdentifier *id;
1317 WERROR status;
1318 drsuapi_DsAddEntryErrorListItem1 first;
1319 } drsuapi_DsAddEntryErrorInfo1;
1321 typedef [switch_type(uint32)] union {
1322 [case(1)] drsuapi_DsAddEntryErrorInfo1 error1;
1323 /* [case(2)] drsuapi_DsAddEntryErrorInfo2 error2;
1324 [case(3)] drsuapi_DsAddEntryErrorInfo3 error3;
1325 */ [case(4)] drsuapi_DsAddEntryErrorInfoX errorX;
1326 [case(5)] drsuapi_DsAddEntryErrorInfoX errorX;
1327 [case(6)] drsuapi_DsAddEntryErrorInfoX errorX;
1328 [case(7)] drsuapi_DsAddEntryErrorInfoX errorX;
1329 } drsuapi_DsAddEntryErrorInfo;
1331 typedef struct {
1332 WERROR status;
1333 uint32 level;
1334 [switch_is(level)] drsuapi_DsAddEntryErrorInfo *info;
1335 } drsuapi_DsAddEntryError1;
1337 typedef [switch_type(uint32)] union {
1338 [case(1)] drsuapi_DsAddEntryError1 info1;
1339 } drsuapi_DsAddEntryError;
1341 typedef struct {
1342 GUID guid;
1343 dom_sid28 sid;
1344 } drsuapi_DsReplicaObjectIdentifier2;
1346 typedef struct {
1347 drsuapi_DsReplicaObjectIdentifier *id;
1348 uint32 unknown1;
1349 drsuapi_DsAddEntryErrorInfoX error;
1350 [range(0,10000)] uint32 count;
1351 [size_is(count)] drsuapi_DsReplicaObjectIdentifier2 *objects;
1352 } drsuapi_DsAddEntryCtr2;
1354 typedef struct {
1355 drsuapi_DsReplicaObjectIdentifier *id;
1356 uint32 level;
1357 [switch_is(level)] drsuapi_DsAddEntryError *error;
1358 [range(0,10000)] uint32 count;
1359 [size_is(count)] drsuapi_DsReplicaObjectIdentifier2 *objects;
1360 } drsuapi_DsAddEntryCtr3;
1362 typedef [switch_type(int32)] union {
1363 [case(2)] drsuapi_DsAddEntryCtr2 ctr2;
1364 [case(3)] drsuapi_DsAddEntryCtr3 ctr3;
1365 } drsuapi_DsAddEntryCtr;
1367 [public] WERROR drsuapi_DsAddEntry(
1368 [in] policy_handle *bind_handle,
1369 [in] int32 level,
1370 [in,ref,switch_is(level)] drsuapi_DsAddEntryRequest *req,
1371 [out,ref] int32 *level_out,
1372 [out,ref,switch_is(*level_out)] drsuapi_DsAddEntryCtr *ctr
1375 /*****************/
1376 /* Function 0x12 */
1377 typedef bitmap {
1378 DRSUAPI_DS_EXECUTE_KCC_ASYNCHRONOUS_OPERATION = 0x00000001,
1379 DRSUAPI_DS_EXECUTE_KCC_DAMPED = 0x00000002
1380 } drsuapi_DsExecuteKCCFlags;
1382 typedef struct {
1383 uint32 taskID;
1384 drsuapi_DsExecuteKCCFlags flags;
1385 } drsuapi_DsExecuteKCC1;
1387 typedef [switch_type(uint32)] union {
1388 [case(1)] drsuapi_DsExecuteKCC1 ctr1;
1389 } drsuapi_DsExecuteKCCRequest;
1391 WERROR drsuapi_DsExecuteKCC(
1392 [in] policy_handle *bind_handle,
1393 [in] uint32 level,
1394 [in, ref, switch_is(level)] drsuapi_DsExecuteKCCRequest *req
1397 /*****************/
1398 /* Function 0x13 */
1399 typedef [v1_enum] enum {
1400 DRSUAPI_DS_REPLICA_GET_INFO = 1,
1401 DRSUAPI_DS_REPLICA_GET_INFO2 = 2
1402 } drsuapi_DsReplicaGetInfoLevel;
1404 typedef [v1_enum] enum {
1405 DRSUAPI_DS_REPLICA_INFO_NEIGHBORS = 0,
1406 DRSUAPI_DS_REPLICA_INFO_CURSORS = 1,
1407 DRSUAPI_DS_REPLICA_INFO_OBJ_METADATA = 2,
1408 DRSUAPI_DS_REPLICA_INFO_KCC_DSA_CONNECT_FAILURES = 3,
1409 DRSUAPI_DS_REPLICA_INFO_KCC_DSA_LINK_FAILURES = 4,
1410 DRSUAPI_DS_REPLICA_INFO_PENDING_OPS = 5,
1411 DRSUAPI_DS_REPLICA_INFO_ATTRIBUTE_VALUE_METADATA = 6,
1412 DRSUAPI_DS_REPLICA_INFO_CURSORS2 = 7,
1413 DRSUAPI_DS_REPLICA_INFO_CURSORS3 = 8,
1414 DRSUAPI_DS_REPLICA_INFO_OBJ_METADATA2 = 9,
1415 DRSUAPI_DS_REPLICA_INFO_ATTRIBUTE_VALUE_METADATA2 = 10,
1416 DRSUAPI_DS_REPLICA_INFO_NEIGHBORS02 = -2,
1417 DRSUAPI_DS_REPLICA_INFO_CONNECTIONS04 = -4,
1418 DRSUAPI_DS_REPLICA_INFO_CURSORS05 = -5,
1419 DRSUAPI_DS_REPLICA_INFO_06 = -6
1420 } drsuapi_DsReplicaInfoType;
1422 typedef struct {
1423 drsuapi_DsReplicaInfoType info_type;
1424 [charset(UTF16),string] uint16 *object_dn;
1425 GUID guid1;
1426 } drsuapi_DsReplicaGetInfoRequest1;
1428 typedef struct {
1429 drsuapi_DsReplicaInfoType info_type;
1430 [charset(UTF16),string] uint16 *object_dn;
1431 GUID guid1;
1432 uint32 unknown1;
1433 [charset(UTF16),string] uint16 *string1;
1434 [charset(UTF16),string] uint16 *string2;
1435 uint32 unknown2;
1436 } drsuapi_DsReplicaGetInfoRequest2;
1438 typedef [switch_type(drsuapi_DsReplicaGetInfoLevel)] union {
1439 [case(DRSUAPI_DS_REPLICA_GET_INFO)] drsuapi_DsReplicaGetInfoRequest1 req1;
1440 [case(DRSUAPI_DS_REPLICA_GET_INFO2)] drsuapi_DsReplicaGetInfoRequest2 req2;
1441 } drsuapi_DsReplicaGetInfoRequest;
1443 typedef struct {
1444 [charset(UTF16),string] uint16 *naming_context_dn;
1445 [charset(UTF16),string] uint16 *source_dsa_obj_dn;
1446 [charset(UTF16),string] uint16 *source_dsa_address;
1447 [charset(UTF16),string] uint16 *transport_obj_dn;
1448 drsuapi_DsReplicaNeighbourFlags replica_flags;
1449 uint32 reserved;
1450 GUID naming_context_obj_guid;
1451 GUID source_dsa_obj_guid;
1452 GUID source_dsa_invocation_id;
1453 GUID transport_obj_guid;
1454 hyper tmp_highest_usn;
1455 hyper highest_usn;
1456 NTTIME last_success;
1457 NTTIME last_attempt;
1458 WERROR result_last_attempt;
1459 uint32 consecutive_sync_failures;
1460 } drsuapi_DsReplicaNeighbour;
1462 typedef struct {
1463 uint32 count;
1464 uint32 reserved;
1465 [size_is(count)] drsuapi_DsReplicaNeighbour array[];
1466 } drsuapi_DsReplicaNeighbourCtr;
1468 typedef struct {
1469 uint32 count;
1470 uint32 reserved;
1471 [size_is(count)] drsuapi_DsReplicaCursor array[];
1472 } drsuapi_DsReplicaCursorCtr;
1474 typedef struct {
1475 [charset(UTF16),string] uint16 *attribute_name;
1476 uint32 version;
1477 NTTIME originating_change_time;
1478 GUID originating_invocation_id;
1479 hyper originating_usn;
1480 hyper local_usn;
1481 } drsuapi_DsReplicaObjMetaData;
1483 typedef struct {
1484 uint32 count;
1485 uint32 reserved;
1486 [size_is(count)] drsuapi_DsReplicaObjMetaData array[];
1487 } drsuapi_DsReplicaObjMetaDataCtr;
1489 typedef struct {
1490 [charset(UTF16),string] uint16 *dsa_obj_dn;
1491 GUID dsa_obj_guid;
1492 NTTIME first_failure;
1493 uint32 num_failures;
1494 WERROR last_result;
1495 } drsuapi_DsReplicaKccDsaFailure;
1497 typedef struct {
1498 uint32 count;
1499 uint32 reserved;
1500 [size_is(count)] drsuapi_DsReplicaKccDsaFailure array[];
1501 } drsuapi_DsReplicaKccDsaFailuresCtr;
1503 typedef enum {
1504 DRSUAPI_DS_REPLICA_OP_TYPE_SYNC = 0,
1505 DRSUAPI_DS_REPLICA_OP_TYPE_ADD = 1,
1506 DRSUAPI_DS_REPLICA_OP_TYPE_DELETE = 2,
1507 DRSUAPI_DS_REPLICA_OP_TYPE_MODIFY = 3,
1508 DRSUAPI_DS_REPLICA_OP_TYPE_UPDATE_REFS = 4
1509 } drsuapi_DsReplicaOpType;
1511 typedef [switch_type(drsuapi_DsReplicaOpType)] union {
1512 [case(DRSUAPI_DS_REPLICA_OP_TYPE_SYNC)] drsuapi_DsReplicaSyncOptions sync;
1513 [case(DRSUAPI_DS_REPLICA_OP_TYPE_ADD)] drsuapi_DsReplicaAddOptions add;
1514 [case(DRSUAPI_DS_REPLICA_OP_TYPE_DELETE)] drsuapi_DsReplicaDeleteOptions op_delete;
1515 [case(DRSUAPI_DS_REPLICA_OP_TYPE_MODIFY)] drsuapi_DsReplicaModifyOptions modify;
1516 [case(DRSUAPI_DS_REPLICA_OP_TYPE_UPDATE_REFS)] drsuapi_DsReplicaUpdateRefsOptions update_refs;
1517 [default] uint32 unknown;
1518 } drsuapi_DsRplicaOpOptions;
1520 typedef struct {
1521 NTTIME operation_start;
1522 uint32 serial_num; /* unique till reboot */
1523 uint32 priority;
1524 drsuapi_DsReplicaOpType operation_type;
1525 [switch_is(operation_type)] drsuapi_DsRplicaOpOptions options;
1526 [charset(UTF16),string] uint16 *nc_dn;
1527 [charset(UTF16),string] uint16 *remote_dsa_obj_dn;
1528 [charset(UTF16),string] uint16 *remote_dsa_address;
1529 GUID nc_obj_guid;
1530 GUID remote_dsa_obj_guid;
1531 } drsuapi_DsReplicaOp;
1533 typedef struct {
1534 NTTIME time;
1535 uint32 count;
1536 [size_is(count)] drsuapi_DsReplicaOp array[];
1537 } drsuapi_DsReplicaOpCtr;
1539 typedef struct {
1540 [charset(UTF16),string] uint16 *attribute_name;
1541 [charset(UTF16),string] uint16 *object_dn;
1542 [value(ndr_size_DATA_BLOB(0,binary,0))] uint32 __ndr_size_binary;
1543 DATA_BLOB *binary;
1544 NTTIME deleted;
1545 NTTIME created;
1546 uint32 version;
1547 NTTIME originating_change_time;
1548 GUID originating_invocation_id;
1549 hyper originating_usn;
1550 hyper local_usn;
1551 } drsuapi_DsReplicaAttrValMetaData;
1553 typedef struct {
1554 uint32 count;
1555 int32 enumeration_context;
1556 [size_is(count)] drsuapi_DsReplicaAttrValMetaData array[];
1557 } drsuapi_DsReplicaAttrValMetaDataCtr;
1559 typedef struct {
1560 uint32 count;
1561 int32 enumeration_context;
1562 [size_is(count)] drsuapi_DsReplicaCursor2 array[];
1563 } drsuapi_DsReplicaCursor2Ctr;
1565 typedef struct {
1566 GUID source_dsa_invocation_id;
1567 hyper highest_usn;
1568 NTTIME last_sync_success;
1569 [charset(UTF16),string] uint16 *source_dsa_obj_dn;
1570 } drsuapi_DsReplicaCursor3;
1572 typedef struct {
1573 uint32 count;
1574 int32 enumeration_context;
1575 [size_is(count)] drsuapi_DsReplicaCursor3 array[];
1576 } drsuapi_DsReplicaCursor3Ctr;
1578 typedef struct {
1579 [charset(UTF16),string] uint16 *attribute_name;
1580 uint32 version;
1581 NTTIME originating_change_time;
1582 GUID originating_invocation_id;
1583 hyper originating_usn;
1584 hyper local_usn;
1585 [charset(UTF16),string] uint16 *originating_dsa_dn;
1586 } drsuapi_DsReplicaObjMetaData2;
1588 typedef struct {
1589 uint32 count;
1590 int32 enumeration_context;
1591 [size_is(count)] drsuapi_DsReplicaObjMetaData2 array[];
1592 } drsuapi_DsReplicaObjMetaData2Ctr;
1594 typedef struct {
1595 [charset(UTF16),string] uint16 *attribute_name;
1596 [charset(UTF16),string] uint16 *object_dn;
1597 [value(ndr_size_DATA_BLOB(0,binary,0))] uint32 __ndr_size_binary;
1598 DATA_BLOB *binary;
1599 NTTIME deleted;
1600 NTTIME created;
1601 uint32 version;
1602 NTTIME originating_change_time;
1603 GUID originating_invocation_id;
1604 hyper originating_usn;
1605 hyper local_usn;
1606 [charset(UTF16),string] uint16 *originating_dsa_dn;
1607 } drsuapi_DsReplicaAttrValMetaData2;
1609 typedef struct {
1610 uint32 count;
1611 int32 enumeration_context;
1612 [size_is(count)] drsuapi_DsReplicaAttrValMetaData2 array[];
1613 } drsuapi_DsReplicaAttrValMetaData2Ctr;
1615 typedef struct {
1616 hyper u1; /* session number? */
1617 uint32 u2;
1618 uint32 u3;
1619 GUID bind_guid;
1620 NTTIME_1sec bind_time;
1621 [flag(NDR_BIG_ENDIAN)] ipv4address client_ip_address;
1622 uint32 u5; /* this is the same value the client used as pid in the DsBindInfoX struct */
1623 } drsuapi_DsReplicaConnection04;
1625 typedef struct {
1626 [range(0,10000)] uint32 count;
1627 uint32 reserved;
1628 [size_is(count)] drsuapi_DsReplicaConnection04 array[];
1629 } drsuapi_DsReplicaConnection04Ctr;
1631 typedef struct {
1632 [charset(UTF16),string] uint16 *str1;
1633 uint32 u1;
1634 uint32 u2;
1635 uint32 u3;
1636 uint32 u4;
1637 uint32 u5;
1638 hyper u6;
1639 uint32 u7;
1640 } drsuapi_DsReplica06;
1642 typedef struct {
1643 [range(0,256)] uint32 count;
1644 uint32 reserved;
1645 [size_is(count)] drsuapi_DsReplica06 array[];
1646 } drsuapi_DsReplica06Ctr;
1648 typedef [switch_type(drsuapi_DsReplicaInfoType)] union {
1649 [case(DRSUAPI_DS_REPLICA_INFO_NEIGHBORS)] drsuapi_DsReplicaNeighbourCtr *neighbours;
1650 [case(DRSUAPI_DS_REPLICA_INFO_CURSORS)] drsuapi_DsReplicaCursorCtr *cursors;
1651 [case(DRSUAPI_DS_REPLICA_INFO_OBJ_METADATA)] drsuapi_DsReplicaObjMetaDataCtr *objmetadata;
1652 [case(DRSUAPI_DS_REPLICA_INFO_KCC_DSA_CONNECT_FAILURES)] drsuapi_DsReplicaKccDsaFailuresCtr *connectfailures;
1653 [case(DRSUAPI_DS_REPLICA_INFO_KCC_DSA_LINK_FAILURES)] drsuapi_DsReplicaKccDsaFailuresCtr *linkfailures;
1654 [case(DRSUAPI_DS_REPLICA_INFO_PENDING_OPS)] drsuapi_DsReplicaOpCtr *pendingops;
1655 [case(DRSUAPI_DS_REPLICA_INFO_ATTRIBUTE_VALUE_METADATA)] drsuapi_DsReplicaAttrValMetaDataCtr *attrvalmetadata;
1656 [case(DRSUAPI_DS_REPLICA_INFO_CURSORS2)] drsuapi_DsReplicaCursor2Ctr *cursors2;
1657 [case(DRSUAPI_DS_REPLICA_INFO_CURSORS3)] drsuapi_DsReplicaCursor3Ctr *cursors3;
1658 [case(DRSUAPI_DS_REPLICA_INFO_OBJ_METADATA2)] drsuapi_DsReplicaObjMetaData2Ctr *objmetadata2;
1659 [case(DRSUAPI_DS_REPLICA_INFO_ATTRIBUTE_VALUE_METADATA2)] drsuapi_DsReplicaAttrValMetaData2Ctr *attrvalmetadata2;
1660 [case(DRSUAPI_DS_REPLICA_INFO_NEIGHBORS02)] drsuapi_DsReplicaNeighbourCtr *neighbours02;
1661 [case(DRSUAPI_DS_REPLICA_INFO_CONNECTIONS04)] drsuapi_DsReplicaConnection04Ctr *connections04;
1662 [case(DRSUAPI_DS_REPLICA_INFO_CURSORS05)] drsuapi_DsReplicaCursorCtrEx *cursors05;
1663 [case(DRSUAPI_DS_REPLICA_INFO_06)] drsuapi_DsReplica06Ctr *i06;
1664 } drsuapi_DsReplicaInfo;
1666 WERROR drsuapi_DsReplicaGetInfo(
1667 [in] policy_handle *bind_handle,
1668 [in] drsuapi_DsReplicaGetInfoLevel level,
1669 [in,ref,switch_is(level)] drsuapi_DsReplicaGetInfoRequest *req,
1670 [out,ref] drsuapi_DsReplicaInfoType *info_type,
1671 [out,ref,switch_is(*info_type)] drsuapi_DsReplicaInfo *info
1674 /*****************/
1675 /* Function 0x14 */
1676 [todo] WERROR DRSUAPI_ADD_SID_HISTORY();
1678 /*****************/
1679 /* Function 0x15 */
1681 typedef struct {
1682 [range(0,10000)] uint32 num_entries;
1683 [size_is(num_entries)] drsuapi_DsGetMembershipsCtr1 **ctrl_array;
1684 } drsuapi_DsGetMemberships2Ctr1;
1686 typedef [switch_type(int32)] union {
1687 [case(1)] drsuapi_DsGetMembershipsCtr1 ctr1;
1688 } drsuapi_DsGetMemberships2Ctr;
1690 typedef struct {
1691 [range(1,10000)] uint32 num_req;
1692 [size_is(num_req)] drsuapi_DsGetMembershipsRequest1 **req_array;
1693 } drsuapi_DsGetMemberships2Request1;
1695 typedef [switch_type(int32)] union {
1696 [case(1)] drsuapi_DsGetMemberships2Request1 req1;
1697 } drsuapi_DsGetMemberships2Request;
1699 WERROR drsuapi_DsGetMemberships2(
1700 [in] policy_handle *bind_handle,
1701 [in] int32 level,
1702 [in,ref] [switch_is(level)] drsuapi_DsGetMemberships2Request *req,
1703 [out,ref] int32 *level_out,
1704 [out,ref] [switch_is(*level_out)] drsuapi_DsGetMemberships2Ctr *ctr
1707 /*****************/
1708 /* Function 0x16 */
1709 [todo] WERROR DRSUAPI_REPLICA_VERIFY_OBJECTS();
1711 /*****************/
1712 /* Function 0x17 */
1713 [todo] WERROR DRSUAPI_GET_OBJECT_EXISTENCE();
1715 /*****************/
1716 /* Function 0x18 */
1717 typedef struct {
1718 WERROR error_code;
1719 uint32 site_cost;
1720 } drsuapi_DsSiteCostInfo;
1722 typedef struct {
1723 [range(0,10000)] uint32 num_info;
1724 [size_is(num_info)] drsuapi_DsSiteCostInfo *info;
1725 uint32 unknown;
1726 } drsuapi_QuerySitesByCostCtr1;
1728 typedef [switch_type(int32)] union {
1729 [case(1)] drsuapi_QuerySitesByCostCtr1 ctr1;
1730 } drsuapi_QuerySitesByCostCtr;
1732 typedef struct {
1733 [charset(UTF16),string] uint16 *site_from;
1734 [range(1,10000)] uint32 num_req;
1735 [size_is(num_req)] [charset(UTF16),string] uint16 **site_to;
1736 uint32 flags;
1737 } drsuapi_QuerySitesByCostRequest1;
1739 typedef [switch_type(int32)] union {
1740 [case(1)] drsuapi_QuerySitesByCostRequest1 req1;
1741 } drsuapi_QuerySitesByCostRequest;
1743 WERROR drsuapi_QuerySitesByCost(
1744 [in] policy_handle *bind_handle,
1745 [in] int32 level,
1746 [in,ref] [switch_is(level)] drsuapi_QuerySitesByCostRequest *req,
1747 [out,ref] int32 *level_out,
1748 [out,ref] [switch_is(*level_out)] drsuapi_QuerySitesByCostCtr *ctr