autouser/autouser.sh

299 lines
6.5 KiB
Bash
Executable File

#!/bin/bash
FILE="${@: -1}"
if [[ ! -f "$FILE" ]]; then
echo "File \"$FILE\" doesn't exist!"
exit
fi
# User '.csv' columns
COL_USERNAME="1"
COL_FULLNAME="2"
COL_USERUID="3"
COL_USERGID="4"
COL_USERGROUPS="5"
COL_TLFN="6"
COL_EXTRAINFO="7"
COL_USERSHELL="8"
COL_USERLOCKED="9"
# Group '.csv' columns
COL_GROUPNAME="1"
COL_GROUPGID="2"
# Control variables
DRYRUN=false
FILE_CONTENTS="$(cat ${@: -1})"
CREATE_USERS=false
DELETE_USERS=false
CREATE_GROUPS=false
DELETE_GROUPS=false
DELIM=";"
usage ()
{
echo "Usage: ./autouser.sh \$PARAMETER file.csv"
echo ""
echo "PARAMETERS"
echo " --help || -h (Show this help prompt)"
echo " --dry-run (Test without executing any changes)"
echo " --create-users users.csv (Create users from a .csv file)"
echo " --create-groups groups.csv (Create groups from a .csv file)"
echo " --delete-users users.csv (Delete users from a .csv file)"
echo " --delete-groups groups.csv (Delete groups from a .csv file)"
exit
}
rootCheck ()
{
if [[ "$(id -u)" -ne 0 ]]; then
echo "You must be root to run this parameter"
exit
fi
}
cutter ()
{
echo "$1" | cut -d "$DELIM" -f "$2"
}
turnLowercase()
{
echo "$1" | tr "[:upper:]" "[:lower:]" | sed 's/ñ/n/g'
}
createGroups ()
{
while read line; do
GID=$(cutter "${line}" "$COL_GROUPGID")
GROUPNAME=$(turnLowercase $(cutter "${line}" "$COL_GROUPNAME"))
if [[ -z "$GID" ]]; then
echo "[+] Adding group $GROUPNAME..."
groupadd $GROUPNAME
else
echo "[+] Adding group $GROUPNAME with GID $GID..."
groupadd $GROUPNAME -g $GID
fi
done <<< "$FILE_CONTENTS"
}
createGroupsDry ()
{
while read line; do
GID=$(cutter "${line}" "$COL_GROUPGID")
GROUPNAME=$(turnLowercase $(cutter "${line}" "$COL_GROUPNAME"))
if [[ -z "$GID" ]]; then
echo "groupadd $GROUPNAME"
else
echo "groupadd $GROUPNAME -g $GID"
fi
done <<< "$FILE_CONTENTS"
}
deleteGroups ()
{
while read line; do
GROUPNAME=$(turnLowercase $(cutter "${line}" "$COL_GROUPNAME"))
echo "[+] Deleting group $GROUPNAME..."
groupdel $GROUPNAME
done <<< "$FILE_CONTENTS"
}
deleteGroupsDry ()
{
while read line; do
GROUPNAME=$(turnLowercase $(cutter "${line}" "$COL_GROUPNAME"))
echo "groupdel $GROUPNAME"
done <<< "$FILE_CONTENTS"
}
createUsers ()
{
while read line; do
USERNAME=$(turnLowercase $(cutter "${line}" "$COL_USERNAME"))
FULLNAME=$(cutter "${line}" "$COL_FULLNAME")
USERUID=$(cutter "${line}" "$COL_USERUID")
USERGID=$(turnLowercase $(cutter "${line}" "$COL_USERGID"))
USERGROUPS=$(turnLowercase $(cutter "${line}" "$COL_USERGROUPS"))
TLFN=$(cutter "${line}" "$COL_TLFN")
EXTRAINFO=$(cutter "${line}" "$COL_EXTRAINFO")
USERSHELL=$(cutter "${line}" "$COL_USERSHELL")
USERLOCKED=$(cutter "${line}" "$COL_USERLOCKED")
echo "[+] Adding user $USERNAME..."
useradd -m $USERNAME
echo $USERNAME:$USERNAME | chpasswd
if [[ ! -z "$FULLNAME" ]]; then
chfn -f "$FULLNAME" "$USERNAME" 1>/dev/null
fi
if [[ ! -z "$USERUID" ]]; then
usermod -u $USERUID $USERNAME
fi
if [[ ! -z "$USERGID" ]]; then
usermod -g $USERGID $USERNAME
fi
if [[ ! -z "$USERGROUPS" ]]; then
usermod -G $(echo $USERGROUPS | tr "|" ",") $USERNAME
fi
if [[ ! -z "$TLFN" ]]; then
chfn -p "$TLFN" $USERNAME 1>/dev/null
fi
if [[ ! -z "$EXTRAINFO" ]]; then
chfn -o "$EXTRAINFO" $USERNAME 1>/dev/null
fi
if [[ ! -z "$USERSHELL" ]]; then
usermod -s $USERSHELL $USERNAME
else
usermod -s /bin/bash $USERNAME
fi
if [[ $USERLOCKED == "SI" ]]; then
usermod -L $USERNAME
fi
done <<< "$FILE_CONTENTS"
}
createUsersDry ()
{
while read line; do
USERNAME=$(turnLowercase $(cutter "${line}" "$COL_USERNAME"))
FULLNAME=$(cutter "${line}" "$COL_FULLNAME")
USERUID=$(cutter "${line}" "$COL_USERUID")
USERGID=$(turnLowercase $(cutter "${line}" "$COL_USERGID"))
USERGROUPS=$(turnLowercase $(cutter "${line}" "$COL_USERGROUPS"))
TLFN=$(cutter "${line}" "$COL_TLFN")
EXTRAINFO=$(cutter "${line}" "$COL_EXTRAINFO")
USERSHELL=$(cutter "${line}" "$COL_USERSHELL")
USERLOCKED=$(cutter "${line}" "$COL_USERLOCKED")
echo "useradd -m $USERNAME"
echo "echo \"$USERNAME:$USERNAME | chpasswd\""
if [[ ! -z "$FULLNAME" ]]; then
echo "chfn -f \"$FULLNAME\" $USERNAME"
fi
if [[ ! -z "$USERUID" ]]; then
echo "usermod -u $USERUID $USERNAME"
fi
if [[ ! -z "$USERGID" ]]; then
echo "usermod -g $USERGID $USERNAME"
fi
if [[ ! -z "$USERGROUPS" ]]; then
echo "usermod -G $(echo $USERGROUPS | tr "|" ",") $USERNAME"
fi
if [[ ! -z "$TLFN" ]]; then
echo "chfn -p \"$TLFN\" $USERNAME"
fi
if [[ ! -z "$EXTRAINFO" ]]; then
echo "usermod -c \"$EXTRAINFO\" $USERNAME"
fi
if [[ ! -z "$USERSHELL" ]]; then
echo "usermod -s $USERSHELL $USERNAME"
else
echo "usermod -s /bin/bash $USERNAME"
fi
if [[ $USERLOCKED == "SI" ]]; then
echo "usermod -L $USERNAME"
fi
done <<< "$FILE_CONTENTS"
}
deleteUsers ()
{
while read line; do
USERNAME=$(turnLowercase $(cutter "${line}" "$COL_USERNAME"))
echo "[+] Deleting user $USERNAME..."
userdel -r $USERNAME 2>/dev/null
groupdel $USERNAME 2>/dev/null
done <<< "$FILE_CONTENTS"
}
deleteUsersDry ()
{
while read line; do
USERNAME=$(turnLowercase $(cutter "${line}" "$COL_USERNAME"))
echo "userdel -r $USERNAME"
echo "groupdel $USERNAME"
done <<< "$FILE_CONTENTS"
}
for arg in "$@"
do
if [[ "$arg" == "-h" || "$arg" == "--help" ]]; then
usage
exit
fi
if [[ "$arg" == "--dry-run" ]]; then
DRYRUN=true
fi
if [[ "$arg" == "--create-groups" ]]; then
CREATE_GROUPS=true
fi
if [[ "$arg" == "--delete-groups" ]]; then
DELETE_GROUPS=true
fi
if [[ "$arg" == "--create-users" ]]; then
CREATE_USERS=true
fi
if [[ "$arg" == "--delete-users" ]]; then
DELETE_USERS=true
fi
done
if [[ "$CREATE_GROUPS" == true ]]; then
if [[ "$DRYRUN" == true ]]; then
createGroupsDry
else
rootCheck
createGroups
fi
exit
fi
if [[ "$DELETE_GROUPS" == true ]]; then
if [[ "$DRYRUN" == true ]]; then
deleteGroupsDry
else
rootCheck
deleteGroups
fi
exit
fi
if [[ "$CREATE_USERS" == true ]]; then
if [[ "$DRYRUN" == true ]]; then
createUsersDry
else
rootCheck
createUsers
fi
exit
fi
if [[ "$DELETE_USERS" == true ]]; then
if [[ "$DRYRUN" == true ]]; then
deleteUsersDry
else
rootCheck
deleteUsers
fi
exit
fi
usage