r15776: Don't generate ref pointers in Samba4-generated code. There is no point
[Samba/aatanasov.git] / source / librpc / idl / netlogon.idl
blob95289b7ea9c07b74da33db0d09be0c69d6a907b5
1 /*
2 netlogon interface
3 much of this was derived from the ethereal sources - thanks to everyone
4 who contributed!
5 */
7 #include "idl_types.h"
10 uuid("12345678-1234-abcd-ef00-01234567cffb"),
11 version(1.0),
12 endpoint("ncacn_np:[\\pipe\\netlogon]","ncacn_ip_tcp:","ncalrpc:"),
13 pointer_default(unique),
14 pointer_default_top(unique),
15 depends(lsa,samr,security),
16 keepref
19 interface netlogon
21 declare bitmap samr_AcctFlags;
23 /*****************/
24 /* Function 0x00 */
26 typedef struct {
27 [string,charset(UTF16)] uint16 *account_name;
28 uint32 priv;
29 uint32 auth_flags;
30 uint32 logon_count;
31 uint32 bad_pw_count;
32 time_t last_logon;
33 time_t last_logoff;
34 time_t logoff_time;
35 time_t kickoff_time;
36 uint32 password_age;
37 time_t pw_can_change;
38 time_t pw_must_change;
39 [string,charset(UTF16)] uint16 *computer;
40 [string,charset(UTF16)] uint16 *domain;
41 [string,charset(UTF16)] uint16 *script_path;
42 uint32 unknown;
43 } netr_UasInfo;
45 WERROR netr_LogonUasLogon(
46 [in] [string,charset(UTF16)] uint16 *server_name,
47 [in] [string,charset(UTF16)] uint16 account_name[],
48 [in] [string,charset(UTF16)] uint16 workstation[],
49 [out] netr_UasInfo *info
53 /*****************/
54 /* Function 0x01 */
56 typedef struct {
57 uint32 duration;
58 uint16 logon_count;
59 } netr_UasLogoffInfo;
61 WERROR netr_LogonUasLogoff(
62 [in] [string,charset(UTF16)] uint16 *server_name,
63 [in] [string,charset(UTF16)] uint16 account_name[],
64 [in] [string,charset(UTF16)] uint16 workstation[],
65 [out] netr_UasLogoffInfo info
69 /*****************/
70 /* Function 0x02 */
72 /* in netr_AcctLockStr size seems to be be 24, and rrenard thinks
73 that the structure of the bindata looks like this:
75 dlong lockout_duration;
76 udlong reset_count;
77 uint32 bad_attempt_lockout;
78 uint32 dummy;
80 but it doesn't look as though this structure is reflected at the
81 NDR level. Maybe it is left to the application to decode the bindata array.
83 typedef struct {
84 uint16 size;
85 uint16 length;
86 [size_is(size/2),length_is(length/2)] uint16 *bindata;
87 } netr_AcctLockStr;
89 const int MSV1_0_CLEARTEXT_PASSWORD_ALLOWED = 0x002;
90 const int MSV1_0_ALLOW_SERVER_TRUST_ACCOUNT = 0x020;
91 const int MSV1_0_ALLOW_WORKSTATION_TRUST_ACCOUNT = 0x800;
93 typedef struct {
94 lsa_String domain_name;
95 uint32 parameter_control; /* see MSV1_0_* */
96 uint32 logon_id_low;
97 uint32 logon_id_high;
98 lsa_String account_name;
99 lsa_String workstation;
100 } netr_IdentityInfo;
102 typedef struct {
103 netr_IdentityInfo identity_info;
104 samr_Password lmpassword;
105 samr_Password ntpassword;
106 } netr_PasswordInfo;
108 typedef [flag(NDR_PAHEX)] struct {
109 uint16 length;
110 [value(length)] uint16 size;
111 [size_is(length),length_is(length)] uint8 *data;
112 } netr_ChallengeResponse;
114 typedef [flag(NDR_PAHEX)] struct {
115 netr_IdentityInfo identity_info;
116 uint8 challenge[8];
117 netr_ChallengeResponse nt;
118 netr_ChallengeResponse lm;
119 } netr_NetworkInfo;
121 typedef [switch_type(uint16)] union {
122 [case(1)] netr_PasswordInfo *password;
123 [case(2)] netr_NetworkInfo *network;
124 [case(3)] netr_PasswordInfo *password;
125 [case(5)] netr_PasswordInfo *password;
126 [case(6)] netr_NetworkInfo *network;
127 } netr_LogonLevel;
129 typedef [public] struct {
130 uint32 rid;
131 uint32 attributes;
132 } netr_GroupMembership;
134 typedef [public,flag(NDR_PAHEX)] struct {
135 uint8 key[16];
136 } netr_UserSessionKey;
138 typedef [public,flag(NDR_PAHEX)] struct {
139 uint8 key[8];
140 } netr_LMSessionKey;
142 /* Flags for user_flags below */
143 typedef [public,bitmap32bit] bitmap {
144 NETLOGON_GUEST = 0x0001,
145 NETLOGON_NOENCRYPTION = 0x0002,
146 NETLOGON_CACHED_ACCOUNT = 0x0004,
147 NETLOGON_USED_LM_PASSWORD = 0x0008,
148 NETLOGON_EXTRA_SIDS = 0x0020,
149 NETLOGON_SUBAUTH_SESSION_KEY = 0x0040,
150 NETLOGON_SERVER_TRUST_ACCOUNT = 0x0080,
151 NETLOGON_NTLMV2_ENABLED = 0x0100,
152 NETLOGON_RESOURCE_GROUPS = 0x0200,
153 NETLOGON_PROFILE_PATH_RETURNED = 0x0400
154 } netr_UserFlags;
156 typedef struct {
157 NTTIME last_logon;
158 NTTIME last_logoff;
159 NTTIME acct_expiry;
160 NTTIME last_password_change;
161 NTTIME allow_password_change;
162 NTTIME force_password_change;
163 lsa_String account_name;
164 lsa_String full_name;
165 lsa_String logon_script;
166 lsa_String profile_path;
167 lsa_String home_directory;
168 lsa_String home_drive;
169 uint16 logon_count;
170 uint16 bad_password_count;
171 uint32 rid;
172 uint32 primary_gid;
173 samr_RidWithAttributeArray groups;
174 netr_UserFlags user_flags;
175 netr_UserSessionKey key;
176 lsa_StringLarge logon_server;
177 lsa_StringLarge domain;
178 dom_sid2 *domain_sid;
179 netr_LMSessionKey LMSessKey;
180 samr_AcctFlags acct_flags;
181 uint32 unknown[7];
182 } netr_SamBaseInfo;
184 typedef struct {
185 netr_SamBaseInfo base;
186 } netr_SamInfo2;
188 typedef struct {
189 dom_sid2 *sid;
190 uint32 attribute;
191 } netr_SidAttr;
193 typedef [public] struct {
194 netr_SamBaseInfo base;
195 uint32 sidcount;
196 [size_is(sidcount)] netr_SidAttr *sids;
197 } netr_SamInfo3;
199 typedef struct {
200 netr_SamBaseInfo base;
201 uint32 sidcount;
202 [size_is(sidcount)] netr_SidAttr *sids;
203 lsa_String forest;
204 lsa_String principle;
205 uint32 unknown4[20];
206 } netr_SamInfo6;
208 typedef struct {
209 uint32 pac_size;
210 [size_is(pac_size)] uint8 *pac;
211 lsa_String logon_domain;
212 lsa_String logon_server;
213 lsa_String principal_name;
214 uint32 auth_size;
215 [size_is(auth_size)] uint8 *auth;
216 netr_UserSessionKey user_session_key;
217 uint32 expansionroom[10];
218 lsa_String unknown1;
219 lsa_String unknown2;
220 lsa_String unknown3;
221 lsa_String unknown4;
222 } netr_PacInfo;
224 typedef [switch_type(uint16)] union {
225 [case(2)] netr_SamInfo2 *sam2;
226 [case(3)] netr_SamInfo3 *sam3;
227 [case(4)] netr_PacInfo *pac;
228 [case(5)] netr_PacInfo *pac;
229 [case(6)] netr_SamInfo6 *sam6;
230 } netr_Validation;
232 typedef [public, flag(NDR_PAHEX)] struct {
233 uint8 data[8];
234 } netr_Credential;
236 typedef [public] struct {
237 netr_Credential cred;
238 time_t timestamp;
239 } netr_Authenticator;
241 NTSTATUS netr_LogonSamLogon(
242 [in] [string,charset(UTF16)] uint16 *server_name,
243 [in] [string,charset(UTF16)] uint16 *computer_name,
244 [in] netr_Authenticator *credential,
245 [in][out] netr_Authenticator *return_authenticator,
246 [in] uint16 logon_level,
247 [in] [switch_is(logon_level)] netr_LogonLevel logon,
248 [in] uint16 validation_level,
249 [out] [switch_is(validation_level)] netr_Validation validation,
250 [out] uint8 authoritative
254 /*****************/
255 /* Function 0x03 */
257 NTSTATUS netr_LogonSamLogoff(
258 [in] [string,charset(UTF16)] uint16 *server_name,
259 [in] [string,charset(UTF16)] uint16 *computer_name,
260 [in] netr_Authenticator *credential,
261 [in][out] netr_Authenticator *return_authenticator,
262 [in] uint16 logon_level,
263 [in] [switch_is(logon_level)] netr_LogonLevel logon
268 /*****************/
269 /* Function 0x04 */
271 NTSTATUS netr_ServerReqChallenge(
272 [in,string,charset(UTF16)] uint16 *server_name,
273 [in,string,charset(UTF16)] uint16 computer_name[],
274 [in,out,ref] netr_Credential *credentials
278 /*****************/
279 /* Function 0x05 */
281 declare enum netr_SchannelType;
283 NTSTATUS netr_ServerAuthenticate(
284 [in,string,charset(UTF16)] uint16 *server_name,
285 [in,string,charset(UTF16)] uint16 account_name[],
286 [in] netr_SchannelType secure_channel_type,
287 [in,string,charset(UTF16)] uint16 computer_name[],
288 [in,out,ref] netr_Credential *credentials
292 /*****************/
293 /* Function 0x06 */
295 NTSTATUS netr_ServerPasswordSet(
296 [in] [string,charset(UTF16)] uint16 *server_name,
297 [in] [string,charset(UTF16)] uint16 account_name[],
298 [in] netr_SchannelType secure_channel_type,
299 [in] [string,charset(UTF16)] uint16 computer_name[],
300 [in] netr_Authenticator credential,
301 [in] samr_Password new_password,
302 [out] netr_Authenticator return_authenticator
306 /*****************/
307 /* Function 0x07 */
309 declare enum netr_SamDatabaseID;
311 typedef struct {
312 [string,charset(UTF16)] uint16 *account_name;
313 lsa_String unknown1;
314 lsa_String unknown2;
315 lsa_String unknown3;
316 lsa_String unknown4;
317 uint32 unknown5;
318 uint32 unknown6;
319 uint32 unknown7;
320 uint32 unknown8;
321 } netr_DELTA_DELETE_USER;
323 typedef struct {
324 uint16 length;
325 [value(length)] uint16 size;
326 uint32 flags;
327 samr_Password pwd;
328 } netr_USER_KEY16;
330 typedef struct {
331 uint16 nt_length;
332 uint16 nt_size;
333 uint32 nt_flags;
334 uint16 lm_length;
335 uint16 lm_size;
336 uint32 lm_flags;
337 uint8 nt_history[nt_length];
338 uint8 lm_history[lm_length];
339 } netr_PasswordHistory;
341 typedef struct {
342 netr_USER_KEY16 lmpassword;
343 netr_USER_KEY16 ntpassword;
344 netr_PasswordHistory lmhistory;
345 } netr_USER_KEYS2;
347 typedef struct {
348 netr_USER_KEYS2 keys2;
349 } netr_USER_KEY_UNION;
351 typedef [public] struct {
352 uint32 version;
353 netr_USER_KEY_UNION keys;
354 } netr_USER_KEYS;
356 typedef struct {
357 boolean8 SensitiveDataFlag;
358 uint32 DataLength;
360 /* netr_USER_KEYS encrypted with the session key */
361 [size_is(DataLength)][flag(NDR_PAHEX)] uint8 *SensitiveData;
362 } netr_USER_PRIVATE_INFO;
364 typedef struct {
365 lsa_String account_name;
366 lsa_String full_name;
367 uint32 rid;
368 uint32 primary_gid;
369 lsa_String home_directory;
370 lsa_String home_drive;
371 lsa_String logon_script;
372 lsa_String description;
373 lsa_String workstations;
374 NTTIME last_logon;
375 NTTIME last_logoff;
376 samr_LogonHours logon_hours;
377 uint16 bad_password_count;
378 uint16 logon_count;
379 NTTIME last_password_change;
380 NTTIME acct_expiry;
381 samr_AcctFlags acct_flags;
382 samr_Password lmpassword;
383 samr_Password ntpassword;
384 boolean8 nt_password_present;
385 boolean8 lm_password_present;
386 boolean8 password_expired;
387 lsa_String comment;
388 lsa_String parameters;
389 uint16 country_code;
390 uint16 code_page;
391 netr_USER_PRIVATE_INFO user_private_info;
392 uint32 SecurityInformation;
393 sec_desc_buf sdbuf;
394 lsa_String profile_path;
395 lsa_String unknown2;
396 lsa_String unknown3;
397 lsa_String unknown4;
398 uint32 unknown5;
399 uint32 unknown6;
400 uint32 unknown7;
401 uint32 unknown8;
402 } netr_DELTA_USER;
404 typedef struct {
405 lsa_String domain_name;
406 lsa_String comment;
407 dlong force_logoff_time;
408 uint16 min_password_length;
409 uint16 password_history_length;
410 /* yes, these are signed. They are in negative 100ns */
411 dlong max_password_age;
412 dlong min_password_age;
413 udlong sequence_num;
414 NTTIME domain_create_time;
415 uint32 SecurityInformation;
416 sec_desc_buf sdbuf;
417 netr_AcctLockStr account_lockout;
418 lsa_String unknown2;
419 lsa_String unknown3;
420 lsa_String unknown4;
421 uint32 logon_to_chgpass;
422 uint32 unknown6;
423 uint32 unknown7;
424 uint32 unknown8;
425 } netr_DELTA_DOMAIN;
427 typedef struct {
428 lsa_String group_name;
429 uint32 rid;
430 uint32 attributes;
431 lsa_String description;
432 uint32 SecurityInformation;
433 sec_desc_buf sdbuf;
434 lsa_String unknown1;
435 lsa_String unknown2;
436 lsa_String unknown3;
437 lsa_String unknown4;
438 uint32 unknown5;
439 uint32 unknown6;
440 uint32 unknown7;
441 uint32 unknown8;
442 } netr_DELTA_GROUP;
444 typedef struct {
445 lsa_String OldName;
446 lsa_String NewName;
447 lsa_String unknown1;
448 lsa_String unknown2;
449 lsa_String unknown3;
450 lsa_String unknown4;
451 uint32 unknown5;
452 uint32 unknown6;
453 uint32 unknown7;
454 uint32 unknown8;
455 } netr_DELTA_RENAME;
457 typedef struct {
458 [size_is(num_rids)] uint32 *rids;
459 [size_is(num_rids)] uint32 *attribs;
460 uint32 num_rids;
461 uint32 unknown1;
462 uint32 unknown2;
463 uint32 unknown3;
464 uint32 unknown4;
465 } netr_DELTA_GROUP_MEMBER;
467 typedef struct {
468 lsa_String alias_name;
469 uint32 rid;
470 uint32 SecurityInformation;
471 sec_desc_buf sdbuf;
472 lsa_String description;
473 lsa_String unknown2;
474 lsa_String unknown3;
475 lsa_String unknown4;
476 uint32 unknown5;
477 uint32 unknown6;
478 uint32 unknown7;
479 uint32 unknown8;
480 } netr_DELTA_ALIAS;
482 typedef struct {
483 lsa_SidArray sids;
484 uint32 unknown1;
485 uint32 unknown2;
486 uint32 unknown3;
487 uint32 unknown4;
488 } netr_DELTA_ALIAS_MEMBER;
490 typedef struct {
491 uint32 pagedpoollimit;
492 uint32 nonpagedpoollimit;
493 uint32 minimumworkingsetsize;
494 uint32 maximumworkingsetsize;
495 uint32 pagefilelimit;
496 NTTIME timelimit;
497 } netr_QUOTA_LIMITS;
499 typedef struct {
500 uint32 maxlogsize;
501 NTTIME auditretentionperiod;
502 boolean8 auditingmode;
503 uint32 maxauditeventcount;
504 [size_is(maxauditeventcount+1)] uint32 *eventauditoptions;
505 lsa_String primary_domain_name;
506 dom_sid2 *sid;
507 netr_QUOTA_LIMITS quota_limits;
508 udlong sequence_num;
509 NTTIME db_create_time;
510 uint32 SecurityInformation;
511 sec_desc_buf sdbuf;
512 lsa_String unknown1;
513 lsa_String unknown2;
514 lsa_String unknown3;
515 lsa_String unknown4;
516 uint32 unknown5;
517 uint32 unknown6;
518 uint32 unknown7;
519 uint32 unknown8;
520 } netr_DELTA_POLICY;
522 typedef struct {
523 lsa_String domain_name;
524 uint32 num_controllers;
525 [size_is(num_controllers)] lsa_String *controller_names;
526 uint32 SecurityInformation;
527 sec_desc_buf sdbuf;
528 lsa_String unknown1;
529 lsa_String unknown2;
530 lsa_String unknown3;
531 lsa_String unknown4;
532 uint32 posix_offset;
533 uint32 unknown6;
534 uint32 unknown7;
535 uint32 unknown8;
536 } netr_DELTA_TRUSTED_DOMAIN;
538 typedef struct {
539 uint16 unknown;
540 } netr_DELTA_DELETE_TRUST;
542 typedef struct {
543 uint32 privilege_entries;
544 uint32 privilege_control;
545 [size_is(privilege_entries)] uint32 *privilege_attrib;
546 [size_is(privilege_entries)] lsa_String *privilege_name;
547 netr_QUOTA_LIMITS quotalimits;
548 uint32 system_flags;
549 uint32 SecurityInformation;
550 sec_desc_buf sdbuf;
551 lsa_String unknown1;
552 lsa_String unknown2;
553 lsa_String unknown3;
554 lsa_String unknown4;
555 uint32 unknown5;
556 uint32 unknown6;
557 uint32 unknown7;
558 uint32 unknown8;
559 } netr_DELTA_ACCOUNT;
561 typedef struct {
562 uint16 unknown;
563 } netr_DELTA_DELETE_ACCOUNT;
565 typedef struct {
566 uint16 unknown;
567 } netr_DELTA_DELETE_SECRET;
569 typedef struct {
570 uint32 len;
571 uint32 maxlen;
572 [size_is(maxlen)][length_is(len)] uint8 *cipher_data;
573 } netr_CIPHER_VALUE;
575 typedef struct {
576 netr_CIPHER_VALUE current_cipher;
577 NTTIME current_cipher_set_time;
578 netr_CIPHER_VALUE old_cipher;
579 NTTIME old_cipher_set_time;
580 uint32 SecurityInformation;
581 sec_desc_buf sdbuf;
582 lsa_String unknown1;
583 lsa_String unknown2;
584 lsa_String unknown3;
585 lsa_String unknown4;
586 uint32 unknown5;
587 uint32 unknown6;
588 uint32 unknown7;
589 uint32 unknown8;
590 } netr_DELTA_SECRET;
592 typedef enum {
593 NETR_DELTA_DOMAIN = 1,
594 NETR_DELTA_GROUP = 2,
595 NETR_DELTA_DELETE_GROUP = 3,
596 NETR_DELTA_RENAME_GROUP = 4,
597 NETR_DELTA_USER = 5,
598 NETR_DELTA_DELETE_USER = 6,
599 NETR_DELTA_RENAME_USER = 7,
600 NETR_DELTA_GROUP_MEMBER = 8,
601 NETR_DELTA_ALIAS = 9,
602 NETR_DELTA_DELETE_ALIAS = 10,
603 NETR_DELTA_RENAME_ALIAS = 11,
604 NETR_DELTA_ALIAS_MEMBER = 12,
605 NETR_DELTA_POLICY = 13,
606 NETR_DELTA_TRUSTED_DOMAIN = 14,
607 NETR_DELTA_DELETE_TRUST = 15,
608 NETR_DELTA_ACCOUNT = 16,
609 NETR_DELTA_DELETE_ACCOUNT = 17,
610 NETR_DELTA_SECRET = 18,
611 NETR_DELTA_DELETE_SECRET = 19,
612 NETR_DELTA_DELETE_GROUP2 = 20,
613 NETR_DELTA_DELETE_USER2 = 21,
614 NETR_DELTA_MODIFY_COUNT = 22
615 } netr_DeltaEnum;
617 typedef [switch_type(netr_DeltaEnum)] union {
618 [case(NETR_DELTA_DOMAIN)] netr_DELTA_DOMAIN *domain;
619 [case(NETR_DELTA_GROUP)] netr_DELTA_GROUP *group;
620 [case(NETR_DELTA_DELETE_GROUP)] ; /* rid only */
621 [case(NETR_DELTA_RENAME_GROUP)] netr_DELTA_RENAME *rename_group;
622 [case(NETR_DELTA_USER)] netr_DELTA_USER *user;
623 [case(NETR_DELTA_DELETE_USER)] ; /* rid only */
624 [case(NETR_DELTA_RENAME_USER)] netr_DELTA_RENAME *rename_user;
625 [case(NETR_DELTA_GROUP_MEMBER)] netr_DELTA_GROUP_MEMBER *group_member;
626 [case(NETR_DELTA_ALIAS)] netr_DELTA_ALIAS *alias;
627 [case(NETR_DELTA_DELETE_ALIAS)] ; /* rid only */
628 [case(NETR_DELTA_RENAME_ALIAS)] netr_DELTA_RENAME *rename_alias;
629 [case(NETR_DELTA_ALIAS_MEMBER)] netr_DELTA_ALIAS_MEMBER *alias_member;
630 [case(NETR_DELTA_POLICY)] netr_DELTA_POLICY *policy;
631 [case(NETR_DELTA_TRUSTED_DOMAIN)] netr_DELTA_TRUSTED_DOMAIN *trusted_domain;
632 [case(NETR_DELTA_DELETE_TRUST)] netr_DELTA_DELETE_TRUST delete_trust;
633 [case(NETR_DELTA_ACCOUNT)] netr_DELTA_ACCOUNT *account;
634 [case(NETR_DELTA_DELETE_ACCOUNT)] netr_DELTA_DELETE_ACCOUNT delete_account;
635 [case(NETR_DELTA_SECRET)] netr_DELTA_SECRET *secret;
636 [case(NETR_DELTA_DELETE_SECRET)] netr_DELTA_DELETE_SECRET delete_secret;
637 [case(NETR_DELTA_DELETE_GROUP2)] netr_DELTA_DELETE_USER *delete_group;
638 [case(NETR_DELTA_DELETE_USER2)] netr_DELTA_DELETE_USER *delete_user;
639 [case(NETR_DELTA_MODIFY_COUNT)] udlong *modified_count;
640 } netr_DELTA_UNION;
642 typedef [switch_type(netr_DeltaEnum)] union {
643 [case(NETR_DELTA_DOMAIN)] uint32 rid;
644 [case(NETR_DELTA_GROUP)] uint32 rid;
645 [case(NETR_DELTA_DELETE_GROUP)] uint32 rid;
646 [case(NETR_DELTA_RENAME_GROUP)] uint32 rid;
647 [case(NETR_DELTA_USER)] uint32 rid;
648 [case(NETR_DELTA_DELETE_USER)] uint32 rid;
649 [case(NETR_DELTA_RENAME_USER)] uint32 rid;
650 [case(NETR_DELTA_GROUP_MEMBER)] uint32 rid;
651 [case(NETR_DELTA_ALIAS)] uint32 rid;
652 [case(NETR_DELTA_DELETE_ALIAS)] uint32 rid;
653 [case(NETR_DELTA_RENAME_ALIAS)] uint32 rid;
654 [case(NETR_DELTA_ALIAS_MEMBER)] uint32 rid;
655 [case(NETR_DELTA_POLICY)] dom_sid2 *sid;
656 [case(NETR_DELTA_TRUSTED_DOMAIN)] dom_sid2 *sid;
657 [case(NETR_DELTA_DELETE_TRUST)] dom_sid2 *sid;
658 [case(NETR_DELTA_ACCOUNT)] dom_sid2 *sid;
659 [case(NETR_DELTA_DELETE_ACCOUNT)] dom_sid2 *sid;
660 [case(NETR_DELTA_SECRET)] [string,charset(UTF16)] uint16 *name;
661 [case(NETR_DELTA_DELETE_SECRET)] [string,charset(UTF16)] uint16 *name;
662 [case(NETR_DELTA_DELETE_GROUP2)] uint32 rid;
663 [case(NETR_DELTA_DELETE_USER2)] uint32 rid;
664 [case(NETR_DELTA_MODIFY_COUNT)] ;
665 } netr_DELTA_ID_UNION;
667 typedef struct {
668 netr_DeltaEnum delta_type;
669 [switch_is(delta_type)] netr_DELTA_ID_UNION delta_id_union;
670 [switch_is(delta_type)] netr_DELTA_UNION delta_union;
671 } netr_DELTA_ENUM;
673 typedef struct {
674 uint32 num_deltas;
675 [size_is(num_deltas)] netr_DELTA_ENUM *delta_enum;
676 } netr_DELTA_ENUM_ARRAY;
679 NTSTATUS netr_DatabaseDeltas(
680 [in] [string,charset(UTF16)] uint16 logon_server[],
681 [in] [string,charset(UTF16)] uint16 computername[],
682 [in] netr_Authenticator credential,
683 [in,out] netr_Authenticator return_authenticator,
684 [in] netr_SamDatabaseID database_id,
685 [in,out] udlong sequence_num,
686 [in] uint32 preferredmaximumlength,
687 [out] netr_DELTA_ENUM_ARRAY *delta_enum_array
691 /*****************/
692 /* Function 0x08 */
694 NTSTATUS netr_DatabaseSync(
695 [in] [string,charset(UTF16)] uint16 logon_server[],
696 [in] [string,charset(UTF16)] uint16 computername[],
697 [in] netr_Authenticator credential,
698 [in,out] netr_Authenticator return_authenticator,
699 [in] netr_SamDatabaseID database_id,
700 [in,out] uint32 sync_context,
701 [in] uint32 preferredmaximumlength,
702 [out] netr_DELTA_ENUM_ARRAY *delta_enum_array
706 /*****************/
707 /* Function 0x09 */
709 /* w2k3 returns NT_STATUS_NOT_IMPLEMENTED for this call */
711 typedef [flag(NDR_PAHEX)] struct {
712 uint8 computer_name[16];
713 uint32 timecreated;
714 uint32 serial_number;
715 } netr_UAS_INFO_0;
717 typedef struct {
718 [flag(NDR_REMAINING)] DATA_BLOB blob;
719 } netr_AccountBuffer;
721 NTSTATUS netr_AccountDeltas(
722 [in] [string,charset(UTF16)] uint16 *logon_server,
723 [in] [string,charset(UTF16)] uint16 computername[],
724 [in] netr_Authenticator credential,
725 [in,out] netr_Authenticator return_authenticator,
726 [in] netr_UAS_INFO_0 uas,
727 [in] uint32 count,
728 [in] uint32 level,
729 [in] uint32 buffersize,
730 [out,subcontext(4)] netr_AccountBuffer buffer,
731 [out] uint32 count_returned,
732 [out] uint32 total_entries,
733 [out] netr_UAS_INFO_0 recordid
737 /*****************/
738 /* Function 0x0A */
740 NTSTATUS netr_AccountSync(
741 [in] [string,charset(UTF16)] uint16 *logon_server,
742 [in] [string,charset(UTF16)] uint16 computername[],
743 [in] netr_Authenticator credential,
744 [in,out] netr_Authenticator return_authenticator,
745 [in] uint32 reference,
746 [in] uint32 level,
747 [in] uint32 buffersize,
748 [out,subcontext(4)] netr_AccountBuffer buffer,
749 [out] uint32 count_returned,
750 [out] uint32 total_entries,
751 [out] uint32 next_reference,
752 [in,out] netr_UAS_INFO_0 recordid
756 /*****************/
757 /* Function 0x0B */
759 NTSTATUS netr_GetDcName(
760 [in] [string,charset(UTF16)] uint16 logon_server[],
761 [in] [string,charset(UTF16)] uint16 *domainname,
762 [out] [string,charset(UTF16)] uint16 *dcname
765 /*****************/
766 /* Function 0x0C */
768 typedef struct {
769 uint32 flags;
770 uint32 pdc_connection_status;
771 } netr_NETLOGON_INFO_1;
773 typedef struct {
774 uint32 flags;
775 uint32 pdc_connection_status;
776 [string,charset(UTF16)] uint16 trusted_dc_name[];
777 uint32 tc_connection_status;
778 } netr_NETLOGON_INFO_2;
780 typedef struct {
781 uint32 flags;
782 uint32 logon_attempts;
783 uint32 unknown1;
784 uint32 unknown2;
785 uint32 unknown3;
786 uint32 unknown4;
787 uint32 unknown5;
788 } netr_NETLOGON_INFO_3;
790 typedef union {
791 [case(1)] netr_NETLOGON_INFO_1 *info1;
792 [case(2)] netr_NETLOGON_INFO_2 *info2;
793 [case(3)] netr_NETLOGON_INFO_3 *info3;
794 } netr_CONTROL_QUERY_INFORMATION;
796 /* function_code values */
797 typedef [v1_enum] enum {
798 NETLOGON_CONTROL_REDISCOVER = 5,
799 NETLOGON_CONTROL_TC_QUERY = 6,
800 NETLOGON_CONTROL_TRANSPORT_NOTIFY = 7,
801 NETLOGON_CONTROL_SET_DBFLAG = 65534
802 } netr_LogonControlCode;
804 WERROR netr_LogonControl(
805 [in] [string,charset(UTF16)] uint16 *logon_server,
806 [in] netr_LogonControlCode function_code,
807 [in] uint32 level,
808 [out,switch_is(level)] netr_CONTROL_QUERY_INFORMATION info
812 /*****************/
813 /* Function 0x0D */
815 WERROR netr_GetAnyDCName(
816 [in] [string,charset(UTF16)] uint16 *logon_server,
817 [in] [string,charset(UTF16)] uint16 *domainname,
818 [out] [string,charset(UTF16)] uint16 *dcname
822 /*****************/
823 /* Function 0x0E */
825 typedef union {
826 [case(NETLOGON_CONTROL_REDISCOVER)] [string,charset(UTF16)] uint16 *domain;
827 [case(NETLOGON_CONTROL_TC_QUERY)] [string,charset(UTF16)] uint16 *domain;
828 [case(NETLOGON_CONTROL_TRANSPORT_NOTIFY)] [string,charset(UTF16)] uint16 *domain;
829 [case(NETLOGON_CONTROL_SET_DBFLAG)] uint32 debug_level;
830 } netr_CONTROL_DATA_INFORMATION;
832 WERROR netr_LogonControl2(
833 [in] [string,charset(UTF16)] uint16 *logon_server,
834 [in] uint32 function_code,
835 [in] uint32 level,
836 [in][switch_is(function_code)] netr_CONTROL_DATA_INFORMATION data,
837 [out][switch_is(level)] netr_CONTROL_QUERY_INFORMATION query
841 /* If this flag is not set, then the passwords and LM session keys are
842 * encrypted with DES calls. (And the user session key is
843 * unencrypted) */
844 const int NETLOGON_NEG_ARCFOUR = 0x00000004;
845 const int NETLOGON_NEG_128BIT = 0x00004000;
846 const int NETLOGON_NEG_SCHANNEL = 0x40000000;
848 /*****************/
849 /* Function 0x0F */
851 NTSTATUS netr_ServerAuthenticate2(
852 [in] [string,charset(UTF16)] uint16 *server_name,
853 [in] [string,charset(UTF16)] uint16 account_name[],
854 [in] netr_SchannelType secure_channel_type,
855 [in] [string,charset(UTF16)] uint16 computer_name[],
856 [in,out,ref] netr_Credential *credentials,
857 [in,out,ref] uint32 *negotiate_flags
861 /*****************/
862 /* Function 0x10 */
864 NTSTATUS netr_DatabaseSync2(
865 [in] [string,charset(UTF16)] uint16 logon_server[],
866 [in] [string,charset(UTF16)] uint16 computername[],
867 [in] netr_Authenticator credential,
868 [in,out] netr_Authenticator return_authenticator,
869 [in] netr_SamDatabaseID database_id,
870 [in] uint16 restart_state,
871 [in,out] uint32 sync_context,
872 [in] uint32 preferredmaximumlength,
873 [out] netr_DELTA_ENUM_ARRAY *delta_enum_array
877 /*****************/
878 /* Function 0x11 */
880 /* i'm not at all sure how this call works */
882 NTSTATUS netr_DatabaseRedo(
883 [in] [string,charset(UTF16)] uint16 logon_server[],
884 [in] [string,charset(UTF16)] uint16 computername[],
885 [in] netr_Authenticator credential,
886 [in,out] netr_Authenticator return_authenticator,
887 [in][size_is(change_log_entry_size)] uint8 *change_log_entry,
888 [in] uint32 change_log_entry_size,
889 [out] netr_DELTA_ENUM_ARRAY *delta_enum_array
893 /*****************/
894 /* Function 0x12 */
896 WERROR netr_LogonControl2Ex(
897 [in] [string,charset(UTF16)] uint16 *logon_server,
898 [in] uint32 function_code,
899 [in] uint32 level,
900 [in][switch_is(function_code)] netr_CONTROL_DATA_INFORMATION data,
901 [out][switch_is(level)] netr_CONTROL_QUERY_INFORMATION query
904 /*****************/
905 /* Function 0x13 */
906 WERROR netr_NETRENUMERATETRUSTEDDOMAINS() ;
908 /*****************/
909 /* Function 0x14 */
910 typedef struct {
911 [string,charset(UTF16)] uint16 *dc_unc;
912 [string,charset(UTF16)] uint16 *dc_address;
913 int32 dc_address_type;
914 GUID domain_guid;
915 [string,charset(UTF16)] uint16 *domain_name;
916 [string,charset(UTF16)] uint16 *forest_name;
917 uint32 dc_flags;
918 [string,charset(UTF16)] uint16 *dc_site_name;
919 [string,charset(UTF16)] uint16 *client_site_name;
920 } netr_DsRGetDCNameInfo;
922 WERROR netr_DsRGetDCName(
923 [in] [string,charset(UTF16)] uint16 *server_unc,
924 [in] [string,charset(UTF16)] uint16 *domain_name,
925 [in] GUID *domain_guid,
926 [in] GUID *site_guid,
927 [in] uint32 flags,
928 [out] netr_DsRGetDCNameInfo *info
931 /*****************/
932 /* Function 0x15 */
933 WERROR netr_NETRLOGONDUMMYROUTINE1();
935 /****************/
936 /* Function 0x16 */
937 WERROR netr_NETRLOGONSETSERVICEBITS();
939 /****************/
940 /* Function 0x17 */
941 WERROR netr_NETRLOGONGETTRUSTRID();
943 /****************/
944 /* Function 0x18 */
945 WERROR netr_NETRLOGONCOMPUTESERVERDIGEST();
947 /****************/
948 /* Function 0x19 */
949 WERROR netr_NETRLOGONCOMPUTECLIENTDIGEST();
951 /****************/
952 /* Function 0x1a */
953 NTSTATUS netr_ServerAuthenticate3(
954 [in] [string,charset(UTF16)] uint16 *server_name,
955 [in] [string,charset(UTF16)] uint16 account_name[],
956 [in] netr_SchannelType secure_channel_type,
957 [in] [string,charset(UTF16)] uint16 computer_name[],
958 [in,out,ref] netr_Credential *credentials,
959 [in,out,ref] uint32 *negotiate_flags,
960 [out,ref] uint32 *rid
963 /****************/
964 /* Function 0x1b */
966 WERROR netr_DsRGetDCNameEx(
967 [in] [string,charset(UTF16)] uint16 *server_unc,
968 [in] [string,charset(UTF16)] uint16 *domain_name,
969 [in] GUID *domain_guid,
970 [in] [string,charset(UTF16)] uint16 *site_name,
971 [in] uint32 flags,
972 [out] netr_DsRGetDCNameInfo *info
975 /****************/
976 /* Function 0x1c */
977 WERROR netr_DsRGetSiteName(
978 [in] [string,charset(UTF16)] uint16 *computer_name,
979 [out] [string,charset(UTF16)] uint16 *site
982 /****************/
983 /* Function 0x1d */
985 typedef struct {
986 uint32 length;
987 [size_is(length)] uint8 *data;
988 } netr_Blob;
990 typedef [flag(NDR_PAHEX)] struct {
991 uint16 length;
992 uint16 size;
993 [size_is(size/2),length_is(length/2)] uint16 *data;
994 } netr_BinaryString;
996 typedef struct {
997 netr_Blob blob;
998 [string,charset(UTF16)] uint16 *workstation_domain;
999 [string,charset(UTF16)] uint16 *workstation_site;
1000 [string,charset(UTF16)] uint16 *unknown1;
1001 [string,charset(UTF16)] uint16 *unknown2;
1002 [string,charset(UTF16)] uint16 *unknown3;
1003 [string,charset(UTF16)] uint16 *unknown4;
1004 netr_BinaryString blob2;
1005 lsa_String product;
1006 lsa_String unknown5;
1007 lsa_String unknown6;
1008 uint32 unknown7[4];
1009 } netr_DomainQuery1;
1011 typedef union {
1012 [case(1)] netr_DomainQuery1 *query1;
1013 [case(2)] netr_DomainQuery1 *query1;
1014 } netr_DomainQuery;
1016 typedef struct {
1017 lsa_String domainname;
1018 lsa_String fulldomainname;
1019 lsa_String forest;
1020 GUID guid;
1021 dom_sid2 *sid;
1022 netr_BinaryString unknown1[4];
1023 uint32 unknown[4];
1024 } netr_DomainTrustInfo;
1026 typedef struct {
1027 netr_DomainTrustInfo domaininfo;
1028 uint32 num_trusts;
1029 [size_is(num_trusts)] netr_DomainTrustInfo *trusts;
1030 uint32 unknown[14]; /* room for expansion? */
1031 } netr_DomainInfo1;
1033 typedef union {
1034 [case(1)] netr_DomainInfo1 *info1;
1035 [case(2)] netr_DomainInfo1 *info1;
1036 } netr_DomainInfo;
1038 NTSTATUS netr_LogonGetDomainInfo(
1039 [in] [string,charset(UTF16)] uint16 server_name[],
1040 [in] [string,charset(UTF16)] uint16 *computer_name,
1041 [in,ref] netr_Authenticator *credential,
1042 [in,out,ref] netr_Authenticator *return_authenticator,
1043 [in] uint32 level,
1044 [in,switch_is(level)] netr_DomainQuery query,
1045 [out,switch_is(level)] netr_DomainInfo info
1048 typedef [flag(NDR_PAHEX)] struct {
1049 uint16 data[256];
1050 uint32 length;
1051 } netr_CryptPassword;
1053 /*****************/
1054 /* Function 0x1e */
1055 NTSTATUS netr_ServerPasswordSet2(
1056 [in] [string,charset(UTF16)] uint16 *server_name,
1057 [in] [string,charset(UTF16)] uint16 account_name[],
1058 [in] netr_SchannelType secure_channel_type,
1059 [in] [string,charset(UTF16)] uint16 computer_name[],
1060 [in] netr_Authenticator credential,
1061 [in] netr_CryptPassword new_password,
1062 [out] netr_Authenticator return_authenticator
1065 /****************/
1066 /* Function 0x1f */
1067 WERROR netr_NETRSERVERPASSWORDGET();
1069 /****************/
1070 /* Function 0x20 */
1071 WERROR netr_NETRLOGONSENDTOSAM();
1073 /****************/
1074 /* Function 0x21 */
1075 WERROR netr_DSRADDRESSTOSITENAMESW();
1077 /****************/
1078 /* Function 0x22 */
1079 WERROR netr_DsRGetDCNameEx2(
1080 [in] [string,charset(UTF16)] uint16 *server_unc,
1081 [in] [string,charset(UTF16)] uint16 *client_account,
1082 [in] uint32 mask,
1083 [in] [string,charset(UTF16)] uint16 *domain_name,
1084 [in] GUID *domain_guid,
1085 [in] [string,charset(UTF16)] uint16 *site_name,
1086 [in] uint32 flags,
1087 [out] netr_DsRGetDCNameInfo *info
1090 /****************/
1091 /* Function 0x23 */
1092 WERROR netr_NETRLOGONGETTIMESERVICEPARENTDOMAIN();
1094 /****************/
1095 /* Function 0x24 */
1096 WERROR netr_NETRENUMERATETRUSTEDDOMAINSEX();
1098 /****************/
1099 /* Function 0x25 */
1100 WERROR netr_DSRADDRESSTOSITENAMESEXW();
1102 /****************/
1103 /* Function 0x26 */
1104 WERROR netr_DSRGETDCSITECOVERAGEW();
1106 /****************/
1107 /* Function 0x27 */
1108 NTSTATUS netr_LogonSamLogonEx(
1109 [in] [string,charset(UTF16)] uint16 *server_name,
1110 [in] [string,charset(UTF16)] uint16 *computer_name,
1111 [in] uint16 logon_level,
1112 [in] [switch_is(logon_level)] netr_LogonLevel logon,
1113 [in] uint16 validation_level,
1114 [out] [switch_is(validation_level)] netr_Validation validation,
1115 [out] uint8 authoritative,
1116 [in,out] uint32 flags
1119 /****************/
1120 /* Function 0x28 */
1122 typedef [bitmap32bit] bitmap {
1123 NETR_TRUST_FLAG_IN_FOREST = 0x00000001,
1124 NETR_TRUST_FLAG_OUTBOUND = 0x00000002,
1125 NETR_TRUST_FLAG_TREEROOT = 0x00000004,
1126 NETR_TRUST_FLAG_PRIMARY = 0x00000008,
1127 NETR_TRUST_FLAG_NATIVE = 0x00000010,
1128 NETR_TRUST_FLAG_INBOUND = 0x00000020
1129 } netr_TrustFlags;
1131 typedef [v1_enum] enum {
1132 NETR_TRUST_TYPE_DOWNLEVEL = 1,
1133 NETR_TRUST_TYPE_UPLEVEL = 2,
1134 NETR_TRUST_TYPE_MIT = 3,
1135 NETR_TRUST_TYPE_DCE = 4
1136 } netr_TrustType;
1138 typedef [bitmap32bit] bitmap {
1139 NETR_TRUST_ATTRIBUTE_NON_TRANSITIVE = 0x00000001,
1140 NETR_TRUST_ATTRIBUTE_UPLEVEL_ONLY = 0x00000002,
1141 NETR_TRUST_ATTRIBUTE_QUARANTINED_DOMAIN = 0x00000004,
1142 NETR_TRUST_ATTRIBUTE_FOREST_TRANSITIVE = 0x00000008,
1143 NETR_TRUST_ATTRIBUTE_CROSS_ORGANIZATION = 0x00000010,
1144 NETR_TRUST_ATTRIBUTE_WITHIN_FOREST = 0x00000020,
1145 NETR_TRUST_ATTRIBUTE_TREAT_AS_EXTERNAL = 0x00000040
1146 } netr_TrustAttributes;
1148 typedef struct {
1149 [string,charset(UTF16)] uint16 *netbios_name;
1150 [string,charset(UTF16)] uint16 *dns_name;
1151 netr_TrustFlags trust_flags;
1152 uint32 parent_index;
1153 netr_TrustType trust_type;
1154 netr_TrustAttributes trust_attributes;
1155 dom_sid2 *sid;
1156 GUID guid;
1157 } netr_DomainTrust;
1159 WERROR netr_DsrEnumerateDomainTrusts(
1160 [in] [string,charset(UTF16)] uint16 *server_name,
1161 [in] netr_TrustFlags trust_flags,
1162 [out] uint32 count,
1163 [out,size_is(count)] netr_DomainTrust *trusts
1167 /****************/
1168 /* Function 0x29 */
1169 WERROR netr_DSRDEREGISTERDNSHOSTRECORDS();
1171 /****************/
1172 /* Function 0x2a */
1173 WERROR netr_NETRSERVERTRUSTPASSWORDSGET();
1175 /****************/
1176 /* Function 0x2b */
1177 WERROR netr_DSRGETFORESTTRUSTINFORMATION();
1179 /****************/
1180 /* Function 0x2c */
1181 WERROR netr_NETRGETFORESTTRUSTINFORMATION();
1183 /****************/
1184 /* Function 0x2d */
1186 /* this is the ADS varient. I don't yet know what the "flags" are for */
1187 NTSTATUS netr_LogonSamLogonWithFlags(
1188 [in] [string,charset(UTF16)] uint16 *server_name,
1189 [in] [string,charset(UTF16)] uint16 *computer_name,
1190 [in] netr_Authenticator *credential,
1191 [in][out] netr_Authenticator *return_authenticator,
1192 [in] uint16 logon_level,
1193 [in] [switch_is(logon_level)] netr_LogonLevel logon,
1194 [in] uint16 validation_level,
1195 [out] [switch_is(validation_level)] netr_Validation validation,
1196 [out] uint8 authoritative,
1197 [in,out] uint32 flags
1200 /****************/
1201 /* Function 0x2e */
1202 WERROR netr_NETRSERVERGETTRUSTINFO();