Line data Source code
1 : /* 2 : Unix SMB/CIFS implementation. 3 : Low-level sessionid.tdb access functions 4 : Copyright (C) Volker Lendecke 2010 5 : 6 : This program is free software; you can redistribute it and/or modify 7 : it under the terms of the GNU General Public License as published by 8 : the Free Software Foundation; either version 3 of the License, or 9 : (at your option) any later version. 10 : 11 : This program is distributed in the hope that it will be useful, 12 : but WITHOUT ANY WARRANTY; without even the implied warranty of 13 : MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 14 : GNU General Public License for more details. 15 : 16 : You should have received a copy of the GNU General Public License 17 : along with this program. If not, see <http://www.gnu.org/licenses/>. 18 : */ 19 : 20 : #include "includes.h" 21 : #include "system/filesys.h" 22 : #include "dbwrap/dbwrap.h" 23 : #include "dbwrap/dbwrap_open.h" 24 : #include "session.h" 25 : #include "util_tdb.h" 26 : #include "smbd/globals.h" 27 : #include "source3/smbd/smbXsrv_session.h" 28 : #include "../libcli/security/session.h" 29 : 30 : struct sessionid_traverse_read_state { 31 : int (*fn)(const char *key, struct sessionid *session, 32 : void *private_data); 33 : void *private_data; 34 : }; 35 : 36 36 : static int sessionid_traverse_read_fn(struct smbXsrv_session_global0 *global, 37 : void *private_data) 38 : { 39 36 : struct sessionid_traverse_read_state *state = 40 : (struct sessionid_traverse_read_state *)private_data; 41 36 : struct auth_session_info *session_info = global->auth_session_info; 42 72 : struct sessionid session = { 43 : .uid = -1, 44 : .gid = -1, 45 36 : .id_num = global->session_global_id, 46 36 : .connect_start = nt_time_to_unix(global->creation_time), 47 36 : .pid = global->channels[0].server_id, 48 36 : .connection_dialect = global->connection_dialect, 49 : .global = global, 50 : }; 51 : 52 36 : if (session_info != NULL) { 53 0 : enum security_user_level ul; 54 : 55 36 : session.uid = session_info->unix_token->uid; 56 36 : session.gid = session_info->unix_token->gid; 57 36 : strncpy(session.username, 58 36 : session_info->unix_info->unix_name, 59 : sizeof(fstring)-1); 60 : 61 36 : ul = security_session_user_level(session_info, NULL); 62 36 : if (ul >= SECURITY_USER) { 63 36 : session.authenticated = true; 64 : } 65 : } 66 : 67 36 : strncpy(session.remote_machine, 68 36 : global->channels[0].remote_name, 69 : sizeof(fstring)-1); 70 36 : strncpy(session.hostname, 71 36 : global->channels[0].remote_address, 72 : sizeof(fstring)-1); 73 36 : strncpy(session.netbios_name, 74 36 : global->channels[0].remote_name, 75 : sizeof(fstring)-1); 76 36 : snprintf(session.id_str, sizeof(fstring)-1, 77 : "smb/%u", global->session_global_id); 78 36 : strncpy(session.ip_addr_str, 79 36 : global->channels[0].remote_address, 80 : sizeof(fstring)-1); 81 : 82 36 : session.encryption_flags = global->encryption_flags; 83 36 : session.cipher = global->channels[0].encryption_cipher; 84 36 : session.signing_flags = global->signing_flags; 85 36 : session.signing = global->channels[0].signing_algo; 86 : 87 36 : return state->fn(NULL, &session, state->private_data); 88 : } 89 : 90 32 : NTSTATUS sessionid_traverse_read(int (*fn)(const char *key, 91 : struct sessionid *session, 92 : void *private_data), 93 : void *private_data) 94 : { 95 0 : struct sessionid_traverse_read_state state; 96 0 : NTSTATUS status; 97 : 98 32 : state.fn = fn; 99 32 : state.private_data = private_data; 100 32 : status = smbXsrv_session_global_traverse(sessionid_traverse_read_fn, 101 : &state); 102 : 103 32 : return status; 104 : }