2002-10-04 23:11:36 +04:00
/*
Unix SMB / CIFS implementation .
RPC pipe client
Copyright ( C ) Gerald Carter 2002 ,
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"
/* implementations of client side DsXXX() functions */
2003-07-30 21:29:00 +04:00
/********************************************************************
Get information about the server and directory services
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2002-11-19 04:12:44 +03:00
NTSTATUS cli_ds_getprimarydominfo ( struct cli_state * cli , TALLOC_CTX * mem_ctx ,
uint16 level , DS_DOMINFO_CTR * ctr )
2002-10-04 23:11:36 +04:00
{
prs_struct qbuf , rbuf ;
DS_Q_GETPRIMDOMINFO q ;
DS_R_GETPRIMDOMINFO r ;
NTSTATUS result ;
ZERO_STRUCT ( q ) ;
ZERO_STRUCT ( r ) ;
/* Initialise parse structures */
prs_init ( & qbuf , MAX_PDU_FRAG_LEN , mem_ctx , MARSHALL ) ;
prs_init ( & rbuf , 0 , mem_ctx , UNMARSHALL ) ;
q . level = level ;
2003-07-30 21:29:00 +04:00
if ( ! ds_io_q_getprimdominfo ( " " , & qbuf , 0 , & q )
2002-11-19 04:12:44 +03:00
| | ! rpc_api_pipe_req ( cli , DS_GETPRIMDOMINFO , & qbuf , & rbuf ) ) {
2002-10-04 23:11:36 +04:00
result = NT_STATUS_UNSUCCESSFUL ;
goto done ;
}
/* Unmarshall response */
2003-07-30 21:29:00 +04:00
if ( ! ds_io_r_getprimdominfo ( " " , & rbuf , 0 , & r ) ) {
2002-10-04 23:11:36 +04:00
result = NT_STATUS_UNSUCCESSFUL ;
goto done ;
}
2002-11-19 04:12:44 +03:00
/* Return basic info - if we are requesting at info != 1 then
there could be trouble . */
2002-10-04 23:11:36 +04:00
result = r . status ;
2002-11-19 04:12:44 +03:00
if ( ctr ) {
ctr - > basic = talloc ( mem_ctx , sizeof ( DSROLE_PRIMARY_DOMAIN_INFO_BASIC ) ) ;
if ( ! ctr - > basic )
goto done ;
2002-11-27 05:22:53 +03:00
memcpy ( ctr - > basic , r . info . basic , sizeof ( DSROLE_PRIMARY_DOMAIN_INFO_BASIC ) ) ;
2002-11-19 04:12:44 +03:00
}
2002-10-04 23:11:36 +04:00
done :
2002-11-19 04:12:44 +03:00
prs_mem_free ( & qbuf ) ;
prs_mem_free ( & rbuf ) ;
2002-10-04 23:11:36 +04:00
return result ;
}
2003-07-30 21:29:00 +04:00
/********************************************************************
Enumerate trusted domains in an AD forest
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
NTSTATUS cli_ds_enum_domain_trusts ( struct cli_state * cli , TALLOC_CTX * mem_ctx ,
const char * server , uint32 flags ,
2004-01-05 05:04:37 +03:00
struct ds_domain_trust * * trusts , uint32 * num_domains )
2003-07-30 21:29:00 +04:00
{
prs_struct qbuf , rbuf ;
DS_Q_ENUM_DOM_TRUSTS q ;
DS_R_ENUM_DOM_TRUSTS r ;
NTSTATUS result ;
ZERO_STRUCT ( q ) ;
ZERO_STRUCT ( r ) ;
/* Initialise parse structures */
prs_init ( & qbuf , MAX_PDU_FRAG_LEN , mem_ctx , MARSHALL ) ;
prs_init ( & rbuf , 0 , mem_ctx , UNMARSHALL ) ;
init_q_ds_enum_domain_trusts ( & q , server , flags ) ;
if ( ! ds_io_q_enum_domain_trusts ( " " , & qbuf , 0 , & q )
| | ! rpc_api_pipe_req ( cli , DS_ENUM_DOM_TRUSTS , & qbuf , & rbuf ) ) {
result = NT_STATUS_UNSUCCESSFUL ;
goto done ;
}
/* Unmarshall response */
if ( ! ds_io_r_enum_domain_trusts ( " " , & rbuf , 0 , & r ) ) {
result = NT_STATUS_UNSUCCESSFUL ;
goto done ;
}
result = r . status ;
2003-07-30 21:37:46 +04:00
if ( NT_STATUS_IS_OK ( result ) ) {
2003-07-31 09:43:47 +04:00
int i ;
2003-07-30 21:37:46 +04:00
* num_domains = r . num_domains ;
2004-01-05 05:04:37 +03:00
* trusts = ( struct ds_domain_trust * ) talloc ( mem_ctx , r . num_domains * sizeof ( * * trusts ) ) ;
for ( i = 0 ; i < * num_domains ; i + + ) {
( * trusts ) [ i ] . flags = r . domains . trusts [ i ] . flags ;
( * trusts ) [ i ] . parent_index = r . domains . trusts [ i ] . parent_index ;
( * trusts ) [ i ] . trust_type = r . domains . trusts [ i ] . trust_type ;
( * trusts ) [ i ] . trust_attributes = r . domains . trusts [ i ] . trust_attributes ;
( * trusts ) [ i ] . guid = r . domains . trusts [ i ] . guid ;
if ( & r . domains . trusts [ i ] . sid_ptr ) {
sid_copy ( & ( * trusts ) [ i ] . sid , & r . domains . trusts [ i ] . sid . sid ) ;
} else {
ZERO_STRUCT ( ( * trusts ) [ i ] . sid ) ;
}
if ( & r . domains . trusts [ i ] . netbios_ptr ) {
( * trusts ) [ i ] . netbios_domain = unistr2_tdup ( mem_ctx , & r . domains . trusts [ i ] . netbios_domain ) ;
} else {
( * trusts ) [ i ] . netbios_domain = NULL ;
}
if ( & r . domains . trusts [ i ] . dns_ptr ) {
( * trusts ) [ i ] . dns_domain = unistr2_tdup ( mem_ctx , & r . domains . trusts [ i ] . dns_domain ) ;
} else {
( * trusts ) [ i ] . dns_domain = NULL ;
}
2003-07-31 09:43:47 +04:00
}
2003-07-30 21:37:46 +04:00
}
2003-07-30 21:29:00 +04:00
done :
prs_mem_free ( & qbuf ) ;
prs_mem_free ( & rbuf ) ;
return result ;
}