summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/chown-core.c14
1 files changed, 7 insertions, 7 deletions
diff --git a/src/chown-core.c b/src/chown-core.c
index 3d6b0ad63..39cb34d8b 100644
--- a/src/chown-core.c
+++ b/src/chown-core.c
@@ -27,7 +27,7 @@
#include "chown-core.h"
#include "error.h"
#include "inttostr.h"
-#include "lchown.h"
+#include "openat.h"
#include "quote.h"
#include "root-dev-ino.h"
#include "xfts.h"
@@ -180,7 +180,7 @@ describe_change (const char *file, enum Change_status changed,
Return one of the RCH_status values. */
static enum RCH_status
-restricted_chown (char const *file,
+restricted_chown (int cwd_fd, char const *file,
struct stat const *orig_st,
uid_t uid, gid_t gid,
uid_t required_uid, gid_t required_gid)
@@ -201,10 +201,10 @@ restricted_chown (char const *file,
return RC_do_ordinary_chown;
}
- fd = open (file, O_RDONLY | open_flags);
+ fd = openat (cwd_fd, file, O_RDONLY | open_flags);
if (! (0 <= fd
|| (errno == EACCES && S_ISREG (orig_st->st_mode)
- && 0 <= (fd = open (file, O_WRONLY | open_flags)))))
+ && 0 <= (fd = openat (cwd_fd, file, O_WRONLY | open_flags)))))
return (errno == EACCES ? RC_do_ordinary_chown : RC_error);
if (fstat (fd, &st) != 0)
@@ -332,7 +332,7 @@ change_file_owner (FTS *fts, FTSENT *ent,
{
if ( ! chopt->affect_symlink_referent)
{
- ok = (lchown (file, uid, gid) == 0);
+ ok = (lchownat (fts->fts_cwd_fd, file, uid, gid) == 0);
/* Ignore any error due to lack of support; POSIX requires
this behavior for top-level symbolic links with -h, and
@@ -356,7 +356,7 @@ change_file_owner (FTS *fts, FTSENT *ent,
that can be opened, this race condition can be avoided safely. */
enum RCH_status err
- = restricted_chown (file, file_stats, uid, gid,
+ = restricted_chown (fts->fts_cwd_fd, file, file_stats, uid, gid,
required_uid, required_gid);
switch (err)
{
@@ -364,7 +364,7 @@ change_file_owner (FTS *fts, FTSENT *ent,
break;
case RC_do_ordinary_chown:
- ok = (chown (file, uid, gid) == 0);
+ ok = (chownat (fts->fts_cwd_fd, file, uid, gid) == 0);
break;
case RC_error: