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