#ifndef _RPC_NETLOGON_H
#define _RPC_NETLOGON_H
#define NET_SAMLOGON 0x02
#define NET_SAMLOGOFF 0x03
#define NET_REQCHAL 0x04
#define NET_AUTH 0x05
#define NET_SRVPWSET 0x06
#define NET_SAM_DELTAS 0x07
#define NET_LOGON_CTRL 0x0c
#define NET_AUTH2 0x0f
#define NET_LOGON_CTRL2 0x0e
#define NET_SAM_SYNC 0x10
#define NET_TRUST_DOM_LIST 0x13
#define SEC_CHAN_WKSTA 2
#define SEC_CHAN_DOMAIN 4
#define SEC_CHAN_BDC 6
#define SAM_DELTA_DOMAIN_INFO 0x01
#define SAM_DELTA_GROUP_INFO 0x02
#define SAM_DELTA_ACCOUNT_INFO 0x05
#define SAM_DELTA_GROUP_MEM 0x08
#define SAM_DELTA_ALIAS_INFO 0x09
#define SAM_DELTA_ALIAS_MEM 0x0C
#define SAM_DELTA_UNKNOWN 0x0D
#define SAM_DELTA_UNKNOWN2 0x10
#define SAM_DELTA_SAM_STAMP 0x16
#define SAM_DATABASE_DOMAIN 0x00
#define SAM_DATABASE_BUILTIN 0x01
#define SAM_DATABASE_PRIVS 0x02
#if 0
typedef struct net_user_info_2
{
uint32 ptr_user_info;
NTTIME logon_time;
NTTIME logoff_time;
NTTIME kickoff_time;
NTTIME pass_last_set_time;
NTTIME pass_can_change_time;
NTTIME pass_must_change_time;
UNIHDR hdr_user_name;
UNIHDR hdr_full_name;
UNIHDR hdr_logon_script;
UNIHDR hdr_profile_path;
UNIHDR hdr_home_dir;
UNIHDR hdr_dir_drive;
uint16 logon_count;
uint16 bad_pw_count;
uint32 user_id;
uint32 group_id;
uint32 num_groups;
uint32 buffer_groups;
uint32 user_flgs;
uint8 user_sess_key[16];
UNIHDR hdr_logon_srv;
UNIHDR hdr_logon_dom;
uint32 buffer_dom_id;
uint8 padding[40];
UNISTR2 uni_user_name;
UNISTR2 uni_full_name;
UNISTR2 uni_logon_script;
UNISTR2 uni_profile_path;
UNISTR2 uni_home_dir;
UNISTR2 uni_dir_drive;
uint32 num_groups2;
DOM_GID *gids;
UNISTR2 uni_logon_srv;
UNISTR2 uni_logon_dom;
DOM_SID2 dom_sid;
uint32 num_other_groups;
DOM_GID *other_gids;
DOM_SID2 *other_sids;
} NET_USER_INFO_2;
#endif
typedef struct net_user_info_3
{
uint32 ptr_user_info;
NTTIME logon_time;
NTTIME logoff_time;
NTTIME kickoff_time;
NTTIME pass_last_set_time;
NTTIME pass_can_change_time;
NTTIME pass_must_change_time;
UNIHDR hdr_user_name;
UNIHDR hdr_full_name;
UNIHDR hdr_logon_script;
UNIHDR hdr_profile_path;
UNIHDR hdr_home_dir;
UNIHDR hdr_dir_drive;
uint16 logon_count;
uint16 bad_pw_count;
uint32 user_rid;
uint32 group_rid;
uint32 num_groups;
uint32 buffer_groups;
uint32 user_flgs;
uint8 user_sess_key[16];
UNIHDR hdr_logon_srv;
UNIHDR hdr_logon_dom;
uint32 buffer_dom_id;
uint8 padding[40];
uint32 num_other_sids;
uint32 buffer_other_sids;
UNISTR2 uni_user_name;
UNISTR2 uni_full_name;
UNISTR2 uni_logon_script;
UNISTR2 uni_profile_path;
UNISTR2 uni_home_dir;
UNISTR2 uni_dir_drive;
uint32 num_groups2;
DOM_GID *gids;
UNISTR2 uni_logon_srv;
UNISTR2 uni_logon_dom;
DOM_SID2 dom_sid;
uint32 num_other_groups;
DOM_GID *other_gids;
DOM_SID2 *other_sids;
} NET_USER_INFO_3;
typedef struct netlogon_1_info
{
uint32 flags;
uint32 pdc_status;
} NETLOGON_INFO_1;
typedef struct netlogon_2_info
{
uint32 flags;
uint32 pdc_status;
uint32 ptr_trusted_dc_name;
uint32 tc_status;
UNISTR2 uni_trusted_dc_name;
} NETLOGON_INFO_2;
typedef struct netlogon_3_info
{
uint32 flags;
uint32 logon_attempts;
uint32 reserved_1;
uint32 reserved_2;
uint32 reserved_3;
uint32 reserved_4;
uint32 reserved_5;
} NETLOGON_INFO_3;
typedef struct net_q_logon_ctrl_info
{
uint32 ptr;
UNISTR2 uni_server_name;
uint32 function_code;
uint32 query_level;
} NET_Q_LOGON_CTRL;
typedef struct net_r_logon_ctrl_info
{
uint32 switch_value;
uint32 ptr;
union {
NETLOGON_INFO_1 info1;
} logon;
NTSTATUS status;
} NET_R_LOGON_CTRL;
typedef struct net_q_logon_ctrl2_info
{
uint32 ptr;
UNISTR2 uni_server_name;
uint32 function_code;
uint32 query_level;
uint32 switch_value;
} NET_Q_LOGON_CTRL2;
typedef struct net_r_logon_ctrl2_info
{
uint32 switch_value;
uint32 ptr;
union
{
NETLOGON_INFO_1 info1;
NETLOGON_INFO_2 info2;
NETLOGON_INFO_3 info3;
} logon;
NTSTATUS status;
} NET_R_LOGON_CTRL2;
typedef struct net_q_trust_dom_info
{
uint32 ptr;
UNISTR2 uni_server_name;
} NET_Q_TRUST_DOM_LIST;
#define MAX_TRUST_DOMS 1
typedef struct net_r_trust_dom_info
{
UNISTR2 uni_trust_dom_name[MAX_TRUST_DOMS];
NTSTATUS status;
} NET_R_TRUST_DOM_LIST;
typedef struct neg_flags_info
{
uint32 neg_flags;
} NEG_FLAGS;
typedef struct net_q_req_chal_info
{
uint32 undoc_buffer;
UNISTR2 uni_logon_srv;
UNISTR2 uni_logon_clnt;
DOM_CHAL clnt_chal;
} NET_Q_REQ_CHAL;
typedef struct net_r_req_chal_info
{
DOM_CHAL srv_chal;
NTSTATUS status;
} NET_R_REQ_CHAL;
typedef struct net_q_auth_info
{
DOM_LOG_INFO clnt_id;
DOM_CHAL clnt_chal;
} NET_Q_AUTH;
typedef struct net_r_auth_info
{
DOM_CHAL srv_chal;
NTSTATUS status;
} NET_R_AUTH;
typedef struct net_q_auth2_info
{
DOM_LOG_INFO clnt_id;
DOM_CHAL clnt_chal;
NEG_FLAGS clnt_flgs;
} NET_Q_AUTH_2;
typedef struct net_r_auth2_info
{
DOM_CHAL srv_chal;
NEG_FLAGS srv_flgs;
NTSTATUS status;
} NET_R_AUTH_2;
typedef struct net_q_srv_pwset_info
{
DOM_CLNT_INFO clnt_id;
uint8 pwd[16];
} NET_Q_SRV_PWSET;
typedef struct net_r_srv_pwset_info
{
DOM_CRED srv_cred;
NTSTATUS status;
} NET_R_SRV_PWSET;
typedef struct net_network_info_2
{
uint32 ptr_id_info2;
UNIHDR hdr_domain_name;
uint32 param_ctrl;
DOM_LOGON_ID logon_id;
UNIHDR hdr_user_name;
UNIHDR hdr_wksta_name;
uint8 lm_chal[8];
STRHDR hdr_nt_chal_resp;
STRHDR hdr_lm_chal_resp;
UNISTR2 uni_domain_name;
UNISTR2 uni_user_name;
UNISTR2 uni_wksta_name;
STRING2 nt_chal_resp;
STRING2 lm_chal_resp;
} NET_ID_INFO_2;
typedef struct id_info_1
{
uint32 ptr_id_info1;
UNIHDR hdr_domain_name;
uint32 param_ctrl;
DOM_LOGON_ID logon_id;
UNIHDR hdr_user_name;
UNIHDR hdr_wksta_name;
OWF_INFO lm_owf;
OWF_INFO nt_owf;
UNISTR2 uni_domain_name;
UNISTR2 uni_user_name;
UNISTR2 uni_wksta_name;
} NET_ID_INFO_1;
#define INTERACTIVE_LOGON_TYPE 1
#define NET_LOGON_TYPE 2
typedef struct net_id_info_ctr_info
{
uint16 switch_value;
union
{
NET_ID_INFO_1 id1;
NET_ID_INFO_2 id2;
} auth;
} NET_ID_INFO_CTR;
typedef struct sam_info
{
DOM_CLNT_INFO2 client;
uint32 ptr_rtn_cred;
DOM_CRED rtn_cred;
uint16 logon_level;
NET_ID_INFO_CTR *ctr;
} DOM_SAM_INFO;
typedef struct net_q_sam_logon_info
{
DOM_SAM_INFO sam_id;
uint16 validation_level;
} NET_Q_SAM_LOGON;
typedef struct net_r_sam_logon_info
{
uint32 buffer_creds;
DOM_CRED srv_creds;
uint16 switch_value;
NET_USER_INFO_3 *user;
uint32 auth_resp;
NTSTATUS status;
} NET_R_SAM_LOGON;
typedef struct net_q_sam_logoff_info
{
DOM_SAM_INFO sam_id;
} NET_Q_SAM_LOGOFF;
typedef struct net_r_sam_logoff_info
{
uint32 buffer_creds;
DOM_CRED srv_creds;
NTSTATUS status;
} NET_R_SAM_LOGOFF;
typedef struct net_q_sam_sync_info
{
UNISTR2 uni_srv_name;
UNISTR2 uni_cli_name;
DOM_CRED cli_creds;
DOM_CRED ret_creds;
uint32 database_id;
uint32 restart_state;
uint32 sync_context;
uint32 max_size;
} NET_Q_SAM_SYNC;
typedef struct sam_delta_hdr_info
{
uint16 type;
uint16 type2;
uint32 target_rid;
uint32 type3;
uint32 ptr_delta;
} SAM_DELTA_HDR;
typedef struct sam_domain_info_info
{
UNIHDR hdr_dom_name;
UNIHDR hdr_oem_info;
UINT64_S force_logoff;
uint16 min_pwd_len;
uint16 pwd_history_len;
UINT64_S max_pwd_age;
UINT64_S min_pwd_age;
UINT64_S dom_mod_count;
NTTIME creation_time;
BUFHDR2 hdr_sec_desc;
UNIHDR hdr_unknown;
uint8 reserved[40];
UNISTR2 uni_dom_name;
UNISTR2 buf_oem_info;
BUFFER4 buf_sec_desc;
UNISTR2 buf_unknown;
} SAM_DOMAIN_INFO;
typedef struct sam_group_info_info
{
UNIHDR hdr_grp_name;
DOM_GID gid;
UNIHDR hdr_grp_desc;
BUFHDR2 hdr_sec_desc;
uint8 reserved[48];
UNISTR2 uni_grp_name;
UNISTR2 uni_grp_desc;
BUFFER4 buf_sec_desc;
} SAM_GROUP_INFO;
typedef struct sam_passwd_info
{
uint32 unk_0;
UNIHDR hdr_lm_pwd;
uint8 buf_lm_pwd[16];
UNIHDR hdr_nt_pwd;
uint8 buf_nt_pwd[16];
UNIHDR hdr_empty_lm;
UNIHDR hdr_empty_nt;
} SAM_PWD;
typedef struct sam_account_info_info
{
UNIHDR hdr_acct_name;
UNIHDR hdr_full_name;
uint32 user_rid;
uint32 group_rid;
UNIHDR hdr_home_dir;
UNIHDR hdr_dir_drive;
UNIHDR hdr_logon_script;
UNIHDR hdr_acct_desc;
UNIHDR hdr_workstations;
NTTIME logon_time;
NTTIME logoff_time;
uint32 logon_divs;
uint32 ptr_logon_hrs;
uint16 bad_pwd_count;
uint16 logon_count;
NTTIME pwd_last_set_time;
NTTIME acct_expiry_time;
uint32 acb_info;
uint8 nt_pwd[16];
uint8 lm_pwd[16];
uint8 nt_pwd_present;
uint8 lm_pwd_present;
uint8 pwd_expired;
UNIHDR hdr_comment;
UNIHDR hdr_parameters;
uint16 country;
uint16 codepage;
BUFHDR2 hdr_sec_desc;
UNIHDR hdr_profile;
UNIHDR hdr_reserved[3];
uint32 dw_reserved[4];
UNISTR2 uni_acct_name;
UNISTR2 uni_full_name;
UNISTR2 uni_home_dir;
UNISTR2 uni_dir_drive;
UNISTR2 uni_logon_script;
UNISTR2 uni_acct_desc;
UNISTR2 uni_workstations;
uint32 unknown1;
uint32 unknown2;
BUFFER4 buf_logon_hrs;
UNISTR2 uni_comment;
UNISTR2 uni_parameters;
SAM_PWD pass;
BUFFER4 buf_sec_desc;
UNISTR2 uni_profile;
} SAM_ACCOUNT_INFO;
typedef struct sam_group_mem_info_info
{
uint32 ptr_rids;
uint32 ptr_attribs;
uint32 num_members;
uint8 unknown[16];
uint32 num_members2;
uint32 *rids;
uint32 num_members3;
uint32 *attribs;
} SAM_GROUP_MEM_INFO;
typedef struct sam_alias_info_info
{
UNIHDR hdr_als_name;
uint32 als_rid;
BUFHDR2 hdr_sec_desc;
UNIHDR hdr_als_desc;
uint8 reserved[40];
UNISTR2 uni_als_name;
BUFFER4 buf_sec_desc;
UNISTR2 uni_als_desc;
} SAM_ALIAS_INFO;
typedef struct sam_alias_mem_info_info
{
uint32 num_members;
uint32 ptr_members;
uint8 unknown[16];
uint32 num_sids;
uint32 *ptr_sids;
DOM_SID2 *sids;
} SAM_ALIAS_MEM_INFO;
typedef struct
{
uint32 seqnum;
uint32 dom_mod_count_ptr;
UINT64_S dom_mod_count;
} SAM_DELTA_STAMP;
typedef union sam_delta_ctr_info
{
SAM_DOMAIN_INFO domain_info ;
SAM_GROUP_INFO group_info ;
SAM_ACCOUNT_INFO account_info;
SAM_GROUP_MEM_INFO grp_mem_info;
SAM_ALIAS_INFO alias_info ;
SAM_ALIAS_MEM_INFO als_mem_info;
SAM_DELTA_STAMP stamp;
} SAM_DELTA_CTR;
typedef struct net_r_sam_sync_info
{
DOM_CRED srv_creds;
uint32 sync_context;
uint32 ptr_deltas;
uint32 num_deltas;
uint32 ptr_deltas2;
uint32 num_deltas2;
SAM_DELTA_HDR *hdr_deltas;
SAM_DELTA_CTR *deltas;
NTSTATUS status;
} NET_R_SAM_SYNC;
typedef struct net_q_sam_deltas_info
{
UNISTR2 uni_srv_name;
UNISTR2 uni_cli_name;
DOM_CRED cli_creds;
DOM_CRED ret_creds;
uint32 database_id;
UINT64_S dom_mod_count;
uint32 max_size;
} NET_Q_SAM_DELTAS;
typedef struct net_r_sam_deltas_info
{
DOM_CRED srv_creds;
UINT64_S dom_mod_count;
uint32 ptr_deltas;
uint32 num_deltas;
uint32 num_deltas2;
SAM_DELTA_HDR *hdr_deltas;
SAM_DELTA_CTR *deltas;
NTSTATUS status;
} NET_R_SAM_DELTAS;
#endif