2010-03-01 16:18:23 +01:00
/*
Unix SMB / CIFS implementation .
Low - level sessionid . tdb access functions
Copyright ( C ) Volker Lendecke 2010
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"
2011-02-25 23:20:06 +01:00
# include "system/filesys.h"
2011-07-07 17:42:08 +02:00
# include "dbwrap/dbwrap.h"
2011-07-06 16:40:21 +02:00
# include "dbwrap/dbwrap_open.h"
2011-02-24 23:14:15 +01:00
# include "session.h"
2011-05-05 11:25:29 +02:00
# include "util_tdb.h"
2012-08-23 10:36:59 +02:00
# include "smbd/globals.h"
2024-02-08 10:04:32 +01:00
# include "source3/smbd/smbXsrv_session.h"
2023-07-03 15:08:31 +02:00
# include "../libcli/security/session.h"
2010-03-01 16:18:23 +01:00
struct sessionid_traverse_read_state {
int ( * fn ) ( const char * key , struct sessionid * session ,
void * private_data ) ;
void * private_data ;
} ;
2012-08-23 10:36:59 +02:00
static int sessionid_traverse_read_fn ( struct smbXsrv_session_global0 * global ,
2010-03-01 16:18:23 +01:00
void * private_data )
{
struct sessionid_traverse_read_state * state =
( struct sessionid_traverse_read_state * ) private_data ;
2012-08-23 10:36:59 +02:00
struct auth_session_info * session_info = global - > auth_session_info ;
struct sessionid session = {
2013-07-05 13:19:59 +02:00
. uid = - 1 ,
. gid = - 1 ,
2012-08-23 10:36:59 +02:00
. id_num = global - > session_global_id ,
. connect_start = nt_time_to_unix ( global - > creation_time ) ,
. pid = global - > channels [ 0 ] . server_id ,
2015-11-30 10:48:12 +01:00
. connection_dialect = global - > connection_dialect ,
2023-12-15 16:45:54 +01:00
. global = global ,
2012-08-23 10:36:59 +02:00
} ;
2013-07-05 13:19:59 +02:00
if ( session_info ! = NULL ) {
2023-07-03 15:08:31 +02:00
enum security_user_level ul ;
2013-07-05 13:19:59 +02:00
session . uid = session_info - > unix_token - > uid ;
session . gid = session_info - > unix_token - > gid ;
strncpy ( session . username ,
session_info - > unix_info - > unix_name ,
sizeof ( fstring ) - 1 ) ;
2023-07-03 15:08:31 +02:00
ul = security_session_user_level ( session_info , NULL ) ;
if ( ul > = SECURITY_USER ) {
session . authenticated = true ;
}
2013-07-05 13:19:59 +02:00
}
2012-08-23 10:36:59 +02:00
strncpy ( session . remote_machine ,
global - > channels [ 0 ] . remote_name ,
sizeof ( fstring ) - 1 ) ;
strncpy ( session . hostname ,
global - > channels [ 0 ] . remote_address ,
sizeof ( fstring ) - 1 ) ;
strncpy ( session . netbios_name ,
global - > channels [ 0 ] . remote_name ,
sizeof ( fstring ) - 1 ) ;
snprintf ( session . id_str , sizeof ( fstring ) - 1 ,
" smb/%u " , global - > session_global_id ) ;
strncpy ( session . ip_addr_str ,
global - > channels [ 0 ] . remote_address ,
sizeof ( fstring ) - 1 ) ;
2015-11-09 17:17:17 +01:00
session . encryption_flags = global - > encryption_flags ;
session . cipher = global - > channels [ 0 ] . encryption_cipher ;
2015-11-30 11:20:43 +01:00
session . signing_flags = global - > signing_flags ;
2021-05-06 23:55:49 +02:00
session . signing = global - > channels [ 0 ] . signing_algo ;
2015-11-09 17:17:17 +01:00
2012-08-23 10:36:59 +02:00
return state - > fn ( NULL , & session , state - > private_data ) ;
2010-03-01 16:18:23 +01:00
}
2011-08-17 10:33:58 +02:00
NTSTATUS sessionid_traverse_read ( int ( * fn ) ( const char * key ,
struct sessionid * session ,
void * private_data ) ,
void * private_data )
2010-03-01 16:18:23 +01:00
{
struct sessionid_traverse_read_state state ;
2011-08-17 10:33:58 +02:00
NTSTATUS status ;
2010-03-01 16:18:23 +01:00
state . fn = fn ;
state . private_data = private_data ;
2012-08-23 10:36:59 +02:00
status = smbXsrv_session_global_traverse ( sessionid_traverse_read_fn ,
& state ) ;
2011-08-17 10:33:58 +02:00
return status ;
2010-03-01 16:18:23 +01:00
}