diff options
author | Andrew Tridgell <tridge@samba.org> | 2001-10-14 06:14:11 +0000 |
---|---|---|
committer | Andrew Tridgell <tridge@samba.org> | 2001-10-14 06:14:11 +0000 |
commit | 131010e9fb842b4d5a8660c538a3313c95fadae7 (patch) | |
tree | 3817ece5bfb3dc596459c36e19385e7829766e12 | |
parent | b218d465a1968a11d2d6a42afa7e552fea8b7f5e (diff) | |
download | samba-131010e9fb842b4d5a8660c538a3313c95fadae7.tar.gz samba-131010e9fb842b4d5a8660c538a3313c95fadae7.tar.xz samba-131010e9fb842b4d5a8660c538a3313c95fadae7.zip |
fixed NTLMSSP with XP servers (who don't send the duplicate challenge
in the asn1 spnego structures)
-rw-r--r-- | source/libsmb/cliconnect.c | 8 | ||||
-rw-r--r-- | source/libsmb/clispnego.c | 12 |
2 files changed, 17 insertions, 3 deletions
diff --git a/source/libsmb/cliconnect.c b/source/libsmb/cliconnect.c index 4a9d2fe59c6..94eda90a3b3 100644 --- a/source/libsmb/cliconnect.c +++ b/source/libsmb/cliconnect.c @@ -439,6 +439,10 @@ static BOOL cli_session_setup_ntlmssp(struct cli_state *cli, char *user, return False; } +#if 0 + file_save("chal.dat", blob.data, blob.length); +#endif + /* the server gives us back two challenges */ if (!spnego_parse_challenge(blob, &chal1, &chal2)) { return False; @@ -499,6 +503,10 @@ static BOOL cli_session_setup_spnego(struct cli_state *cli, char *user, goto ntlmssp; } +#if 0 + file_save("negprot.dat", cli->secblob.data, cli->secblob.length); +#endif + /* the server sent us the first part of the SPNEGO exchange in the negprot reply */ if (!spnego_parse_negTokenInit(cli->secblob, guid, OIDs, &principle)) { diff --git a/source/libsmb/clispnego.c b/source/libsmb/clispnego.c index 6b705658c37..da8c6450ae5 100644 --- a/source/libsmb/clispnego.c +++ b/source/libsmb/clispnego.c @@ -241,6 +241,9 @@ BOOL spnego_parse_challenge(DATA_BLOB blob, BOOL ret; ASN1_DATA data; + ZERO_STRUCTP(chal1); + ZERO_STRUCTP(chal2); + asn1_load(&data, blob); asn1_start_tag(&data,ASN1_CONTEXT(1)); asn1_start_tag(&data,ASN1_SEQUENCE(0)); @@ -257,9 +260,12 @@ BOOL spnego_parse_challenge(DATA_BLOB blob, asn1_read_octet_string(&data, chal1); asn1_end_tag(&data); - asn1_start_tag(&data,ASN1_CONTEXT(3)); - asn1_read_octet_string(&data, chal2); - asn1_end_tag(&data); + /* the second challenge is optional (XP doesn't send it) */ + if (asn1_tag_remaining(&data)) { + asn1_start_tag(&data,ASN1_CONTEXT(3)); + asn1_read_octet_string(&data, chal2); + asn1_end_tag(&data); + } asn1_end_tag(&data); asn1_end_tag(&data); |