s3:smbd: change blocking.c to use fsp_fnum_dbg() for fsp->fnum logging.
[Samba/gebeck_regimport.git] / source3 / smbd / conn_idle.c
blob4dfa4097c31ff3dbc4261db1c91fd82a3b728d61
1 /*
2 Unix SMB/CIFS implementation.
3 Manage connections_struct structures
4 Copyright (C) Andrew Tridgell 1998
5 Copyright (C) Alexander Bokovoy 2002
6 Copyright (C) Jeremy Allison 2010
8 This program is free software; you can redistribute it and/or modify
9 it under the terms of the GNU General Public License as published by
10 the Free Software Foundation; either version 3 of the License, or
11 (at your option) any later version.
13 This program is distributed in the hope that it will be useful,
14 but WITHOUT ANY WARRANTY; without even the implied warranty of
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 GNU General Public License for more details.
18 You should have received a copy of the GNU General Public License
19 along with this program. If not, see <http://www.gnu.org/licenses/>.
22 #include "includes.h"
23 #include "smbd/smbd.h"
24 #include "smbd/globals.h"
25 #include "rpc_server/rpc_pipes.h"
27 /****************************************************************************
28 Update last used timestamps.
29 ****************************************************************************/
31 static void conn_lastused_update(struct smbd_server_connection *sconn,time_t t)
33 struct connection_struct *conn;
35 for (conn=sconn->connections; conn; conn=conn->next) {
36 /* Update if connection wasn't idle. */
37 if (conn->lastused != conn->lastused_count) {
38 conn->lastused = t;
39 conn->lastused_count = t;
44 /****************************************************************************
45 Idle inactive connections.
46 ****************************************************************************/
48 bool conn_idle_all(struct smbd_server_connection *sconn, time_t t)
50 int deadtime = lp_deadtime()*60;
51 struct connection_struct *conn;
53 conn_lastused_update(sconn, t);
55 if (deadtime <= 0) {
56 deadtime = DEFAULT_SMBD_TIMEOUT;
59 for (conn=sconn->connections;conn;conn=conn->next) {
60 time_t age = t - conn->lastused;
62 /* close dirptrs on connections that are idle */
63 if (age > DPTR_IDLE_TIMEOUT) {
64 dptr_idlecnum(conn);
67 if (conn->num_files_open > 0 || age < deadtime) {
68 return false;
73 * Check all pipes for any open handles. We cannot
74 * idle with a handle open.
76 if (check_open_pipes()) {
77 return false;
80 return true;
83 /****************************************************************************
84 Close all conn structures.
85 Return true if any were closed.
86 ****************************************************************************/
88 void conn_close_all(struct smbd_server_connection *sconn)
90 if (sconn->using_smb2) {
91 /* SMB2 */
92 struct smbd_smb2_session *sess;
94 for (sess = sconn->smb2.sessions.list; sess; sess = sess->next) {
95 struct smbd_smb2_tcon *tcon, *tc_next;
97 file_close_user(sconn, sess->vuid);
99 for (tcon = sess->tcons.list; tcon; tcon = tc_next) {
100 tc_next = tcon->next;
101 TALLOC_FREE(tcon);
104 } else {
105 /* SMB1 */
106 connection_struct *conn, *next;
108 for (conn=sconn->connections;conn;conn=next) {
109 next=conn->next;
110 set_current_service(conn, 0, True);
111 close_cnum(conn, conn->vuid);
117 /****************************************************************************
118 Forcibly unmount a share.
119 All instances of the parameter 'sharename' share are unmounted.
120 The special sharename '*' forces unmount of all shares.
121 ****************************************************************************/
123 void conn_force_tdis(struct smbd_server_connection *sconn, const char *sharename)
125 connection_struct *conn, *next;
127 if (strcmp(sharename, "*") == 0) {
128 DEBUG(1,("Forcing close of all shares\n"));
129 conn_close_all(sconn);
130 return;
133 if (sconn->using_smb2) {
134 /* SMB2 */
135 struct smbd_smb2_session *sess;
136 for (sess = sconn->smb2.sessions.list; sess; sess = sess->next) {
137 struct smbd_smb2_tcon *tcon, *tc_next;
139 for (tcon = sess->tcons.list; tcon; tcon = tc_next) {
140 tc_next = tcon->next;
141 if (tcon->compat_conn &&
142 strequal(lp_servicename(SNUM(tcon->compat_conn)),
143 sharename)) {
144 DEBUG(1,("Forcing close of share %s cnum=%d\n",
145 sharename, tcon->compat_conn->cnum));
146 TALLOC_FREE(tcon);
150 } else {
151 /* SMB1 */
152 for (conn=sconn->connections;conn;conn=next) {
153 next=conn->next;
154 if (strequal(lp_servicename(SNUM(conn)), sharename)) {
155 DEBUG(1,("Forcing close of share %s cnum=%d\n",
156 sharename, conn->cnum));
157 close_cnum(conn, UID_FIELD_INVALID);