aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDenys Vlasenko <vda.linux@googlemail.com>2010-01-10 04:25:05 +0100
committerDenys Vlasenko <vda.linux@googlemail.com>2010-01-10 04:25:05 +0100
commit38d3e64d2593aa5bc6bb578e1cd9a73a2d4b26fa (patch)
tree7215b21dee93cbbc4e2739f7cd99e11c56fbd49b
parent1fbcb805a370e2e5f8ccfd4a45dff3ae401cd8bb (diff)
downloadbusybox-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.c24
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
80static void passwd_wrapper(const char *login) 83static 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 }