3 much of this was derived from the ethereal sources - thanks to everyone
9 import
"lsa.idl", "samr.idl", "security.idl";
13 uuid("12345678-1234-abcd-ef00-01234567cffb"),
15 endpoint("ncacn_np:[\\pipe\\netlogon]","ncacn_ip_tcp:","ncalrpc:"),
16 pointer_default(unique),
17 pointer_default_top
(unique)
22 declare bitmap samr_AcctFlags
;
28 [string,charset
(UTF16
)] uint16
*account_name
;
39 time_t pw_must_change
;
40 [string,charset
(UTF16
)] uint16
*computer
;
41 [string,charset
(UTF16
)] uint16
*domain
;
42 [string,charset
(UTF16
)] uint16
*script_path
;
46 WERROR netr_LogonUasLogon
(
47 [in] [string,charset
(UTF16
)] uint16
*server_name
,
48 [in] [string,charset
(UTF16
)] uint16 account_name
[],
49 [in] [string,charset
(UTF16
)] uint16 workstation
[],
50 [out] netr_UasInfo
*info
62 WERROR netr_LogonUasLogoff
(
63 [in] [string,charset
(UTF16
)] uint16
*server_name
,
64 [in] [string,charset
(UTF16
)] uint16 account_name
[],
65 [in] [string,charset
(UTF16
)] uint16 workstation
[],
66 [out,ref] netr_UasLogoffInfo
*info
73 /* in netr_AcctLockStr size seems to be be 24, and rrenard thinks
74 that the structure of the bindata looks like this:
76 dlong lockout_duration;
78 uint32 bad_attempt_lockout;
81 but it doesn't look as though this structure is reflected at the
82 NDR level. Maybe it is left to the application to decode the bindata array.
87 [size_is(size
/2),length_is(length
/2)] uint16
*bindata
;
90 const int MSV1_0_CLEARTEXT_PASSWORD_ALLOWED
= 0x002;
91 const int MSV1_0_ALLOW_SERVER_TRUST_ACCOUNT
= 0x020;
92 const int MSV1_0_ALLOW_WORKSTATION_TRUST_ACCOUNT
= 0x800;
95 lsa_String domain_name
;
96 uint32 parameter_control
; /* see MSV1_0_* */
99 lsa_String account_name
;
100 lsa_String workstation
;
104 netr_IdentityInfo identity_info
;
105 samr_Password lmpassword
;
106 samr_Password ntpassword
;
109 typedef [flag
(NDR_PAHEX
)] struct {
111 [value
(length
)] uint16 size
;
112 [size_is(length
),length_is(length
)] uint8
*data
;
113 } netr_ChallengeResponse
;
115 typedef [flag
(NDR_PAHEX
)] struct {
116 netr_IdentityInfo identity_info
;
118 netr_ChallengeResponse nt
;
119 netr_ChallengeResponse lm
;
122 typedef [public,switch_type(uint16
)] union {
123 [case(1)] netr_PasswordInfo
*password
;
124 [case(2)] netr_NetworkInfo
*network
;
125 [case(3)] netr_PasswordInfo
*password
;
126 [case(5)] netr_PasswordInfo
*password
;
127 [case(6)] netr_NetworkInfo
*network
;
130 typedef [public] struct {
133 } netr_GroupMembership
;
135 typedef [public,flag
(NDR_PAHEX
)] struct {
137 } netr_UserSessionKey
;
139 typedef [public,flag
(NDR_PAHEX
)] struct {
143 /* Flags for user_flags below */
144 typedef [public,bitmap32bit
] bitmap
{
145 NETLOGON_GUEST
= 0x0001,
146 NETLOGON_NOENCRYPTION
= 0x0002,
147 NETLOGON_CACHED_ACCOUNT
= 0x0004,
148 NETLOGON_USED_LM_PASSWORD
= 0x0008,
149 NETLOGON_EXTRA_SIDS
= 0x0020,
150 NETLOGON_SUBAUTH_SESSION_KEY
= 0x0040,
151 NETLOGON_SERVER_TRUST_ACCOUNT
= 0x0080,
152 NETLOGON_NTLMV2_ENABLED
= 0x0100,
153 NETLOGON_RESOURCE_GROUPS
= 0x0200,
154 NETLOGON_PROFILE_PATH_RETURNED
= 0x0400
161 NTTIME last_password_change
;
162 NTTIME allow_password_change
;
163 NTTIME force_password_change
;
164 lsa_String account_name
;
165 lsa_String full_name
;
166 lsa_String logon_script
;
167 lsa_String profile_path
;
168 lsa_String home_directory
;
169 lsa_String home_drive
;
171 uint16 bad_password_count
;
174 samr_RidWithAttributeArray groups
;
175 netr_UserFlags user_flags
;
176 netr_UserSessionKey key
;
177 lsa_StringLarge logon_server
;
178 lsa_StringLarge domain
;
179 dom_sid2
*domain_sid
;
180 netr_LMSessionKey LMSessKey
;
181 samr_AcctFlags acct_flags
;
186 netr_SamBaseInfo base
;
194 typedef [public] struct {
195 netr_SamBaseInfo base
;
197 [size_is(sidcount
)] netr_SidAttr
*sids
;
201 netr_SamBaseInfo base
;
203 [size_is(sidcount
)] netr_SidAttr
*sids
;
205 lsa_String principle
;
211 [size_is(pac_size
)] uint8
*pac
;
212 lsa_String logon_domain
;
213 lsa_String logon_server
;
214 lsa_String principal_name
;
216 [size_is(auth_size
)] uint8
*auth
;
217 netr_UserSessionKey user_session_key
;
218 uint32 expansionroom
[10];
225 typedef [public,switch_type(uint16
)] union {
226 [case(2)] netr_SamInfo2
*sam2
;
227 [case(3)] netr_SamInfo3
*sam3
;
228 [case(4)] netr_PacInfo
*pac
;
229 [case(5)] netr_PacInfo
*pac
;
230 [case(6)] netr_SamInfo6
*sam6
;
233 typedef [public, flag
(NDR_PAHEX
)] struct {
237 typedef [public] struct {
238 netr_Credential cred
;
240 } netr_Authenticator
;
242 NTSTATUS netr_LogonSamLogon
(
243 [in] [string,charset
(UTF16
)] uint16
*server_name
,
244 [in] [string,charset
(UTF16
)] uint16
*computer_name
,
245 [in] netr_Authenticator
*credential
,
246 [in][out] netr_Authenticator
*return_authenticator
,
247 [in] uint16 logon_level
,
248 [in] [switch_is(logon_level
)] netr_LogonLevel logon
,
249 [in] uint16 validation_level
,
250 [out,ref] [switch_is(validation_level
)] netr_Validation
*validation
,
251 [out,ref] uint8
*authoritative
258 NTSTATUS netr_LogonSamLogoff
(
259 [in] [string,charset
(UTF16
)] uint16
*server_name
,
260 [in] [string,charset
(UTF16
)] uint16
*computer_name
,
261 [in] netr_Authenticator
*credential
,
262 [in][out] netr_Authenticator
*return_authenticator
,
263 [in] uint16 logon_level
,
264 [in] [switch_is(logon_level
)] netr_LogonLevel logon
272 NTSTATUS netr_ServerReqChallenge
(
273 [in,string,charset
(UTF16
)] uint16
*server_name
,
274 [in,string,charset
(UTF16
)] uint16 computer_name
[],
275 [in,out,ref] netr_Credential
*credentials
282 declare
enum netr_SchannelType
;
284 NTSTATUS netr_ServerAuthenticate
(
285 [in,string,charset
(UTF16
)] uint16
*server_name
,
286 [in,string,charset
(UTF16
)] uint16 account_name
[],
287 [in] netr_SchannelType secure_channel_type
,
288 [in,string,charset
(UTF16
)] uint16 computer_name
[],
289 [in,out,ref] netr_Credential
*credentials
296 NTSTATUS netr_ServerPasswordSet
(
297 [in] [string,charset
(UTF16
)] uint16
*server_name
,
298 [in] [string,charset
(UTF16
)] uint16 account_name
[],
299 [in] netr_SchannelType secure_channel_type
,
300 [in] [string,charset
(UTF16
)] uint16 computer_name
[],
301 [in] netr_Authenticator credential
,
302 [in] samr_Password new_password
,
303 [out,ref] netr_Authenticator
*return_authenticator
310 declare
enum netr_SamDatabaseID
;
313 [string,charset
(UTF16
)] uint16
*account_name
;
322 } netr_DELTA_DELETE_USER
;
326 [value
(length
)] uint16 size
;
338 uint8 nt_history
[nt_length
];
339 uint8 lm_history
[lm_length
];
340 } netr_PasswordHistory
;
343 netr_USER_KEY16 lmpassword
;
344 netr_USER_KEY16 ntpassword
;
345 netr_PasswordHistory lmhistory
;
349 netr_USER_KEYS2 keys2
;
350 } netr_USER_KEY_UNION
;
352 typedef [public] struct {
354 netr_USER_KEY_UNION keys
;
358 boolean8 SensitiveDataFlag
;
361 /* netr_USER_KEYS encrypted with the session key */
362 [size_is(DataLength
)][flag
(NDR_PAHEX
)] uint8
*SensitiveData
;
363 } netr_USER_PRIVATE_INFO
;
366 lsa_String account_name
;
367 lsa_String full_name
;
370 lsa_String home_directory
;
371 lsa_String home_drive
;
372 lsa_String logon_script
;
373 lsa_String description
;
374 lsa_String workstations
;
377 samr_LogonHours logon_hours
;
378 uint16 bad_password_count
;
380 NTTIME last_password_change
;
382 samr_AcctFlags acct_flags
;
383 samr_Password lmpassword
;
384 samr_Password ntpassword
;
385 boolean8 nt_password_present
;
386 boolean8 lm_password_present
;
387 boolean8 password_expired
;
389 lsa_String parameters
;
392 netr_USER_PRIVATE_INFO user_private_info
;
393 uint32 SecurityInformation
;
395 lsa_String profile_path
;
406 lsa_String domain_name
;
408 dlong force_logoff_time
;
409 uint16 min_password_length
;
410 uint16 password_history_length
;
411 /* yes, these are signed. They are in negative 100ns */
412 dlong max_password_age
;
413 dlong min_password_age
;
415 NTTIME domain_create_time
;
416 uint32 SecurityInformation
;
418 netr_AcctLockStr account_lockout
;
422 uint32 logon_to_chgpass
;
429 lsa_String group_name
;
432 lsa_String description
;
433 uint32 SecurityInformation
;
459 [size_is(num_rids
)] uint32
*rids
;
460 [size_is(num_rids
)] uint32
*attribs
;
466 } netr_DELTA_GROUP_MEMBER
;
469 lsa_String alias_name
;
471 uint32 SecurityInformation
;
473 lsa_String description
;
489 } netr_DELTA_ALIAS_MEMBER
;
492 uint32 pagedpoollimit
;
493 uint32 nonpagedpoollimit
;
494 uint32 minimumworkingsetsize
;
495 uint32 maximumworkingsetsize
;
496 uint32 pagefilelimit
;
502 NTTIME auditretentionperiod
;
503 boolean8 auditingmode
;
504 uint32 maxauditeventcount
;
505 [size_is(maxauditeventcount
+1)] uint32
*eventauditoptions
;
506 lsa_String primary_domain_name
;
508 netr_QUOTA_LIMITS quota_limits
;
510 NTTIME db_create_time
;
511 uint32 SecurityInformation
;
524 lsa_String domain_name
;
525 uint32 num_controllers
;
526 [size_is(num_controllers
)] lsa_String
*controller_names
;
527 uint32 SecurityInformation
;
537 } netr_DELTA_TRUSTED_DOMAIN
;
541 } netr_DELTA_DELETE_TRUST
;
544 uint32 privilege_entries
;
545 uint32 privilege_control
;
546 [size_is(privilege_entries
)] uint32
*privilege_attrib
;
547 [size_is(privilege_entries
)] lsa_String
*privilege_name
;
548 netr_QUOTA_LIMITS quotalimits
;
550 uint32 SecurityInformation
;
560 } netr_DELTA_ACCOUNT
;
564 } netr_DELTA_DELETE_ACCOUNT
;
568 } netr_DELTA_DELETE_SECRET
;
573 [size_is(maxlen
)][length_is(len
)] uint8
*cipher_data
;
577 netr_CIPHER_VALUE current_cipher
;
578 NTTIME current_cipher_set_time
;
579 netr_CIPHER_VALUE old_cipher
;
580 NTTIME old_cipher_set_time
;
581 uint32 SecurityInformation
;
594 NETR_DELTA_DOMAIN
= 1,
595 NETR_DELTA_GROUP
= 2,
596 NETR_DELTA_DELETE_GROUP
= 3,
597 NETR_DELTA_RENAME_GROUP
= 4,
599 NETR_DELTA_DELETE_USER
= 6,
600 NETR_DELTA_RENAME_USER
= 7,
601 NETR_DELTA_GROUP_MEMBER
= 8,
602 NETR_DELTA_ALIAS
= 9,
603 NETR_DELTA_DELETE_ALIAS
= 10,
604 NETR_DELTA_RENAME_ALIAS
= 11,
605 NETR_DELTA_ALIAS_MEMBER
= 12,
606 NETR_DELTA_POLICY
= 13,
607 NETR_DELTA_TRUSTED_DOMAIN
= 14,
608 NETR_DELTA_DELETE_TRUST
= 15,
609 NETR_DELTA_ACCOUNT
= 16,
610 NETR_DELTA_DELETE_ACCOUNT
= 17,
611 NETR_DELTA_SECRET
= 18,
612 NETR_DELTA_DELETE_SECRET
= 19,
613 NETR_DELTA_DELETE_GROUP2
= 20,
614 NETR_DELTA_DELETE_USER2
= 21,
615 NETR_DELTA_MODIFY_COUNT
= 22
618 typedef [switch_type(netr_DeltaEnum
)] union {
619 [case(NETR_DELTA_DOMAIN
)] netr_DELTA_DOMAIN
*domain
;
620 [case(NETR_DELTA_GROUP
)] netr_DELTA_GROUP
*group
;
621 [case(NETR_DELTA_DELETE_GROUP
)] ; /* rid only */
622 [case(NETR_DELTA_RENAME_GROUP
)] netr_DELTA_RENAME
*rename_group
;
623 [case(NETR_DELTA_USER
)] netr_DELTA_USER
*user
;
624 [case(NETR_DELTA_DELETE_USER
)] ; /* rid only */
625 [case(NETR_DELTA_RENAME_USER
)] netr_DELTA_RENAME
*rename_user
;
626 [case(NETR_DELTA_GROUP_MEMBER
)] netr_DELTA_GROUP_MEMBER
*group_member
;
627 [case(NETR_DELTA_ALIAS
)] netr_DELTA_ALIAS
*alias
;
628 [case(NETR_DELTA_DELETE_ALIAS
)] ; /* rid only */
629 [case(NETR_DELTA_RENAME_ALIAS
)] netr_DELTA_RENAME
*rename_alias
;
630 [case(NETR_DELTA_ALIAS_MEMBER
)] netr_DELTA_ALIAS_MEMBER
*alias_member
;
631 [case(NETR_DELTA_POLICY
)] netr_DELTA_POLICY
*policy
;
632 [case(NETR_DELTA_TRUSTED_DOMAIN
)] netr_DELTA_TRUSTED_DOMAIN
*trusted_domain
;
633 [case(NETR_DELTA_DELETE_TRUST
)] netr_DELTA_DELETE_TRUST delete_trust
;
634 [case(NETR_DELTA_ACCOUNT
)] netr_DELTA_ACCOUNT
*account
;
635 [case(NETR_DELTA_DELETE_ACCOUNT
)] netr_DELTA_DELETE_ACCOUNT delete_account
;
636 [case(NETR_DELTA_SECRET
)] netr_DELTA_SECRET
*secret
;
637 [case(NETR_DELTA_DELETE_SECRET
)] netr_DELTA_DELETE_SECRET delete_secret
;
638 [case(NETR_DELTA_DELETE_GROUP2
)] netr_DELTA_DELETE_USER
*delete_group
;
639 [case(NETR_DELTA_DELETE_USER2
)] netr_DELTA_DELETE_USER
*delete_user
;
640 [case(NETR_DELTA_MODIFY_COUNT
)] udlong
*modified_count
;
643 typedef [switch_type(netr_DeltaEnum
)] union {
644 [case(NETR_DELTA_DOMAIN
)] uint32 rid
;
645 [case(NETR_DELTA_GROUP
)] uint32 rid
;
646 [case(NETR_DELTA_DELETE_GROUP
)] uint32 rid
;
647 [case(NETR_DELTA_RENAME_GROUP
)] uint32 rid
;
648 [case(NETR_DELTA_USER
)] uint32 rid
;
649 [case(NETR_DELTA_DELETE_USER
)] uint32 rid
;
650 [case(NETR_DELTA_RENAME_USER
)] uint32 rid
;
651 [case(NETR_DELTA_GROUP_MEMBER
)] uint32 rid
;
652 [case(NETR_DELTA_ALIAS
)] uint32 rid
;
653 [case(NETR_DELTA_DELETE_ALIAS
)] uint32 rid
;
654 [case(NETR_DELTA_RENAME_ALIAS
)] uint32 rid
;
655 [case(NETR_DELTA_ALIAS_MEMBER
)] uint32 rid
;
656 [case(NETR_DELTA_POLICY
)] dom_sid2
*sid
;
657 [case(NETR_DELTA_TRUSTED_DOMAIN
)] dom_sid2
*sid
;
658 [case(NETR_DELTA_DELETE_TRUST
)] dom_sid2
*sid
;
659 [case(NETR_DELTA_ACCOUNT
)] dom_sid2
*sid
;
660 [case(NETR_DELTA_DELETE_ACCOUNT
)] dom_sid2
*sid
;
661 [case(NETR_DELTA_SECRET
)] [string,charset
(UTF16
)] uint16
*name
;
662 [case(NETR_DELTA_DELETE_SECRET
)] [string,charset
(UTF16
)] uint16
*name
;
663 [case(NETR_DELTA_DELETE_GROUP2
)] uint32 rid
;
664 [case(NETR_DELTA_DELETE_USER2
)] uint32 rid
;
665 [case(NETR_DELTA_MODIFY_COUNT
)] ;
666 } netr_DELTA_ID_UNION
;
669 netr_DeltaEnum delta_type
;
670 [switch_is(delta_type
)] netr_DELTA_ID_UNION delta_id_union
;
671 [switch_is(delta_type
)] netr_DELTA_UNION delta_union
;
676 [size_is(num_deltas
)] netr_DELTA_ENUM
*delta_enum
;
677 } netr_DELTA_ENUM_ARRAY
;
680 NTSTATUS netr_DatabaseDeltas
(
681 [in] [string,charset
(UTF16
)] uint16 logon_server
[],
682 [in] [string,charset
(UTF16
)] uint16 computername
[],
683 [in] netr_Authenticator credential
,
684 [in,out,ref] netr_Authenticator
*return_authenticator
,
685 [in] netr_SamDatabaseID database_id
,
686 [in,out,ref] udlong
*sequence_num
,
687 [in] uint32 preferredmaximumlength
,
688 [out] netr_DELTA_ENUM_ARRAY
*delta_enum_array
695 NTSTATUS netr_DatabaseSync
(
696 [in] [string,charset
(UTF16
)] uint16 logon_server
[],
697 [in] [string,charset
(UTF16
)] uint16 computername
[],
698 [in] netr_Authenticator credential
,
699 [in,out,ref] netr_Authenticator
*return_authenticator
,
700 [in] netr_SamDatabaseID database_id
,
701 [in,out,ref] uint32
*sync_context
,
702 [in] uint32 preferredmaximumlength
,
703 [out] netr_DELTA_ENUM_ARRAY
*delta_enum_array
710 /* w2k3 returns NT_STATUS_NOT_IMPLEMENTED for this call */
712 typedef [flag
(NDR_PAHEX
)] struct {
713 uint8 computer_name
[16];
715 uint32 serial_number
;
719 [flag
(NDR_REMAINING
)] DATA_BLOB blob
;
720 } netr_AccountBuffer
;
722 NTSTATUS netr_AccountDeltas
(
723 [in] [string,charset
(UTF16
)] uint16
*logon_server
,
724 [in] [string,charset
(UTF16
)] uint16 computername
[],
725 [in] netr_Authenticator credential
,
726 [in,out,ref] netr_Authenticator
*return_authenticator
,
727 [in] netr_UAS_INFO_0 uas
,
730 [in] uint32 buffersize
,
731 [out,ref,subcontext
(4)] netr_AccountBuffer
*buffer
,
732 [out,ref] uint32
*count_returned
,
733 [out,ref] uint32
*total_entries
,
734 [out,ref] netr_UAS_INFO_0
*recordid
741 NTSTATUS netr_AccountSync
(
742 [in] [string,charset
(UTF16
)] uint16
*logon_server
,
743 [in] [string,charset
(UTF16
)] uint16 computername
[],
744 [in] netr_Authenticator credential
,
745 [in,out,ref] netr_Authenticator
*return_authenticator
,
746 [in] uint32 reference
,
748 [in] uint32 buffersize
,
749 [out,ref,subcontext
(4)] netr_AccountBuffer
*buffer
,
750 [out,ref] uint32
*count_returned
,
751 [out,ref] uint32
*total_entries
,
752 [out,ref] uint32
*next_reference
,
753 [in,out,ref] netr_UAS_INFO_0
*recordid
760 NTSTATUS netr_GetDcName
(
761 [in] [string,charset
(UTF16
)] uint16 logon_server
[],
762 [in] [string,charset
(UTF16
)] uint16
*domainname
,
763 [out,ref] [string,charset
(UTF16
)] uint16
**dcname
771 uint32 pdc_connection_status
;
772 } netr_NETLOGON_INFO_1
;
776 uint32 pdc_connection_status
;
777 [string,charset
(UTF16
)] uint16 trusted_dc_name
[];
778 uint32 tc_connection_status
;
779 } netr_NETLOGON_INFO_2
;
783 uint32 logon_attempts
;
789 } netr_NETLOGON_INFO_3
;
792 [case(1)] netr_NETLOGON_INFO_1
*info1
;
793 [case(2)] netr_NETLOGON_INFO_2
*info2
;
794 [case(3)] netr_NETLOGON_INFO_3
*info3
;
795 } netr_CONTROL_QUERY_INFORMATION
;
797 /* function_code values */
798 typedef [v1_enum] enum {
799 NETLOGON_CONTROL_REDISCOVER
= 5,
800 NETLOGON_CONTROL_TC_QUERY
= 6,
801 NETLOGON_CONTROL_TRANSPORT_NOTIFY
= 7,
802 NETLOGON_CONTROL_SET_DBFLAG
= 65534
803 } netr_LogonControlCode
;
805 WERROR netr_LogonControl
(
806 [in] [string,charset
(UTF16
)] uint16
*logon_server
,
807 [in] netr_LogonControlCode function_code
,
809 [out,ref,switch_is(level
)] netr_CONTROL_QUERY_INFORMATION
*info
816 WERROR netr_GetAnyDCName
(
817 [in] [string,charset
(UTF16
)] uint16
*logon_server
,
818 [in] [string,charset
(UTF16
)] uint16
*domainname
,
819 [out,ref] [string,charset
(UTF16
)] uint16
**dcname
827 [case(NETLOGON_CONTROL_REDISCOVER
)] [string,charset
(UTF16
)] uint16
*domain
;
828 [case(NETLOGON_CONTROL_TC_QUERY
)] [string,charset
(UTF16
)] uint16
*domain
;
829 [case(NETLOGON_CONTROL_TRANSPORT_NOTIFY
)] [string,charset
(UTF16
)] uint16
*domain
;
830 [case(NETLOGON_CONTROL_SET_DBFLAG
)] uint32 debug_level
;
831 } netr_CONTROL_DATA_INFORMATION
;
833 WERROR netr_LogonControl2
(
834 [in] [string,charset
(UTF16
)] uint16
*logon_server
,
835 [in] uint32 function_code
,
837 [in][switch_is(function_code
)] netr_CONTROL_DATA_INFORMATION data
,
838 [out,ref][switch_is(level
)] netr_CONTROL_QUERY_INFORMATION
*query
842 /* If this flag is not set, then the passwords and LM session keys are
843 * encrypted with DES calls. (And the user session key is
845 const int NETLOGON_NEG_ARCFOUR
= 0x00000004;
846 const int NETLOGON_NEG_128BIT
= 0x00004000;
847 const int NETLOGON_NEG_SCHANNEL
= 0x40000000;
852 NTSTATUS netr_ServerAuthenticate2
(
853 [in] [string,charset
(UTF16
)] uint16
*server_name
,
854 [in] [string,charset
(UTF16
)] uint16 account_name
[],
855 [in] netr_SchannelType secure_channel_type
,
856 [in] [string,charset
(UTF16
)] uint16 computer_name
[],
857 [in,out,ref] netr_Credential
*credentials
,
858 [in,out,ref] uint32
*negotiate_flags
865 NTSTATUS netr_DatabaseSync2
(
866 [in] [string,charset
(UTF16
)] uint16 logon_server
[],
867 [in] [string,charset
(UTF16
)] uint16 computername
[],
868 [in] netr_Authenticator credential
,
869 [in,out,ref] netr_Authenticator
*return_authenticator
,
870 [in] netr_SamDatabaseID database_id
,
871 [in] uint16 restart_state
,
872 [in,out,ref] uint32
*sync_context
,
873 [in] uint32 preferredmaximumlength
,
874 [out] netr_DELTA_ENUM_ARRAY
*delta_enum_array
881 /* i'm not at all sure how this call works */
883 NTSTATUS netr_DatabaseRedo
(
884 [in] [string,charset
(UTF16
)] uint16 logon_server
[],
885 [in] [string,charset
(UTF16
)] uint16 computername
[],
886 [in] netr_Authenticator credential
,
887 [in,out,ref] netr_Authenticator
*return_authenticator
,
888 [in][size_is(change_log_entry_size
)] uint8
*change_log_entry
,
889 [in] uint32 change_log_entry_size
,
890 [out] netr_DELTA_ENUM_ARRAY
*delta_enum_array
897 WERROR netr_LogonControl2Ex
(
898 [in] [string,charset
(UTF16
)] uint16
*logon_server
,
899 [in] uint32 function_code
,
901 [in][switch_is(function_code
)] netr_CONTROL_DATA_INFORMATION data
,
902 [out,ref][switch_is(level
)] netr_CONTROL_QUERY_INFORMATION
*query
907 WERROR netr_NETRENUMERATETRUSTEDDOMAINS
() ;
912 [string,charset
(UTF16
)] uint16
*dc_unc
;
913 [string,charset
(UTF16
)] uint16
*dc_address
;
914 int32 dc_address_type
;
916 [string,charset
(UTF16
)] uint16
*domain_name
;
917 [string,charset
(UTF16
)] uint16
*forest_name
;
919 [string,charset
(UTF16
)] uint16
*dc_site_name
;
920 [string,charset
(UTF16
)] uint16
*client_site_name
;
921 } netr_DsRGetDCNameInfo
;
923 WERROR netr_DsRGetDCName
(
924 [in] [string,charset
(UTF16
)] uint16
*server_unc
,
925 [in] [string,charset
(UTF16
)] uint16
*domain_name
,
926 [in] GUID
*domain_guid
,
927 [in] GUID
*site_guid
,
929 [out] netr_DsRGetDCNameInfo
*info
934 WERROR netr_NETRLOGONDUMMYROUTINE1
();
938 WERROR netr_NETRLOGONSETSERVICEBITS
();
942 WERROR netr_NETRLOGONGETTRUSTRID
();
946 WERROR netr_NETRLOGONCOMPUTESERVERDIGEST
();
950 WERROR netr_NETRLOGONCOMPUTECLIENTDIGEST
();
954 NTSTATUS netr_ServerAuthenticate3
(
955 [in] [string,charset
(UTF16
)] uint16
*server_name
,
956 [in] [string,charset
(UTF16
)] uint16 account_name
[],
957 [in] netr_SchannelType secure_channel_type
,
958 [in] [string,charset
(UTF16
)] uint16 computer_name
[],
959 [in,out,ref] netr_Credential
*credentials
,
960 [in,out,ref] uint32
*negotiate_flags
,
961 [out,ref] uint32
*rid
967 WERROR netr_DsRGetDCNameEx
(
968 [in] [string,charset
(UTF16
)] uint16
*server_unc
,
969 [in] [string,charset
(UTF16
)] uint16
*domain_name
,
970 [in] GUID
*domain_guid
,
971 [in] [string,charset
(UTF16
)] uint16
*site_name
,
973 [out] netr_DsRGetDCNameInfo
*info
978 WERROR netr_DsRGetSiteName
(
979 [in] [string,charset
(UTF16
)] uint16
*computer_name
,
980 [out,ref] [string,charset
(UTF16
)] uint16
**site
988 [size_is(length
)] uint8
*data
;
991 typedef [flag
(NDR_PAHEX
)] struct {
994 [size_is(size
/2),length_is(length
/2)] uint16
*data
;
999 [string,charset
(UTF16
)] uint16
*workstation_domain
;
1000 [string,charset
(UTF16
)] uint16
*workstation_site
;
1001 [string,charset
(UTF16
)] uint16
*unknown1
;
1002 [string,charset
(UTF16
)] uint16
*unknown2
;
1003 [string,charset
(UTF16
)] uint16
*unknown3
;
1004 [string,charset
(UTF16
)] uint16
*unknown4
;
1005 netr_BinaryString blob2
;
1007 lsa_String unknown5
;
1008 lsa_String unknown6
;
1010 } netr_DomainQuery1
;
1013 [case(1)] netr_DomainQuery1
*query1
;
1014 [case(2)] netr_DomainQuery1
*query1
;
1018 lsa_String domainname
;
1019 lsa_String fulldomainname
;
1023 netr_BinaryString unknown1
[4];
1025 } netr_DomainTrustInfo
;
1028 netr_DomainTrustInfo domaininfo
;
1030 [size_is(num_trusts
)] netr_DomainTrustInfo
*trusts
;
1031 uint32 unknown
[14]; /* room for expansion? */
1035 [case(1)] netr_DomainInfo1
*info1
;
1036 [case(2)] netr_DomainInfo1
*info1
;
1039 NTSTATUS netr_LogonGetDomainInfo
(
1040 [in] [string,charset
(UTF16
)] uint16 server_name
[],
1041 [in] [string,charset
(UTF16
)] uint16
*computer_name
,
1042 [in,ref] netr_Authenticator
*credential
,
1043 [in,out,ref] netr_Authenticator
*return_authenticator
,
1045 [in,switch_is(level
)] netr_DomainQuery query
,
1046 [out,ref,switch_is(level
)] netr_DomainInfo
*info
1049 typedef [flag
(NDR_PAHEX
)] struct {
1052 } netr_CryptPassword
;
1056 NTSTATUS netr_ServerPasswordSet2
(
1057 [in] [string,charset
(UTF16
)] uint16
*server_name
,
1058 [in] [string,charset
(UTF16
)] uint16 account_name
[],
1059 [in] netr_SchannelType secure_channel_type
,
1060 [in] [string,charset
(UTF16
)] uint16 computer_name
[],
1061 [in] netr_Authenticator credential
,
1062 [in] netr_CryptPassword new_password
,
1063 [out,ref] netr_Authenticator
*return_authenticator
1068 WERROR netr_NETRSERVERPASSWORDGET
();
1072 WERROR netr_NETRLOGONSENDTOSAM
();
1076 WERROR netr_DSRADDRESSTOSITENAMESW
();
1080 WERROR netr_DsRGetDCNameEx2
(
1081 [in] [string,charset
(UTF16
)] uint16
*server_unc
,
1082 [in] [string,charset
(UTF16
)] uint16
*client_account
,
1084 [in] [string,charset
(UTF16
)] uint16
*domain_name
,
1085 [in] GUID
*domain_guid
,
1086 [in] [string,charset
(UTF16
)] uint16
*site_name
,
1088 [out] netr_DsRGetDCNameInfo
*info
1093 WERROR netr_NETRLOGONGETTIMESERVICEPARENTDOMAIN
();
1097 WERROR netr_NETRENUMERATETRUSTEDDOMAINSEX
();
1101 WERROR netr_DSRADDRESSTOSITENAMESEXW
();
1105 WERROR netr_DSRGETDCSITECOVERAGEW
();
1109 NTSTATUS netr_LogonSamLogonEx
(
1110 [in] [string,charset
(UTF16
)] uint16
*server_name
,
1111 [in] [string,charset
(UTF16
)] uint16
*computer_name
,
1112 [in] uint16 logon_level
,
1113 [in] [switch_is(logon_level
)] netr_LogonLevel logon
,
1114 [in] uint16 validation_level
,
1115 [out,ref] [switch_is(validation_level
)] netr_Validation
*validation
,
1116 [out,ref] uint8
*authoritative
,
1117 [in,out,ref] uint32
*flags
1123 typedef [bitmap32bit
] bitmap
{
1124 NETR_TRUST_FLAG_IN_FOREST
= 0x00000001,
1125 NETR_TRUST_FLAG_OUTBOUND
= 0x00000002,
1126 NETR_TRUST_FLAG_TREEROOT
= 0x00000004,
1127 NETR_TRUST_FLAG_PRIMARY
= 0x00000008,
1128 NETR_TRUST_FLAG_NATIVE
= 0x00000010,
1129 NETR_TRUST_FLAG_INBOUND
= 0x00000020
1132 typedef [v1_enum] enum {
1133 NETR_TRUST_TYPE_DOWNLEVEL
= 1,
1134 NETR_TRUST_TYPE_UPLEVEL
= 2,
1135 NETR_TRUST_TYPE_MIT
= 3,
1136 NETR_TRUST_TYPE_DCE
= 4
1139 typedef [bitmap32bit
] bitmap
{
1140 NETR_TRUST_ATTRIBUTE_NON_TRANSITIVE
= 0x00000001,
1141 NETR_TRUST_ATTRIBUTE_UPLEVEL_ONLY
= 0x00000002,
1142 NETR_TRUST_ATTRIBUTE_QUARANTINED_DOMAIN
= 0x00000004,
1143 NETR_TRUST_ATTRIBUTE_FOREST_TRANSITIVE
= 0x00000008,
1144 NETR_TRUST_ATTRIBUTE_CROSS_ORGANIZATION
= 0x00000010,
1145 NETR_TRUST_ATTRIBUTE_WITHIN_FOREST
= 0x00000020,
1146 NETR_TRUST_ATTRIBUTE_TREAT_AS_EXTERNAL
= 0x00000040
1147 } netr_TrustAttributes
;
1150 [string,charset
(UTF16
)] uint16
*netbios_name
;
1151 [string,charset
(UTF16
)] uint16
*dns_name
;
1152 netr_TrustFlags trust_flags
;
1153 uint32 parent_index
;
1154 netr_TrustType trust_type
;
1155 netr_TrustAttributes trust_attributes
;
1160 WERROR netr_DsrEnumerateDomainTrusts
(
1161 [in] [string,charset
(UTF16
)] uint16
*server_name
,
1162 [in] netr_TrustFlags trust_flags
,
1163 [out,ref] uint32
*count
,
1164 [out,ref,size_is(count
)] netr_DomainTrust
**trusts
1170 WERROR netr_DSRDEREGISTERDNSHOSTRECORDS
();
1174 WERROR netr_NETRSERVERTRUSTPASSWORDSGET
();
1178 WERROR netr_DSRGETFORESTTRUSTINFORMATION
();
1182 WERROR netr_NETRGETFORESTTRUSTINFORMATION
();
1187 /* this is the ADS varient. I don't yet know what the "flags" are for */
1188 NTSTATUS netr_LogonSamLogonWithFlags
(
1189 [in] [string,charset
(UTF16
)] uint16
*server_name
,
1190 [in] [string,charset
(UTF16
)] uint16
*computer_name
,
1191 [in] netr_Authenticator
*credential
,
1192 [in][out] netr_Authenticator
*return_authenticator
,
1193 [in] uint16 logon_level
,
1194 [in] [switch_is(logon_level
)] netr_LogonLevel logon
,
1195 [in] uint16 validation_level
,
1196 [out,ref] [switch_is(validation_level
)] netr_Validation
*validation
,
1197 [out,ref] uint8
*authoritative
,
1198 [in,out,ref] uint32
*flags
1203 WERROR netr_NETRSERVERGETTRUSTINFO
();