diff options
Diffstat (limited to 'source3/rpc_server')
-rw-r--r-- | source3/rpc_server/srvsvc/srv_srvsvc_nt.c | 31 |
1 files changed, 14 insertions, 17 deletions
diff --git a/source3/rpc_server/srvsvc/srv_srvsvc_nt.c b/source3/rpc_server/srvsvc/srv_srvsvc_nt.c index 8f3a4cf17d..3d4ee22ea1 100644 --- a/source3/rpc_server/srvsvc/srv_srvsvc_nt.c +++ b/source3/rpc_server/srvsvc/srv_srvsvc_nt.c @@ -1296,30 +1296,27 @@ WERROR _srvsvc_NetSessDel(struct pipes_struct *p, machine += 2; } - num_sessions = list_sessions(p->mem_ctx, &session_list); + num_sessions = find_sessions(p->mem_ctx, username, machine, + &session_list); for (snum = 0; snum < num_sessions; snum++) { - if ((strequal(session_list[snum].username, username) || username[0] == '\0' ) && - strequal(session_list[snum].remote_machine, machine)) { + NTSTATUS ntstat; - NTSTATUS ntstat; - - if (p->session_info->unix_token->uid != sec_initial_uid()) { - not_root = True; - become_root(); - } + if (p->session_info->unix_token->uid != sec_initial_uid()) { + not_root = True; + become_root(); + } - ntstat = messaging_send(p->msg_ctx, - session_list[snum].pid, - MSG_SHUTDOWN, &data_blob_null); + ntstat = messaging_send(p->msg_ctx, + session_list[snum].pid, + MSG_SHUTDOWN, &data_blob_null); - if (NT_STATUS_IS_OK(ntstat)) - werr = WERR_OK; + if (NT_STATUS_IS_OK(ntstat)) + werr = WERR_OK; - if (not_root) - unbecome_root(); - } + if (not_root) + unbecome_root(); } DEBUG(5,("_srvsvc_NetSessDel: %d\n", __LINE__)); |