This file is indexed.

/usr/sbin/drbl-useradd-file 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
#!/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 use 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

#
ACCOUNT_FILE="$1"
ACCOUNT_FILE_TMP=`mktemp /tmp/account_tmp.XXXXXX`
mode=""

USAGE="Usage: $0 account_file"
# Check if root or not
if [ ! "$UID" = "0" ]; then
  echo
  echo "[$LOGNAME] You need to run this script \"$0\" as root."
  echo
  exit 1
fi

if [ $# -ne 1 ]; then
  echo "$USAGE"
  echo "Create or delete accounts from the specified account_file."
  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 "-----------------------------------------------------------------"
  echo "# account for student"
  echo "s		89101	89129  g3c9   8"
  echo "# account for teacher"
  echo "tckps	01	99   teacher  drblnice"
  echo "-----------------------------------------------------------------"
  exit 1
fi

[ ! -f "$ACCOUNT_FILE" ] && echo "File $ACCOUNT_FILE not exists!" && exit 1
[ ! -f "$useradd_range_exec_file" ] && echo "Can NOT find $useradd_range_exec_file file!" && exit 1 
[ ! -f "$userdel_range_exec_file" ] && echo "Can NOT find $userdel_range_exec_file file!" && exit 1 

# filter the comment line, only keep the account line
grep -v '^[[:space:]]*#' $ACCOUNT_FILE > $ACCOUNT_FILE_TMP

#
if [ -n "$(basename $0 | grep -E "useradd")" ]; then
  mode="useradd"
elif [ -n "$(basename $0 | grep -E "userdel")" ]; then
  mode="userdel"
else
  echo "Unknown mode!"
  exit 1
fi

# useradd mode
if [ "$mode" = "useradd" ]; then
   while read prefix start end groupname password_opt; do
     # 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 
     if [ -n "$prefix" ]; then
       echo -n "Creating accounts with $prefix $start $end $groupname $password_opt"
       $useradd_range_exec_file $prefix $start $end $groupname $password_opt
       echo "done!"
     fi
   done < $ACCOUNT_FILE_TMP
fi

# userdel mode
if [ "$mode" = "userdel" ]; then
   # prompt to ask some confirmation
   echo -n "Do you also want to clean user's home directory [y/N] ? "
   read clean_home
   case "$clean_home" in
      y|Y|[yY][eE][sS]) 
         echo "Warning! The user's home directory will be deleted! Are you sure ?"
         echo -n "[y/N] "
         read clean_home_confirm
         ;;
      *)
         RM_HOME_OPT=""
   esac
   echo -n "Do you also want to clean group [Y/n] ? "
   read clean_group
   CONFIRM_TMP=`mktemp /tmp/confirm_tmp.XXXXXX`
   echo "$clean_home" >> $CONFIRM_TMP
   echo "$clean_home_confirm" >> $CONFIRM_TMP
   echo "$clean_group" >> $CONFIRM_TMP

   while read prefix start end groupname password_opt; do
     if [ -n "$prefix" ]; then
       echo "Deleting accounts with $prefix $start $end $groupname $password_opt"
       $userdel_range_exec_file $prefix $start $end $groupname < $CONFIRM_TMP
       echo "done!"
     fi
   done < $ACCOUNT_FILE_TMP
fi

[ -f "$ACCOUNT_FILE_TMP" ] && rm -f $ACCOUNT_FILE_TMP
[ -f "$CONFIRM_TMP" ] && rm -f $CONFIRM_TMP