X-Git-Url: http://git.samba.org/?p=samba.git;a=blobdiff_plain;f=auth%2Fntlmssp%2Fntlmssp_server.c;fp=auth%2Fntlmssp%2Fntlmssp_server.c;h=001238278d7ff66b58b9a373c7750f35dd2b9dae;hp=29559b3fe02e112cef2febe0175c8e70bfb70f2b;hb=7f75dec865256049e99f7fcf46317cd2d53e95d1;hpb=add8fd21c08f1225191b0794a92206f5c9248d23 diff --git a/auth/ntlmssp/ntlmssp_server.c b/auth/ntlmssp/ntlmssp_server.c index 29559b3fe02..001238278d7 100644 --- a/auth/ntlmssp/ntlmssp_server.c +++ b/auth/ntlmssp/ntlmssp_server.c @@ -335,8 +335,8 @@ struct tevent_req *ntlmssp_server_auth_send(TALLOC_CTX *mem_ctx, struct gensec_ntlmssp_context); struct auth4_context *auth_context = gensec_security->auth_context; struct tevent_req *req = NULL; + struct tevent_req *subreq = NULL; struct ntlmssp_server_auth_state *state = NULL; - uint8_t authoritative = 0; NTSTATUS status; req = tevent_req_create(mem_ctx, &state, @@ -355,54 +355,13 @@ struct tevent_req *ntlmssp_server_auth_send(TALLOC_CTX *mem_ctx, return tevent_req_post(req, ev); } - if (auth_context->check_ntlm_password_send != NULL) { - struct tevent_req *subreq = NULL; - - subreq = auth_context->check_ntlm_password_send(state, ev, - auth_context, - state->user_info); - if (tevent_req_nomem(subreq, req)) { - return tevent_req_post(req, ev); - } - tevent_req_set_callback(subreq, - ntlmssp_server_auth_done, - req); - return req; - } - - if (auth_context->check_ntlm_password == NULL) { - tevent_req_nterror(req, NT_STATUS_INTERNAL_ERROR); + subreq = auth_context->check_ntlm_password_send( + state, ev, auth_context, state->user_info); + if (tevent_req_nomem(subreq, req)) { return tevent_req_post(req, ev); } - - status = auth_context->check_ntlm_password(auth_context, - gensec_ntlmssp, - state->user_info, - &authoritative, - &gensec_ntlmssp->server_returned_info, - &state->user_session_key, - &state->lm_session_key); - if (!NT_STATUS_IS_OK(status)) { - DBG_INFO("Checking NTLMSSP password for %s\\%s failed: %s\n", - state->user_info->client.domain_name, - state->user_info->client.account_name, - nt_errstr(status)); - } - if (tevent_req_nterror(req, status)) { - return tevent_req_post(req, ev); - } - talloc_steal(state, state->user_session_key.data); - talloc_steal(state, state->lm_session_key.data); - - status = ntlmssp_server_postauth(gensec_security, - gensec_ntlmssp, - state, in); - if (tevent_req_nterror(req, status)) { - return tevent_req_post(req, ev); - } - - tevent_req_done(req); - return tevent_req_post(req, ev); + tevent_req_set_callback(subreq, ntlmssp_server_auth_done, req); + return req; } /**