From 540b7130750f82d52a514a5117237e1b3e90e97b Mon Sep 17 00:00:00 2001 From: Stefan Metzmacher Date: Wed, 20 May 2009 17:17:07 +0200 Subject: s4:libcli/smb2: use raw ntlmssp if the server didn't provide a sec blob metze --- source4/libcli/smb2/session.c | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) (limited to 'source4/libcli/smb2/session.c') diff --git a/source4/libcli/smb2/session.c b/source4/libcli/smb2/session.c index 127bb9bcae..cf50ba6831 100644 --- a/source4/libcli/smb2/session.c +++ b/source4/libcli/smb2/session.c @@ -207,6 +207,7 @@ struct composite_context *smb2_session_setup_spnego_send(struct smb2_session *se { struct composite_context *c; struct smb2_session_state *state; + const char *chosen_oid; c = composite_create(session, session->transport->socket->event.ctx); if (c == NULL) return NULL; @@ -235,7 +236,13 @@ struct composite_context *smb2_session_setup_spnego_send(struct smb2_session *se c->status = gensec_set_target_service(session->gensec, "cifs"); if (!composite_is_ok(c)) return c; - c->status = gensec_start_mech_by_oid(session->gensec, GENSEC_OID_SPNEGO); + if (session->transport->negotiate.secblob.length > 0) { + chosen_oid = GENSEC_OID_SPNEGO; + } else { + chosen_oid = GENSEC_OID_NTLMSSP; + } + + c->status = gensec_start_mech_by_oid(session->gensec, chosen_oid); if (!composite_is_ok(c)) return c; c->status = gensec_update(session->gensec, c, -- cgit