]> git.cameronkatri.com Git - pw-darwin.git/commitdiff
Removing -batch option from adduser. Adduser was written as
authorWolfram Schneider <wosch@FreeBSD.org>
Mon, 17 Aug 1998 18:50:29 +0000 (18:50 +0000)
committerWolfram Schneider <wosch@FreeBSD.org>
Mon, 17 Aug 1998 18:50:29 +0000 (18:50 +0000)
an *interactive* command for newbies. The pw(8) does now a much better
job for adding users from command line.  Also, the -batch option is
not well tested, buggy and unsupported.

adduser/adduser.8
adduser/adduser.perl

index 3b5bc9dfd4a7088626db46e90682778b40774d13..cbd8c05b8c679efcc6f8d830242c09ce0d3e9723 100644 (file)
@@ -22,7 +22,7 @@
 .\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
 .\" SUCH DAMAGE.
 .\"
-.\" $Id: adduser.8,v 1.24 1998/02/14 22:55:23 steve Exp $
+.\" $Id: adduser.8,v 1.25 1998/03/18 16:21:55 hoek Exp $
 .\"
 .Dd January 9, 1995
 .Dt ADDUSER 8
 .Nd command for adding new users
 .Sh SYNOPSIS
 .Nm adduser
-.Oo
-.Fl batch Ar username
-.Op Ar group Ns , Ns Op Ar group,...
-.Op Ar class
-.Op Ar fullname 
-.Op Ar password 
-.Oc
-.br
 .Op Fl check_only
 .br
 .Op Fl class Ar login_class
@@ -137,12 +129,6 @@ Parse command line options.
 .El
 .Sh OPTIONS
 .Bl -tag -width Ds
-.It Sy -batch username [group[,group]...] [class] [fullname] [password]
-Batch mode.
-The listed groups are secondary groups that the new user should be a
-member of in addition to the default login group. Null string arguments
-may be used as place holders and result in the default value for the
-nulled field being used.
 .It Sy -check_only
 Check /etc/passwd, /etc/group, /etc/shells and exit.
 .It Sy -class Ar login_class
@@ -217,34 +203,6 @@ Eval variables in this file. See
 for more
 details.
 .El
