/usr/sbin/drbl-useradd is in drbl 2.20.11-4.
This file is owned by root:root, with mode 0o755.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 | #!/bin/bash
# Author: Blake, Kuo-Lien Huang
# License: GPL
# Description:
# * creat and delete accounts for DRBL, actually it for NIS (YP).
#
# Modified by Steven Shiau <steven@nchc.org.tw> to used in DRBL for Redhat
# Load DRBL setting and functions
DRBL_SCRIPT_PATH="${DRBL_SCRIPT_PATH:-/usr/share/drbl}"
. $DRBL_SCRIPT_PATH/sbin/drbl-conf-functions
#
USAGE() {
echo "Usage: "
echo "Option 1:"
echo "$0 [-s|--single] <username> <groupname>"
echo " generate a single user <username> with group <groupname>"
echo "Option 2:"
echo "$0 [-r|--range] <prefix> <start> <end> <groupname> [<passwd_opt>]"
echo " generate a range of users from <prefix><start> to <prefix><end> with group <groupname>,"
echo " passwd_opt:"
echo " If one digit, it's the length of randomly created password."
echo " If blank, it will be randomly generated with some (say:8) characters."
echo " Other setting is the password itself."
echo "Option 3:"
echo "$0 [-f|--file] <filename>"
echo " generate users that are listed in <filename>."
echo " the username/password pairs are listed in $useradd_gen"
echo
echo " the format of the file <filename>: PREFIX START END GROUPNAME PASSWD_OPT"
echo " passwd_opt:"
echo " If one digit, it's the length of randomly created password."
echo " If blank, it will be randomly generated with some (say:8) characters."
echo " Other setting is the password itself."
echo " for example: "
echo " # account for student"
echo " s 89101 89129 g3c9 8"
echo " # account for teacher"
echo " tckps 01 99 teacher drblnice"
echo "Option 4:"
echo "$0 [-l|--list] <filename>"
echo " generate users that are listed in <filename>."
echo " the username/password pairs are listed in $useradd_gen"
echo
echo " the format of the file <filename>: ID GROUPNAME PASSWD_OPT"
echo " passwd_opt:"
echo " If one digit, it's the length of randomly created password."
echo " If blank, it will be randomly generated with some (say:8) characters."
echo " Other setting is the password itself."
echo " for example: "
echo " # account for student001"
echo " student001 g3c9 8"
echo " # account for student002"
echo " student002 g3c9 drblnice"
}
#
check_if_root
# Parse command-line options
while [ $# -gt 0 ]; do
case "$1" in
-s|--single)
format="single"
shift; username=$1
shift; groupname=$1
shift;;
-r|--range)
format="range"
shift; prefix=$1
shift; start=$1
shift; end=$1
shift; groupname=$1
shift
if [ -z "$(echo $1 |grep ^-.)" ]; then
# skip the -xx option, in case
passwd_opt=$1
fi
shift ;;
-f|--file)
format="file"
shift; filename=$1
shift ;;
-l|--list)
format="list"
shift; filename=$1
shift ;;
-*) echo "${0}: ${1}: invalid option" >&2
USAGE
exit 2 ;;
*) break ;;
esac
done
# check if groupname is not valid one
if `echo "$groupname" | grep -q "^[0-9]"`; then
echo "groupname can NOT begin with digits (0-9)!"
echo "The one you specified is \"$groupname\""
echo "Program terminated"
exit 1
fi
#
case "$format" in
single)
[ -z "$username" ] && echo "No username! Program terminated!" && exit 1
[ -z "$groupname" ] && echo "No groupname! Program terminated!" && exit 1
;;
range)
[ -z "$prefix" ] && echo "No prefix! Program terminated!" && exit 1
[ -z "$start" ] && echo "No start! Program terminated!" && exit 1
[ -z "$end" ] && echo "No end! Program terminated!" && exit 1
[ -z "$groupname" ] && echo "No groupname! Program terminated!" && exit 1
;;
file)
[ -z "$filename" ] && echo "No filename! Program terminated!" && exit 1
;;
list)
[ -z "$filename" ] && echo "No filename! Program terminated!" && exit 1
;;
*)
USAGE
exit 1
;;
esac
# check the necessary files
file_to_be_checked="$useradd_range_exec_file $userdel_range_exec_file $useradd_file_exec_file $userdel_file_exec_file $useradd_list_exec_file $userdel_list_exec_file"
for ifile in $file_to_be_checked; do
if ! type "$ifile" &>/dev/null; then
echo "No $ifile file!"
exit 1
fi
done
#
useradd_gen_tmp="$(mktemp /tmp/useradd.XXXXXX)"
# file to store the username and password, clean it first.
[ -f "$useradd_gen" ] && rm -f $useradd_gen
# add/delete single user
case "$format" in
single)
# add single users
echo "Password of $username ? (It will not be echoed in the screen. If you want to use random password, just press Enter)"
read -s passwd_single1
if [ -z "$passwd_single1" ]; then
make_random_password
passwd_single1=$random_password
else
echo "Retype password of $username: (It will not be echoed in the screen)"
read -s passwd_single2
while [ "$passwd_single1" != "$passwd_single2" ]; do
echo "Sorry, passwords do not match"
echo "Password of $username ? (It will not be echoed in the screen. If you want to use random password, just press Enter)"
read -s passwd_single1
echo "Retype password of $username: (It will not be echoed in the screen)"
read -s passwd_single2
done
fi
echo "The password of $username is \"$passwd_single1\"" >> $useradd_gen_tmp
run_cmd="/usr/sbin/groupadd $groupname; /usr/sbin/useradd -m $username -g $groupname; echo \"$username:$passwd_single1\" | /usr/sbin/chpasswd"
;;
range)
# add a range of users
run_cmd="$useradd_range_exec_file $prefix $start $end $groupname $passwd_opt"
;;
file)
# add users which are listed in file
run_cmd="$useradd_file_exec_file $filename"
;;
list)
# add users which are listed line by line in file
run_cmd="$useradd_list_exec_file $filename"
;;
esac
echo "Creating..."
eval "$run_cmd | tee -a $useradd_gen_tmp"
# filter those we do not want... just output the password and username
grep "The password of" $useradd_gen_tmp > $useradd_gen
chmod 600 $useradd_gen
chown root.root $useradd_gen
#
if [ -e /etc/debian_version ]; then
tune-debian-dev-group-perm -g "$desktop_user_group_debian" -e -r
fi
#
echo "Now update the NIS data in /var/yp ..."
make -C /var/yp/
echo
#
[ "$BOOTUP" = "color" ] && $SETCOLOR_WARNING
echo "***********************************************************"
echo "The username/password pairs are listed in \"$useradd_gen\"."
echo "***********************************************************"
[ "$BOOTUP" = "color" ] && $SETCOLOR_NORMAL
[ -f "$useradd_gen_tmp" ] && rm -f $useradd_gen_tmp
echo "Done."
exit 0
|