diff options
author | Denys Vlasenko <vda.linux@googlemail.com> | 2010-01-10 04:25:05 +0100 |
---|---|---|
committer | Denys Vlasenko <vda.linux@googlemail.com> | 2010-01-10 04:25:05 +0100 |
commit | 38d3e64d2593aa5bc6bb578e1cd9a73a2d4b26fa (patch) | |
tree | 7215b21dee93cbbc4e2739f7cd99e11c56fbd49b | |
parent | 1fbcb805a370e2e5f8ccfd4a45dff3ae401cd8bb (diff) | |
download | busybox-w32-38d3e64d2593aa5bc6bb578e1cd9a73a2d4b26fa.tar.gz busybox-w32-38d3e64d2593aa5bc6bb578e1cd9a73a2d4b26fa.tar.bz2 busybox-w32-38d3e64d2593aa5bc6bb578e1cd9a73a2d4b26fa.zip |
adduser: create a group for net user too
Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
-rw-r--r-- | loginutils/adduser.c | 24 |
1 files changed, 11 insertions, 13 deletions
diff --git a/loginutils/adduser.c b/loginutils/adduser.c index 5f593ac16..da41fd7ac 100644 --- a/loginutils/adduser.c +++ b/loginutils/adduser.c | |||
@@ -69,8 +69,11 @@ static void addgroup_wrapper(struct passwd *p, const char *group_name) | |||
69 | { | 69 | { |
70 | char *cmd; | 70 | char *cmd; |
71 | 71 | ||
72 | cmd = xasprintf("addgroup '%s' '%s'", | 72 | if (group_name) /* Add user to existing group */ |
73 | p->pw_name, group_name); | 73 | cmd = xasprintf("addgroup '%s' '%s'", p->pw_name, group_name); |
74 | else /* Add user to his own group with the first free gid found in passwd_study */ | ||
75 | cmd = xasprintf("addgroup -g %u '%s'", (unsigned)p->pw_gid, p->pw_name); | ||
76 | /* Warning: to be compatible with external addgroup programs we should use --gid instead */ | ||
74 | system(cmd); | 77 | system(cmd); |
75 | free(cmd); | 78 | free(cmd); |
76 | } | 79 | } |
@@ -79,10 +82,8 @@ static void passwd_wrapper(const char *login) NORETURN; | |||
79 | 82 | ||
80 | static void passwd_wrapper(const char *login) | 83 | static void passwd_wrapper(const char *login) |
81 | { | 84 | { |
82 | static const char prog[] ALIGN1 = "passwd"; | 85 | BB_EXECLP("passwd", "passwd", login, NULL); |
83 | 86 | bb_error_msg_and_die("can't execute passwd, you must set password manually"); | |
84 | BB_EXECLP(prog, prog, login, NULL); | ||
85 | bb_error_msg_and_die("can't execute %s, you must set password manually", prog); | ||
86 | } | 87 | } |
87 | 88 | ||
88 | #if ENABLE_FEATURE_ADDUSER_LONG_OPTIONS | 89 | #if ENABLE_FEATURE_ADDUSER_LONG_OPTIONS |
@@ -189,10 +190,7 @@ int adduser_main(int argc UNUSED_PARAM, char **argv) | |||
189 | #endif | 190 | #endif |
190 | 191 | ||
191 | /* add to group */ | 192 | /* add to group */ |
192 | /* addgroup should be responsible for dealing w/ gshadow */ | 193 | addgroup_wrapper(&pw, usegroup); |
193 | /* if using a pre-existing group, don't create one */ | ||
194 | if (usegroup) | ||
195 | addgroup_wrapper(&pw, usegroup); | ||
196 | 194 | ||
197 | /* clear the umask for this process so it doesn't | 195 | /* clear the umask for this process so it doesn't |
198 | * screw up the permissions on the mkdir and chown. */ | 196 | * screw up the permissions on the mkdir and chown. */ |
@@ -201,9 +199,9 @@ int adduser_main(int argc UNUSED_PARAM, char **argv) | |||
201 | /* 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, |
202 | * 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 |
203 | * since chown will clear the setgid bit */ | 201 | * since chown will clear the setgid bit */ |
204 | if (mkdir(pw.pw_dir, 0755) | 202 | if ((mkdir(pw.pw_dir, 0755) != 0 && errno != EEXIST) |
205 | || chown(pw.pw_dir, pw.pw_uid, pw.pw_gid) | 203 | || chown(pw.pw_dir, pw.pw_uid, pw.pw_gid) != 0 |
206 | || chmod(pw.pw_dir, 02755) /* set setgid bit on homedir */ | 204 | || chmod(pw.pw_dir, 02755) != 0 /* set setgid bit on homedir */ |
207 | ) { | 205 | ) { |
208 | bb_simple_perror_msg(pw.pw_dir); | 206 | bb_simple_perror_msg(pw.pw_dir); |
209 | } | 207 | } |