2008-01-17 12:15:30 +03:00
/* header auto-generated by pidl */
# include <stdint.h>
2009-02-25 17:22:08 +03:00
# include "libcli/util/ntstatus.h"
2008-01-17 12:15:30 +03:00
# include "librpc/gen_ndr/misc.h"
# include "librpc/gen_ndr/lsa.h"
# include "librpc/gen_ndr/security.h"
# ifndef _HEADER_samr
# define _HEADER_samr
2008-10-23 21:24:41 +04:00
# 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) )
2009-04-16 02:40:00 +04:00
# define GENERIC_RIGHTS_SAM_EXECUTE ( (STANDARD_RIGHTS_EXECUTE_ACCESS|SAMR_ACCESS_LOOKUP_DOMAIN|SAMR_ACCESS_CONNECT_TO_SERVER) )
2008-10-23 21:24:41 +04:00
# 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) )
2008-10-23 21:39:14 +04:00
# 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) )
2008-10-23 21:45:58 +04:00
# 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) )
2008-10-23 21:53:11 +04:00
# 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) )
2008-01-17 12:15:30 +03:00
# define SAMR_ENUM_USERS_MULTIPLIER ( 54 )
2008-02-27 19:14:22 +03:00
# define PASS_MUST_CHANGE_AT_NEXT_LOGON ( 0x01 )
# define PASS_DONT_CHANGE_AT_NEXT_LOGON ( 0x00 )
2008-11-26 20:20:51 +03:00
enum netr_SamDatabaseID
# ifndef USE_UINT_ENUMS
{
SAM_DATABASE_DOMAIN = 0 ,
SAM_DATABASE_BUILTIN = 1 ,
SAM_DATABASE_PRIVS = 2
}
# else
{ __donnot_use_enum_netr_SamDatabaseID = 0x7FFFFFFF }
# define SAM_DATABASE_DOMAIN ( 0 )
# define SAM_DATABASE_BUILTIN ( 1 )
# define SAM_DATABASE_PRIVS ( 2 )
# endif
;
enum samr_RejectReason
# ifndef USE_UINT_ENUMS
{
SAMR_REJECT_OTHER = 0 ,
SAMR_REJECT_TOO_SHORT = 1 ,
SAMR_REJECT_IN_HISTORY = 2 ,
SAMR_REJECT_COMPLEXITY = 5
}
# else
{ __donnot_use_enum_samr_RejectReason = 0x7FFFFFFF }
# define SAMR_REJECT_OTHER ( 0 )
# define SAMR_REJECT_TOO_SHORT ( 1 )
# define SAMR_REJECT_IN_HISTORY ( 2 )
# define SAMR_REJECT_COMPLEXITY ( 5 )
# endif
;
2008-01-17 12:15:30 +03:00
/* 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 )
2009-04-16 02:40:00 +04:00
# define SAMR_ACCESS_LOOKUP_DOMAIN ( 0x00000020 )
2008-01-17 12:15:30 +03:00
/* bitmap samr_UserAccessMask */
2008-01-25 02:11:58 +03:00
# 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 )
2008-01-17 12:15:30 +03:00
/* bitmap samr_DomainAccessMask */
2008-01-25 02:11:58 +03:00
# 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 )
2008-01-17 12:15:30 +03:00
/* bitmap samr_GroupAccessMask */
2008-01-25 02:11:58 +03:00
# 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 )
2008-01-17 12:15:30 +03:00
/* bitmap samr_AliasAccessMask */
2008-01-25 02:11:58 +03:00
# 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 )
2008-01-17 12:15:30 +03:00
struct samr_SamEntry {
uint32_t idx ;
struct lsa_String name ;
} ;
struct samr_SamArray {
uint32_t count ;
struct samr_SamEntry * entries ; /* [unique,size_is(count)] */
} ;
2009-06-23 12:58:04 +04:00
enum samr_DomainInfoClass
# ifndef USE_UINT_ENUMS
{
DomainPasswordInformation = 1 ,
DomainGeneralInformation = 2 ,
DomainLogoffInformation = 3 ,
DomainOemInformation = 4 ,
DomainNameInformation = 5 ,
DomainReplicationInformation = 6 ,
DomainServerRoleInformation = 7 ,
DomainModifiedInformation = 8 ,
DomainStateInformation = 9 ,
DomainUasInformation = 10 ,
DomainGeneralInformation2 = 11 ,
DomainLockoutInformation = 12 ,
DomainModifiedInformation2 = 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
;
2008-01-17 12:15:30 +03:00
enum samr_Role
# ifndef USE_UINT_ENUMS
{
SAMR_ROLE_STANDALONE = 0 ,
SAMR_ROLE_DOMAIN_MEMBER = 1 ,
SAMR_ROLE_DOMAIN_BDC = 2 ,
SAMR_ROLE_DOMAIN_PDC = 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 )
2008-12-02 02:14:02 +03:00
enum samr_DomainServerState
# ifndef USE_UINT_ENUMS
{
DOMAIN_SERVER_ENABLED = 1 ,
DOMAIN_SERVER_DISABLED = 2
}
# else
{ __donnot_use_enum_samr_DomainServerState = 0x7FFFFFFF }
# define DOMAIN_SERVER_ENABLED ( 1 )
# define DOMAIN_SERVER_DISABLED ( 2 )
# endif
;
2008-01-17 12:15:30 +03:00
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 ;
} ;
2008-10-15 19:10:16 +04:00
struct samr_DomGeneralInformation {
2008-01-17 12:15:30 +03:00
NTTIME force_logoff_time ;
2008-10-15 19:10:16 +04:00
struct lsa_String oem_information ;
2008-01-17 12:15:30 +03:00
struct lsa_String domain_name ;
struct lsa_String primary ;
uint64_t sequence_num ;
2008-12-02 02:14:02 +03:00
enum samr_DomainServerState domain_server_state ;
2008-01-17 12:15:30 +03:00
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 ;
} ;
2008-10-15 19:10:16 +04:00
struct samr_DomOEMInformation {
struct lsa_String oem_information ;
2008-01-17 12:15:30 +03:00
} ;
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 {
2008-12-02 02:14:02 +03:00
enum samr_DomainServerState domain_server_state ;
2008-01-17 12:15:30 +03:00
} ;
2008-10-15 19:10:16 +04:00
struct samr_DomGeneralInformation2 {
struct samr_DomGeneralInformation general ;
2008-01-17 12:15:30 +03:00
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 ;
2008-11-29 02:30:21 +03:00
uint64_t modified_count_at_last_promotion ;
2008-01-17 12:15:30 +03:00
} ;
union samr_DomainInfo {
struct samr_DomInfo1 info1 ; /* [case] */
2008-10-15 19:10:16 +04:00
struct samr_DomGeneralInformation general ; /* [case(2)] */
2008-01-17 12:15:30 +03:00
struct samr_DomInfo3 info3 ; /* [case(3)] */
2008-10-15 19:10:16 +04:00
struct samr_DomOEMInformation oem ; /* [case(4)] */
2008-01-17 12:15:30 +03:00
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)] */
2008-10-15 19:10:16 +04:00
struct samr_DomGeneralInformation2 general2 ; /* [case(11)] */
2008-01-17 12:15:30 +03:00
struct samr_DomInfo12 info12 ; /* [case(12)] */
struct samr_DomInfo13 info13 ; /* [case(13)] */
} /* [switch_type(uint16)] */ ;
struct samr_Ids {
2008-02-02 01:28:37 +03:00
uint32_t count ; /* [range(0,1024)] */
2008-01-17 12:15:30 +03:00
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 = 1 ,
GROUPINFONAME = 2 ,
GROUPINFOATTRIBUTES = 3 ,
GROUPINFODESCRIPTION = 4 ,
GROUPINFOALL2 = 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 = 1 ,
ALIASINFONAME = 2 ,
ALIASINFODESCRIPTION = 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)] */ ;
2009-06-23 12:58:04 +04:00
enum samr_UserInfoLevel
# ifndef USE_UINT_ENUMS
{
UserGeneralInformation = 1 ,
UserPreferencesInformation = 2 ,
UserLogonInformation = 3 ,
UserLogonHoursInformation = 4 ,
UserAccountInformation = 5 ,
UserNameInformation = 6 ,
UserAccountNameInformation = 7 ,
UserFullNameInformation = 8 ,
UserPrimaryGroupInformation = 9 ,
UserHomeInformation = 10 ,
UserScriptInformation = 11 ,
UserProfileInformation = 12 ,
UserAdminCommentInformation = 13 ,
UserWorkStationsInformation = 14 ,
UserControlInformation = 16 ,
UserExpiresInformation = 17 ,
UserInternal1Information = 18 ,
UserParametersInformation = 20 ,
UserAllInformation = 21 ,
UserInternal4Information = 23 ,
UserInternal5Information = 24 ,
UserInternal4InformationNew = 25 ,
UserInternal5InformationNew = 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
;
2008-01-17 12:15:30 +03:00
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 ;
} ;
2008-02-08 11:43:21 +03:00
struct samr_Password {
uint8_t hash [ 16 ] ;
} /* [public,flag(LIBNDR_PRINT_ARRAY_HEX)] */ ;
struct samr_UserInfo18 {
struct samr_Password nt_pwd ;
2008-11-29 02:30:21 +03:00
struct samr_Password lm_pwd ;
2008-02-08 11:43:21 +03:00
uint8_t nt_pwd_active ;
2008-11-29 02:30:21 +03:00
uint8_t lm_pwd_active ;
uint8_t password_expired ;
2008-02-08 11:43:21 +03:00
} ;
2008-01-17 12:15:30 +03:00
struct samr_UserInfo20 {
2008-03-31 22:42:26 +04:00
struct lsa_BinaryString parameters ;
2008-01-17 12:15:30 +03:00
} ;
/* 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 )
2008-11-29 02:30:21 +03:00
# define SAMR_FIELD_NT_PASSWORD_PRESENT ( 0x01000000 )
# define SAMR_FIELD_LM_PASSWORD_PRESENT ( 0x02000000 )
2008-01-17 12:15:30 +03:00
# 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 ;
2008-03-31 22:42:26 +04:00
struct lsa_BinaryString parameters ;
2008-11-29 02:30:21 +03:00
struct lsa_BinaryString lm_owf_password ;
struct lsa_BinaryString nt_owf_password ;
2008-01-17 12:15:30 +03:00
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 ;
2008-11-29 02:30:21 +03:00
uint8_t nt_password_set ;
2008-01-17 12:15:30 +03:00
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 ;
2008-11-24 18:32:18 +03:00
uint8_t password_expired ;
2008-01-17 12:15:30 +03:00
} ;
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 ;
2008-11-24 18:32:18 +03:00
uint8_t password_expired ;
2008-01-17 12:15:30 +03:00
} ;
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)] */
2008-02-08 11:43:21 +03:00
struct samr_UserInfo18 info18 ; /* [case(18)] */
2008-01-17 12:15:30 +03:00
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 ;
2008-02-29 01:37:18 +03:00
struct lsa_AsciiStringLarge account_name ;
2008-01-17 12:15:30 +03:00
} ;
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 ;
} ;
2008-02-05 15:23:18 +03:00
enum samr_ConnectVersion
# ifndef USE_UINT_ENUMS
{
SAMR_CONNECT_PRE_W2K = 1 ,
SAMR_CONNECT_W2K = 2 ,
SAMR_CONNECT_AFTER_W2K = 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
;
2008-01-17 12:15:30 +03:00
struct samr_ChangeReject {
enum samr_RejectReason reason ;
uint32_t unknown1 ;
uint32_t unknown2 ;
} ;
struct samr_ConnectInfo1 {
2008-02-05 15:23:18 +03:00
enum samr_ConnectVersion client_version ;
2008-01-17 12:15:30 +03:00
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 = 1 ,
NetValidatePasswordChange = 2 ,
NetValidatePasswordReset = 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 = 0 ,
SAMR_VALIDATION_STATUS_PASSWORD_MUST_CHANGE = 1 ,
SAMR_VALIDATION_STATUS_ACCOUNT_LOCKED_OUT = 2 ,
2009-07-14 01:38:16 +04:00
SAMR_VALIDATION_STATUS_PASSWORD_EXPIRED = 3 ,
2008-01-17 12:15:30 +03:00
SAMR_VALIDATION_STATUS_BAD_PASSWORD = 4 ,
SAMR_VALIDATION_STATUS_PWD_HISTORY_CONFLICT = 5 ,
SAMR_VALIDATION_STATUS_PWD_TOO_SHORT = 6 ,
SAMR_VALIDATION_STATUS_PWD_TOO_LONG = 7 ,
SAMR_VALIDATION_STATUS_NOT_COMPLEX_ENOUGH = 8 ,
2009-07-14 01:38:16 +04:00
SAMR_VALIDATION_STATUS_PASSWORD_TOO_RECENT = 9 ,
SAMR_VALIDATION_STATUS_PASSWORD_FILTER_ERROR = 10
2008-01-17 12:15:30 +03:00
}
# 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 )
2009-07-14 01:38:16 +04:00
# define SAMR_VALIDATION_STATUS_PASSWORD_EXPIRED ( 3 )
2008-01-17 12:15:30 +03:00
# 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 )
2009-07-14 01:38:16 +04:00
# define SAMR_VALIDATION_STATUS_PASSWORD_FILTER_ERROR ( 10 )
2008-01-17 12:15:30 +03:00
# 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 {
2008-02-02 01:32:48 +03:00
struct sec_desc_buf * * sdbuf ; /* [ref] */
2008-01-17 12:15:30 +03:00
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 {
2008-02-05 03:27:46 +03:00
struct dom_sid2 * * sid ; /* [ref] */
2008-01-17 12:15:30 +03:00
NTSTATUS result ;
} out ;
} ;
struct samr_EnumDomains {
struct {
struct policy_handle * connect_handle ; /* [ref] */
uint32_t buf_size ;
uint32_t * resume_handle ; /* [ref] */
} in ;
struct {
2008-02-09 01:01:09 +03:00
struct samr_SamArray * * sam ; /* [ref] */
2008-01-17 12:15:30 +03:00
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] */
2009-06-23 12:58:04 +04:00
enum samr_DomainInfoClass level ;
2008-01-17 12:15:30 +03:00
} in ;
struct {
2008-02-05 16:42:01 +03:00
union samr_DomainInfo * * info ; /* [ref,switch_is(level)] */
2008-01-17 12:15:30 +03:00
NTSTATUS result ;
} out ;
} ;
struct samr_SetDomainInfo {
struct {
struct policy_handle * domain_handle ; /* [ref] */
2009-06-23 12:58:04 +04:00
enum samr_DomainInfoClass level ;
2008-01-17 12:15:30 +03:00
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 {
2008-02-12 11:52:46 +03:00
struct samr_SamArray * * sam ; /* [ref] */
2008-01-17 12:15:30 +03:00
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 {
2008-02-08 11:43:21 +03:00
struct samr_SamArray * * sam ; /* [ref] */
2008-01-17 12:15:30 +03:00
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] */
2008-02-12 11:54:11 +03:00
uint32_t max_size ;
2008-01-17 12:15:30 +03:00
uint32_t * resume_handle ; /* [ref] */
} in ;
struct {
2008-02-12 11:54:11 +03:00
struct samr_SamArray * * sam ; /* [ref] */
2008-01-17 12:15:30 +03:00
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] */
2008-02-02 01:28:37 +03:00
uint32_t num_names ; /* [range(0,1000)] */
2008-01-17 12:15:30 +03:00
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] */
2008-02-02 01:28:37 +03:00
uint32_t num_rids ; /* [range(0,1000)] */
2008-01-17 12:15:30 +03:00
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 {
2008-02-07 15:43:48 +03:00
union samr_GroupInfo * * info ; /* [ref,switch_is(level)] */
2008-01-17 12:15:30 +03:00
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 {
2008-02-05 05:19:35 +03:00
struct samr_RidTypeArray * * rids ; /* [ref] */
2008-01-17 12:15:30 +03:00
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 {
2008-02-07 12:02:17 +03:00
union samr_AliasInfo * * info ; /* [ref,switch_is(level)] */
2008-01-17 12:15:30 +03:00
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] */
2009-06-23 12:58:04 +04:00
enum samr_UserInfoLevel level ;
2008-01-17 12:15:30 +03:00
} in ;
struct {
2008-02-12 12:07:18 +03:00
union samr_UserInfo * * info ; /* [ref,switch_is(level)] */
2008-01-17 12:15:30 +03:00
NTSTATUS result ;
} out ;
} ;
struct samr_SetUserInfo {
struct {
struct policy_handle * user_handle ; /* [ref] */
2009-06-23 12:58:04 +04:00
enum samr_UserInfoLevel level ;
2008-01-17 12:15:30 +03:00
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 {
2008-02-07 16:24:21 +03:00
struct samr_RidWithAttributeArray * * rids ; /* [ref] */
2008-01-17 12:15:30 +03:00
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 ;
2008-04-23 01:11:21 +04:00
struct lsa_String * name ; /* [ref] */
2008-01-17 12:15:30 +03:00
} 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] */
2009-06-23 12:58:04 +04:00
enum samr_DomainInfoClass level ;
2008-01-17 12:15:30 +03:00
} in ;
struct {
2008-02-05 16:42:01 +03:00
union samr_DomainInfo * * info ; /* [ref,switch_is(level)] */
2008-01-17 12:15:30 +03:00
NTSTATUS result ;
} out ;
} ;
struct samr_QueryUserInfo2 {
struct {
struct policy_handle * user_handle ; /* [ref] */
2009-06-23 12:58:04 +04:00
enum samr_UserInfoLevel level ;
2008-01-17 12:15:30 +03:00
} in ;
struct {
2008-11-05 17:10:52 +03:00
union samr_UserInfo * * info ; /* [ref,switch_is(level)] */
2008-01-17 12:15:30 +03:00
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 ;
2008-04-23 01:11:21 +04:00
struct lsa_String * name ; /* [ref] */
2008-01-17 12:15:30 +03:00
} 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] */
2009-06-23 12:58:04 +04:00
enum samr_UserInfoLevel level ;
2008-01-17 12:15:30 +03:00
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)] */
2008-02-05 15:23:18 +03:00
enum samr_ConnectVersion client_version ;
2008-01-17 12:15:30 +03:00
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 {
2008-02-07 12:06:44 +03:00
struct samr_DomInfo1 * * dominfo ; /* [ref] */
struct samr_ChangeReject * * reject ; /* [ref] */
2008-01-17 12:15:30 +03:00
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 {
2008-11-10 18:08:43 +03:00
struct dom_sid2 * * sid ; /* [ref] */
2008-01-17 12:15:30 +03:00
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 ;
2008-11-05 17:10:52 +03:00
union samr_ValidatePasswordReq * req ; /* [ref,switch_is(level)] */
2008-01-17 12:15:30 +03:00
} in ;
struct {
2008-11-05 17:10:52 +03:00
union samr_ValidatePasswordRep * * rep ; /* [ref,switch_is(level)] */
2008-01-17 12:15:30 +03:00
NTSTATUS result ;
} out ;
} ;
# endif /* _HEADER_samr */