mirror of
https://github.com/samba-team/samba.git
synced 2024-12-31 17:18:04 +03:00
cf90dbd158
clients. Did this by importing Samba-TNG code that correctly handles LSA
lookups.
*MANY* thanks to Luke, Sander, Elrond and the rest of the TNG gang !
Jeremy
(This used to be commit f76dc952f7
)
364 lines
9.5 KiB
C
364 lines
9.5 KiB
C
/*
|
|
Unix SMB/Netbios implementation.
|
|
Version 1.9.
|
|
SMB parameters and setup
|
|
Copyright (C) Andrew Tridgell 1992-1997
|
|
Copyright (C) Luke Kenneth Casson Leighton 1996-1997
|
|
Copyright (C) Paul Ashton 1997
|
|
|
|
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
|
|
|
|
#include "rpc_misc.h"
|
|
|
|
enum SID_NAME_USE
|
|
{
|
|
SID_NAME_USER = 1, /* user */
|
|
SID_NAME_DOM_GRP = 2, /* domain group */
|
|
SID_NAME_DOMAIN = 3, /* domain: don't know what this is */
|
|
SID_NAME_ALIAS = 4, /* local group */
|
|
SID_NAME_WKN_GRP = 5, /* well-known group */
|
|
SID_NAME_DELETED = 6, /* deleted account: needed for c2 rating */
|
|
SID_NAME_INVALID = 7, /* invalid account */
|
|
SID_NAME_UNKNOWN = 8 /* oops. */
|
|
};
|
|
|
|
/* ntlsa pipe */
|
|
#define LSA_CLOSE 0x00
|
|
#define LSA_QUERYINFOPOLICY 0x07
|
|
#define LSA_ENUMTRUSTDOM 0x0d
|
|
#define LSA_LOOKUPNAMES 0x0e
|
|
#define LSA_LOOKUPSIDS 0x0f
|
|
#define LSA_OPENPOLICY 0x06
|
|
#define LSA_OPENPOLICY2 0x2c
|
|
#define LSA_OPENSECRET 0x1C
|
|
|
|
/* XXXX these are here to get a compile! */
|
|
#define LSA_LOOKUPRIDS 0xFD
|
|
|
|
#define LSA_MAX_GROUPS 96
|
|
#define LSA_MAX_SIDS 128
|
|
|
|
/* 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. we hope. */
|
|
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 */
|
|
uint32 unknown; /* 0x2000 0000 - not known */
|
|
|
|
} 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 */
|
|
uint32 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 */
|
|
uint32 status; /* return code */
|
|
|
|
} LSA_R_OPEN_POL2;
|
|
|
|
/* 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;
|
|
|
|
uint32 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;
|
|
|
|
uint32 status; /* return code */
|
|
|
|
} LSA_R_QUERY_INFO;
|
|
|
|
/* LSA_Q_ENUM_TRUST_DOM - LSA enumerate trusted domains */
|
|
typedef struct lsa_enum_trust_dom_info
|
|
{
|
|
POLICY_HND pol; /* policy handle */
|
|
uint32 enum_context; /* enumeration context handle */
|
|
uint32 preferred_len; /* preferred maximum length */
|
|
|
|
} LSA_Q_ENUM_TRUST_DOM;
|
|
|
|
/* LSA_R_ENUM_TRUST_DOM - response to LSA enumerate trusted domains */
|
|
typedef struct lsa_r_enum_trust_dom_info
|
|
{
|
|
uint32 enum_context; /* enumeration context handle */
|
|
uint32 num_domains; /* number of domains */
|
|
uint32 ptr_enum_domains; /* buffer pointer to num domains */
|
|
|
|
/* this lot is only added if ptr_enum_domains is non-NULL */
|
|
uint32 num_domains2; /* number of domains */
|
|
UNIHDR2 *hdr_domain_name;
|
|
UNISTR2 *uni_domain_name;
|
|
DOM_SID2 *domain_sid;
|
|
|
|
uint32 status; /* return code */
|
|
|
|
} 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. */
|
|
|
|
uint32 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;
|
|
|
|
#define MAX_LOOKUP_SIDS 30
|
|
|
|
/* 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;
|
|
LOOKUP_LEVEL 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;
|
|
|
|
uint32 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;
|
|
|
|
uint32 status; /* return code */
|
|
|
|
} LSA_R_LOOKUP_NAMES;
|
|
|
|
#endif /* _RPC_LSA_H */
|