mirror of
https://github.com/samba-team/samba.git
synced 2025-01-08 21:18:16 +03:00
auth/ntlmssp: introduce ntlmssp_server_auth_send/recv
We still use the sync ntlmssp_server_check_password(). Signed-off-by: Stefan Metzmacher <metze@samba.org> Reviewed-by: Andreas Schneider <asn@samba.org>
This commit is contained in:
parent
da3baf64d5
commit
260e535252
@ -71,7 +71,8 @@ static const struct ntlmssp_callbacks {
|
|||||||
},{
|
},{
|
||||||
.role = NTLMSSP_SERVER,
|
.role = NTLMSSP_SERVER,
|
||||||
.command = NTLMSSP_AUTH,
|
.command = NTLMSSP_AUTH,
|
||||||
.sync_fn = gensec_ntlmssp_server_auth,
|
.send_fn = ntlmssp_server_auth_send,
|
||||||
|
.recv_fn = ntlmssp_server_auth_recv,
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -117,18 +117,14 @@ NTSTATUS gensec_ntlmssp_server_negotiate(struct gensec_security *gensec_security
|
|||||||
TALLOC_CTX *out_mem_ctx,
|
TALLOC_CTX *out_mem_ctx,
|
||||||
const DATA_BLOB request, DATA_BLOB *reply);
|
const DATA_BLOB request, DATA_BLOB *reply);
|
||||||
|
|
||||||
/**
|
struct tevent_req *ntlmssp_server_auth_send(TALLOC_CTX *mem_ctx,
|
||||||
* Next state function for the Authenticate packet (GENSEC wrapper)
|
struct tevent_context *ev,
|
||||||
*
|
struct gensec_security *gensec_security,
|
||||||
* @param gensec_security GENSEC state
|
const DATA_BLOB in);
|
||||||
* @param out_mem_ctx Memory context for *out
|
NTSTATUS ntlmssp_server_auth_recv(struct tevent_req *req,
|
||||||
* @param in The request, as a DATA_BLOB. reply.data must be NULL
|
TALLOC_CTX *out_mem_ctx,
|
||||||
* @param out The reply, as an allocated DATA_BLOB, caller to free.
|
DATA_BLOB *out);
|
||||||
* @return Errors or NT_STATUS_OK if authentication sucessful
|
|
||||||
*/
|
|
||||||
NTSTATUS gensec_ntlmssp_server_auth(struct gensec_security *gensec_security,
|
|
||||||
TALLOC_CTX *out_mem_ctx,
|
|
||||||
const DATA_BLOB in, DATA_BLOB *out);
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Start NTLMSSP on the server side
|
* Start NTLMSSP on the server side
|
||||||
|
@ -21,6 +21,8 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include "includes.h"
|
#include "includes.h"
|
||||||
|
#include <tevent.h>
|
||||||
|
#include "lib/util/tevent_ntstatus.h"
|
||||||
#include "lib/util/time_basic.h"
|
#include "lib/util/time_basic.h"
|
||||||
#include "auth/ntlmssp/ntlmssp.h"
|
#include "auth/ntlmssp/ntlmssp.h"
|
||||||
#include "auth/ntlmssp/ntlmssp_private.h"
|
#include "auth/ntlmssp/ntlmssp_private.h"
|
||||||
@ -304,6 +306,66 @@ struct ntlmssp_server_auth_state {
|
|||||||
uint8_t session_nonce[16];
|
uint8_t session_nonce[16];
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static NTSTATUS ntlmssp_server_preauth(struct gensec_security *gensec_security,
|
||||||
|
struct gensec_ntlmssp_context *gensec_ntlmssp,
|
||||||
|
struct ntlmssp_server_auth_state *state,
|
||||||
|
const DATA_BLOB request);
|
||||||
|
static NTSTATUS ntlmssp_server_check_password(struct gensec_security *gensec_security,
|
||||||
|
struct gensec_ntlmssp_context *gensec_ntlmssp,
|
||||||
|
const struct auth_usersupplied_info *user_info,
|
||||||
|
TALLOC_CTX *mem_ctx,
|
||||||
|
DATA_BLOB *user_session_key, DATA_BLOB *lm_session_key);
|
||||||
|
static NTSTATUS ntlmssp_server_postauth(struct gensec_security *gensec_security,
|
||||||
|
struct gensec_ntlmssp_context *gensec_ntlmssp,
|
||||||
|
struct ntlmssp_server_auth_state *state,
|
||||||
|
DATA_BLOB request);
|
||||||
|
|
||||||
|
struct tevent_req *ntlmssp_server_auth_send(TALLOC_CTX *mem_ctx,
|
||||||
|
struct tevent_context *ev,
|
||||||
|
struct gensec_security *gensec_security,
|
||||||
|
const DATA_BLOB in)
|
||||||
|
{
|
||||||
|
struct gensec_ntlmssp_context *gensec_ntlmssp =
|
||||||
|
talloc_get_type_abort(gensec_security->private_data,
|
||||||
|
struct gensec_ntlmssp_context);
|
||||||
|
struct tevent_req *req = NULL;
|
||||||
|
struct ntlmssp_server_auth_state *state = NULL;
|
||||||
|
NTSTATUS status;
|
||||||
|
|
||||||
|
req = tevent_req_create(mem_ctx, &state,
|
||||||
|
struct ntlmssp_server_auth_state);
|
||||||
|
if (req == NULL) {
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
status = ntlmssp_server_preauth(gensec_security,
|
||||||
|
gensec_ntlmssp,
|
||||||
|
state, in);
|
||||||
|
if (tevent_req_nterror(req, status)) {
|
||||||
|
return tevent_req_post(req, ev);
|
||||||
|
}
|
||||||
|
|
||||||
|
status = ntlmssp_server_check_password(gensec_security,
|
||||||
|
gensec_ntlmssp,
|
||||||
|
state->user_info,
|
||||||
|
state,
|
||||||
|
&state->user_session_key,
|
||||||
|
&state->lm_session_key);
|
||||||
|
if (tevent_req_nterror(req, status)) {
|
||||||
|
return tevent_req_post(req, ev);
|
||||||
|
}
|
||||||
|
|
||||||
|
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);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Next state function for the Authenticate packet
|
* Next state function for the Authenticate packet
|
||||||
*
|
*
|
||||||
@ -989,63 +1051,19 @@ static NTSTATUS ntlmssp_server_postauth(struct gensec_security *gensec_security,
|
|||||||
return nt_status;
|
return nt_status;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
NTSTATUS ntlmssp_server_auth_recv(struct tevent_req *req,
|
||||||
/**
|
TALLOC_CTX *out_mem_ctx,
|
||||||
* Next state function for the NTLMSSP Authenticate packet
|
DATA_BLOB *out)
|
||||||
*
|
|
||||||
* @param gensec_security GENSEC state
|
|
||||||
* @param out_mem_ctx Memory context for *out
|
|
||||||
* @param in The request, as a DATA_BLOB. reply.data must be NULL
|
|
||||||
* @param out The reply, as an allocated DATA_BLOB, caller to free.
|
|
||||||
* @return Errors or NT_STATUS_OK if authentication sucessful
|
|
||||||
*/
|
|
||||||
|
|
||||||
NTSTATUS gensec_ntlmssp_server_auth(struct gensec_security *gensec_security,
|
|
||||||
TALLOC_CTX *out_mem_ctx,
|
|
||||||
const DATA_BLOB in, DATA_BLOB *out)
|
|
||||||
{
|
{
|
||||||
struct gensec_ntlmssp_context *gensec_ntlmssp =
|
NTSTATUS status;
|
||||||
talloc_get_type_abort(gensec_security->private_data,
|
|
||||||
struct gensec_ntlmssp_context);
|
|
||||||
struct ntlmssp_server_auth_state *state;
|
|
||||||
NTSTATUS nt_status;
|
|
||||||
|
|
||||||
/* zero the outbound NTLMSSP packet */
|
|
||||||
*out = data_blob_null;
|
*out = data_blob_null;
|
||||||
|
|
||||||
state = talloc_zero(gensec_ntlmssp, struct ntlmssp_server_auth_state);
|
if (tevent_req_is_nterror(req, &status)) {
|
||||||
if (state == NULL) {
|
tevent_req_received(req);
|
||||||
return NT_STATUS_NO_MEMORY;
|
return status;
|
||||||
}
|
}
|
||||||
|
|
||||||
nt_status = ntlmssp_server_preauth(gensec_security, gensec_ntlmssp, state, in);
|
tevent_req_received(req);
|
||||||
if (!NT_STATUS_IS_OK(nt_status)) {
|
return NT_STATUS_OK;
|
||||||
TALLOC_FREE(state);
|
|
||||||
return nt_status;
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Note we don't check here for NTLMv2 auth settings. If NTLMv2 auth
|
|
||||||
* is required (by "ntlm auth = no" and "lm auth = no" being set in the
|
|
||||||
* smb.conf file) and no NTLMv2 response was sent then the password check
|
|
||||||
* will fail here. JRA.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/* Finally, actually ask if the password is OK */
|
|
||||||
nt_status = ntlmssp_server_check_password(gensec_security, gensec_ntlmssp,
|
|
||||||
state->user_info, state,
|
|
||||||
&state->user_session_key,
|
|
||||||
&state->lm_session_key);
|
|
||||||
if (!NT_STATUS_IS_OK(nt_status)) {
|
|
||||||
TALLOC_FREE(state);
|
|
||||||
return nt_status;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* When we get more async in the auth code behind
|
|
||||||
ntlmssp_state->check_password, the ntlmssp_server_postpath
|
|
||||||
can be done in a callback */
|
|
||||||
|
|
||||||
nt_status = ntlmssp_server_postauth(gensec_security, gensec_ntlmssp, state, in);
|
|
||||||
TALLOC_FREE(state);
|
|
||||||
return nt_status;
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user