mirror of
https://github.com/joglomedia/LEMPer.git
synced 2026-04-11 23:48:19 +00:00
86 lines
2.2 KiB
Bash
Executable File
86 lines
2.2 KiB
Bash
Executable File
#!/bin/bash
|
|
function header_msg() {
|
|
clear
|
|
cat <<- _EOF_
|
|
#==========================================================================#
|
|
# Welcome to LEMPer Stack Manager for Debian/Ubuntu server #
|
|
#==========================================================================#
|
|
# A simple tool to add new user into system. #
|
|
# #
|
|
# For more information please visit https://masedi.net/lemper #
|
|
#==========================================================================#
|
|
_EOF_
|
|
}
|
|
|
|
# Check if user is root
|
|
if [ $(id -u) != "0" ]; then
|
|
echo "Error: Please use root to add new user."
|
|
exit 1
|
|
fi
|
|
|
|
header_msg
|
|
|
|
echo -n "Add new user? [y/n]: "
|
|
read tambah
|
|
|
|
while [[ "${tambah}" != n* ]]
|
|
do
|
|
echo -en "\nUsername: "
|
|
read namauser
|
|
echo -n "Password: "
|
|
read katasandi
|
|
|
|
echo -n "Expire date? 'unlimited' for unlimited [yyyy-mm-dd]: "
|
|
read expired
|
|
if [[ "${expired}" != "unlimited" ]]; then
|
|
setexpiredate="-e $expired"
|
|
else
|
|
setexpiredate=""
|
|
fi
|
|
|
|
echo -n "Allow shell access? [y/n]: "
|
|
read aksessh
|
|
if [[ "${aksessh}" == y* ]]; then
|
|
setusershell="-s /bin/bash"
|
|
else
|
|
setusershell="-s /bin/false"
|
|
fi
|
|
|
|
echo -n "Create home directory? [y/n]: "
|
|
read enablehomedir
|
|
if [[ "${enablehomedir}" == y* ]]; then
|
|
sethomedir="-d /home/${namauser} -m"
|
|
else
|
|
sethomedir="-d /home/${namauser} -M"
|
|
fi
|
|
|
|
echo -n "Set users group? [y/n]: "
|
|
read setug
|
|
if [[ "${setug}" == y* ]]; then
|
|
setgroup="-g users"
|
|
else
|
|
setgroup=""
|
|
fi
|
|
|
|
#user_exists=$(grep -c '^${namauser}:' /etc/passwd)
|
|
|
|
if [[ -z $(getent passwd "${namauser}") ]]; then
|
|
useradd ${sethomedir} ${setexpiredate} ${setgroup} ${setusershell} ${namauser}
|
|
echo "${namauser}:${katasandi}" | chpasswd
|
|
|
|
echo -n "Add user ${namauser} to sudoers? [y/n]: "
|
|
read setsudoers
|
|
if [[ "${setsudoers}" == y* ]]; then
|
|
usermod -aG sudo ${namauser}
|
|
fi
|
|
else
|
|
echo -e "\nUser '${namauser}' already exits."
|
|
sleep 3
|
|
fi
|
|
|
|
header_msg
|
|
|
|
echo -en "\nAdd another user? [y/n]: "
|
|
read tambah
|
|
done
|