s3:smbd: pass the current time to make_connection[_smb1]()
authorStefan Metzmacher <metze@samba.org>
Thu, 1 Nov 2012 12:53:27 +0000 (13:53 +0100)
committerChristian Ambach <ambi@samba.org>
Mon, 5 Nov 2012 19:43:23 +0000 (20:43 +0100)
Otherwise smbstatus reports the wrong time for tree connects.

Signed-off-by: Stefan Metzmacher <metze@samba.org>
Reviewed-by: Christian Ambach <ambi@samba.org>
Autobuild-User(master): Christian Ambach <ambi@samba.org>
Autobuild-Date(master): Mon Nov  5 20:43:23 CET 2012 on sn-devel-104

source3/smbd/proto.h
source3/smbd/reply.c
source3/smbd/service.c

index c80ef14a0107c55c5222c79b9b910c6e7cc7aca3..221499cead63fca5c461d8a40937dae2727e78b7 100644 (file)
@@ -985,6 +985,7 @@ connection_struct *make_connection_smb2(struct smbd_server_connection *sconn,
                                        const char *pdev,
                                        NTSTATUS *pstatus);
 connection_struct *make_connection(struct smbd_server_connection *sconn,
+                                  NTTIME now,
                                   const char *service_in,
                                   const char *pdev, uint64_t vuid,
                                   NTSTATUS *status);
index 4423e8e19091f15217e00b84cee5a3c19cde1de4..8db9c623f779bc374774a6fb41af83cdf01ca3bd 100644 (file)
@@ -666,6 +666,7 @@ void reply_tcon(struct smb_request *req)
        const char *p;
        TALLOC_CTX *ctx = talloc_tos();
        struct smbd_server_connection *sconn = req->sconn;
+       NTTIME now = timeval_to_nttime(&req->request_time);
 
        START_PROFILE(SMBtcon);
 
@@ -695,7 +696,7 @@ void reply_tcon(struct smb_request *req)
                service = service_buf;
        }
 
-       conn = make_connection(sconn,service,dev,
+       conn = make_connection(sconn, now, service, dev,
                               req->vuid,&nt_status);
        req->conn = conn;
 
@@ -911,7 +912,7 @@ void reply_tcon_and_X(struct smb_request *req)
                session_key_updated = true;
        }
 
-       conn = make_connection(sconn, service, client_devicetype,
+       conn = make_connection(sconn, now, service, client_devicetype,
                               req->vuid, &nt_status);
        req->conn =conn;
 
index bb28fbfcc8ecd660e87fc64648e18fd46ec12a2d..2214ac0a2dd8657c22ec6dd870e7a112c3ac7bda 100644 (file)
@@ -922,13 +922,13 @@ static NTSTATUS make_connection_snum(struct smbd_server_connection *sconn,
 ****************************************************************************/
 
 static connection_struct *make_connection_smb1(struct smbd_server_connection *sconn,
+                                       NTTIME now,
                                        int snum, struct user_struct *vuser,
                                        const char *pdev,
                                        NTSTATUS *pstatus)
 {
        struct smbXsrv_tcon *tcon;
        NTSTATUS status;
-       NTTIME now = 0;
        struct connection_struct *conn;
 
        status = smb1srv_tcon_create(sconn->conn, now, &tcon);
@@ -1025,6 +1025,7 @@ connection_struct *make_connection_smb2(struct smbd_server_connection *sconn,
 ****************************************************************************/
 
 connection_struct *make_connection(struct smbd_server_connection *sconn,
+                                  NTTIME now,
                                   const char *service_in,
                                   const char *pdev, uint64_t vuid,
                                   NTSTATUS *status)
@@ -1078,7 +1079,7 @@ connection_struct *make_connection(struct smbd_server_connection *sconn,
                }
                DEBUG(5, ("making a connection to [homes] service "
                          "created at session setup time\n"));
-               return make_connection_smb1(sconn,
+               return make_connection_smb1(sconn, now,
                                            vuser->homes_snum,
                                            vuser,
                                            dev, status);
@@ -1087,7 +1088,7 @@ connection_struct *make_connection(struct smbd_server_connection *sconn,
                               lp_servicename(talloc_tos(), vuser->homes_snum))) {
                DEBUG(5, ("making a connection to 'homes' service [%s] "
                          "created at session setup time\n", service_in));
-               return make_connection_smb1(sconn,
+               return make_connection_smb1(sconn, now,
                                            vuser->homes_snum,
                                            vuser,
                                            dev, status);
@@ -1139,7 +1140,7 @@ connection_struct *make_connection(struct smbd_server_connection *sconn,
 
        DEBUG(5, ("making a connection to 'normal' service %s\n", service));
 
-       return make_connection_smb1(sconn, snum, vuser,
+       return make_connection_smb1(sconn, now, snum, vuser,
                                    dev, status);
 }