⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 rpc_lsa.h

📁 samba-3.0.22.tar.gz 编译smb服务器的源码
💻 H
📖 第 1 页 / 共 2 页
字号:
/*    Unix SMB/CIFS implementation.   SMB parameters and setup   Copyright (C) Andrew Tridgell               1992-1997   Copyright (C) Luke Kenneth Casson Leighton  1996-1997   Copyright (C) Paul Ashton                   1997   Copyright (C) Gerald (Jerry) Carter         2005      This program is free software; you can redistribute it and/or modify   it under the terms of the GNU General Public License as published by   the Free Software Foundation; either version 2 of the License, or   (at your option) any later version.      This program is distributed in the hope that it will be useful,   but WITHOUT ANY WARRANTY; without even the implied warranty of   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the   GNU General Public License for more details.      You should have received a copy of the GNU General Public License   along with this program; if not, write to the Free Software   Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.*/#ifndef _RPC_LSA_H /* _RPC_LSA_H */#define _RPC_LSA_H /* Opcodes available on PIPE_LSARPC */#if 0	/* UNIMPLEMENTED */#define LSA_LOOKUPSIDS2		0x39#endif#define LSA_CLOSE              0x00#define LSA_DELETE             0x01#define LSA_ENUM_PRIVS         0x02#define LSA_QUERYSECOBJ        0x03#define LSA_SETSECOBJ          0x04#define LSA_CHANGEPASSWORD     0x05#define LSA_OPENPOLICY         0x06#define LSA_QUERYINFOPOLICY    0x07#define LSA_SETINFOPOLICY      0x08#define LSA_CLEARAUDITLOG      0x09#define LSA_CREATEACCOUNT      0x0a#define LSA_ENUM_ACCOUNTS      0x0b#define LSA_CREATETRUSTDOM     0x0c	/* TODO: implement this one  -- jerry */#define LSA_ENUMTRUSTDOM       0x0d#define LSA_LOOKUPNAMES        0x0e#define LSA_LOOKUPSIDS         0x0f#define LSA_CREATESECRET       0x10	/* TODO: implement this one  -- jerry */#define LSA_OPENACCOUNT	       0x11#define LSA_ENUMPRIVSACCOUNT   0x12#define LSA_ADDPRIVS           0x13#define LSA_REMOVEPRIVS        0x14#define LSA_GETQUOTAS          0x15#define LSA_SETQUOTAS          0x16#define LSA_GETSYSTEMACCOUNT   0x17#define LSA_SETSYSTEMACCOUNT   0x18#define LSA_OPENTRUSTDOM       0x19	/* TODO: implement this one  -- jerry */#define LSA_QUERYTRUSTDOMINFO  0x1a#define LSA_SETINFOTRUSTDOM    0x1b#define LSA_OPENSECRET         0x1c	/* TODO: implement this one  -- jerry */#define LSA_SETSECRET          0x1d	/* TODO: implement this one  -- jerry */#define LSA_QUERYSECRET        0x1e#define LSA_LOOKUPPRIVVALUE    0x1f#define LSA_LOOKUPPRIVNAME     0x20#define LSA_PRIV_GET_DISPNAME  0x21#define LSA_DELETEOBJECT       0x22	/* TODO: implement this one  -- jerry */#define LSA_ENUMACCTWITHRIGHT  0x23	/* TODO: implement this one  -- jerry */#define LSA_ENUMACCTRIGHTS     0x24#define LSA_ADDACCTRIGHTS      0x25#define LSA_REMOVEACCTRIGHTS   0x26#define LSA_QUERYTRUSTDOMINFOBYSID  0x27#define LSA_SETTRUSTDOMINFO    0x28#define LSA_DELETETRUSTDOM     0x29#define LSA_STOREPRIVDATA      0x2a#define LSA_RETRPRIVDATA       0x2b#define LSA_OPENPOLICY2        0x2c#define LSA_UNK_GET_CONNUSER   0x2d /* LsaGetConnectedCredentials ? */#define LSA_QUERYINFO2         0x2e#define LSA_QUERYTRUSTDOMINFOBYNAME 0x30#define LSA_OPENTRUSTDOMBYNAME 0x37/* XXXX these are here to get a compile! */#define LSA_LOOKUPRIDS      0xFD/* DOM_QUERY - info class 3 and 5 LSA Query response */typedef struct dom_query_info{  uint16 uni_dom_max_len; /* domain name string length * 2 */  uint16 uni_dom_str_len; /* domain name string length * 2 */  uint32 buffer_dom_name; /* undocumented domain name string buffer pointer */  uint32 buffer_dom_sid; /* undocumented domain SID string buffer pointer */  UNISTR2 uni_domain_name; /* domain name (unicode string) */  DOM_SID2 dom_sid; /* domain SID */} DOM_QUERY;/* level 5 is same as level 3. */typedef DOM_QUERY DOM_QUERY_3;typedef DOM_QUERY DOM_QUERY_5;/* level 2 is auditing settings */typedef struct dom_query_2{	uint32 auditing_enabled;	uint32 count1; /* usualy 7, at least on nt4sp4 */	uint32 count2; /* the same */	uint32 *auditsettings;} DOM_QUERY_2;/* level 6 is server role information */typedef struct dom_query_6{	uint16 server_role; /* 2=backup, 3=primary */} DOM_QUERY_6;typedef struct seq_qos_info{	uint32 len; /* 12 */	uint16 sec_imp_level; /* 0x02 - impersonation level */	uint8  sec_ctxt_mode; /* 0x01 - context tracking mode */	uint8  effective_only; /* 0x00 - effective only */} LSA_SEC_QOS;typedef struct obj_attr_info{	uint32 len;          /* 0x18 - length (in bytes) inc. the length field. */	uint32 ptr_root_dir; /* 0 - root directory (pointer) */	uint32 ptr_obj_name; /* 0 - object name (pointer) */	uint32 attributes;   /* 0 - attributes (undocumented) */	uint32 ptr_sec_desc; /* 0 - security descriptior (pointer) */	uint32 ptr_sec_qos;  /* security quality of service */	LSA_SEC_QOS *sec_qos;} LSA_OBJ_ATTR;/* LSA_Q_OPEN_POL - LSA Query Open Policy */typedef struct lsa_q_open_pol_info{	uint32 ptr;         /* undocumented buffer pointer */	uint16 system_name; /* 0x5c - system name */	LSA_OBJ_ATTR attr ; /* object attributes */	uint32 des_access; /* desired access attributes */} LSA_Q_OPEN_POL;/* LSA_R_OPEN_POL - response to LSA Open Policy */typedef struct lsa_r_open_pol_info{	POLICY_HND pol; /* policy handle */	NTSTATUS status; /* return code */} LSA_R_OPEN_POL;/* LSA_Q_OPEN_POL2 - LSA Query Open Policy */typedef struct lsa_q_open_pol2_info{	uint32       ptr;             /* undocumented buffer pointer */	UNISTR2      uni_server_name; /* server name, starting with two '\'s */	LSA_OBJ_ATTR attr           ; /* object attributes */	uint32 des_access; /* desired access attributes */} LSA_Q_OPEN_POL2;/* LSA_R_OPEN_POL2 - response to LSA Open Policy */typedef struct lsa_r_open_pol2_info{	POLICY_HND pol; /* policy handle */	NTSTATUS status; /* return code */} LSA_R_OPEN_POL2;#define POLICY_VIEW_LOCAL_INFORMATION    0x00000001#define POLICY_VIEW_AUDIT_INFORMATION    0x00000002#define POLICY_GET_PRIVATE_INFORMATION   0x00000004#define POLICY_TRUST_ADMIN               0x00000008#define POLICY_CREATE_ACCOUNT            0x00000010#define POLICY_CREATE_SECRET             0x00000020#define POLICY_CREATE_PRIVILEGE          0x00000040#define POLICY_SET_DEFAULT_QUOTA_LIMITS  0x00000080#define POLICY_SET_AUDIT_REQUIREMENTS    0x00000100#define POLICY_AUDIT_LOG_ADMIN           0x00000200#define POLICY_SERVER_ADMIN              0x00000400#define POLICY_LOOKUP_NAMES              0x00000800#define POLICY_ALL_ACCESS ( STANDARD_RIGHTS_REQUIRED_ACCESS  |\                            POLICY_VIEW_LOCAL_INFORMATION    |\                            POLICY_VIEW_AUDIT_INFORMATION    |\                            POLICY_GET_PRIVATE_INFORMATION   |\                            POLICY_TRUST_ADMIN               |\                            POLICY_CREATE_ACCOUNT            |\                            POLICY_CREATE_SECRET             |\                            POLICY_CREATE_PRIVILEGE          |\                            POLICY_SET_DEFAULT_QUOTA_LIMITS  |\                            POLICY_SET_AUDIT_REQUIREMENTS    |\                            POLICY_AUDIT_LOG_ADMIN           |\                            POLICY_SERVER_ADMIN              |\                            POLICY_LOOKUP_NAMES )#define POLICY_READ       ( STANDARD_RIGHTS_READ_ACCESS      |\                            POLICY_VIEW_AUDIT_INFORMATION    |\                            POLICY_GET_PRIVATE_INFORMATION)#define POLICY_WRITE      ( STD_RIGHT_READ_CONTROL_ACCESS     |\                            POLICY_TRUST_ADMIN               |\                            POLICY_CREATE_ACCOUNT            |\                            POLICY_CREATE_SECRET             |\                            POLICY_CREATE_PRIVILEGE          |\                            POLICY_SET_DEFAULT_QUOTA_LIMITS  |\                            POLICY_SET_AUDIT_REQUIREMENTS    |\                            POLICY_AUDIT_LOG_ADMIN           |\                            POLICY_SERVER_ADMIN)#define POLICY_EXECUTE    ( STANDARD_RIGHTS_EXECUTE_ACCESS   |\                            POLICY_VIEW_LOCAL_INFORMATION    |\                            POLICY_LOOKUP_NAMES )/* LSA_Q_QUERY_SEC_OBJ - LSA query security */typedef struct lsa_query_sec_obj_info{	POLICY_HND pol; /* policy handle */	uint32 sec_info;} LSA_Q_QUERY_SEC_OBJ;/* LSA_R_QUERY_SEC_OBJ - probably an open */typedef struct r_lsa_query_sec_obj_info{	uint32 ptr;	SEC_DESC_BUF *buf;	NTSTATUS status;         /* return status */} LSA_R_QUERY_SEC_OBJ;/* LSA_Q_QUERY_INFO - LSA query info policy */typedef struct lsa_query_info{	POLICY_HND pol; /* policy handle */    uint16 info_class; /* info class */} LSA_Q_QUERY_INFO;/* LSA_INFO_UNION */typedef union lsa_info_union{	DOM_QUERY_2 id2;	DOM_QUERY_3 id3;	DOM_QUERY_5 id5;	DOM_QUERY_6 id6;} LSA_INFO_UNION;/* LSA_R_QUERY_INFO - response to LSA query info policy */typedef struct lsa_r_query_info{    uint32 undoc_buffer; /* undocumented buffer pointer */    uint16 info_class; /* info class (same as info class in request) */   	LSA_INFO_UNION dom; 	NTSTATUS status; /* return code */} LSA_R_QUERY_INFO;/* LSA_DNS_DOM_INFO - DNS domain info - info class 12*/typedef struct lsa_dns_dom_info{	UNIHDR  hdr_nb_dom_name; /* netbios domain name */	UNIHDR  hdr_dns_dom_name;	UNIHDR  hdr_forest_name;	struct uuid dom_guid; /* domain GUID */	UNISTR2 uni_nb_dom_name;	UNISTR2 uni_dns_dom_name;	UNISTR2 uni_forest_name;	uint32 ptr_dom_sid;	DOM_SID2   dom_sid; /* domain SID */} LSA_DNS_DOM_INFO;typedef union lsa_info2_union{	LSA_DNS_DOM_INFO dns_dom_info;} LSA_INFO2_UNION;/* LSA_Q_QUERY_INFO2 - LSA query info */typedef struct lsa_q_query_info2{	POLICY_HND pol;    /* policy handle */	uint16 info_class; /* info class */} LSA_Q_QUERY_INFO2;typedef struct lsa_r_query_info2{	uint32 ptr;    /* pointer to info struct */	uint16 info_class;	LSA_INFO2_UNION info; /* so far the only one */	NTSTATUS status;} LSA_R_QUERY_INFO2;/*******************************************************/typedef struct {	POLICY_HND pol; 	uint32 enum_context; 	uint32 preferred_len; 	/* preferred maximum length */} LSA_Q_ENUM_TRUST_DOM;typedef struct {	UNISTR4	name;	DOM_SID2 *sid;} DOMAIN_INFO;typedef struct {	uint32 count;	DOMAIN_INFO *domains;} DOMAIN_LIST;typedef struct {	uint32 enum_context;	uint32 count;	DOMAIN_LIST *domlist;	NTSTATUS status; } LSA_R_ENUM_TRUST_DOM;/*******************************************************//* LSA_Q_CLOSE */typedef struct lsa_q_close_info{	POLICY_HND pol; /* policy handle */} LSA_Q_CLOSE;/* LSA_R_CLOSE */typedef struct lsa_r_close_info{	POLICY_HND pol; /* policy handle.  should be all zeros. */	NTSTATUS status; /* return code */} LSA_R_CLOSE;#define MAX_REF_DOMAINS 32/* DOM_TRUST_HDR */typedef struct dom_trust_hdr{	UNIHDR hdr_dom_name; /* referenced domain unicode string headers */	uint32 ptr_dom_sid;} DOM_TRUST_HDR;	/* DOM_TRUST_INFO */typedef struct dom_trust_info{	UNISTR2  uni_dom_name; /* domain name unicode string */	DOM_SID2 ref_dom     ; /* referenced domain SID */} DOM_TRUST_INFO;	/* DOM_R_REF */typedef struct dom_ref_info{    uint32 num_ref_doms_1; /* num referenced domains */    uint32 ptr_ref_dom; /* pointer to referenced domains */    uint32 max_entries; /* 32 - max number of entries */    uint32 num_ref_doms_2; /* num referenced domains */    DOM_TRUST_HDR  hdr_ref_dom[MAX_REF_DOMAINS]; /* referenced domains */    DOM_TRUST_INFO ref_dom    [MAX_REF_DOMAINS]; /* referenced domains */} DOM_R_REF;/* the domain_idx points to a SID associated with the name *//* LSA_TRANS_NAME - translated name */typedef struct lsa_trans_name_info{	uint16 sid_name_use; /* value is 5 for a well-known group; 2 for a domain group; 1 for a user... */	UNIHDR hdr_name; 	uint32 domain_idx; /* index into DOM_R_REF array of SIDs */} LSA_TRANS_NAME;/* This number is based on Win2k and later maximum response allowed */#define MAX_LOOKUP_SIDS 20480/* LSA_TRANS_NAME_ENUM - LSA Translated Name Enumeration container */typedef struct lsa_trans_name_enum_info{	uint32 num_entries;	uint32 ptr_trans_names;	uint32 num_entries2;		LSA_TRANS_NAME *name; /* translated names  */	UNISTR2 *uni_name;} LSA_TRANS_NAME_ENUM;/* LSA_SID_ENUM - LSA SID enumeration container */typedef struct lsa_sid_enum_info{	uint32 num_entries;	uint32 ptr_sid_enum;	uint32 num_entries2;		uint32 *ptr_sid; /* domain SID pointers to be looked up. */	DOM_SID2 *sid; /* domain SIDs to be looked up. */} LSA_SID_ENUM;/* LSA_Q_LOOKUP_SIDS - LSA Lookup SIDs */typedef struct lsa_q_lookup_sids{	POLICY_HND          pol; /* policy handle */	LSA_SID_ENUM        sids;	LSA_TRANS_NAME_ENUM names;	uint16              level;	uint32              mapped_count;} LSA_Q_LOOKUP_SIDS;/* LSA_R_LOOKUP_SIDS - response to LSA Lookup SIDs */typedef struct lsa_r_lookup_sids{	uint32              ptr_dom_ref;	DOM_R_REF           *dom_ref; /* domain reference info */	LSA_TRANS_NAME_ENUM *names;	uint32              mapped_count;	NTSTATUS            status; /* return code */} LSA_R_LOOKUP_SIDS;/* LSA_Q_LOOKUP_NAMES - LSA Lookup NAMEs */typedef struct lsa_q_lookup_names{	POLICY_HND pol; /* policy handle */	uint32 num_entries;	uint32 num_entries2;	UNIHDR  *hdr_name; /* name buffer pointers */	UNISTR2 *uni_name; /* names to be looked up */	uint32 num_trans_entries;	uint32 ptr_trans_sids; /* undocumented domain SID buffer pointer */	uint32 lookup_level;	uint32 mapped_count;} LSA_Q_LOOKUP_NAMES;/* LSA_R_LOOKUP_NAMES - response to LSA Lookup NAMEs by name */typedef struct lsa_r_lookup_names{	uint32 ptr_dom_ref;	DOM_R_REF *dom_ref; /* domain reference info */	uint32 num_entries;	uint32 ptr_entries;	uint32 num_entries2;	DOM_RID2 *dom_rid; /* domain RIDs being looked up */	uint32 mapped_count;	NTSTATUS status; /* return code */} LSA_R_LOOKUP_NAMES;typedef struct lsa_enum_priv_entry{	UNIHDR hdr_name;

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -