2003-11-21 13:14:17 +00:00
/*
Unix SMB / CIFS implementation .
test suite for epmapper rpc operations
Copyright ( C ) Andrew Tridgell 2003
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"
2003-11-24 05:28:10 +00:00
/*
display any protocol tower
*/
static void display_tower ( TALLOC_CTX * mem_ctx , struct epm_towers * twr )
{
int i ;
const char * uuid ;
for ( i = 0 ; i < twr - > num_floors ; i + + ) {
struct epm_lhs * lhs = & twr - > floors [ i ] . lhs ;
struct epm_rhs * rhs = & twr - > floors [ i ] . rhs ;
switch ( lhs - > protocol ) {
2004-08-10 20:55:42 +00:00
case EPM_PROTOCOL_NCACN_DNET_NSP :
printf ( " DNET/NSP " ) ;
break ;
2003-11-27 07:28:46 +00:00
case EPM_PROTOCOL_UUID :
2003-11-24 05:28:10 +00:00
uuid = GUID_string ( mem_ctx , & lhs - > info . uuid . uuid ) ;
if ( strcasecmp ( uuid , NDR_GUID ) = = 0 ) {
printf ( " NDR " ) ;
} else {
printf ( " uuid %s/0x%02x " , uuid , lhs - > info . uuid . version ) ;
}
break ;
2003-11-27 07:28:46 +00:00
2004-08-10 20:55:42 +00:00
case EPM_PROTOCOL_NCACN_RPC_C :
2003-11-24 05:28:10 +00:00
printf ( " RPC-C " ) ;
break ;
2004-08-10 20:55:42 +00:00
case EPM_PROTOCOL_NCACN_IP :
2003-11-24 05:28:10 +00:00
printf ( " IP: " ) ;
2003-11-24 10:15:17 +00:00
if ( rhs - > rhs_data . length = = 4 ) {
2003-11-24 05:28:10 +00:00
struct in_addr in ;
2003-11-24 13:19:00 +00:00
in . s_addr = IVAL ( rhs - > rhs_data . data , 0 ) ;
2003-11-24 05:28:10 +00:00
printf ( " %s " , inet_ntoa ( in ) ) ;
}
break ;
2004-08-10 20:55:42 +00:00
case EPM_PROTOCOL_NCACN_PIPE :
2003-11-24 10:15:17 +00:00
printf ( " PIPE:%.*s " , rhs - > rhs_data . length , rhs - > rhs_data . data ) ;
2003-11-24 05:28:10 +00:00
break ;
2004-08-10 20:55:42 +00:00
case EPM_PROTOCOL_NCACN_SMB :
2003-11-24 10:15:17 +00:00
printf ( " SMB:%.*s " , rhs - > rhs_data . length , rhs - > rhs_data . data ) ;
2003-11-24 05:28:10 +00:00
break ;
2004-08-10 20:55:42 +00:00
case EPM_PROTOCOL_NCACN_NETBIOS :
2003-11-24 10:15:17 +00:00
printf ( " NetBIOS:%.*s " , rhs - > rhs_data . length , rhs - > rhs_data . data ) ;
2003-11-24 05:28:10 +00:00
break ;
2004-08-10 20:55:42 +00:00
case EPM_PROTOCOL_NCACN_NB_NB :
printf ( " NB_NB " ) ;
break ;
case EPM_PROTOCOL_NCACN_SPX :
printf ( " SPX " ) ;
break ;
/*
case EPM_PROTOCOL_NCACN_NB_IPX :
printf ( " NB_IPX " ) ;
break ; */
2003-11-24 05:28:10 +00:00
case 0x01 :
2003-11-24 10:15:17 +00:00
printf ( " UNK(1):%.*s " , rhs - > rhs_data . length , rhs - > rhs_data . data ) ;
2003-11-24 05:28:10 +00:00
break ;
2004-08-10 20:55:42 +00:00
case EPM_PROTOCOL_NCACN_HTTP :
2003-11-27 07:28:46 +00:00
printf ( " HTTP: " ) ;
2003-11-26 01:16:41 +00:00
if ( rhs - > rhs_data . length = = 2 ) {
printf ( " %d " , RSVAL ( rhs - > rhs_data . data , 0 ) ) ;
}
break ;
2004-08-10 20:55:42 +00:00
case EPM_PROTOCOL_NCACN_TCP :
2003-11-26 01:16:41 +00:00
/* what is the difference between this and 0x1f? */
2003-11-24 05:28:10 +00:00
printf ( " TCP: " ) ;
2003-11-24 10:15:17 +00:00
if ( rhs - > rhs_data . length = = 2 ) {
2003-11-24 13:19:00 +00:00
printf ( " %d " , RSVAL ( rhs - > rhs_data . data , 0 ) ) ;
2003-11-24 05:28:10 +00:00
}
break ;
2004-08-10 20:55:42 +00:00
case EPM_PROTOCOL_NCADG_UDP :
printf ( " UDP: " ) ;
break ;
2003-11-24 05:28:10 +00:00
default :
printf ( " UNK(%02x): " , lhs - > protocol ) ;
2003-11-24 10:15:17 +00:00
if ( rhs - > rhs_data . length = = 2 ) {
2003-11-24 13:19:00 +00:00
printf ( " %d " , RSVAL ( rhs - > rhs_data . data , 0 ) ) ;
2003-11-24 05:28:10 +00:00
}
break ;
}
}
printf ( " \n " ) ;
}
2003-11-24 10:15:17 +00:00
static BOOL test_Map ( struct dcerpc_pipe * p , TALLOC_CTX * mem_ctx ,
struct epm_twr_t * twr )
{
NTSTATUS status ;
struct epm_Map r ;
2003-12-16 09:02:58 +00:00
struct GUID uuid ;
2003-11-27 07:28:46 +00:00
const char * uuid_str ;
2003-11-24 10:15:17 +00:00
struct policy_handle handle ;
int i ;
ZERO_STRUCT ( uuid ) ;
ZERO_STRUCT ( handle ) ;
r . in . object = & uuid ;
r . in . map_tower = twr ;
r . in . entry_handle = & handle ;
r . out . entry_handle = & handle ;
r . in . max_towers = 100 ;
2003-11-28 05:20:11 +00:00
if ( twr - > towers . num_floors ! = 5 ) {
printf ( " tower has %d floors - skipping test_Map \n " , twr - > towers . num_floors ) ;
return True ;
}
2003-11-27 07:28:46 +00:00
uuid_str = GUID_string ( mem_ctx , & twr - > towers . floors [ 0 ] . lhs . info . uuid . uuid ) ;
printf ( " epm_Map results for '%s': \n " ,
idl_pipe_name ( uuid_str , twr - > towers . floors [ 0 ] . lhs . info . uuid . version ) ) ;
2004-08-10 20:55:42 +00:00
twr - > towers . floors [ 2 ] . lhs . protocol = EPM_PROTOCOL_NCACN_RPC_C ;
2003-11-27 07:28:46 +00:00
twr - > towers . floors [ 2 ] . lhs . info . lhs_data = data_blob ( NULL , 0 ) ;
2003-12-13 02:20:40 +00:00
twr - > towers . floors [ 2 ] . rhs . rhs_data = data_blob_talloc_zero ( p - > mem_ctx , 2 ) ;
2003-11-27 07:28:46 +00:00
2004-08-10 20:55:42 +00:00
twr - > towers . floors [ 3 ] . lhs . protocol = EPM_PROTOCOL_NCACN_TCP ;
2003-11-27 07:28:46 +00:00
twr - > towers . floors [ 3 ] . lhs . info . lhs_data = data_blob ( NULL , 0 ) ;
2003-12-13 02:20:40 +00:00
twr - > towers . floors [ 3 ] . rhs . rhs_data = data_blob_talloc_zero ( p - > mem_ctx , 2 ) ;
2003-11-27 07:28:46 +00:00
2004-08-10 20:55:42 +00:00
twr - > towers . floors [ 4 ] . lhs . protocol = EPM_PROTOCOL_NCACN_IP ;
2003-11-27 07:28:46 +00:00
twr - > towers . floors [ 4 ] . lhs . info . lhs_data = data_blob ( NULL , 0 ) ;
2003-12-13 02:20:40 +00:00
twr - > towers . floors [ 4 ] . rhs . rhs_data = data_blob_talloc_zero ( p - > mem_ctx , 4 ) ;
2003-11-27 07:28:46 +00:00
2003-11-24 10:15:17 +00:00
status = dcerpc_epm_Map ( p , mem_ctx , & r ) ;
2004-08-14 05:53:53 +00:00
if ( NT_STATUS_IS_OK ( status ) & & r . out . result = = 0 ) {
2003-11-27 07:28:46 +00:00
for ( i = 0 ; i < r . out . num_towers ; i + + ) {
if ( r . out . towers [ i ] . twr ) {
display_tower ( mem_ctx , & r . out . towers [ i ] . twr - > towers ) ;
}
}
2003-11-24 10:15:17 +00:00
}
2004-08-10 20:55:42 +00:00
twr - > towers . floors [ 3 ] . lhs . protocol = EPM_PROTOCOL_NCACN_HTTP ;
2003-11-27 07:28:46 +00:00
twr - > towers . floors [ 3 ] . lhs . info . lhs_data = data_blob ( NULL , 0 ) ;
2003-12-13 02:20:40 +00:00
twr - > towers . floors [ 3 ] . rhs . rhs_data = data_blob_talloc_zero ( p - > mem_ctx , 2 ) ;
2003-11-24 10:15:17 +00:00
2003-11-27 07:28:46 +00:00
status = dcerpc_epm_Map ( p , mem_ctx , & r ) ;
2004-08-14 05:53:53 +00:00
if ( NT_STATUS_IS_OK ( status ) & & r . out . result = = 0 ) {
2003-11-27 07:28:46 +00:00
for ( i = 0 ; i < r . out . num_towers ; i + + ) {
if ( r . out . towers [ i ] . twr ) {
display_tower ( mem_ctx , & r . out . towers [ i ] . twr - > towers ) ;
}
}
}
2004-08-10 20:55:42 +00:00
twr - > towers . floors [ 3 ] . lhs . protocol = EPM_PROTOCOL_NCACN_SMB ;
2003-11-27 07:28:46 +00:00
twr - > towers . floors [ 3 ] . lhs . info . lhs_data = data_blob ( NULL , 0 ) ;
2003-12-13 02:20:40 +00:00
twr - > towers . floors [ 3 ] . rhs . rhs_data = data_blob_talloc_zero ( p - > mem_ctx , 2 ) ;
2003-11-27 07:28:46 +00:00
2004-08-10 20:55:42 +00:00
twr - > towers . floors [ 4 ] . lhs . protocol = EPM_PROTOCOL_NCACN_NETBIOS ;
2003-11-27 07:28:46 +00:00
twr - > towers . floors [ 4 ] . lhs . info . lhs_data = data_blob ( NULL , 0 ) ;
2003-12-13 02:20:40 +00:00
twr - > towers . floors [ 4 ] . rhs . rhs_data = data_blob_talloc_zero ( p - > mem_ctx , 2 ) ;
2003-11-27 07:28:46 +00:00
status = dcerpc_epm_Map ( p , mem_ctx , & r ) ;
2004-08-14 05:53:53 +00:00
if ( NT_STATUS_IS_OK ( status ) & & r . out . result = = 0 ) {
2003-11-27 07:28:46 +00:00
for ( i = 0 ; i < r . out . num_towers ; i + + ) {
if ( r . out . towers [ i ] . twr ) {
display_tower ( mem_ctx , & r . out . towers [ i ] . twr - > towers ) ;
}
2003-11-24 10:15:17 +00:00
}
}
return True ;
}
2003-11-21 13:14:17 +00:00
static BOOL test_Lookup ( struct dcerpc_pipe * p , TALLOC_CTX * mem_ctx )
{
NTSTATUS status ;
struct epm_Lookup r ;
struct GUID uuid ;
struct rpc_if_id_t iface ;
struct policy_handle handle ;
ZERO_STRUCT ( uuid ) ;
ZERO_STRUCT ( iface ) ;
ZERO_STRUCT ( handle ) ;
r . in . inquiry_type = 0 ;
r . in . object = & uuid ;
r . in . interface_id = & iface ;
r . in . vers_option = 0 ;
r . in . entry_handle = & handle ;
r . out . entry_handle = & handle ;
2003-11-24 05:28:10 +00:00
r . in . max_ents = 10 ;
2003-11-21 13:14:17 +00:00
do {
2003-11-24 10:15:17 +00:00
int i ;
2003-11-21 13:14:17 +00:00
status = dcerpc_epm_Lookup ( p , mem_ctx , & r ) ;
2004-08-14 05:53:53 +00:00
if ( ! NT_STATUS_IS_OK ( status ) | | r . out . result ! = 0 ) {
2003-11-24 10:15:17 +00:00
break ;
}
for ( i = 0 ; i < r . out . num_ents ; i + + ) {
printf ( " \n Found '%s' \n " , r . out . entries [ i ] . annotation ) ;
display_tower ( mem_ctx , & r . out . entries [ i ] . tower - > towers ) ;
test_Map ( p , mem_ctx , r . out . entries [ i ] . tower ) ;
2003-11-21 13:14:17 +00:00
}
2003-11-24 05:28:10 +00:00
} while ( NT_STATUS_IS_OK ( status ) & &
2004-08-14 05:53:53 +00:00
r . out . result = = 0 & &
2003-11-24 05:28:10 +00:00
r . out . num_ents = = r . in . max_ents ) ;
2003-11-21 13:14:17 +00:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " Lookup failed - %s \n " , nt_errstr ( status ) ) ;
return False ;
}
return True ;
}
BOOL torture_rpc_epmapper ( int dummy )
{
NTSTATUS status ;
struct dcerpc_pipe * p ;
TALLOC_CTX * mem_ctx ;
BOOL ret = True ;
mem_ctx = talloc_init ( " torture_rpc_epmapper " ) ;
2003-11-24 13:19:00 +00:00
status = torture_rpc_connection ( & p ,
DCERPC_EPMAPPER_NAME ,
DCERPC_EPMAPPER_UUID ,
DCERPC_EPMAPPER_VERSION ) ;
2003-11-21 13:14:17 +00:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
return False ;
}
if ( ! test_Lookup ( p , mem_ctx ) ) {
ret = False ;
}
2003-11-22 08:11:32 +00:00
talloc_destroy ( mem_ctx ) ;
2003-11-21 13:14:17 +00:00
torture_rpc_close ( p ) ;
return ret ;
}