-.Sh EXAMPLES
-.Pp
-$ adduser
-.Pp
-Start adduser in interactive mode.
-.Pp
-$ adduser -batch baerenklau guest,staff,baer '' 'Teddy II' qwerty7
-.Pp
-Create user 'baerenklau' and  login group 'baerenklau'. Invite user 
-baerenklau into groups guest, staff and baer. Use default login class.
-Realname (fullname)
-is 'Teddy II'. Password is 'qwerty7' (don't use such passwords!). Create
-.Ev HOME
-directory 
-.Pa /home/baerenklau
-and copy all files and directories 
-from 
-.Pa /usr/share/skel
-to 
-.Pa /home/baerenklau .
-Send user baerenklau 
-a welcome message.
-.Pp
-$ adduser -uid 5000 -group guest -message no -batch vehlefanz
-.Pp
-Create user 'vehlefanz'. Login group is guest. Uid next available uid
-after 5000, for instance 5007. No other groups, no realname, no password.
-Do not send a welcome message.
 .Sh FILES
 .Bl -tag -width /etc/master.passwdxx -compact
 .It Pa /etc/master.passwd
@@ -276,6 +234,7 @@ logfile for adduser
 .Xr passwd 5 ,
 .Xr shells 5 ,
 .Xr addgroup 8 ,
+.Xr pw 8 ,
 .Xr pwd_mkdb 8 ,
 .Xr rmgroup 8 ,
 .Xr rmuser 8 ,
index 6c4e51c2f204a22536fffbd8a7bab1240b269c87..b6e57284848834495e04a4be775da17395736d76 100644 (file)
@@ -24,7 +24,7 @@
 # OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
 # SUCH DAMAGE.
 #
-# $Id: adduser.perl,v 1.39 1998/01/10 17:27:21 wosch Exp $
+# $Id: adduser.perl,v 1.40 1998/06/07 18:38:32 wosch Exp $
 
 
 # read variables
@@ -466,29 +466,6 @@ sub new_users_grplogin {
     return ($group_login, $group_login);
 }
 
-# return login group
-sub new_users_grplogin_batch {
-    local($name, $defaultgroup) = @_;
-    local($group_login, $group);
-
-    $group_login = $name;
-    $group_login = $defaultgroup if $defaultgroup ne $group_uniq;
-
-    if (defined $gid{$group_login}) {
-       # convert numeric groupname (gid) to groupname
-       $group_login = $gid{$group_login};
-    }
-
-    # if (defined($groupname{$group_login})) {
-    #  &add_group($groupname{$group_login}, $name);
-    # }
-
-    return $group_login
-       if defined($groupname{$group_login}) || $group_login eq $name;
-    warn "Group ``$group_login'' does not exist\a\n";
-    return 0;
-}
-
 # return other groups (string)
 sub new_users_groups {
     local($name, $other_groups) = @_;
@@ -748,39 +725,6 @@ sub new_users {
     }
 }
 
-sub batch {
-    local($name, $groups, $class, $fullname, $password) = @_;
-    local($sh);
-
-    $defaultshell = &shell_default_valid($defaultshell);
-    return 0 unless $home = &home_partition_valid($home);
-    return 0 if $dotdir ne &dotdir_default_valid($dotdir);
-    $send_message = &message_default;
-
-    return 0 if $name ne &new_users_name_valid($name);
-    $sh = $shell{$defaultshell};
-    ($u_id, $g_id) = &next_id($name);
-    $group_login = &new_users_grplogin_batch($name, $defaultgroup);
-    return 0 unless $group_login;
-    $g_id = $groupname{$group_login} if (defined($groupname{$group_login}));
-    ($flag, $new_groups) = &new_users_groups_valid($groups);
-    return 0 if $flag;
-
-    $class = $defaultclass if $class eq "";
-    $cryptpwd = "";
-    $cryptpwd = crypt($password, &salt) if $password ne "";
-    # obscure perl bug
-    $new_entry = "$name\:" . "$cryptpwd" .
-       "\:$u_id\:$g_id\:$class\:0:0:$fullname:$home/$name:$sh";
-    &append_file($etc_passwd, "$new_entry");
-    &new_users_pwdmkdb("$new_entry");
-    &new_users_group_update;
-    &new_users_passwd_update;  print "Added user ``$name''\n";
-    &sendmessage($name, @message_buffer) if $send_message ne "no";
-    &adduser_log("$name:*:$u_id:$g_id($group_login):$fullname");
-    &home_create("$home/$name", $name, $group_login);
-}
-
 # ask for password usage
 sub password_default {
     local($p) = $defaultpasswd;
@@ -801,7 +745,6 @@ sub check_root {
 sub usage {
     warn <<USAGE;
 usage: adduser
-    [-batch username [group[,group]...] [class] [fullname] [password]]
     [-check_only]
     [-class login_class]
     [-config_create]
@@ -838,7 +781,7 @@ sub uniq {
 sub salt {
     local($salt);              # initialization
     local($i, $rand);
-    local(@itoa64) = ( 0 .. 9, a .. z, A .. Z ); # 0 .. 63
+    local(@itoa64) = ( '0' .. '9', 'a' .. 'z', 'A' .. 'Z' ); # 0 .. 63
 
     warn "calculate salt\n" if $verbose > 1;
     # to64
@@ -890,8 +833,9 @@ sub parse_arguments {
        elsif (/^--?(message)$/) { $send_message = $argv[0]; shift @argv;
                                   $sendmessage = 1; }
        elsif (/^--?(batch)$/)   {
-           @batch = splice(@argv, 0, 5); $verbose = 0;
-           die "batch: too few arguments\n" if $#batch < 0;
+           warn "The -batch option is not supported anymore.\n",
+           "Please use the pw(8) command line tool!\n";
+           exit(0);
        }
        # see &config_read
        elsif (/^--?(config_create)$/)  { &create_conf; }
@@ -1419,7 +1363,7 @@ $check_only = 0;
 &config_read(@ARGV);   # read variables form config-file
 &parse_arguments(@ARGV);    # parse arguments
 
-if (!$check_only &&  $#batch < 0) {
+if (!$check_only) {
     &copyright; &hints;
 }
 
@@ -1432,7 +1376,6 @@ $changes = 0;
 &group_check;                  # check for incon*
 exit 0 if $check_only;         # only check consistence and exit
 
-exit(!&batch(@batch)) if $#batch >= 0; # batch mode
 
 # interactive
 # some questions