wordpress.sh 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117
  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="Wordpress"
  4. SERVICE_NAME="$(echo -e "${PROPER_NAME,,}" | tr -d '[:space:]')"
  5. PROMPT_SSL=1
  6. declare -a environment=( "data/env/dockerbunker.env" "data/include/init.sh" )
  7. for env in "${environment[@]}";do
  8. [[ -f "${BASE_DIR}/$env" ]] && source "${BASE_DIR}/$env"
  9. done
  10. declare -A WEB_SERVICES
  11. declare -a containers=( "${SERVICE_NAME}-db-dockerbunker" "${SERVICE_NAME}-service-dockerbunker" )
  12. declare -a add_to_network=( "${SERVICE_NAME}-service-dockerbunker" )
  13. declare -A volumes=( [${SERVICE_NAME}-db-vol-1]="/var/lib/mysql" [${SERVICE_NAME}-data-vol-1]="/var/www/html/wp-content" )
  14. declare -a networks=( "dockerbunker-${SERVICE_NAME}" )
  15. declare -A IMAGES=( [db]="mariadb:10.2" [service]="dockerbunker/${SERVICE_NAME}" )
  16. declare -A BUILD_IMAGES=( [dockerbunker/${SERVICE_NAME}]="${DOCKERFILES}/${SERVICE_NAME}" )
  17. [[ -z $1 ]] && options_menu
  18. configure() {
  19. pre_configure_routine
  20. echo -e "# \e[4m${PROPER_NAME} Settings\e[0m"
  21. set_domain
  22. prompt_confirm "Use Basic Authentication to protect /wp-admin?"
  23. if [[ $? == 0 ]];then
  24. BASIC_AUTH="yes"
  25. if [[ -z $HTUSER ]]; then
  26. while [[ -z ${HTUSER} ]];do
  27. read -p "Basic Auth Username: " -ei "" HTUSER
  28. done
  29. else
  30. read -p "Basic Auth Username: " -ei "${HTUSER}" HTUSER
  31. fi
  32. unset HTPASSWD
  33. while [[ "${#HTPASSWD}" -le 6 || "$HTPASSWD" != *[A-Z]* || "$HTPASSWD" != *[a-z]* || "$HTPASSWD" != *[0-9]* ]];do
  34. if [ $VALIDATE ];then
  35. echo -e "\n\e[31m Password does not meet requirements\e[0m"
  36. fi
  37. stty_orig=$(stty -g)
  38. stty -echo
  39. read -p " $(printf "\n \e[4mPassword requirements\e[0m\n Minimum Length 6, Uppercase, Lowercase, Integer\n\n Enter Password:") " -ei "" HTPASSWD
  40. stty "$stty_orig"
  41. echo ""
  42. VALIDATE=1
  43. done
  44. unset VALIDATE
  45. echo ""
  46. else
  47. AUTH_SWITCH="#"
  48. BASIC_AUTH="no"
  49. fi
  50. # avoid tr illegal byte sequence in macOS when generating random strings
  51. if [[ $OSTYPE =~ "darwin" ]];then
  52. if [[ $LC_ALL ]];then
  53. oldLC_ALL=$LC_ALL
  54. export LC_ALL=C
  55. else
  56. export LC_ALL=C
  57. fi
  58. fi
  59. cat <<-EOF >> "${SERVICE_ENV}"
  60. SERVICE_DOMAIN=${SERVICE_DOMAIN}
  61. LE_EMAIL=${LE_EMAIL}
  62. # ------------------------------
  63. # Security Settings
  64. # ------------------------------
  65. SSL_CHOICE=${SSL_CHOICE}
  66. BASIC_AUTH=${BASIC_AUTH}
  67. AUTH_SWITCH=${AUTH_SWITCH}
  68. HTUSER=${HTUSER}
  69. HTPASSWD=${HTPASSWD}
  70. # ------------------------------
  71. # SQL database configuration
  72. # ------------------------------
  73. MYSQL_DATABASE=wpdb
  74. MYSQL_USER=wordpress
  75. # Please use long, random alphanumeric strings (A-Za-z0-9)
  76. MYSQL_PASSWORD=$(tr -dc 'a-zA-Z0-9' < /dev/urandom | head -c 28)
  77. MYSQL_ROOT_PASSWORD=$(tr -dc 'a-zA-Z0-9' < /dev/urandom | head -c 28)
  78. EOF
  79. if [[ $OSTYPE =~ "darwin" ]];then
  80. [[ $oldLC_ALL ]] && export LC_ALL=$oldLC_ALL || unset LC_ALL
  81. fi
  82. post_configure_routine
  83. }
  84. setup() {
  85. initial_setup_routine
  86. SUBSTITUTE=( "\${SERVICE_DOMAIN}" "\${AUTH_SWITCH}" )
  87. basic_nginx
  88. docker_run_all
  89. post_setup_routine
  90. }
  91. if [[ $1 == "letsencrypt" ]];then
  92. $1 $*
  93. else
  94. $1
  95. fi