/* 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/security.h" #ifndef _HEADER_samr #define _HEADER_samr #define SAMR_ACCESS_ALL_ACCESS ( 0x0000003F ) #define GENERIC_RIGHTS_SAM_ALL_ACCESS ( (STANDARD_RIGHTS_REQUIRED_ACCESS|SAMR_ACCESS_ALL_ACCESS) ) #define GENERIC_RIGHTS_SAM_READ ( (STANDARD_RIGHTS_READ_ACCESS|SAMR_ACCESS_ENUM_DOMAINS) ) #define GENERIC_RIGHTS_SAM_WRITE ( (STANDARD_RIGHTS_WRITE_ACCESS|SAMR_ACCESS_CREATE_DOMAIN|SAMR_ACCESS_INITIALIZE_SERVER|SAMR_ACCESS_SHUTDOWN_SERVER) ) #define GENERIC_RIGHTS_SAM_EXECUTE ( (STANDARD_RIGHTS_EXECUTE_ACCESS|SAMR_ACCESS_LOOKUP_DOMAIN|SAMR_ACCESS_CONNECT_TO_SERVER) ) #define SAMR_USER_ACCESS_ALL_ACCESS ( 0x000007FF ) #define GENERIC_RIGHTS_USER_ALL_ACCESS ( (STANDARD_RIGHTS_REQUIRED_ACCESS|SAMR_USER_ACCESS_ALL_ACCESS) ) #define GENERIC_RIGHTS_USER_READ ( (STANDARD_RIGHTS_READ_ACCESS|SAMR_USER_ACCESS_GET_GROUP_MEMBERSHIP|SAMR_USER_ACCESS_GET_GROUPS|SAMR_USER_ACCESS_GET_ATTRIBUTES|SAMR_USER_ACCESS_GET_LOGONINFO|SAMR_USER_ACCESS_GET_LOCALE) ) #define GENERIC_RIGHTS_USER_WRITE ( (STANDARD_RIGHTS_WRITE_ACCESS|SAMR_USER_ACCESS_CHANGE_PASSWORD|SAMR_USER_ACCESS_SET_LOC_COM|SAMR_USER_ACCESS_SET_ATTRIBUTES|SAMR_USER_ACCESS_SET_PASSWORD|SAMR_USER_ACCESS_CHANGE_GROUP_MEMBERSHIP) ) #define GENERIC_RIGHTS_USER_EXECUTE ( (STANDARD_RIGHTS_EXECUTE_ACCESS|SAMR_USER_ACCESS_CHANGE_PASSWORD|SAMR_USER_ACCESS_GET_NAME_ETC) ) #define SAMR_DOMAIN_ACCESS_ALL_ACCESS ( 0x000007FF ) #define GENERIC_RIGHTS_DOMAIN_ALL_ACCESS ( (STANDARD_RIGHTS_REQUIRED_ACCESS|SAMR_DOMAIN_ACCESS_ALL_ACCESS) ) #define GENERIC_RIGHTS_DOMAIN_READ ( (STANDARD_RIGHTS_READ_ACCESS|SAMR_DOMAIN_ACCESS_LOOKUP_ALIAS|SAMR_DOMAIN_ACCESS_LOOKUP_INFO_2) ) #define GENERIC_RIGHTS_DOMAIN_WRITE ( (STANDARD_RIGHTS_WRITE_ACCESS|SAMR_DOMAIN_ACCESS_SET_INFO_3|SAMR_DOMAIN_ACCESS_CREATE_ALIAS|SAMR_DOMAIN_ACCESS_CREATE_GROUP|SAMR_DOMAIN_ACCESS_CREATE_USER|SAMR_DOMAIN_ACCESS_SET_INFO_2|SAMR_DOMAIN_ACCESS_SET_INFO_1) ) #define GENERIC_RIGHTS_DOMAIN_EXECUTE ( (STANDARD_RIGHTS_EXECUTE_ACCESS|SAMR_DOMAIN_ACCESS_OPEN_ACCOUNT|SAMR_DOMAIN_ACCESS_ENUM_ACCOUNTS|SAMR_DOMAIN_ACCESS_LOOKUP_INFO_1) ) #define SAMR_GROUP_ACCESS_ALL_ACCESS ( 0x0000001F ) #define GENERIC_RIGHTS_GROUP_ALL_ACCESS ( (STANDARD_RIGHTS_REQUIRED_ACCESS|SAMR_GROUP_ACCESS_ALL_ACCESS) ) #define GENERIC_RIGHTS_GROUP_READ ( (STANDARD_RIGHTS_READ_ACCESS|SAMR_GROUP_ACCESS_GET_MEMBERS) ) #define GENERIC_RIGHTS_GROUP_WRITE ( (STANDARD_RIGHTS_WRITE_ACCESS|SAMR_GROUP_ACCESS_REMOVE_MEMBER|SAMR_GROUP_ACCESS_ADD_MEMBER|SAMR_GROUP_ACCESS_SET_INFO) ) #define GENERIC_RIGHTS_GROUP_EXECUTE ( (STANDARD_RIGHTS_EXECUTE_ACCESS|SAMR_GROUP_ACCESS_LOOKUP_INFO) ) #define SAMR_ALIAS_ACCESS_ALL_ACCESS ( 0x0000001F ) #define GENERIC_RIGHTS_ALIAS_ALL_ACCESS ( (STANDARD_RIGHTS_REQUIRED_ACCESS|SAMR_ALIAS_ACCESS_ALL_ACCESS) ) #define GENERIC_RIGHTS_ALIAS_READ ( (STANDARD_RIGHTS_READ_ACCESS|SAMR_ALIAS_ACCESS_GET_MEMBERS) ) #define GENERIC_RIGHTS_ALIAS_WRITE ( (STANDARD_RIGHTS_WRITE_ACCESS|SAMR_ALIAS_ACCESS_REMOVE_MEMBER|SAMR_ALIAS_ACCESS_ADD_MEMBER|SAMR_ALIAS_ACCESS_SET_INFO) ) #define GENERIC_RIGHTS_ALIAS_EXECUTE ( (STANDARD_RIGHTS_EXECUTE_ACCESS|SAMR_ALIAS_ACCESS_LOOKUP_INFO) ) #define SAMR_ENUM_USERS_MULTIPLIER ( 54 ) #define PASS_MUST_CHANGE_AT_NEXT_LOGON ( 0x01 ) #define PASS_DONT_CHANGE_AT_NEXT_LOGON ( 0x00 ) enum netr_SamDatabaseID #ifndef USE_UINT_ENUMS { SAM_DATABASE_DOMAIN=(int)(0), SAM_DATABASE_BUILTIN=(int)(1), SAM_DATABASE_PRIVS=(int)(2) } #else { __donnot_use_enum_netr_SamDatabaseID=0x7FFFFFFF} #define SAM_DATABASE_DOMAIN ( 0 ) #define SAM_DATABASE_BUILTIN ( 1 ) #define SAM_DATABASE_PRIVS ( 2 ) #endif ; /* bitmap samr_AcctFlags */ #define ACB_DISABLED ( 0x00000001 ) #define ACB_HOMDIRREQ ( 0x00000002 ) #define ACB_PWNOTREQ ( 0x00000004 ) #define ACB_TEMPDUP ( 0x00000008 ) #define ACB_NORMAL ( 0x00000010 ) #define ACB_MNS ( 0x00000020 ) #define ACB_DOMTRUST ( 0x00000040 ) #define ACB_WSTRUST ( 0x00000080 ) #define ACB_SVRTRUST ( 0x00000100 ) #define ACB_PWNOEXP ( 0x00000200 ) #define ACB_AUTOLOCK ( 0x00000400 ) #define ACB_ENC_TXT_PWD_ALLOWED ( 0x00000800 ) #define ACB_SMARTCARD_REQUIRED ( 0x00001000 ) #define ACB_TRUSTED_FOR_DELEGATION ( 0x00002000 ) #define ACB_NOT_DELEGATED ( 0x00004000 ) #define ACB_USE_DES_KEY_ONLY ( 0x00008000 ) #define ACB_DONT_REQUIRE_PREAUTH ( 0x00010000 ) #define ACB_PW_EXPIRED ( 0x00020000 ) #define ACB_NO_AUTH_DATA_REQD ( 0x00080000 ) /* bitmap samr_ConnectAccessMask */ #define SAMR_ACCESS_CONNECT_TO_SERVER ( 0x00000001 ) #define SAMR_ACCESS_SHUTDOWN_SERVER ( 0x00000002 ) #define SAMR_ACCESS_INITIALIZE_SERVER ( 0x00000004 ) #define SAMR_ACCESS_CREATE_DOMAIN ( 0x00000008 ) #define SAMR_ACCESS_ENUM_DOMAINS ( 0x00000010 ) #define SAMR_ACCESS_LOOKUP_DOMAIN ( 0x00000020 ) /* bitmap samr_UserAccessMask */ #define SAMR_USER_ACCESS_GET_NAME_ETC ( 0x00000001 ) #define SAMR_USER_ACCESS_GET_LOCALE ( 0x00000002 ) #define SAMR_USER_ACCESS_SET_LOC_COM ( 0x00000004 ) #define SAMR_USER_ACCESS_GET_LOGONINFO ( 0x00000008 ) #define SAMR_USER_ACCESS_GET_ATTRIBUTES ( 0x00000010 ) #define SAMR_USER_ACCESS_SET_ATTRIBUTES ( 0x00000020 ) #define SAMR_USER_ACCESS_CHANGE_PASSWORD ( 0x00000040 ) #define SAMR_USER_ACCESS_SET_PASSWORD ( 0x00000080 ) #define SAMR_USER_ACCESS_GET_GROUPS ( 0x00000100 ) #define SAMR_USER_ACCESS_GET_GROUP_MEMBERSHIP ( 0x00000200 ) #define SAMR_USER_ACCESS_CHANGE_GROUP_MEMBERSHIP ( 0x00000400 ) /* bitmap samr_DomainAccessMask */ #define SAMR_DOMAIN_ACCESS_LOOKUP_INFO_1 ( 0x00000001 ) #define SAMR_DOMAIN_ACCESS_SET_INFO_1 ( 0x00000002 ) #define SAMR_DOMAIN_ACCESS_LOOKUP_INFO_2 ( 0x00000004 ) #define SAMR_DOMAIN_ACCESS_SET_INFO_2 ( 0x00000008 ) #define SAMR_DOMAIN_ACCESS_CREATE_USER ( 0x00000010 ) #define SAMR_DOMAIN_ACCESS_CREATE_GROUP ( 0x00000020 ) #define SAMR_DOMAIN_ACCESS_CREATE_ALIAS ( 0x00000040 ) #define SAMR_DOMAIN_ACCESS_LOOKUP_ALIAS ( 0x00000080 ) #define SAMR_DOMAIN_ACCESS_ENUM_ACCOUNTS ( 0x00000100 ) #define SAMR_DOMAIN_ACCESS_OPEN_ACCOUNT ( 0x00000200 ) #define SAMR_DOMAIN_ACCESS_SET_INFO_3 ( 0x00000400 ) /* bitmap samr_GroupAccessMask */ #define SAMR_GROUP_ACCESS_LOOKUP_INFO ( 0x00000001 ) #define SAMR_GROUP_ACCESS_SET_INFO ( 0x00000002 ) #define SAMR_GROUP_ACCESS_ADD_MEMBER ( 0x00000004 ) #define SAMR_GROUP_ACCESS_REMOVE_MEMBER ( 0x00000008 ) #define SAMR_GROUP_ACCESS_GET_MEMBERS ( 0x00000010 ) /* bitmap samr_AliasAccessMask */ #define SAMR_ALIAS_ACCESS_ADD_MEMBER ( 0x00000001 ) #define SAMR_ALIAS_ACCESS_REMOVE_MEMBER ( 0x00000002 ) #define SAMR_ALIAS_ACCESS_GET_MEMBERS ( 0x00000004 ) #define SAMR_ALIAS_ACCESS_LOOKUP_INFO ( 0x00000008 ) #define SAMR_ALIAS_ACCESS_SET_INFO ( 0x00000010 ) struct samr_SamEntry { uint32_t idx; struct lsa_String name; }; struct samr_SamArray { uint32_t count; struct samr_SamEntry *entries;/* [unique,size_is(count)] */ }; enum samr_DomainInfoClass #ifndef USE_UINT_ENUMS { DomainPasswordInformation=(int)(1), DomainGeneralInformation=(int)(2), DomainLogoffInformation=(int)(3), DomainOemInformation=(int)(4), DomainNameInformation=(int)(5), DomainReplicationInformation=(int)(6), DomainServerRoleInformation=(int)(7), DomainModifiedInformation=(int)(8), DomainStateInformation=(int)(9), DomainUasInformation=(int)(10), DomainGeneralInformation2=(int)(11), DomainLockoutInformation=(int)(12), DomainModifiedInformation2=(int)(13) } #else { __donnot_use_enum_samr_DomainInfoClass=0x7FFFFFFF} #define DomainPasswordInformation ( 1 ) #define DomainGeneralInformation ( 2 ) #define DomainLogoffInformation ( 3 ) #define DomainOemInformation ( 4 ) #define DomainNameInformation ( 5 ) #define DomainReplicationInformation ( 6 ) #define DomainServerRoleInformation ( 7 ) #define DomainModifiedInformation ( 8 ) #define DomainStateInformation ( 9 ) #define DomainUasInformation ( 10 ) #define DomainGeneralInformation2 ( 11 ) #define DomainLockoutInformation ( 12 ) #define DomainModifiedInformation2 ( 13 ) #endif ; enum samr_Role #ifndef USE_UINT_ENUMS { SAMR_ROLE_STANDALONE=(int)(0), SAMR_ROLE_DOMAIN_MEMBER=(int)(1), SAMR_ROLE_DOMAIN_BDC=(int)(2), SAMR_ROLE_DOMAIN_PDC=(int)(3) } #else { __donnot_use_enum_samr_Role=0x7FFFFFFF} #define SAMR_ROLE_STANDALONE ( 0 ) #define SAMR_ROLE_DOMAIN_MEMBER ( 1 ) #define SAMR_ROLE_DOMAIN_BDC ( 2 ) #define SAMR_ROLE_DOMAIN_PDC ( 3 ) #endif ; /* bitmap samr_PasswordProperties */ #define DOMAIN_PASSWORD_COMPLEX ( 0x00000001 ) #define DOMAIN_PASSWORD_NO_ANON_CHANGE ( 0x00000002 ) #define DOMAIN_PASSWORD_NO_CLEAR_CHANGE ( 0x00000004 ) #define DOMAIN_PASSWORD_LOCKOUT_ADMINS ( 0x00000008 ) #define DOMAIN_PASSWORD_STORE_CLEARTEXT ( 0x00000010 ) #define DOMAIN_REFUSE_PASSWORD_CHANGE ( 0x00000020 ) enum samr_DomainServerState #ifndef USE_UINT_ENUMS { DOMAIN_SERVER_ENABLED=(int)(1), DOMAIN_SERVER_DISABLED=(int)(2) } #else { __donnot_use_enum_samr_DomainServerState=0x7FFFFFFF} #define DOMAIN_SERVER_ENABLED ( 1 ) #define DOMAIN_SERVER_DISABLED ( 2 ) #endif ; struct samr_DomInfo1 { uint16_t min_password_length; uint16_t password_history_length; uint32_t password_properties; int64_t max_password_age; int64_t min_password_age; }; struct samr_DomGeneralInformation { NTTIME force_logoff_time; struct lsa_String oem_information; struct lsa_String domain_name; struct lsa_String primary; uint64_t sequence_num; enum samr_DomainServerState domain_server_state; enum samr_Role role; uint32_t unknown3; uint32_t num_users; uint32_t num_groups; uint32_t num_aliases; }; struct samr_DomInfo3 { NTTIME force_logoff_time; }; struct samr_DomOEMInformation { struct lsa_String oem_information; }; struct samr_DomInfo5 { struct lsa_String domain_name; }; struct samr_DomInfo6 { struct lsa_String primary; }; struct samr_DomInfo7 { enum samr_Role role; }; struct samr_DomInfo8 { uint64_t sequence_num; NTTIME domain_create_time; }; struct samr_DomInfo9 { enum samr_DomainServerState domain_server_state; }; struct samr_DomGeneralInformation2 { struct samr_DomGeneralInformation general; uint64_t lockout_duration; uint64_t lockout_window; uint16_t lockout_threshold; }; struct samr_DomInfo12 { uint64_t lockout_duration; uint64_t lockout_window; uint16_t lockout_threshold; }; struct samr_DomInfo13 { uint64_t sequence_num; NTTIME domain_create_time; uint64_t modified_count_at_last_promotion; }; union samr_DomainInfo { struct samr_DomInfo1 info1;/* [case] */ struct samr_DomGeneralInformation general;/* [case(2)] */ struct samr_DomInfo3 info3;/* [case(3)] */ struct samr_DomOEMInformation oem;/* [case(4)] */ struct samr_DomInfo5 info5;/* [case(5)] */ struct samr_DomInfo6 info6;/* [case(6)] */ struct samr_DomInfo7 info7;/* [case(7)] */ struct samr_DomInfo8 info8;/* [case(8)] */ struct samr_DomInfo9 info9;/* [case(9)] */ struct samr_DomGeneralInformation2 general2;/* [case(11)] */ struct samr_DomInfo12 info12;/* [case(12)] */ struct samr_DomInfo13 info13;/* [case(13)] */ }/* [switch_type(uint16)] */; struct samr_Ids { uint32_t count;/* [range(0,1024)] */ uint32_t *ids;/* [unique,size_is(count)] */ }; /* bitmap samr_GroupAttrs */ #define SE_GROUP_MANDATORY ( 0x00000001 ) #define SE_GROUP_ENABLED_BY_DEFAULT ( 0x00000002 ) #define SE_GROUP_ENABLED ( 0x00000004 ) #define SE_GROUP_OWNER ( 0x00000008 ) #define SE_GROUP_USE_FOR_DENY_ONLY ( 0x00000010 ) #define SE_GROUP_RESOURCE ( 0x20000000 ) #define SE_GROUP_LOGON_ID ( 0xC0000000 ) struct samr_GroupInfoAll { struct lsa_String name; uint32_t attributes; uint32_t num_members; struct lsa_String description; }; struct samr_GroupInfoAttributes { uint32_t attributes; }; struct samr_GroupInfoDescription { struct lsa_String description; }; enum samr_GroupInfoEnum #ifndef USE_UINT_ENUMS { GROUPINFOALL=(int)(1), GROUPINFONAME=(int)(2), GROUPINFOATTRIBUTES=(int)(3), GROUPINFODESCRIPTION=(int)(4), GROUPINFOALL2=(int)(5) } #else { __donnot_use_enum_samr_GroupInfoEnum=0x7FFFFFFF} #define GROUPINFOALL ( 1 ) #define GROUPINFONAME ( 2 ) #define GROUPINFOATTRIBUTES ( 3 ) #define GROUPINFODESCRIPTION ( 4 ) #define GROUPINFOALL2 ( 5 ) #endif ; union samr_GroupInfo { struct samr_GroupInfoAll all;/* [case(GROUPINFOALL)] */ struct lsa_String name;/* [case(GROUPINFONAME)] */ struct samr_GroupInfoAttributes attributes;/* [case(GROUPINFOATTRIBUTES)] */ struct lsa_String description;/* [case(GROUPINFODESCRIPTION)] */ struct samr_GroupInfoAll all2;/* [case(GROUPINFOALL2)] */ }/* [switch_type(samr_GroupInfoEnum)] */; struct samr_RidTypeArray { uint32_t count; uint32_t *rids;/* [unique,size_is(count)] */ uint32_t *types;/* [unique,size_is(count)] */ }; struct samr_AliasInfoAll { struct lsa_String name; uint32_t num_members; struct lsa_String description; }; enum samr_AliasInfoEnum #ifndef USE_UINT_ENUMS { ALIASINFOALL=(int)(1), ALIASINFONAME=(int)(2), ALIASINFODESCRIPTION=(int)(3) } #else { __donnot_use_enum_samr_AliasInfoEnum=0x7FFFFFFF} #define ALIASINFOALL ( 1 ) #define ALIASINFONAME ( 2 ) #define ALIASINFODESCRIPTION ( 3 ) #endif ; union samr_AliasInfo { struct samr_AliasInfoAll all;/* [case(ALIASINFOALL)] */ struct lsa_String name;/* [case(ALIASINFONAME)] */ struct lsa_String description;/* [case(ALIASINFODESCRIPTION)] */ }/* [switch_type(samr_AliasInfoEnum)] */; enum samr_UserInfoLevel #ifndef USE_UINT_ENUMS { UserGeneralInformation=(int)(1), UserPreferencesInformation=(int)(2), UserLogonInformation=(int)(3), UserLogonHoursInformation=(int)(4), UserAccountInformation=(int)(5), UserNameInformation=(int)(6), UserAccountNameInformation=(int)(7), UserFullNameInformation=(int)(8), UserPrimaryGroupInformation=(int)(9), UserHomeInformation=(int)(10), UserScriptInformation=(int)(11), UserProfileInformation=(int)(12), UserAdminCommentInformation=(int)(13), UserWorkStationsInformation=(int)(14), UserControlInformation=(int)(16), UserExpiresInformation=(int)(17), UserInternal1Information=(int)(18), UserParametersInformation=(int)(20), UserAllInformation=(int)(21), UserInternal4Information=(int)(23), UserInternal5Information=(int)(24), UserInternal4InformationNew=(int)(25), UserInternal5InformationNew=(int)(26) } #else { __donnot_use_enum_samr_UserInfoLevel=0x7FFFFFFF} #define UserGeneralInformation ( 1 ) #define UserPreferencesInformation ( 2 ) #define UserLogonInformation ( 3 ) #define UserLogonHoursInformation ( 4 ) #define UserAccountInformation ( 5 ) #define UserNameInformation ( 6 ) #define UserAccountNameInformation ( 7 ) #define UserFullNameInformation ( 8 ) #define UserPrimaryGroupInformation ( 9 ) #define UserHomeInformation ( 10 ) #define UserScriptInformation ( 11 ) #define UserProfileInformation ( 12 ) #define UserAdminCommentInformation ( 13 ) #define UserWorkStationsInformation ( 14 ) #define UserControlInformation ( 16 ) #define UserExpiresInformation ( 17 ) #define UserInternal1Information ( 18 ) #define UserParametersInformation ( 20 ) #define UserAllInformation ( 21 ) #define UserInternal4Information ( 23 ) #define UserInternal5Information ( 24 ) #define UserInternal4InformationNew ( 25 ) #define UserInternal5InformationNew ( 26 ) #endif ; struct samr_UserInfo1 { struct lsa_String account_name; struct lsa_String full_name; uint32_t primary_gid; struct lsa_String description; struct lsa_String comment; }; struct samr_UserInfo2 { struct lsa_String comment; struct lsa_String unknown; uint16_t country_code; uint16_t code_page; }; struct samr_LogonHours { uint16_t units_per_week; uint8_t *bits;/* [unique,length_is(units_per_week/8),size_is(1260)] */ }/* [public,flag(LIBNDR_PRINT_ARRAY_HEX)] */; struct samr_UserInfo3 { 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 profile_path; struct lsa_String workstations; NTTIME last_logon; NTTIME last_logoff; NTTIME last_password_change; NTTIME allow_password_change; NTTIME force_password_change; struct samr_LogonHours logon_hours; uint16_t bad_password_count; uint16_t logon_count; uint32_t acct_flags; }; struct samr_UserInfo4 { struct samr_LogonHours logon_hours; }; struct samr_UserInfo5 { 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 profile_path; 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_UserInfo6 { struct lsa_String account_name; struct lsa_String full_name; }; struct samr_UserInfo7 { struct lsa_String account_name; }; struct samr_UserInfo8 { struct lsa_String full_name; }; struct samr_UserInfo9 { uint32_t primary_gid; }; struct samr_UserInfo10 { struct lsa_String home_directory; struct lsa_String home_drive; }; struct samr_UserInfo11 { struct lsa_String logon_script; }; struct samr_UserInfo12 { struct lsa_String profile_path; }; struct samr_UserInfo13 { struct lsa_String description; }; struct samr_UserInfo14 { struct lsa_String workstations; }; struct samr_UserInfo16 { uint32_t acct_flags; }; struct samr_UserInfo17 { NTTIME acct_expiry; }; struct samr_Password { uint8_t hash[16]; }/* [public,flag(LIBNDR_PRINT_ARRAY_HEX)] */; struct samr_UserInfo18 { struct samr_Password nt_pwd; struct samr_Password lm_pwd; uint8_t nt_pwd_active; uint8_t lm_pwd_active; uint8_t password_expired; }; struct samr_UserInfo20 { struct lsa_BinaryString parameters; }; /* bitmap samr_FieldsPresent */ #define SAMR_FIELD_ACCOUNT_NAME ( 0x00000001 ) #define SAMR_FIELD_FULL_NAME ( 0x00000002 ) #define SAMR_FIELD_RID ( 0x00000004 ) #define SAMR_FIELD_PRIMARY_GID ( 0x00000008 ) #define SAMR_FIELD_DESCRIPTION ( 0x00000010 ) #define SAMR_FIELD_COMMENT ( 0x00000020 ) #define SAMR_FIELD_HOME_DIRECTORY ( 0x00000040 ) #define SAMR_FIELD_HOME_DRIVE ( 0x00000080 ) #define SAMR_FIELD_LOGON_SCRIPT ( 0x00000100 ) #define SAMR_FIELD_PROFILE_PATH ( 0x00000200 ) #define SAMR_FIELD_WORKSTATIONS ( 0x00000400 ) #define SAMR_FIELD_LAST_LOGON ( 0x00000800 ) #define SAMR_FIELD_LAST_LOGOFF ( 0x00001000 ) #define SAMR_FIELD_LOGON_HOURS ( 0x00002000 ) #define SAMR_FIELD_BAD_PWD_COUNT ( 0x00004000 ) #define SAMR_FIELD_NUM_LOGONS ( 0x00008000 ) #define SAMR_FIELD_ALLOW_PWD_CHANGE ( 0x00010000 ) #define SAMR_FIELD_FORCE_PWD_CHANGE ( 0x00020000 ) #define SAMR_FIELD_LAST_PWD_CHANGE ( 0x00040000 ) #define SAMR_FIELD_ACCT_EXPIRY ( 0x00080000 ) #define SAMR_FIELD_ACCT_FLAGS ( 0x00100000 ) #define SAMR_FIELD_PARAMETERS ( 0x00200000 ) #define SAMR_FIELD_COUNTRY_CODE ( 0x00400000 ) #define SAMR_FIELD_CODE_PAGE ( 0x00800000 ) #define SAMR_FIELD_NT_PASSWORD_PRESENT ( 0x01000000 ) #define SAMR_FIELD_LM_PASSWORD_PRESENT ( 0x02000000 ) #define SAMR_FIELD_PRIVATE_DATA ( 0x04000000 ) #define SAMR_FIELD_EXPIRED_FLAG ( 0x08000000 ) #define SAMR_FIELD_SEC_DESC ( 0x10000000 ) #define SAMR_FIELD_OWF_PWD ( 0x20000000 ) struct samr_UserInfo21 { NTTIME last_logon; NTTIME last_logoff; NTTIME last_password_change; NTTIME acct_expiry; NTTIME allow_password_change; NTTIME force_password_change; struct lsa_String account_name; struct lsa_String full_name; struct lsa_String home_directory; struct lsa_String home_drive; struct lsa_String logon_script; struct lsa_String profile_path; struct lsa_String description; struct lsa_String workstations; struct lsa_String comment; struct lsa_BinaryString parameters; struct lsa_BinaryString lm_owf_password; struct lsa_BinaryString nt_owf_password; struct lsa_String unknown3; uint32_t buf_count; uint8_t *buffer;/* [unique,size_is(buf_count)] */ uint32_t rid; uint32_t primary_gid; uint32_t acct_flags; uint32_t fields_present; struct samr_LogonHours logon_hours; uint16_t bad_password_count; uint16_t logon_count; uint16_t country_code; uint16_t code_page; uint8_t lm_password_set; uint8_t nt_password_set; uint8_t password_expired; uint8_t unknown4; }; struct samr_CryptPassword { uint8_t data[516]; }/* [public,flag(LIBNDR_PRINT_ARRAY_HEX)] */; struct samr_UserInfo23 { struct samr_UserInfo21 info; struct samr_CryptPassword password; }; struct samr_UserInfo24 { struct samr_CryptPassword password; uint8_t password_expired; }; struct samr_CryptPasswordEx { uint8_t data[532]; }/* [flag(LIBNDR_PRINT_ARRAY_HEX)] */; struct samr_UserInfo25 { struct samr_UserInfo21 info; struct samr_CryptPasswordEx password; }; struct samr_UserInfo26 { struct samr_CryptPasswordEx password; uint8_t password_expired; }; union samr_UserInfo { struct samr_UserInfo1 info1;/* [case] */ struct samr_UserInfo2 info2;/* [case(2)] */ struct samr_UserInfo3 info3;/* [case(3)] */ struct samr_UserInfo4 info4;/* [case(4)] */ struct samr_UserInfo5 info5;/* [case(5)] */ struct samr_UserInfo6 info6;/* [case(6)] */ struct samr_UserInfo7 info7;/* [case(7)] */ struct samr_UserInfo8 info8;/* [case(8)] */ struct samr_UserInfo9 info9;/* [case(9)] */ struct samr_UserInfo10 info10;/* [case(10)] */ struct samr_UserInfo11 info11;/* [case(11)] */ struct samr_UserInfo12 info12;/* [case(12)] */ struct samr_UserInfo13 info13;/* [case(13)] */ struct samr_UserInfo14 info14;/* [case(14)] */ struct samr_UserInfo16 info16;/* [case(16)] */ struct samr_UserInfo17 info17;/* [case(17)] */ struct samr_UserInfo18 info18;/* [case(18)] */ struct samr_UserInfo20 info20;/* [case(20)] */ struct samr_UserInfo21 info21;/* [case(21)] */ struct samr_UserInfo23 info23;/* [case(23)] */ struct samr_UserInfo24 info24;/* [case(24)] */ struct samr_UserInfo25 info25;/* [case(25)] */ struct samr_UserInfo26 info26;/* [case(26)] */ }/* [switch_type(uint16)] */; struct samr_RidWithAttribute { uint32_t rid; uint32_t attributes; }/* [public] */; struct samr_RidWithAttributeArray { uint32_t count; struct samr_RidWithAttribute *rids;/* [unique,size_is(count)] */ }/* [public] */; struct samr_DispEntryGeneral { uint32_t idx; uint32_t rid; uint32_t acct_flags; struct lsa_String account_name; struct lsa_String description; struct lsa_String full_name; }; struct samr_DispInfoGeneral { uint32_t count; struct samr_DispEntryGeneral *entries;/* [unique,size_is(count)] */ }; struct samr_DispEntryFull { uint32_t idx; uint32_t rid; uint32_t acct_flags; struct lsa_String account_name; struct lsa_String description; }; struct samr_DispInfoFull { uint32_t count; struct samr_DispEntryFull *entries;/* [unique,size_is(count)] */ }; struct samr_DispEntryFullGroup { uint32_t idx; uint32_t rid; uint32_t acct_flags; struct lsa_String account_name; struct lsa_String description; }; struct samr_DispInfoFullGroups { uint32_t count; struct samr_DispEntryFullGroup *entries;/* [unique,size_is(count)] */ }; struct samr_DispEntryAscii { uint32_t idx; struct lsa_AsciiStringLarge account_name; }; struct samr_DispInfoAscii { uint32_t count; struct samr_DispEntryAscii *entries;/* [unique,size_is(count)] */ }; union samr_DispInfo { struct samr_DispInfoGeneral info1;/* [case] */ struct samr_DispInfoFull info2;/* [case(2)] */ struct samr_DispInfoFullGroups info3;/* [case(3)] */ struct samr_DispInfoAscii info4;/* [case(4)] */ struct samr_DispInfoAscii info5;/* [case(5)] */ }/* [switch_type(uint16)] */; struct samr_PwInfo { uint16_t min_password_length; uint32_t password_properties; }; enum samr_ConnectVersion #ifndef USE_UINT_ENUMS { SAMR_CONNECT_PRE_W2K=(int)(1), SAMR_CONNECT_W2K=(int)(2), SAMR_CONNECT_AFTER_W2K=(int)(3) } #else { __donnot_use_enum_samr_ConnectVersion=0x7FFFFFFF} #define SAMR_CONNECT_PRE_W2K ( 1 ) #define SAMR_CONNECT_W2K ( 2 ) #define SAMR_CONNECT_AFTER_W2K ( 3 ) #endif ; enum samPwdChangeReason #ifndef USE_UINT_ENUMS { SAM_PWD_CHANGE_NO_ERROR=(int)(0), SAM_PWD_CHANGE_PASSWORD_TOO_SHORT=(int)(1), SAM_PWD_CHANGE_PWD_IN_HISTORY=(int)(2), SAM_PWD_CHANGE_USERNAME_IN_PASSWORD=(int)(3), SAM_PWD_CHANGE_FULLNAME_IN_PASSWORD=(int)(4), SAM_PWD_CHANGE_NOT_COMPLEX=(int)(5), SAM_PWD_CHANGE_MACHINE_NOT_DEFAULT=(int)(6), SAM_PWD_CHANGE_FAILED_BY_FILTER=(int)(7), SAM_PWD_CHANGE_PASSWORD_TOO_LONG=(int)(8) } #else { __donnot_use_enum_samPwdChangeReason=0x7FFFFFFF} #define SAM_PWD_CHANGE_NO_ERROR ( 0 ) #define SAM_PWD_CHANGE_PASSWORD_TOO_SHORT ( 1 ) #define SAM_PWD_CHANGE_PWD_IN_HISTORY ( 2 ) #define SAM_PWD_CHANGE_USERNAME_IN_PASSWORD ( 3 ) #define SAM_PWD_CHANGE_FULLNAME_IN_PASSWORD ( 4 ) #define SAM_PWD_CHANGE_NOT_COMPLEX ( 5 ) #define SAM_PWD_CHANGE_MACHINE_NOT_DEFAULT ( 6 ) #define SAM_PWD_CHANGE_FAILED_BY_FILTER ( 7 ) #define SAM_PWD_CHANGE_PASSWORD_TOO_LONG ( 8 ) #endif ; struct userPwdChangeFailureInformation { enum samPwdChangeReason extendedFailureReason; const char *filterModuleName;/* [unique,charset(UTF16)] */ }; struct samr_ConnectInfo1 { enum samr_ConnectVersion client_version; uint32_t unknown2; }; union samr_ConnectInfo { struct samr_ConnectInfo1 info1;/* [case] */ }; /* bitmap samr_ValidateFieldsPresent */ #define SAMR_VALIDATE_FIELD_PASSWORD_LAST_SET ( 0x00000001 ) #define SAMR_VALIDATE_FIELD_BAD_PASSWORD_TIME ( 0x00000002 ) #define SAMR_VALIDATE_FIELD_LOCKOUT_TIME ( 0x00000004 ) #define SAMR_VALIDATE_FIELD_BAD_PASSWORD_COUNT ( 0x00000008 ) #define SAMR_VALIDATE_FIELD_PASSWORD_HISTORY_LENGTH ( 0x00000010 ) #define SAMR_VALIDATE_FIELD_PASSWORD_HISTORY ( 0x00000020 ) enum samr_ValidatePasswordLevel #ifndef USE_UINT_ENUMS { NetValidateAuthentication=(int)(1), NetValidatePasswordChange=(int)(2), NetValidatePasswordReset=(int)(3) } #else { __donnot_use_enum_samr_ValidatePasswordLevel=0x7FFFFFFF} #define NetValidateAuthentication ( 1 ) #define NetValidatePasswordChange ( 2 ) #define NetValidatePasswordReset ( 3 ) #endif ; enum samr_ValidationStatus #ifndef USE_UINT_ENUMS { SAMR_VALIDATION_STATUS_SUCCESS=(int)(0), SAMR_VALIDATION_STATUS_PASSWORD_MUST_CHANGE=(int)(1), SAMR_VALIDATION_STATUS_ACCOUNT_LOCKED_OUT=(int)(2), SAMR_VALIDATION_STATUS_PASSWORD_EXPIRED=(int)(3), SAMR_VALIDATION_STATUS_BAD_PASSWORD=(int)(4), SAMR_VALIDATION_STATUS_PWD_HISTORY_CONFLICT=(int)(5), SAMR_VALIDATION_STATUS_PWD_TOO_SHORT=(int)(6), SAMR_VALIDATION_STATUS_PWD_TOO_LONG=(int)(7), SAMR_VALIDATION_STATUS_NOT_COMPLEX_ENOUGH=(int)(8), SAMR_VALIDATION_STATUS_PASSWORD_TOO_RECENT=(int)(9), SAMR_VALIDATION_STATUS_PASSWORD_FILTER_ERROR=(int)(10) } #else { __donnot_use_enum_samr_ValidationStatus=0x7FFFFFFF} #define SAMR_VALIDATION_STATUS_SUCCESS ( 0 ) #define SAMR_VALIDATION_STATUS_PASSWORD_MUST_CHANGE ( 1 ) #define SAMR_VALIDATION_STATUS_ACCOUNT_LOCKED_OUT ( 2 ) #define SAMR_VALIDATION_STATUS_PASSWORD_EXPIRED ( 3 ) #define SAMR_VALIDATION_STATUS_BAD_PASSWORD ( 4 ) #define SAMR_VALIDATION_STATUS_PWD_HISTORY_CONFLICT ( 5 ) #define SAMR_VALIDATION_STATUS_PWD_TOO_SHORT ( 6 ) #define SAMR_VALIDATION_STATUS_PWD_TOO_LONG ( 7 ) #define SAMR_VALIDATION_STATUS_NOT_COMPLEX_ENOUGH ( 8 ) #define SAMR_VALIDATION_STATUS_PASSWORD_TOO_RECENT ( 9 ) #define SAMR_VALIDATION_STATUS_PASSWORD_FILTER_ERROR ( 10 ) #endif ; struct samr_ValidationBlob { uint32_t length; uint8_t *data;/* [unique,size_is(length)] */ }; struct samr_ValidatePasswordInfo { uint32_t fields_present; NTTIME last_password_change; NTTIME bad_password_time; NTTIME lockout_time; uint32_t bad_pwd_count; uint32_t pwd_history_len; struct samr_ValidationBlob *pwd_history;/* [unique,size_is(pwd_history_len)] */ }; struct samr_ValidatePasswordRepCtr { struct samr_ValidatePasswordInfo info; enum samr_ValidationStatus status; }; union samr_ValidatePasswordRep { struct samr_ValidatePasswordRepCtr ctr1;/* [case] */ struct samr_ValidatePasswordRepCtr ctr2;/* [case(2)] */ struct samr_ValidatePasswordRepCtr ctr3;/* [case(3)] */ }/* [switch_type(uint16)] */; struct samr_ValidatePasswordReq3 { struct samr_ValidatePasswordInfo info; struct lsa_StringLarge password; struct lsa_StringLarge account; struct samr_ValidationBlob hash; uint8_t pwd_must_change_at_next_logon; uint8_t clear_lockout; }; struct samr_ValidatePasswordReq2 { struct samr_ValidatePasswordInfo info; struct lsa_StringLarge password; struct lsa_StringLarge account; struct samr_ValidationBlob hash; uint8_t password_matched; }; struct samr_ValidatePasswordReq1 { struct samr_ValidatePasswordInfo info; uint8_t password_matched; }; union samr_ValidatePasswordReq { struct samr_ValidatePasswordReq1 req1;/* [case] */ struct samr_ValidatePasswordReq2 req2;/* [case(2)] */ struct samr_ValidatePasswordReq3 req3;/* [case(3)] */ }/* [switch_type(uint16)] */; struct samr_Connect { struct { uint16_t *system_name;/* [unique] */ uint32_t access_mask; } in; struct { struct policy_handle *connect_handle;/* [ref] */ NTSTATUS result; } out; }; struct samr_Close { struct { struct policy_handle *handle;/* [ref] */ } in; struct { struct policy_handle *handle;/* [ref] */ NTSTATUS result; } out; }; struct samr_SetSecurity { struct { struct policy_handle *handle;/* [ref] */ uint32_t sec_info; struct sec_desc_buf *sdbuf;/* [ref] */ } in; struct { NTSTATUS result; } out; }; struct samr_QuerySecurity { struct { struct policy_handle *handle;/* [ref] */ uint32_t sec_info; } in; struct { struct sec_desc_buf **sdbuf;/* [ref] */ NTSTATUS result; } out; }; struct samr_Shutdown { struct { struct policy_handle *connect_handle;/* [ref] */ } in; struct { NTSTATUS result; } out; }; struct samr_LookupDomain { struct { struct policy_handle *connect_handle;/* [ref] */ struct lsa_String *domain_name;/* [ref] */ } in; struct { struct dom_sid2 **sid;/* [ref] */ NTSTATUS result; } out; }; struct samr_EnumDomains { struct { struct policy_handle *connect_handle;/* [ref] */ uint32_t buf_size; uint32_t *resume_handle;/* [ref] */ } in; struct { struct samr_SamArray **sam;/* [ref] */ uint32_t *num_entries;/* [ref] */ uint32_t *resume_handle;/* [ref] */ NTSTATUS result; } out; }; struct samr_OpenDomain { struct { struct policy_handle *connect_handle;/* [ref] */ uint32_t access_mask; struct dom_sid2 *sid;/* [ref] */ } in; struct { struct policy_handle *domain_handle;/* [ref] */ NTSTATUS result; } out; }; struct samr_QueryDomainInfo { struct { struct policy_handle *domain_handle;/* [ref] */ enum samr_DomainInfoClass level; } in; struct { union samr_DomainInfo **info;/* [ref,switch_is(level)] */ NTSTATUS result; } out; }; struct samr_SetDomainInfo { struct { struct policy_handle *domain_handle;/* [ref] */ enum samr_DomainInfoClass level; union samr_DomainInfo *info;/* [ref,switch_is(level)] */ } in; struct { NTSTATUS result; } out; }; struct samr_CreateDomainGroup { struct { struct policy_handle *domain_handle;/* [ref] */ struct lsa_String *name;/* [ref] */ uint32_t access_mask; } in; struct { struct policy_handle *group_handle;/* [ref] */ uint32_t *rid;/* [ref] */ NTSTATUS result; } out; }; struct samr_EnumDomainGroups { struct { struct policy_handle *domain_handle;/* [ref] */ uint32_t max_size; uint32_t *resume_handle;/* [ref] */ } in; struct { struct samr_SamArray **sam;/* [ref] */ uint32_t *num_entries;/* [ref] */ uint32_t *resume_handle;/* [ref] */ NTSTATUS result; } out; }; struct samr_CreateUser { struct { struct policy_handle *domain_handle;/* [ref] */ struct lsa_String *account_name;/* [ref] */ uint32_t access_mask; } in; struct { struct policy_handle *user_handle;/* [ref] */ uint32_t *rid;/* [ref] */ NTSTATUS result; } out; }; struct samr_EnumDomainUsers { struct { struct policy_handle *domain_handle;/* [ref] */ uint32_t acct_flags; uint32_t max_size; uint32_t *resume_handle;/* [ref] */ } in; struct { struct samr_SamArray **sam;/* [ref] */ uint32_t *num_entries;/* [ref] */ uint32_t *resume_handle;/* [ref] */ NTSTATUS result; } out; }; struct samr_CreateDomAlias { struct { struct policy_handle *domain_handle;/* [ref] */ struct lsa_String *alias_name;/* [ref] */ uint32_t access_mask; } in; struct { struct policy_handle *alias_handle;/* [ref] */ uint32_t *rid;/* [ref] */ NTSTATUS result; } out; }; struct samr_EnumDomainAliases { struct { struct policy_handle *domain_handle;/* [ref] */ uint32_t max_size; uint32_t *resume_handle;/* [ref] */ } in; struct { struct samr_SamArray **sam;/* [ref] */ uint32_t *num_entries;/* [ref] */ uint32_t *resume_handle;/* [ref] */ NTSTATUS result; } out; }; struct samr_GetAliasMembership { struct { struct policy_handle *domain_handle;/* [ref] */ struct lsa_SidArray *sids;/* [ref] */ } in; struct { struct samr_Ids *rids;/* [ref] */ NTSTATUS result; } out; }; struct samr_LookupNames { struct { struct policy_handle *domain_handle;/* [ref] */ uint32_t num_names;/* [range(0,1000)] */ struct lsa_String *names;/* [length_is(num_names),size_is(1000)] */ } in; struct { struct samr_Ids *rids;/* [ref] */ struct samr_Ids *types;/* [ref] */ NTSTATUS result; } out; }; struct samr_LookupRids { struct { struct policy_handle *domain_handle;/* [ref] */ uint32_t num_rids;/* [range(0,1000)] */ uint32_t *rids;/* [length_is(num_rids),size_is(1000)] */ } in; struct { struct lsa_Strings *names;/* [ref] */ struct samr_Ids *types;/* [ref] */ NTSTATUS result; } out; }; struct samr_OpenGroup { struct { struct policy_handle *domain_handle;/* [ref] */ uint32_t access_mask; uint32_t rid; } in; struct { struct policy_handle *group_handle;/* [ref] */ NTSTATUS result; } out; }; struct samr_QueryGroupInfo { struct { struct policy_handle *group_handle;/* [ref] */ enum samr_GroupInfoEnum level; } in; struct { union samr_GroupInfo **info;/* [ref,switch_is(level)] */ NTSTATUS result; } out; }; struct samr_SetGroupInfo { struct { struct policy_handle *group_handle;/* [ref] */ enum samr_GroupInfoEnum level; union samr_GroupInfo *info;/* [ref,switch_is(level)] */ } in; struct { NTSTATUS result; } out; }; struct samr_AddGroupMember { struct { struct policy_handle *group_handle;/* [ref] */ uint32_t rid; uint32_t flags; } in; struct { NTSTATUS result; } out; }; struct samr_DeleteDomainGroup { struct { struct policy_handle *group_handle;/* [ref] */ } in; struct { struct policy_handle *group_handle;/* [ref] */ NTSTATUS result; } out; }; struct samr_DeleteGroupMember { struct { struct policy_handle *group_handle;/* [ref] */ uint32_t rid; } in; struct { NTSTATUS result; } out; }; struct samr_QueryGroupMember { struct { struct policy_handle *group_handle;/* [ref] */ } in; struct { struct samr_RidTypeArray **rids;/* [ref] */ NTSTATUS result; } out; }; struct samr_SetMemberAttributesOfGroup { struct { struct policy_handle *group_handle;/* [ref] */ uint32_t unknown1; uint32_t unknown2; } in; struct { NTSTATUS result; } out; }; struct samr_OpenAlias { struct { struct policy_handle *domain_handle;/* [ref] */ uint32_t access_mask; uint32_t rid; } in; struct { struct policy_handle *alias_handle;/* [ref] */ NTSTATUS result; } out; }; struct samr_QueryAliasInfo { struct { struct policy_handle *alias_handle;/* [ref] */ enum samr_AliasInfoEnum level; } in; struct { union samr_AliasInfo **info;/* [ref,switch_is(level)] */ NTSTATUS result; } out; }; struct samr_SetAliasInfo { struct { struct policy_handle *alias_handle;/* [ref] */ enum samr_AliasInfoEnum level; union samr_AliasInfo *info;/* [ref,switch_is(level)] */ } in; struct { NTSTATUS result; } out; }; struct samr_DeleteDomAlias { struct { struct policy_handle *alias_handle;/* [ref] */ } in; struct { struct policy_handle *alias_handle;/* [ref] */ NTSTATUS result; } out; }; struct samr_AddAliasMember { struct { struct policy_handle *alias_handle;/* [ref] */ struct dom_sid2 *sid;/* [ref] */ } in; struct { NTSTATUS result; } out; }; struct samr_DeleteAliasMember { struct { struct policy_handle *alias_handle;/* [ref] */ struct dom_sid2 *sid;/* [ref] */ } in; struct { NTSTATUS result; } out; }; struct samr_GetMembersInAlias { struct { struct policy_handle *alias_handle;/* [ref] */ } in; struct { struct lsa_SidArray *sids;/* [ref] */ NTSTATUS result; } out; }; struct samr_OpenUser { struct { struct policy_handle *domain_handle;/* [ref] */ uint32_t access_mask; uint32_t rid; } in; struct { struct policy_handle *user_handle;/* [ref] */ NTSTATUS result; } out; }; struct samr_DeleteUser { struct { struct policy_handle *user_handle;/* [ref] */ } in; struct { struct policy_handle *user_handle;/* [ref] */ NTSTATUS result; } out; }; struct samr_QueryUserInfo { struct { struct policy_handle *user_handle;/* [ref] */ enum samr_UserInfoLevel level; } in; struct { union samr_UserInfo **info;/* [ref,switch_is(level)] */ NTSTATUS result; } out; }; struct samr_SetUserInfo { struct { struct policy_handle *user_handle;/* [ref] */ enum samr_UserInfoLevel level; union samr_UserInfo *info;/* [ref,switch_is(level)] */ } in; struct { NTSTATUS result; } out; }; struct samr_ChangePasswordUser { struct { struct policy_handle *user_handle;/* [ref] */ uint8_t lm_present; struct samr_Password *old_lm_crypted;/* [unique] */ struct samr_Password *new_lm_crypted;/* [unique] */ uint8_t nt_present; struct samr_Password *old_nt_crypted;/* [unique] */ struct samr_Password *new_nt_crypted;/* [unique] */ uint8_t cross1_present; struct samr_Password *nt_cross;/* [unique] */ uint8_t cross2_present; struct samr_Password *lm_cross;/* [unique] */ } in; struct { NTSTATUS result; } out; }; struct samr_GetGroupsForUser { struct { struct policy_handle *user_handle;/* [ref] */ } in; struct { struct samr_RidWithAttributeArray **rids;/* [ref] */ NTSTATUS result; } out; }; struct samr_QueryDisplayInfo { struct { struct policy_handle *domain_handle;/* [ref] */ uint16_t level; uint32_t start_idx; uint32_t max_entries; uint32_t buf_size; } in; struct { uint32_t *total_size;/* [ref] */ uint32_t *returned_size;/* [ref] */ union samr_DispInfo *info;/* [ref,switch_is(level)] */ NTSTATUS result; } out; }; struct samr_GetDisplayEnumerationIndex { struct { struct policy_handle *domain_handle;/* [ref] */ uint16_t level; struct lsa_String *name;/* [ref] */ } in; struct { uint32_t *idx;/* [ref] */ NTSTATUS result; } out; }; struct samr_TestPrivateFunctionsDomain { struct { struct policy_handle *domain_handle;/* [ref] */ } in; struct { NTSTATUS result; } out; }; struct samr_TestPrivateFunctionsUser { struct { struct policy_handle *user_handle;/* [ref] */ } in; struct { NTSTATUS result; } out; }; struct samr_GetUserPwInfo { struct { struct policy_handle *user_handle;/* [ref] */ } in; struct { struct samr_PwInfo *info;/* [ref] */ NTSTATUS result; } out; }; struct samr_RemoveMemberFromForeignDomain { struct { struct policy_handle *domain_handle;/* [ref] */ struct dom_sid2 *sid;/* [ref] */ } in; struct { NTSTATUS result; } out; }; struct samr_QueryDomainInfo2 { struct { struct policy_handle *domain_handle;/* [ref] */ enum samr_DomainInfoClass level; } in; struct { union samr_DomainInfo **info;/* [ref,switch_is(level)] */ NTSTATUS result; } out; }; struct samr_QueryUserInfo2 { struct { struct policy_handle *user_handle;/* [ref] */ enum samr_UserInfoLevel level; } in; struct { union samr_UserInfo **info;/* [ref,switch_is(level)] */ NTSTATUS result; } out; }; struct samr_QueryDisplayInfo2 { struct { struct policy_handle *domain_handle;/* [ref] */ uint16_t level; uint32_t start_idx; uint32_t max_entries; uint32_t buf_size; } in; struct { uint32_t *total_size;/* [ref] */ uint32_t *returned_size;/* [ref] */ union samr_DispInfo *info;/* [ref,switch_is(level)] */ NTSTATUS result; } out; }; struct samr_GetDisplayEnumerationIndex2 { struct { struct policy_handle *domain_handle;/* [ref] */ uint16_t level; struct lsa_String *name;/* [ref] */ } in; struct { uint32_t *idx;/* [ref] */ NTSTATUS result; } out; }; struct samr_CreateUser2 { struct { struct policy_handle *domain_handle;/* [ref] */ struct lsa_String *account_name;/* [ref] */ uint32_t acct_flags; uint32_t access_mask; } in; struct { struct policy_handle *user_handle;/* [ref] */ uint32_t *access_granted;/* [ref] */ uint32_t *rid;/* [ref] */ NTSTATUS result; } out; }; struct samr_QueryDisplayInfo3 { struct { struct policy_handle *domain_handle;/* [ref] */ uint16_t level; uint32_t start_idx; uint32_t max_entries; uint32_t buf_size; } in; struct { uint32_t *total_size;/* [ref] */ uint32_t *returned_size;/* [ref] */ union samr_DispInfo *info;/* [ref,switch_is(level)] */ NTSTATUS result; } out; }; struct samr_AddMultipleMembersToAlias { struct { struct policy_handle *alias_handle;/* [ref] */ struct lsa_SidArray *sids;/* [ref] */ } in; struct { NTSTATUS result; } out; }; struct samr_RemoveMultipleMembersFromAlias { struct { struct policy_handle *alias_handle;/* [ref] */ struct lsa_SidArray *sids;/* [ref] */ } in; struct { NTSTATUS result; } out; }; struct samr_OemChangePasswordUser2 { struct { struct lsa_AsciiString *server;/* [unique] */ struct lsa_AsciiString *account;/* [ref] */ struct samr_CryptPassword *password;/* [unique] */ struct samr_Password *hash;/* [unique] */ } in; struct { NTSTATUS result; } out; }; struct samr_ChangePasswordUser2 { struct { struct lsa_String *server;/* [unique] */ struct lsa_String *account;/* [ref] */ struct samr_CryptPassword *nt_password;/* [unique] */ struct samr_Password *nt_verifier;/* [unique] */ uint8_t lm_change; struct samr_CryptPassword *lm_password;/* [unique] */ struct samr_Password *lm_verifier;/* [unique] */ } in; struct { NTSTATUS result; } out; }; struct samr_GetDomPwInfo { struct { struct lsa_String *domain_name;/* [unique] */ } in; struct { struct samr_PwInfo *info;/* [ref] */ NTSTATUS result; } out; }; struct samr_Connect2 { struct { const char *system_name;/* [unique,charset(UTF16)] */ uint32_t access_mask; } in; struct { struct policy_handle *connect_handle;/* [ref] */ NTSTATUS result; } out; }; struct samr_SetUserInfo2 { struct { struct policy_handle *user_handle;/* [ref] */ enum samr_UserInfoLevel level; union samr_UserInfo *info;/* [ref,switch_is(level)] */ } in; struct { NTSTATUS result; } out; }; struct samr_SetBootKeyInformation { struct { struct policy_handle *connect_handle;/* [ref] */ uint32_t unknown1; uint32_t unknown2; uint32_t unknown3; } in; struct { NTSTATUS result; } out; }; struct samr_GetBootKeyInformation { struct { struct policy_handle *domain_handle;/* [ref] */ } in; struct { uint32_t *unknown;/* [ref] */ NTSTATUS result; } out; }; struct samr_Connect3 { struct { const char *system_name;/* [unique,charset(UTF16)] */ uint32_t unknown; uint32_t access_mask; } in; struct { struct policy_handle *connect_handle;/* [ref] */ NTSTATUS result; } out; }; struct samr_Connect4 { struct { const char *system_name;/* [unique,charset(UTF16)] */ enum samr_ConnectVersion client_version; uint32_t access_mask; } in; struct { struct policy_handle *connect_handle;/* [ref] */ NTSTATUS result; } out; }; struct samr_ChangePasswordUser3 { struct { struct lsa_String *server;/* [unique] */ struct lsa_String *account;/* [ref] */ struct samr_CryptPassword *nt_password;/* [unique] */ struct samr_Password *nt_verifier;/* [unique] */ uint8_t lm_change; struct samr_CryptPassword *lm_password;/* [unique] */ struct samr_Password *lm_verifier;/* [unique] */ struct samr_CryptPassword *password3;/* [unique] */ } in; struct { struct samr_DomInfo1 **dominfo;/* [ref] */ struct userPwdChangeFailureInformation **reject;/* [ref] */ NTSTATUS result; } out; }; struct samr_Connect5 { struct { const char *system_name;/* [unique,charset(UTF16)] */ uint32_t access_mask; uint32_t level_in; union samr_ConnectInfo *info_in;/* [ref,switch_is(level_in)] */ } in; struct { uint32_t *level_out;/* [ref] */ union samr_ConnectInfo *info_out;/* [ref,switch_is(*level_out)] */ struct policy_handle *connect_handle;/* [ref] */ NTSTATUS result; } out; }; struct samr_RidToSid { struct { struct policy_handle *domain_handle;/* [ref] */ uint32_t rid; } in; struct { struct dom_sid2 **sid;/* [ref] */ NTSTATUS result; } out; }; struct samr_SetDsrmPassword { struct { struct lsa_String *name;/* [unique] */ uint32_t unknown; struct samr_Password *hash;/* [unique] */ } in; struct { NTSTATUS result; } out; }; struct samr_ValidatePassword { struct { enum samr_ValidatePasswordLevel level; union samr_ValidatePasswordReq *req;/* [ref,switch_is(level)] */ } in; struct { union samr_ValidatePasswordRep **rep;/* [ref,switch_is(level)] */ NTSTATUS result; } out; }; #endif /* _HEADER_samr */