diff options
author | Denys Vlasenko <vda.linux@googlemail.com> | 2010-02-06 21:50:59 +0100 |
---|---|---|
committer | Denys Vlasenko <vda.linux@googlemail.com> | 2010-02-06 21:50:59 +0100 |
commit | cb7edc26611f8df6b81ef4337206d5833ea98771 (patch) | |
tree | ce211298be0d9f7d59d31139b47a5f915966e193 /loginutils/adduser.c | |
parent | 0cd445f4d1ff322051ca2ad869e8757bb5ac2227 (diff) | |
download | busybox-w32-cb7edc26611f8df6b81ef4337206d5833ea98771.tar.gz busybox-w32-cb7edc26611f8df6b81ef4337206d5833ea98771.tar.bz2 busybox-w32-cb7edc26611f8df6b81ef4337206d5833ea98771.zip |
adduser: copy /etc/skel to mew homes. +100 bytes
Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
Diffstat (limited to 'loginutils/adduser.c')
-rw-r--r-- | loginutils/adduser.c | 18 |
1 files changed, 16 insertions, 2 deletions
diff --git a/loginutils/adduser.c b/loginutils/adduser.c index da41fd7ac..f5dca929f 100644 --- a/loginutils/adduser.c +++ b/loginutils/adduser.c | |||
@@ -199,7 +199,21 @@ int adduser_main(int argc UNUSED_PARAM, char **argv) | |||
199 | /* set the owner and group so it is owned by the new user, | 199 | /* set the owner and group so it is owned by the new user, |
200 | * then fix up the permissions to 2755. Can't do it before | 200 | * then fix up the permissions to 2755. Can't do it before |
201 | * since chown will clear the setgid bit */ | 201 | * since chown will clear the setgid bit */ |
202 | if ((mkdir(pw.pw_dir, 0755) != 0 && errno != EEXIST) | 202 | int mkdir_err = mkdir(pw.pw_dir, 0755); |
203 | if (mkdir_err == 0) { | ||
204 | /* New home. Copy /etc/skel to it */ | ||
205 | const char *args[] = { | ||
206 | "chown", "-R", | ||
207 | xasprintf("%u:%u", (int)pw.pw_uid, (int)pw.pw_gid), | ||
208 | pw.pw_dir, NULL | ||
209 | }; | ||
210 | /* Be silent on any errors (like: no /etc/skel) */ | ||
211 | logmode = LOGMODE_NONE; | ||
212 | copy_file("/etc/skel", pw.pw_dir, FILEUTILS_RECUR); | ||
213 | logmode = LOGMODE_STDIO; | ||
214 | chown_main(4, (char**)args); | ||
215 | } | ||
216 | if ((mkdir_err != 0 && errno != EEXIST) | ||
203 | || chown(pw.pw_dir, pw.pw_uid, pw.pw_gid) != 0 | 217 | || chown(pw.pw_dir, pw.pw_uid, pw.pw_gid) != 0 |
204 | || chmod(pw.pw_dir, 02755) != 0 /* set setgid bit on homedir */ | 218 | || chmod(pw.pw_dir, 02755) != 0 /* set setgid bit on homedir */ |
205 | ) { | 219 | ) { |
@@ -212,5 +226,5 @@ int adduser_main(int argc UNUSED_PARAM, char **argv) | |||
212 | passwd_wrapper(pw.pw_name); | 226 | passwd_wrapper(pw.pw_name); |
213 | } | 227 | } |
214 | 228 | ||
215 | return 0; | 229 | return EXIT_SUCCESS; |
216 | } | 230 | } |