1
/* header auto-generated by pidl */
5
#include "libcli/util/ntstatus.h"
7
#include "librpc/gen_ndr/drsuapi.h"
8
#include "librpc/gen_ndr/misc.h"
9
#include "librpc/gen_ndr/samr.h"
10
#include "librpc/gen_ndr/lsa.h"
11
#ifndef _HEADER_drsblobs
12
#define _HEADER_drsblobs
14
#define SUPPLEMENTAL_CREDENTIALS_PREFIX ( " " )
15
struct replPropertyMetaData1 {
16
enum drsuapi_DsAttributeId attid;
18
NTTIME originating_change_time;
19
struct GUID originating_invocation_id;
20
uint64_t originating_usn;
24
struct replPropertyMetaDataCtr1 {
27
struct replPropertyMetaData1 *array;
30
union replPropertyMetaDataCtr {
31
struct replPropertyMetaDataCtr1 ctr1;/* [case] */
32
}/* [nodiscriminant] */;
34
struct replPropertyMetaDataBlob {
37
union replPropertyMetaDataCtr ctr;/* [switch_is(version)] */
40
struct replUpToDateVectorCtr1 {
43
struct drsuapi_DsReplicaCursor *cursors;
46
struct replUpToDateVectorCtr2 {
49
struct drsuapi_DsReplicaCursor2 *cursors;
52
union replUpToDateVectorCtr {
53
struct replUpToDateVectorCtr1 ctr1;/* [case] */
54
struct replUpToDateVectorCtr2 ctr2;/* [case(2)] */
55
}/* [nodiscriminant] */;
57
struct replUpToDateVectorBlob {
60
union replUpToDateVectorCtr ctr;/* [switch_is(version)] */
63
struct repsFromTo1OtherInfo {
64
uint32_t __dns_name_size;/* [value(strlen(dns_name)+1)] */
65
const char *dns_name;/* [charset(DOS)] */
66
}/* [gensize,public] */;
69
uint32_t blobsize;/* [value(ndr_size_repsFromTo1(this,ndr->iconv_convenience,ndr->flags)+8)] */
70
uint32_t consecutive_sync_failures;
73
WERROR result_last_attempt;
74
struct repsFromTo1OtherInfo *other_info;/* [relative] */
75
uint32_t other_info_length;/* [value(ndr_size_repsFromTo1OtherInfo(other_info,ndr->iconv_convenience,ndr->flags))] */
76
uint32_t replica_flags;
79
struct drsuapi_DsReplicaHighWaterMark highwatermark;
80
struct GUID source_dsa_obj_guid;
81
struct GUID source_dsa_invocation_id;
82
struct GUID transport_guid;
83
}/* [gensize,public,flag(LIBNDR_PRINT_ARRAY_HEX)] */;
86
struct repsFromTo1 ctr1;/* [case] */
87
}/* [nodiscriminant] */;
89
struct repsFromToBlob {
92
union repsFromTo ctr;/* [switch_is(version)] */
95
struct partialAttributeSetCtr1 {
97
enum drsuapi_DsAttributeId *array;
100
union partialAttributeSetCtr {
101
struct partialAttributeSetCtr1 ctr1;/* [case] */
102
}/* [nodiscriminant] */;
104
struct partialAttributeSetBlob {
107
union partialAttributeSetCtr ctr;/* [switch_is(version)] */
110
enum prefixMapVersion
111
#ifndef USE_UINT_ENUMS
113
PREFIX_MAP_VERSION_DSDB=0x44534442
116
{ __donnot_use_enum_prefixMapVersion=0x7FFFFFFF}
117
#define PREFIX_MAP_VERSION_DSDB ( 0x44534442 )
122
struct drsuapi_DsReplicaOIDMapping_Ctr dsdb;/* [case(PREFIX_MAP_VERSION_DSDB)] */
123
}/* [nodiscriminant] */;
125
struct prefixMapBlob {
126
enum prefixMapVersion version;
128
union prefixMapCtr ctr;/* [switch_is(version)] */
131
union ldapControlDirSyncExtra {
132
struct replUpToDateVectorBlob uptodateness_vector;/* [default] */
133
}/* [gensize,nodiscriminant] */;
135
struct ldapControlDirSyncBlob {
136
uint32_t u1;/* [value(3)] */
140
uint32_t extra_length;/* [value(ndr_size_ldapControlDirSyncExtra(&extra,extra.uptodateness_vector.version,ndr->iconv_convenience,0))] */
141
struct drsuapi_DsReplicaHighWaterMark highwatermark;
143
union ldapControlDirSyncExtra extra;/* [switch_is(extra_length)] */
146
struct ldapControlDirSyncCookie {
147
const char *msds;/* [value("MSDS"),charset(DOS)] */
148
struct ldapControlDirSyncBlob blob;/* [subcontext(0)] */
149
}/* [relative_base,public] */;
151
struct supplementalCredentialsPackage {
152
uint16_t name_len;/* [value(2*strlen_m(name))] */
153
uint16_t data_len;/* [value(strlen(data))] */
155
const char *name;/* [charset(UTF16)] */
156
const char *data;/* [charset(DOS)] */
159
enum supplementalCredentialsSignature
160
#ifndef USE_UINT_ENUMS
162
SUPPLEMENTAL_CREDENTIALS_SIGNATURE=0x0050
165
{ __donnot_use_enum_supplementalCredentialsSignature=0x7FFFFFFF}
166
#define SUPPLEMENTAL_CREDENTIALS_SIGNATURE ( 0x0050 )
170
struct supplementalCredentialsSubBlob {
171
const char *prefix;/* [value(SUPPLEMENTAL_CREDENTIALS_PREFIX),charset(UTF16)] */
172
enum supplementalCredentialsSignature signature;/* [value(SUPPLEMENTAL_CREDENTIALS_SIGNATURE)] */
173
uint16_t num_packages;
174
struct supplementalCredentialsPackage *packages;
177
struct supplementalCredentialsBlob {
178
uint32_t unknown1;/* [value(0)] */
179
uint32_t __ndr_size;/* [value(ndr_size_supplementalCredentialsSubBlob(&sub,ndr->iconv_convenience,ndr->flags))] */
180
uint32_t unknown2;/* [value(0)] */
181
struct supplementalCredentialsSubBlob sub;/* [subcontext_size(__ndr_size),subcontext(0)] */
182
uint8_t unknown3;/* [value(0)] */
185
struct package_PackagesBlob {
186
const char ** names;/* [flag(LIBNDR_FLAG_STR_NOTERM|LIBNDR_FLAG_REMAINING)] */
189
struct package_PrimaryKerberosString {
190
uint16_t length;/* [value(2*strlen_m(string))] */
191
uint16_t size;/* [value(2*strlen_m(string))] */
192
const char * string;/* [relative,subcontext_size(size),subcontext(0),flag(LIBNDR_FLAG_STR_NOTERM|LIBNDR_FLAG_REMAINING)] */
195
struct package_PrimaryKerberosKey3 {
196
uint16_t reserved1;/* [value(0)] */
197
uint16_t reserved2;/* [value(0)] */
198
uint32_t reserved3;/* [value(0)] */
200
uint32_t value_len;/* [value((value?value->length:0))] */
201
DATA_BLOB *value;/* [relative,subcontext_size(value_len),subcontext(0),flag(LIBNDR_FLAG_REMAINING)] */
204
struct package_PrimaryKerberosCtr3 {
206
uint16_t num_old_keys;
207
struct package_PrimaryKerberosString salt;
208
struct package_PrimaryKerberosKey3 *keys;
209
struct package_PrimaryKerberosKey3 *old_keys;
210
uint32_t padding1;/* [value(0)] */
211
uint32_t padding2;/* [value(0)] */
212
uint32_t padding3;/* [value(0)] */
213
uint32_t padding4;/* [value(0)] */
214
uint32_t padding5;/* [value(0)] */
217
struct package_PrimaryKerberosKey4 {
218
uint16_t reserved1;/* [value(0)] */
219
uint16_t reserved2;/* [value(0)] */
220
uint32_t reserved3;/* [value(0)] */
221
uint32_t iteration_count;
223
uint32_t value_len;/* [value((value?value->length:0))] */
224
DATA_BLOB *value;/* [relative,subcontext_size(value_len),subcontext(0),flag(LIBNDR_FLAG_REMAINING)] */
227
struct package_PrimaryKerberosCtr4 {
229
uint16_t num_service_keys;/* [value(0)] */
230
uint16_t num_old_keys;
231
uint16_t num_older_keys;
232
struct package_PrimaryKerberosString salt;
233
uint32_t default_iteration_count;
234
struct package_PrimaryKerberosKey4 *keys;
235
struct package_PrimaryKerberosKey4 *service_keys;
236
struct package_PrimaryKerberosKey4 *old_keys;
237
struct package_PrimaryKerberosKey4 *older_keys;
240
union package_PrimaryKerberosCtr {
241
struct package_PrimaryKerberosCtr3 ctr3;/* [case(3)] */
242
struct package_PrimaryKerberosCtr4 ctr4;/* [case(4)] */
243
}/* [nodiscriminant] */;
245
struct package_PrimaryKerberosBlob {
247
uint16_t flags;/* [value(0)] */
248
union package_PrimaryKerberosCtr ctr;/* [switch_is(version)] */
251
struct package_PrimaryCLEARTEXTBlob {
252
DATA_BLOB cleartext;/* [flag(LIBNDR_FLAG_REMAINING)] */
255
struct package_PrimaryWDigestHash {
257
}/* [flag(LIBNDR_PRINT_ARRAY_HEX)] */;
259
struct package_PrimaryWDigestBlob {
260
uint16_t unknown1;/* [value(0x31)] */
261
uint8_t unknown2;/* [value(0x01)] */
263
uint32_t unknown3;/* [value(0)] */
264
uint64_t uuknown4;/* [value(0)] */
265
struct package_PrimaryWDigestHash *hashes;
268
struct AuthInfoNone {
269
uint32_t size;/* [value(0)] */
272
struct AuthInfoNT4Owf {
273
uint32_t size;/* [value(16)] */
274
struct samr_Password password;
277
struct AuthInfoClear {
282
struct AuthInfoVersion {
283
uint32_t size;/* [value(4)] */
288
struct AuthInfoNone none;/* [case(TRUST_AUTH_TYPE_NONE)] */
289
struct AuthInfoNT4Owf nt4owf;/* [case(TRUST_AUTH_TYPE_NT4OWF)] */
290
struct AuthInfoClear clear;/* [case(TRUST_AUTH_TYPE_CLEAR)] */
291
struct AuthInfoVersion version;/* [case(TRUST_AUTH_TYPE_VERSION)] */
292
}/* [nodiscriminant] */;
294
struct AuthenticationInformation {
295
NTTIME LastUpdateTime;
296
enum lsa_TrustAuthType AuthType;
297
union AuthInfo AuthInfo;/* [switch_is(AuthType)] */
298
DATA_BLOB _pad;/* [flag(LIBNDR_FLAG_ALIGN4)] */
301
struct AuthenticationInformationArray {
302
struct AuthenticationInformation *array;/* [size_is] */
303
}/* [noprint,nopush,nopull] */;
305
struct trustAuthInOutBlob {
307
struct AuthenticationInformationArray *current;/* [relative] */
308
struct AuthenticationInformationArray *previous;/* [relative] */
309
}/* [noprint,gensize,nopull,public,nopush] */;
311
struct trustCurrentPasswords {
313
struct AuthenticationInformation **current;/* [relative] */
314
}/* [gensize,public] */;
316
struct trustDomainPasswords {
317
uint8_t confounder[512];
318
struct trustCurrentPasswords outgoing;/* [subcontext_size(outgoing_size),subcontext(0)] */
319
struct trustCurrentPasswords incoming;/* [subcontext_size(incoming_size),subcontext(0)] */
320
uint32_t outgoing_size;/* [value(ndr_size_trustCurrentPasswords(&outgoing,ndr->iconv_convenience,ndr->flags))] */
321
uint32_t incoming_size;/* [value(ndr_size_trustCurrentPasswords(&incoming,ndr->iconv_convenience,ndr->flags))] */
322
}/* [public,nopull] */;
324
struct DsCompressedChunk {
329
struct ExtendedErrorAString {
331
const char *string;/* [unique,charset(DOS),size_is(__size)] */
334
struct ExtendedErrorUString {
336
const char *string;/* [unique,charset(UTF16),size_is(__size)] */
339
struct ExtendedErrorBlob {
341
uint8_t *data;/* [unique,size_is(length)] */
344
enum ExtendedErrorComputerNamePresent
345
#ifndef USE_UINT_ENUMS
347
EXTENDED_ERROR_COMPUTER_NAME_PRESENT=1,
348
EXTENDED_ERROR_COMPUTER_NAME_NOT_PRESENT=2
351
{ __donnot_use_enum_ExtendedErrorComputerNamePresent=0x7FFFFFFF}
352
#define EXTENDED_ERROR_COMPUTER_NAME_PRESENT ( 1 )
353
#define EXTENDED_ERROR_COMPUTER_NAME_NOT_PRESENT ( 2 )
357
union ExtendedErrorComputerNameU {
358
struct ExtendedErrorUString name;/* [case(EXTENDED_ERROR_COMPUTER_NAME_PRESENT)] */
359
}/* [switch_type(ExtendedErrorComputerNamePresent)] */;
361
struct ExtendedErrorComputerName {
362
enum ExtendedErrorComputerNamePresent present;
363
union ExtendedErrorComputerNameU n;/* [switch_is(present)] */
366
enum ExtendedErrorParamType
367
#ifndef USE_UINT_ENUMS
369
EXTENDED_ERROR_PARAM_TYPE_ASCII_STRING=1,
370
EXTENDED_ERROR_PARAM_TYPE_UNICODE_STRING=2,
371
EXTENDED_ERROR_PARAM_TYPE_UINT32=3,
372
EXTENDED_ERROR_PARAM_TYPE_UINT16=4,
373
EXTENDED_ERROR_PARAM_TYPE_UINT64=5,
374
EXTENDED_ERROR_PARAM_TYPE_NONE=6,
375
EXTENDED_ERROR_PARAM_TYPE_BLOB=7
378
{ __donnot_use_enum_ExtendedErrorParamType=0x7FFFFFFF}
379
#define EXTENDED_ERROR_PARAM_TYPE_ASCII_STRING ( 1 )
380
#define EXTENDED_ERROR_PARAM_TYPE_UNICODE_STRING ( 2 )
381
#define EXTENDED_ERROR_PARAM_TYPE_UINT32 ( 3 )
382
#define EXTENDED_ERROR_PARAM_TYPE_UINT16 ( 4 )
383
#define EXTENDED_ERROR_PARAM_TYPE_UINT64 ( 5 )
384
#define EXTENDED_ERROR_PARAM_TYPE_NONE ( 6 )
385
#define EXTENDED_ERROR_PARAM_TYPE_BLOB ( 7 )
389
union ExtendedErrorParamU {
390
struct ExtendedErrorAString a_string;/* [case(EXTENDED_ERROR_PARAM_TYPE_ASCII_STRING)] */
391
struct ExtendedErrorUString u_string;/* [case(EXTENDED_ERROR_PARAM_TYPE_UNICODE_STRING)] */
392
uint32_t uint32;/* [case(EXTENDED_ERROR_PARAM_TYPE_UINT32)] */
393
uint16_t uint16;/* [case(EXTENDED_ERROR_PARAM_TYPE_UINT16)] */
394
uint64_t uint64;/* [case(EXTENDED_ERROR_PARAM_TYPE_UINT64)] */
395
struct ExtendedErrorBlob blob;/* [case(EXTENDED_ERROR_PARAM_TYPE_BLOB)] */
396
}/* [switch_type(ExtendedErrorParamType)] */;
398
struct ExtendedErrorParam {
399
enum ExtendedErrorParamType type;
400
union ExtendedErrorParamU p;/* [switch_is(type)] */
403
struct ExtendedErrorInfo {
404
struct ExtendedErrorInfo *next;/* [unique] */
405
struct ExtendedErrorComputerName computer_name;
408
uint32_t generating_component;
410
uint16_t detection_location;
413
struct ExtendedErrorParam *params;/* [size_is(num_params)] */
416
struct ExtendedErrorInfoPtr {
417
struct ExtendedErrorInfo *info;/* [unique] */
421
struct decode_replPropertyMetaData {
423
struct replPropertyMetaDataBlob blob;
429
struct decode_replUpToDateVector {
431
struct replUpToDateVectorBlob blob;
437
struct decode_repsFromTo {
439
struct repsFromToBlob blob;
445
struct decode_partialAttributeSet {
447
struct partialAttributeSetBlob blob;
453
struct decode_prefixMap {
455
struct prefixMapBlob blob;
461
struct decode_ldapControlDirSync {
463
struct ldapControlDirSyncCookie cookie;
469
struct decode_supplementalCredentials {
471
struct supplementalCredentialsBlob blob;
477
struct decode_Packages {
479
struct package_PackagesBlob blob;
485
struct decode_PrimaryKerberos {
487
struct package_PrimaryKerberosBlob blob;
493
struct decode_PrimaryCLEARTEXT {
495
struct package_PrimaryCLEARTEXTBlob blob;
501
struct decode_PrimaryWDigest {
503
struct package_PrimaryWDigestBlob blob;
509
struct decode_trustAuthInOut {
511
struct trustAuthInOutBlob blob;
517
struct decode_trustDomainPasswords {
519
struct trustDomainPasswords blob;
525
struct decode_ExtendedErrorInfo {
527
struct ExtendedErrorInfoPtr ptr;/* [subcontext(0xFFFFFC01)] */
532
#endif /* _HEADER_drsblobs */