|
| 1 | +#!/bin/bash |
| 2 | + |
| 3 | +# ############################################################################# |
| 4 | +# (C) @RandomCoderOrg @SaicharanKandukuri 2022 |
| 5 | +# A useradd wrapper to add a new non-root user for proot linux container |
| 6 | +# ############################################################################# |
| 7 | + |
| 8 | +REQUIRED_DEPS="openssl" |
| 9 | +NOPASSWD=false |
| 10 | + |
| 11 | +# sudo check |
| 12 | +[[ $EUID -ne 0 ]] && die "You need to be root to run this script" |
| 13 | + |
| 14 | +# check for dependencies |
| 15 | +for debs in $REQUIRED_DEPS; do |
| 16 | + if ! dpkg -s "$debs" >/dev/null 2>&1; then |
| 17 | + echo "Missing dependency: $debs" |
| 18 | + fi |
| 19 | +done |
| 20 | + |
| 21 | +# check for arguments |
| 22 | +if [[ $# -le 1 ]]; then |
| 23 | + echo "Usage: $0 [ -u | --user | --username ] <username> [ -p | --passwd | --password ] <password> [options]" |
| 24 | + echo "options:" |
| 25 | + echo "--nopasswd -> do not set a password" |
| 26 | + exit 1 |
| 27 | +fi |
| 28 | + |
| 29 | +while [[ $# -gt 0 ]]; do |
| 30 | + case $1 in |
| 31 | + -u | --user | --username) |
| 32 | + USERNAME="$2" |
| 33 | + shift 2 |
| 34 | + ;; |
| 35 | + -p | --passwd | --password) |
| 36 | + PASSWORD="$2" |
| 37 | + shift 2 |
| 38 | + ;; |
| 39 | + --nopasswd) NOPASSWD=true ;; |
| 40 | + esac |
| 41 | +done |
| 42 | + |
| 43 | +if [ -d /home/$USERNAME ]; then |
| 44 | + echo "User $USERNAME already exists" |
| 45 | + exit 1 |
| 46 | +fi |
| 47 | + |
| 48 | +echo "creating user $USERNAME" |
| 49 | +if $NOPASSWD; then |
| 50 | + useradd -m -G sudo -p "$(openssl passwd -1 "$PASSWORD")" -d /home/"$USERNAME" -k /etc/skel -s "$SHELL" "$USERNAME" |
| 51 | + echo "Adding user $USERNAME to sudoers " |
| 52 | + echo "$USERNAME" ALL=\(root\) ALL >/etc/sudoers.d/"$USERNAME" |
| 53 | + chmod 0440 /etc/sudoers.d/"$USERNAME" |
| 54 | +else |
| 55 | + useradd -m -G sudo -p "$(openssl passwd -1 "$PASSWORD")" -d /home/"$USERNAME" -k /etc/skel -s "$SHELL" "$USERNAME" |
| 56 | + echo "Adding user $USERNAME to sudoers" |
| 57 | + echo "$USERNAME" ALL=\(root\) NOPASSWD: ALL >/etc/sudoers.d/"$USERNAME" |
| 58 | + chmod 0440 /etc/sudoers.d/"$USERNAME" |
| 59 | +fi |
| 60 | + |
| 61 | +# TODO: copy user layout from root to new user |
| 62 | +echo "Done" |
0 commit comments