script-user-add 1.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. #!/usr/bin/env bash
  2. # Add a user to the Hartman Lab server
  3. # Copyright 2021-2025 Bryan C. Roessler
  4. # Licensed under the Apache License, Version 2.0
  5. p="${BASH_SOURCE[0]%/*}"; [[ -r $p/script-functions ]] && . "$p"/script-functions || exit 1
  6. is_root
  7. echo "Usage: $0 [username] [password]"
  8. case $# in
  9. 0) prompt user; prompt password ;;
  10. 1) user="$1"; prompt password ;;
  11. 2) user="$1"; password="$2" ;;
  12. *) echo "Too many arguments provided"; exit 1 ;;
  13. esac
  14. useradd_cmd=(useradd -m -U)
  15. group_str=""
  16. if id -u "$user" &>/dev/null; then
  17. ask_ok "User $user exists. Run script-user-remove first?" || exit $?
  18. "$p/script-user-remove" "$user" || exit $?
  19. fi
  20. ask_ok "Create user $user with password $password?" || exit $?
  21. restore=0
  22. if [[ -d /mnt/array/home-retired/$user ]]; then
  23. ask_ok "Restore user $user's files from /mnt/array/home-retired/$user?" && restore=1
  24. fi
  25. samba=0
  26. ask_ok "Enable shared file access for user $user?" && group_str="smbgrp" && samba=1
  27. ask_ok "Make $user an admin?" && group_str+=",wheel"
  28. [[ -n $group_str ]] && useradd_cmd+=("-G" "$group_str")
  29. useradd_cmd+=("$user")
  30. "${useradd_cmd[@]}"
  31. echo "$user:$password" | chpasswd
  32. if (( restore )); then
  33. if rsync -av --progress=info2 "/mnt/array/home-retired/$user/" "/home/$user/"; then
  34. ask_ok "User $user's files successfully restored, remove backup at /mnt/array/home-retired/$user?" && \
  35. rm -rf "/mnt/array/home-retired/$user"
  36. fi
  37. fi
  38. if (( samba )); then
  39. (echo "$password"; echo "$password") | smbpasswd -a -s "$user"
  40. fi
  41. ask_ok "Prompt user to reset password on next login?" &&
  42. passwd --expire "$user" &&
  43. echo "NOTE: The file sharing (smbpasswd) will not be changed"
  44. # Copy manual to user desktop
  45. desktop="/home/$user/Desktop"
  46. mkdir -p "$desktop"
  47. "$p/script-deploy-manual" "$user"
  48. exit 0