Changing File Ownership
At first blush, changing file ownership is pretty easy. Given the
list of usernames and new UID numbers, we ought to be able to write a
loop like this (to be run as root):
while read user old new
do
cd /home/$user Change to user's directory
chown -R $new . Recursively change ownership, see chown(1)
done < old-new-listThe idea is to change to the user's home directory and recursively
chown everything to the new UID
number. However, this isn't enough. It's possible for users to have
files in places outside their home directory. For example, consider two
users, ben and jhancock, working on a joint project in
/home/ben/declaration:
$cd /home/ben/declaration$ls -l draft*-rw-r--r-- 1 ben fathers 2102 Jul 3 16:00 draft10 -rw-r--r-- 1 jhancock fathers 2191 Jul 3 17:09 draft.final
If we just did the recursive chown, both files would end up belonging to
ben, and jhancock wouldn't be too happy upon returning
to work the day after the Great Filesystem Reorganization.
Even worse, though, is the case in which users have files that
live outside their home directory. /tmp is an obvious example, but consider a
source code management system, such as CVS. CVS stores the master files
for a project in a repository that is typically not in
any home directory, but in a system directory
somewhere. Source files in the repository belong to multiple users. The
ownership of these files should also be changed over.
Thus, the only way to be sure that all files are changed correctly everywhere ...
Become an O’Reilly member and get unlimited access to this title plus top books and audiobooks from O’Reilly and nearly 200 top publishers, thousands of courses curated by job role, 150+ live events each month,
and much more.
Read now
Unlock full access