2003-12-13 02:20:40 +00:00
/*
Unix SMB / CIFS implementation .
endpoint server for the epmapper pipe
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"
2004-08-14 05:53:53 +00:00
# include "rpc_server/common/common.h"
2003-12-13 02:20:40 +00:00
2004-08-14 05:53:53 +00:00
typedef uint32_t error_status_t ;
2003-12-13 02:20:40 +00:00
/* handle types for this module */
enum handle_types { HTYPE_LOOKUP } ;
This patch adds a better dcerpc server infastructure.
1.) We now register endpoint servers add startup via register_backend()
and later use the smb.conf 'dcerpc endpoint servers' parameter to setup the dcesrv_context
2.) each endpoint server can register at context creation time as much interfaces as it wants
(multiple interfaces on one endpoint are supported!)
(NOTE: there's a difference between 'endpoint server' and 'endpoint'!
for details look at rpc_server/dcesrv_server.h)
3.) one endpoint can have a security descriptor registered to it self
this will be checked in the future when a client wants to connect
to an smb pipe endpoint.
4.) we now have a 'remote' endpoint server, which works like the ntvfs_cifs module
it takes this options in the [globals] section:
dcerpc remote:interfaces = srvsvc, winreg, w32time, epmapper
dcerpc remote:binding = ...
dcerpc remote:user = ...
dcerpc remote:password = ...
5.) we currently have tree endpoint servers: epmapper, rpcecho and remote
the default for the 'dcerpc endpiont servers = epmapper, rpcecho'
for testing you can also do
dcerpc endpoint servers = rpcecho, remote, epmapper
dcerpc remote:interfaces = srvsvc, samr, netlogon
6,) please notice the the epmapper now only returns NO_ENTRIES
(but I think we'll find a solution for this too:-)
7.) also there're some other stuff left, but step by step :-)
This patch also includes updates for the
register_subsystem() , ntvfs_init(), and some other funtions
to check for duplicate subsystem registration
metze
(hmmm, my first large commit...I hope it works as supposed :-)
(This used to be commit 917e45dafd5be4c2cd90ff425b8d6f8403122349)
2004-01-08 22:55:27 +00:00
/* a endpoint combined with an interface description */
struct dcesrv_ep_iface {
const char * name ;
struct dcesrv_ep_description ep_description ;
const char * uuid ;
2004-05-25 16:24:13 +00:00
uint32_t if_version ;
This patch adds a better dcerpc server infastructure.
1.) We now register endpoint servers add startup via register_backend()
and later use the smb.conf 'dcerpc endpoint servers' parameter to setup the dcesrv_context
2.) each endpoint server can register at context creation time as much interfaces as it wants
(multiple interfaces on one endpoint are supported!)
(NOTE: there's a difference between 'endpoint server' and 'endpoint'!
for details look at rpc_server/dcesrv_server.h)
3.) one endpoint can have a security descriptor registered to it self
this will be checked in the future when a client wants to connect
to an smb pipe endpoint.
4.) we now have a 'remote' endpoint server, which works like the ntvfs_cifs module
it takes this options in the [globals] section:
dcerpc remote:interfaces = srvsvc, winreg, w32time, epmapper
dcerpc remote:binding = ...
dcerpc remote:user = ...
dcerpc remote:password = ...
5.) we currently have tree endpoint servers: epmapper, rpcecho and remote
the default for the 'dcerpc endpiont servers = epmapper, rpcecho'
for testing you can also do
dcerpc endpoint servers = rpcecho, remote, epmapper
dcerpc remote:interfaces = srvsvc, samr, netlogon
6,) please notice the the epmapper now only returns NO_ENTRIES
(but I think we'll find a solution for this too:-)
7.) also there're some other stuff left, but step by step :-)
This patch also includes updates for the
register_subsystem() , ntvfs_init(), and some other funtions
to check for duplicate subsystem registration
metze
(hmmm, my first large commit...I hope it works as supposed :-)
(This used to be commit 917e45dafd5be4c2cd90ff425b8d6f8403122349)
2004-01-08 22:55:27 +00:00
} ;
2003-12-13 03:23:41 +00:00
/*
simple routine to compare a GUID string to a GUID structure
*/
2003-12-16 09:02:58 +00:00
static int guid_cmp ( TALLOC_CTX * mem_ctx , const struct GUID * guid , const char * uuid_str )
2003-12-13 03:23:41 +00:00
{
const char * s = GUID_string ( mem_ctx , guid ) ;
if ( ! s | | strcasecmp ( s , uuid_str ) ) {
return - 1 ;
}
return 0 ;
}
/*
fill a protocol tower
*/
2004-10-21 11:39:58 +00:00
static BOOL fill_protocol_tower ( TALLOC_CTX * mem_ctx , struct epm_tower * twr ,
2003-12-13 03:23:41 +00:00
struct dcesrv_ep_iface * e )
{
twr - > num_floors = 5 ;
twr - > floors = talloc_array_p ( mem_ctx , struct epm_floor , 5 ) ;
if ( ! twr - > floors ) {
return False ;
}
twr - > floors [ 0 ] . lhs . protocol = EPM_PROTOCOL_UUID ;
GUID_from_string ( e - > uuid , & twr - > floors [ 0 ] . lhs . info . uuid . uuid ) ;
twr - > floors [ 0 ] . lhs . info . uuid . version = e - > if_version ;
2004-10-12 12:41:50 +00:00
twr - > floors [ 0 ] . rhs . uuid . unknown = 0 ;
2003-12-13 03:23:41 +00:00
/* encoded with NDR ... */
twr - > floors [ 1 ] . lhs . protocol = EPM_PROTOCOL_UUID ;
GUID_from_string ( NDR_GUID , & twr - > floors [ 1 ] . lhs . info . uuid . uuid ) ;
twr - > floors [ 1 ] . lhs . info . uuid . version = NDR_GUID_VERSION ;
2004-10-12 12:41:50 +00:00
twr - > floors [ 1 ] . rhs . uuid . unknown = 0 ;
2003-12-13 03:23:41 +00:00
/* on an RPC connection ... */
2004-10-11 20:12:51 +00:00
twr - > floors [ 2 ] . lhs . protocol = EPM_PROTOCOL_NCACN ;
2003-12-13 03:23:41 +00:00
twr - > floors [ 2 ] . lhs . info . lhs_data = data_blob ( NULL , 0 ) ;
2004-10-12 12:41:50 +00:00
twr - > floors [ 2 ] . rhs . ncacn . minor_version = 0 ;
2003-12-13 10:58:48 +00:00
This patch adds a better dcerpc server infastructure.
1.) We now register endpoint servers add startup via register_backend()
and later use the smb.conf 'dcerpc endpoint servers' parameter to setup the dcesrv_context
2.) each endpoint server can register at context creation time as much interfaces as it wants
(multiple interfaces on one endpoint are supported!)
(NOTE: there's a difference between 'endpoint server' and 'endpoint'!
for details look at rpc_server/dcesrv_server.h)
3.) one endpoint can have a security descriptor registered to it self
this will be checked in the future when a client wants to connect
to an smb pipe endpoint.
4.) we now have a 'remote' endpoint server, which works like the ntvfs_cifs module
it takes this options in the [globals] section:
dcerpc remote:interfaces = srvsvc, winreg, w32time, epmapper
dcerpc remote:binding = ...
dcerpc remote:user = ...
dcerpc remote:password = ...
5.) we currently have tree endpoint servers: epmapper, rpcecho and remote
the default for the 'dcerpc endpiont servers = epmapper, rpcecho'
for testing you can also do
dcerpc endpoint servers = rpcecho, remote, epmapper
dcerpc remote:interfaces = srvsvc, samr, netlogon
6,) please notice the the epmapper now only returns NO_ENTRIES
(but I think we'll find a solution for this too:-)
7.) also there're some other stuff left, but step by step :-)
This patch also includes updates for the
register_subsystem() , ntvfs_init(), and some other funtions
to check for duplicate subsystem registration
metze
(hmmm, my first large commit...I hope it works as supposed :-)
(This used to be commit 917e45dafd5be4c2cd90ff425b8d6f8403122349)
2004-01-08 22:55:27 +00:00
switch ( e - > ep_description . type ) {
2004-10-21 12:47:02 +00:00
case NCACN_NP :
2003-12-13 10:58:48 +00:00
/* on a SMB pipe ... */
2004-10-11 20:12:51 +00:00
twr - > floors [ 3 ] . lhs . protocol = EPM_PROTOCOL_SMB ;
2003-12-13 10:58:48 +00:00
twr - > floors [ 3 ] . lhs . info . lhs_data = data_blob ( NULL , 0 ) ;
2004-10-18 15:18:05 +00:00
twr - > floors [ 3 ] . rhs . smb . unc = talloc_strdup ( mem_ctx , e - > ep_description . info . smb_pipe ) ;
2003-12-13 10:58:48 +00:00
/* on an NetBIOS link ... */
2004-10-11 20:12:51 +00:00
twr - > floors [ 4 ] . lhs . protocol = EPM_PROTOCOL_NETBIOS ;
2003-12-13 10:58:48 +00:00
twr - > floors [ 4 ] . lhs . info . lhs_data = data_blob ( NULL , 0 ) ;
2004-10-12 12:41:50 +00:00
twr - > floors [ 4 ] . rhs . netbios . name = talloc_asprintf ( mem_ctx , " \\ \\ %s " ,
2003-12-13 10:58:48 +00:00
lp_netbios_name ( ) ) ;
break ;
2004-10-21 12:47:02 +00:00
case NCACN_IP_TCP :
2003-12-13 10:58:48 +00:00
/* on a TCP connection ... */
2004-10-11 20:12:51 +00:00
twr - > floors [ 3 ] . lhs . protocol = EPM_PROTOCOL_TCP ;
2003-12-13 10:58:48 +00:00
twr - > floors [ 3 ] . lhs . info . lhs_data = data_blob ( NULL , 0 ) ;
2004-10-12 12:41:50 +00:00
twr - > floors [ 3 ] . rhs . tcp . port = e - > ep_description . info . tcp_port ;
2003-12-13 10:58:48 +00:00
/* on an IP link ... */
2004-10-11 20:12:51 +00:00
twr - > floors [ 4 ] . lhs . protocol = EPM_PROTOCOL_IP ;
2003-12-13 10:58:48 +00:00
twr - > floors [ 4 ] . lhs . info . lhs_data = data_blob ( NULL , 0 ) ;
2004-10-12 12:41:50 +00:00
twr - > floors [ 4 ] . rhs . ip . address = 0 ;
2004-06-03 23:15:16 +00:00
/* TODO: we should fill in our IP address here as a hint to the
client */
2003-12-13 10:58:48 +00:00
break ;
}
2003-12-13 03:23:41 +00:00
return True ;
}
/*
build a list of all interfaces handled by all endpoint servers
*/
2004-05-25 16:24:13 +00:00
static uint32_t build_ep_list ( TALLOC_CTX * mem_ctx ,
2004-09-26 12:50:36 +00:00
struct dcesrv_endpoint * endpoint_list ,
struct dcesrv_ep_iface * * eps )
2003-12-13 03:23:41 +00:00
{
2004-01-09 02:43:23 +00:00
struct dcesrv_endpoint * d ;
2004-05-25 16:24:13 +00:00
uint32_t total = 0 ;
2003-12-13 03:23:41 +00:00
2004-09-27 01:36:19 +00:00
* eps = NULL ;
2004-01-09 02:43:23 +00:00
for ( d = endpoint_list ; d ; d = d - > next ) {
struct dcesrv_if_list * iface ;
for ( iface = d - > interface_list ; iface ; iface = iface - > next ) {
2004-09-27 01:36:19 +00:00
( * eps ) = talloc_realloc_p ( mem_ctx ,
* eps ,
2004-01-09 02:43:23 +00:00
struct dcesrv_ep_iface ,
total + 1 ) ;
if ( ! * eps ) {
return 0 ;
}
( * eps ) [ total ] . name = iface - > iface . ndr - > name ;
( * eps ) [ total ] . uuid = iface - > iface . ndr - > uuid ;
( * eps ) [ total ] . if_version = iface - > iface . ndr - > if_version ;
( * eps ) [ total ] . ep_description = d - > ep_description ;
total + + ;
}
}
2003-12-13 03:23:41 +00:00
return total ;
}
2004-08-14 05:53:53 +00:00
static error_status_t epm_Insert ( struct dcesrv_call_state * dce_call , TALLOC_CTX * mem_ctx ,
struct epm_Insert * r )
2003-12-13 02:20:40 +00:00
{
2004-08-14 05:29:16 +00:00
DCESRV_FAULT ( DCERPC_FAULT_OP_RNG_ERROR ) ;
2003-12-13 02:20:40 +00:00
}
2004-08-14 05:53:53 +00:00
static error_status_t epm_Delete ( struct dcesrv_call_state * dce_call , TALLOC_CTX * mem_ctx ,
struct epm_Delete * r )
2003-12-13 02:20:40 +00:00
{
2004-08-14 05:29:16 +00:00
DCESRV_FAULT ( DCERPC_FAULT_OP_RNG_ERROR ) ;
2003-12-13 02:20:40 +00:00
}
/*
implement epm_Lookup . This call is used to enumerate the interfaces
available on a rpc server
*/
2004-08-14 05:53:53 +00:00
static error_status_t epm_Lookup ( struct dcesrv_call_state * dce_call , TALLOC_CTX * mem_ctx ,
struct epm_Lookup * r )
2003-12-13 02:20:40 +00:00
{
struct dcesrv_handle * h ;
struct rpc_eps {
2004-05-25 16:24:13 +00:00
uint32_t count ;
2003-12-13 02:20:40 +00:00
struct dcesrv_ep_iface * e ;
} * eps ;
2004-05-25 16:24:13 +00:00
uint32_t num_ents ;
2003-12-13 02:20:40 +00:00
int i ;
This patch adds a better dcerpc server infastructure.
1.) We now register endpoint servers add startup via register_backend()
and later use the smb.conf 'dcerpc endpoint servers' parameter to setup the dcesrv_context
2.) each endpoint server can register at context creation time as much interfaces as it wants
(multiple interfaces on one endpoint are supported!)
(NOTE: there's a difference between 'endpoint server' and 'endpoint'!
for details look at rpc_server/dcesrv_server.h)
3.) one endpoint can have a security descriptor registered to it self
this will be checked in the future when a client wants to connect
to an smb pipe endpoint.
4.) we now have a 'remote' endpoint server, which works like the ntvfs_cifs module
it takes this options in the [globals] section:
dcerpc remote:interfaces = srvsvc, winreg, w32time, epmapper
dcerpc remote:binding = ...
dcerpc remote:user = ...
dcerpc remote:password = ...
5.) we currently have tree endpoint servers: epmapper, rpcecho and remote
the default for the 'dcerpc endpiont servers = epmapper, rpcecho'
for testing you can also do
dcerpc endpoint servers = rpcecho, remote, epmapper
dcerpc remote:interfaces = srvsvc, samr, netlogon
6,) please notice the the epmapper now only returns NO_ENTRIES
(but I think we'll find a solution for this too:-)
7.) also there're some other stuff left, but step by step :-)
This patch also includes updates for the
register_subsystem() , ntvfs_init(), and some other funtions
to check for duplicate subsystem registration
metze
(hmmm, my first large commit...I hope it works as supposed :-)
(This used to be commit 917e45dafd5be4c2cd90ff425b8d6f8403122349)
2004-01-08 22:55:27 +00:00
h = dcesrv_handle_fetch ( dce_call - > conn , r - > in . entry_handle , HTYPE_LOOKUP ) ;
2004-08-14 05:53:53 +00:00
DCESRV_CHECK_HANDLE ( h ) ;
2003-12-13 02:20:40 +00:00
eps = h - > data ;
if ( ! eps ) {
/* this is the first call - fill the list. Subsequent calls
will feed from this list , stored in the handle */
2004-09-25 11:24:10 +00:00
eps = talloc_p ( h , struct rpc_eps ) ;
2003-12-13 02:20:40 +00:00
if ( ! eps ) {
2004-08-14 05:53:53 +00:00
return EPMAPPER_STATUS_NO_MEMORY ;
2003-12-13 02:20:40 +00:00
}
h - > data = eps ;
2003-12-13 03:23:41 +00:00
2004-09-25 11:24:10 +00:00
eps - > count = build_ep_list ( h , dce_call - > conn - > dce_ctx - > endpoint_list , & eps - > e ) ;
2003-12-13 02:20:40 +00:00
}
/* return the next N elements */
num_ents = r - > in . max_ents ;
if ( num_ents > eps - > count ) {
num_ents = eps - > count ;
}
* r - > out . entry_handle = h - > wire_handle ;
r - > out . num_ents = num_ents ;
if ( num_ents = = 0 ) {
r - > out . entries = NULL ;
2003-12-13 04:46:50 +00:00
ZERO_STRUCTP ( r - > out . entry_handle ) ;
This patch adds a better dcerpc server infastructure.
1.) We now register endpoint servers add startup via register_backend()
and later use the smb.conf 'dcerpc endpoint servers' parameter to setup the dcesrv_context
2.) each endpoint server can register at context creation time as much interfaces as it wants
(multiple interfaces on one endpoint are supported!)
(NOTE: there's a difference between 'endpoint server' and 'endpoint'!
for details look at rpc_server/dcesrv_server.h)
3.) one endpoint can have a security descriptor registered to it self
this will be checked in the future when a client wants to connect
to an smb pipe endpoint.
4.) we now have a 'remote' endpoint server, which works like the ntvfs_cifs module
it takes this options in the [globals] section:
dcerpc remote:interfaces = srvsvc, winreg, w32time, epmapper
dcerpc remote:binding = ...
dcerpc remote:user = ...
dcerpc remote:password = ...
5.) we currently have tree endpoint servers: epmapper, rpcecho and remote
the default for the 'dcerpc endpiont servers = epmapper, rpcecho'
for testing you can also do
dcerpc endpoint servers = rpcecho, remote, epmapper
dcerpc remote:interfaces = srvsvc, samr, netlogon
6,) please notice the the epmapper now only returns NO_ENTRIES
(but I think we'll find a solution for this too:-)
7.) also there're some other stuff left, but step by step :-)
This patch also includes updates for the
register_subsystem() , ntvfs_init(), and some other funtions
to check for duplicate subsystem registration
metze
(hmmm, my first large commit...I hope it works as supposed :-)
(This used to be commit 917e45dafd5be4c2cd90ff425b8d6f8403122349)
2004-01-08 22:55:27 +00:00
dcesrv_handle_destroy ( dce_call - > conn , h ) ;
2004-08-14 05:53:53 +00:00
return EPMAPPER_STATUS_NO_MORE_ENTRIES ;
2003-12-13 02:20:40 +00:00
}
r - > out . entries = talloc_array_p ( mem_ctx , struct epm_entry_t , num_ents ) ;
if ( ! r - > out . entries ) {
2004-08-14 05:53:53 +00:00
return EPMAPPER_STATUS_NO_MEMORY ;
2003-12-13 02:20:40 +00:00
}
for ( i = 0 ; i < num_ents ; i + + ) {
ZERO_STRUCT ( r - > out . entries [ i ] . object ) ;
2003-12-13 04:46:50 +00:00
r - > out . entries [ i ] . annotation = eps - > e [ i ] . name ;
2003-12-13 03:23:41 +00:00
r - > out . entries [ i ] . tower = talloc_p ( mem_ctx , struct epm_twr_t ) ;
if ( ! r - > out . entries [ i ] . tower ) {
2004-08-14 05:53:53 +00:00
return EPMAPPER_STATUS_NO_MEMORY ;
2003-12-13 02:20:40 +00:00
}
2003-12-13 03:23:41 +00:00
2004-10-21 10:52:03 +00:00
if ( ! fill_protocol_tower ( mem_ctx , & r - > out . entries [ i ] . tower - > tower , & eps - > e [ i ] ) ) {
2004-08-14 05:53:53 +00:00
return EPMAPPER_STATUS_NO_MEMORY ;
2003-12-13 02:20:40 +00:00
}
}
eps - > count - = num_ents ;
eps - > e + = num_ents ;
2004-08-14 05:53:53 +00:00
return EPMAPPER_STATUS_OK ;
2003-12-13 02:20:40 +00:00
}
/*
implement epm_Map . This is used to find the specific endpoint to talk to given
a generic protocol tower
*/
2004-08-14 05:53:53 +00:00
static error_status_t epm_Map ( struct dcesrv_call_state * dce_call , TALLOC_CTX * mem_ctx ,
struct epm_Map * r )
2003-12-13 02:20:40 +00:00
{
2004-05-25 16:24:13 +00:00
uint32_t count ;
2003-12-13 03:23:41 +00:00
int i ;
struct dcesrv_ep_iface * eps ;
struct epm_floor * floors ;
This patch adds a better dcerpc server infastructure.
1.) We now register endpoint servers add startup via register_backend()
and later use the smb.conf 'dcerpc endpoint servers' parameter to setup the dcesrv_context
2.) each endpoint server can register at context creation time as much interfaces as it wants
(multiple interfaces on one endpoint are supported!)
(NOTE: there's a difference between 'endpoint server' and 'endpoint'!
for details look at rpc_server/dcesrv_server.h)
3.) one endpoint can have a security descriptor registered to it self
this will be checked in the future when a client wants to connect
to an smb pipe endpoint.
4.) we now have a 'remote' endpoint server, which works like the ntvfs_cifs module
it takes this options in the [globals] section:
dcerpc remote:interfaces = srvsvc, winreg, w32time, epmapper
dcerpc remote:binding = ...
dcerpc remote:user = ...
dcerpc remote:password = ...
5.) we currently have tree endpoint servers: epmapper, rpcecho and remote
the default for the 'dcerpc endpiont servers = epmapper, rpcecho'
for testing you can also do
dcerpc endpoint servers = rpcecho, remote, epmapper
dcerpc remote:interfaces = srvsvc, samr, netlogon
6,) please notice the the epmapper now only returns NO_ENTRIES
(but I think we'll find a solution for this too:-)
7.) also there're some other stuff left, but step by step :-)
This patch also includes updates for the
register_subsystem() , ntvfs_init(), and some other funtions
to check for duplicate subsystem registration
metze
(hmmm, my first large commit...I hope it works as supposed :-)
(This used to be commit 917e45dafd5be4c2cd90ff425b8d6f8403122349)
2004-01-08 22:55:27 +00:00
count = build_ep_list ( mem_ctx , dce_call - > conn - > dce_ctx - > endpoint_list , & eps ) ;
2003-12-13 03:23:41 +00:00
2004-06-03 23:15:16 +00:00
ZERO_STRUCT ( * r - > out . entry_handle ) ;
2003-12-13 03:23:41 +00:00
r - > out . num_towers = 1 ;
r - > out . towers = talloc_p ( mem_ctx , struct epm_twr_p_t ) ;
if ( ! r - > out . towers ) {
2004-08-14 05:53:53 +00:00
return EPMAPPER_STATUS_NO_MEMORY ;
2003-12-13 03:23:41 +00:00
}
r - > out . towers - > twr = talloc_p ( mem_ctx , struct epm_twr_t ) ;
if ( ! r - > out . towers - > twr ) {
2004-08-14 05:53:53 +00:00
return EPMAPPER_STATUS_NO_MEMORY ;
2003-12-13 03:23:41 +00:00
}
if ( ! r - > in . map_tower | | r - > in . max_towers = = 0 | |
2004-10-21 10:52:03 +00:00
r - > in . map_tower - > tower . num_floors ! = 5 ) {
2003-12-13 03:23:41 +00:00
goto failed ;
}
2004-10-21 10:52:03 +00:00
floors = r - > in . map_tower - > tower . floors ;
2003-12-13 03:23:41 +00:00
if ( floors [ 0 ] . lhs . protocol ! = EPM_PROTOCOL_UUID | |
floors [ 1 ] . lhs . protocol ! = EPM_PROTOCOL_UUID | |
guid_cmp ( mem_ctx , & floors [ 1 ] . lhs . info . uuid . uuid , NDR_GUID ) ! = 0 | |
floors [ 1 ] . lhs . info . uuid . version ! = NDR_GUID_VERSION | |
2004-10-11 20:12:51 +00:00
floors [ 2 ] . lhs . protocol ! = EPM_PROTOCOL_NCACN ) {
2003-12-13 03:23:41 +00:00
goto failed ;
}
for ( i = 0 ; i < count ; i + + ) {
if ( guid_cmp ( mem_ctx , & floors [ 0 ] . lhs . info . uuid . uuid , eps [ i ] . uuid ) ! = 0 | |
floors [ 0 ] . lhs . info . uuid . version ! = eps [ i ] . if_version ) {
continue ;
}
This patch adds a better dcerpc server infastructure.
1.) We now register endpoint servers add startup via register_backend()
and later use the smb.conf 'dcerpc endpoint servers' parameter to setup the dcesrv_context
2.) each endpoint server can register at context creation time as much interfaces as it wants
(multiple interfaces on one endpoint are supported!)
(NOTE: there's a difference between 'endpoint server' and 'endpoint'!
for details look at rpc_server/dcesrv_server.h)
3.) one endpoint can have a security descriptor registered to it self
this will be checked in the future when a client wants to connect
to an smb pipe endpoint.
4.) we now have a 'remote' endpoint server, which works like the ntvfs_cifs module
it takes this options in the [globals] section:
dcerpc remote:interfaces = srvsvc, winreg, w32time, epmapper
dcerpc remote:binding = ...
dcerpc remote:user = ...
dcerpc remote:password = ...
5.) we currently have tree endpoint servers: epmapper, rpcecho and remote
the default for the 'dcerpc endpiont servers = epmapper, rpcecho'
for testing you can also do
dcerpc endpoint servers = rpcecho, remote, epmapper
dcerpc remote:interfaces = srvsvc, samr, netlogon
6,) please notice the the epmapper now only returns NO_ENTRIES
(but I think we'll find a solution for this too:-)
7.) also there're some other stuff left, but step by step :-)
This patch also includes updates for the
register_subsystem() , ntvfs_init(), and some other funtions
to check for duplicate subsystem registration
metze
(hmmm, my first large commit...I hope it works as supposed :-)
(This used to be commit 917e45dafd5be4c2cd90ff425b8d6f8403122349)
2004-01-08 22:55:27 +00:00
switch ( eps [ i ] . ep_description . type ) {
2004-10-21 12:47:02 +00:00
case NCACN_NP :
2004-10-11 20:12:51 +00:00
if ( floors [ 3 ] . lhs . protocol ! = EPM_PROTOCOL_SMB | |
floors [ 4 ] . lhs . protocol ! = EPM_PROTOCOL_NETBIOS ) {
2003-12-13 03:23:41 +00:00
continue ;
}
break ;
2004-10-21 12:47:02 +00:00
case NCACN_IP_TCP :
2004-10-11 20:12:51 +00:00
if ( floors [ 3 ] . lhs . protocol ! = EPM_PROTOCOL_TCP | |
floors [ 4 ] . lhs . protocol ! = EPM_PROTOCOL_IP ) {
2003-12-13 03:23:41 +00:00
continue ;
}
break ;
}
2004-10-21 10:52:03 +00:00
fill_protocol_tower ( mem_ctx , & r - > out . towers - > twr - > tower , & eps [ i ] ) ;
2004-06-06 10:49:26 +00:00
r - > out . towers - > twr - > tower_length = 0 ;
2004-08-14 05:53:53 +00:00
return EPMAPPER_STATUS_OK ;
2003-12-13 03:23:41 +00:00
}
failed :
r - > out . num_towers = 0 ;
r - > out . towers - > twr = NULL ;
2004-08-14 05:53:53 +00:00
return EPMAPPER_STATUS_NO_MORE_ENTRIES ;
2003-12-13 02:20:40 +00:00
}
2004-08-14 05:53:53 +00:00
static error_status_t epm_LookupHandleFree ( struct dcesrv_call_state * dce_call , TALLOC_CTX * mem_ctx ,
struct epm_LookupHandleFree * r )
2003-12-13 02:20:40 +00:00
{
2004-08-14 05:29:16 +00:00
DCESRV_FAULT ( DCERPC_FAULT_OP_RNG_ERROR ) ;
2003-12-13 02:20:40 +00:00
}
2004-08-14 05:53:53 +00:00
static error_status_t epm_InqObject ( struct dcesrv_call_state * dce_call , TALLOC_CTX * mem_ctx ,
struct epm_InqObject * r )
2003-12-13 02:20:40 +00:00
{
2004-08-14 05:29:16 +00:00
DCESRV_FAULT ( DCERPC_FAULT_OP_RNG_ERROR ) ;
2003-12-13 02:20:40 +00:00
}
2004-08-14 05:53:53 +00:00
static error_status_t epm_MgmtDelete ( struct dcesrv_call_state * dce_call , TALLOC_CTX * mem_ctx ,
2003-12-13 03:23:41 +00:00
struct epm_MgmtDelete * r )
2003-12-13 02:20:40 +00:00
{
2004-08-14 05:29:16 +00:00
DCESRV_FAULT ( DCERPC_FAULT_OP_RNG_ERROR ) ;
2003-12-13 02:20:40 +00:00
}
2004-08-14 05:53:53 +00:00
static error_status_t epm_MapAuth ( struct dcesrv_call_state * dce_call , TALLOC_CTX * mem_ctx ,
2004-08-14 01:11:34 +00:00
struct epm_MapAuth * r )
{
2004-08-14 05:53:53 +00:00
DCESRV_FAULT ( DCERPC_FAULT_OP_RNG_ERROR ) ;
2004-08-14 01:11:34 +00:00
}
2003-12-13 02:20:40 +00:00
2003-12-14 13:22:12 +00:00
/* include the generated boilerplate */
# include "librpc/gen_ndr/ndr_epmapper_s.c"