sftpserver.sh 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  1. #!/usr/bin/env bash
  2. while true;do ls | grep -q dockerbunker.sh;if [[ $? == 0 ]];then BASE_DIR=$PWD;break;else cd ../;fi;done
  3. PROPER_NAME="sFTP Server"
  4. SERVICE_NAME="$(echo -e "${PROPER_NAME,,}" | tr -d '[:space:]')"
  5. PROMPT_SSL=1
  6. safe_to_keep_volumes_when_reconfiguring=1
  7. declare -a environment=( "data/env/dockerbunker.env" "data/include/init.sh" )
  8. for env in "${environment[@]}";do
  9. [[ -f "${BASE_DIR}/$env" ]] && source "${BASE_DIR}/$env"
  10. done
  11. declare -A WEB_SERVICES
  12. declare -a containers=( "sftpserver-service-dockerbunker" )
  13. declare -a volumes=( )
  14. declare -a networks=( )
  15. declare -A IMAGES=( [service]="atmoz/sftp:alpine-3.7" )
  16. declare -a add_to_network=( "sftpserver-service-dockerbunker" )
  17. [[ -z $1 ]] && options_menu
  18. configure() {
  19. pre_configure_routine
  20. echo -e "# \e[4msFTP Settings\e[0m"
  21. set_domain
  22. userNumber=0
  23. done=""
  24. while [[ -z $done ]];do
  25. [[ -f "${CONF_DIR}"/sftpserver/users.conf ]] && rm "${CONF_DIR}"/sftpserver/users.conf
  26. unset user password
  27. ((++userNumber))
  28. read -p "sFTP User $userNumber: " -ei "" user
  29. echo "USER $user"
  30. while [[ "${#password}" -le 6 || "$password" != *[A-Z]* || "$password" != *[a-z]* || "$password" != *[0-9]* ]];do
  31. if [ $VALIDATE ];then
  32. echo -e "\n\e[31m Password does not meet requirements\e[0m"
  33. fi
  34. stty_orig=$(stty -g)
  35. stty -echo
  36. read -p " $(printf "\n \e[4mPassword requirements\e[0m\n Minimum Length 6,Uppercase, Lowercase, Integer\n\n Enter Password:") " -ei "" password
  37. stty "$stty_orig"
  38. echo ""
  39. VALIDATE=1
  40. done
  41. unset VALIDATE
  42. declare -A FTP_USERS
  43. FTP_USERS+=( [$user]="$password" )
  44. FTP_USERS_ARRAY+=( "[${user}]=\"${password}\"" )
  45. prompt_confirm "Add another user?"
  46. [[ $? == 1 ]] && done=1
  47. done
  48. [[ ! -d "${CONF_DIR}"/sftpserver/conf/ssh ]] && mkdir -p "${CONF_DIR}"/sftpserver/conf/ssh
  49. USERID=1001
  50. for user in ${!FTP_USERS[@]};do
  51. echo "$user:${FTP_USERS[$user]}:${USERID}:100" >> "${CONF_DIR}"/sftpserver/users.conf
  52. ((++USERID))
  53. done
  54. cat <<-EOF >> "${SERVICE_ENV}"
  55. PROPER_NAME="${PROPER_NAME}"
  56. SERVICE_NAME=${SERVICE_NAME}
  57. LE_EMAIL=${LE_EMAIL}
  58. SSL_CHOICE=${SSL_CHOICE}
  59. SERVICE_DOMAIN=${SERVICE_DOMAIN}
  60. FTP_USERS=( ${FTP_USERS_ARRAY[@]} )
  61. EOF
  62. [[ ! -d "${BASE_DIR}"/data/web/sftpserver ]] && mkdir -p "${BASE_DIR}"/data/web/sftpserver
  63. [[ ! -d "${CONF_DIR}"/sftpserver/conf/ssh ]] && mkdir "${CONF_DIR}"/sftpserver/conf/ssh
  64. [[ ! -f "${CONF_DIR}"/sftpserver/ssh/ssh_host_ed25519_key ]] && ssh-keygen -t ed25519 -f "${CONF_DIR}"/sftpserver/ssh/ssh_host_ed25519_key
  65. [[ ! -f "${CONF_DIR}"/sftpserver/ssh/ssh_host_rsa_key ]] && ssh-keygen -t rsa -b 4096 -f "${CONF_DIR}"/sftpserver/ssh/ssh_host_rsa_key
  66. post_configure_routine
  67. }
  68. if [[ $1 == "letsencrypt" ]];then
  69. $1 $*
  70. else
  71. $1
  72. fi