From dfd4cba3856cea89037f1e8dc217f692e87c7edf Mon Sep 17 00:00:00 2001 From: Peter Belm Date: Tue, 19 Jan 2021 10:13:09 +0000 Subject: [PATCH] Workaround for mkdir on existing directory (#242) Added a secondary check so if a mkdir request fails with EPERM an access request will be tried - returning EEXIST if the access was successful. This matches the correct behaviour expected by applications such as git. Co-authored-by: Peter Belm --- ChangeLog.rst | 8 ++++++++ sshfs.c | 7 +++++++ 2 files changed, 15 insertions(+) diff --git a/ChangeLog.rst b/ChangeLog.rst index f3f63525..37a4408a 100644 --- a/ChangeLog.rst +++ b/ChangeLog.rst @@ -1,3 +1,11 @@ +Unreleased Changes +-------------------------- + +* Added a secondary check so if a mkdir request fails with EPERM an access request will be + tried - returning EEXIST if the access was successful. + Fixes: https://github.com/libfuse/sshfs/issues/243 + + Release 3.7.1 (2020-11-09) -------------------------- diff --git a/sshfs.c b/sshfs.c index ff40c814..0a409506 100644 --- a/sshfs.c +++ b/sshfs.c @@ -2377,6 +2377,13 @@ static int sshfs_mkdir(const char *path, mode_t mode) // Commutes with pending write(), so we can use any connection err = sftp_request(get_conn(NULL, NULL), SSH_FXP_MKDIR, &buf, SSH_FXP_STATUS, NULL); buf_free(&buf); + + if (err == -EPERM) { + if (sshfs.op->access(path, R_OK) == 0) { + return -EEXIST; + } + } + return err; }