2003-08-13 01:53:07 +00:00
/*
Unix SMB / CIFS implementation .
default IPC $ NTVFS backend
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-08-13 01:53:07 +00:00
Copyright ( C ) Andrew Tridgell 2003
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
Copyright ( C ) Stefan ( metze ) Metzmacher 2004
2003-08-13 01:53:07 +00:00
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 .
*/
/*
this implements the IPC $ backend , called by the NTVFS subsystem to
handle requests on IPC $ shares
*/
# include "includes.h"
2003-12-10 22:24:33 +00:00
/* this is the private structure used to keep the state of an open
ipc $ connection . It needs to keep information about all open
pipes */
struct ipc_private {
2004-05-25 17:24:24 +00:00
uint16_t next_fnum ;
uint16_t num_open ;
2003-12-10 22:24:33 +00:00
/* a list of open pipes */
struct pipe_state {
struct pipe_state * next , * prev ;
TALLOC_CTX * mem_ctx ;
const char * pipe_name ;
2004-05-25 17:24:24 +00:00
uint16_t fnum ;
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
struct dcesrv_connection * dce_conn ;
2004-05-25 17:24:24 +00:00
uint16_t ipc_state ;
2003-12-10 22:24:33 +00:00
} * pipe_list ;
} ;
/*
find the next fnum available on this connection
*/
2004-05-25 17:24:24 +00:00
static uint16_t find_next_fnum ( struct ipc_private * ipc )
2003-12-10 22:24:33 +00:00
{
struct pipe_state * p ;
2004-05-25 16:24:13 +00:00
uint32_t ret ;
2003-12-10 22:24:33 +00:00
if ( ipc - > num_open = = 0xFFFF ) {
return 0 ;
}
again :
ret = ipc - > next_fnum + + ;
for ( p = ipc - > pipe_list ; p ; p = p - > next ) {
if ( p - > fnum = = ret ) {
goto again ;
}
}
return ret ;
}
/*
shutdown a single pipe . Called on a close or disconnect
*/
static void pipe_shutdown ( struct ipc_private * private , struct pipe_state * p )
{
TALLOC_CTX * mem_ctx = private - > pipe_list - > mem_ctx ;
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_endpoint_disconnect ( private - > pipe_list - > dce_conn ) ;
2003-12-10 22:24:33 +00:00
DLIST_REMOVE ( private - > pipe_list , private - > pipe_list ) ;
talloc_destroy ( mem_ctx ) ;
}
/*
find a open pipe give a file descriptor
*/
2004-05-25 17:24:24 +00:00
static struct pipe_state * pipe_state_find ( struct ipc_private * private , uint16_t fnum )
2003-12-10 22:24:33 +00:00
{
struct pipe_state * p ;
for ( p = private - > pipe_list ; p ; p = p - > next ) {
if ( p - > fnum = = fnum ) {
return p ;
}
}
return NULL ;
}
2003-08-13 01:53:07 +00:00
/*
connect to a share - always works
*/
2004-06-28 08:39:00 +00:00
static NTSTATUS ipc_connect ( struct smbsrv_request * req , const char * sharename )
2003-08-13 01:53:07 +00:00
{
2004-06-28 08:27:36 +00:00
struct smbsrv_tcon * tcon = req - > tcon ;
2003-12-10 22:24:33 +00:00
struct ipc_private * private ;
2003-08-13 01:53:07 +00:00
2004-06-28 08:27:36 +00:00
tcon - > fs_type = talloc_strdup ( tcon - > mem_ctx , " IPC " ) ;
tcon - > dev_type = talloc_strdup ( tcon - > mem_ctx , " IPC " ) ;
2003-08-13 01:53:07 +00:00
2003-12-10 22:24:33 +00:00
/* prepare the private state for this connection */
2004-06-28 08:27:36 +00:00
private = talloc ( tcon - > mem_ctx , sizeof ( struct ipc_private ) ) ;
2003-12-10 22:24:33 +00:00
if ( ! private ) {
return NT_STATUS_NO_MEMORY ;
}
2004-06-28 08:27:36 +00:00
tcon - > ntvfs_private = ( void * ) private ;
2003-12-10 22:24:33 +00:00
private - > pipe_list = NULL ;
private - > next_fnum = 1 ;
private - > num_open = 0 ;
2003-08-13 01:53:07 +00:00
return NT_STATUS_OK ;
}
/*
disconnect from a share
*/
2004-06-28 08:27:36 +00:00
static NTSTATUS ipc_disconnect ( struct smbsrv_tcon * tcon )
2003-08-13 01:53:07 +00:00
{
2003-12-10 22:24:33 +00:00
struct ipc_private * private = tcon - > ntvfs_private ;
/* close any pipes that are open. Discard any unread data */
while ( private - > pipe_list ) {
pipe_shutdown ( private , private - > pipe_list ) ;
}
2003-08-13 01:53:07 +00:00
return NT_STATUS_OK ;
}
/*
delete a file
*/
2004-06-28 08:39:00 +00:00
static NTSTATUS ipc_unlink ( struct smbsrv_request * req , struct smb_unlink * unl )
2003-08-13 01:53:07 +00:00
{
return NT_STATUS_ACCESS_DENIED ;
}
/*
ioctl interface - we don ' t do any
*/
2004-06-28 08:39:00 +00:00
static NTSTATUS ipc_ioctl ( struct smbsrv_request * req , union smb_ioctl * io )
2003-08-13 01:53:07 +00:00
{
return NT_STATUS_ACCESS_DENIED ;
}
/*
check if a directory exists
*/
2004-06-28 08:39:00 +00:00
static NTSTATUS ipc_chkpath ( struct smbsrv_request * req , struct smb_chkpath * cp )
2003-08-13 01:53:07 +00:00
{
return NT_STATUS_ACCESS_DENIED ;
}
/*
return info on a pathname
*/
2004-06-28 08:39:00 +00:00
static NTSTATUS ipc_qpathinfo ( struct smbsrv_request * req , union smb_fileinfo * info )
2003-08-13 01:53:07 +00:00
{
return NT_STATUS_ACCESS_DENIED ;
}
/*
set info on a pathname
*/
2004-06-28 08:39:00 +00:00
static NTSTATUS ipc_setpathinfo ( struct smbsrv_request * req , union smb_setfileinfo * st )
2003-08-13 01:53:07 +00:00
{
return NT_STATUS_ACCESS_DENIED ;
}
2003-12-16 09:02:58 +00:00
2003-08-13 01:53:07 +00:00
/*
2003-12-16 09:02:58 +00:00
open a file backend - used for MSRPC pipes
2003-08-13 01:53:07 +00:00
*/
2004-06-28 08:39:00 +00:00
static NTSTATUS ipc_open_generic ( struct smbsrv_request * req , const char * fname ,
2003-12-16 09:02:58 +00:00
struct pipe_state * * ps )
2003-08-13 01:53:07 +00:00
{
2003-12-10 22:24:33 +00:00
struct pipe_state * p ;
TALLOC_CTX * mem_ctx ;
NTSTATUS status ;
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
struct dcesrv_ep_description ep_description ;
2004-06-07 21:34:32 +00:00
struct auth_session_info * session_info = NULL ;
2004-06-28 08:27:36 +00:00
struct ipc_private * private = req - > tcon - > ntvfs_private ;
2003-12-10 22:24:33 +00:00
2003-12-16 09:02:58 +00:00
mem_ctx = talloc_init ( " ipc_open '%s' " , fname ) ;
2003-12-10 22:24:33 +00:00
if ( ! mem_ctx ) {
return NT_STATUS_NO_MEMORY ;
}
p = talloc ( mem_ctx , sizeof ( struct pipe_state ) ) ;
if ( ! p ) {
talloc_destroy ( mem_ctx ) ;
return NT_STATUS_NO_MEMORY ;
}
p - > mem_ctx = mem_ctx ;
2003-12-16 09:02:58 +00:00
p - > pipe_name = talloc_strdup ( mem_ctx , fname ) ;
2003-12-10 22:24:33 +00:00
if ( ! p - > pipe_name ) {
talloc_destroy ( mem_ctx ) ;
return NT_STATUS_NO_MEMORY ;
}
p - > fnum = find_next_fnum ( private ) ;
if ( p - > fnum = = 0 ) {
talloc_destroy ( mem_ctx ) ;
return NT_STATUS_TOO_MANY_OPENED_FILES ;
}
2003-12-11 09:07:45 +00:00
while ( p - > pipe_name [ 0 ] = = ' \\ ' ) {
p - > pipe_name + + ;
2003-12-10 22:24:33 +00:00
}
2003-12-13 04:46:50 +00:00
p - > ipc_state = 0x5ff ;
2003-12-10 22:24:33 +00:00
/*
we ' re all set , now ask the dcerpc server subsystem to open the
endpoint . At this stage the pipe isn ' t bound , so we don ' t
know what interface the user actually wants , just that they want
one of the interfaces attached to this pipe endpoint .
TODO : note that we aren ' t passing any credentials here . We
will need to do that once the credentials infrastructure is
finalised for Samba4
*/
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
ep_description . type = ENDPOINT_SMB ;
ep_description . info . smb_pipe = p - > pipe_name ;
2003-12-10 22:24:33 +00:00
2004-06-07 21:34:32 +00:00
/* tell the RPC layer the session_info */
if ( req - > user_ctx - > vuser ) {
/*
* TODO : we need to reference count the entire session_info
*/
session_info = req - > user_ctx - > vuser - > session_info ;
}
2004-06-29 07:40:14 +00:00
status = dcesrv_endpoint_search_connect ( & req - > smb_conn - > dcesrv ,
2004-06-07 21:34:32 +00:00
& ep_description ,
session_info ,
& p - > dce_conn ) ;
2003-12-10 22:24:33 +00:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
talloc_destroy ( mem_ctx ) ;
return status ;
}
private - > num_open + + ;
DLIST_ADD ( private - > pipe_list , p ) ;
2003-12-16 09:02:58 +00:00
* ps = p ;
return NT_STATUS_OK ;
}
/*
open a file with ntcreatex - used for MSRPC pipes
*/
2004-06-28 08:39:00 +00:00
static NTSTATUS ipc_open_ntcreatex ( struct smbsrv_request * req , union smb_open * oi )
2003-12-16 09:02:58 +00:00
{
struct pipe_state * p ;
NTSTATUS status ;
status = ipc_open_generic ( req , oi - > ntcreatex . in . fname , & p ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
return status ;
}
2003-12-10 22:24:33 +00:00
ZERO_STRUCT ( oi - > ntcreatex . out ) ;
oi - > ntcreatex . out . fnum = p - > fnum ;
2003-12-13 04:46:50 +00:00
oi - > ntcreatex . out . ipc_state = p - > ipc_state ;
2003-12-10 22:24:33 +00:00
2003-12-16 09:02:58 +00:00
return status ;
}
/*
open a file with openx - used for MSRPC pipes
*/
2004-06-28 08:39:00 +00:00
static NTSTATUS ipc_open_openx ( struct smbsrv_request * req , union smb_open * oi )
2003-12-16 09:02:58 +00:00
{
struct pipe_state * p ;
NTSTATUS status ;
const char * fname = oi - > openx . in . fname ;
if ( strncasecmp ( fname , " PIPE \\ " , 5 ) ! = 0 ) {
return NT_STATUS_OBJECT_NAME_NOT_FOUND ;
}
fname + = 4 ;
status = ipc_open_generic ( req , fname , & p ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
return status ;
}
ZERO_STRUCT ( oi - > openx . out ) ;
oi - > openx . out . fnum = p - > fnum ;
oi - > openx . out . ftype = 2 ;
oi - > openx . out . devstate = p - > ipc_state ;
return status ;
}
/*
open a file - used for MSRPC pipes
*/
2004-06-28 08:39:00 +00:00
static NTSTATUS ipc_open ( struct smbsrv_request * req , union smb_open * oi )
2003-12-16 09:02:58 +00:00
{
NTSTATUS status ;
switch ( oi - > generic . level ) {
case RAW_OPEN_NTCREATEX :
status = ipc_open_ntcreatex ( req , oi ) ;
break ;
case RAW_OPEN_OPENX :
status = ipc_open_openx ( req , oi ) ;
break ;
default :
status = NT_STATUS_NOT_SUPPORTED ;
break ;
}
return status ;
2003-08-13 01:53:07 +00:00
}
/*
create a directory
*/
2004-06-28 08:39:00 +00:00
static NTSTATUS ipc_mkdir ( struct smbsrv_request * req , union smb_mkdir * md )
2003-08-13 01:53:07 +00:00
{
return NT_STATUS_ACCESS_DENIED ;
}
/*
remove a directory
*/
2004-06-28 08:39:00 +00:00
static NTSTATUS ipc_rmdir ( struct smbsrv_request * req , struct smb_rmdir * rd )
2003-08-13 01:53:07 +00:00
{
return NT_STATUS_ACCESS_DENIED ;
}
/*
rename a set of files
*/
2004-06-28 08:39:00 +00:00
static NTSTATUS ipc_rename ( struct smbsrv_request * req , union smb_rename * ren )
2003-08-13 01:53:07 +00:00
{
return NT_STATUS_ACCESS_DENIED ;
}
/*
copy a set of files
*/
2004-06-28 08:39:00 +00:00
static NTSTATUS ipc_copy ( struct smbsrv_request * req , struct smb_copy * cp )
2003-08-13 01:53:07 +00:00
{
return NT_STATUS_ACCESS_DENIED ;
}
/*
read from a file
*/
2004-06-28 08:39:00 +00:00
static NTSTATUS ipc_read ( struct smbsrv_request * req , union smb_read * rd )
2003-08-13 01:53:07 +00:00
{
2004-06-28 08:27:36 +00:00
struct ipc_private * private = req - > tcon - > ntvfs_private ;
2003-12-11 09:07:45 +00:00
DATA_BLOB data ;
2004-05-25 17:24:24 +00:00
uint16_t fnum ;
2003-12-11 09:07:45 +00:00
struct pipe_state * p ;
NTSTATUS status ;
switch ( rd - > generic . level ) {
case RAW_READ_READ :
fnum = rd - > read . in . fnum ;
data . length = rd - > read . in . count ;
data . data = rd - > read . out . data ;
break ;
case RAW_READ_READX :
fnum = rd - > readx . in . fnum ;
data . length = rd - > readx . in . maxcnt ;
data . data = rd - > readx . out . data ;
break ;
default :
return NT_STATUS_NOT_SUPPORTED ;
}
p = pipe_state_find ( private , fnum ) ;
if ( ! p ) {
return NT_STATUS_INVALID_HANDLE ;
}
2004-01-20 05:54:17 +00:00
status = dcesrv_output_blob ( p - > dce_conn , & data ) ;
2004-06-16 06:49:24 +00:00
if ( NT_STATUS_IS_ERR ( status ) ) {
2003-12-11 09:07:45 +00:00
return status ;
}
switch ( rd - > generic . level ) {
case RAW_READ_READ :
rd - > read . out . nread = data . length ;
break ;
case RAW_READ_READX :
rd - > readx . out . remaining = 0 ;
rd - > readx . out . compaction_mode = 0 ;
rd - > readx . out . nread = data . length ;
break ;
default :
return NT_STATUS_NOT_SUPPORTED ;
}
2004-06-16 06:49:24 +00:00
return status ;
2003-08-13 01:53:07 +00:00
}
/*
write to a file
*/
2004-06-28 08:39:00 +00:00
static NTSTATUS ipc_write ( struct smbsrv_request * req , union smb_write * wr )
2003-08-13 01:53:07 +00:00
{
2004-06-28 08:27:36 +00:00
struct ipc_private * private = req - > tcon - > ntvfs_private ;
2003-12-11 09:07:45 +00:00
DATA_BLOB data ;
2004-05-25 17:24:24 +00:00
uint16_t fnum ;
2003-12-11 09:07:45 +00:00
struct pipe_state * p ;
NTSTATUS status ;
switch ( wr - > generic . level ) {
case RAW_WRITE_WRITE :
fnum = wr - > write . in . fnum ;
data . data = wr - > write . in . data ;
data . length = wr - > write . in . count ;
break ;
case RAW_WRITE_WRITEX :
fnum = wr - > writex . in . fnum ;
data . data = wr - > writex . in . data ;
data . length = wr - > writex . in . count ;
break ;
default :
return NT_STATUS_NOT_SUPPORTED ;
}
p = pipe_state_find ( private , fnum ) ;
if ( ! p ) {
return NT_STATUS_INVALID_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
status = dcesrv_input ( p - > dce_conn , & data ) ;
2003-12-11 09:07:45 +00:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
return status ;
}
switch ( wr - > generic . level ) {
case RAW_WRITE_WRITE :
wr - > write . out . nwritten = data . length ;
break ;
case RAW_WRITE_WRITEX :
wr - > writex . out . nwritten = data . length ;
wr - > writex . out . remaining = 0 ;
break ;
default :
return NT_STATUS_NOT_SUPPORTED ;
}
return NT_STATUS_OK ;
2003-08-13 01:53:07 +00:00
}
/*
seek in a file
*/
2004-06-28 08:39:00 +00:00
static NTSTATUS ipc_seek ( struct smbsrv_request * req , struct smb_seek * io )
2003-08-13 01:53:07 +00:00
{
return NT_STATUS_ACCESS_DENIED ;
}
/*
flush a file
*/
2004-06-28 08:39:00 +00:00
static NTSTATUS ipc_flush ( struct smbsrv_request * req , struct smb_flush * io )
2003-08-13 01:53:07 +00:00
{
return NT_STATUS_ACCESS_DENIED ;
}
/*
close a file
*/
2004-06-28 08:39:00 +00:00
static NTSTATUS ipc_close ( struct smbsrv_request * req , union smb_close * io )
2003-08-13 01:53:07 +00:00
{
2004-06-28 08:27:36 +00:00
struct ipc_private * private = req - > tcon - > ntvfs_private ;
2003-12-10 22:24:33 +00:00
struct pipe_state * p ;
if ( io - > generic . level ! = RAW_CLOSE_CLOSE ) {
return NT_STATUS_ACCESS_DENIED ;
}
p = pipe_state_find ( private , io - > close . in . fnum ) ;
if ( ! p ) {
return NT_STATUS_INVALID_HANDLE ;
}
pipe_shutdown ( private , p ) ;
private - > num_open - - ;
return NT_STATUS_OK ;
2003-08-13 01:53:07 +00:00
}
/*
exit - closing files ?
*/
2004-06-28 08:39:00 +00:00
static NTSTATUS ipc_exit ( struct smbsrv_request * req )
2003-08-13 01:53:07 +00:00
{
return NT_STATUS_ACCESS_DENIED ;
}
/*
lock a byte range
*/
2004-06-28 08:39:00 +00:00
static NTSTATUS ipc_lock ( struct smbsrv_request * req , union smb_lock * lck )
2003-08-13 01:53:07 +00:00
{
return NT_STATUS_ACCESS_DENIED ;
}
/*
set info on a open file
*/
2004-06-28 08:39:00 +00:00
static NTSTATUS ipc_setfileinfo ( struct smbsrv_request * req , union smb_setfileinfo * info )
2003-08-13 01:53:07 +00:00
{
return NT_STATUS_ACCESS_DENIED ;
}
/*
query info on a open file
*/
2004-06-28 08:39:00 +00:00
static NTSTATUS ipc_qfileinfo ( struct smbsrv_request * req , union smb_fileinfo * info )
2003-08-13 01:53:07 +00:00
{
return NT_STATUS_ACCESS_DENIED ;
}
/*
return filesystem info
*/
2004-06-28 08:39:00 +00:00
static NTSTATUS ipc_fsinfo ( struct smbsrv_request * req , union smb_fsinfo * fs )
2003-08-13 01:53:07 +00:00
{
return NT_STATUS_ACCESS_DENIED ;
}
/*
return print queue info
*/
2004-06-28 08:39:00 +00:00
static NTSTATUS ipc_lpq ( struct smbsrv_request * req , union smb_lpq * lpq )
2003-08-13 01:53:07 +00:00
{
return NT_STATUS_ACCESS_DENIED ;
}
/*
list files in a directory matching a wildcard pattern
*/
2004-06-28 08:39:00 +00:00
NTSTATUS ipc_search_first ( struct smbsrv_request * req , union smb_search_first * io ,
2003-08-13 01:53:07 +00:00
void * search_private ,
BOOL ( * callback ) ( void * , union smb_search_data * ) )
{
return NT_STATUS_ACCESS_DENIED ;
}
/*
continue listing files in a directory
*/
2004-06-28 08:39:00 +00:00
NTSTATUS ipc_search_next ( struct smbsrv_request * req , union smb_search_next * io ,
2003-08-13 01:53:07 +00:00
void * search_private ,
BOOL ( * callback ) ( void * , union smb_search_data * ) )
{
return NT_STATUS_ACCESS_DENIED ;
}
/*
end listing files in a directory
*/
2004-06-28 08:39:00 +00:00
NTSTATUS ipc_search_close ( struct smbsrv_request * req , union smb_search_close * io )
2003-08-13 01:53:07 +00:00
{
return NT_STATUS_ACCESS_DENIED ;
}
2003-12-13 04:46:50 +00:00
/* SMBtrans - handle a DCERPC command */
2004-06-28 08:39:00 +00:00
static NTSTATUS ipc_dcerpc_cmd ( struct smbsrv_request * req , struct smb_trans2 * trans )
2003-12-11 09:07:45 +00:00
{
struct pipe_state * p ;
2004-06-28 08:27:36 +00:00
struct ipc_private * private = req - > tcon - > ntvfs_private ;
2003-12-11 09:07:45 +00:00
NTSTATUS status ;
/* the fnum is in setup[1] */
p = pipe_state_find ( private , trans - > in . setup [ 1 ] ) ;
if ( ! p ) {
return NT_STATUS_INVALID_HANDLE ;
}
2003-12-12 03:59:09 +00:00
trans - > out . data = data_blob_talloc ( req - > mem_ctx , NULL , trans - > in . max_data ) ;
if ( ! trans - > out . data . data ) {
return NT_STATUS_NO_MEMORY ;
}
2003-12-11 09:07:45 +00:00
/* pass the data to the dcerpc server. Note that we don't
expect this to fail , and things like NDR faults are not
reported at this stage . Those sorts of errors happen in the
dcesrv_output stage */
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
status = dcesrv_input ( p - > dce_conn , & trans - > in . data ) ;
2003-12-11 09:07:45 +00:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
return status ;
}
/*
now ask the dcerpc system for some output . This doesn ' t yet handle
async calls . Again , we only expect NT_STATUS_OK . If the call fails then
the error is encoded at the dcerpc level
*/
2004-01-20 05:54:17 +00:00
status = dcesrv_output_blob ( p - > dce_conn , & trans - > out . data ) ;
2004-06-16 06:49:24 +00:00
if ( NT_STATUS_IS_ERR ( status ) ) {
2003-12-11 09:07:45 +00:00
return status ;
}
trans - > out . setup_count = 0 ;
trans - > out . setup = NULL ;
trans - > out . params = data_blob ( NULL , 0 ) ;
2004-06-16 06:49:24 +00:00
return status ;
2003-12-11 09:07:45 +00:00
}
2003-12-13 04:46:50 +00:00
/* SMBtrans - set named pipe state */
2004-06-28 08:39:00 +00:00
static NTSTATUS ipc_set_nm_pipe_state ( struct smbsrv_request * req , struct smb_trans2 * trans )
2003-12-13 04:46:50 +00:00
{
struct pipe_state * p ;
2004-06-28 08:27:36 +00:00
struct ipc_private * private = req - > tcon - > ntvfs_private ;
2003-12-13 04:46:50 +00:00
/* the fnum is in setup[1] */
p = pipe_state_find ( private , trans - > in . setup [ 1 ] ) ;
if ( ! p ) {
return NT_STATUS_INVALID_HANDLE ;
}
if ( trans - > in . params . length ! = 2 ) {
return NT_STATUS_INVALID_PARAMETER ;
}
p - > ipc_state = SVAL ( trans - > in . params . data , 0 ) ;
trans - > out . setup_count = 0 ;
trans - > out . setup = NULL ;
trans - > out . params = data_blob ( NULL , 0 ) ;
trans - > out . data = data_blob ( NULL , 0 ) ;
return NT_STATUS_OK ;
}
/* SMBtrans - used to provide access to SMB pipes */
2004-06-28 08:39:00 +00:00
static NTSTATUS ipc_trans ( struct smbsrv_request * req , struct smb_trans2 * trans )
2003-12-13 04:46:50 +00:00
{
NTSTATUS status ;
if ( trans - > in . setup_count ! = 2 ) {
return NT_STATUS_INVALID_PARAMETER ;
}
switch ( trans - > in . setup [ 0 ] ) {
case TRANSACT_SETNAMEDPIPEHANDLESTATE :
status = ipc_set_nm_pipe_state ( req , trans ) ;
break ;
case TRANSACT_DCERPCCMD :
status = ipc_dcerpc_cmd ( req , trans ) ;
break ;
default :
status = NT_STATUS_INVALID_PARAMETER ;
break ;
}
return status ;
}
2003-12-11 09:07:45 +00:00
2003-08-13 01:53:07 +00:00
/*
initialialise the IPC backend , registering ourselves with the ntvfs subsystem
*/
2003-11-25 03:15:26 +00:00
NTSTATUS ntvfs_ipc_init ( void )
2003-08-13 01:53:07 +00:00
{
2003-11-25 03:15:26 +00:00
NTSTATUS ret ;
2003-08-13 01:53:07 +00:00
struct ntvfs_ops ops ;
ZERO_STRUCT ( ops ) ;
2004-02-02 13:28:29 +00:00
/* fill in the name and type */
ops . name = " default " ;
2003-11-25 03:15:26 +00:00
ops . type = NTVFS_IPC ;
2004-02-02 13:28:29 +00:00
/* fill in all the operations */
2003-08-13 01:53:07 +00:00
ops . connect = ipc_connect ;
ops . disconnect = ipc_disconnect ;
ops . unlink = ipc_unlink ;
ops . chkpath = ipc_chkpath ;
ops . qpathinfo = ipc_qpathinfo ;
ops . setpathinfo = ipc_setpathinfo ;
ops . open = ipc_open ;
ops . mkdir = ipc_mkdir ;
ops . rmdir = ipc_rmdir ;
ops . rename = ipc_rename ;
ops . copy = ipc_copy ;
ops . ioctl = ipc_ioctl ;
ops . read = ipc_read ;
ops . write = ipc_write ;
ops . seek = ipc_seek ;
ops . flush = ipc_flush ;
ops . close = ipc_close ;
ops . exit = ipc_exit ;
ops . lock = ipc_lock ;
ops . setfileinfo = ipc_setfileinfo ;
ops . qfileinfo = ipc_qfileinfo ;
ops . fsinfo = ipc_fsinfo ;
ops . lpq = ipc_lpq ;
ops . search_first = ipc_search_first ;
ops . search_next = ipc_search_next ;
ops . search_close = ipc_search_close ;
2003-12-11 09:07:45 +00:00
ops . trans = ipc_trans ;
2003-08-13 01:53:07 +00:00
/* register ourselves with the NTVFS subsystem. */
2003-11-25 03:15:26 +00:00
ret = register_backend ( " ntvfs " , & ops ) ;
2003-08-13 01:53:07 +00:00
2003-11-25 03:15:26 +00:00
if ( ! NT_STATUS_IS_OK ( ret ) ) {
2003-08-13 01:53:07 +00:00
DEBUG ( 0 , ( " Failed to register IPC backend! \n " ) ) ;
2003-11-25 03:15:26 +00:00
return ret ;
2003-08-13 01:53:07 +00:00
}
2003-11-25 03:15:26 +00:00
return ret ;
2003-08-13 01:53:07 +00:00
}