From 0e8e05d556a7f84e500cca3fa858f9b4a9522a5f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?G=C3=BCnther=20Deschner?= Date: Tue, 29 Apr 2008 20:11:02 +0200 Subject: [PATCH] netapi: fix returned name buffer in NetGetJoinInformation_r(). Guenther --- source/lib/netapi/joindomain.c | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/source/lib/netapi/joindomain.c b/source/lib/netapi/joindomain.c index 8e0a62e820b..74ed8f2302f 100644 --- a/source/lib/netapi/joindomain.c +++ b/source/lib/netapi/joindomain.c @@ -282,6 +282,7 @@ WERROR NetGetJoinInformation_r(struct libnetapi_ctx *ctx, struct rpc_pipe_client *pipe_cli = NULL; NTSTATUS status; WERROR werr; + const char *buffer = NULL; werr = libnetapi_open_ipc_connection(ctx, r->in.server_name, &cli); if (!W_ERROR_IS_OK(werr)) { @@ -295,7 +296,7 @@ WERROR NetGetJoinInformation_r(struct libnetapi_ctx *ctx, status = rpccli_wkssvc_NetrGetJoinInformation(pipe_cli, ctx, r->in.server_name, - r->out.name_buffer, + &buffer, (enum wkssvc_NetJoinStatus *)r->out.name_type, &werr); if (!NT_STATUS_IS_OK(status)) { @@ -303,6 +304,9 @@ WERROR NetGetJoinInformation_r(struct libnetapi_ctx *ctx, goto done; } + *r->out.name_buffer = talloc_strdup(ctx, buffer); + W_ERROR_HAVE_NO_MEMORY(*r->out.name_buffer); + done: return werr; }