r8480: fixed a typo
[samba.git] / source4 / librpc / idl / drsuapi.idl
index 8a6a96dcacfe5707c19e72d19ff27e7e354c2bbf..1eaa242ff0cf14c7b47346fd55e783b9fce9c7fe 100644 (file)
@@ -6,7 +6,9 @@
   endpoint("ncacn_np:[\\pipe\\lsass]","ncacn_np:[\\pipe\\protected_storage]", "ncacn_ip_tcp:", "ncalrpc:"),
   authservice("ldap"),
   helpstring("Active Directory Replication"),
-  pointer_default(unique)
+  pointer_default(unique),
+  pointer_default_top(unique),
+  depends(security)
 ] 
 interface drsuapi
 {
@@ -113,15 +115,15 @@ interface drsuapi
 
        /*****************/
        /* Function 0x02 */
-       typedef [gensize,flag(NDR_PAHEX)] struct {
-               [value(ndr_size_drsuapi_DsReplicaSyncRequest1Info(r, ndr->flags)-4)] uint32 __ndr_size;
-               uint32 unknown1;
-               GUID guid1;
-               uint8 byte_array[28];
-               [flag(STR_SIZE4|STR_CHARLEN|STR_CONFORMANT)] string nc_dn;
-       } drsuapi_DsReplicaSyncRequest1Info;
-
-       typedef bitmap {
+       typedef [gensize] struct {
+               [value(ndr_size_drsuapi_DsReplicaObjectIdentifier(r, ndr->flags)-4)] uint32 __ndr_size;
+               /*[value(ndr_length_dom_sid(&r->sid))]*/  uint32 __ndr_size_sid;
+               GUID guid;
+               dom_sid28 sid;
+               [flag(STR_SIZE4|STR_CHARLEN|STR_CONFORMANT)] string dn;
+       } drsuapi_DsReplicaObjectIdentifier;
+
+       typedef [public] bitmap {
                DRSUAPI_DS_REPLICA_SYNC_ASYNCHRONOUS_OPERATION  = 0x00000001,
                DRSUAPI_DS_REPLICA_SYNC_WRITEABLE               = 0x00000002,
                DRSUAPI_DS_REPLICA_SYNC_PERIODIC                = 0x00000004,
@@ -149,7 +151,7 @@ interface drsuapi
        } drsuapi_DsReplicaSyncOptions;
 
        typedef struct {
-               drsuapi_DsReplicaSyncRequest1Info *info;
+               drsuapi_DsReplicaObjectIdentifier *naming_context;
                GUID guid1;
                astring *string1;
                drsuapi_DsReplicaSyncOptions options;
@@ -167,28 +169,467 @@ interface drsuapi
 
        /*****************/
        /* Function 0x03 */
+       typedef [public] struct {
+               hyper tmp_highest_usn; /* updated after each object update */
+               hyper reserved_usn;
+               hyper highest_usn; /* updated after a full replication cycle */
+       } drsuapi_DsReplicaHighWaterMark;
+
+       typedef [public] struct {
+               GUID source_dsa_invocation_id; /* the 'invocationId' field of the CN=NTDS Settings object */
+               hyper highest_usn;  /* updated after a full replication cycle */
+       } drsuapi_DsReplicaCoursor;
+
+       typedef struct {
+               uint32 u1;
+               uint32 u2;
+               [range(0,0x100000)] uint32 count;
+               uint32 u3;
+               [size_is(count)] drsuapi_DsReplicaCoursor coursors[];
+       } drsuapi_DsReplicaCoursorCtrEx;
+
+       typedef [public] bitmap {
+               /* the _WRITEABLE flag seems to indicate a replication with all attributes,
+                * and I'm currently always on error when it's set, but w2k and w2k3 uses it
+                * in the dc join
+                * --metze
+                */
+               DRSUAPI_DS_REPLICA_NEIGHBOUR_WRITEABLE                          = 0x00000010,
+               DRSUAPI_DS_REPLICA_NEIGHBOUR_SYNC_ON_STARTUP                    = 0x00000020,
+               DRSUAPI_DS_REPLICA_NEIGHBOUR_DO_SCHEDULED_SYNCS                 = 0x00000040,
+               DRSUAPI_DS_REPLICA_NEIGHBOUR_USE_ASYNC_INTERSIDE_TRANSPORT      = 0x00000080,
+               DRSUAPI_DS_REPLICA_NEIGHBOUR_TWO_WAY_SYNC                       = 0x00000200,
+               DRSUAPI_DS_REPLICA_NEIGHBOUR_RETURN_OBJECT_PARENTS              = 0x00000800,
+               DRSUAPI_DS_REPLICA_NEIGHBOUR_FULL_IN_PROGRESS                   = 0x00010000,
+               DRSUAPI_DS_REPLICA_NEIGHBOUR_FULL_NEXT_PACKET                   = 0x00020000,
+               DRSUAPI_DS_REPLICA_NEIGHBOUR_NEVER_SYNCED                       = 0x00200000,
+               DRSUAPI_DS_REPLICA_NEIGHBOUR_PREEMPTED                          = 0x01000000,
+               DRSUAPI_DS_REPLICA_NEIGHBOUR_IGNORE_CHANGE_NOTIFICATIONS        = 0x04000000,
+               DRSUAPI_DS_REPLICA_NEIGHBOUR_DISABLE_SCHEDULED_SYNC             = 0x08000000,
+               /* 
+                * the following NOTE applies to DsGetNCChangesRequest5:
+                *  - the data is only compressed when 10 or more objects are replicated
+                *  - but there could also be a size limit of 35 KBytes or something like that
+                *  - the reply is DsGetNCChangesCtr2
+                *  - maybe the same applies to DsGetNCChangesRequest8...
+                *
+                *  --metze
+                */
+               DRSUAPI_DS_REPLICA_NEIGHBOUR_COMPRESS_CHANGES                   = 0x10000000,
+               DRSUAPI_DS_REPLICA_NEIGHBOUR_NO_CHANGE_NOTIFICATIONS            = 0x20000000,
+               DRSUAPI_DS_REPLICA_NEIGHBOUR_PARTIAL_ATTRIBUTE_SET              = 0x40000000
+       } drsuapi_DsReplicaNeighbourFlags;
+
        typedef struct {
-               hyper usn1;
-               hyper usn2;
-               hyper usn3;
-       } drsuapi_DsGetNCChangesUsnTriple;
+               GUID destination_dsa_guid;
+               GUID source_dsa_guid;
+               [ref] drsuapi_DsReplicaObjectIdentifier *naming_context;
+               drsuapi_DsReplicaHighWaterMark highwatermark;
+               drsuapi_DsReplicaCoursorCtrEx *uptodateness_vector;
+               drsuapi_DsReplicaNeighbourFlags replica_flags;
+               uint32 unknown2;
+               uint32 unknown3;
+               uint32 unknown4;
+               hyper h1;
+       } drsuapi_DsGetNCChangesRequest5;
+
+       typedef [flag(NDR_PAHEX)] struct {
+               [range(0,10000)] uint32 length;
+               [size_is(length)] uint8 *byte_array;
+       } drsuapi_DsGetNCChangesRequest_Ctr14;
 
        typedef struct {
-               GUID guid1;
-               GUID guid2;
-               uint32 unknown1[20];
-               drsuapi_DsReplicaSyncRequest1Info sync_req_info1;
-               drsuapi_DsGetNCChangesUsnTriple usn;
+               uint32 unknown1;
+               drsuapi_DsGetNCChangesRequest_Ctr14 data;
+       } drsuapi_DsGetNCChangesRequest_Ctr13;
+
+       typedef struct {
+               [range(0,0x100000)] uint32 count;
+               [size_is(count)] drsuapi_DsGetNCChangesRequest_Ctr13 *array;
+       } drsuapi_DsGetNCChangesRequest_Ctr12;
+
+       typedef struct {
+               GUID destination_dsa_guid;
+               GUID source_dsa_guid;
+               [ref] drsuapi_DsReplicaObjectIdentifier *naming_context;
+               drsuapi_DsReplicaHighWaterMark highwatermark;
+               drsuapi_DsReplicaCoursorCtrEx *uptodateness_vector;
+               drsuapi_DsReplicaNeighbourFlags replica_flags;
+               uint32 unknown2;
+               uint32 unknown3;
+               uint32 unknown4;
+               hyper h1;
+               uint32 unique_ptr1;
+               uint32 unique_ptr2;
+               drsuapi_DsGetNCChangesRequest_Ctr12 ctr12;
        } drsuapi_DsGetNCChangesRequest8;
 
        typedef [switch_type(int32)] union {
+               [case(5)] drsuapi_DsGetNCChangesRequest5 req5;
                [case(8)] drsuapi_DsGetNCChangesRequest8 req8;
        } drsuapi_DsGetNCChangesRequest;
 
+       typedef [public] struct {
+               GUID source_dsa_invocation_id; /* the 'invocationId' field of the CN=NTDS Settings object */
+               hyper highest_usn;  /* updated after a full replication cycle */
+               NTTIME last_sync_success;
+       } drsuapi_DsReplicaCoursor2;
+
+       typedef struct {
+               uint32 u1;
+               uint32 u2;
+               [range(0,0x100000)] uint32 count;
+               uint32 u3;
+               [size_is(count)] drsuapi_DsReplicaCoursor2 coursors[];
+       } drsuapi_DsReplicaCoursor2CtrEx;
+
+       /*
+        * In DRSUAPI the objectClasses and attributes
+        * are identified by uint32 values, but in the schema
+        * they are identified by the governsID (objectClasses)
+        * and attributeID (attributes)
+        *
+        * the following table shows the mapping used between the two representations
+        * e.g. - objectClass 'nTDSDSA' has governsID: 1.2.840.113556.1.5.7000.47
+        *        and a UINT32-ID of '0x0017002F'.
+        *      - so the OID 1.2.840.113556.1.5.7000.47 is splitted into a
+        *        OID-prefix: 1.2.840.113556.1.5.7000
+        *        and a value: 47 => 0x2F
+        *      - the mapping table gives a UINT32-prefix: 0x00170000
+        *      - and the UINT32-ID is 0x0017002F = 0x00170000 | 0x2F
+        *
+        * OID-prefix                   => UINT32-Id prefix
+        *
+        * 2.5.4.*                      => 0x00000000 (standard attributes RFC2256 core.schema)
+        * 2.5.6.*                      => 0x00010000 (standard object classes RFC2256 core.schema)
+        * 1.2.840.113556.1.2.*         => 0x00020000
+        * 1.2.840.113556.1.3.*         => 0x00030000
+        * 1.2.840.113556.1.4.*         => 0x00090000
+        * 1.2.840.113556.1.5.*         => 0x000A0000
+        * 2.16.840.1.113730.3.*        => 0x00140000
+        * 0.9.2342.19200300.100.1.*    => 0x00150000
+        * 2.16.840.1.113730.3.1.*      => 0x00160000
+        * 1.2.840.113556.1.5.7000.*    => 0x00170000
+        * 2.5.20.*                     => 0x001A0000
+        * 2.16.840.1.113730.3.2.*      => 0x001C0000
+        * 1.3.6.1.4.1.250.1.*          => 0x001D0000
+        * 0.9.2342.19200300.100.4.*    => 0x001F0000
+        *
+        * 1.2.840.113549.1.9.*         (unstructuredAddress,unstructuredName)
+        * 1.3.6.1.4.1.1466.101.119.2   (dynamicObject)
+        * 1.3.6.1.4.1.1466.101.119.3   (entryTTL)
+        * 2.5.18.*                     (createTimeStamp,modifyTimeStamp, SubSchema)            
+        * 2.5.21.*                     (attrs for SubSchema)
+        *
+        * Here's a list of used 'attributeSyntax' OID's
+        *
+        * 2.5.5.1      => Object(DS-DN) string
+        *                 struct drsuapi_DsObjectIdentifier3
+        *
+        * 2.5.5.2      => OID-string
+        *              => mayContain, mustContain... also have this syntax but have string values
+        *
+        * 2.5.5.4      => String(Teletex) case-insensitive string with teletex charset
+        *
+        * 2.5.5.5      => String(IA5) case-sensitive string
+        *
+        * 2.5.5.6      => String(Numeric)
+        *              => eg. internationalISDNNumber
+        *
+        * 2.5.5.7      => Object(DN-Binary) B:<byte count>:<bytes>:<object DN>
+        *              => e.g. wellKnownObjects
+        *
+        * 2.5.5.8      => BOOL
+        *
+        * 2.5.5.9      => int32
+        *
+        * 2.5.5.10     => DATA_BLOB
+        *              => struct GUID
+        *
+        * 2.5.5.11     => LDAP timestring
+        *              => NTTIME_1sec
+        *
+        * 2.5.5.12     => String(Unicode) case-insensitive string
+        *              => 'standard strings'
+        *
+        * 2.5.5.13     => Object(Presentation-Address) string
+        *              => used in objectClass applicationEntity
+        *
+        * 2.5.5.14     => Object(DN-String) S:<char count>:<string>:<object DN>
+        *              => not used
+        *
+        * 2.5.5.15     => ntSecurityDescriptor
+        *
+        * 2.5.5.16     => int64
+        *
+        * 2.5.5.17     => dom_sid
+        */
+
+       typedef [v1_enum] enum {
+               DRSUAPI_OBJECTCLASS_top                 = 0x00010000
+       } drsuapi_DsObjectClassId;
+
+       typedef [v1_enum,public] enum {
+               DRSUAPI_ATTRIBUTE_objectClass           = 0x00000000,
+               DRSUAPI_ATTRIBUTE_description           = 0x0000000d,
+               DRSUAPI_ATTRIBUTE_invocationId          = 0x00020073,
+               DRSUAPI_ATTRIBUTE_ntSecurityDescriptor  = 0x00020119,
+               DRSUAPI_ATTRIBUTE_objectSid             = 0x00090092,
+               DRSUAPI_ATTRIBUTE_dBCSPwd               = 0x00090037,/* lmPwdHash */
+               DRSUAPI_ATTRIBUTE_unicodePwd            = 0x0009005a,/* ntPwdHash */
+               DRSUAPI_ATTRIBUTE_ntPwdHistory          = 0x0009005e,
+               DRSUAPI_ATTRIBUTE_lmPwdHistory          = 0x000900a0,
+               DRSUAPI_ATTRIBUTE_objectCategory        = 0x0009030e
+               /* DRSUAPI_ATTRIBUTE_ */
+       } drsuapi_DsAttributeId;
+
+       /* Generic DATA_BLOB values */
+       typedef struct {
+               [range(0,10485760)] uint32 length;
+               DATA_BLOB *data;
+       } drsuapi_DsAttributeValueDataBlob;
+
+       typedef struct {
+               [range(0,10485760)] uint32 num_values;
+               [size_is(num_values)] drsuapi_DsAttributeValueDataBlob *values;
+       } drsuapi_DsAttributeValueCtrDataBlob;
+
+       /* objectClass values */
+       typedef struct {
+               [range(0,10485760)] uint32 length;
+               [subcontext(4)] drsuapi_DsObjectClassId *objectClassId;
+       } drsuapi_DsAttributeValueObjectClassId;
+
+       typedef struct {
+               [range(0,10485760)] uint32 num_values;
+               [size_is(num_values)] drsuapi_DsAttributeValueObjectClassId *values;
+       } drsuapi_DsAttributeValueCtrObjectClassId;
+
+       /* uint32 values */
+       typedef struct {
+               [range(0,10485760)] uint32 length;
+               [subcontext(4)] uint32 *value;
+       } drsuapi_DsAttributeValueUINT32;
+
+       typedef struct {
+               [range(0,10485760)] uint32 num_values;
+               [size_is(num_values)] drsuapi_DsAttributeValueUINT32 *values;
+       } drsuapi_DsAttributeValueCtrUINT32;
+
+       /* UnicodeString values */
+       typedef struct {
+               [range(0,10485760)] uint32 length;
+               [subcontext(4)] nstring *string;
+       } drsuapi_DsAttributeValueUnicodeString;
+
+       typedef struct {
+               [range(0,10485760)] uint32 num_values;
+               [size_is(num_values)] drsuapi_DsAttributeValueUnicodeString *values;
+       } drsuapi_DsAttributeValueCtrUnicodeString;
+
+       /* DN String values */
+       typedef [gensize] struct {
+               [value(ndr_size_drsuapi_DsReplicaObjectIdentifier3(r, ndr->flags)-4)] uint32 __ndr_size;
+               [value(ndr_length_dom_sid(&r->sid))]  uint32 __ndr_size_sid;
+               GUID guid;
+               dom_sid28 sid;
+               [flag(STR_SIZE4|STR_CHARLEN)] string dn;
+       } drsuapi_DsReplicaObjectIdentifier3;
+
+       typedef  struct {
+               [range(0,10485760)] uint32 length;
+               [subcontext(4)] drsuapi_DsReplicaObjectIdentifier3 *object;
+       } drsuapi_DsAttributeValueDNString;
+
+       typedef struct {
+               [range(0,10485760)] uint32 num_values;
+               [size_is(num_values)] drsuapi_DsAttributeValueDNString *values;
+       } drsuapi_DsAttributeValueCtrDNString;
+
+       /* GUID values */
+       typedef struct {
+               [range(0,10485760)] uint32 length;
+               [subcontext(4)] GUID *guid;
+       } drsuapi_DsAttributeValueGUID;
+
+       typedef struct {
+               [range(0,10485760)] uint32 num_values;
+               [size_is(num_values)] drsuapi_DsAttributeValueGUID *values;
+       } drsuapi_DsAttributeValueCtrGUID;
+
+       /* SID values */
+       typedef struct {
+               [range(0,10485760)] uint32 length;
+               [subcontext(4)] dom_sid *sid;
+       } drsuapi_DsAttributeValueSID;
+
        typedef struct {
+               [range(0,10485760)] uint32 num_values;
+               [size_is(num_values)] drsuapi_DsAttributeValueSID *values;
+       } drsuapi_DsAttributeValueCtrSID;
+
+       /* SecurityDescriptor values */
+       typedef struct {
+               [range(0,10485760)] uint32 length;
+               [subcontext(4)] security_descriptor *sd;
+       } drsuapi_DsAttributeValueSecurityDescriptor;
+
+       typedef struct {
+               [range(0,10485760)] uint32 num_values;
+               [size_is(num_values)] drsuapi_DsAttributeValueSecurityDescriptor *values;
+       } drsuapi_DsAttributeValueCtrSecurityDescriptor;
+
+       /* NTTIME_1sec values */
+       typedef struct {
+               [range(0,10485760)] uint32 length;
+               [subcontext(4)] NTTIME_1sec *time;
+       } drsuapi_DsAttributeValueNTTIME_1sec;
+
+       typedef struct {
+               [range(0,10485760)] uint32 num_values;
+               [size_is(num_values)] drsuapi_DsAttributeValueNTTIME_1sec *values;
+       } drsuapi_DsAttributeValueCtrNTTIME_1sec;
+
+       typedef [nodiscriminant] union {
+               [case(DRSUAPI_ATTRIBUTE_objectClass)] drsuapi_DsAttributeValueCtrObjectClassId object_class_id;
+
+               /* UINT32 */
+               [case(0x00020001)] drsuapi_DsAttributeValueCtrUINT32 uint32;
+               [case(0x0002004c)] drsuapi_DsAttributeValueCtrUINT32 uint32;
+               [case(0x000200a9)] drsuapi_DsAttributeValueCtrUINT32 uint32;
+               [case(0x00090177)] drsuapi_DsAttributeValueCtrUINT32 uint32;
+               [case(0x000905b3)] drsuapi_DsAttributeValueCtrUINT32 uint32;
+
+               /* GUID */
+               [case(DRSUAPI_ATTRIBUTE_invocationId)] drsuapi_DsAttributeValueCtrGUID guid;
+
+               /* SID */
+               [case(DRSUAPI_ATTRIBUTE_objectSid)] drsuapi_DsAttributeValueCtrSID sid;
+
+               /* SecurityDescriptor */
+               [case(DRSUAPI_ATTRIBUTE_ntSecurityDescriptor)] drsuapi_DsAttributeValueCtrSecurityDescriptor security_descriptor;
+
+               /* UnicodeString */
+               [case(DRSUAPI_ATTRIBUTE_description)]           drsuapi_DsAttributeValueCtrUnicodeString unicode_string;
+               [case(0x00090001)]                              drsuapi_DsAttributeValueCtrUnicodeString unicode_string;
+               [case(0x000900dd)]                              drsuapi_DsAttributeValueCtrUnicodeString unicode_string;
+               [case(0x0009037b)]                              drsuapi_DsAttributeValueCtrUnicodeString unicode_string;
+
+               /* DN String */
+               [case(DRSUAPI_ATTRIBUTE_objectCategory)]        drsuapi_DsAttributeValueCtrDNString dn_string;
+               [case(0x0002000e)]                              drsuapi_DsAttributeValueCtrDNString dn_string;
+               [case(0x00020024)]                              drsuapi_DsAttributeValueCtrDNString dn_string;
+               [case(0x00090171)]                              drsuapi_DsAttributeValueCtrDNString dn_string;
+               [case(0x0009071c)]                              drsuapi_DsAttributeValueCtrDNString dn_string;
+               [case(0x0009072c)]                              drsuapi_DsAttributeValueCtrDNString dn_string;
+               [case(0x0009026a)]                              drsuapi_DsAttributeValueCtrDNString dn_string;
+               [case(0x00090203)]                              drsuapi_DsAttributeValueCtrDNString dn_string;
+
+               /* NTTIME_1sec */
+               [case(0x00020002)] drsuapi_DsAttributeValueCtrNTTIME_1sec nttime_1sec;
+
+               /* the default is the DATA_BLOB */
+               [default] drsuapi_DsAttributeValueCtrDataBlob data_blob;
+       } drsuapi_DsReplicaAttributeValueCtr;
+
+       typedef [flag(NDR_PAHEX)] struct {
+               drsuapi_DsAttributeId attid;
+               [switch_is(attid)] drsuapi_DsReplicaAttributeValueCtr value_ctr;
+       } drsuapi_DsReplicaAttribute;
+
+       typedef struct {
+               [range(0,1048576)] uint32 num_attributes;
+               [size_is(num_attributes)]  drsuapi_DsReplicaAttribute *attributes;
+       } drsuapi_DsReplicaAttributeCtr;
+
+       typedef [public] struct {
+               drsuapi_DsReplicaObjectIdentifier *identifier;
+               uint32 unknown1;
+               drsuapi_DsReplicaAttributeCtr attribute_ctr;
+       } drsuapi_DsReplicaObject;
+
+       typedef struct {
+               uint32 version;
+               NTTIME_1sec orginating_time;
+               GUID orginating_invocation_id;
+               hyper orginating_usn;
+       } drsuapi_DsReplicaMetaData;
+
+       typedef [public] struct {
+               [range(0,1048576)] uint32 count;
+               [size_is(count)] drsuapi_DsReplicaMetaData meta_data[];
+       } drsuapi_DsReplicaMetaDataCtr;
+
+       typedef [public,noprint] struct {
+               drsuapi_DsReplicaObjectListItemEx *next_object;
+               drsuapi_DsReplicaObject object;
+               uint32 unknown1;
+               GUID *parent_object_guid;
+               drsuapi_DsReplicaMetaDataCtr *meta_data_ctr;
+       } drsuapi_DsReplicaObjectListItemEx;
+
+       typedef [gensize] struct {
+               GUID guid1;
+               GUID guid2;
+               drsuapi_DsReplicaObjectIdentifier *naming_context;
+               drsuapi_DsReplicaHighWaterMark old_highwatermark;
+               drsuapi_DsReplicaHighWaterMark new_highwatermark;
+               drsuapi_DsReplicaCoursorCtrEx *uptodateness_vector;
+               drsuapi_DsGetNCChangesRequest_Ctr12 ctr12;
+               uint32 unknown1;
+               uint32 object_count;
+               /* this +55 is sometimes +56, so I don't know where this comes from... --metze */
+               [value(ndr_size_drsuapi_DsGetNCChangesCtr1(r,ndr->flags)+55)] uint32 __ndr_size;
+               drsuapi_DsReplicaObjectListItemEx *first_object;
+               uint32 unknown4;
+       } drsuapi_DsGetNCChangesCtr1;
+
+       typedef struct {
+               uint32 decompressed_length;
+               uint32 compressed_length;
+               [subcontext(4),subcontext_size(r->compressed_length),compression(NDR_COMPRESSION_MSZIP,compressed_length,decompressed_length)] drsuapi_DsGetNCChangesCtr1 *ctr1;
+       } drsuapi_DsGetNCChangesCompressedInfo;
+
+       typedef struct {
+               uint32 decompressed_length;
+               uint32 compressed_length;
+               [subcontext(4),subcontext_size(r->compressed_length),flag(NDR_REMAINING)] DATA_BLOB *decompressed;
+       } drsuapi_DsGetNCChangesCompressedInfo_Test;
+
+       typedef struct {
+               drsuapi_DsGetNCChangesCompressedInfo info;
+       } drsuapi_DsGetNCChangesCtr2;
+
+       typedef struct {
+               GUID guid1;
+               GUID guid2;
+               drsuapi_DsReplicaObjectIdentifier *naming_context;
+               drsuapi_DsReplicaHighWaterMark old_highwatermark;
+               drsuapi_DsReplicaHighWaterMark new_highwatermark;
+               drsuapi_DsReplicaCoursor2CtrEx *uptodateness_vector;
+               drsuapi_DsGetNCChangesRequest_Ctr12 ctr12;
+               uint32 unknown1;
+               uint32 unknown2;
+               uint32 unknown3;
+               drsuapi_DsReplicaObjectListItemEx *first_object;
+               uint32 unknown4;
+               uint32 unknown5;
+               uint32 unknown6;
+               uint32 len1;
+               uint32 array_ptr1;
+               uint32 unknown7;
+       } drsuapi_DsGetNCChangesCtr6;
+
+       typedef struct {
+               uint32 unknown1;
+               uint16 unknown2; /* enum */
+               drsuapi_DsGetNCChangesCompressedInfo_Test info;
        } drsuapi_DsGetNCChangesCtr7;
 
        typedef [switch_type(int32)] union {
+               [case(1)] drsuapi_DsGetNCChangesCtr1 ctr1;
+               [case(2)] drsuapi_DsGetNCChangesCtr2 ctr2;
+               [case(6)] drsuapi_DsGetNCChangesCtr6 ctr6;
                [case(7)] drsuapi_DsGetNCChangesCtr7 ctr7;
        } drsuapi_DsGetNCChangesCtr;
 
@@ -210,12 +651,10 @@ interface drsuapi
        } drsuapi_DsReplicaUpdateRefsOptions;
 
        typedef struct {
-               uint32 unknown1;
-               uint32 unknown2;
+               [ref] drsuapi_DsReplicaObjectIdentifier *naming_context;
+               [ref] ascstr *dest_dsa_dns_name;
                GUID dest_dsa_guid;
                drsuapi_DsReplicaUpdateRefsOptions options;
-               drsuapi_DsReplicaSyncRequest1Info sync_req_info1;
-               ascstr dest_dsa_dns_name;
        } drsuapi_DsReplicaUpdateRefsRequest1;
 
        typedef [switch_type(int32)] union {
@@ -319,7 +758,7 @@ interface drsuapi
                drsuapi_DsNameFormat format_offered;
                drsuapi_DsNameFormat format_desired;
                [range(1,10000)] uint32 count;
-               [size_is(count)] drsuapi_DsNameString *names[];
+               [size_is(count)] drsuapi_DsNameString *names;
        } drsuapi_DsNameRequest1;
 
        typedef [switch_type(int32)] union {
@@ -334,7 +773,7 @@ interface drsuapi
 
        typedef struct {
                uint32 count;
-               [size_is(count)] drsuapi_DsNameInfo1 *array[];
+               [size_is(count)] drsuapi_DsNameInfo1 *array;
        } drsuapi_DsNameCtr1;
 
        typedef [switch_type(int32)] union {
@@ -361,7 +800,7 @@ interface drsuapi
                uint32 unknown1;
                unistr *object_dn;
                [range(0,10000)] uint32 count;
-               [size_is(count)] drsuapi_DsNameString *spn_names[];
+               [size_is(count)] drsuapi_DsNameString *spn_names;
        } drsuapi_DsWriteAccountSpnRequest1;
 
        typedef [switch_type(int32)] union {
@@ -414,7 +853,7 @@ interface drsuapi
 
        typedef struct {
                [range(0,10000)] uint32 count;
-               [size_is(count)] drsuapi_DsGetDCInfo1 *array[];
+               [size_is(count)] drsuapi_DsGetDCInfo1 *array;
        } drsuapi_DsGetDCInfoCtr1;
 
        typedef struct {
@@ -436,7 +875,7 @@ interface drsuapi
 
        typedef struct {
                [range(0,10000)] uint32 count;
-               [size_is(count)] drsuapi_DsGetDCInfo2 *array[];
+               [size_is(count)] drsuapi_DsGetDCInfo2 *array;
        } drsuapi_DsGetDCInfoCtr2;
 
        typedef struct {
@@ -451,13 +890,19 @@ interface drsuapi
 
        typedef struct {
                [range(0,10000)] uint32 count;
-               [size_is(count)] drsuapi_DsGetDCInfo01 *array[];
+               [size_is(count)] drsuapi_DsGetDCInfo01 *array;
        } drsuapi_DsGetDCInfoCtr01;
 
-       typedef [switch_type(int32)] union {
-               [case(1)] drsuapi_DsGetDCInfoCtr1 ctr1;
-               [case(2)] drsuapi_DsGetDCInfoCtr2 ctr2;
-               [case(-1)] drsuapi_DsGetDCInfoCtr01 ctr01;
+       typedef [v1_enum] enum {
+               DRSUAPI_DC_INFO_CTR_1  = 1,
+               DRSUAPI_DC_INFO_CTR_2  = 2,
+               DRSUAPI_DC_INFO_CTR_01 = -1
+       } drsuapi_DsGetDCInfoCtrLevels;
+
+        typedef [switch_type(int32)] union {
+               [case(DRSUAPI_DC_INFO_CTR_1)]  drsuapi_DsGetDCInfoCtr1  ctr1;
+               [case(DRSUAPI_DC_INFO_CTR_2)]  drsuapi_DsGetDCInfoCtr2  ctr2;
+               [case(DRSUAPI_DC_INFO_CTR_01)] drsuapi_DsGetDCInfoCtr01 ctr01;
        } drsuapi_DsGetDCInfoCtr;
 
        WERROR drsuapi_DsGetDomainControllerInfo(
@@ -469,7 +914,60 @@ interface drsuapi
 
        /*****************/
         /* Function 0x11 */
-       WERROR drsuapi_DsAddEntry();
+       typedef [public,noprint] struct {
+               drsuapi_DsReplicaObjectListItem *next_object;
+               drsuapi_DsReplicaObject object;
+       } drsuapi_DsReplicaObjectListItem;
+
+       /*
+        * please note the the current idl
+        * for DsAddEntry does only parse 
+        * what I saw between 2 w2k3 boxes
+        * in my dssync experiments I got some other replies
+        * so all I want to say is that this is very incomplete yet...
+        * --metze
+        */
+       typedef struct {
+               drsuapi_DsReplicaObjectListItem first_object;
+       } drsuapi_DsAddEntryRequest2;
+
+       typedef [switch_type(int32)] union {
+               [case(2)] drsuapi_DsAddEntryRequest2 req2;
+       } drsuapi_DsAddEntryRequest;
+
+       typedef struct {
+               uint32 unknown1;
+               uint32 unknown2;
+               uint32 unknown3;
+       } drsuapi_DsAddEntryCtr3Info1;
+
+       typedef [switch_type(uint32)] union {
+               [case(1)] drsuapi_DsAddEntryCtr3Info1 info1;
+       } drsuapi_DsAddEntryCtr3Info;
+
+       typedef struct {
+               GUID guid;
+               dom_sid28 sid;
+       } drsuapi_DsReplicaObjectIdentifier2;
+
+       typedef struct {
+               drsuapi_DsReplicaObjectIdentifier *id;
+               uint32 level;
+               [switch_is(level)] drsuapi_DsAddEntryCtr3Info *info;
+               [range(0,10000)] uint32 count;
+               [size_is(count)] drsuapi_DsReplicaObjectIdentifier2 *objects;
+       } drsuapi_DsAddEntryCtr3;
+
+       typedef [switch_type(int32)] union {
+               [case(3)] drsuapi_DsAddEntryCtr3 ctr3;
+       } drsuapi_DsAddEntryCtr;
+
+       WERROR drsuapi_DsAddEntry(
+               [in,ref] policy_handle *bind_handle,
+               [in,out] int32 level,
+               [in,switch_is(level)] drsuapi_DsAddEntryRequest req,
+               [out,switch_is(level)] drsuapi_DsAddEntryCtr ctr
+               );
 
        /*****************/
         /* Function 0x12 */
@@ -526,7 +1024,7 @@ interface drsuapi
                unistr *source_dsa_obj_dn;
                unistr *source_dsa_address;
                unistr *transport_obj_dn;
-               uint32 replica_flags;
+               drsuapi_DsReplicaNeighbourFlags replica_flags;
                uint32 reserved;
                GUID naming_context_obj_guid;
                GUID source_dsa_obj_guid;
@@ -546,11 +1044,6 @@ interface drsuapi
                [size_is(count)] drsuapi_DsReplicaNeighbour array[];
        } drsuapi_DsReplicaNeighbourCtr;
 
-       typedef struct {
-               GUID source_dsa_invocation_id;
-               hyper highest_usn;
-       } drsuapi_DsReplicaCoursor;
-
        typedef struct {
                uint32 count;
                uint32 reserved;
@@ -626,7 +1119,7 @@ interface drsuapi
                unistr *attribute_name;
                unistr *object_dn;
                uint32 value_length;
-               [size_is(value_length)] uint8 *value[];
+               [size_is(value_length)] uint8 *value;
                NTTIME deleted;
                NTTIME created;
                uint32 version;
@@ -642,12 +1135,6 @@ interface drsuapi
                [size_is(count)] drsuapi_DsReplicaAttrValMetaData array[];
        } drsuapi_DsReplicaAttrValMetaDataCtr;
 
-       typedef struct {
-               GUID source_dsa_invocation_id;
-               hyper highest_usn;
-               NTTIME last_sync_success;
-       } drsuapi_DsReplicaCoursor2;
-
        typedef struct {
                uint32 count;
                int32 enumeration_context;
@@ -687,7 +1174,7 @@ interface drsuapi
                unistr *attribute_name;
                unistr *object_dn;
                uint32 value_length;
-               [size_is(value_length)] uint8 *value[];
+               [size_is(value_length)] uint8 *value;
                NTTIME deleted;
                NTTIME created;
                uint32 version;
@@ -720,14 +1207,6 @@ interface drsuapi
                [size_is(count)] drsuapi_DsReplicaConnection04 array[];
        } drsuapi_DsReplicaConnection04Ctr;
 
-       typedef struct {
-               uint32 u1;
-               uint32 u2;
-               [range(0,0x100000)] uint32 count;
-               uint32 u3;
-               [size_is(count)] drsuapi_DsReplicaCoursor array[];
-       } drsuapi_DsReplicaCoursor05Ctr;
-
        typedef struct {
                unistr *str1;
                uint32 u1;
@@ -759,7 +1238,7 @@ interface drsuapi
                [case(DRSUAPI_DS_REPLICA_INFO_ATTRIBUTE_VALUE_METADATA2)] drsuapi_DsReplicaAttrValMetaData2Ctr *attrvalmetadata2;
                [case(DRSUAPI_DS_REPLICA_INFO_NEIGHBORS02)] drsuapi_DsReplicaNeighbourCtr *neighbours02;
                [case(DRSUAPI_DS_REPLICA_INFO_CONNECTIONS04)] drsuapi_DsReplicaConnection04Ctr *connections04;
-               [case(DRSUAPI_DS_REPLICA_INFO_CURSURS05)] drsuapi_DsReplicaCoursor05Ctr *coursors05;
+               [case(DRSUAPI_DS_REPLICA_INFO_CURSURS05)] drsuapi_DsReplicaCoursorCtrEx *coursors05;
                [case(DRSUAPI_DS_REPLICA_INFO_06)] drsuapi_DsReplica06Ctr *i06;
        } drsuapi_DsReplicaInfo;