r24476: Fix the mappings in reply_opeXXX calls. Now to test renames.
authorJeremy Allison <jra@samba.org>
Thu, 16 Aug 2007 00:37:07 +0000 (00:37 +0000)
committerGerald (Jerry) Carter <jerry@samba.org>
Wed, 10 Oct 2007 17:29:51 +0000 (12:29 -0500)
Jeremy.
(This used to be commit 74d10b09a68f5c06d6b3ceffe0a40818dc84106e)

source3/smbd/reply.c
source3/smbd/trans2.c

index 786fe9c6a16dfd521eff0be389be71bf58c7d952..1b0785285dff52d0647ea356fb93b296c0a62ef2 100644 (file)
@@ -1551,13 +1551,23 @@ void reply_open(connection_struct *conn, struct smb_request *req)
                        &info, &fsp);
 
        if (!NT_STATUS_IS_OK(status)) {
+               END_PROFILE(SMBopen);
                if (open_was_deferred(req->mid)) {
                        /* We have re-scheduled this call. */
-                       END_PROFILE(SMBopen);
+                       return;
+               }
+               if (NT_STATUS_EQUAL(status, NT_STATUS_OBJECT_NAME_COLLISION)) {
+                       /*
+                        * We hit an existing file, and if we're returning DOS
+                        * error codes OBJECT_NAME_COLLISION would map to
+                        * ERRDOS/183, we need to return ERRDOS/80, see bug
+                        * 4852.
+                        */
+                       reply_botherror(req, NT_STATUS_OBJECT_NAME_COLLISION,
+                                       ERRDOS, ERRfilexists);
                        return;
                }
                reply_nterror(req, status);
-               END_PROFILE(SMBopen);
                return;
        }
 
@@ -1718,7 +1728,6 @@ void reply_open_and_X(connection_struct *conn, struct smb_request *req)
                END_PROFILE(SMBopenX);
                if (open_was_deferred(req->mid)) {
                        /* We have re-scheduled this call. */
-                       END_PROFILE(SMBopenX);
                        return;
                }
                if (NT_STATUS_EQUAL(status, NT_STATUS_OBJECT_NAME_COLLISION)) {
@@ -1730,11 +1739,9 @@ void reply_open_and_X(connection_struct *conn, struct smb_request *req)
                         */
                        reply_botherror(req, NT_STATUS_OBJECT_NAME_COLLISION,
                                        ERRDOS, ERRfilexists);
-                       END_PROFILE(SMBopenX);
                        return;
                }
                reply_nterror(req, status);
-               END_PROFILE(SMBopenX);
                return;
        }
 
@@ -2075,13 +2082,23 @@ void reply_ctemp(connection_struct *conn, struct smb_request *req)
        close(tmpfd);
 
        if (!NT_STATUS_IS_OK(status)) {
+               END_PROFILE(SMBctemp);
                if (open_was_deferred(req->mid)) {
                        /* We have re-scheduled this call. */
-                       END_PROFILE(SMBctemp);
+                       return;
+               }
+               if (NT_STATUS_EQUAL(status, NT_STATUS_OBJECT_NAME_COLLISION)) {
+                       /*
+                        * We hit an existing file, and if we're returning DOS
+                        * error codes OBJECT_NAME_COLLISION would map to
+                        * ERRDOS/183, we need to return ERRDOS/80, see bug
+                        * 4852.
+                        */
+                       reply_botherror(req, NT_STATUS_OBJECT_NAME_COLLISION,
+                                       ERRDOS, ERRfilexists);
                        return;
                }
                reply_nterror(req, status);
-               END_PROFILE(SMBctemp);
                return;
        }
 
index a01e79b6243dce064736765f45caa440e88ac7cd..dbbb2faba98215256c90af93fb2f8442e97b7179 100644 (file)
@@ -6523,8 +6523,10 @@ static void call_trans2setfilepathinfo(connection_struct *conn,
                                 * ERRDOS/183, we need to return ERRDOS/80, see bug
                                 * 4852.
                                 */
-                               return ERROR_BOTH(NT_STATUS_OBJECT_NAME_COLLISION,
+                               reply_botherror(req,
+                                       NT_STATUS_OBJECT_NAME_COLLISION,
                                        ERRDOS, ERRfilexists);
+                               return;
                }
 
                reply_nterror(req, status);