From aa6f0a01513b91ead65069734a896eb9700b6c5b Mon Sep 17 00:00:00 2001 From: Volker Lendecke Date: Sun, 2 Dec 2007 13:34:59 +0100 Subject: Fix error returns (This used to be commit f5cdaacd1784d3801d638fa9984b52c57dad6ebd) --- source3/smbd/nttrans.c | 14 ++++++++++++-- 1 file changed, 12 insertions(+), 2 deletions(-) diff --git a/source3/smbd/nttrans.c b/source3/smbd/nttrans.c index c9bc3f45a0..739bf01ef9 100644 --- a/source3/smbd/nttrans.c +++ b/source3/smbd/nttrans.c @@ -992,7 +992,12 @@ void reply_ntcreate_and_X(connection_struct *conn, struct smb_request *req) END_PROFILE(SMBntcreateX); return; } - reply_nterror(req, status); + if (NT_STATUS_EQUAL(status, NT_STATUS_OBJECT_NAME_COLLISION)) { + reply_botherror(req, status, ERRDOS, ERRfilexists); + } + else { + reply_nterror(req, status); + } END_PROFILE(SMBntcreateX); return; } @@ -1422,7 +1427,12 @@ static void call_nt_transact_create(connection_struct *conn, /* We have re-scheduled this call, no error. */ return; } - reply_nterror(req, status); + if (NT_STATUS_EQUAL(status, NT_STATUS_OBJECT_NAME_COLLISION)) { + reply_botherror(req, status, ERRDOS, ERRfilexists); + } + else { + reply_nterror(req, status); + } return; } -- cgit