summaryrefslogtreecommitdiff
path: root/source3/rpc_server/srv_srvsvc_nt.c
diff options
context:
space:
mode:
authorSimo Sorce <idra@samba.org>2005-03-23 20:57:03 +0000
committerGerald (Jerry) Carter <jerry@samba.org>2007-10-10 10:56:15 -0500
commitbece9417d2e232e5b13ea340c79430bb9680eb8a (patch)
tree37b9c30816909d8c4706744b3017fe67dfe30ffc /source3/rpc_server/srv_srvsvc_nt.c
parent8b6a50cf3ecad43fbb70b778983231d7ec5adbbc (diff)
downloadsamba-bece9417d2e232e5b13ea340c79430bb9680eb8a.tar.gz
samba-bece9417d2e232e5b13ea340c79430bb9680eb8a.tar.bz2
samba-bece9417d2e232e5b13ea340c79430bb9680eb8a.zip
r6004: Let's make server manager able to kill a user session.
This will send a shutdown command to the right process by pid read from the sessions list. (This used to be commit 5d3d025db757f7d48f241142a60a93214f2b47ea)
Diffstat (limited to 'source3/rpc_server/srv_srvsvc_nt.c')
-rw-r--r--source3/rpc_server/srv_srvsvc_nt.c43
1 files changed, 43 insertions, 0 deletions
diff --git a/source3/rpc_server/srv_srvsvc_nt.c b/source3/rpc_server/srv_srvsvc_nt.c
index 13e1971925..8bcb5c82ac 100644
--- a/source3/rpc_server/srv_srvsvc_nt.c
+++ b/source3/rpc_server/srv_srvsvc_nt.c
@@ -1349,6 +1349,49 @@ WERROR _srv_net_sess_enum(pipes_struct *p, SRV_Q_NET_SESS_ENUM *q_u, SRV_R_NET_S
}
/*******************************************************************
+net sess del
+********************************************************************/
+
+WERROR _srv_net_sess_del(pipes_struct *p, SRV_Q_NET_SESS_DEL *q_u, SRV_R_NET_SESS_DEL *r_u)
+{
+ struct sessionid *session_list;
+ int num_sessions, snum, ret;
+ fstring username;
+ fstring machine;
+
+ rpcstr_pull_unistr2_fstring(username, &q_u->uni_user_name);
+ rpcstr_pull_unistr2_fstring(machine, &q_u->uni_cli_name);
+
+ /* strip leading backslashes if any */
+ while (machine[0] == '\\') {
+ memmove(machine, &machine[1], strlen(machine));
+ }
+
+ num_sessions = list_sessions(&session_list);
+
+ DEBUG(5,("_srv_net_sess_del: %d\n", __LINE__));
+
+ r_u->status = WERR_ACCESS_DENIED;
+
+ for (snum = 0; snum < num_sessions; snum++) {
+
+ if ((StrCaseCmp(session_list[snum].username, username) == 0 || username[0] == '\0' ) &&
+ StrCaseCmp(session_list[snum].remote_machine, machine) == 0) {
+
+ if ((ret = message_send_pid(session_list[snum].pid, MSG_SHUTDOWN, NULL, 0, False))) {
+ r_u->status = WERR_OK;
+ } else {
+ r_u->status = WERR_ACCESS_DENIED;
+ }
+ }
+ }
+
+ DEBUG(5,("_srv_net_sess_del: %d\n", __LINE__));
+
+ return r_u->status;
+}
+
+/*******************************************************************
Net share enum all.
********************************************************************/