r892: Actually add the NTLMSSP self-check torture code this time...
authorAndrew Bartlett <abartlet@samba.org>
Tue, 25 May 2004 23:12:52 +0000 (23:12 +0000)
committerGerald (Jerry) Carter <jerry@samba.org>
Wed, 10 Oct 2007 17:56:18 +0000 (12:56 -0500)
Andrew Bartlett
(This used to be commit 9df5cbbd7694202c17a7c47ed0469d6f80412c54)

source4/torture/auth/ntlmssp.c [new file with mode: 0644]
source4/torture/config.mk
source4/torture/torture.c

diff --git a/source4/torture/auth/ntlmssp.c b/source4/torture/auth/ntlmssp.c
new file mode 100644 (file)
index 0000000..1fa2d49
--- /dev/null
@@ -0,0 +1,57 @@
+/* 
+   Unix SMB/CIFS implementation.
+   basic raw test suite for change notify
+   Copyright (C) Andrew Bartlett <abartlet@samba.org> 2004
+   
+   This program is free software; you can redistribute it and/or modify
+   it under the terms of the GNU General Public License as published by
+   the Free Software Foundation; either version 2 of the License, or
+   (at your option) any later version.
+   
+   This program is distributed in the hope that it will be useful,
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+   GNU General Public License for more details.
+   
+   You should have received a copy of the GNU General Public License
+   along with this program; if not, write to the Free Software
+   Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
+*/
+
+#include "includes.h"
+
+BOOL torture_ntlmssp_self_check(int dummy) 
+{
+       NTLMSSP_STATE *ntlmssp_state;
+       DATA_BLOB data;
+       DATA_BLOB sig, expected_sig;
+       NTSTATUS status;
+
+       if (!NT_STATUS_IS_OK(ntlmssp_client_start(&ntlmssp_state))) {
+               return False;
+       }
+
+       ntlmssp_state->session_key = strhex_to_data_blob("0102030405060708090a0b0c0d0e0f00");
+       dump_data_pw("NTLMSSP session key: \n", 
+                    ntlmssp_state->session_key.data,  
+                    ntlmssp_state->session_key.length);
+
+       ntlmssp_state->server_use_session_keys = True;
+       ntlmssp_state->neg_flags = NTLMSSP_NEGOTIATE_UNICODE | NTLMSSP_NEGOTIATE_128 | NTLMSSP_NEGOTIATE_KEY_EXCH | NTLMSSP_NEGOTIATE_NTLM2;
+
+       if (!NT_STATUS_IS_OK(status = ntlmssp_sign_init(ntlmssp_state))) {
+               printf("Failed to sign_init: %s\n", nt_errstr(status));
+               return False;
+       }
+
+       data = strhex_to_data_blob("6a43494653");
+       ntlmssp_sign_packet(ntlmssp_state, ntlmssp_state->mem_ctx, 
+                           data.data, data.length, &sig);
+
+       expected_sig = strhex_to_data_blob("01000000e37f97f2544f4d7e00000000");
+
+       dump_data_pw("NTLMSSP sig: ", sig.data, sig.length);
+       dump_data_pw("NTLMSSP sig: ", expected_sig.data, expected_sig.length);
+
+       return True;
+}
index febe02500cea78750e3c71c95c99098b5c46165c..4bbcf21b58c474786f904ec9cd73bac692a8e999 100644 (file)
@@ -70,8 +70,8 @@ REQUIRED_SUBSYSTEMS = \
 #################################
 # Start SUBSYSTEM TORTURE_AUTH
 [SUBSYSTEM::TORTURE_AUTH]
 #################################
 # Start SUBSYSTEM TORTURE_AUTH
 [SUBSYSTEM::TORTURE_AUTH]
-#ADD_OBJ_FILES = \
-#              torture/auth/ntlmssp.o
+ADD_OBJ_FILES = \
+               torture/auth/ntlmssp.o
 REQUIRED_SUBSYSTEMS = \
                LIBSMB
 # End SUBSYSTEM TORTURE_AUTH
 REQUIRED_SUBSYSTEMS = \
                LIBSMB
 # End SUBSYSTEM TORTURE_AUTH
index 7351f42c8b320a4de00727c27aa6ee16b5c7301f..266f543f1b1a1fc8739a5aa970a58169354ee456 100644 (file)
@@ -4140,7 +4140,7 @@ static struct {
         {"RPC-MGMT", torture_rpc_mgmt, 0},
         {"RPC-SCANNER", torture_rpc_scanner, 0},
         {"RPC-AUTOIDL", torture_rpc_autoidl, 0},
         {"RPC-MGMT", torture_rpc_mgmt, 0},
         {"RPC-SCANNER", torture_rpc_scanner, 0},
         {"RPC-AUTOIDL", torture_rpc_autoidl, 0},
-/*     {"NTLMSSP-SELFCHECK", torture_ntlmssp_self_check, 0},*/
+       {"NTLMSSP-SELFCHECK", torture_ntlmssp_self_check, 0},
        {NULL, NULL, 0}};
 
 
        {NULL, NULL, 0}};