2005-10-19 13:45:44 +00:00
/*
Unix SMB / CIFS implementation .
Command backend for wbinfo - m
Copyright ( C ) Volker Lendecke 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
2007-07-10 02:07:03 +00:00
the Free Software Foundation ; either version 3 of the License , or
2005-10-19 13:45:44 +00:00
( 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
2007-07-10 02:07:03 +00:00
along with this program . If not , see < http : //www.gnu.org/licenses/>.
2005-10-19 13:45:44 +00:00
*/
# include "includes.h"
# include "libcli/composite/composite.h"
# include "winbind/wb_server.h"
# include "smbd/service_task.h"
2006-03-14 23:35:30 +00:00
# include "librpc/gen_ndr/ndr_lsa_c.h"
2005-10-19 13:45:44 +00:00
/* List trusted domains. To avoid the trouble with having to wait for other
* conflicting requests waiting for the lsa pipe we ' re opening our own lsa
* pipe here . */
struct cmd_list_trustdom_state {
struct composite_context * ctx ;
struct dcerpc_pipe * lsa_pipe ;
struct policy_handle * lsa_policy ;
2010-03-09 17:54:12 +01:00
uint32_t num_domains ;
2005-10-19 21:53:03 +00:00
struct wb_dom_info * * domains ;
2005-10-19 13:45:44 +00:00
uint32_t resume_handle ;
2005-10-19 21:53:03 +00:00
struct lsa_DomainList domainlist ;
2005-10-19 13:45:44 +00:00
struct lsa_EnumTrustDom r ;
} ;
static void cmd_list_trustdoms_recv_domain ( struct composite_context * ctx ) ;
static void cmd_list_trustdoms_recv_lsa ( struct composite_context * ctx ) ;
2010-03-10 10:01:23 +01:00
static void cmd_list_trustdoms_recv_doms ( struct tevent_req * subreq ) ;
2005-10-19 13:45:44 +00:00
2005-11-05 09:34:07 +00:00
struct composite_context * wb_cmd_list_trustdoms_send ( TALLOC_CTX * mem_ctx ,
struct wbsrv_service * service )
2005-10-19 13:45:44 +00:00
{
struct composite_context * result , * ctx ;
struct cmd_list_trustdom_state * state ;
2007-04-30 16:52:30 +00:00
result = composite_create ( mem_ctx , service - > task - > event_ctx ) ;
2005-10-19 13:45:44 +00:00
if ( result = = NULL ) goto failed ;
state = talloc ( result , struct cmd_list_trustdom_state ) ;
if ( state = = NULL ) goto failed ;
state - > ctx = result ;
result - > private_data = state ;
2005-11-05 09:34:07 +00:00
ctx = wb_sid2domain_send ( state , service , service - > primary_sid ) ;
2005-10-19 13:45:44 +00:00
if ( ctx = = NULL ) goto failed ;
ctx - > async . fn = cmd_list_trustdoms_recv_domain ;
ctx - > async . private_data = state ;
return result ;
failed :
talloc_free ( result ) ;
return NULL ;
}
static void cmd_list_trustdoms_recv_domain ( struct composite_context * ctx )
{
struct cmd_list_trustdom_state * state =
talloc_get_type ( ctx - > async . private_data ,
struct cmd_list_trustdom_state ) ;
struct wbsrv_domain * domain ;
struct smbcli_tree * tree ;
state - > ctx - > status = wb_sid2domain_recv ( ctx , & domain ) ;
if ( ! composite_is_ok ( state - > ctx ) ) return ;
2007-07-23 02:56:51 +00:00
tree = dcerpc_smb_tree ( domain - > libnet_ctx - > lsa . pipe - > conn ) ;
2005-10-19 21:53:03 +00:00
if ( composite_nomem ( tree , state - > ctx ) ) return ;
2005-10-19 13:45:44 +00:00
2007-05-25 08:04:39 +00:00
ctx = wb_init_lsa_send ( state , domain ) ;
2005-10-19 13:45:44 +00:00
composite_continue ( state - > ctx , ctx , cmd_list_trustdoms_recv_lsa ,
state ) ;
}
static void cmd_list_trustdoms_recv_lsa ( struct composite_context * ctx )
{
struct cmd_list_trustdom_state * state =
talloc_get_type ( ctx - > async . private_data ,
struct cmd_list_trustdom_state ) ;
2010-03-10 10:01:23 +01:00
struct tevent_req * subreq ;
2005-10-19 13:45:44 +00:00
state - > ctx - > status = wb_init_lsa_recv ( ctx , state ,
& state - > lsa_pipe ,
& state - > lsa_policy ) ;
if ( ! composite_is_ok ( state - > ctx ) ) return ;
2005-10-19 21:53:03 +00:00
state - > num_domains = 0 ;
state - > domains = NULL ;
state - > domainlist . count = 0 ;
state - > domainlist . domains = NULL ;
2005-10-19 13:45:44 +00:00
state - > resume_handle = 0 ;
2005-10-19 21:53:03 +00:00
state - > r . in . handle = state - > lsa_policy ;
2005-10-19 13:45:44 +00:00
state - > r . in . resume_handle = & state - > resume_handle ;
state - > r . in . max_size = 1000 ;
state - > r . out . resume_handle = & state - > resume_handle ;
2005-10-19 21:53:03 +00:00
state - > r . out . domains = & state - > domainlist ;
2005-10-19 13:45:44 +00:00
2010-03-10 10:01:23 +01:00
subreq = dcerpc_lsa_EnumTrustDom_r_send ( state ,
state - > ctx - > event_ctx ,
state - > lsa_pipe - > binding_handle ,
& state - > r ) ;
if ( composite_nomem ( subreq , state - > ctx ) ) return ;
tevent_req_set_callback ( subreq , cmd_list_trustdoms_recv_doms , state ) ;
2005-10-19 13:45:44 +00:00
}
2010-03-10 10:01:23 +01:00
static void cmd_list_trustdoms_recv_doms ( struct tevent_req * subreq )
2005-10-19 13:45:44 +00:00
{
2005-10-19 21:53:03 +00:00
struct cmd_list_trustdom_state * state =
2010-03-10 10:01:23 +01:00
tevent_req_callback_data ( subreq ,
struct cmd_list_trustdom_state ) ;
2010-03-09 17:54:12 +01:00
uint32_t i , old_num_domains ;
2005-10-19 21:53:03 +00:00
2010-03-10 10:01:23 +01:00
state - > ctx - > status = dcerpc_lsa_EnumTrustDom_r_recv ( subreq , state ) ;
TALLOC_FREE ( subreq ) ;
2005-10-19 21:53:03 +00:00
if ( ! composite_is_ok ( state - > ctx ) ) return ;
state - > ctx - > status = state - > r . out . result ;
if ( ! NT_STATUS_IS_OK ( state - > ctx - > status ) & &
! NT_STATUS_EQUAL ( state - > ctx - > status , NT_STATUS_NO_MORE_ENTRIES ) & &
! NT_STATUS_EQUAL ( state - > ctx - > status , STATUS_MORE_ENTRIES ) ) {
composite_error ( state - > ctx , state - > ctx - > status ) ;
return ;
}
old_num_domains = state - > num_domains ;
state - > num_domains + = state - > r . out . domains - > count ;
state - > domains = talloc_realloc ( state , state - > domains ,
struct wb_dom_info * ,
state - > num_domains ) ;
2008-04-16 16:10:16 +02:00
if ( state - > num_domains & &
composite_nomem ( state - > domains , state - > ctx ) ) return ;
2005-10-19 21:53:03 +00:00
for ( i = 0 ; i < state - > r . out . domains - > count ; i + + ) {
2010-03-09 17:54:12 +01:00
uint32_t j = i + old_num_domains ;
2005-10-19 21:53:03 +00:00
state - > domains [ j ] = talloc ( state - > domains ,
struct wb_dom_info ) ;
if ( composite_nomem ( state - > domains [ i ] , state - > ctx ) ) return ;
state - > domains [ j ] - > name = talloc_steal (
state - > domains [ j ] ,
state - > r . out . domains - > domains [ i ] . name . string ) ;
state - > domains [ j ] - > sid = talloc_steal (
state - > domains [ j ] ,
state - > r . out . domains - > domains [ i ] . sid ) ;
}
2008-07-21 15:00:18 +10:00
if ( NT_STATUS_IS_OK ( state - > ctx - > status ) | | NT_STATUS_EQUAL ( state - > ctx - > status , NT_STATUS_NO_MORE_ENTRIES ) ) {
state - > ctx - > status = NT_STATUS_OK ;
2005-10-19 21:53:03 +00:00
composite_done ( state - > ctx ) ;
return ;
}
state - > domainlist . count = 0 ;
state - > domainlist . domains = NULL ;
state - > r . in . handle = state - > lsa_policy ;
state - > r . in . resume_handle = & state - > resume_handle ;
state - > r . in . max_size = 1000 ;
state - > r . out . resume_handle = & state - > resume_handle ;
state - > r . out . domains = & state - > domainlist ;
2005-10-19 13:45:44 +00:00
2010-03-10 10:01:23 +01:00
subreq = dcerpc_lsa_EnumTrustDom_r_send ( state ,
state - > ctx - > event_ctx ,
state - > lsa_pipe - > binding_handle ,
& state - > r ) ;
if ( composite_nomem ( subreq , state - > ctx ) ) return ;
tevent_req_set_callback ( subreq , cmd_list_trustdoms_recv_doms , state ) ;
2005-10-19 21:53:03 +00:00
}
NTSTATUS wb_cmd_list_trustdoms_recv ( struct composite_context * ctx ,
TALLOC_CTX * mem_ctx ,
2010-03-09 17:54:12 +01:00
uint32_t * num_domains ,
2005-10-19 21:53:03 +00:00
struct wb_dom_info * * * domains )
{
NTSTATUS status = composite_wait ( ctx ) ;
if ( NT_STATUS_IS_OK ( status ) ) {
struct cmd_list_trustdom_state * state =
talloc_get_type ( ctx - > private_data ,
struct cmd_list_trustdom_state ) ;
* num_domains = state - > num_domains ;
* domains = talloc_steal ( mem_ctx , state - > domains ) ;
}
talloc_free ( ctx ) ;
return status ;
2005-10-19 13:45:44 +00:00
}