1
0
mirror of https://github.com/samba-team/samba.git synced 2025-01-12 09:18:10 +03:00

s3:rpc_server: pass down local and remote tsocket_address to np_open()

metze
This commit is contained in:
Stefan Metzmacher 2010-04-27 15:12:32 +02:00
parent 56ebbb53c8
commit 9a6636a56e
3 changed files with 22 additions and 3 deletions

View File

@ -5205,8 +5205,10 @@ pipes_struct *get_first_internal_pipe(void);
pipes_struct *get_next_internal_pipe(pipes_struct *p); pipes_struct *get_next_internal_pipe(pipes_struct *p);
bool fsp_is_np(struct files_struct *fsp); bool fsp_is_np(struct files_struct *fsp);
struct tsocket_address;
NTSTATUS np_open(TALLOC_CTX *mem_ctx, const char *name, NTSTATUS np_open(TALLOC_CTX *mem_ctx, const char *name,
const char *client_address, const struct tsocket_address *local_address,
const struct tsocket_address *remote_address,
struct auth_serversupplied_info *server_info, struct auth_serversupplied_info *server_info,
struct fake_file_handle **phandle); struct fake_file_handle **phandle);
bool np_read_in_progress(struct fake_file_handle *handle); bool np_read_in_progress(struct fake_file_handle *handle);

View File

@ -1132,7 +1132,8 @@ static struct np_proxy_state *make_external_rpc_pipe_p(TALLOC_CTX *mem_ctx,
} }
NTSTATUS np_open(TALLOC_CTX *mem_ctx, const char *name, NTSTATUS np_open(TALLOC_CTX *mem_ctx, const char *name,
const char *client_address, const struct tsocket_address *local_address,
const struct tsocket_address *remote_address,
struct auth_serversupplied_info *server_info, struct auth_serversupplied_info *server_info,
struct fake_file_handle **phandle) struct fake_file_handle **phandle)
{ {
@ -1156,12 +1157,25 @@ NTSTATUS np_open(TALLOC_CTX *mem_ctx, const char *name,
} else { } else {
struct pipes_struct *p; struct pipes_struct *p;
struct ndr_syntax_id syntax; struct ndr_syntax_id syntax;
const char *client_address;
if (!is_known_pipename(name, &syntax)) { if (!is_known_pipename(name, &syntax)) {
TALLOC_FREE(handle); TALLOC_FREE(handle);
return NT_STATUS_OBJECT_NAME_NOT_FOUND; return NT_STATUS_OBJECT_NAME_NOT_FOUND;
} }
if (tsocket_address_is_inet(remote_address, "ip")) {
client_address = tsocket_address_inet_addr_string(
remote_address,
talloc_tos());
if (client_address == NULL) {
TALLOC_FREE(handle);
return NT_STATUS_NO_MEMORY;
}
} else {
client_address = "";
}
p = make_internal_rpc_pipe_p(handle, &syntax, client_address, p = make_internal_rpc_pipe_p(handle, &syntax, client_address,
server_info); server_info);

View File

@ -26,6 +26,7 @@
#include "includes.h" #include "includes.h"
#include "smbd/globals.h"
#define PIPE "\\PIPE\\" #define PIPE "\\PIPE\\"
#define PIPELEN strlen(PIPE) #define PIPELEN strlen(PIPE)
@ -65,7 +66,9 @@ NTSTATUS open_np_file(struct smb_request *smb_req, const char *name,
return status; return status;
} }
status = np_open(fsp, name, conn->client_address, status = np_open(fsp, name,
conn->sconn->local_address,
conn->sconn->remote_address,
conn->server_info, &fsp->fake_file_handle); conn->server_info, &fsp->fake_file_handle);
if (!NT_STATUS_IS_OK(status)) { if (!NT_STATUS_IS_OK(status)) {
DEBUG(10, ("np_open(%s) returned %s\n", name, DEBUG(10, ("np_open(%s) returned %s\n", name,