From 33206b1e240e55acedad606aed4f1952f7496b35 Mon Sep 17 00:00:00 2001 From: Andreas Schneider Date: Tue, 10 Jan 2012 16:38:16 +0100 Subject: [PATCH] s3-rpc_client: Fix updating netlogon credentials. MIME-Version: 1.0 Content-Type: text/plain; charset=utf8 Content-Transfer-Encoding: 8bit Signed-off-by: Günther Deschner --- source3/rpc_client/cli_pipe.c | 15 +++++++-------- 1 file changed, 7 insertions(+), 8 deletions(-) diff --git a/source3/rpc_client/cli_pipe.c b/source3/rpc_client/cli_pipe.c index 38f0d7aa1ac..8b9e513b000 100644 --- a/source3/rpc_client/cli_pipe.c +++ b/source3/rpc_client/cli_pipe.c @@ -1800,9 +1800,6 @@ static void rpc_pipe_bind_step_two_done(struct tevent_req *subreq) struct rpc_pipe_bind_state *state = tevent_req_data(req, struct rpc_pipe_bind_state); - struct schannel_state *schannel_auth = - talloc_get_type_abort(state->cli->auth->auth_ctx, - struct schannel_state); NTSTATUS status; status = dcerpc_netr_LogonGetCapabilities_r_recv(subreq, talloc_tos()); @@ -1860,8 +1857,8 @@ static void rpc_pipe_bind_step_two_done(struct tevent_req *subreq) return; } - TALLOC_FREE(schannel_auth->creds); - schannel_auth->creds = talloc_steal(state->cli, state->creds); + TALLOC_FREE(state->cli->dc); + state->cli->dc = talloc_steal(state->cli, state->creds); if (!NT_STATUS_IS_OK(state->r.out.result)) { DEBUG(0, ("dcerpc_netr_LogonGetCapabilities_r_recv failed with %s\n", @@ -3016,10 +3013,12 @@ NTSTATUS cli_rpc_pipe_open_schannel_with_key(struct cli_state *cli, * The credentials on a new netlogon pipe are the ones we are passed * in - copy them over */ - result->dc = netlogon_creds_copy(result, *pdc); if (result->dc == NULL) { - TALLOC_FREE(result); - return NT_STATUS_NO_MEMORY; + result->dc = netlogon_creds_copy(result, *pdc); + if (result->dc == NULL) { + TALLOC_FREE(result); + return NT_STATUS_NO_MEMORY; + } } DEBUG(10,("cli_rpc_pipe_open_schannel_with_key: opened pipe %s to machine %s " -- 2.34.1