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 | } |
