2011-05-05 18:12:07 +02:00
/*
Unix SMB / CIFS implementation .
Initial test for the smb2 client lib
Copyright ( C ) Volker Lendecke 2011
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 3 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 , see < http : //www.gnu.org/licenses/>.
*/
# include "includes.h"
# include "torture/proto.h"
# include "client.h"
2012-05-03 12:07:11 +02:00
# include "trans2.h"
2011-08-30 11:38:26 +02:00
# include "../libcli/smb/smbXcli_base.h"
2011-05-05 18:12:07 +02:00
# include "libsmb/smb2cli.h"
# include "libcli/security/security.h"
2011-09-28 00:58:28 +02:00
# include "libsmb/proto.h"
2011-12-27 13:27:45 +11:00
# include "auth/gensec/gensec.h"
# include "auth_generic.h"
2011-05-05 18:12:07 +02:00
extern fstring host , workgroup , share , password , username , myname ;
bool run_smb2_basic ( int dummy )
{
struct cli_state * cli ;
NTSTATUS status ;
uint64_t fid_persistent , fid_volatile ;
const char * hello = " Hello, world \n " ;
uint8_t * result ;
uint32_t nread ;
uint8_t * dir_data ;
uint32_t dir_data_length ;
2011-11-24 12:33:19 +01:00
uint32_t saved_tid = 0 ;
2012-07-24 20:11:25 +02:00
struct smbXcli_tcon * saved_tcon = NULL ;
2011-11-24 12:33:19 +01:00
uint64_t saved_uid = 0 ;
2011-05-05 18:12:07 +02:00
printf ( " Starting SMB2-BASIC \n " ) ;
if ( ! torture_init_connection ( & cli ) ) {
return false ;
}
2011-08-30 11:38:26 +02:00
status = smbXcli_negprot ( cli - > conn , cli - > timeout ,
PROTOCOL_SMB2_02 , PROTOCOL_SMB2_02 ) ;
2011-05-05 18:12:07 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
2011-08-30 11:38:26 +02:00
printf ( " smbXcli_negprot returned %s \n " , nt_errstr ( status ) ) ;
2011-05-05 18:12:07 +02:00
return false ;
}
2011-09-28 00:58:28 +02:00
status = cli_session_setup ( cli , username ,
password , strlen ( password ) ,
password , strlen ( password ) ,
workgroup ) ;
2011-05-05 18:12:07 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
2011-09-28 00:58:28 +02:00
printf ( " cli_session_setup returned %s \n " , nt_errstr ( status ) ) ;
2011-05-05 18:12:07 +02:00
return false ;
}
2011-11-24 13:03:11 +01:00
status = cli_tree_connect ( cli , share , " ????? " , " " , 0 ) ;
2011-05-05 18:12:07 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
2011-11-24 13:03:11 +01:00
printf ( " cli_tree_connect returned %s \n " , nt_errstr ( status ) ) ;
2011-05-05 18:12:07 +02:00
return false ;
}
2012-05-10 18:34:40 +02:00
status = smb2cli_create ( cli - > conn , cli - > timeout , cli - > smb2 . session ,
2012-07-23 22:32:49 +02:00
cli - > smb2 . tcon , " smb2-basic.txt " ,
2011-11-02 14:38:08 +01:00
SMB2_OPLOCK_LEVEL_NONE , /* oplock_level, */
SMB2_IMPERSONATION_IMPERSONATION , /* impersonation_level, */
SEC_STD_ALL | SEC_FILE_ALL , /* desired_access, */
FILE_ATTRIBUTE_NORMAL , /* file_attributes, */
FILE_SHARE_READ | FILE_SHARE_WRITE | FILE_SHARE_DELETE , /* share_access, */
FILE_CREATE , /* create_disposition, */
FILE_DELETE_ON_CLOSE , /* create_options, */
NULL , /* smb2_create_blobs *blobs */
& fid_persistent ,
2013-08-07 15:01:50 -07:00
& fid_volatile ,
2014-06-27 09:32:34 +00:00
NULL , NULL , NULL ) ;
2011-05-05 18:12:07 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smb2cli_create returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2012-05-10 18:40:56 +02:00
status = smb2cli_write ( cli - > conn , cli - > timeout , cli - > smb2 . session ,
2012-07-23 22:32:49 +02:00
cli - > smb2 . tcon , strlen ( hello ) , 0 , fid_persistent ,
2013-08-07 14:41:24 -07:00
fid_volatile , 0 , 0 , ( const uint8_t * ) hello , NULL ) ;
2011-05-05 18:12:07 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smb2cli_write returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2012-05-10 18:35:50 +02:00
status = smb2cli_flush ( cli - > conn , cli - > timeout , cli - > smb2 . session ,
2012-07-23 22:32:49 +02:00
cli - > smb2 . tcon , fid_persistent , fid_volatile ) ;
2011-09-17 19:29:51 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smb2cli_flush returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2012-05-10 18:30:25 +02:00
status = smb2cli_read ( cli - > conn , cli - > timeout , cli - > smb2 . session ,
2012-07-23 22:32:49 +02:00
cli - > smb2 . tcon , 0x10000 , 0 , fid_persistent ,
2012-05-10 18:30:25 +02:00
fid_volatile , 2 , 0 ,
talloc_tos ( ) , & result , & nread ) ;
2011-05-05 18:12:07 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smb2cli_read returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
if ( nread ! = strlen ( hello ) ) {
printf ( " smb2cli_read returned %d bytes, expected %d \n " ,
( int ) nread , ( int ) strlen ( hello ) ) ;
return false ;
}
if ( memcmp ( hello , result , nread ) ! = 0 ) {
printf ( " smb2cli_read returned '%s', expected '%s' \n " ,
result , hello ) ;
return false ;
}
2012-05-10 18:32:49 +02:00
status = smb2cli_close ( cli - > conn , cli - > timeout , cli - > smb2 . session ,
2012-07-23 22:32:49 +02:00
cli - > smb2 . tcon , 0 , fid_persistent , fid_volatile ) ;
2011-05-05 18:12:07 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smb2cli_close returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2012-05-10 18:34:40 +02:00
status = smb2cli_create ( cli - > conn , cli - > timeout , cli - > smb2 . session ,
2012-07-23 22:32:49 +02:00
cli - > smb2 . tcon , " " ,
2011-11-02 14:38:08 +01:00
SMB2_OPLOCK_LEVEL_NONE , /* oplock_level, */
SMB2_IMPERSONATION_IMPERSONATION , /* impersonation_level, */
SEC_STD_SYNCHRONIZE |
SEC_DIR_LIST |
SEC_DIR_READ_ATTRIBUTE , /* desired_access, */
0 , /* file_attributes, */
FILE_SHARE_READ | FILE_SHARE_WRITE | FILE_SHARE_DELETE , /* share_access, */
FILE_OPEN , /* create_disposition, */
FILE_SYNCHRONOUS_IO_NONALERT | FILE_DIRECTORY_FILE , /* create_options, */
NULL , /* smb2_create_blobs *blobs */
& fid_persistent ,
2013-08-07 15:01:50 -07:00
& fid_volatile ,
2014-06-27 09:32:34 +00:00
NULL , NULL , NULL ) ;
2011-05-05 18:12:07 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smb2cli_create returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
status = smb2cli_query_directory (
2012-07-23 22:32:49 +02:00
cli - > conn , cli - > timeout , cli - > smb2 . session , cli - > smb2 . tcon ,
2012-05-10 18:37:43 +02:00
1 , 0 , 0 , fid_persistent , fid_volatile , " * " , 0xffff ,
2011-05-05 18:12:07 +02:00
talloc_tos ( ) , & dir_data , & dir_data_length ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smb2cli_query_directory returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2012-05-10 18:32:49 +02:00
status = smb2cli_close ( cli - > conn , cli - > timeout , cli - > smb2 . session ,
2012-07-23 22:32:49 +02:00
cli - > smb2 . tcon , 0 , fid_persistent , fid_volatile ) ;
2011-05-05 18:12:07 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smb2cli_close returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2012-07-25 09:01:02 +02:00
saved_tid = smb2cli_tcon_current_id ( cli - > smb2 . tcon ) ;
2012-07-24 20:11:25 +02:00
saved_tcon = cli - > smb2 . tcon ;
cli - > smb2 . tcon = smbXcli_tcon_create ( cli ) ;
smb2cli_tcon_set_values ( cli - > smb2 . tcon ,
2012-07-25 12:33:39 +02:00
NULL , /* session */
2012-07-24 20:11:25 +02:00
saved_tid ,
0 , /* type */
0 , /* flags */
0 , /* capabilities */
0 /* maximal_access */ ) ;
2011-11-24 12:33:19 +01:00
status = smb2cli_tdis ( cli ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smb2cli_tdis returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2012-07-24 20:11:25 +02:00
talloc_free ( cli - > smb2 . tcon ) ;
cli - > smb2 . tcon = saved_tcon ;
2011-11-24 12:33:19 +01:00
status = smb2cli_tdis ( cli ) ;
if ( ! NT_STATUS_EQUAL ( status , NT_STATUS_NETWORK_NAME_DELETED ) ) {
printf ( " 2nd smb2cli_tdis returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
saved_uid = smb2cli_session_current_id ( cli - > smb2 . session ) ;
2012-05-10 18:39:11 +02:00
status = smb2cli_logoff ( cli - > conn , cli - > timeout , cli - > smb2 . session ) ;
2011-11-24 12:33:19 +01:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smb2cli_logoff returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
cli - > smb2 . session = smbXcli_session_create ( cli , cli - > conn ) ;
if ( cli - > smb2 . session = = NULL ) {
printf ( " smbXcli_session_create() returned NULL \n " ) ;
return false ;
}
smb2cli_session_set_id_and_flags ( cli - > smb2 . session , saved_uid , 0 ) ;
2012-05-10 18:39:11 +02:00
status = smb2cli_logoff ( cli - > conn , cli - > timeout , cli - > smb2 . session ) ;
2011-11-24 12:33:19 +01:00
if ( ! NT_STATUS_EQUAL ( status , NT_STATUS_USER_SESSION_DELETED ) ) {
printf ( " 2nd smb2cli_logoff returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2011-05-05 18:12:07 +02:00
return true ;
}
2011-08-30 18:50:35 +02:00
bool run_smb2_negprot ( int dummy )
{
struct cli_state * cli ;
NTSTATUS status ;
enum protocol_types protocol ;
const char * name = NULL ;
printf ( " Starting SMB2-NEGPROT \n " ) ;
if ( ! torture_init_connection ( & cli ) ) {
return false ;
}
status = smbXcli_negprot ( cli - > conn , cli - > timeout ,
2012-05-05 09:42:28 +02:00
PROTOCOL_CORE , PROTOCOL_LATEST ) ;
2011-08-30 18:50:35 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smbXcli_negprot returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
protocol = smbXcli_conn_protocol ( cli - > conn ) ;
switch ( protocol ) {
case PROTOCOL_SMB2_02 :
name = " SMB2_02 " ;
break ;
case PROTOCOL_SMB2_10 :
name = " SMB2_10 " ;
break ;
case PROTOCOL_SMB2_22 :
name = " SMB2_22 " ;
break ;
2011-12-22 13:14:21 +01:00
case PROTOCOL_SMB2_24 :
name = " SMB2_24 " ;
break ;
2012-05-05 09:42:28 +02:00
case PROTOCOL_SMB3_00 :
name = " SMB3_00 " ;
break ;
2013-09-13 11:28:03 +02:00
case PROTOCOL_SMB3_02 :
name = " SMB3_02 " ;
break ;
2011-08-30 18:50:35 +02:00
default :
break ;
}
if ( name ) {
printf ( " Server supports %s \n " , name ) ;
} else {
printf ( " Server DOES NOT support SMB2 \n " ) ;
return false ;
}
status = smbXcli_negprot ( cli - > conn , cli - > timeout ,
protocol , protocol ) ;
if ( ! NT_STATUS_EQUAL ( status , NT_STATUS_CONNECTION_RESET ) & &
! NT_STATUS_EQUAL ( status , NT_STATUS_CONNECTION_DISCONNECTED ) & &
! NT_STATUS_EQUAL ( status , NT_STATUS_CONNECTION_ABORTED ) ) {
printf ( " 2nd smbXcli_negprot should disconnect - returned %s \n " ,
nt_errstr ( status ) ) ;
return false ;
}
if ( smbXcli_conn_is_connected ( cli - > conn ) ) {
printf ( " 2nd smbXcli_negprot should disconnect "
" - still connected \n " ) ;
return false ;
}
return true ;
}
2011-09-19 10:08:48 +02:00
bool run_smb2_session_reconnect ( int dummy )
{
struct cli_state * cli1 ;
struct cli_state * cli2 ;
NTSTATUS status ;
bool ok ;
uint64_t fid_persistent , fid_volatile ;
struct tevent_context * ev ;
struct tevent_req * subreq ;
DATA_BLOB in_blob = data_blob_null ;
DATA_BLOB out_blob ;
2011-12-27 13:27:45 +11:00
DATA_BLOB session_key ;
struct auth_generic_state * auth_generic_state ;
2011-09-19 10:08:48 +02:00
struct iovec * recv_iov ;
const char * hello = " Hello, world \n " ;
uint8_t * result ;
uint32_t nread ;
printf ( " Starting SMB2-SESSION-RECONNECT \n " ) ;
if ( ! torture_init_connection ( & cli1 ) ) {
return false ;
}
status = smbXcli_negprot ( cli1 - > conn , cli1 - > timeout ,
2012-05-05 09:42:28 +02:00
PROTOCOL_SMB2_02 , PROTOCOL_LATEST ) ;
2011-09-19 10:08:48 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smbXcli_negprot returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
status = cli_session_setup ( cli1 , username ,
password , strlen ( password ) ,
password , strlen ( password ) ,
workgroup ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " cli_session_setup returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
status = cli_tree_connect ( cli1 , share , " ????? " , " " , 0 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " cli_tree_connect returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2012-05-10 18:34:40 +02:00
status = smb2cli_create ( cli1 - > conn , cli1 - > timeout , cli1 - > smb2 . session ,
2012-07-23 22:32:49 +02:00
cli1 - > smb2 . tcon , " session-reconnect.txt " ,
2011-09-19 10:08:48 +02:00
SMB2_OPLOCK_LEVEL_NONE , /* oplock_level, */
SMB2_IMPERSONATION_IMPERSONATION , /* impersonation_level, */
SEC_STD_ALL | SEC_FILE_ALL , /* desired_access, */
FILE_ATTRIBUTE_NORMAL , /* file_attributes, */
FILE_SHARE_READ | FILE_SHARE_WRITE | FILE_SHARE_DELETE , /* share_access, */
FILE_CREATE , /* create_disposition, */
FILE_DELETE_ON_CLOSE , /* create_options, */
NULL , /* smb2_create_blobs *blobs */
& fid_persistent ,
2013-08-07 15:01:50 -07:00
& fid_volatile ,
2014-06-27 09:32:34 +00:00
NULL , NULL , NULL ) ;
2011-09-19 10:08:48 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smb2cli_create on cli1 %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2012-05-10 18:40:56 +02:00
status = smb2cli_write ( cli1 - > conn , cli1 - > timeout , cli1 - > smb2 . session ,
2012-07-23 22:32:49 +02:00
cli1 - > smb2 . tcon , strlen ( hello ) , 0 , fid_persistent ,
2013-08-07 14:41:24 -07:00
fid_volatile , 0 , 0 , ( const uint8_t * ) hello , NULL ) ;
2011-09-19 10:08:48 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smb2cli_write returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2012-05-10 18:35:50 +02:00
status = smb2cli_flush ( cli1 - > conn , cli1 - > timeout , cli1 - > smb2 . session ,
2012-07-23 22:32:49 +02:00
cli1 - > smb2 . tcon , fid_persistent , fid_volatile ) ;
2011-09-19 10:08:48 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smb2cli_flush returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2012-05-10 18:30:25 +02:00
status = smb2cli_read ( cli1 - > conn , cli1 - > timeout , cli1 - > smb2 . session ,
2012-07-23 22:32:49 +02:00
cli1 - > smb2 . tcon , 0x10000 , 0 , fid_persistent ,
2012-05-10 18:30:25 +02:00
fid_volatile , 2 , 0 ,
talloc_tos ( ) , & result , & nread ) ;
2011-09-19 10:08:48 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smb2cli_read returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
if ( nread ! = strlen ( hello ) ) {
printf ( " smb2cli_read returned %d bytes, expected %d \n " ,
( int ) nread , ( int ) strlen ( hello ) ) ;
return false ;
}
if ( memcmp ( hello , result , nread ) ! = 0 ) {
printf ( " smb2cli_read returned '%s', expected '%s' \n " ,
result , hello ) ;
return false ;
}
/* prepare second session */
if ( ! torture_init_connection ( & cli2 ) ) {
return false ;
}
status = smbXcli_negprot ( cli2 - > conn , cli2 - > timeout ,
2012-05-05 09:42:28 +02:00
PROTOCOL_SMB2_02 , PROTOCOL_LATEST ) ;
2011-09-19 10:08:48 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smbXcli_negprot returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2011-12-27 13:27:45 +11:00
status = auth_generic_client_prepare ( talloc_tos ( ) , & auth_generic_state ) ;
2011-09-19 10:08:48 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
2011-12-27 13:27:45 +11:00
printf ( " auth_generic_client_prepare returned %s \n " , nt_errstr ( status ) ) ;
2011-09-19 10:08:48 +02:00
return false ;
}
2011-12-27 13:27:45 +11:00
gensec_want_feature ( auth_generic_state - > gensec_security ,
GENSEC_FEATURE_SESSION_KEY ) ;
status = auth_generic_set_username ( auth_generic_state , username ) ;
2011-09-19 10:08:48 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
2011-12-27 13:27:45 +11:00
printf ( " auth_generic_set_username returned %s \n " , nt_errstr ( status ) ) ;
2011-09-19 10:08:48 +02:00
return false ;
}
2011-12-27 13:27:45 +11:00
status = auth_generic_set_domain ( auth_generic_state , workgroup ) ;
2011-09-19 10:08:48 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
2011-12-27 13:27:45 +11:00
printf ( " auth_generic_set_domain returned %s \n " , nt_errstr ( status ) ) ;
2011-09-19 10:08:48 +02:00
return false ;
}
2011-12-27 13:27:45 +11:00
status = auth_generic_set_password ( auth_generic_state , password ) ;
2011-09-19 10:08:48 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
2011-12-27 13:27:45 +11:00
printf ( " auth_generic_set_password returned %s \n " , nt_errstr ( status ) ) ;
2011-09-19 10:08:48 +02:00
return false ;
}
2011-12-27 13:27:45 +11:00
status = auth_generic_client_start ( auth_generic_state , GENSEC_OID_NTLMSSP ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " auth_generic_client_start returned %s \n " , nt_errstr ( status ) ) ;
2011-09-19 10:08:48 +02:00
return false ;
}
2013-02-18 09:11:19 +01:00
ev = samba_tevent_context_init ( talloc_tos ( ) ) ;
2011-09-19 10:08:48 +02:00
if ( ev = = NULL ) {
2013-02-18 09:11:19 +01:00
printf ( " samba_tevent_context_init() returned NULL \n " ) ;
2011-09-19 10:08:48 +02:00
return false ;
}
2013-12-13 19:56:13 +01:00
status = gensec_update ( auth_generic_state - > gensec_security ,
talloc_tos ( ) , data_blob_null , & in_blob ) ;
2011-12-27 13:27:45 +11:00
if ( ! NT_STATUS_EQUAL ( status , NT_STATUS_MORE_PROCESSING_REQUIRED ) ) {
printf ( " gensec_update returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
cli2 - > smb2 . session = smbXcli_session_create ( cli2 , cli2 - > conn ) ;
2011-09-19 10:08:48 +02:00
subreq = smb2cli_session_setup_send ( talloc_tos ( ) , ev ,
cli2 - > conn ,
cli2 - > timeout ,
cli2 - > smb2 . session ,
0x0 , /* in_flags */
SMB2_CAP_DFS , /* in_capabilities */
0 , /* in_channel */
2012-02-26 17:35:28 +01:00
/* in_previous_session_id: */
smb2cli_session_current_id ( cli1 - > smb2 . session ) ,
2011-09-19 10:08:48 +02:00
& in_blob ) ; /* in_security_buffer */
if ( subreq = = NULL ) {
printf ( " smb2cli_session_setup_send() returned NULL \n " ) ;
return false ;
}
ok = tevent_req_poll ( subreq , ev ) ;
if ( ! ok ) {
printf ( " tevent_req_poll() returned false \n " ) ;
return false ;
}
status = smb2cli_session_setup_recv ( subreq , talloc_tos ( ) ,
NULL , & out_blob ) ;
if ( ! NT_STATUS_EQUAL ( status , NT_STATUS_MORE_PROCESSING_REQUIRED ) ) {
printf ( " smb2cli_session_setup_recv returned %s \n " ,
nt_errstr ( status ) ) ;
return false ;
}
2013-12-13 19:56:13 +01:00
status = gensec_update ( auth_generic_state - > gensec_security ,
talloc_tos ( ) , out_blob , & in_blob ) ;
2011-09-19 10:08:48 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
2011-12-27 13:27:45 +11:00
printf ( " auth_generic_update returned %s \n " , nt_errstr ( status ) ) ;
2011-09-19 10:08:48 +02:00
return false ;
}
subreq = smb2cli_session_setup_send ( talloc_tos ( ) , ev ,
cli2 - > conn ,
cli2 - > timeout ,
cli2 - > smb2 . session ,
0x0 , /* in_flags */
SMB2_CAP_DFS , /* in_capabilities */
0 , /* in_channel */
2012-02-26 17:35:28 +01:00
/* in_previous_session_id: */
smb2cli_session_current_id ( cli1 - > smb2 . session ) ,
2011-09-19 10:08:48 +02:00
& in_blob ) ; /* in_security_buffer */
if ( subreq = = NULL ) {
printf ( " smb2cli_session_setup_send() returned NULL \n " ) ;
return false ;
}
ok = tevent_req_poll ( subreq , ev ) ;
if ( ! ok ) {
printf ( " tevent_req_poll() returned false \n " ) ;
return false ;
}
status = smb2cli_session_setup_recv ( subreq , talloc_tos ( ) ,
& recv_iov , & out_blob ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smb2cli_session_setup_recv returned %s \n " ,
nt_errstr ( status ) ) ;
return false ;
}
2011-12-27 13:27:45 +11:00
status = gensec_session_key ( auth_generic_state - > gensec_security , talloc_tos ( ) ,
& session_key ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " gensec_session_key returned %s \n " ,
nt_errstr ( status ) ) ;
return false ;
}
2011-09-19 10:08:48 +02:00
/* check file operation on the old client */
2012-05-10 18:35:50 +02:00
status = smb2cli_flush ( cli1 - > conn , cli1 - > timeout , cli1 - > smb2 . session ,
2012-07-23 22:32:49 +02:00
cli1 - > smb2 . tcon , fid_persistent , fid_volatile ) ;
2011-09-19 10:08:48 +02:00
if ( ! NT_STATUS_EQUAL ( status , NT_STATUS_USER_SESSION_DELETED ) ) {
printf ( " smb2cli_flush returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
status = cli_tree_connect ( cli1 , share , " ????? " , " " , 0 ) ;
if ( ! NT_STATUS_EQUAL ( status , NT_STATUS_USER_SESSION_DELETED ) ) {
printf ( " cli_tree_connect returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
/*
* checking file operations without signing .
* on w2k8r2 at least , flush , read and write also work the same way ,
* while create gives ACCESS_DENIED without signing
*/
2012-05-10 18:35:50 +02:00
status = smb2cli_flush ( cli2 - > conn , cli2 - > timeout , cli2 - > smb2 . session ,
2012-07-23 22:32:49 +02:00
cli2 - > smb2 . tcon , fid_persistent , fid_volatile ) ;
2012-04-18 17:55:51 +02:00
if ( ! NT_STATUS_EQUAL ( status , NT_STATUS_FILE_CLOSED ) & &
! NT_STATUS_EQUAL ( status , NT_STATUS_NETWORK_NAME_DELETED ) )
{
2011-09-19 10:08:48 +02:00
printf ( " smb2cli_flush returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2012-05-10 18:40:56 +02:00
status = smb2cli_write ( cli2 - > conn , cli2 - > timeout , cli2 - > smb2 . session ,
2012-07-23 22:32:49 +02:00
cli2 - > smb2 . tcon , strlen ( hello ) , 0 , fid_persistent ,
2013-08-07 14:41:24 -07:00
fid_volatile , 0 , 0 , ( const uint8_t * ) hello , NULL ) ;
2012-04-18 17:55:51 +02:00
if ( ! NT_STATUS_EQUAL ( status , NT_STATUS_FILE_CLOSED ) & &
! NT_STATUS_EQUAL ( status , NT_STATUS_NETWORK_NAME_DELETED ) )
{
2011-09-19 10:08:48 +02:00
printf ( " smb2cli_write returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2012-05-10 18:30:25 +02:00
status = smb2cli_read ( cli2 - > conn , cli2 - > timeout , cli2 - > smb2 . session ,
2012-07-23 22:32:49 +02:00
cli2 - > smb2 . tcon , 0x10000 , 0 , fid_persistent ,
2012-05-10 18:30:25 +02:00
fid_volatile , 2 , 0 ,
talloc_tos ( ) , & result , & nread ) ;
2012-04-18 17:55:51 +02:00
if ( ! NT_STATUS_EQUAL ( status , NT_STATUS_FILE_CLOSED ) & &
! NT_STATUS_EQUAL ( status , NT_STATUS_NETWORK_NAME_DELETED ) )
{
2011-09-19 10:08:48 +02:00
printf ( " smb2cli_read returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2012-05-10 18:34:40 +02:00
status = smb2cli_create ( cli2 - > conn , cli2 - > timeout , cli2 - > smb2 . session ,
2012-07-23 22:32:49 +02:00
cli2 - > smb2 . tcon , " session-reconnect.txt " ,
2011-09-19 10:08:48 +02:00
SMB2_OPLOCK_LEVEL_NONE , /* oplock_level, */
SMB2_IMPERSONATION_IMPERSONATION , /* impersonation_level, */
SEC_STD_ALL | SEC_FILE_ALL , /* desired_access, */
FILE_ATTRIBUTE_NORMAL , /* file_attributes, */
FILE_SHARE_READ | FILE_SHARE_WRITE | FILE_SHARE_DELETE , /* share_access, */
FILE_CREATE , /* create_disposition, */
FILE_DELETE_ON_CLOSE , /* create_options, */
NULL , /* smb2_create_blobs *blobs */
& fid_persistent ,
2013-08-07 15:01:50 -07:00
& fid_volatile ,
2014-06-27 09:32:34 +00:00
NULL , NULL , NULL ) ;
2012-01-06 08:31:16 +01:00
if ( ! NT_STATUS_EQUAL ( status , NT_STATUS_ACCESS_DENIED ) & &
! NT_STATUS_EQUAL ( status , NT_STATUS_NETWORK_NAME_DELETED ) ) {
2011-09-19 10:08:48 +02:00
printf ( " smb2cli_create on cli2 %s \n " , nt_errstr ( status ) ) ;
return false ;
}
/* now grab the session key and try with signing */
2012-02-27 08:48:55 +01:00
status = smb2cli_session_set_session_key ( cli2 - > smb2 . session ,
session_key ,
recv_iov ) ;
2011-09-19 10:08:48 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
2012-02-27 08:48:55 +01:00
printf ( " smb2cli_session_set_session_key %s \n " , nt_errstr ( status ) ) ;
2011-09-19 10:08:48 +02:00
return false ;
}
/* the tid seems to be irrelevant at this stage */
2012-05-10 18:35:50 +02:00
status = smb2cli_flush ( cli2 - > conn , cli2 - > timeout , cli2 - > smb2 . session ,
2012-07-25 09:01:02 +02:00
cli1 - > smb2 . tcon , fid_persistent , fid_volatile ) ;
2012-04-18 17:55:51 +02:00
if ( ! NT_STATUS_EQUAL ( status , NT_STATUS_FILE_CLOSED ) & &
! NT_STATUS_EQUAL ( status , NT_STATUS_NETWORK_NAME_DELETED ) )
{
2011-09-19 10:08:48 +02:00
printf ( " smb2cli_flush returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2012-05-10 18:40:56 +02:00
status = smb2cli_write ( cli2 - > conn , cli2 - > timeout , cli2 - > smb2 . session ,
2012-07-25 09:01:02 +02:00
cli1 - > smb2 . tcon , strlen ( hello ) , 0 , fid_persistent ,
2013-08-07 14:41:24 -07:00
fid_volatile , 0 , 0 , ( const uint8_t * ) hello , NULL ) ;
2012-04-18 17:55:51 +02:00
if ( ! NT_STATUS_EQUAL ( status , NT_STATUS_FILE_CLOSED ) & &
! NT_STATUS_EQUAL ( status , NT_STATUS_NETWORK_NAME_DELETED ) )
{
2011-09-19 10:08:48 +02:00
printf ( " smb2cli_write returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2012-05-10 18:30:25 +02:00
status = smb2cli_read ( cli2 - > conn , cli2 - > timeout , cli2 - > smb2 . session ,
2012-07-25 09:01:02 +02:00
cli1 - > smb2 . tcon , 0x10000 , 0 , fid_persistent ,
2012-05-10 18:30:25 +02:00
fid_volatile , 2 , 0 ,
talloc_tos ( ) , & result , & nread ) ;
2012-04-18 17:55:51 +02:00
if ( ! NT_STATUS_EQUAL ( status , NT_STATUS_FILE_CLOSED ) & &
! NT_STATUS_EQUAL ( status , NT_STATUS_NETWORK_NAME_DELETED ) )
{
2011-09-19 10:08:48 +02:00
printf ( " smb2cli_read returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2012-05-10 18:34:40 +02:00
status = smb2cli_create ( cli2 - > conn , cli2 - > timeout , cli2 - > smb2 . session ,
2012-07-25 09:01:02 +02:00
cli1 - > smb2 . tcon , " session-reconnect.txt " ,
2011-09-19 10:08:48 +02:00
SMB2_OPLOCK_LEVEL_NONE , /* oplock_level, */
SMB2_IMPERSONATION_IMPERSONATION , /* impersonation_level, */
SEC_STD_ALL | SEC_FILE_ALL , /* desired_access, */
FILE_ATTRIBUTE_NORMAL , /* file_attributes, */
FILE_SHARE_READ | FILE_SHARE_WRITE | FILE_SHARE_DELETE , /* share_access, */
FILE_CREATE , /* create_disposition, */
FILE_DELETE_ON_CLOSE , /* create_options, */
NULL , /* smb2_create_blobs *blobs */
& fid_persistent ,
2013-08-07 15:01:50 -07:00
& fid_volatile ,
2014-06-27 09:32:34 +00:00
NULL , NULL , NULL ) ;
2012-04-18 17:55:51 +02:00
if ( ! NT_STATUS_EQUAL ( status , NT_STATUS_NETWORK_NAME_DELETED ) & &
! NT_STATUS_EQUAL ( status , NT_STATUS_NETWORK_NAME_DELETED ) )
{
2011-09-19 10:08:48 +02:00
printf ( " smb2cli_create on cli2 %s \n " , nt_errstr ( status ) ) ;
return false ;
}
/* now do a new tcon and test file calls again */
status = cli_tree_connect ( cli2 , share , " ????? " , " " , 0 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " cli_tree_connect returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2012-05-10 18:34:40 +02:00
status = smb2cli_create ( cli2 - > conn , cli2 - > timeout , cli2 - > smb2 . session ,
2012-07-23 22:32:49 +02:00
cli2 - > smb2 . tcon , " session-reconnect.txt " ,
2011-09-19 10:08:48 +02:00
SMB2_OPLOCK_LEVEL_NONE , /* oplock_level, */
SMB2_IMPERSONATION_IMPERSONATION , /* impersonation_level, */
SEC_STD_ALL | SEC_FILE_ALL , /* desired_access, */
FILE_ATTRIBUTE_NORMAL , /* file_attributes, */
FILE_SHARE_READ | FILE_SHARE_WRITE | FILE_SHARE_DELETE , /* share_access, */
FILE_CREATE , /* create_disposition, */
FILE_DELETE_ON_CLOSE , /* create_options, */
NULL , /* smb2_create_blobs *blobs */
& fid_persistent ,
2013-08-07 15:01:50 -07:00
& fid_volatile ,
2014-06-27 09:32:34 +00:00
NULL , NULL , NULL ) ;
2011-09-19 10:08:48 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smb2cli_create on cli2 %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2012-05-10 18:40:56 +02:00
status = smb2cli_write ( cli2 - > conn , cli2 - > timeout , cli2 - > smb2 . session ,
2012-07-23 22:32:49 +02:00
cli2 - > smb2 . tcon , strlen ( hello ) , 0 , fid_persistent ,
2013-08-07 14:41:24 -07:00
fid_volatile , 0 , 0 , ( const uint8_t * ) hello , NULL ) ;
2011-09-19 10:08:48 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smb2cli_write returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2012-05-10 18:35:50 +02:00
status = smb2cli_flush ( cli2 - > conn , cli2 - > timeout , cli2 - > smb2 . session ,
2012-07-23 22:32:49 +02:00
cli2 - > smb2 . tcon , fid_persistent , fid_volatile ) ;
2011-09-19 10:08:48 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smb2cli_flush returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2012-05-10 18:30:25 +02:00
status = smb2cli_read ( cli2 - > conn , cli2 - > timeout , cli2 - > smb2 . session ,
2012-07-23 22:32:49 +02:00
cli2 - > smb2 . tcon , 0x10000 , 0 , fid_persistent ,
2012-05-10 18:30:25 +02:00
fid_volatile , 2 , 0 ,
talloc_tos ( ) , & result , & nread ) ;
2011-09-19 10:08:48 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smb2cli_read returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
if ( nread ! = strlen ( hello ) ) {
printf ( " smb2cli_read returned %d bytes, expected %d \n " ,
( int ) nread , ( int ) strlen ( hello ) ) ;
return false ;
}
if ( memcmp ( hello , result , nread ) ! = 0 ) {
printf ( " smb2cli_read returned '%s', expected '%s' \n " ,
result , hello ) ;
return false ;
}
return true ;
}
2011-09-19 10:09:34 +02:00
bool run_smb2_tcon_dependence ( int dummy )
{
struct cli_state * cli ;
NTSTATUS status ;
uint64_t fid_persistent , fid_volatile ;
const char * hello = " Hello, world \n " ;
uint8_t * result ;
uint32_t nread ;
2012-07-23 22:32:49 +02:00
struct smbXcli_tcon * tcon2 ;
uint32_t tcon2_id ;
2011-09-19 10:09:34 +02:00
printf ( " Starting SMB2-TCON-DEPENDENCE \n " ) ;
if ( ! torture_init_connection ( & cli ) ) {
return false ;
}
status = smbXcli_negprot ( cli - > conn , cli - > timeout ,
2012-05-05 09:42:28 +02:00
PROTOCOL_SMB2_02 , PROTOCOL_LATEST ) ;
2011-09-19 10:09:34 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smbXcli_negprot returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
status = cli_session_setup ( cli , username ,
password , strlen ( password ) ,
password , strlen ( password ) ,
workgroup ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " cli_session_setup returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
status = cli_tree_connect ( cli , share , " ????? " , " " , 0 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " cli_tree_connect returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2012-05-10 18:34:40 +02:00
status = smb2cli_create ( cli - > conn , cli - > timeout , cli - > smb2 . session ,
2012-07-23 22:32:49 +02:00
cli - > smb2 . tcon , " tcon_depedence.txt " ,
2011-09-19 10:09:34 +02:00
SMB2_OPLOCK_LEVEL_NONE , /* oplock_level, */
SMB2_IMPERSONATION_IMPERSONATION , /* impersonation_level, */
SEC_STD_ALL | SEC_FILE_ALL , /* desired_access, */
FILE_ATTRIBUTE_NORMAL , /* file_attributes, */
FILE_SHARE_READ | FILE_SHARE_WRITE | FILE_SHARE_DELETE , /* share_access, */
FILE_CREATE , /* create_disposition, */
FILE_DELETE_ON_CLOSE , /* create_options, */
NULL , /* smb2_create_blobs *blobs */
& fid_persistent ,
2013-08-07 15:01:50 -07:00
& fid_volatile ,
2014-06-27 09:32:34 +00:00
NULL , NULL , NULL ) ;
2011-09-19 10:09:34 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smb2cli_create on cli %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2012-05-10 18:40:56 +02:00
status = smb2cli_write ( cli - > conn , cli - > timeout , cli - > smb2 . session ,
2012-07-23 22:32:49 +02:00
cli - > smb2 . tcon , strlen ( hello ) , 0 , fid_persistent ,
2013-08-07 14:41:24 -07:00
fid_volatile , 0 , 0 , ( const uint8_t * ) hello , NULL ) ;
2011-09-19 10:09:34 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smb2cli_write returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2012-05-10 18:35:50 +02:00
status = smb2cli_flush ( cli - > conn , cli - > timeout , cli - > smb2 . session ,
2012-07-23 22:32:49 +02:00
cli - > smb2 . tcon , fid_persistent , fid_volatile ) ;
2011-09-19 10:09:34 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smb2cli_flush returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2012-05-10 18:30:25 +02:00
status = smb2cli_read ( cli - > conn , cli - > timeout , cli - > smb2 . session ,
2012-07-23 22:32:49 +02:00
cli - > smb2 . tcon , 0x10000 , 0 , fid_persistent ,
2012-05-10 18:30:25 +02:00
fid_volatile , 2 , 0 ,
talloc_tos ( ) , & result , & nread ) ;
2011-09-19 10:09:34 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smb2cli_read returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
if ( nread ! = strlen ( hello ) ) {
printf ( " smb2cli_read returned %d bytes, expected %d \n " ,
( int ) nread , ( int ) strlen ( hello ) ) ;
return false ;
}
if ( memcmp ( hello , result , nread ) ! = 0 ) {
printf ( " smb2cli_read returned '%s', expected '%s' \n " ,
result , hello ) ;
return false ;
}
/* check behaviour with wrong tid... */
2012-07-23 22:32:49 +02:00
tcon2 = smbXcli_tcon_create ( cli ) ;
tcon2_id = smb2cli_tcon_current_id ( cli - > smb2 . tcon ) ;
tcon2_id + + ;
smb2cli_tcon_set_values ( tcon2 ,
2012-07-25 12:33:39 +02:00
NULL , /* session */
2012-07-23 22:32:49 +02:00
tcon2_id ,
0 , /* type */
0 , /* flags */
0 , /* capabilities */
0 /* maximal_access */ ) ;
2011-09-19 10:09:34 +02:00
2012-05-10 18:30:25 +02:00
status = smb2cli_read ( cli - > conn , cli - > timeout , cli - > smb2 . session ,
2012-07-23 22:32:49 +02:00
tcon2 , 0x10000 , 0 , fid_persistent ,
2012-05-10 18:30:25 +02:00
fid_volatile , 2 , 0 ,
talloc_tos ( ) , & result , & nread ) ;
2011-09-19 10:09:34 +02:00
if ( ! NT_STATUS_EQUAL ( status , NT_STATUS_NETWORK_NAME_DELETED ) ) {
printf ( " smb2cli_read returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2012-07-23 22:32:49 +02:00
talloc_free ( tcon2 ) ;
2011-09-19 10:09:34 +02:00
return true ;
}
2011-10-22 10:34:31 +02:00
bool run_smb2_multi_channel ( int dummy )
{
struct cli_state * cli1 ;
struct cli_state * cli2 ;
2012-02-27 11:50:40 +01:00
struct cli_state * cli3 ;
2011-10-22 10:34:31 +02:00
NTSTATUS status ;
bool ok ;
uint64_t fid_persistent , fid_volatile ;
struct tevent_context * ev ;
struct tevent_req * subreq ;
DATA_BLOB in_blob = data_blob_null ;
DATA_BLOB out_blob ;
2012-02-27 08:48:55 +01:00
DATA_BLOB channel_session_key ;
2011-12-27 13:27:45 +11:00
struct auth_generic_state * auth_generic_state ;
2011-10-22 10:34:31 +02:00
struct iovec * recv_iov ;
const char * hello = " Hello, world \n " ;
uint8_t * result ;
uint32_t nread ;
printf ( " Starting SMB2-MULTI-CHANNEL \n " ) ;
if ( ! torture_init_connection ( & cli1 ) ) {
return false ;
}
if ( ! torture_init_connection ( & cli2 ) ) {
return false ;
}
2012-02-27 11:50:40 +01:00
if ( ! torture_init_connection ( & cli3 ) ) {
return false ;
}
2011-10-22 10:34:31 +02:00
status = smbXcli_negprot ( cli1 - > conn , cli1 - > timeout ,
2012-05-05 09:42:28 +02:00
PROTOCOL_SMB2_22 , PROTOCOL_LATEST ) ;
2011-10-22 10:34:31 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smbXcli_negprot returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
status = smbXcli_negprot ( cli2 - > conn , cli2 - > timeout ,
2012-05-05 09:42:28 +02:00
PROTOCOL_SMB2_22 , PROTOCOL_LATEST ) ;
2011-10-22 10:34:31 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smbXcli_negprot returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2012-02-27 11:50:40 +01:00
status = smbXcli_negprot ( cli3 - > conn , cli3 - > timeout ,
2012-05-05 09:42:28 +02:00
PROTOCOL_SMB2_22 , PROTOCOL_LATEST ) ;
2012-02-27 11:50:40 +01:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smbXcli_negprot returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2011-10-22 10:34:31 +02:00
status = cli_session_setup ( cli1 , username ,
password , strlen ( password ) ,
password , strlen ( password ) ,
workgroup ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smb2cli_sesssetup returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
status = cli_tree_connect ( cli1 , share , " ????? " , " " , 0 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " cli_tree_connect returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
status = smb2cli_session_create_channel ( cli2 ,
cli1 - > smb2 . session ,
cli2 - > conn ,
& cli2 - > smb2 . session ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smb2cli_session_create_channel returned %s \n " ,
nt_errstr ( status ) ) ;
return false ;
}
2011-12-27 13:27:45 +11:00
status = auth_generic_client_prepare ( talloc_tos ( ) , & auth_generic_state ) ;
2011-10-22 10:34:31 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
2011-12-27 13:27:45 +11:00
printf ( " auth_generic_client_prepare returned %s \n " , nt_errstr ( status ) ) ;
2011-10-22 10:34:31 +02:00
return false ;
}
2011-12-27 13:27:45 +11:00
gensec_want_feature ( auth_generic_state - > gensec_security ,
GENSEC_FEATURE_SESSION_KEY ) ;
status = auth_generic_set_username ( auth_generic_state , username ) ;
2011-10-22 10:34:31 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
2011-12-27 13:27:45 +11:00
printf ( " auth_generic_set_username returned %s \n " , nt_errstr ( status ) ) ;
2011-10-22 10:34:31 +02:00
return false ;
}
2011-12-27 13:27:45 +11:00
status = auth_generic_set_domain ( auth_generic_state , workgroup ) ;
2011-10-22 10:34:31 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
2011-12-27 13:27:45 +11:00
printf ( " auth_generic_set_domain returned %s \n " , nt_errstr ( status ) ) ;
2011-10-22 10:34:31 +02:00
return false ;
}
2011-12-27 13:27:45 +11:00
status = auth_generic_set_password ( auth_generic_state , password ) ;
2011-10-22 10:34:31 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
2011-12-27 13:27:45 +11:00
printf ( " auth_generic_set_password returned %s \n " , nt_errstr ( status ) ) ;
2011-10-22 10:34:31 +02:00
return false ;
}
2011-12-27 13:27:45 +11:00
status = auth_generic_client_start ( auth_generic_state , GENSEC_OID_NTLMSSP ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " auth_generic_client_start returned %s \n " , nt_errstr ( status ) ) ;
2011-10-22 10:34:31 +02:00
return false ;
}
2013-02-18 09:11:19 +01:00
ev = samba_tevent_context_init ( talloc_tos ( ) ) ;
2011-10-22 10:34:31 +02:00
if ( ev = = NULL ) {
2013-02-18 09:11:19 +01:00
printf ( " samba_tevent_context_init() returned NULL \n " ) ;
2011-10-22 10:34:31 +02:00
return false ;
}
2013-12-13 19:56:13 +01:00
status = gensec_update ( auth_generic_state - > gensec_security ,
talloc_tos ( ) , data_blob_null , & in_blob ) ;
2011-12-27 13:27:45 +11:00
if ( ! NT_STATUS_EQUAL ( status , NT_STATUS_MORE_PROCESSING_REQUIRED ) ) {
printf ( " gensec_update returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2011-10-22 10:34:31 +02:00
subreq = smb2cli_session_setup_send ( talloc_tos ( ) , ev ,
cli2 - > conn ,
cli2 - > timeout ,
cli2 - > smb2 . session ,
0x01 , /* in_flags */
SMB2_CAP_DFS , /* in_capabilities */
0 , /* in_channel */
2012-02-26 17:35:28 +01:00
0 , /* in_previous_session_id */
2011-10-22 10:34:31 +02:00
& in_blob ) ; /* in_security_buffer */
if ( subreq = = NULL ) {
printf ( " smb2cli_session_setup_send() returned NULL \n " ) ;
return false ;
}
ok = tevent_req_poll ( subreq , ev ) ;
if ( ! ok ) {
printf ( " tevent_req_poll() returned false \n " ) ;
return false ;
}
status = smb2cli_session_setup_recv ( subreq , talloc_tos ( ) ,
NULL , & out_blob ) ;
if ( ! NT_STATUS_EQUAL ( status , NT_STATUS_MORE_PROCESSING_REQUIRED ) ) {
printf ( " smb2cli_session_setup_recv returned %s \n " ,
nt_errstr ( status ) ) ;
return false ;
}
2013-12-13 19:56:13 +01:00
status = gensec_update ( auth_generic_state - > gensec_security ,
talloc_tos ( ) , out_blob , & in_blob ) ;
2011-10-22 10:34:31 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
2011-12-27 13:27:45 +11:00
printf ( " auth_generic_update returned %s \n " , nt_errstr ( status ) ) ;
2011-10-22 10:34:31 +02:00
return false ;
}
subreq = smb2cli_session_setup_send ( talloc_tos ( ) , ev ,
cli2 - > conn ,
cli2 - > timeout ,
cli2 - > smb2 . session ,
0x01 , /* in_flags */
SMB2_CAP_DFS , /* in_capabilities */
0 , /* in_channel */
2012-02-26 17:35:28 +01:00
0 , /* in_previous_session_id */
2011-10-22 10:34:31 +02:00
& in_blob ) ; /* in_security_buffer */
if ( subreq = = NULL ) {
printf ( " smb2cli_session_setup_send() returned NULL \n " ) ;
return false ;
}
ok = tevent_req_poll ( subreq , ev ) ;
if ( ! ok ) {
printf ( " tevent_req_poll() returned false \n " ) ;
return false ;
}
status = smb2cli_session_setup_recv ( subreq , talloc_tos ( ) ,
& recv_iov , & out_blob ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smb2cli_session_setup_recv returned %s \n " ,
nt_errstr ( status ) ) ;
return false ;
}
2011-12-27 13:27:45 +11:00
status = gensec_session_key ( auth_generic_state - > gensec_security , talloc_tos ( ) ,
2012-02-27 08:48:55 +01:00
& channel_session_key ) ;
2011-12-27 13:27:45 +11:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " gensec_session_key returned %s \n " ,
nt_errstr ( status ) ) ;
return false ;
}
2012-02-27 08:48:55 +01:00
status = smb2cli_session_set_channel_key ( cli2 - > smb2 . session ,
channel_session_key ,
recv_iov ) ;
2011-10-22 10:34:31 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
2012-02-27 08:48:55 +01:00
printf ( " smb2cli_session_set_channel_key %s \n " , nt_errstr ( status ) ) ;
2011-10-22 10:34:31 +02:00
return false ;
}
2012-02-27 11:50:40 +01:00
status = smb2cli_session_create_channel ( cli3 ,
2012-07-23 13:34:05 +02:00
cli1 - > smb2 . session ,
2012-02-27 11:50:40 +01:00
cli3 - > conn ,
& cli3 - > smb2 . session ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smb2cli_session_create_channel returned %s \n " ,
nt_errstr ( status ) ) ;
return false ;
}
status = auth_generic_client_prepare ( talloc_tos ( ) , & auth_generic_state ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " auth_generic_client_prepare returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
gensec_want_feature ( auth_generic_state - > gensec_security ,
GENSEC_FEATURE_SESSION_KEY ) ;
status = auth_generic_set_username ( auth_generic_state , username ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " auth_generic_set_username returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
status = auth_generic_set_domain ( auth_generic_state , workgroup ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " auth_generic_set_domain returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
status = auth_generic_set_password ( auth_generic_state , password ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " auth_generic_set_password returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
status = auth_generic_client_start ( auth_generic_state , GENSEC_OID_NTLMSSP ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " auth_generic_client_start returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2013-12-13 19:56:13 +01:00
status = gensec_update ( auth_generic_state - > gensec_security ,
talloc_tos ( ) , data_blob_null , & in_blob ) ;
2012-02-27 11:50:40 +01:00
if ( ! NT_STATUS_EQUAL ( status , NT_STATUS_MORE_PROCESSING_REQUIRED ) ) {
printf ( " gensec_update returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
subreq = smb2cli_session_setup_send ( talloc_tos ( ) , ev ,
cli3 - > conn ,
cli3 - > timeout ,
cli3 - > smb2 . session ,
0x01 , /* in_flags */
SMB2_CAP_DFS , /* in_capabilities */
0 , /* in_channel */
0 , /* in_previous_session_id */
& in_blob ) ; /* in_security_buffer */
if ( subreq = = NULL ) {
printf ( " smb2cli_session_setup_send() returned NULL \n " ) ;
return false ;
}
ok = tevent_req_poll ( subreq , ev ) ;
if ( ! ok ) {
printf ( " tevent_req_poll() returned false \n " ) ;
return false ;
}
status = smb2cli_session_setup_recv ( subreq , talloc_tos ( ) ,
NULL , & out_blob ) ;
if ( ! NT_STATUS_EQUAL ( status , NT_STATUS_MORE_PROCESSING_REQUIRED ) ) {
printf ( " smb2cli_session_setup_recv returned %s \n " ,
nt_errstr ( status ) ) ;
return false ;
}
2013-12-13 19:56:13 +01:00
status = gensec_update ( auth_generic_state - > gensec_security ,
talloc_tos ( ) , out_blob , & in_blob ) ;
2012-02-27 11:50:40 +01:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " auth_generic_update returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
subreq = smb2cli_session_setup_send ( talloc_tos ( ) , ev ,
cli3 - > conn ,
cli3 - > timeout ,
cli3 - > smb2 . session ,
0x01 , /* in_flags */
SMB2_CAP_DFS , /* in_capabilities */
0 , /* in_channel */
0 , /* in_previous_session_id */
& in_blob ) ; /* in_security_buffer */
if ( subreq = = NULL ) {
printf ( " smb2cli_session_setup_send() returned NULL \n " ) ;
return false ;
}
ok = tevent_req_poll ( subreq , ev ) ;
if ( ! ok ) {
printf ( " tevent_req_poll() returned false \n " ) ;
return false ;
}
status = smb2cli_session_setup_recv ( subreq , talloc_tos ( ) ,
& recv_iov , & out_blob ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smb2cli_session_setup_recv returned %s \n " ,
nt_errstr ( status ) ) ;
return false ;
}
status = gensec_session_key ( auth_generic_state - > gensec_security , talloc_tos ( ) ,
& channel_session_key ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " gensec_session_key returned %s \n " ,
nt_errstr ( status ) ) ;
return false ;
}
status = smb2cli_session_set_channel_key ( cli3 - > smb2 . session ,
channel_session_key ,
recv_iov ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smb2cli_session_set_channel_key %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2012-05-10 18:34:40 +02:00
status = smb2cli_create ( cli2 - > conn , cli2 - > timeout , cli2 - > smb2 . session ,
2012-07-25 09:01:02 +02:00
cli1 - > smb2 . tcon , " multi-channel.txt " ,
2011-10-22 10:34:31 +02:00
SMB2_OPLOCK_LEVEL_NONE , /* oplock_level, */
SMB2_IMPERSONATION_IMPERSONATION , /* impersonation_level, */
SEC_STD_ALL | SEC_FILE_ALL , /* desired_access, */
FILE_ATTRIBUTE_NORMAL , /* file_attributes, */
FILE_SHARE_READ | FILE_SHARE_WRITE | FILE_SHARE_DELETE , /* share_access, */
FILE_CREATE , /* create_disposition, */
FILE_DELETE_ON_CLOSE , /* create_options, */
NULL , /* smb2_create_blobs *blobs */
& fid_persistent ,
2013-08-07 15:01:50 -07:00
& fid_volatile ,
2014-06-27 09:32:34 +00:00
NULL , NULL , NULL ) ;
2011-10-22 10:34:31 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smb2cli_create on cli2 %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2012-05-10 18:40:56 +02:00
status = smb2cli_write ( cli1 - > conn , cli1 - > timeout , cli1 - > smb2 . session ,
2012-07-23 22:32:49 +02:00
cli1 - > smb2 . tcon , strlen ( hello ) , 0 , fid_persistent ,
2013-08-07 14:41:24 -07:00
fid_volatile , 0 , 0 , ( const uint8_t * ) hello , NULL ) ;
2011-10-22 10:34:31 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smb2cli_write returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2012-05-10 18:35:50 +02:00
status = smb2cli_flush ( cli2 - > conn , cli2 - > timeout , cli2 - > smb2 . session ,
2012-07-25 09:01:02 +02:00
cli1 - > smb2 . tcon , fid_persistent , fid_volatile ) ;
2011-10-22 10:34:31 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smb2cli_flush returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2012-05-10 18:35:50 +02:00
status = smb2cli_flush ( cli1 - > conn , cli1 - > timeout , cli1 - > smb2 . session ,
2012-07-23 22:32:49 +02:00
cli1 - > smb2 . tcon , fid_persistent , fid_volatile ) ;
2011-10-22 10:34:31 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smb2cli_flush returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2012-05-10 18:35:50 +02:00
status = smb2cli_flush ( cli3 - > conn , cli3 - > timeout , cli3 - > smb2 . session ,
2012-07-25 09:01:02 +02:00
cli1 - > smb2 . tcon , fid_persistent , fid_volatile ) ;
2012-02-27 11:50:40 +01:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smb2cli_flush returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2012-05-10 18:30:25 +02:00
status = smb2cli_read ( cli2 - > conn , cli2 - > timeout , cli2 - > smb2 . session ,
2012-07-25 09:01:02 +02:00
cli1 - > smb2 . tcon , 0x10000 , 0 , fid_persistent ,
2012-05-10 18:30:25 +02:00
fid_volatile , 2 , 0 ,
talloc_tos ( ) , & result , & nread ) ;
2011-10-22 10:34:31 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smb2cli_read returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
if ( nread ! = strlen ( hello ) ) {
printf ( " smb2cli_read returned %d bytes, expected %d \n " ,
( int ) nread , ( int ) strlen ( hello ) ) ;
return false ;
}
if ( memcmp ( hello , result , nread ) ! = 0 ) {
printf ( " smb2cli_read returned '%s', expected '%s' \n " ,
result , hello ) ;
return false ;
}
2012-02-27 11:19:22 +01:00
status = auth_generic_client_prepare ( talloc_tos ( ) , & auth_generic_state ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " auth_generic_client_prepare returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
gensec_want_feature ( auth_generic_state - > gensec_security ,
GENSEC_FEATURE_SESSION_KEY ) ;
status = auth_generic_set_username ( auth_generic_state , username ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " auth_generic_set_username returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
status = auth_generic_set_domain ( auth_generic_state , workgroup ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " auth_generic_set_domain returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
status = auth_generic_set_password ( auth_generic_state , password ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " auth_generic_set_password returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
status = auth_generic_client_start ( auth_generic_state , GENSEC_OID_NTLMSSP ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " auth_generic_client_start returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2013-12-13 19:56:13 +01:00
status = gensec_update ( auth_generic_state - > gensec_security ,
talloc_tos ( ) , data_blob_null , & in_blob ) ;
2012-02-27 11:19:22 +01:00
if ( ! NT_STATUS_EQUAL ( status , NT_STATUS_MORE_PROCESSING_REQUIRED ) ) {
printf ( " gensec_update returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
subreq = smb2cli_session_setup_send ( talloc_tos ( ) , ev ,
cli3 - > conn ,
cli3 - > timeout ,
cli3 - > smb2 . session ,
0x0 , /* in_flags */
SMB2_CAP_DFS , /* in_capabilities */
0 , /* in_channel */
0 , /* in_previous_session_id */
& in_blob ) ; /* in_security_buffer */
if ( subreq = = NULL ) {
printf ( " smb2cli_session_setup_send() returned NULL \n " ) ;
return false ;
}
ok = tevent_req_poll ( subreq , ev ) ;
if ( ! ok ) {
printf ( " tevent_req_poll() returned false \n " ) ;
return false ;
}
status = smb2cli_session_setup_recv ( subreq , talloc_tos ( ) ,
NULL , & out_blob ) ;
if ( ! NT_STATUS_EQUAL ( status , NT_STATUS_MORE_PROCESSING_REQUIRED ) ) {
printf ( " smb2cli_session_setup_recv returned %s \n " ,
nt_errstr ( status ) ) ;
return false ;
}
2013-12-13 19:56:13 +01:00
status = gensec_update ( auth_generic_state - > gensec_security ,
talloc_tos ( ) , out_blob , & in_blob ) ;
2012-02-27 13:27:38 +01:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " auth_generic_update returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2012-05-10 18:35:50 +02:00
status = smb2cli_flush ( cli1 - > conn , cli1 - > timeout , cli1 - > smb2 . session ,
2012-07-23 22:32:49 +02:00
cli1 - > smb2 . tcon , fid_persistent , fid_volatile ) ;
2012-02-27 13:27:38 +01:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smb2cli_flush returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2012-05-10 18:35:50 +02:00
status = smb2cli_flush ( cli2 - > conn , cli2 - > timeout , cli2 - > smb2 . session ,
2012-07-25 09:01:02 +02:00
cli1 - > smb2 . tcon , fid_persistent , fid_volatile ) ;
2012-02-27 13:27:38 +01:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smb2cli_flush returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2012-05-10 18:35:50 +02:00
status = smb2cli_flush ( cli3 - > conn , cli3 - > timeout , cli3 - > smb2 . session ,
2012-07-25 09:01:02 +02:00
cli1 - > smb2 . tcon , fid_persistent , fid_volatile ) ;
2012-02-27 13:27:38 +01:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smb2cli_flush returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2012-05-10 18:34:40 +02:00
status = smb2cli_create ( cli1 - > conn , cli1 - > timeout , cli1 - > smb2 . session ,
2012-07-23 22:32:49 +02:00
cli1 - > smb2 . tcon , " multi-channel-invalid.txt " ,
2012-02-27 13:27:38 +01:00
SMB2_OPLOCK_LEVEL_NONE , /* oplock_level, */
SMB2_IMPERSONATION_IMPERSONATION , /* impersonation_level, */
SEC_STD_ALL | SEC_FILE_ALL , /* desired_access, */
FILE_ATTRIBUTE_NORMAL , /* file_attributes, */
FILE_SHARE_READ | FILE_SHARE_WRITE | FILE_SHARE_DELETE , /* share_access, */
FILE_CREATE , /* create_disposition, */
FILE_DELETE_ON_CLOSE , /* create_options, */
NULL , /* smb2_create_blobs *blobs */
& fid_persistent ,
2013-08-07 15:01:50 -07:00
& fid_volatile ,
2014-06-27 09:32:34 +00:00
NULL , NULL , NULL ) ;
2012-02-27 13:27:38 +01:00
if ( ! NT_STATUS_EQUAL ( status , NT_STATUS_INVALID_HANDLE ) ) {
printf ( " smb2cli_create %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2012-05-10 18:34:40 +02:00
status = smb2cli_create ( cli2 - > conn , cli2 - > timeout , cli2 - > smb2 . session ,
2012-07-25 09:01:02 +02:00
cli1 - > smb2 . tcon , " multi-channel-invalid.txt " ,
2012-02-27 13:27:38 +01:00
SMB2_OPLOCK_LEVEL_NONE , /* oplock_level, */
SMB2_IMPERSONATION_IMPERSONATION , /* impersonation_level, */
SEC_STD_ALL | SEC_FILE_ALL , /* desired_access, */
FILE_ATTRIBUTE_NORMAL , /* file_attributes, */
FILE_SHARE_READ | FILE_SHARE_WRITE | FILE_SHARE_DELETE , /* share_access, */
FILE_CREATE , /* create_disposition, */
FILE_DELETE_ON_CLOSE , /* create_options, */
NULL , /* smb2_create_blobs *blobs */
& fid_persistent ,
2013-08-07 15:01:50 -07:00
& fid_volatile ,
2014-06-27 09:32:34 +00:00
NULL , NULL , NULL ) ;
2012-02-27 13:27:38 +01:00
if ( ! NT_STATUS_EQUAL ( status , NT_STATUS_INVALID_HANDLE ) ) {
printf ( " smb2cli_create %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2012-05-10 18:34:40 +02:00
status = smb2cli_create ( cli3 - > conn , cli3 - > timeout , cli3 - > smb2 . session ,
2012-07-25 09:01:02 +02:00
cli1 - > smb2 . tcon , " multi-channel-invalid.txt " ,
2012-02-27 13:27:38 +01:00
SMB2_OPLOCK_LEVEL_NONE , /* oplock_level, */
SMB2_IMPERSONATION_IMPERSONATION , /* impersonation_level, */
SEC_STD_ALL | SEC_FILE_ALL , /* desired_access, */
FILE_ATTRIBUTE_NORMAL , /* file_attributes, */
FILE_SHARE_READ | FILE_SHARE_WRITE | FILE_SHARE_DELETE , /* share_access, */
FILE_CREATE , /* create_disposition, */
FILE_DELETE_ON_CLOSE , /* create_options, */
NULL , /* smb2_create_blobs *blobs */
& fid_persistent ,
2013-08-07 15:01:50 -07:00
& fid_volatile ,
2014-06-27 09:32:34 +00:00
NULL , NULL , NULL ) ;
2012-02-27 13:27:38 +01:00
if ( ! NT_STATUS_EQUAL ( status , NT_STATUS_INVALID_HANDLE ) ) {
printf ( " smb2cli_create %s \n " , nt_errstr ( status ) ) ;
2012-02-27 11:19:22 +01:00
return false ;
}
subreq = smb2cli_session_setup_send ( talloc_tos ( ) , ev ,
cli2 - > conn ,
cli2 - > timeout ,
cli2 - > smb2 . session ,
0x0 , /* in_flags */
SMB2_CAP_DFS , /* in_capabilities */
0 , /* in_channel */
0 , /* in_previous_session_id */
& in_blob ) ; /* in_security_buffer */
if ( subreq = = NULL ) {
printf ( " smb2cli_session_setup_send() returned NULL \n " ) ;
return false ;
}
ok = tevent_req_poll ( subreq , ev ) ;
if ( ! ok ) {
printf ( " tevent_req_poll() returned false \n " ) ;
return false ;
}
status = smb2cli_session_setup_recv ( subreq , talloc_tos ( ) ,
& recv_iov , & out_blob ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smb2cli_session_setup_recv returned %s \n " ,
nt_errstr ( status ) ) ;
return false ;
}
2012-05-10 18:32:49 +02:00
status = smb2cli_close ( cli3 - > conn , cli3 - > timeout , cli3 - > smb2 . session ,
2012-07-25 09:01:02 +02:00
cli1 - > smb2 . tcon , 0 , fid_persistent , fid_volatile ) ;
2011-10-22 10:34:31 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smb2cli_close returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2012-05-10 18:35:50 +02:00
status = smb2cli_flush ( cli3 - > conn , cli3 - > timeout , cli3 - > smb2 . session ,
2012-07-25 09:01:02 +02:00
cli1 - > smb2 . tcon , fid_persistent , fid_volatile ) ;
2012-02-27 11:50:40 +01:00
if ( ! NT_STATUS_EQUAL ( status , NT_STATUS_FILE_CLOSED ) ) {
printf ( " smb2cli_flush returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2012-05-10 18:35:50 +02:00
status = smb2cli_flush ( cli2 - > conn , cli2 - > timeout , cli2 - > smb2 . session ,
2012-07-25 09:01:02 +02:00
cli1 - > smb2 . tcon , fid_persistent , fid_volatile ) ;
2012-02-29 03:57:34 +01:00
if ( ! NT_STATUS_EQUAL ( status , NT_STATUS_FILE_CLOSED ) ) {
2011-10-22 10:34:31 +02:00
printf ( " smb2cli_flush returned %s \n " , nt_errstr ( status ) ) ;
2012-02-29 03:57:34 +01:00
return false ;
2011-10-22 10:34:31 +02:00
}
2012-05-10 18:35:50 +02:00
status = smb2cli_flush ( cli1 - > conn , cli1 - > timeout , cli1 - > smb2 . session ,
2012-07-23 22:32:49 +02:00
cli1 - > smb2 . tcon , fid_persistent , fid_volatile ) ;
2012-02-29 03:57:34 +01:00
if ( ! NT_STATUS_EQUAL ( status , NT_STATUS_FILE_CLOSED ) ) {
2011-10-22 10:34:31 +02:00
printf ( " smb2cli_flush returned %s \n " , nt_errstr ( status ) ) ;
2012-02-29 03:57:34 +01:00
return false ;
2011-10-22 10:34:31 +02:00
}
return true ;
}
2011-10-22 10:37:34 +02:00
bool run_smb2_session_reauth ( int dummy )
{
struct cli_state * cli ;
NTSTATUS status ;
bool ok ;
uint64_t fid_persistent , fid_volatile ;
2012-02-28 04:24:12 +01:00
uint64_t dir_persistent , dir_volatile ;
uint8_t * dir_data ;
uint32_t dir_data_length ;
2011-10-22 10:37:34 +02:00
struct tevent_context * ev ;
struct tevent_req * subreq ;
DATA_BLOB in_blob = data_blob_null ;
DATA_BLOB out_blob ;
2012-05-03 12:07:11 +02:00
DATA_BLOB in_input_buffer ;
DATA_BLOB out_output_buffer ;
uint8_t in_file_info_class ;
2011-12-27 13:27:45 +11:00
struct auth_generic_state * auth_generic_state ;
2011-10-22 10:37:34 +02:00
struct iovec * recv_iov ;
2012-02-28 05:11:23 +01:00
uint32_t saved_tid ;
2012-07-24 20:11:25 +02:00
struct smbXcli_tcon * saved_tcon ;
2011-10-22 10:37:34 +02:00
printf ( " Starting SMB2-SESSION_REAUTH \n " ) ;
if ( ! torture_init_connection ( & cli ) ) {
return false ;
}
/*
* PROTOCOL_SMB2_22 has a bug in win8pre0
* it behaves like PROTOCOL_SMB2_02
* and returns NT_STATUS_REQUEST_NOT_ACCEPTED ,
* while it allows it on PROTOCOL_SMB2_02 .
*/
status = smbXcli_negprot ( cli - > conn , cli - > timeout ,
PROTOCOL_SMB2_10 , PROTOCOL_SMB2_10 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smbXcli_negprot returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
status = cli_session_setup ( cli , username ,
password , strlen ( password ) ,
password , strlen ( password ) ,
workgroup ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smb2cli_sesssetup returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
status = cli_tree_connect ( cli , share , " ????? " , " " , 0 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " cli_tree_connect returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2012-05-10 18:34:40 +02:00
status = smb2cli_create ( cli - > conn , cli - > timeout , cli - > smb2 . session ,
2012-07-23 22:32:49 +02:00
cli - > smb2 . tcon , " session-reauth.txt " ,
2011-10-22 10:37:34 +02:00
SMB2_OPLOCK_LEVEL_NONE , /* oplock_level, */
SMB2_IMPERSONATION_IMPERSONATION , /* impersonation_level, */
SEC_STD_ALL | SEC_FILE_ALL , /* desired_access, */
FILE_ATTRIBUTE_NORMAL , /* file_attributes, */
FILE_SHARE_READ | FILE_SHARE_WRITE | FILE_SHARE_DELETE , /* share_access, */
FILE_CREATE , /* create_disposition, */
FILE_DELETE_ON_CLOSE , /* create_options, */
NULL , /* smb2_create_blobs *blobs */
& fid_persistent ,
2013-08-07 15:01:50 -07:00
& fid_volatile ,
2014-06-27 09:32:34 +00:00
NULL , NULL , NULL ) ;
2011-10-22 10:37:34 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smb2cli_create %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2012-05-10 18:34:40 +02:00
status = smb2cli_create ( cli - > conn , cli - > timeout , cli - > smb2 . session ,
2012-07-23 22:32:49 +02:00
cli - > smb2 . tcon , " " ,
2012-02-28 04:24:12 +01:00
SMB2_OPLOCK_LEVEL_NONE , /* oplock_level, */
SMB2_IMPERSONATION_IMPERSONATION , /* impersonation_level, */
SEC_STD_SYNCHRONIZE |
SEC_DIR_LIST |
SEC_DIR_READ_ATTRIBUTE , /* desired_access, */
0 , /* file_attributes, */
FILE_SHARE_READ | FILE_SHARE_WRITE | FILE_SHARE_DELETE , /* share_access, */
FILE_OPEN , /* create_disposition, */
FILE_SYNCHRONOUS_IO_NONALERT | FILE_DIRECTORY_FILE , /* create_options, */
NULL , /* smb2_create_blobs *blobs */
& dir_persistent ,
2013-08-07 15:01:50 -07:00
& dir_volatile ,
2014-06-27 09:32:34 +00:00
NULL , NULL , NULL ) ;
2012-02-28 04:24:12 +01:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smb2cli_create returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
status = smb2cli_query_directory (
2012-07-23 22:32:49 +02:00
cli - > conn , cli - > timeout , cli - > smb2 . session , cli - > smb2 . tcon ,
2012-05-10 18:37:43 +02:00
1 , 0x3 , 0 , dir_persistent , dir_volatile ,
2012-02-28 04:24:12 +01:00
" session-reauth.txt " , 0xffff ,
talloc_tos ( ) , & dir_data , & dir_data_length ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smb2cli_query_directory returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2011-12-27 13:27:45 +11:00
status = auth_generic_client_prepare ( talloc_tos ( ) , & auth_generic_state ) ;
2011-10-22 10:37:34 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
2011-12-27 13:27:45 +11:00
printf ( " auth_generic_client_prepare returned %s \n " , nt_errstr ( status ) ) ;
2011-10-22 10:37:34 +02:00
return false ;
}
2011-12-27 13:27:45 +11:00
gensec_want_feature ( auth_generic_state - > gensec_security ,
GENSEC_FEATURE_SESSION_KEY ) ;
status = auth_generic_set_username ( auth_generic_state , username ) ;
2011-10-22 10:37:34 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
2011-12-27 13:27:45 +11:00
printf ( " auth_generic_set_username returned %s \n " , nt_errstr ( status ) ) ;
2011-10-22 10:37:34 +02:00
return false ;
}
2011-12-27 13:27:45 +11:00
status = auth_generic_set_domain ( auth_generic_state , workgroup ) ;
2011-10-22 10:37:34 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
2011-12-27 13:27:45 +11:00
printf ( " auth_generic_set_domain returned %s \n " , nt_errstr ( status ) ) ;
2011-10-22 10:37:34 +02:00
return false ;
}
2011-12-27 13:27:45 +11:00
status = auth_generic_set_password ( auth_generic_state , password ) ;
2011-10-22 10:37:34 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
2011-12-27 13:27:45 +11:00
printf ( " auth_generic_set_password returned %s \n " , nt_errstr ( status ) ) ;
2011-10-22 10:37:34 +02:00
return false ;
}
2011-12-27 13:27:45 +11:00
status = auth_generic_client_start ( auth_generic_state , GENSEC_OID_NTLMSSP ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " auth_generic_client_start returned %s \n " , nt_errstr ( status ) ) ;
2011-10-22 10:37:34 +02:00
return false ;
}
2013-02-18 09:11:19 +01:00
ev = samba_tevent_context_init ( talloc_tos ( ) ) ;
2011-10-22 10:37:34 +02:00
if ( ev = = NULL ) {
2013-02-18 09:11:19 +01:00
printf ( " samba_tevent_context_init() returned NULL \n " ) ;
2011-10-22 10:37:34 +02:00
return false ;
}
2013-12-13 19:56:13 +01:00
status = gensec_update ( auth_generic_state - > gensec_security ,
talloc_tos ( ) , data_blob_null , & in_blob ) ;
2011-12-27 13:27:45 +11:00
if ( ! NT_STATUS_EQUAL ( status , NT_STATUS_MORE_PROCESSING_REQUIRED ) ) {
printf ( " gensec_update returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2011-10-22 10:37:34 +02:00
subreq = smb2cli_session_setup_send ( talloc_tos ( ) , ev ,
cli - > conn ,
cli - > timeout ,
cli - > smb2 . session ,
0x0 , /* in_flags */
SMB2_CAP_DFS , /* in_capabilities */
0 , /* in_channel */
2012-02-26 17:35:28 +01:00
0 , /* in_previous_session_id */
2011-10-22 10:37:34 +02:00
& in_blob ) ; /* in_security_buffer */
if ( subreq = = NULL ) {
printf ( " smb2cli_session_setup_send() returned NULL \n " ) ;
return false ;
}
ok = tevent_req_poll ( subreq , ev ) ;
if ( ! ok ) {
printf ( " tevent_req_poll() returned false \n " ) ;
return false ;
}
status = smb2cli_session_setup_recv ( subreq , talloc_tos ( ) ,
NULL , & out_blob ) ;
if ( ! NT_STATUS_EQUAL ( status , NT_STATUS_MORE_PROCESSING_REQUIRED ) ) {
printf ( " smb2cli_session_setup_recv returned %s \n " ,
nt_errstr ( status ) ) ;
return false ;
}
2013-12-13 19:56:13 +01:00
status = gensec_update ( auth_generic_state - > gensec_security ,
talloc_tos ( ) , out_blob , & in_blob ) ;
2011-10-22 10:37:34 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
2011-12-27 13:27:45 +11:00
printf ( " auth_generic_update returned %s \n " , nt_errstr ( status ) ) ;
2011-10-22 10:37:34 +02:00
return false ;
}
2012-05-10 18:35:50 +02:00
status = smb2cli_flush ( cli - > conn , cli - > timeout , cli - > smb2 . session ,
2012-07-23 22:32:49 +02:00
cli - > smb2 . tcon , fid_persistent , fid_volatile ) ;
2012-02-27 13:18:42 +01:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smb2cli_flush returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2012-02-28 04:24:12 +01:00
status = smb2cli_query_directory (
2012-07-23 22:32:49 +02:00
cli - > conn , cli - > timeout , cli - > smb2 . session , cli - > smb2 . tcon ,
2012-05-10 18:37:43 +02:00
1 , 0x3 , 0 , dir_persistent , dir_volatile ,
2012-02-28 04:24:12 +01:00
" session-reauth.txt " , 0xffff ,
talloc_tos ( ) , & dir_data , & dir_data_length ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smb2cli_query_directory returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2012-05-03 12:07:11 +02:00
/*
* query_info seems to be a path based operation on Windows . . .
*/
status = smb2cli_query_info ( cli - > conn ,
cli - > timeout ,
cli - > smb2 . session ,
2012-07-23 22:32:49 +02:00
cli - > smb2 . tcon ,
2012-05-03 12:07:11 +02:00
SMB2_GETINFO_SECURITY ,
0 , /* in_file_info_class */
1024 , /* in_max_output_length */
NULL , /* in_input_buffer */
SECINFO_OWNER , /* in_additional_info */
0 , /* in_flags */
fid_persistent ,
fid_volatile ,
talloc_tos ( ) ,
& out_output_buffer ) ;
if ( ! NT_STATUS_EQUAL ( status , NT_STATUS_INVALID_HANDLE ) ) {
printf ( " smb2cli_query_info (security) returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
in_file_info_class = SMB_FILE_POSITION_INFORMATION - 1000 ;
status = smb2cli_query_info ( cli - > conn ,
cli - > timeout ,
cli - > smb2 . session ,
2012-07-23 22:32:49 +02:00
cli - > smb2 . tcon ,
2012-05-03 12:07:11 +02:00
SMB2_GETINFO_FILE ,
in_file_info_class ,
1024 , /* in_max_output_length */
NULL , /* in_input_buffer */
0 , /* in_additional_info */
0 , /* in_flags */
fid_persistent ,
fid_volatile ,
talloc_tos ( ) ,
& out_output_buffer ) ;
if ( ! NT_STATUS_EQUAL ( status , NT_STATUS_INVALID_HANDLE ) ) {
printf ( " smb2cli_query_info (position) returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
in_input_buffer = data_blob_talloc ( talloc_tos ( ) , NULL , 8 ) ;
SBVAL ( in_input_buffer . data , 0 , 512 ) ;
in_file_info_class = SMB_FILE_POSITION_INFORMATION - 1000 ;
status = smb2cli_set_info ( cli - > conn ,
cli - > timeout ,
cli - > smb2 . session ,
2012-07-23 22:32:49 +02:00
cli - > smb2 . tcon ,
2012-05-03 12:07:11 +02:00
SMB2_GETINFO_FILE ,
in_file_info_class ,
& in_input_buffer ,
0 , /* in_additional_info */
fid_persistent ,
fid_volatile ) ;
if ( ! NT_STATUS_EQUAL ( status , NT_STATUS_INVALID_HANDLE ) ) {
printf ( " smb2cli_set_info (position) returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2012-05-10 18:34:40 +02:00
status = smb2cli_create ( cli - > conn , cli - > timeout , cli - > smb2 . session ,
2012-07-23 22:32:49 +02:00
cli - > smb2 . tcon , " session-reauth-invalid.txt " ,
2012-02-27 13:23:53 +01:00
SMB2_OPLOCK_LEVEL_NONE , /* oplock_level, */
SMB2_IMPERSONATION_IMPERSONATION , /* impersonation_level, */
SEC_STD_ALL | SEC_FILE_ALL , /* desired_access, */
FILE_ATTRIBUTE_NORMAL , /* file_attributes, */
FILE_SHARE_READ | FILE_SHARE_WRITE | FILE_SHARE_DELETE , /* share_access, */
FILE_CREATE , /* create_disposition, */
FILE_DELETE_ON_CLOSE , /* create_options, */
NULL , /* smb2_create_blobs *blobs */
& fid_persistent ,
2013-08-07 15:01:50 -07:00
& fid_volatile ,
2014-06-27 09:32:34 +00:00
NULL , NULL , NULL ) ;
2012-02-27 13:23:53 +01:00
if ( ! NT_STATUS_EQUAL ( status , NT_STATUS_INVALID_HANDLE ) ) {
printf ( " smb2cli_create %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2012-05-10 18:34:40 +02:00
status = smb2cli_create ( cli - > conn , cli - > timeout , cli - > smb2 . session ,
2012-07-23 22:32:49 +02:00
cli - > smb2 . tcon , " " ,
2012-02-28 04:24:12 +01:00
SMB2_OPLOCK_LEVEL_NONE , /* oplock_level, */
SMB2_IMPERSONATION_IMPERSONATION , /* impersonation_level, */
SEC_STD_SYNCHRONIZE |
SEC_DIR_LIST |
SEC_DIR_READ_ATTRIBUTE , /* desired_access, */
0 , /* file_attributes, */
FILE_SHARE_READ | FILE_SHARE_WRITE | FILE_SHARE_DELETE , /* share_access, */
FILE_OPEN , /* create_disposition, */
FILE_SYNCHRONOUS_IO_NONALERT | FILE_DIRECTORY_FILE , /* create_options, */
NULL , /* smb2_create_blobs *blobs */
& dir_persistent ,
2013-08-07 15:01:50 -07:00
& dir_volatile ,
2014-06-27 09:32:34 +00:00
NULL , NULL , NULL ) ;
2012-02-28 04:24:12 +01:00
if ( ! NT_STATUS_EQUAL ( status , NT_STATUS_INVALID_HANDLE ) ) {
printf ( " smb2cli_create returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2012-07-25 09:01:02 +02:00
saved_tid = smb2cli_tcon_current_id ( cli - > smb2 . tcon ) ;
2012-07-24 20:11:25 +02:00
saved_tcon = cli - > smb2 . tcon ;
cli - > smb2 . tcon = smbXcli_tcon_create ( cli ) ;
smb2cli_tcon_set_values ( cli - > smb2 . tcon ,
2012-07-25 12:33:39 +02:00
NULL , /* session */
2012-07-24 20:11:25 +02:00
saved_tid ,
0 , /* type */
0 , /* flags */
0 , /* capabilities */
0 /* maximal_access */ ) ;
2012-02-28 05:11:23 +01:00
status = cli_tree_connect ( cli , share , " ????? " , " " , 0 ) ;
if ( ! NT_STATUS_EQUAL ( status , NT_STATUS_INVALID_HANDLE ) ) {
printf ( " cli_tree_connect returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2012-07-24 20:11:25 +02:00
talloc_free ( cli - > smb2 . tcon ) ;
cli - > smb2 . tcon = saved_tcon ;
2012-02-28 05:11:23 +01:00
2011-10-22 10:37:34 +02:00
subreq = smb2cli_session_setup_send ( talloc_tos ( ) , ev ,
cli - > conn ,
cli - > timeout ,
cli - > smb2 . session ,
0x0 , /* in_flags */
SMB2_CAP_DFS , /* in_capabilities */
0 , /* in_channel */
2012-02-26 17:35:28 +01:00
0 , /* in_previous_session_id */
2011-10-22 10:37:34 +02:00
& in_blob ) ; /* in_security_buffer */
if ( subreq = = NULL ) {
printf ( " smb2cli_session_setup_send() returned NULL \n " ) ;
return false ;
}
ok = tevent_req_poll ( subreq , ev ) ;
if ( ! ok ) {
printf ( " tevent_req_poll() returned false \n " ) ;
return false ;
}
status = smb2cli_session_setup_recv ( subreq , talloc_tos ( ) ,
& recv_iov , & out_blob ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smb2cli_session_setup_recv returned %s \n " ,
nt_errstr ( status ) ) ;
return false ;
}
2012-05-10 18:35:50 +02:00
status = smb2cli_flush ( cli - > conn , cli - > timeout , cli - > smb2 . session ,
2012-07-23 22:32:49 +02:00
cli - > smb2 . tcon , fid_persistent , fid_volatile ) ;
2011-10-22 10:37:34 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smb2cli_flush returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2012-05-03 12:07:11 +02:00
status = smb2cli_query_info ( cli - > conn ,
cli - > timeout ,
cli - > smb2 . session ,
2012-07-23 22:32:49 +02:00
cli - > smb2 . tcon ,
2012-05-03 12:07:11 +02:00
SMB2_GETINFO_SECURITY ,
0 , /* in_file_info_class */
1024 , /* in_max_output_length */
NULL , /* in_input_buffer */
SECINFO_OWNER , /* in_additional_info */
0 , /* in_flags */
fid_persistent ,
fid_volatile ,
talloc_tos ( ) ,
& out_output_buffer ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smb2cli_query_info (security) returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
in_file_info_class = SMB_FILE_POSITION_INFORMATION - 1000 ;
status = smb2cli_query_info ( cli - > conn ,
cli - > timeout ,
cli - > smb2 . session ,
2012-07-23 22:32:49 +02:00
cli - > smb2 . tcon ,
2012-05-03 12:07:11 +02:00
SMB2_GETINFO_FILE ,
in_file_info_class ,
1024 , /* in_max_output_length */
NULL , /* in_input_buffer */
0 , /* in_additional_info */
0 , /* in_flags */
fid_persistent ,
fid_volatile ,
talloc_tos ( ) ,
& out_output_buffer ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smb2cli_query_info (position) returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
in_input_buffer = data_blob_talloc ( talloc_tos ( ) , NULL , 8 ) ;
SBVAL ( in_input_buffer . data , 0 , 512 ) ;
in_file_info_class = SMB_FILE_POSITION_INFORMATION - 1000 ;
status = smb2cli_set_info ( cli - > conn ,
cli - > timeout ,
cli - > smb2 . session ,
2012-07-23 22:32:49 +02:00
cli - > smb2 . tcon ,
2012-05-03 12:07:11 +02:00
SMB2_GETINFO_FILE ,
in_file_info_class ,
& in_input_buffer ,
0 , /* in_additional_info */
fid_persistent ,
fid_volatile ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smb2cli_set_info (position) returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
in_file_info_class = SMB_FILE_POSITION_INFORMATION - 1000 ;
status = smb2cli_query_info ( cli - > conn ,
cli - > timeout ,
cli - > smb2 . session ,
2012-07-23 22:32:49 +02:00
cli - > smb2 . tcon ,
2012-05-03 12:07:11 +02:00
SMB2_GETINFO_FILE ,
in_file_info_class ,
1024 , /* in_max_output_length */
NULL , /* in_input_buffer */
0 , /* in_additional_info */
0 , /* in_flags */
fid_persistent ,
fid_volatile ,
talloc_tos ( ) ,
& out_output_buffer ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smb2cli_query_info (position) returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2012-05-10 18:32:49 +02:00
status = smb2cli_close ( cli - > conn , cli - > timeout , cli - > smb2 . session ,
2012-07-23 22:32:49 +02:00
cli - > smb2 . tcon , 0 , fid_persistent , fid_volatile ) ;
2011-10-22 10:37:34 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smb2cli_close returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2012-05-10 18:34:40 +02:00
status = smb2cli_create ( cli - > conn , cli - > timeout , cli - > smb2 . session ,
2012-07-23 22:32:49 +02:00
cli - > smb2 . tcon , " session-reauth.txt " ,
2011-10-22 10:37:34 +02:00
SMB2_OPLOCK_LEVEL_NONE , /* oplock_level, */
SMB2_IMPERSONATION_IMPERSONATION , /* impersonation_level, */
SEC_STD_ALL | SEC_FILE_ALL , /* desired_access, */
FILE_ATTRIBUTE_NORMAL , /* file_attributes, */
FILE_SHARE_READ | FILE_SHARE_WRITE | FILE_SHARE_DELETE , /* share_access, */
FILE_CREATE , /* create_disposition, */
FILE_DELETE_ON_CLOSE , /* create_options, */
NULL , /* smb2_create_blobs *blobs */
& fid_persistent ,
2013-08-07 15:01:50 -07:00
& fid_volatile ,
2014-06-27 09:32:34 +00:00
NULL , NULL , NULL ) ;
2011-10-22 10:37:34 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smb2cli_create %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2012-02-28 04:24:12 +01:00
status = smb2cli_query_directory (
2012-07-23 22:32:49 +02:00
cli - > conn , cli - > timeout , cli - > smb2 . session , cli - > smb2 . tcon ,
2012-05-10 18:37:43 +02:00
1 , 0x3 , 0 , dir_persistent , dir_volatile ,
2012-02-28 04:24:12 +01:00
" session-reauth.txt " , 0xffff ,
talloc_tos ( ) , & dir_data , & dir_data_length ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smb2cli_query_directory returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2012-05-10 18:32:49 +02:00
status = smb2cli_close ( cli - > conn , cli - > timeout , cli - > smb2 . session ,
2012-07-23 22:32:49 +02:00
cli - > smb2 . tcon , 0 , dir_persistent , dir_volatile ) ;
2012-02-28 04:24:12 +01:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smb2cli_close returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2012-05-10 18:32:49 +02:00
status = smb2cli_close ( cli - > conn , cli - > timeout , cli - > smb2 . session ,
2012-07-23 22:32:49 +02:00
cli - > smb2 . tcon , 0 , fid_persistent , fid_volatile ) ;
2011-10-22 10:37:34 +02:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " smb2cli_close returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2012-07-25 09:01:02 +02:00
saved_tid = smb2cli_tcon_current_id ( cli - > smb2 . tcon ) ;
2012-07-24 20:11:25 +02:00
saved_tcon = cli - > smb2 . tcon ;
cli - > smb2 . tcon = smbXcli_tcon_create ( cli ) ;
smb2cli_tcon_set_values ( cli - > smb2 . tcon ,
2012-07-25 12:33:39 +02:00
NULL , /* session */
2012-07-24 20:11:25 +02:00
saved_tid ,
0 , /* type */
0 , /* flags */
0 , /* capabilities */
0 /* maximal_access */ ) ;
2012-02-28 05:11:23 +01:00
status = cli_tree_connect ( cli , share , " ????? " , " " , 0 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
printf ( " cli_tree_connect returned %s \n " , nt_errstr ( status ) ) ;
return false ;
}
2012-07-24 20:11:25 +02:00
talloc_free ( cli - > smb2 . tcon ) ;
cli - > smb2 . tcon = saved_tcon ;
2012-02-28 05:11:23 +01:00
2011-10-22 10:37:34 +02:00
return true ;
}