mirror of
https://github.com/samba-team/samba.git
synced 2025-01-27 14:04:05 +03:00
1883 lines
52 KiB
C
1883 lines
52 KiB
C
/* header auto-generated by pidl */
|
|
|
|
#include <stdint.h>
|
|
|
|
#include "libcli/util/ntstatus.h"
|
|
|
|
#include "librpc/gen_ndr/misc.h"
|
|
#include "librpc/gen_ndr/lsa.h"
|
|
#include "librpc/gen_ndr/samr.h"
|
|
#include "librpc/gen_ndr/security.h"
|
|
#include "librpc/gen_ndr/nbt.h"
|
|
#define netr_DeltaEnum8Bit netr_DeltaEnum
|
|
#define netr_SamDatabaseID8Bit netr_SamDatabaseID
|
|
#ifndef _HEADER_netlogon
|
|
#define _HEADER_netlogon
|
|
|
|
#define NETLOGON_NEG_128BIT ( NETLOGON_NEG_STRONG_KEYS )
|
|
#define NETLOGON_NEG_SCHANNEL ( NETLOGON_NEG_AUTHENTICATED_RPC )
|
|
#define DSGETDC_VALID_FLAGS ( (DS_FORCE_REDISCOVERY|DS_DIRECTORY_SERVICE_REQUIRED|DS_DIRECTORY_SERVICE_PREFERRED|DS_GC_SERVER_REQUIRED|DS_PDC_REQUIRED|DS_BACKGROUND_ONLY|DS_IP_REQUIRED|DS_KDC_REQUIRED|DS_TIMESERV_REQUIRED|DS_WRITABLE_REQUIRED|DS_GOOD_TIMESERV_PREFERRED|DS_AVOID_SELF|DS_ONLY_LDAP_NEEDED|DS_IS_FLAT_NAME|DS_IS_DNS_NAME|DS_RETURN_FLAT_NAME|DS_RETURN_DNS_NAME) )
|
|
#define DS_GFTI_UPDATE_TDO ( 0x1 )
|
|
struct netr_UasInfo {
|
|
const char *account_name;/* [unique,charset(UTF16)] */
|
|
uint32_t priv;
|
|
uint32_t auth_flags;
|
|
uint32_t logon_count;
|
|
uint32_t bad_pw_count;
|
|
time_t last_logon;
|
|
time_t last_logoff;
|
|
time_t logoff_time;
|
|
time_t kickoff_time;
|
|
uint32_t password_age;
|
|
time_t pw_can_change;
|
|
time_t pw_must_change;
|
|
const char *computer;/* [unique,charset(UTF16)] */
|
|
const char *domain;/* [unique,charset(UTF16)] */
|
|
const char *script_path;/* [unique,charset(UTF16)] */
|
|
uint32_t unknown;
|
|
};
|
|
|
|
struct netr_UasLogoffInfo {
|
|
uint32_t duration;
|
|
uint16_t logon_count;
|
|
};
|
|
|
|
struct netr_AcctLockStr {
|
|
int64_t lockout_duration;
|
|
uint64_t reset_count;
|
|
uint32_t bad_attempt_lockout;
|
|
uint32_t dummy;
|
|
}/* [public] */;
|
|
|
|
/* bitmap netr_LogonParameterControl */
|
|
#define MSV1_0_CLEARTEXT_PASSWORD_ALLOWED ( 0x00000002 )
|
|
#define MSV1_0_UPDATE_LOGON_STATISTICS ( 0x00000004 )
|
|
#define MSV1_0_RETURN_USER_PARAMETERS ( 0x00000008 )
|
|
#define MSV1_0_DONT_TRY_GUEST_ACCOUNT ( 0x00000010 )
|
|
#define MSV1_0_ALLOW_SERVER_TRUST_ACCOUNT ( 0x00000020 )
|
|
#define MSV1_0_RETURN_PASSWORD_EXPIRY ( 0x00000040 )
|
|
#define MSV1_0_USE_CLIENT_CHALLENGE ( 0x00000080 )
|
|
#define MSV1_0_TRY_GUEST_ACCOUNT_ONLY ( 0x00000100 )
|
|
#define MSV1_0_RETURN_PROFILE_PATH ( 0x00000200 )
|
|
#define MSV1_0_TRY_SPECIFIED_DOMAIN_ONLY ( 0x00000400 )
|
|
#define MSV1_0_ALLOW_WORKSTATION_TRUST_ACCOUNT ( 0x00000800 )
|
|
#define MSV1_0_DISABLE_PERSONAL_FALLBACK ( 0x00001000 )
|
|
#define MSV1_0_ALLOW_FORCE_GUEST ( 0x00002000 )
|
|
#define MSV1_0_CLEARTEXT_PASSWORD_SUPPLIED ( 0x00004000 )
|
|
#define MSV1_0_USE_DOMAIN_FOR_ROUTING_ONLY ( 0x00008000 )
|
|
#define MSV1_0_ALLOW_MSVCHAPV2 ( 0x00010000 )
|
|
#define MSV1_0_S4U2SELF ( 0x00020000 )
|
|
#define MSV1_0_CHECK_LOGONHOURS_FOR_S4U ( 0x00040000 )
|
|
#define MSV1_0_SUBAUTHENTICATION_DLL_EX ( 0x00100000 )
|
|
|
|
struct netr_IdentityInfo {
|
|
struct lsa_String domain_name;
|
|
uint32_t parameter_control;
|
|
uint32_t logon_id_low;
|
|
uint32_t logon_id_high;
|
|
struct lsa_String account_name;
|
|
struct lsa_String workstation;
|
|
};
|
|
|
|
struct netr_PasswordInfo {
|
|
struct netr_IdentityInfo identity_info;
|
|
struct samr_Password lmpassword;
|
|
struct samr_Password ntpassword;
|
|
};
|
|
|
|
struct netr_ChallengeResponse {
|
|
uint16_t length;
|
|
uint16_t size;/* [value(length)] */
|
|
uint8_t *data;/* [unique,length_is(length),size_is(length)] */
|
|
}/* [flag(LIBNDR_PRINT_ARRAY_HEX)] */;
|
|
|
|
struct netr_NetworkInfo {
|
|
struct netr_IdentityInfo identity_info;
|
|
uint8_t challenge[8];
|
|
struct netr_ChallengeResponse nt;
|
|
struct netr_ChallengeResponse lm;
|
|
}/* [flag(LIBNDR_PRINT_ARRAY_HEX)] */;
|
|
|
|
struct netr_GenericInfo {
|
|
struct netr_IdentityInfo identity_info;
|
|
struct lsa_String package_name;
|
|
uint32_t length;
|
|
uint8_t *data;/* [unique,size_is(length)] */
|
|
}/* [flag(LIBNDR_PRINT_ARRAY_HEX)] */;
|
|
|
|
enum netr_LogonInfoClass
|
|
#ifndef USE_UINT_ENUMS
|
|
{
|
|
NetlogonInteractiveInformation=(int)(1),
|
|
NetlogonNetworkInformation=(int)(2),
|
|
NetlogonServiceInformation=(int)(3),
|
|
NetlogonGenericInformation=(int)(4),
|
|
NetlogonInteractiveTransitiveInformation=(int)(5),
|
|
NetlogonNetworkTransitiveInformation=(int)(6),
|
|
NetlogonServiceTransitiveInformation=(int)(7)
|
|
}
|
|
#else
|
|
{ __donnot_use_enum_netr_LogonInfoClass=0x7FFFFFFF}
|
|
#define NetlogonInteractiveInformation ( 1 )
|
|
#define NetlogonNetworkInformation ( 2 )
|
|
#define NetlogonServiceInformation ( 3 )
|
|
#define NetlogonGenericInformation ( 4 )
|
|
#define NetlogonInteractiveTransitiveInformation ( 5 )
|
|
#define NetlogonNetworkTransitiveInformation ( 6 )
|
|
#define NetlogonServiceTransitiveInformation ( 7 )
|
|
#endif
|
|
;
|
|
|
|
union netr_LogonLevel {
|
|
struct netr_PasswordInfo *password;/* [unique,case(NetlogonInteractiveInformation)] */
|
|
struct netr_NetworkInfo *network;/* [unique,case(NetlogonNetworkInformation)] */
|
|
struct netr_GenericInfo *generic;/* [unique,case(NetlogonGenericInformation)] */
|
|
}/* [public,switch_type(netr_LogonInfoClass)] */;
|
|
|
|
struct netr_UserSessionKey {
|
|
uint8_t key[16];
|
|
}/* [public,flag(LIBNDR_PRINT_ARRAY_HEX)] */;
|
|
|
|
struct netr_LMSessionKey {
|
|
uint8_t key[8];
|
|
}/* [public,flag(LIBNDR_PRINT_ARRAY_HEX)] */;
|
|
|
|
/* bitmap netr_UserFlags */
|
|
#define NETLOGON_GUEST ( 0x00000001 )
|
|
#define NETLOGON_NOENCRYPTION ( 0x00000002 )
|
|
#define NETLOGON_CACHED_ACCOUNT ( 0x00000004 )
|
|
#define NETLOGON_USED_LM_PASSWORD ( 0x00000008 )
|
|
#define NETLOGON_EXTRA_SIDS ( 0x00000020 )
|
|
#define NETLOGON_SUBAUTH_SESSION_KEY ( 0x00000040 )
|
|
#define NETLOGON_SERVER_TRUST_ACCOUNT ( 0x00000080 )
|
|
#define NETLOGON_NTLMV2_ENABLED ( 0x00000100 )
|
|
#define NETLOGON_RESOURCE_GROUPS ( 0x00000200 )
|
|
#define NETLOGON_PROFILE_PATH_RETURNED ( 0x00000400 )
|
|
#define NETLOGON_GRACE_LOGON ( 0x01000000 )
|
|
|
|
struct netr_SamBaseInfo {
|
|
NTTIME last_logon;
|
|
NTTIME last_logoff;
|
|
NTTIME acct_expiry;
|
|
NTTIME last_password_change;
|
|
NTTIME allow_password_change;
|
|
NTTIME force_password_change;
|
|
struct lsa_String account_name;
|
|
struct lsa_String full_name;
|
|
struct lsa_String logon_script;
|
|
struct lsa_String profile_path;
|
|
struct lsa_String home_directory;
|
|
struct lsa_String home_drive;
|
|
uint16_t logon_count;
|
|
uint16_t bad_password_count;
|
|
uint32_t rid;
|
|
uint32_t primary_gid;
|
|
struct samr_RidWithAttributeArray groups;
|
|
uint32_t user_flags;
|
|
struct netr_UserSessionKey key;
|
|
struct lsa_StringLarge logon_server;
|
|
struct lsa_StringLarge domain;
|
|
struct dom_sid2 *domain_sid;/* [unique] */
|
|
struct netr_LMSessionKey LMSessKey;
|
|
uint32_t acct_flags;
|
|
uint32_t unknown[7];
|
|
};
|
|
|
|
struct netr_SamInfo2 {
|
|
struct netr_SamBaseInfo base;
|
|
};
|
|
|
|
struct netr_SidAttr {
|
|
struct dom_sid2 *sid;/* [unique] */
|
|
uint32_t attributes;
|
|
};
|
|
|
|
struct netr_SamInfo3 {
|
|
struct netr_SamBaseInfo base;
|
|
uint32_t sidcount;
|
|
struct netr_SidAttr *sids;/* [unique,size_is(sidcount)] */
|
|
}/* [public] */;
|
|
|
|
struct netr_SamInfo6 {
|
|
struct netr_SamBaseInfo base;
|
|
uint32_t sidcount;
|
|
struct netr_SidAttr *sids;/* [unique,size_is(sidcount)] */
|
|
struct lsa_String forest;
|
|
struct lsa_String principle;
|
|
uint32_t unknown4[20];
|
|
};
|
|
|
|
struct netr_PacInfo {
|
|
uint32_t pac_size;
|
|
uint8_t *pac;/* [unique,size_is(pac_size)] */
|
|
struct lsa_String logon_domain;
|
|
struct lsa_String logon_server;
|
|
struct lsa_String principal_name;
|
|
uint32_t auth_size;
|
|
uint8_t *auth;/* [unique,size_is(auth_size)] */
|
|
struct netr_UserSessionKey user_session_key;
|
|
uint32_t expansionroom[10];
|
|
struct lsa_String unknown1;
|
|
struct lsa_String unknown2;
|
|
struct lsa_String unknown3;
|
|
struct lsa_String unknown4;
|
|
};
|
|
|
|
struct netr_GenericInfo2 {
|
|
uint32_t length;
|
|
uint8_t *data;/* [unique,size_is(length)] */
|
|
}/* [flag(LIBNDR_PRINT_ARRAY_HEX)] */;
|
|
|
|
enum netr_ValidationInfoClass
|
|
#ifndef USE_UINT_ENUMS
|
|
{
|
|
NetlogonValidationUasInfo=(int)(1),
|
|
NetlogonValidationSamInfo=(int)(2),
|
|
NetlogonValidationSamInfo2=(int)(3),
|
|
NetlogonValidationGenericInfo2=(int)(5),
|
|
NetlogonValidationSamInfo4=(int)(6)
|
|
}
|
|
#else
|
|
{ __donnot_use_enum_netr_ValidationInfoClass=0x7FFFFFFF}
|
|
#define NetlogonValidationUasInfo ( 1 )
|
|
#define NetlogonValidationSamInfo ( 2 )
|
|
#define NetlogonValidationSamInfo2 ( 3 )
|
|
#define NetlogonValidationGenericInfo2 ( 5 )
|
|
#define NetlogonValidationSamInfo4 ( 6 )
|
|
#endif
|
|
;
|
|
|
|
union netr_Validation {
|
|
struct netr_SamInfo2 *sam2;/* [unique,case(NetlogonValidationSamInfo)] */
|
|
struct netr_SamInfo3 *sam3;/* [unique,case(NetlogonValidationSamInfo2)] */
|
|
struct netr_PacInfo *pac;/* [unique,case(4)] */
|
|
struct netr_GenericInfo2 *generic;/* [unique,case(NetlogonValidationGenericInfo2)] */
|
|
struct netr_SamInfo6 *sam6;/* [unique,case(NetlogonValidationSamInfo4)] */
|
|
}/* [public,switch_type(uint16)] */;
|
|
|
|
struct netr_Credential {
|
|
uint8_t data[8];
|
|
}/* [public,flag(LIBNDR_PRINT_ARRAY_HEX)] */;
|
|
|
|
struct netr_Authenticator {
|
|
struct netr_Credential cred;
|
|
time_t timestamp;
|
|
}/* [public] */;
|
|
|
|
struct netr_DELTA_DELETE_USER {
|
|
const char *account_name;/* [unique,charset(UTF16)] */
|
|
struct lsa_String unknown1;
|
|
struct lsa_String unknown2;
|
|
struct lsa_String unknown3;
|
|
struct lsa_String unknown4;
|
|
uint32_t unknown5;
|
|
uint32_t unknown6;
|
|
uint32_t unknown7;
|
|
uint32_t unknown8;
|
|
};
|
|
|
|
struct netr_USER_KEY16 {
|
|
uint16_t length;
|
|
uint16_t size;/* [value(length)] */
|
|
uint32_t flags;
|
|
struct samr_Password pwd;
|
|
};
|
|
|
|
struct netr_PasswordHistory {
|
|
uint16_t nt_length;
|
|
uint16_t nt_size;/* [value(nt_length)] */
|
|
uint32_t nt_flags;
|
|
uint16_t lm_length;
|
|
uint16_t lm_size;/* [value(lm_length)] */
|
|
uint32_t lm_flags;
|
|
uint8_t *nt_history;
|
|
uint8_t *lm_history;
|
|
};
|
|
|
|
struct netr_USER_KEYS2 {
|
|
struct netr_USER_KEY16 lmpassword;
|
|
struct netr_USER_KEY16 ntpassword;
|
|
struct netr_PasswordHistory history;
|
|
};
|
|
|
|
struct netr_USER_KEY_UNION {
|
|
struct netr_USER_KEYS2 keys2;
|
|
};
|
|
|
|
struct netr_USER_KEYS {
|
|
uint32_t version;
|
|
struct netr_USER_KEY_UNION keys;
|
|
}/* [public] */;
|
|
|
|
struct netr_USER_PRIVATE_INFO {
|
|
uint8_t SensitiveDataFlag;
|
|
uint32_t DataLength;
|
|
uint8_t *SensitiveData;/* [unique,flag(LIBNDR_PRINT_ARRAY_HEX),size_is(DataLength)] */
|
|
};
|
|
|
|
struct netr_DELTA_USER {
|
|
struct lsa_String account_name;
|
|
struct lsa_String full_name;
|
|
uint32_t rid;
|
|
uint32_t primary_gid;
|
|
struct lsa_String home_directory;
|
|
struct lsa_String home_drive;
|
|
struct lsa_String logon_script;
|
|
struct lsa_String description;
|
|
struct lsa_String workstations;
|
|
NTTIME last_logon;
|
|
NTTIME last_logoff;
|
|
struct samr_LogonHours logon_hours;
|
|
uint16_t bad_password_count;
|
|
uint16_t logon_count;
|
|
NTTIME last_password_change;
|
|
NTTIME acct_expiry;
|
|
uint32_t acct_flags;
|
|
struct samr_Password lmpassword;
|
|
struct samr_Password ntpassword;
|
|
uint8_t nt_password_present;
|
|
uint8_t lm_password_present;
|
|
uint8_t password_expired;
|
|
struct lsa_String comment;
|
|
struct lsa_BinaryString parameters;
|
|
uint16_t country_code;
|
|
uint16_t code_page;
|
|
struct netr_USER_PRIVATE_INFO user_private_info;
|
|
uint32_t SecurityInformation;
|
|
struct sec_desc_buf sdbuf;
|
|
struct lsa_String profile_path;
|
|
struct lsa_String unknown2;
|
|
struct lsa_String unknown3;
|
|
struct lsa_String unknown4;
|
|
uint32_t unknown5;
|
|
uint32_t unknown6;
|
|
uint32_t unknown7;
|
|
uint32_t unknown8;
|
|
};
|
|
|
|
struct netr_DELTA_DOMAIN {
|
|
struct lsa_String domain_name;
|
|
struct lsa_String oem_information;
|
|
int64_t force_logoff_time;
|
|
uint16_t min_password_length;
|
|
uint16_t password_history_length;
|
|
int64_t max_password_age;
|
|
int64_t min_password_age;
|
|
uint64_t sequence_num;
|
|
NTTIME domain_create_time;
|
|
uint32_t SecurityInformation;
|
|
struct sec_desc_buf sdbuf;
|
|
struct lsa_BinaryString account_lockout;
|
|
struct lsa_String unknown2;
|
|
struct lsa_String unknown3;
|
|
struct lsa_String unknown4;
|
|
uint32_t logon_to_chgpass;
|
|
uint32_t unknown6;
|
|
uint32_t unknown7;
|
|
uint32_t unknown8;
|
|
};
|
|
|
|
struct netr_DELTA_GROUP {
|
|
struct lsa_String group_name;
|
|
uint32_t rid;
|
|
uint32_t attributes;
|
|
struct lsa_String description;
|
|
uint32_t SecurityInformation;
|
|
struct sec_desc_buf sdbuf;
|
|
struct lsa_String unknown1;
|
|
struct lsa_String unknown2;
|
|
struct lsa_String unknown3;
|
|
struct lsa_String unknown4;
|
|
uint32_t unknown5;
|
|
uint32_t unknown6;
|
|
uint32_t unknown7;
|
|
uint32_t unknown8;
|
|
};
|
|
|
|
struct netr_DELTA_RENAME {
|
|
struct lsa_String OldName;
|
|
struct lsa_String NewName;
|
|
struct lsa_String unknown1;
|
|
struct lsa_String unknown2;
|
|
struct lsa_String unknown3;
|
|
struct lsa_String unknown4;
|
|
uint32_t unknown5;
|
|
uint32_t unknown6;
|
|
uint32_t unknown7;
|
|
uint32_t unknown8;
|
|
};
|
|
|
|
struct netr_DELTA_GROUP_MEMBER {
|
|
uint32_t *rids;/* [unique,size_is(num_rids)] */
|
|
uint32_t *attribs;/* [unique,size_is(num_rids)] */
|
|
uint32_t num_rids;
|
|
uint32_t unknown1;
|
|
uint32_t unknown2;
|
|
uint32_t unknown3;
|
|
uint32_t unknown4;
|
|
};
|
|
|
|
struct netr_DELTA_ALIAS {
|
|
struct lsa_String alias_name;
|
|
uint32_t rid;
|
|
uint32_t SecurityInformation;
|
|
struct sec_desc_buf sdbuf;
|
|
struct lsa_String description;
|
|
struct lsa_String unknown2;
|
|
struct lsa_String unknown3;
|
|
struct lsa_String unknown4;
|
|
uint32_t unknown5;
|
|
uint32_t unknown6;
|
|
uint32_t unknown7;
|
|
uint32_t unknown8;
|
|
};
|
|
|
|
struct netr_DELTA_ALIAS_MEMBER {
|
|
struct lsa_SidArray sids;
|
|
uint32_t unknown1;
|
|
uint32_t unknown2;
|
|
uint32_t unknown3;
|
|
uint32_t unknown4;
|
|
};
|
|
|
|
struct netr_QUOTA_LIMITS {
|
|
uint32_t pagedpoollimit;
|
|
uint32_t nonpagedpoollimit;
|
|
uint32_t minimumworkingsetsize;
|
|
uint32_t maximumworkingsetsize;
|
|
uint32_t pagefilelimit;
|
|
NTTIME timelimit;
|
|
};
|
|
|
|
struct netr_DELTA_POLICY {
|
|
uint32_t maxlogsize;
|
|
NTTIME auditretentionperiod;
|
|
uint8_t auditingmode;
|
|
uint32_t maxauditeventcount;
|
|
uint32_t *eventauditoptions;/* [unique,size_is(maxauditeventcount+1)] */
|
|
struct lsa_String primary_domain_name;
|
|
struct dom_sid2 *sid;/* [unique] */
|
|
struct netr_QUOTA_LIMITS quota_limits;
|
|
uint64_t sequence_num;
|
|
NTTIME db_create_time;
|
|
uint32_t SecurityInformation;
|
|
struct sec_desc_buf sdbuf;
|
|
struct lsa_String unknown1;
|
|
struct lsa_String unknown2;
|
|
struct lsa_String unknown3;
|
|
struct lsa_String unknown4;
|
|
uint32_t unknown5;
|
|
uint32_t unknown6;
|
|
uint32_t unknown7;
|
|
uint32_t unknown8;
|
|
};
|
|
|
|
struct netr_DELTA_TRUSTED_DOMAIN {
|
|
struct lsa_String domain_name;
|
|
uint32_t num_controllers;
|
|
struct lsa_String *controller_names;/* [unique,size_is(num_controllers)] */
|
|
uint32_t SecurityInformation;
|
|
struct sec_desc_buf sdbuf;
|
|
struct lsa_String unknown1;
|
|
struct lsa_String unknown2;
|
|
struct lsa_String unknown3;
|
|
struct lsa_String unknown4;
|
|
uint32_t posix_offset;
|
|
uint32_t unknown6;
|
|
uint32_t unknown7;
|
|
uint32_t unknown8;
|
|
};
|
|
|
|
struct netr_DELTA_DELETE_TRUST {
|
|
uint16_t unknown;
|
|
};
|
|
|
|
struct netr_DELTA_ACCOUNT {
|
|
uint32_t privilege_entries;
|
|
uint32_t privilege_control;
|
|
uint32_t *privilege_attrib;/* [unique,size_is(privilege_entries)] */
|
|
struct lsa_String *privilege_name;/* [unique,size_is(privilege_entries)] */
|
|
struct netr_QUOTA_LIMITS quotalimits;
|
|
uint32_t system_flags;
|
|
uint32_t SecurityInformation;
|
|
struct sec_desc_buf sdbuf;
|
|
struct lsa_String unknown1;
|
|
struct lsa_String unknown2;
|
|
struct lsa_String unknown3;
|
|
struct lsa_String unknown4;
|
|
uint32_t unknown5;
|
|
uint32_t unknown6;
|
|
uint32_t unknown7;
|
|
uint32_t unknown8;
|
|
};
|
|
|
|
struct netr_DELTA_DELETE_ACCOUNT {
|
|
uint16_t unknown;
|
|
};
|
|
|
|
struct netr_DELTA_DELETE_SECRET {
|
|
uint16_t unknown;
|
|
};
|
|
|
|
struct netr_CIPHER_VALUE {
|
|
uint32_t len;
|
|
uint32_t maxlen;
|
|
uint8_t *cipher_data;/* [unique,length_is(len),size_is(maxlen)] */
|
|
};
|
|
|
|
struct netr_DELTA_SECRET {
|
|
struct netr_CIPHER_VALUE current_cipher;
|
|
NTTIME current_cipher_set_time;
|
|
struct netr_CIPHER_VALUE old_cipher;
|
|
NTTIME old_cipher_set_time;
|
|
uint32_t SecurityInformation;
|
|
struct sec_desc_buf sdbuf;
|
|
struct lsa_String unknown1;
|
|
struct lsa_String unknown2;
|
|
struct lsa_String unknown3;
|
|
struct lsa_String unknown4;
|
|
uint32_t unknown5;
|
|
uint32_t unknown6;
|
|
uint32_t unknown7;
|
|
uint32_t unknown8;
|
|
};
|
|
|
|
enum netr_DeltaEnum
|
|
#ifndef USE_UINT_ENUMS
|
|
{
|
|
NETR_DELTA_DOMAIN=(int)(1),
|
|
NETR_DELTA_GROUP=(int)(2),
|
|
NETR_DELTA_DELETE_GROUP=(int)(3),
|
|
NETR_DELTA_RENAME_GROUP=(int)(4),
|
|
NETR_DELTA_USER=(int)(5),
|
|
NETR_DELTA_DELETE_USER=(int)(6),
|
|
NETR_DELTA_RENAME_USER=(int)(7),
|
|
NETR_DELTA_GROUP_MEMBER=(int)(8),
|
|
NETR_DELTA_ALIAS=(int)(9),
|
|
NETR_DELTA_DELETE_ALIAS=(int)(10),
|
|
NETR_DELTA_RENAME_ALIAS=(int)(11),
|
|
NETR_DELTA_ALIAS_MEMBER=(int)(12),
|
|
NETR_DELTA_POLICY=(int)(13),
|
|
NETR_DELTA_TRUSTED_DOMAIN=(int)(14),
|
|
NETR_DELTA_DELETE_TRUST=(int)(15),
|
|
NETR_DELTA_ACCOUNT=(int)(16),
|
|
NETR_DELTA_DELETE_ACCOUNT=(int)(17),
|
|
NETR_DELTA_SECRET=(int)(18),
|
|
NETR_DELTA_DELETE_SECRET=(int)(19),
|
|
NETR_DELTA_DELETE_GROUP2=(int)(20),
|
|
NETR_DELTA_DELETE_USER2=(int)(21),
|
|
NETR_DELTA_MODIFY_COUNT=(int)(22)
|
|
}
|
|
#else
|
|
{ __donnot_use_enum_netr_DeltaEnum=0x7FFFFFFF}
|
|
#define NETR_DELTA_DOMAIN ( 1 )
|
|
#define NETR_DELTA_GROUP ( 2 )
|
|
#define NETR_DELTA_DELETE_GROUP ( 3 )
|
|
#define NETR_DELTA_RENAME_GROUP ( 4 )
|
|
#define NETR_DELTA_USER ( 5 )
|
|
#define NETR_DELTA_DELETE_USER ( 6 )
|
|
#define NETR_DELTA_RENAME_USER ( 7 )
|
|
#define NETR_DELTA_GROUP_MEMBER ( 8 )
|
|
#define NETR_DELTA_ALIAS ( 9 )
|
|
#define NETR_DELTA_DELETE_ALIAS ( 10 )
|
|
#define NETR_DELTA_RENAME_ALIAS ( 11 )
|
|
#define NETR_DELTA_ALIAS_MEMBER ( 12 )
|
|
#define NETR_DELTA_POLICY ( 13 )
|
|
#define NETR_DELTA_TRUSTED_DOMAIN ( 14 )
|
|
#define NETR_DELTA_DELETE_TRUST ( 15 )
|
|
#define NETR_DELTA_ACCOUNT ( 16 )
|
|
#define NETR_DELTA_DELETE_ACCOUNT ( 17 )
|
|
#define NETR_DELTA_SECRET ( 18 )
|
|
#define NETR_DELTA_DELETE_SECRET ( 19 )
|
|
#define NETR_DELTA_DELETE_GROUP2 ( 20 )
|
|
#define NETR_DELTA_DELETE_USER2 ( 21 )
|
|
#define NETR_DELTA_MODIFY_COUNT ( 22 )
|
|
#endif
|
|
;
|
|
|
|
union netr_DELTA_UNION {
|
|
struct netr_DELTA_DOMAIN *domain;/* [unique,case(NETR_DELTA_DOMAIN)] */
|
|
struct netr_DELTA_GROUP *group;/* [unique,case(NETR_DELTA_GROUP)] */
|
|
struct netr_DELTA_RENAME *rename_group;/* [unique,case(NETR_DELTA_RENAME_GROUP)] */
|
|
struct netr_DELTA_USER *user;/* [unique,case(NETR_DELTA_USER)] */
|
|
struct netr_DELTA_RENAME *rename_user;/* [unique,case(NETR_DELTA_RENAME_USER)] */
|
|
struct netr_DELTA_GROUP_MEMBER *group_member;/* [unique,case(NETR_DELTA_GROUP_MEMBER)] */
|
|
struct netr_DELTA_ALIAS *alias;/* [unique,case(NETR_DELTA_ALIAS)] */
|
|
struct netr_DELTA_RENAME *rename_alias;/* [unique,case(NETR_DELTA_RENAME_ALIAS)] */
|
|
struct netr_DELTA_ALIAS_MEMBER *alias_member;/* [unique,case(NETR_DELTA_ALIAS_MEMBER)] */
|
|
struct netr_DELTA_POLICY *policy;/* [unique,case(NETR_DELTA_POLICY)] */
|
|
struct netr_DELTA_TRUSTED_DOMAIN *trusted_domain;/* [unique,case(NETR_DELTA_TRUSTED_DOMAIN)] */
|
|
struct netr_DELTA_DELETE_TRUST delete_trust;/* [case(NETR_DELTA_DELETE_TRUST)] */
|
|
struct netr_DELTA_ACCOUNT *account;/* [unique,case(NETR_DELTA_ACCOUNT)] */
|
|
struct netr_DELTA_DELETE_ACCOUNT delete_account;/* [case(NETR_DELTA_DELETE_ACCOUNT)] */
|
|
struct netr_DELTA_SECRET *secret;/* [unique,case(NETR_DELTA_SECRET)] */
|
|
struct netr_DELTA_DELETE_SECRET delete_secret;/* [case(NETR_DELTA_DELETE_SECRET)] */
|
|
struct netr_DELTA_DELETE_USER *delete_group;/* [unique,case(NETR_DELTA_DELETE_GROUP2)] */
|
|
struct netr_DELTA_DELETE_USER *delete_user;/* [unique,case(NETR_DELTA_DELETE_USER2)] */
|
|
uint64_t *modified_count;/* [unique,case(NETR_DELTA_MODIFY_COUNT)] */
|
|
}/* [switch_type(netr_DeltaEnum)] */;
|
|
|
|
union netr_DELTA_ID_UNION {
|
|
uint32_t rid;/* [case(NETR_DELTA_DOMAIN)] */
|
|
struct dom_sid2 *sid;/* [unique,case(NETR_DELTA_POLICY)] */
|
|
const char *name;/* [unique,charset(UTF16),case(NETR_DELTA_SECRET)] */
|
|
}/* [switch_type(netr_DeltaEnum)] */;
|
|
|
|
struct netr_DELTA_ENUM {
|
|
enum netr_DeltaEnum delta_type;
|
|
union netr_DELTA_ID_UNION delta_id_union;/* [switch_is(delta_type)] */
|
|
union netr_DELTA_UNION delta_union;/* [switch_is(delta_type)] */
|
|
};
|
|
|
|
struct netr_DELTA_ENUM_ARRAY {
|
|
uint32_t num_deltas;
|
|
struct netr_DELTA_ENUM *delta_enum;/* [unique,size_is(num_deltas)] */
|
|
};
|
|
|
|
struct netr_UAS_INFO_0 {
|
|
uint8_t computer_name[16];
|
|
uint32_t timecreated;
|
|
uint32_t serial_number;
|
|
}/* [flag(LIBNDR_PRINT_ARRAY_HEX)] */;
|
|
|
|
struct netr_AccountBuffer {
|
|
DATA_BLOB blob;/* [flag(LIBNDR_FLAG_REMAINING)] */
|
|
};
|
|
|
|
/* bitmap netr_InfoFlags */
|
|
#define NETLOGON_REPLICATION_NEEDED ( 0x00000001 )
|
|
#define NETLOGON_REPLICATION_IN_PROGRESS ( 0x00000002 )
|
|
#define NETLOGON_FULL_SYNC_REPLICATION ( 0x00000004 )
|
|
#define NETLOGON_REDO_NEEDED ( 0x00000008 )
|
|
#define NETLOGON_HAS_IP ( 0x00000010 )
|
|
#define NETLOGON_HAS_TIMESERV ( 0x00000020 )
|
|
#define NETLOGON_DNS_UPDATE_FAILURE ( 0x00000040 )
|
|
#define NETLOGON_VERIFY_STATUS_RETURNED ( 0x00000080 )
|
|
|
|
struct netr_NETLOGON_INFO_1 {
|
|
uint32_t flags;
|
|
WERROR pdc_connection_status;
|
|
};
|
|
|
|
struct netr_NETLOGON_INFO_2 {
|
|
uint32_t flags;
|
|
WERROR pdc_connection_status;
|
|
const char *trusted_dc_name;/* [unique,charset(UTF16)] */
|
|
WERROR tc_connection_status;
|
|
};
|
|
|
|
struct netr_NETLOGON_INFO_3 {
|
|
uint32_t flags;
|
|
uint32_t logon_attempts;
|
|
uint32_t unknown1;
|
|
uint32_t unknown2;
|
|
uint32_t unknown3;
|
|
uint32_t unknown4;
|
|
uint32_t unknown5;
|
|
};
|
|
|
|
struct netr_NETLOGON_INFO_4 {
|
|
const char *trusted_dc_name;/* [unique,charset(UTF16)] */
|
|
const char *trusted_domain_name;/* [unique,charset(UTF16)] */
|
|
};
|
|
|
|
union netr_CONTROL_QUERY_INFORMATION {
|
|
struct netr_NETLOGON_INFO_1 *info1;/* [unique,case] */
|
|
struct netr_NETLOGON_INFO_2 *info2;/* [unique,case(2)] */
|
|
struct netr_NETLOGON_INFO_3 *info3;/* [unique,case(3)] */
|
|
struct netr_NETLOGON_INFO_4 *info4;/* [unique,case(4)] */
|
|
};
|
|
|
|
enum netr_LogonControlCode
|
|
#ifndef USE_UINT_ENUMS
|
|
{
|
|
NETLOGON_CONTROL_QUERY=(int)(0x00000001),
|
|
NETLOGON_CONTROL_REPLICATE=(int)(0x00000002),
|
|
NETLOGON_CONTROL_SYNCHRONIZE=(int)(0x00000003),
|
|
NETLOGON_CONTROL_PDC_REPLICATE=(int)(0x00000004),
|
|
NETLOGON_CONTROL_REDISCOVER=(int)(0x00000005),
|
|
NETLOGON_CONTROL_TC_QUERY=(int)(0x00000006),
|
|
NETLOGON_CONTROL_TRANSPORT_NOTIFY=(int)(0x00000007),
|
|
NETLOGON_CONTROL_FIND_USER=(int)(0x00000008),
|
|
NETLOGON_CONTROL_CHANGE_PASSWORD=(int)(0x00000009),
|
|
NETLOGON_CONTROL_TC_VERIFY=(int)(0x0000000A),
|
|
NETLOGON_CONTROL_FORCE_DNS_REG=(int)(0x0000000B),
|
|
NETLOGON_CONTROL_QUERY_DNS_REG=(int)(0x0000000C),
|
|
NETLOGON_CONTROL_BACKUP_CHANGE_LOG=(int)(0x0000FFFC),
|
|
NETLOGON_CONTROL_TRUNCATE_LOG=(int)(0x0000FFFD),
|
|
NETLOGON_CONTROL_SET_DBFLAG=(int)(0x0000FFFE),
|
|
NETLOGON_CONTROL_BREAKPOINT=(int)(0x0000FFFF)
|
|
}
|
|
#else
|
|
{ __donnot_use_enum_netr_LogonControlCode=0x7FFFFFFF}
|
|
#define NETLOGON_CONTROL_QUERY ( 0x00000001 )
|
|
#define NETLOGON_CONTROL_REPLICATE ( 0x00000002 )
|
|
#define NETLOGON_CONTROL_SYNCHRONIZE ( 0x00000003 )
|
|
#define NETLOGON_CONTROL_PDC_REPLICATE ( 0x00000004 )
|
|
#define NETLOGON_CONTROL_REDISCOVER ( 0x00000005 )
|
|
#define NETLOGON_CONTROL_TC_QUERY ( 0x00000006 )
|
|
#define NETLOGON_CONTROL_TRANSPORT_NOTIFY ( 0x00000007 )
|
|
#define NETLOGON_CONTROL_FIND_USER ( 0x00000008 )
|
|
#define NETLOGON_CONTROL_CHANGE_PASSWORD ( 0x00000009 )
|
|
#define NETLOGON_CONTROL_TC_VERIFY ( 0x0000000A )
|
|
#define NETLOGON_CONTROL_FORCE_DNS_REG ( 0x0000000B )
|
|
#define NETLOGON_CONTROL_QUERY_DNS_REG ( 0x0000000C )
|
|
#define NETLOGON_CONTROL_BACKUP_CHANGE_LOG ( 0x0000FFFC )
|
|
#define NETLOGON_CONTROL_TRUNCATE_LOG ( 0x0000FFFD )
|
|
#define NETLOGON_CONTROL_SET_DBFLAG ( 0x0000FFFE )
|
|
#define NETLOGON_CONTROL_BREAKPOINT ( 0x0000FFFF )
|
|
#endif
|
|
;
|
|
|
|
union netr_CONTROL_DATA_INFORMATION {
|
|
const char *domain;/* [unique,charset(UTF16),case(NETLOGON_CONTROL_REDISCOVER)] */
|
|
const char *user;/* [unique,charset(UTF16),case(NETLOGON_CONTROL_FIND_USER)] */
|
|
uint32_t debug_level;/* [case(NETLOGON_CONTROL_SET_DBFLAG)] */
|
|
};
|
|
|
|
/* bitmap netr_NegotiateFlags */
|
|
#define NETLOGON_NEG_ACCOUNT_LOCKOUT ( 0x00000001 )
|
|
#define NETLOGON_NEG_PERSISTENT_SAMREPL ( 0x00000002 )
|
|
#define NETLOGON_NEG_ARCFOUR ( 0x00000004 )
|
|
#define NETLOGON_NEG_PROMOTION_COUNT ( 0x00000008 )
|
|
#define NETLOGON_NEG_CHANGELOG_BDC ( 0x00000010 )
|
|
#define NETLOGON_NEG_FULL_SYNC_REPL ( 0x00000020 )
|
|
#define NETLOGON_NEG_MULTIPLE_SIDS ( 0x00000040 )
|
|
#define NETLOGON_NEG_REDO ( 0x00000080 )
|
|
#define NETLOGON_NEG_PASSWORD_CHANGE_REFUSAL ( 0x00000100 )
|
|
#define NETLOGON_NEG_SEND_PASSWORD_INFO_PDC ( 0x00000200 )
|
|
#define NETLOGON_NEG_GENERIC_PASSTHROUGH ( 0x00000400 )
|
|
#define NETLOGON_NEG_CONCURRENT_RPC ( 0x00000800 )
|
|
#define NETLOGON_NEG_AVOID_ACCOUNT_DB_REPL ( 0x00001000 )
|
|
#define NETLOGON_NEG_AVOID_SECURITYAUTH_DB_REPL ( 0x00002000 )
|
|
#define NETLOGON_NEG_STRONG_KEYS ( 0x00004000 )
|
|
#define NETLOGON_NEG_TRANSITIVE_TRUSTS ( 0x00008000 )
|
|
#define NETLOGON_NEG_DNS_DOMAIN_TRUSTS ( 0x00010000 )
|
|
#define NETLOGON_NEG_PASSWORD_SET2 ( 0x00020000 )
|
|
#define NETLOGON_NEG_GETDOMAININFO ( 0x00040000 )
|
|
#define NETLOGON_NEG_CROSS_FOREST_TRUSTS ( 0x00080000 )
|
|
#define NETLOGON_NEG_NEUTRALIZE_NT4_EMULATION ( 0x00100000 )
|
|
#define NETLOGON_NEG_RODC_PASSTHROUGH ( 0x00200000 )
|
|
#define NETLOGON_NEG_SUPPORTS_AES_SHA2 ( 0x00400000 )
|
|
#define NETLOGON_NEG_SUPPORTS_AES ( 0x01000000 )
|
|
#define NETLOGON_NEG_AUTHENTICATED_RPC_LSASS ( 0x20000000 )
|
|
#define NETLOGON_NEG_AUTHENTICATED_RPC ( 0x40000000 )
|
|
|
|
enum SyncStateEnum
|
|
#ifndef USE_UINT_ENUMS
|
|
{
|
|
SYNCSTATE_NORMAL_STATE=(int)(0),
|
|
SYNCSTATE_DOMAIN_STATE=(int)(1),
|
|
SYNCSTATE_GROUP_STATE=(int)(2),
|
|
SYNCSTATE_UAS_BUILT_IN_GROUP_STATE=(int)(3),
|
|
SYNCSTATE_USER_STATE=(int)(4),
|
|
SYNCSTATE_GROUP_MEMBER_STATE=(int)(5),
|
|
SYNCSTATE_ALIAS_STATE=(int)(6),
|
|
SYNCSTATE_ALIAS_MEMBER_STATE=(int)(7),
|
|
SYNCSTATE_SAM_DONE_STATE=(int)(8)
|
|
}
|
|
#else
|
|
{ __donnot_use_enum_SyncStateEnum=0x7FFFFFFF}
|
|
#define SYNCSTATE_NORMAL_STATE ( 0 )
|
|
#define SYNCSTATE_DOMAIN_STATE ( 1 )
|
|
#define SYNCSTATE_GROUP_STATE ( 2 )
|
|
#define SYNCSTATE_UAS_BUILT_IN_GROUP_STATE ( 3 )
|
|
#define SYNCSTATE_USER_STATE ( 4 )
|
|
#define SYNCSTATE_GROUP_MEMBER_STATE ( 5 )
|
|
#define SYNCSTATE_ALIAS_STATE ( 6 )
|
|
#define SYNCSTATE_ALIAS_MEMBER_STATE ( 7 )
|
|
#define SYNCSTATE_SAM_DONE_STATE ( 8 )
|
|
#endif
|
|
;
|
|
|
|
/* bitmap netr_ChangeLogFlags */
|
|
#define NETR_CHANGELOG_IMMEDIATE_REPL_REQUIRED ( 0x0001 )
|
|
#define NETR_CHANGELOG_CHANGED_PASSWORD ( 0x0002 )
|
|
#define NETR_CHANGELOG_SID_INCLUDED ( 0x0004 )
|
|
#define NETR_CHANGELOG_NAME_INCLUDED ( 0x0008 )
|
|
#define NETR_CHANGELOG_FIRST_PROMOTION_OBJ ( 0x0010 )
|
|
|
|
union netr_ChangeLogObject {
|
|
struct dom_sid object_sid;/* [case(NETR_CHANGELOG_SID_INCLUDED)] */
|
|
const char * object_name;/* [flag(LIBNDR_FLAG_STR_NULLTERM),case(NETR_CHANGELOG_NAME_INCLUDED)] */
|
|
}/* [nodiscriminant] */;
|
|
|
|
struct netr_ChangeLogEntry {
|
|
uint32_t serial_number1;
|
|
uint32_t serial_number2;
|
|
uint32_t object_rid;
|
|
uint16_t flags;
|
|
enum netr_SamDatabaseID8Bit db_index;
|
|
enum netr_DeltaEnum8Bit delta_type;
|
|
union netr_ChangeLogObject object;/* [switch_is(flags&(NETR_CHANGELOG_SID_INCLUDED|NETR_CHANGELOG_NAME_INCLUDED))] */
|
|
}/* [gensize,public] */;
|
|
|
|
struct netr_Blob {
|
|
uint32_t length;
|
|
uint8_t *data;/* [unique,size_is(length)] */
|
|
};
|
|
|
|
/* bitmap netr_DsRGetDCName_flags */
|
|
#define DS_FORCE_REDISCOVERY ( 0x00000001 )
|
|
#define DS_DIRECTORY_SERVICE_REQUIRED ( 0x00000010 )
|
|
#define DS_DIRECTORY_SERVICE_PREFERRED ( 0x00000020 )
|
|
#define DS_GC_SERVER_REQUIRED ( 0x00000040 )
|
|
#define DS_PDC_REQUIRED ( 0x00000080 )
|
|
#define DS_BACKGROUND_ONLY ( 0x00000100 )
|
|
#define DS_IP_REQUIRED ( 0x00000200 )
|
|
#define DS_KDC_REQUIRED ( 0x00000400 )
|
|
#define DS_TIMESERV_REQUIRED ( 0x00000800 )
|
|
#define DS_WRITABLE_REQUIRED ( 0x00001000 )
|
|
#define DS_GOOD_TIMESERV_PREFERRED ( 0x00002000 )
|
|
#define DS_AVOID_SELF ( 0x00004000 )
|
|
#define DS_ONLY_LDAP_NEEDED ( 0x00008000 )
|
|
#define DS_IS_FLAT_NAME ( 0x00010000 )
|
|
#define DS_IS_DNS_NAME ( 0x00020000 )
|
|
#define DS_TRY_NEXTCLOSEST_SITE ( 0x00040000 )
|
|
#define DS_DIRECTORY_SERVICE_6_REQUIRED ( 0x00080000 )
|
|
#define DS_WEB_SERVICE_REQUIRED ( 0x00100000 )
|
|
#define DS_RETURN_DNS_NAME ( 0x40000000 )
|
|
#define DS_RETURN_FLAT_NAME ( 0x80000000 )
|
|
|
|
enum netr_DsRGetDCNameInfo_AddressType
|
|
#ifndef USE_UINT_ENUMS
|
|
{
|
|
DS_ADDRESS_TYPE_INET=(int)(1),
|
|
DS_ADDRESS_TYPE_NETBIOS=(int)(2)
|
|
}
|
|
#else
|
|
{ __donnot_use_enum_netr_DsRGetDCNameInfo_AddressType=0x7FFFFFFF}
|
|
#define DS_ADDRESS_TYPE_INET ( 1 )
|
|
#define DS_ADDRESS_TYPE_NETBIOS ( 2 )
|
|
#endif
|
|
;
|
|
|
|
/* bitmap netr_DsR_DcFlags */
|
|
#define DS_SERVER_PDC ( NBT_SERVER_PDC )
|
|
#define DS_SERVER_GC ( NBT_SERVER_GC )
|
|
#define DS_SERVER_LDAP ( NBT_SERVER_LDAP )
|
|
#define DS_SERVER_DS ( NBT_SERVER_DS )
|
|
#define DS_SERVER_KDC ( NBT_SERVER_KDC )
|
|
#define DS_SERVER_TIMESERV ( NBT_SERVER_TIMESERV )
|
|
#define DS_SERVER_CLOSEST ( NBT_SERVER_CLOSEST )
|
|
#define DS_SERVER_WRITABLE ( NBT_SERVER_WRITABLE )
|
|
#define DS_SERVER_GOOD_TIMESERV ( NBT_SERVER_GOOD_TIMESERV )
|
|
#define DS_SERVER_NDNC ( NBT_SERVER_NDNC )
|
|
#define DS_SERVER_SELECT_SECRET_DOMAIN_6 ( NBT_SERVER_SELECT_SECRET_DOMAIN_6 )
|
|
#define DS_SERVER_FULL_SECRET_DOMAIN_6 ( NBT_SERVER_FULL_SECRET_DOMAIN_6 )
|
|
#define DS_DNS_CONTROLLER ( 0x20000000 )
|
|
#define DS_DNS_DOMAIN ( 0x40000000 )
|
|
#define DS_DNS_FOREST ( 0x80000000 )
|
|
|
|
struct netr_DsRGetDCNameInfo {
|
|
const char *dc_unc;/* [unique,charset(UTF16)] */
|
|
const char *dc_address;/* [unique,charset(UTF16)] */
|
|
enum netr_DsRGetDCNameInfo_AddressType dc_address_type;
|
|
struct GUID domain_guid;
|
|
const char *domain_name;/* [unique,charset(UTF16)] */
|
|
const char *forest_name;/* [unique,charset(UTF16)] */
|
|
uint32_t dc_flags;
|
|
const char *dc_site_name;/* [unique,charset(UTF16)] */
|
|
const char *client_site_name;/* [unique,charset(UTF16)] */
|
|
}/* [public] */;
|
|
|
|
union netr_Capabilities {
|
|
uint32_t server_capabilities;/* [case] */
|
|
}/* [switch_type(uint32)] */;
|
|
|
|
/* bitmap netr_TrustFlags */
|
|
#define NETR_TRUST_FLAG_IN_FOREST ( 0x00000001 )
|
|
#define NETR_TRUST_FLAG_OUTBOUND ( 0x00000002 )
|
|
#define NETR_TRUST_FLAG_TREEROOT ( 0x00000004 )
|
|
#define NETR_TRUST_FLAG_PRIMARY ( 0x00000008 )
|
|
#define NETR_TRUST_FLAG_NATIVE ( 0x00000010 )
|
|
#define NETR_TRUST_FLAG_INBOUND ( 0x00000020 )
|
|
#define NETR_TRUST_FLAG_MIT_KRB5 ( 0x00000080 )
|
|
#define NETR_TRUST_FLAG_AES ( 0x00000100 )
|
|
|
|
/* bitmap netr_WorkstationFlags */
|
|
#define NETR_WS_FLAG_HANDLES_INBOUND_TRUSTS ( 0x00000001 )
|
|
#define NETR_WS_FLAG_HANDLES_SPN_UPDATE ( 0x00000002 )
|
|
|
|
/* bitmap netr_SuiteMask */
|
|
#define NETR_VER_SUITE_BACKOFFICE ( 0x0004 )
|
|
#define NETR_VER_SUITE_BLADE ( 0x0400 )
|
|
#define NETR_VER_SUITE_COMPUTE_SERVER ( 0x4000 )
|
|
#define NETR_VER_SUITE_DATACENTER ( 0x0080 )
|
|
#define NETR_VER_SUITE_ENTERPRISE ( 0x0002 )
|
|
#define NETR_VER_SUITE_EMBEDDEDNT ( 0x0040 )
|
|
#define NETR_VER_SUITE_PERSONAL ( 0x0200 )
|
|
#define NETR_VER_SUITE_SINGLEUSERTS ( 0x0100 )
|
|
#define NETR_VER_SUITE_SMALLBUSINESS ( 0x0001 )
|
|
#define NETR_VER_SUITE_SMALLBUSINESS_RESTRICTED ( 0x0020 )
|
|
#define NETR_VER_SUITE_STORAGE_SERVER ( 0x2000 )
|
|
#define NETR_VER_SUITE_TERMINAL ( 0x0010 )
|
|
#define NETR_VER_SUITE_WH_SERVER ( 0x8000 )
|
|
|
|
/* bitmap netr_ProductType */
|
|
#define NETR_VER_NT_DOMAIN_CONTROLLER ( 0x02 )
|
|
#define NETR_VER_NT_SERVER ( 0x03 )
|
|
#define NETR_VER_NT_WORKSTATION ( 0x01 )
|
|
|
|
struct netr_LsaPolicyInformation {
|
|
uint32_t policy_size;
|
|
uint8_t *policy;/* [unique,size_is(policy_size)] */
|
|
};
|
|
|
|
struct netr_OsVersionInfoEx {
|
|
uint32_t OSVersionInfoSize;/* [value(284)] */
|
|
uint32_t MajorVersion;
|
|
uint32_t MinorVersion;
|
|
uint32_t BuildNumber;
|
|
uint32_t PlatformId;
|
|
const char * CSDVersion;/* [subcontext_size(256),subcontext(0),flag(LIBNDR_FLAG_STR_NULLTERM)] */
|
|
uint16_t ServicePackMajor;
|
|
uint16_t ServicePackMinor;
|
|
uint16_t SuiteMask;
|
|
uint8_t ProductType;
|
|
uint8_t Reserved;
|
|
};
|
|
|
|
struct netr_OsVersion {
|
|
uint32_t length;/* [value(142)] */
|
|
uint32_t dummy;/* [value(0)] */
|
|
uint32_t size;/* [value(142)] */
|
|
struct netr_OsVersionInfoEx os;
|
|
};
|
|
|
|
struct netr_OsVersionContainer {
|
|
uint16_t length;/* [value(os==NULL?0:284)] */
|
|
uint16_t size;/* [value(os==NULL?0:284)] */
|
|
struct netr_OsVersion *os;/* [unique] */
|
|
};
|
|
|
|
struct netr_WorkstationInformation {
|
|
struct netr_LsaPolicyInformation lsa_policy;
|
|
const char *dns_hostname;/* [unique,charset(UTF16)] */
|
|
const char *sitename;/* [unique,charset(UTF16)] */
|
|
const char *dummy1;/* [unique,charset(UTF16)] */
|
|
const char *dummy2;/* [unique,charset(UTF16)] */
|
|
const char *dummy3;/* [unique,charset(UTF16)] */
|
|
const char *dummy4;/* [unique,charset(UTF16)] */
|
|
struct netr_OsVersionContainer os_version;
|
|
struct lsa_String os_name;
|
|
struct lsa_String dummy_string3;
|
|
struct lsa_String dummy_string4;
|
|
uint32_t workstation_flags;
|
|
uint32_t dummy_long2;
|
|
uint32_t dummy_long3;
|
|
uint32_t dummy_long4;
|
|
};
|
|
|
|
union netr_WorkstationInfo {
|
|
struct netr_WorkstationInformation *workstation_info;/* [unique,case] */
|
|
struct netr_WorkstationInformation *lsa_policy_info;/* [unique,case(2)] */
|
|
};
|
|
|
|
struct netr_trust_extension {
|
|
uint32_t length;/* [value(8)] */
|
|
uint32_t dummy;/* [value(0)] */
|
|
uint32_t size;/* [value(8)] */
|
|
uint32_t flags;
|
|
uint32_t parent_index;
|
|
uint32_t trust_type;
|
|
uint32_t trust_attributes;
|
|
};
|
|
|
|
struct netr_trust_extension_container {
|
|
uint16_t length;
|
|
uint16_t size;/* [value(length)] */
|
|
struct netr_trust_extension *info;/* [unique] */
|
|
};
|
|
|
|
struct netr_OneDomainInfo {
|
|
struct lsa_StringLarge domainname;
|
|
struct lsa_StringLarge dns_domainname;
|
|
struct lsa_StringLarge dns_forestname;
|
|
struct GUID domain_guid;
|
|
struct dom_sid2 *domain_sid;/* [unique] */
|
|
struct netr_trust_extension_container trust_extension;
|
|
struct lsa_StringLarge dummy_string2;
|
|
struct lsa_StringLarge dummy_string3;
|
|
struct lsa_StringLarge dummy_string4;
|
|
uint32_t dummy_long1;
|
|
uint32_t dummy_long2;
|
|
uint32_t dummy_long3;
|
|
uint32_t dummy_long4;
|
|
};
|
|
|
|
/* bitmap netr_SupportedEncTypes */
|
|
#define ENC_CRC32 ( 0x00000001 )
|
|
#define ENC_RSA_MD5 ( 0x00000002 )
|
|
#define ENC_RC4_HMAC_MD5 ( 0x00000004 )
|
|
#define ENC_HMAC_SHA1_96_AES128 ( 0x00000008 )
|
|
#define ENC_HMAC_SHA1_96_AES256 ( 0x00000010 )
|
|
|
|
struct netr_DomainInformation {
|
|
struct netr_OneDomainInfo primary_domain;
|
|
uint32_t trusted_domain_count;
|
|
struct netr_OneDomainInfo *trusted_domains;/* [unique,size_is(trusted_domain_count)] */
|
|
struct netr_LsaPolicyInformation lsa_policy;
|
|
struct lsa_StringLarge dns_hostname;
|
|
struct lsa_StringLarge dummy_string2;
|
|
struct lsa_StringLarge dummy_string3;
|
|
struct lsa_StringLarge dummy_string4;
|
|
uint32_t workstation_flags;
|
|
uint32_t supported_enc_types;
|
|
uint32_t dummy_long3;
|
|
uint32_t dummy_long4;
|
|
};
|
|
|
|
union netr_DomainInfo {
|
|
struct netr_DomainInformation *domain_info;/* [unique,case] */
|
|
struct netr_LsaPolicyInformation *lsa_policy_info;/* [unique,case(2)] */
|
|
};
|
|
|
|
struct netr_CryptPassword {
|
|
uint8_t data[512];
|
|
uint32_t length;
|
|
}/* [flag(LIBNDR_PRINT_ARRAY_HEX)] */;
|
|
|
|
struct netr_DsRAddressToSitenamesWCtr {
|
|
uint32_t count;
|
|
struct lsa_String *sitename;/* [unique,size_is(count)] */
|
|
};
|
|
|
|
struct netr_DsRAddress {
|
|
uint8_t *buffer;/* [unique,size_is(size)] */
|
|
uint32_t size;
|
|
};
|
|
|
|
enum netr_TrustType
|
|
#ifndef USE_UINT_ENUMS
|
|
{
|
|
NETR_TRUST_TYPE_DOWNLEVEL=(int)(1),
|
|
NETR_TRUST_TYPE_UPLEVEL=(int)(2),
|
|
NETR_TRUST_TYPE_MIT=(int)(3),
|
|
NETR_TRUST_TYPE_DCE=(int)(4)
|
|
}
|
|
#else
|
|
{ __donnot_use_enum_netr_TrustType=0x7FFFFFFF}
|
|
#define NETR_TRUST_TYPE_DOWNLEVEL ( 1 )
|
|
#define NETR_TRUST_TYPE_UPLEVEL ( 2 )
|
|
#define NETR_TRUST_TYPE_MIT ( 3 )
|
|
#define NETR_TRUST_TYPE_DCE ( 4 )
|
|
#endif
|
|
;
|
|
|
|
/* bitmap netr_TrustAttributes */
|
|
#define NETR_TRUST_ATTRIBUTE_NON_TRANSITIVE ( 0x00000001 )
|
|
#define NETR_TRUST_ATTRIBUTE_UPLEVEL_ONLY ( 0x00000002 )
|
|
#define NETR_TRUST_ATTRIBUTE_QUARANTINED_DOMAIN ( 0x00000004 )
|
|
#define NETR_TRUST_ATTRIBUTE_FOREST_TRANSITIVE ( 0x00000008 )
|
|
#define NETR_TRUST_ATTRIBUTE_CROSS_ORGANIZATION ( 0x00000010 )
|
|
#define NETR_TRUST_ATTRIBUTE_WITHIN_FOREST ( 0x00000020 )
|
|
#define NETR_TRUST_ATTRIBUTE_TREAT_AS_EXTERNAL ( 0x00000040 )
|
|
|
|
struct netr_DomainTrust {
|
|
const char *netbios_name;/* [unique,charset(UTF16)] */
|
|
const char *dns_name;/* [unique,charset(UTF16)] */
|
|
uint32_t trust_flags;
|
|
uint32_t parent_index;
|
|
enum netr_TrustType trust_type;
|
|
uint32_t trust_attributes;
|
|
struct dom_sid2 *sid;/* [unique] */
|
|
struct GUID guid;
|
|
};
|
|
|
|
struct netr_DomainTrustList {
|
|
uint32_t count;
|
|
struct netr_DomainTrust *array;/* [unique,size_is(count)] */
|
|
};
|
|
|
|
struct netr_DsRAddressToSitenamesExWCtr {
|
|
uint32_t count;
|
|
struct lsa_String *sitename;/* [unique,size_is(count)] */
|
|
struct lsa_String *subnetname;/* [unique,size_is(count)] */
|
|
};
|
|
|
|
struct DcSitesCtr {
|
|
uint32_t num_sites;
|
|
struct lsa_String *sites;/* [unique,size_is(num_sites)] */
|
|
};
|
|
|
|
struct netr_TrustInfo {
|
|
uint32_t count;
|
|
uint32_t *data;/* [unique,size_is(count)] */
|
|
uint32_t entry_count;
|
|
struct lsa_String *entries;/* [unique,size_is(count)] */
|
|
};
|
|
|
|
|
|
struct netr_LogonUasLogon {
|
|
struct {
|
|
const char *server_name;/* [unique,charset(UTF16)] */
|
|
const char *account_name;/* [ref,charset(UTF16)] */
|
|
const char *workstation;/* [ref,charset(UTF16)] */
|
|
} in;
|
|
|
|
struct {
|
|
struct netr_UasInfo **info;/* [ref] */
|
|
WERROR result;
|
|
} out;
|
|
|
|
};
|
|
|
|
|
|
struct netr_LogonUasLogoff {
|
|
struct {
|
|
const char *server_name;/* [unique,charset(UTF16)] */
|
|
const char *account_name;/* [ref,charset(UTF16)] */
|
|
const char *workstation;/* [ref,charset(UTF16)] */
|
|
} in;
|
|
|
|
struct {
|
|
struct netr_UasLogoffInfo *info;/* [ref] */
|
|
WERROR result;
|
|
} out;
|
|
|
|
};
|
|
|
|
|
|
struct netr_LogonSamLogon {
|
|
struct {
|
|
const char *server_name;/* [unique,charset(UTF16)] */
|
|
const char *computer_name;/* [unique,charset(UTF16)] */
|
|
struct netr_Authenticator *credential;/* [unique] */
|
|
enum netr_LogonInfoClass logon_level;
|
|
union netr_LogonLevel *logon;/* [ref,switch_is(logon_level)] */
|
|
uint16_t validation_level;
|
|
struct netr_Authenticator *return_authenticator;/* [unique] */
|
|
} in;
|
|
|
|
struct {
|
|
union netr_Validation *validation;/* [ref,switch_is(validation_level)] */
|
|
uint8_t *authoritative;/* [ref] */
|
|
struct netr_Authenticator *return_authenticator;/* [unique] */
|
|
NTSTATUS result;
|
|
} out;
|
|
|
|
};
|
|
|
|
|
|
struct netr_LogonSamLogoff {
|
|
struct {
|
|
const char *server_name;/* [unique,charset(UTF16)] */
|
|
const char *computer_name;/* [unique,charset(UTF16)] */
|
|
struct netr_Authenticator *credential;/* [unique] */
|
|
enum netr_LogonInfoClass logon_level;
|
|
union netr_LogonLevel logon;/* [switch_is(logon_level)] */
|
|
struct netr_Authenticator *return_authenticator;/* [unique] */
|
|
} in;
|
|
|
|
struct {
|
|
struct netr_Authenticator *return_authenticator;/* [unique] */
|
|
NTSTATUS result;
|
|
} out;
|
|
|
|
};
|
|
|
|
|
|
struct netr_ServerReqChallenge {
|
|
struct {
|
|
const char *server_name;/* [unique,charset(UTF16)] */
|
|
const char *computer_name;/* [ref,charset(UTF16)] */
|
|
struct netr_Credential *credentials;/* [ref] */
|
|
} in;
|
|
|
|
struct {
|
|
struct netr_Credential *return_credentials;/* [ref] */
|
|
NTSTATUS result;
|
|
} out;
|
|
|
|
};
|
|
|
|
|
|
struct netr_ServerAuthenticate {
|
|
struct {
|
|
const char *server_name;/* [unique,charset(UTF16)] */
|
|
const char *account_name;/* [ref,charset(UTF16)] */
|
|
enum netr_SchannelType secure_channel_type;
|
|
const char *computer_name;/* [ref,charset(UTF16)] */
|
|
struct netr_Credential *credentials;/* [ref] */
|
|
} in;
|
|
|
|
struct {
|
|
struct netr_Credential *return_credentials;/* [ref] */
|
|
NTSTATUS result;
|
|
} out;
|
|
|
|
};
|
|
|
|
|
|
struct netr_ServerPasswordSet {
|
|
struct {
|
|
const char *server_name;/* [unique,charset(UTF16)] */
|
|
const char *account_name;/* [ref,charset(UTF16)] */
|
|
enum netr_SchannelType secure_channel_type;
|
|
const char *computer_name;/* [ref,charset(UTF16)] */
|
|
struct netr_Authenticator *credential;/* [ref] */
|
|
struct samr_Password *new_password;/* [ref] */
|
|
} in;
|
|
|
|
struct {
|
|
struct netr_Authenticator *return_authenticator;/* [ref] */
|
|
NTSTATUS result;
|
|
} out;
|
|
|
|
};
|
|
|
|
|
|
struct netr_DatabaseDeltas {
|
|
struct {
|
|
const char *logon_server;/* [ref,charset(UTF16)] */
|
|
const char *computername;/* [ref,charset(UTF16)] */
|
|
struct netr_Authenticator *credential;/* [ref] */
|
|
enum netr_SamDatabaseID database_id;
|
|
uint32_t preferredmaximumlength;
|
|
struct netr_Authenticator *return_authenticator;/* [ref] */
|
|
uint64_t *sequence_num;/* [ref] */
|
|
} in;
|
|
|
|
struct {
|
|
struct netr_DELTA_ENUM_ARRAY **delta_enum_array;/* [ref] */
|
|
struct netr_Authenticator *return_authenticator;/* [ref] */
|
|
uint64_t *sequence_num;/* [ref] */
|
|
NTSTATUS result;
|
|
} out;
|
|
|
|
};
|
|
|
|
|
|
struct netr_DatabaseSync {
|
|
struct {
|
|
const char *logon_server;/* [ref,charset(UTF16)] */
|
|
const char *computername;/* [ref,charset(UTF16)] */
|
|
struct netr_Authenticator *credential;/* [ref] */
|
|
enum netr_SamDatabaseID database_id;
|
|
uint32_t preferredmaximumlength;
|
|
struct netr_Authenticator *return_authenticator;/* [ref] */
|
|
uint32_t *sync_context;/* [ref] */
|
|
} in;
|
|
|
|
struct {
|
|
struct netr_DELTA_ENUM_ARRAY **delta_enum_array;/* [ref] */
|
|
struct netr_Authenticator *return_authenticator;/* [ref] */
|
|
uint32_t *sync_context;/* [ref] */
|
|
NTSTATUS result;
|
|
} out;
|
|
|
|
};
|
|
|
|
|
|
struct netr_AccountDeltas {
|
|
struct {
|
|
const char *logon_server;/* [unique,charset(UTF16)] */
|
|
const char *computername;/* [ref,charset(UTF16)] */
|
|
struct netr_Authenticator credential;
|
|
struct netr_UAS_INFO_0 uas;
|
|
uint32_t count;
|
|
uint32_t level;
|
|
uint32_t buffersize;
|
|
struct netr_Authenticator *return_authenticator;/* [ref] */
|
|
} in;
|
|
|
|
struct {
|
|
struct netr_AccountBuffer *buffer;/* [ref,subcontext(4)] */
|
|
uint32_t *count_returned;/* [ref] */
|
|
uint32_t *total_entries;/* [ref] */
|
|
struct netr_UAS_INFO_0 *recordid;/* [ref] */
|
|
struct netr_Authenticator *return_authenticator;/* [ref] */
|
|
NTSTATUS result;
|
|
} out;
|
|
|
|
};
|
|
|
|
|
|
struct netr_AccountSync {
|
|
struct {
|
|
const char *logon_server;/* [unique,charset(UTF16)] */
|
|
const char *computername;/* [ref,charset(UTF16)] */
|
|
struct netr_Authenticator credential;
|
|
uint32_t reference;
|
|
uint32_t level;
|
|
uint32_t buffersize;
|
|
struct netr_Authenticator *return_authenticator;/* [ref] */
|
|
struct netr_UAS_INFO_0 *recordid;/* [ref] */
|
|
} in;
|
|
|
|
struct {
|
|
struct netr_AccountBuffer *buffer;/* [ref,subcontext(4)] */
|
|
uint32_t *count_returned;/* [ref] */
|
|
uint32_t *total_entries;/* [ref] */
|
|
uint32_t *next_reference;/* [ref] */
|
|
struct netr_Authenticator *return_authenticator;/* [ref] */
|
|
struct netr_UAS_INFO_0 *recordid;/* [ref] */
|
|
NTSTATUS result;
|
|
} out;
|
|
|
|
};
|
|
|
|
|
|
struct netr_GetDcName {
|
|
struct {
|
|
const char *logon_server;/* [ref,charset(UTF16)] */
|
|
const char *domainname;/* [unique,charset(UTF16)] */
|
|
} in;
|
|
|
|
struct {
|
|
const char **dcname;/* [ref,charset(UTF16)] */
|
|
WERROR result;
|
|
} out;
|
|
|
|
};
|
|
|
|
|
|
struct netr_LogonControl {
|
|
struct {
|
|
const char *logon_server;/* [unique,charset(UTF16)] */
|
|
enum netr_LogonControlCode function_code;
|
|
uint32_t level;
|
|
} in;
|
|
|
|
struct {
|
|
union netr_CONTROL_QUERY_INFORMATION *query;/* [ref,switch_is(level)] */
|
|
WERROR result;
|
|
} out;
|
|
|
|
};
|
|
|
|
|
|
struct netr_GetAnyDCName {
|
|
struct {
|
|
const char *logon_server;/* [unique,charset(UTF16)] */
|
|
const char *domainname;/* [unique,charset(UTF16)] */
|
|
} in;
|
|
|
|
struct {
|
|
const char **dcname;/* [ref,charset(UTF16)] */
|
|
WERROR result;
|
|
} out;
|
|
|
|
};
|
|
|
|
|
|
struct netr_LogonControl2 {
|
|
struct {
|
|
const char *logon_server;/* [unique,charset(UTF16)] */
|
|
enum netr_LogonControlCode function_code;
|
|
uint32_t level;
|
|
union netr_CONTROL_DATA_INFORMATION *data;/* [ref,switch_is(function_code)] */
|
|
} in;
|
|
|
|
struct {
|
|
union netr_CONTROL_QUERY_INFORMATION *query;/* [ref,switch_is(level)] */
|
|
WERROR result;
|
|
} out;
|
|
|
|
};
|
|
|
|
|
|
struct netr_ServerAuthenticate2 {
|
|
struct {
|
|
const char *server_name;/* [unique,charset(UTF16)] */
|
|
const char *account_name;/* [ref,charset(UTF16)] */
|
|
enum netr_SchannelType secure_channel_type;
|
|
const char *computer_name;/* [ref,charset(UTF16)] */
|
|
struct netr_Credential *credentials;/* [ref] */
|
|
uint32_t *negotiate_flags;/* [ref] */
|
|
} in;
|
|
|
|
struct {
|
|
struct netr_Credential *return_credentials;/* [ref] */
|
|
uint32_t *negotiate_flags;/* [ref] */
|
|
NTSTATUS result;
|
|
} out;
|
|
|
|
};
|
|
|
|
|
|
struct netr_DatabaseSync2 {
|
|
struct {
|
|
const char *logon_server;/* [ref,charset(UTF16)] */
|
|
const char *computername;/* [ref,charset(UTF16)] */
|
|
struct netr_Authenticator *credential;/* [ref] */
|
|
enum netr_SamDatabaseID database_id;
|
|
enum SyncStateEnum restart_state;
|
|
uint32_t preferredmaximumlength;
|
|
struct netr_Authenticator *return_authenticator;/* [ref] */
|
|
uint32_t *sync_context;/* [ref] */
|
|
} in;
|
|
|
|
struct {
|
|
struct netr_DELTA_ENUM_ARRAY **delta_enum_array;/* [ref] */
|
|
struct netr_Authenticator *return_authenticator;/* [ref] */
|
|
uint32_t *sync_context;/* [ref] */
|
|
NTSTATUS result;
|
|
} out;
|
|
|
|
};
|
|
|
|
|
|
struct netr_DatabaseRedo {
|
|
struct {
|
|
const char *logon_server;/* [ref,charset(UTF16)] */
|
|
const char *computername;/* [ref,charset(UTF16)] */
|
|
struct netr_Authenticator *credential;/* [ref] */
|
|
struct netr_ChangeLogEntry change_log_entry;/* [subcontext_size(change_log_entry_size),subcontext(4)] */
|
|
uint32_t change_log_entry_size;/* [value(ndr_size_netr_ChangeLogEntry(&change_log_entry,ndr->iconv_convenience,ndr->flags))] */
|
|
struct netr_Authenticator *return_authenticator;/* [ref] */
|
|
} in;
|
|
|
|
struct {
|
|
struct netr_DELTA_ENUM_ARRAY **delta_enum_array;/* [ref] */
|
|
struct netr_Authenticator *return_authenticator;/* [ref] */
|
|
NTSTATUS result;
|
|
} out;
|
|
|
|
};
|
|
|
|
|
|
struct netr_LogonControl2Ex {
|
|
struct {
|
|
const char *logon_server;/* [unique,charset(UTF16)] */
|
|
enum netr_LogonControlCode function_code;
|
|
uint32_t level;
|
|
union netr_CONTROL_DATA_INFORMATION *data;/* [ref,switch_is(function_code)] */
|
|
} in;
|
|
|
|
struct {
|
|
union netr_CONTROL_QUERY_INFORMATION *query;/* [ref,switch_is(level)] */
|
|
WERROR result;
|
|
} out;
|
|
|
|
};
|
|
|
|
|
|
struct netr_NetrEnumerateTrustedDomains {
|
|
struct {
|
|
const char *server_name;/* [unique,charset(UTF16)] */
|
|
} in;
|
|
|
|
struct {
|
|
struct netr_Blob *trusted_domains_blob;/* [ref] */
|
|
WERROR result;
|
|
} out;
|
|
|
|
};
|
|
|
|
|
|
struct netr_DsRGetDCName {
|
|
struct {
|
|
const char *server_unc;/* [unique,charset(UTF16)] */
|
|
const char *domain_name;/* [unique,charset(UTF16)] */
|
|
struct GUID *domain_guid;/* [unique] */
|
|
struct GUID *site_guid;/* [unique] */
|
|
uint32_t flags;
|
|
} in;
|
|
|
|
struct {
|
|
struct netr_DsRGetDCNameInfo **info;/* [ref] */
|
|
WERROR result;
|
|
} out;
|
|
|
|
};
|
|
|
|
|
|
struct netr_LogonGetCapabilities {
|
|
struct {
|
|
const char *server_name;/* [ref,charset(UTF16)] */
|
|
const char *computer_name;/* [unique,charset(UTF16)] */
|
|
struct netr_Authenticator *credential;/* [ref] */
|
|
uint32_t query_level;
|
|
struct netr_Authenticator *return_authenticator;/* [ref] */
|
|
} in;
|
|
|
|
struct {
|
|
union netr_Capabilities *capabilities;/* [ref,switch_is(query_level)] */
|
|
struct netr_Authenticator *return_authenticator;/* [ref] */
|
|
NTSTATUS result;
|
|
} out;
|
|
|
|
};
|
|
|
|
|
|
struct netr_NETRLOGONSETSERVICEBITS {
|
|
struct {
|
|
WERROR result;
|
|
} out;
|
|
|
|
};
|
|
|
|
|
|
struct netr_LogonGetTrustRid {
|
|
struct {
|
|
const char *server_name;/* [unique,charset(UTF16)] */
|
|
const char *domain_name;/* [unique,charset(UTF16)] */
|
|
} in;
|
|
|
|
struct {
|
|
uint32_t *rid;/* [ref] */
|
|
WERROR result;
|
|
} out;
|
|
|
|
};
|
|
|
|
|
|
struct netr_NETRLOGONCOMPUTESERVERDIGEST {
|
|
struct {
|
|
WERROR result;
|
|
} out;
|
|
|
|
};
|
|
|
|
|
|
struct netr_NETRLOGONCOMPUTECLIENTDIGEST {
|
|
struct {
|
|
WERROR result;
|
|
} out;
|
|
|
|
};
|
|
|
|
|
|
struct netr_ServerAuthenticate3 {
|
|
struct {
|
|
const char *server_name;/* [unique,charset(UTF16)] */
|
|
const char *account_name;/* [ref,charset(UTF16)] */
|
|
enum netr_SchannelType secure_channel_type;
|
|
const char *computer_name;/* [ref,charset(UTF16)] */
|
|
struct netr_Credential *credentials;/* [ref] */
|
|
uint32_t *negotiate_flags;/* [ref] */
|
|
} in;
|
|
|
|
struct {
|
|
struct netr_Credential *return_credentials;/* [ref] */
|
|
uint32_t *rid;/* [ref] */
|
|
uint32_t *negotiate_flags;/* [ref] */
|
|
NTSTATUS result;
|
|
} out;
|
|
|
|
};
|
|
|
|
|
|
struct netr_DsRGetDCNameEx {
|
|
struct {
|
|
const char *server_unc;/* [unique,charset(UTF16)] */
|
|
const char *domain_name;/* [unique,charset(UTF16)] */
|
|
struct GUID *domain_guid;/* [unique] */
|
|
const char *site_name;/* [unique,charset(UTF16)] */
|
|
uint32_t flags;
|
|
} in;
|
|
|
|
struct {
|
|
struct netr_DsRGetDCNameInfo **info;/* [ref] */
|
|
WERROR result;
|
|
} out;
|
|
|
|
};
|
|
|
|
|
|
struct netr_DsRGetSiteName {
|
|
struct {
|
|
const char *computer_name;/* [unique,charset(UTF16)] */
|
|
} in;
|
|
|
|
struct {
|
|
const char **site;/* [ref,charset(UTF16)] */
|
|
WERROR result;
|
|
} out;
|
|
|
|
};
|
|
|
|
|
|
struct netr_LogonGetDomainInfo {
|
|
struct {
|
|
const char *server_name;/* [ref,charset(UTF16)] */
|
|
const char *computer_name;/* [unique,charset(UTF16)] */
|
|
struct netr_Authenticator *credential;/* [ref] */
|
|
uint32_t level;
|
|
union netr_WorkstationInfo *query;/* [ref,switch_is(level)] */
|
|
struct netr_Authenticator *return_authenticator;/* [ref] */
|
|
} in;
|
|
|
|
struct {
|
|
union netr_DomainInfo *info;/* [ref,switch_is(level)] */
|
|
struct netr_Authenticator *return_authenticator;/* [ref] */
|
|
NTSTATUS result;
|
|
} out;
|
|
|
|
};
|
|
|
|
|
|
struct netr_ServerPasswordSet2 {
|
|
struct {
|
|
const char *server_name;/* [unique,charset(UTF16)] */
|
|
const char *account_name;/* [ref,charset(UTF16)] */
|
|
enum netr_SchannelType secure_channel_type;
|
|
const char *computer_name;/* [ref,charset(UTF16)] */
|
|
struct netr_Authenticator *credential;/* [ref] */
|
|
struct netr_CryptPassword *new_password;/* [ref] */
|
|
} in;
|
|
|
|
struct {
|
|
struct netr_Authenticator *return_authenticator;/* [ref] */
|
|
NTSTATUS result;
|
|
} out;
|
|
|
|
};
|
|
|
|
|
|
struct netr_ServerPasswordGet {
|
|
struct {
|
|
const char *server_name;/* [unique,charset(UTF16)] */
|
|
const char *account_name;/* [ref,charset(UTF16)] */
|
|
enum netr_SchannelType secure_channel_type;
|
|
const char *computer_name;/* [ref,charset(UTF16)] */
|
|
struct netr_Authenticator *credential;/* [ref] */
|
|
} in;
|
|
|
|
struct {
|
|
struct netr_Authenticator *return_authenticator;/* [ref] */
|
|
struct samr_Password *password;/* [ref] */
|
|
WERROR result;
|
|
} out;
|
|
|
|
};
|
|
|
|
|
|
struct netr_NETRLOGONSENDTOSAM {
|
|
struct {
|
|
WERROR result;
|
|
} out;
|
|
|
|
};
|
|
|
|
|
|
struct netr_DsRAddressToSitenamesW {
|
|
struct {
|
|
const char *server_name;/* [unique,charset(UTF16)] */
|
|
uint32_t count;/* [range(0,32000)] */
|
|
struct netr_DsRAddress *addresses;/* [ref,size_is(count)] */
|
|
} in;
|
|
|
|
struct {
|
|
struct netr_DsRAddressToSitenamesWCtr **ctr;/* [ref] */
|
|
WERROR result;
|
|
} out;
|
|
|
|
};
|
|
|
|
|
|
struct netr_DsRGetDCNameEx2 {
|
|
struct {
|
|
const char *server_unc;/* [unique,charset(UTF16)] */
|
|
const char *client_account;/* [unique,charset(UTF16)] */
|
|
uint32_t mask;
|
|
const char *domain_name;/* [unique,charset(UTF16)] */
|
|
struct GUID *domain_guid;/* [unique] */
|
|
const char *site_name;/* [unique,charset(UTF16)] */
|
|
uint32_t flags;
|
|
} in;
|
|
|
|
struct {
|
|
struct netr_DsRGetDCNameInfo **info;/* [ref] */
|
|
WERROR result;
|
|
} out;
|
|
|
|
};
|
|
|
|
|
|
struct netr_NETRLOGONGETTIMESERVICEPARENTDOMAIN {
|
|
struct {
|
|
WERROR result;
|
|
} out;
|
|
|
|
};
|
|
|
|
|
|
struct netr_NetrEnumerateTrustedDomainsEx {
|
|
struct {
|
|
const char *server_name;/* [unique,charset(UTF16)] */
|
|
} in;
|
|
|
|
struct {
|
|
struct netr_DomainTrustList *dom_trust_list;/* [ref] */
|
|
WERROR result;
|
|
} out;
|
|
|
|
};
|
|
|
|
|
|
struct netr_DsRAddressToSitenamesExW {
|
|
struct {
|
|
const char *server_name;/* [unique,charset(UTF16)] */
|
|
uint32_t count;/* [range(0,32000)] */
|
|
struct netr_DsRAddress *addresses;/* [ref,size_is(count)] */
|
|
} in;
|
|
|
|
struct {
|
|
struct netr_DsRAddressToSitenamesExWCtr **ctr;/* [ref] */
|
|
WERROR result;
|
|
} out;
|
|
|
|
};
|
|
|
|
|
|
struct netr_DsrGetDcSiteCoverageW {
|
|
struct {
|
|
const char *server_name;/* [unique,charset(UTF16)] */
|
|
} in;
|
|
|
|
struct {
|
|
struct DcSitesCtr **ctr;/* [ref] */
|
|
WERROR result;
|
|
} out;
|
|
|
|
};
|
|
|
|
|
|
struct netr_LogonSamLogonEx {
|
|
struct {
|
|
const char *server_name;/* [unique,charset(UTF16)] */
|
|
const char *computer_name;/* [unique,charset(UTF16)] */
|
|
enum netr_LogonInfoClass logon_level;
|
|
union netr_LogonLevel *logon;/* [ref,switch_is(logon_level)] */
|
|
uint16_t validation_level;
|
|
uint32_t *flags;/* [ref] */
|
|
} in;
|
|
|
|
struct {
|
|
union netr_Validation *validation;/* [ref,switch_is(validation_level)] */
|
|
uint8_t *authoritative;/* [ref] */
|
|
uint32_t *flags;/* [ref] */
|
|
NTSTATUS result;
|
|
} out;
|
|
|
|
};
|
|
|
|
|
|
struct netr_DsrEnumerateDomainTrusts {
|
|
struct {
|
|
const char *server_name;/* [unique,charset(UTF16)] */
|
|
uint32_t trust_flags;
|
|
} in;
|
|
|
|
struct {
|
|
struct netr_DomainTrustList *trusts;/* [ref] */
|
|
WERROR result;
|
|
} out;
|
|
|
|
};
|
|
|
|
|
|
struct netr_DsrDeregisterDNSHostRecords {
|
|
struct {
|
|
const char *server_name;/* [unique,charset(UTF16)] */
|
|
const char *domain;/* [unique,charset(UTF16)] */
|
|
struct GUID *domain_guid;/* [unique] */
|
|
struct GUID *dsa_guid;/* [unique] */
|
|
const char *dns_host;/* [ref,charset(UTF16)] */
|
|
} in;
|
|
|
|
struct {
|
|
WERROR result;
|
|
} out;
|
|
|
|
};
|
|
|
|
|
|
struct netr_ServerTrustPasswordsGet {
|
|
struct {
|
|
const char *server_name;/* [unique,charset(UTF16)] */
|
|
const char *account_name;/* [ref,charset(UTF16)] */
|
|
enum netr_SchannelType secure_channel_type;
|
|
const char *computer_name;/* [ref,charset(UTF16)] */
|
|
struct netr_Authenticator *credential;/* [ref] */
|
|
} in;
|
|
|
|
struct {
|
|
struct netr_Authenticator *return_authenticator;/* [ref] */
|
|
struct samr_Password *password;/* [ref] */
|
|
struct samr_Password *password2;/* [ref] */
|
|
NTSTATUS result;
|
|
} out;
|
|
|
|
};
|
|
|
|
|
|
struct netr_DsRGetForestTrustInformation {
|
|
struct {
|
|
const char *server_name;/* [unique,charset(UTF16)] */
|
|
const char *trusted_domain_name;/* [unique,charset(UTF16)] */
|
|
uint32_t flags;
|
|
} in;
|
|
|
|
struct {
|
|
struct lsa_ForestTrustInformation **forest_trust_info;/* [ref] */
|
|
WERROR result;
|
|
} out;
|
|
|
|
};
|
|
|
|
|
|
struct netr_GetForestTrustInformation {
|
|
struct {
|
|
const char *server_name;/* [unique,charset(UTF16)] */
|
|
const char *trusted_domain_name;/* [ref,charset(UTF16)] */
|
|
struct netr_Authenticator *credential;/* [ref] */
|
|
uint32_t flags;
|
|
} in;
|
|
|
|
struct {
|
|
struct netr_Authenticator *return_authenticator;/* [ref] */
|
|
struct lsa_ForestTrustInformation **forest_trust_info;/* [ref] */
|
|
WERROR result;
|
|
} out;
|
|
|
|
};
|
|
|
|
|
|
struct netr_LogonSamLogonWithFlags {
|
|
struct {
|
|
const char *server_name;/* [unique,charset(UTF16)] */
|
|
const char *computer_name;/* [unique,charset(UTF16)] */
|
|
struct netr_Authenticator *credential;/* [unique] */
|
|
enum netr_LogonInfoClass logon_level;
|
|
union netr_LogonLevel *logon;/* [ref,switch_is(logon_level)] */
|
|
uint16_t validation_level;
|
|
struct netr_Authenticator *return_authenticator;/* [unique] */
|
|
uint32_t *flags;/* [ref] */
|
|
} in;
|
|
|
|
struct {
|
|
union netr_Validation *validation;/* [ref,switch_is(validation_level)] */
|
|
uint8_t *authoritative;/* [ref] */
|
|
struct netr_Authenticator *return_authenticator;/* [unique] */
|
|
uint32_t *flags;/* [ref] */
|
|
NTSTATUS result;
|
|
} out;
|
|
|
|
};
|
|
|
|
|
|
struct netr_ServerGetTrustInfo {
|
|
struct {
|
|
const char *server_name;/* [unique,charset(UTF16)] */
|
|
const char *account_name;/* [ref,charset(UTF16)] */
|
|
enum netr_SchannelType secure_channel_type;
|
|
const char *computer_name;/* [ref,charset(UTF16)] */
|
|
struct netr_Authenticator *credential;/* [ref] */
|
|
} in;
|
|
|
|
struct {
|
|
struct netr_Authenticator *return_authenticator;/* [ref] */
|
|
struct samr_Password *new_owf_password;/* [ref] */
|
|
struct samr_Password *old_owf_password;/* [ref] */
|
|
struct netr_TrustInfo **trust_info;/* [ref] */
|
|
NTSTATUS result;
|
|
} out;
|
|
|
|
};
|
|
|
|
#endif /* _HEADER_netlogon */
|