/*
* Unix SMB / Netbios implementation .
* Version 1.9 .
* RPC Pipe client / server routines
* 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 0213 9 , USA .
*/
# include "includes.h"
extern int DEBUGLEVEL ;
static BOOL lsa_io_trans_names ( char * desc , LSA_TRANS_NAME_ENUM * trn , prs_struct * ps , int depth ) ;
/*******************************************************************
Inits a LSA_TRANS_NAME structure .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
void init_lsa_trans_name ( LSA_TRANS_NAME * trn , UNISTR2 * uni_name ,
uint16 sid_name_use , char * name , uint32 idx )
{
int len_name = strlen ( name ) ;
if ( len_name = = 0 )
len_name = 1 ;
trn - > sid_name_use = sid_name_use ;
init_uni_hdr ( & trn - > hdr_name , len_name ) ;
init_unistr2 ( uni_name , name , len_name ) ;
trn - > domain_idx = idx ;
}
/*******************************************************************
Reads or writes a LSA_TRANS_NAME structure .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
static BOOL lsa_io_trans_name ( char * desc , LSA_TRANS_NAME * trn , prs_struct * ps ,
int depth )
{
prs_debug ( ps , depth , desc , " lsa_io_trans_name " ) ;
depth + + ;
if ( ! prs_align ( ps ) )
return False ;
if ( ! prs_uint16 ( " sid_name_use " , ps , depth , & trn - > sid_name_use ) )
return False ;
if ( ! prs_align ( ps ) )
return False ;
if ( ! smb_io_unihdr ( " hdr_name " , & trn - > hdr_name , ps , depth ) )
return False ;
if ( ! prs_uint32 ( " domain_idx " , ps , depth , & trn - > domain_idx ) )
return False ;
return True ;
}
/*******************************************************************
Reads or writes a DOM_R_REF structure .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
static BOOL lsa_io_dom_r_ref ( char * desc , DOM_R_REF * r_r , prs_struct * ps ,
int depth )
{
int i ;
prs_debug ( ps , depth , desc , " lsa_io_dom_r_ref " ) ;
depth + + ;
if ( ! prs_align ( ps ) )
return False ;
if ( ! prs_uint32 ( " num_ref_doms_1 " , ps , depth , & r_r - > num_ref_doms_1 ) ) /* num referenced domains? */
return False ;
if ( ! prs_uint32 ( " ptr_ref_dom " , ps , depth , & r_r - > ptr_ref_dom ) ) /* undocumented buffer pointer. */
return False ;
if ( ! prs_uint32 ( " max_entries " , ps , depth , & r_r - > max_entries ) ) /* 32 - max number of entries */
return False ;
- lib/unix_sec_ctxt.c
attempt at taking lib/uid.c and getting a unix security context
change module that is independent of "cnums" and "snums".
a security context is needed for pipes, not just IPC$ or other
services.
- group database API
added add_group/alias_member, del_group/alias_member,
del_group/alias_entry functions. del_builtin_entry() is
deliberately set to NULL to cause an exception, you cannot
delete builtin aliases.
- parse_lsa.c srv_lsa.c
fixed lookup_names code, it was a load of trash and didn't do
anything.
- cmd_samr.c rpcclient.c srv_samr.c
added "deletegroup", "deletealias", "delaliasmem", "delgroupmem",
"addgroupmem", "addaliasmem", "createalias", "creategroup", to
both client and server code.
server code calls into unix stubs right now, which don't actually
do anything. the only instance where they are expected to do
anything is in appliance mode NOT even in the ldap code or anything.
client code modified to call samr_lookup_names() for group code
(because we can) and lsa_lookup_names() for alias code (because
we have to).
- srv_lookup.c
oops, lookup on unsplit name, we got lookup on DOMAIN, DOMAIN\name
instead of DOMAIN, name.
-
SMB_ASSERT_ARRAY ( r_r - > hdr_ref_dom , r_r - > num_ref_doms_1 ) ;
if ( r_r - > ptr_ref_dom ! = 0 ) {
if ( ! prs_uint32 ( " num_ref_doms_2 " , ps , depth , & r_r - > num_ref_doms_2 ) ) /* 4 - num referenced domains? */
return False ;
SMB_ASSERT_ARRAY ( r_r - > ref_dom , r_r - > num_ref_doms_2 ) ;
for ( i = 0 ; i < r_r - > num_ref_doms_1 ; i + + ) {
fstring t ;
slprintf ( t , sizeof ( t ) - 1 , " dom_ref[%d] " , i ) ;
if ( ! smb_io_unihdr ( t , & r_r - > hdr_ref_dom [ i ] . hdr_dom_name , ps , depth ) )
return False ;
slprintf ( t , sizeof ( t ) - 1 , " sid_ptr[%d] " , i ) ;
if ( ! prs_uint32 ( t , ps , depth , & r_r - > hdr_ref_dom [ i ] . ptr_dom_sid ) )
return False ;
}
for ( i = 0 ; i < r_r - > num_ref_doms_2 ; i + + ) {
fstring t ;
if ( r_r - > hdr_ref_dom [ i ] . hdr_dom_name . buffer ! = 0 ) {
slprintf ( t , sizeof ( t ) - 1 , " dom_ref[%d] " , i ) ;
if ( ! smb_io_unistr2 ( t , & r_r - > ref_dom [ i ] . uni_dom_name , True , ps , depth ) ) /* domain name unicode string */
return False ;
if ( ! prs_align ( ps ) )
return False ;
}
if ( r_r - > hdr_ref_dom [ i ] . ptr_dom_sid ! = 0 ) {
slprintf ( t , sizeof ( t ) - 1 , " sid_ptr[%d] " , i ) ;
if ( ! smb_io_dom_sid2 ( t , & r_r - > ref_dom [ i ] . ref_dom , ps , depth ) ) /* referenced domain SIDs */
return False ;
}
}
}
return True ;
}
/*******************************************************************
Inits an LSA_SEC_QOS structure .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
void init_lsa_sec_qos ( LSA_SEC_QOS * qos , uint16 imp_lev , uint8 ctxt , uint8 eff ,
uint32 unknown )
{
DEBUG ( 5 , ( " init_lsa_sec_qos \n " ) ) ;
qos - > len = 0x0c ; /* length of quality of service block, in bytes */
qos - > sec_imp_level = imp_lev ;
qos - > sec_ctxt_mode = ctxt ;
qos - > effective_only = eff ;
qos - > unknown = unknown ;
}
/*******************************************************************
Reads or writes an LSA_SEC_QOS structure .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
static BOOL lsa_io_sec_qos ( char * desc , LSA_SEC_QOS * qos , prs_struct * ps ,
int depth )
{
uint32 start ;
prs_debug ( ps , depth , desc , " lsa_io_obj_qos " ) ;
depth + + ;
if ( ! prs_align ( ps ) )
return False ;
start = prs_offset ( ps ) ;
/* these pointers had _better_ be zero, because we don't know
what they point to !
*/
if ( ! prs_uint32 ( " len " , ps , depth , & qos - > len ) ) /* 0x18 - length (in bytes) inc. the length field. */
return False ;
if ( ! prs_uint16 ( " sec_imp_level " , ps , depth , & qos - > sec_imp_level ) )
return False ;
if ( ! prs_uint8 ( " sec_ctxt_mode " , ps , depth , & qos - > sec_ctxt_mode ) )
return False ;
if ( ! prs_uint8 ( " effective_only " , ps , depth , & qos - > effective_only ) )
return False ;
if ( ! prs_uint32 ( " unknown " , ps , depth , & qos - > unknown ) )
return False ;
if ( qos - > len ! = prs_offset ( ps ) - start ) {
DEBUG ( 3 , ( " lsa_io_sec_qos: length %x does not match size %x \n " ,
qos - > len , prs_offset ( ps ) - start ) ) ;
return False ;
}
return True ;
}
/*******************************************************************
Inits an LSA_OBJ_ATTR structure .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
void init_lsa_obj_attr ( LSA_OBJ_ATTR * attr , uint32 attributes , LSA_SEC_QOS * qos )
{
DEBUG ( 5 , ( " init_lsa_obj_attr \n " ) ) ;
attr - > len = 0x18 ; /* length of object attribute block, in bytes */
attr - > ptr_root_dir = 0 ;
attr - > ptr_obj_name = 0 ;
attr - > attributes = attributes ;
attr - > ptr_sec_desc = 0 ;
if ( qos ! = NULL ) {
attr - > ptr_sec_qos = 1 ;
attr - > sec_qos = qos ;
} else {
attr - > ptr_sec_qos = 0 ;
attr - > sec_qos = NULL ;
}
}
/*******************************************************************
Reads or writes an LSA_OBJ_ATTR structure .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
static BOOL lsa_io_obj_attr ( char * desc , LSA_OBJ_ATTR * attr , prs_struct * ps ,
int depth )
{
uint32 start ;
prs_debug ( ps , depth , desc , " lsa_io_obj_attr " ) ;
depth + + ;
if ( ! prs_align ( ps ) )
return False ;
start = prs_offset ( ps ) ;
/* these pointers had _better_ be zero, because we don't know
what they point to !
*/
if ( ! prs_uint32 ( " len " , ps , depth , & attr - > len ) ) /* 0x18 - length (in bytes) inc. the length field. */
return False ;
if ( ! prs_uint32 ( " ptr_root_dir " , ps , depth , & attr - > ptr_root_dir ) ) /* 0 - root directory (pointer) */
return False ;
if ( ! prs_uint32 ( " ptr_obj_name " , ps , depth , & attr - > ptr_obj_name ) ) /* 0 - object name (pointer) */
return False ;
if ( ! prs_uint32 ( " attributes " , ps , depth , & attr - > attributes ) ) /* 0 - attributes (undocumented) */
return False ;
if ( ! prs_uint32 ( " ptr_sec_desc " , ps , depth , & attr - > ptr_sec_desc ) ) /* 0 - security descriptior (pointer) */
return False ;
if ( ! prs_uint32 ( " ptr_sec_qos " , ps , depth , & attr - > ptr_sec_qos ) ) /* security quality of service (pointer) */
return False ;
if ( attr - > len ! = prs_offset ( ps ) - start ) {
DEBUG ( 3 , ( " lsa_io_obj_attr: length %x does not match size %x \n " ,
attr - > len , prs_offset ( ps ) - start ) ) ;
return False ;
}
if ( attr - > ptr_sec_qos ! = 0 & & attr - > sec_qos ! = NULL ) {
if ( ! lsa_io_sec_qos ( " sec_qos " , attr - > sec_qos , ps , depth ) )
return False ;
}
return True ;
}
/*******************************************************************
Inits an LSA_Q_OPEN_POL structure .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
void init_q_open_pol ( LSA_Q_OPEN_POL * r_q , uint16 system_name ,
uint32 attributes , uint32 desired_access ,
LSA_SEC_QOS * qos )
{
DEBUG ( 5 , ( " init_open_pol: attr:%d da:%d \n " , attributes ,
desired_access ) ) ;
r_q - > ptr = 1 ; /* undocumented pointer */
if ( qos = = NULL )
r_q - > des_access = desired_access ;
r_q - > system_name = system_name ;
init_lsa_obj_attr ( & r_q - > attr , attributes , qos ) ;
}
/*******************************************************************
Reads or writes an LSA_Q_OPEN_POL structure .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
BOOL lsa_io_q_open_pol ( char * desc , LSA_Q_OPEN_POL * r_q , prs_struct * ps ,
int depth )
{
prs_debug ( ps , depth , desc , " lsa_io_q_open_pol " ) ;
depth + + ;
if ( ! prs_uint32 ( " ptr " , ps , depth , & r_q - > ptr ) )
return False ;
if ( ! prs_uint16 ( " system_name " , ps , depth , & r_q - > system_name ) )
return False ;
if ( ! prs_align ( ps ) )
return False ;
if ( ! lsa_io_obj_attr ( " " , & r_q - > attr , ps , depth ) )
return False ;
if ( r_q - > attr . ptr_sec_qos = = 0 ) {
if ( ! prs_uint32 ( " des_access " , ps , depth , & r_q - > des_access ) )
return False ;
}
return True ;
}
/*******************************************************************
Reads or writes an LSA_R_OPEN_POL structure .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
BOOL lsa_io_r_open_pol ( char * desc , LSA_R_OPEN_POL * r_p , prs_struct * ps ,
int depth )
{
prs_debug ( ps , depth , desc , " lsa_io_r_open_pol " ) ;
depth + + ;
if ( ! smb_io_pol_hnd ( " " , & r_p - > pol , ps , depth ) )
return False ;
if ( ! prs_uint32 ( " status " , ps , depth , & r_p - > status ) )
return False ;
return True ;
}
/*******************************************************************
Inits an LSA_Q_OPEN_POL2 structure .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
void init_q_open_pol2 ( LSA_Q_OPEN_POL2 * r_q , char * server_name ,
uint32 attributes , uint32 desired_access ,
LSA_SEC_QOS * qos )
{
DEBUG ( 5 , ( " init_q_open_pol2: attr:%d da:%d \n " , attributes ,
desired_access ) ) ;
r_q - > ptr = 1 ; /* undocumented pointer */
if ( qos = = NULL )
r_q - > des_access = desired_access ;
init_unistr2 ( & r_q - > uni_server_name , server_name ,
strlen ( server_name ) + 1 ) ;
init_lsa_obj_attr ( & r_q - > attr , attributes , qos ) ;
}
/*******************************************************************
Reads or writes an LSA_Q_OPEN_POL2 structure .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
BOOL lsa_io_q_open_pol2 ( char * desc , LSA_Q_OPEN_POL2 * r_q , prs_struct * ps ,
int depth )
{
prs_debug ( ps , depth , desc , " lsa_io_q_open_pol2 " ) ;
depth + + ;
if ( ! prs_uint32 ( " ptr " , ps , depth , & r_q - > ptr ) )
return False ;
if ( ! smb_io_unistr2 ( " " , & r_q - > uni_server_name , r_q - > ptr , ps , depth ) )
return False ;
if ( ! lsa_io_obj_attr ( " " , & r_q - > attr , ps , depth ) )
return False ;
if ( r_q - > attr . ptr_sec_qos = = 0 ) {
if ( ! prs_uint32 ( " des_access " , ps , depth , & r_q - > des_access ) )
return False ;
}
return True ;
}
/*******************************************************************
Reads or writes an LSA_R_OPEN_POL2 structure .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
BOOL lsa_io_r_open_pol2 ( char * desc , LSA_R_OPEN_POL2 * r_p , prs_struct * ps ,
int depth )
{
prs_debug ( ps , depth , desc , " lsa_io_r_open_pol2 " ) ;
depth + + ;
if ( ! smb_io_pol_hnd ( " " , & r_p - > pol , ps , depth ) )
return False ;
if ( ! prs_uint32 ( " status " , ps , depth , & r_p - > status ) )
return False ;
return True ;
}
/*******************************************************************
makes an LSA_Q_QUERY_SEC_OBJ structure .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
void init_q_query_sec_obj ( LSA_Q_QUERY_SEC_OBJ * q_q , const POLICY_HND * hnd ,
uint32 sec_info )
{
DEBUG ( 5 , ( " init_q_query_sec_obj \n " ) ) ;
q_q - > pol = * hnd ;
q_q - > sec_info = sec_info ;
return ;
}
/*******************************************************************
Reads or writes an LSA_Q_QUERY_SEC_OBJ structure .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
BOOL lsa_io_q_query_sec_obj ( char * desc , LSA_Q_QUERY_SEC_OBJ * q_q ,
prs_struct * ps , int depth )
{
prs_debug ( ps , depth , desc , " lsa_io_q_query_sec_obj " ) ;
depth + + ;
if ( ! smb_io_pol_hnd ( " " , & q_q - > pol , ps , depth ) )
return False ;
if ( ! prs_uint32 ( " sec_info " , ps , depth , & q_q - > sec_info ) )
return False ;
return True ;
}
/*******************************************************************
Reads or writes a LSA_R_QUERY_SEC_OBJ structure .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
BOOL lsa_io_r_query_sec_obj ( char * desc , LSA_R_QUERY_SEC_OBJ * r_u ,
prs_struct * ps , int depth )
{
prs_debug ( ps , depth , desc , " lsa_io_r_query_sec_obj " ) ;
depth + + ;
if ( ! prs_align ( ps ) )
return False ;
if ( ! prs_uint32 ( " ptr " , ps , depth , & r_u - > ptr ) )
return False ;
if ( r_u - > ptr ! = 0 ) {
if ( ! sec_io_desc_buf ( " sec " , & r_u - > buf , ps , depth ) )
return False ;
}
if ( ! prs_uint32 ( " status " , ps , depth , & r_u - > status ) )
return False ;
return True ;
}
/*******************************************************************
Inits an LSA_Q_QUERY_INFO structure .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
void init_q_query ( LSA_Q_QUERY_INFO * q_q , POLICY_HND * hnd , uint16 info_class )
{
DEBUG ( 5 , ( " init_q_query \n " ) ) ;
memcpy ( & q_q - > pol , hnd , sizeof ( q_q - > pol ) ) ;
q_q - > info_class = info_class ;
}
/*******************************************************************
Reads or writes an LSA_Q_QUERY_INFO structure .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
BOOL lsa_io_q_query ( char * desc , LSA_Q_QUERY_INFO * q_q , prs_struct * ps ,
int depth )
{
prs_debug ( ps , depth , desc , " lsa_io_q_query " ) ;
depth + + ;
if ( ! smb_io_pol_hnd ( " " , & q_q - > pol , ps , depth ) )
return False ;
if ( ! prs_uint16 ( " info_class " , ps , depth , & q_q - > info_class ) )
return False ;
return True ;
}
/*******************************************************************
makes an LSA_Q_ENUM_TRUST_DOM structure .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
BOOL init_q_enum_trust_dom ( LSA_Q_ENUM_TRUST_DOM * q_e , POLICY_HND * pol ,
uint32 enum_context , uint32 preferred_len )
{
DEBUG ( 5 , ( " init_q_enum_trust_dom \n " ) ) ;
q_e - > pol = * pol ;
q_e - > enum_context = enum_context ;
q_e - > preferred_len = preferred_len ;
return True ;
}
/*******************************************************************
Reads or writes an LSA_Q_ENUM_TRUST_DOM structure .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
BOOL lsa_io_q_enum_trust_dom ( char * desc , LSA_Q_ENUM_TRUST_DOM * q_e ,
prs_struct * ps , int depth )
{
prs_debug ( ps , depth , desc , " lsa_io_q_enum_trust_dom " ) ;
depth + + ;
if ( ! smb_io_pol_hnd ( " " , & q_e - > pol , ps , depth ) )
return False ;
if ( ! prs_uint32 ( " enum_context " , ps , depth , & q_e - > enum_context ) )
return False ;
if ( ! prs_uint32 ( " preferred_len " , ps , depth , & q_e - > preferred_len ) )
return False ;
return True ;
}
/*******************************************************************
Inits an LSA_R_ENUM_TRUST_DOM structure .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
void init_r_enum_trust_dom ( LSA_R_ENUM_TRUST_DOM * r_e , uint32 enum_context ,
char * domain_name , DOM_SID * domain_sid ,
uint32 status )
{
DEBUG ( 5 , ( " init_r_enum_trust_dom \n " ) ) ;
r_e - > enum_context = enum_context ;
if ( status = = 0 ) {
int len_domain_name = strlen ( domain_name ) + 1 ;
r_e - > num_domains = 1 ;
r_e - > ptr_enum_domains = 1 ;
r_e - > num_domains2 = 1 ;
if ( ! ( r_e - > hdr_domain_name = ( UNIHDR2 * )
malloc ( sizeof ( UNIHDR2 ) ) ) ) return ;
if ( ! ( r_e - > uni_domain_name = ( UNISTR2 * )
malloc ( sizeof ( UNISTR2 ) ) ) ) return ;
if ( ! ( r_e - > domain_sid = ( DOM_SID2 * )
malloc ( sizeof ( DOM_SID2 ) ) ) ) return ;
init_uni_hdr2 ( & r_e - > hdr_domain_name [ 0 ] , len_domain_name ) ;
init_unistr2 ( & r_e - > uni_domain_name [ 0 ] , domain_name ,
len_domain_name ) ;
init_dom_sid2 ( & r_e - > domain_sid [ 0 ] , domain_sid ) ;
} else {
r_e - > num_domains = 0 ;
r_e - > ptr_enum_domains = 0 ;
}
r_e - > status = status ;
}
/*******************************************************************
Reads or writes an LSA_R_ENUM_TRUST_DOM structure .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
BOOL lsa_io_r_enum_trust_dom ( char * desc , LSA_R_ENUM_TRUST_DOM * r_e ,
prs_struct * ps , int depth )
{
prs_debug ( ps , depth , desc , " lsa_io_r_enum_trust_dom " ) ;
depth + + ;
if ( ! prs_uint32 ( " enum_context " , ps , depth , & r_e - > enum_context ) )
return False ;
if ( ! prs_uint32 ( " num_domains " , ps , depth , & r_e - > num_domains ) )
return False ;
if ( ! prs_uint32 ( " ptr_enum_domains " , ps , depth , & r_e - > ptr_enum_domains ) )
return False ;
if ( r_e - > ptr_enum_domains ) {
int i , num_domains ;
if ( ! prs_uint32 ( " num_domains2 " , ps , depth , & r_e - > num_domains2 ) )
return False ;
num_domains = r_e - > num_domains2 ;
if ( ! ( r_e - > hdr_domain_name = ( UNIHDR2 * )
malloc ( sizeof ( UNIHDR2 ) * num_domains ) ) )
return False ;
if ( ! ( r_e - > uni_domain_name = ( UNISTR2 * )
malloc ( sizeof ( UNISTR2 ) * num_domains ) ) )
return False ;
if ( ! ( r_e - > domain_sid = ( DOM_SID2 * )
malloc ( sizeof ( DOM_SID2 ) * num_domains ) ) )
return False ;
for ( i = 0 ; i < num_domains ; i + + ) {
if ( ! smb_io_unihdr2 ( " " , & r_e - > hdr_domain_name [ i ] , ps ,
depth ) )
return False ;
}
for ( i = 0 ; i < num_domains ; i + + ) {
if ( ! smb_io_unistr2 ( " " , & r_e - > uni_domain_name [ i ] ,
r_e - > hdr_domain_name [ i ] . buffer ,
ps , depth ) )
return False ;
if ( ! smb_io_dom_sid2 ( " " , & r_e - > domain_sid [ i ] , ps ,
depth ) )
return False ;
}
}
if ( ! prs_uint32 ( " status " , ps , depth , & r_e - > status ) )
return False ;
return True ;
}
void lsa_free_r_enum_trust_dom ( LSA_R_ENUM_TRUST_DOM * r_e )
{
safe_free ( r_e - > uni_domain_name ) ;
safe_free ( r_e - > hdr_domain_name ) ;
safe_free ( r_e - > domain_sid ) ;
r_e - > uni_domain_name = NULL ;
r_e - > hdr_domain_name = NULL ;
r_e - > domain_sid = NULL ;
r_e - > num_domains = 0 ;
r_e - > ptr_enum_domains = 0 ;
}
/*******************************************************************
reads or writes a dom query structure .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
static BOOL lsa_io_dom_query ( char * desc , DOM_QUERY * d_q , prs_struct * ps , int depth )
{
if ( d_q = = NULL )
return False ;
prs_debug ( ps , depth , desc , " lsa_io_dom_query " ) ;
depth + + ;
if ( ! prs_align ( ps ) )
return False ;
if ( ! prs_uint16 ( " uni_dom_max_len " , ps , depth , & d_q - > uni_dom_max_len ) ) /* domain name string length * 2 */
return False ;
if ( ! prs_uint16 ( " uni_dom_str_len " , ps , depth , & d_q - > uni_dom_str_len ) ) /* domain name string length * 2 */
return False ;
if ( ! prs_uint32 ( " buffer_dom_name " , ps , depth , & d_q - > buffer_dom_name ) ) /* undocumented domain name string buffer pointer */
return False ;
if ( ! prs_uint32 ( " buffer_dom_sid " , ps , depth , & d_q - > buffer_dom_sid ) ) /* undocumented domain SID string buffer pointer */
return False ;
if ( ! smb_io_unistr2 ( " unistr2 " , & d_q - > uni_domain_name , d_q - > buffer_dom_name , ps , depth ) ) /* domain name (unicode string) */
return False ;
if ( ! prs_align ( ps ) )
return False ;
if ( d_q - > buffer_dom_sid ! = 0 ) {
if ( ! smb_io_dom_sid2 ( " " , & d_q - > dom_sid , ps , depth ) ) /* domain SID */
return False ;
} else {
memset ( ( char * ) & d_q - > dom_sid , ' \0 ' , sizeof ( d_q - > dom_sid ) ) ;
}
return True ;
}
/*******************************************************************
reads or writes a structure .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
static BOOL lsa_io_dom_query_2 ( char * desc , DOM_QUERY_2 * d_q , prs_struct * ps , int depth )
{
uint32 ptr = 1 ;
if ( d_q = = NULL )
return False ;
prs_debug ( ps , depth , desc , " lsa_io_dom_query_2 " ) ;
depth + + ;
if ( ! prs_align ( ps ) )
return False ;
if ( ! prs_uint32 ( " auditing_enabled " , ps , depth , & d_q - > auditing_enabled ) )
return False ;
if ( ! prs_uint32 ( " ptr " , ps , depth , & ptr ) )
return False ;
if ( ! prs_uint32 ( " count1 " , ps , depth , & d_q - > count1 ) )
return False ;
if ( ! prs_uint32 ( " count2 " , ps , depth , & d_q - > count2 ) )
return False ;
if ( UNMARSHALLING ( ps ) ) {
d_q - > auditsettings = ( uint32 * ) talloc ( ps - > mem_ctx , d_q - > count2 * sizeof ( uint32 ) ) ;
}
if ( d_q - > auditsettings = = NULL ) {
DEBUG ( 1 , ( " lsa_io_dom_query_2: NULL auditsettings! \n " ) ) ;
return False ;
}
if ( ! prs_uint32s ( False , " auditsettings " , ps , depth , d_q - > auditsettings , d_q - > count2 ) )
return False ;
return True ;
}
/*******************************************************************
Reads or writes a dom query structure .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
static BOOL lsa_io_dom_query_3 ( char * desc , DOM_QUERY_3 * d_q , prs_struct * ps , int depth )
{
return lsa_io_dom_query ( " " , d_q , ps , depth ) ;
}
/*******************************************************************
Reads or writes a dom query structure .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
BOOL lsa_io_dom_query_5 ( char * desc , DOM_QUERY_5 * d_q , prs_struct * ps , int depth )
{
return lsa_io_dom_query ( " " , d_q , ps , depth ) ;
}
/*******************************************************************
Reads or writes a dom query structure .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
static BOOL lsa_io_dom_query_6 ( char * desc , DOM_QUERY_6 * d_q , prs_struct * ps , int depth )
{
if ( d_q = = NULL )
return False ;
prs_debug ( ps , depth , desc , " lsa_io_dom_query_6 " ) ;
depth + + ;
if ( ! prs_uint16 ( " server_role " , ps , depth , & d_q - > server_role ) )
return False ;
return True ;
}
/*******************************************************************
Reads or writes an LSA_Q_QUERY_INFO structure .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
BOOL lsa_io_r_query ( char * desc , LSA_R_QUERY_INFO * r_q , prs_struct * ps ,
int depth )
{
prs_debug ( ps , depth , desc , " lsa_io_r_query " ) ;
depth + + ;
if ( ! prs_uint32 ( " undoc_buffer " , ps , depth , & r_q - > undoc_buffer ) )
return False ;
if ( r_q - > undoc_buffer ! = 0 ) {
if ( ! prs_uint16 ( " info_class " , ps , depth , & r_q - > info_class ) )
return False ;
if ( ! prs_align ( ps ) )
return False ;
switch ( r_q - > info_class ) {
case 2 :
if ( ! lsa_io_dom_query_2 ( " " , & r_q - > dom . id2 , ps , depth ) )
return False ;
break ;
case 3 :
if ( ! lsa_io_dom_query_3 ( " " , & r_q - > dom . id3 , ps , depth ) )
return False ;
break ;
case 5 :
if ( ! lsa_io_dom_query_5 ( " " , & r_q - > dom . id5 , ps , depth ) )
return False ;
break ;
case 6 :
if ( ! lsa_io_dom_query_6 ( " " , & r_q - > dom . id6 , ps , depth ) )
return False ;
break ;
default :
/* PANIC! */
break ;
}
}
if ( ! prs_align ( ps ) )
return False ;
if ( ! prs_uint32 ( " status " , ps , depth , & r_q - > status ) )
return False ;
return True ;
}
/*******************************************************************
Inits a LSA_SID_ENUM structure .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
void init_lsa_sid_enum ( TALLOC_CTX * mem_ctx , LSA_SID_ENUM * sen ,
int num_entries , DOM_SID * sids )
{
int i ;
DEBUG ( 5 , ( " init_lsa_sid_enum \n " ) ) ;
sen - > num_entries = num_entries ;
sen - > ptr_sid_enum = ( num_entries ! = 0 ) ;
sen - > num_entries2 = num_entries ;
/* Allocate memory for sids and sid pointers */
if ( num_entries = = 0 ) return ;
if ( ( sen - > ptr_sid = ( uint32 * ) talloc ( mem_ctx , num_entries *
sizeof ( uint32 ) ) ) = = NULL ) {
DEBUG ( 3 , ( " init_lsa_sid_enum(): out of memory for ptr_sid \n " ) ) ;
return ;
}
if ( ( sen - > sid = ( DOM_SID2 * ) talloc ( mem_ctx , num_entries *
sizeof ( DOM_SID2 ) ) ) = = NULL ) {
DEBUG ( 3 , ( " init_lsa_sid_enum(): out of memory for sids \n " ) ) ;
return ;
}
/* Copy across SIDs and SID pointers */
for ( i = 0 ; i < num_entries ; i + + ) {
sen - > ptr_sid [ i ] = 1 ;
init_dom_sid2 ( & sen - > sid [ i ] , & sids [ i ] ) ;
}
}
/*******************************************************************
Reads or writes a LSA_SID_ENUM structure .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
static BOOL lsa_io_sid_enum ( char * desc , LSA_SID_ENUM * sen , prs_struct * ps ,
int depth )
{
int i ;
prs_debug ( ps , depth , desc , " lsa_io_sid_enum " ) ;
depth + + ;
if ( ! prs_align ( ps ) )
return False ;
if ( ! prs_uint32 ( " num_entries " , ps , depth , & sen - > num_entries ) )
return False ;
if ( ! prs_uint32 ( " ptr_sid_enum " , ps , depth , & sen - > ptr_sid_enum ) )
return False ;
if ( ! prs_uint32 ( " num_entries2 " , ps , depth , & sen - > num_entries2 ) )
return False ;
/* Mallocate memory if we're unpacking from the wire */
if ( UNMARSHALLING ( ps ) ) {
if ( ( sen - > ptr_sid = ( uint32 * ) prs_alloc_mem ( ps ,
sen - > num_entries * sizeof ( uint32 ) ) ) = = NULL ) {
DEBUG ( 3 , ( " init_lsa_sid_enum(): out of memory for "
" ptr_sid \n " ) ) ;
return False ;
}
if ( ( sen - > sid = ( DOM_SID2 * ) prs_alloc_mem ( ps ,
sen - > num_entries * sizeof ( DOM_SID2 ) ) ) = = NULL ) {
DEBUG ( 3 , ( " init_lsa_sid_enum(): out of memory for "
" sids \n " ) ) ;
return False ;
}
}
for ( i = 0 ; i < sen - > num_entries ; i + + ) {
fstring temp ;
slprintf ( temp , sizeof ( temp ) - 1 , " ptr_sid[%d] " , i ) ;
if ( ! prs_uint32 ( temp , ps , depth , & sen - > ptr_sid [ i ] ) ) {
return False ;
}
}
for ( i = 0 ; i < sen - > num_entries ; i + + ) {
fstring temp ;
slprintf ( temp , sizeof ( temp ) - 1 , " sid[%d] " , i ) ;
if ( ! smb_io_dom_sid2 ( temp , & sen - > sid [ i ] , ps , depth ) ) {
return False ;
}
}
return True ;
}
/*******************************************************************
Inits an LSA_R_ENUM_TRUST_DOM structure .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
void init_q_lookup_sids ( TALLOC_CTX * mem_ctx , LSA_Q_LOOKUP_SIDS * q_l ,
POLICY_HND * hnd , int num_sids , DOM_SID * sids ,
uint16 level )
{
DEBUG ( 5 , ( " init_r_enum_trust_dom \n " ) ) ;
ZERO_STRUCTP ( q_l ) ;
memcpy ( & q_l - > pol , hnd , sizeof ( q_l - > pol ) ) ;
init_lsa_sid_enum ( mem_ctx , & q_l - > sids , num_sids , sids ) ;
q_l - > level . value = level ;
}
/*******************************************************************
Reads or writes a LSA_Q_LOOKUP_SIDS structure .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
BOOL lsa_io_q_lookup_sids ( char * desc , LSA_Q_LOOKUP_SIDS * q_s , prs_struct * ps ,
int depth )
{
prs_debug ( ps , depth , desc , " lsa_io_q_lookup_sids " ) ;
depth + + ;
if ( ! prs_align ( ps ) )
return False ;
if ( ! smb_io_pol_hnd ( " pol_hnd " , & q_s - > pol , ps , depth ) ) /* policy handle */
return False ;
if ( ! lsa_io_sid_enum ( " sids " , & q_s - > sids , ps , depth ) ) /* sids to be looked up */
return False ;
if ( ! lsa_io_trans_names ( " names " , & q_s - > names , ps , depth ) ) /* translated names */
return False ;
if ( ! smb_io_lookup_level ( " switch " , & q_s - > level , ps , depth ) ) /* lookup level */
return False ;
if ( ! prs_uint32 ( " mapped_count " , ps , depth , & q_s - > mapped_count ) )
return False ;
return True ;
}
/*******************************************************************
Reads or writes a structure .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
static BOOL lsa_io_trans_names ( char * desc , LSA_TRANS_NAME_ENUM * trn ,
prs_struct * ps , int depth )
{
int i ;
prs_debug ( ps , depth , desc , " lsa_io_trans_names " ) ;
depth + + ;
if ( ! prs_align ( ps ) )
return False ;
if ( ! prs_uint32 ( " num_entries " , ps , depth , & trn - > num_entries ) )
return False ;
if ( ! prs_uint32 ( " ptr_trans_names " , ps , depth , & trn - > ptr_trans_names ) )
return False ;
if ( trn - > ptr_trans_names ! = 0 ) {
if ( ! prs_uint32 ( " num_entries2 " , ps , depth ,
& trn - > num_entries2 ) )
return False ;
if ( UNMARSHALLING ( ps ) ) {
if ( ( trn - > name = ( LSA_TRANS_NAME * )
prs_alloc_mem ( ps , trn - > num_entries *
sizeof ( LSA_TRANS_NAME ) ) ) = = NULL ) {
return False ;
}
if ( ( trn - > uni_name = ( UNISTR2 * )
prs_alloc_mem ( ps , trn - > num_entries *
sizeof ( UNISTR2 ) ) ) = = NULL ) {
return False ;
}
}
for ( i = 0 ; i < trn - > num_entries2 ; i + + ) {
fstring t ;
slprintf ( t , sizeof ( t ) - 1 , " name[%d] " , i ) ;
if ( ! lsa_io_trans_name ( t , & trn - > name [ i ] , ps , depth ) ) /* translated name */
return False ;
}
for ( i = 0 ; i < trn - > num_entries2 ; i + + ) {
fstring t ;
slprintf ( t , sizeof ( t ) - 1 , " name[%d] " , i ) ;
if ( ! smb_io_unistr2 ( t , & trn - > uni_name [ i ] , trn - > name [ i ] . hdr_name . buffer , ps , depth ) )
return False ;
if ( ! prs_align ( ps ) )
return False ;
}
}
return True ;
}
/*******************************************************************
Reads or writes a structure .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
BOOL lsa_io_r_lookup_sids ( char * desc , LSA_R_LOOKUP_SIDS * r_s ,
prs_struct * ps , int depth )
{
prs_debug ( ps , depth , desc , " lsa_io_r_lookup_sids " ) ;
depth + + ;
if ( ! prs_align ( ps ) )
return False ;
if ( ! prs_uint32 ( " ptr_dom_ref " , ps , depth , & r_s - > ptr_dom_ref ) )
return False ;
if ( r_s - > ptr_dom_ref ! = 0 )
if ( ! lsa_io_dom_r_ref ( " dom_ref " , r_s - > dom_ref , ps , depth ) ) /* domain reference info */
return False ;
if ( ! lsa_io_trans_names ( " names " , r_s - > names , ps , depth ) ) /* translated names */
return False ;
if ( ! prs_align ( ps ) )
return False ;
if ( ! prs_uint32 ( " mapped_count " , ps , depth , & r_s - > mapped_count ) )
return False ;
if ( ! prs_uint32 ( " status " , ps , depth , & r_s - > status ) )
return False ;
return True ;
}
/*******************************************************************
makes a structure .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
void init_q_lookup_names ( TALLOC_CTX * mem_ctx , LSA_Q_LOOKUP_NAMES * q_l ,
POLICY_HND * hnd , int num_names , char * * names )
{
int i ;
DEBUG ( 5 , ( " init_q_lookup_names \n " ) ) ;
ZERO_STRUCTP ( q_l ) ;
q_l - > pol = * hnd ;
q_l - > num_entries = num_names ;
q_l - > num_entries2 = num_names ;
q_l - > lookup_level = 1 ;
if ( ( q_l - > uni_name = ( UNISTR2 * ) talloc (
mem_ctx , num_names * sizeof ( UNISTR2 ) ) ) = = NULL ) {
DEBUG ( 3 , ( " init_q_lookup_names(): out of memory \n " ) ) ;
return ;
}
if ( ( q_l - > hdr_name = ( UNIHDR * ) talloc (
mem_ctx , num_names * sizeof ( UNIHDR ) ) ) = = NULL ) {
DEBUG ( 3 , ( " init_q_lookup_names(): out of memory \n " ) ) ;
return ;
}
for ( i = 0 ; i < num_names ; i + + ) {
char * name = names [ i ] ;
int len = strlen ( name ) ;
init_uni_hdr ( & q_l - > hdr_name [ i ] , len ) ;
init_unistr2 ( & q_l - > uni_name [ i ] , name , len ) ;
}
}
/*******************************************************************
reads or writes a structure .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
BOOL lsa_io_q_lookup_names ( char * desc , LSA_Q_LOOKUP_NAMES * q_r ,
prs_struct * ps , int depth )
{
int i ;
prs_debug ( ps , depth , desc , " lsa_io_q_lookup_names " ) ;
depth + + ;
if ( ! prs_align ( ps ) )
return False ;
if ( ! smb_io_pol_hnd ( " " , & q_r - > pol , ps , depth ) ) /* policy handle */
return False ;
if ( ! prs_align ( ps ) )
return False ;
if ( ! prs_uint32 ( " num_entries " , ps , depth , & q_r - > num_entries ) )
return False ;
if ( ! prs_uint32 ( " num_entries2 " , ps , depth , & q_r - > num_entries2 ) )
return False ;
if ( UNMARSHALLING ( ps ) ) {
if ( q_r - > num_entries ) {
if ( ( q_r - > hdr_name = ( UNIHDR * ) prs_alloc_mem ( ps ,
q_r - > num_entries * sizeof ( UNIHDR ) ) ) = = NULL )
return False ;
if ( ( q_r - > uni_name = ( UNISTR2 * ) prs_alloc_mem ( ps ,
q_r - > num_entries * sizeof ( UNISTR2 ) ) ) = = NULL )
return False ;
}
}
for ( i = 0 ; i < q_r - > num_entries ; i + + ) {
if ( ! prs_align ( ps ) )
return False ;
if ( ! smb_io_unihdr ( " hdr_name " , & q_r - > hdr_name [ i ] , ps , depth ) ) /* pointer names */
return False ;
}
for ( i = 0 ; i < q_r - > num_entries ; i + + ) {
if ( ! prs_align ( ps ) )
return False ;
if ( ! smb_io_unistr2 ( " dom_name " , & q_r - > uni_name [ i ] , q_r - > hdr_name [ i ] . buffer , ps , depth ) ) /* names to be looked up */
return False ;
}
if ( ! prs_align ( ps ) )
return False ;
if ( ! prs_uint32 ( " num_trans_entries " , ps , depth , & q_r - > num_trans_entries ) )
return False ;
if ( ! prs_uint32 ( " ptr_trans_sids " , ps , depth , & q_r - > ptr_trans_sids ) )
return False ;
if ( ! prs_uint32 ( " lookup_level " , ps , depth , & q_r - > lookup_level ) )
return False ;
if ( ! prs_uint32 ( " mapped_count " , ps , depth , & q_r - > mapped_count ) )
return False ;
return True ;
}
/*******************************************************************
reads or writes a structure .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
BOOL lsa_io_r_lookup_names ( char * desc , LSA_R_LOOKUP_NAMES * r_r ,
prs_struct * ps , int depth )
{
int i ;
prs_debug ( ps , depth , desc , " lsa_io_r_lookup_names " ) ;
depth + + ;
if ( ! prs_align ( ps ) )
return False ;
if ( ! prs_uint32 ( " ptr_dom_ref " , ps , depth , & r_r - > ptr_dom_ref ) )
return False ;
if ( r_r - > ptr_dom_ref ! = 0 )
if ( ! lsa_io_dom_r_ref ( " " , r_r - > dom_ref , ps , depth ) )
return False ;
if ( ! prs_uint32 ( " num_entries " , ps , depth , & r_r - > num_entries ) )
return False ;
if ( ! prs_uint32 ( " ptr_entries " , ps , depth , & r_r - > ptr_entries ) )
return False ;
if ( r_r - > ptr_entries ! = 0 ) {
if ( ! prs_uint32 ( " num_entries2 " , ps , depth , & r_r - > num_entries2 ) )
return False ;
if ( r_r - > num_entries2 ! = r_r - > num_entries ) {
/* RPC fault */
return False ;
}
if ( UNMARSHALLING ( ps ) ) {
if ( ( r_r - > dom_rid = ( DOM_RID2 * ) prs_alloc_mem ( ps , r_r - > num_entries2 * sizeof ( DOM_RID2 ) ) )
= = NULL ) {
DEBUG ( 3 , ( " lsa_io_r_lookup_names(): out of memory \n " ) ) ;
return False ;
}
}
for ( i = 0 ; i < r_r - > num_entries2 ; i + + )
if ( ! smb_io_dom_rid2 ( " " , & r_r - > dom_rid [ i ] , ps , depth ) ) /* domain RIDs being looked up */
return False ;
}
if ( ! prs_uint32 ( " mapped_count " , ps , depth , & r_r - > mapped_count ) )
return False ;
if ( ! prs_uint32 ( " status " , ps , depth , & r_r - > status ) )
return False ;
return True ;
}
/*******************************************************************
Inits an LSA_Q_CLOSE structure .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
void init_lsa_q_close ( LSA_Q_CLOSE * q_c , POLICY_HND * hnd )
{
DEBUG ( 5 , ( " init_lsa_q_close \n " ) ) ;
memcpy ( & q_c - > pol , hnd , sizeof ( q_c - > pol ) ) ;
}
/*******************************************************************
Reads or writes an LSA_Q_CLOSE structure .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
BOOL lsa_io_q_close ( char * desc , LSA_Q_CLOSE * q_c , prs_struct * ps , int depth )
{
prs_debug ( ps , depth , desc , " lsa_io_q_close " ) ;
depth + + ;
if ( ! smb_io_pol_hnd ( " " , & q_c - > pol , ps , depth ) )
return False ;
return True ;
}
/*******************************************************************
Reads or writes an LSA_R_CLOSE structure .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
BOOL lsa_io_r_close ( char * desc , LSA_R_CLOSE * r_c , prs_struct * ps , int depth )
{
prs_debug ( ps , depth , desc , " lsa_io_r_close " ) ;
depth + + ;
if ( ! smb_io_pol_hnd ( " " , & r_c - > pol , ps , depth ) )
return False ;
if ( ! prs_uint32 ( " status " , ps , depth , & r_c - > status ) )
return False ;
return True ;
}
/*******************************************************************
Reads or writes an LSA_Q_OPEN_SECRET structure .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
BOOL lsa_io_q_open_secret ( char * desc , LSA_Q_OPEN_SECRET * q_c , prs_struct * ps , int depth )
{
prs_debug ( ps , depth , desc , " lsa_io_q_open_secret " ) ;
depth + + ;
/* Don't bother to read or write at present... */
return True ;
}
/*******************************************************************
Reads or writes an LSA_R_OPEN_SECRET structure .
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
BOOL lsa_io_r_open_secret ( char * desc , LSA_R_OPEN_SECRET * r_c , prs_struct * ps , int depth )
{
prs_debug ( ps , depth , desc , " lsa_io_r_open_secret " ) ;
depth + + ;
if ( ! prs_align ( ps ) )
return False ;
if ( ! prs_uint32 ( " dummy1 " , ps , depth , & r_c - > dummy1 ) )
return False ;
if ( ! prs_uint32 ( " dummy2 " , ps , depth , & r_c - > dummy2 ) )
return False ;
if ( ! prs_uint32 ( " dummy3 " , ps , depth , & r_c - > dummy3 ) )
return False ;
if ( ! prs_uint32 ( " dummy4 " , ps , depth , & r_c - > dummy4 ) )
return False ;
if ( ! prs_uint32 ( " status " , ps , depth , & r_c - > status ) )
return False ;
return True ;
}