mirror of
https://github.com/samba-team/samba.git
synced 2024-12-24 21:34:56 +03:00
acd6a086b3
dcerpc_interface_table struct rather then a tuple of interface
name, UUID and version.
This removes the requirement for having a global list of DCE/RPC interfaces,
except for these parts of the code that use that list explicitly
(ndrdump and the scanner torture test).
This should also allow us to remove the hack that put the authservice parameter
in the dcerpc_binding struct as it can now be read directly from
dcerpc_interface_table.
I will now modify some of these functions to take a dcerpc_syntax_id
structure rather then a full dcerpc_interface_table.
(This used to be commit 8aae0f168e
)
138 lines
3.8 KiB
C
138 lines
3.8 KiB
C
/*
|
|
Unix SMB/CIFS implementation.
|
|
|
|
Copyright (C) Stefan Metzmacher 2004
|
|
Copyright (C) Rafal Szczesniak 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
|
|
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 02139, USA.
|
|
*/
|
|
|
|
#include "includes.h"
|
|
#include "libnet/libnet.h"
|
|
|
|
|
|
/**
|
|
* Connects rpc pipe on remote server
|
|
*
|
|
* @param ctx initialised libnet context
|
|
* @param mem_ctx memory context of this call
|
|
* @param r data structure containing necessary parameters and return values
|
|
* @return nt status of the call
|
|
**/
|
|
|
|
static NTSTATUS libnet_RpcConnectSrv(struct libnet_context *ctx, TALLOC_CTX *mem_ctx, struct libnet_RpcConnect *r)
|
|
{
|
|
NTSTATUS status;
|
|
const char *binding = NULL;
|
|
|
|
/* prepare binding string */
|
|
switch (r->level) {
|
|
case LIBNET_RPC_CONNECT_PDC:
|
|
case LIBNET_RPC_CONNECT_SERVER:
|
|
binding = talloc_asprintf(mem_ctx, "ncacn_np:%s", r->in.domain_name);
|
|
break;
|
|
|
|
case LIBNET_RPC_CONNECT_BINDING:
|
|
binding = r->in.binding;
|
|
break;
|
|
}
|
|
|
|
/* connect to remote dcerpc pipe */
|
|
status = dcerpc_pipe_connect(mem_ctx, &r->out.dcerpc_pipe,
|
|
binding, r->in.dcerpc_iface,
|
|
ctx->cred, ctx->event_ctx);
|
|
|
|
if (!NT_STATUS_IS_OK(status)) {
|
|
r->out.error_string = talloc_asprintf(mem_ctx,
|
|
"dcerpc_pipe_connect to pipe %s failed with %s\n",
|
|
r->in.dcerpc_iface->name, binding);
|
|
return status;
|
|
}
|
|
|
|
r->out.error_string = NULL;
|
|
ctx->pipe = r->out.dcerpc_pipe;
|
|
|
|
return status;
|
|
}
|
|
|
|
|
|
/**
|
|
* Connects rpc pipe on domain pdc
|
|
*
|
|
* @param ctx initialised libnet context
|
|
* @param mem_ctx memory context of this call
|
|
* @param r data structure containing necessary parameters and return values
|
|
* @return nt status of the call
|
|
**/
|
|
|
|
static NTSTATUS libnet_RpcConnectPdc(struct libnet_context *ctx, TALLOC_CTX *mem_ctx, struct libnet_RpcConnect *r)
|
|
{
|
|
NTSTATUS status;
|
|
struct libnet_RpcConnect r2;
|
|
struct libnet_Lookup f;
|
|
|
|
f.in.hostname = r->in.domain_name;
|
|
f.in.methods = NULL;
|
|
f.out.address = NULL;
|
|
|
|
/* find the domain pdc first */
|
|
status = libnet_LookupPdc(ctx, mem_ctx, &f);
|
|
if (!NT_STATUS_IS_OK(status)) {
|
|
r->out.error_string = talloc_asprintf(mem_ctx, "libnet_LookupPdc failed: %s",
|
|
nt_errstr(status));
|
|
return status;
|
|
}
|
|
|
|
/* ok, pdc has been found so do attempt to rpc connect */
|
|
r2.level = LIBNET_RPC_CONNECT_SERVER;
|
|
r2.in.domain_name = talloc_strdup(mem_ctx, f.out.address[0]);
|
|
r2.in.dcerpc_iface = r->in.dcerpc_iface;
|
|
|
|
status = libnet_RpcConnect(ctx, mem_ctx, &r2);
|
|
|
|
r->out.dcerpc_pipe = r2.out.dcerpc_pipe;
|
|
r->out.error_string = r2.out.error_string;
|
|
|
|
ctx->pipe = r->out.dcerpc_pipe;
|
|
|
|
return status;
|
|
}
|
|
|
|
|
|
/**
|
|
* Connects to rpc pipe on remote server or pdc
|
|
*
|
|
* @param ctx initialised libnet context
|
|
* @param mem_ctx memory context of this call
|
|
* @param r data structure containing necessary parameters and return values
|
|
* @return nt status of the call
|
|
**/
|
|
|
|
NTSTATUS libnet_RpcConnect(struct libnet_context *ctx, TALLOC_CTX *mem_ctx, struct libnet_RpcConnect *r)
|
|
{
|
|
switch (r->level) {
|
|
case LIBNET_RPC_CONNECT_SERVER:
|
|
return libnet_RpcConnectSrv(ctx, mem_ctx, r);
|
|
|
|
case LIBNET_RPC_CONNECT_BINDING:
|
|
return libnet_RpcConnectSrv(ctx, mem_ctx, r);
|
|
|
|
case LIBNET_RPC_CONNECT_PDC:
|
|
return libnet_RpcConnectPdc(ctx, mem_ctx, r);
|
|
}
|
|
|
|
return NT_STATUS_INVALID_LEVEL;
|
|
}
|