When writing to a daemon with read only = false and uid = root and -g,
authorDavid Dykstra <dwd@samba.org>
Wed, 29 Dec 1999 20:50:48 +0000 (20:50 +0000)
committerDavid Dykstra <dwd@samba.org>
Wed, 29 Dec 1999 20:50:48 +0000 (20:50 +0000)
was not preserving group permisions.  Bug was introduced March 1 in
version 1.100 of rsync.c with an error in re-ordering of the boolean
expressions.  In order to completely preserve the earlier semantics,
change_gid should depend on "(am_root || !am_daemon)", but I don't see why
group ownership should behave differently in a non-root daemon.

rsync.c

diff --git a/rsync.c b/rsync.c
index 680fc0b..a65f01f 100644 (file)
--- a/rsync.c
+++ b/rsync.c
@@ -179,7 +179,7 @@ int set_perms(char *fname,struct file_struct *file,STRUCT_STAT *st,
        }
 
        change_uid = am_root && preserve_uid && st->st_uid != file->uid;
-       change_gid = !am_daemon && preserve_gid && file->gid != (gid_t) -1 && \
+       change_gid = preserve_gid && file->gid != (gid_t) -1 && \
                                st->st_gid != file->gid;
        if (change_gid && !am_root) {
                /* enforce bsd-style group semantics: non-root can only