dockerbunker.sh 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220
  1. #!/usr/bin/env bash
  2. if [[ -r /etc/redhat-release ]];then
  3. if ! dnf list installed docker-ce &>/dev/null;then
  4. docker_missing=1
  5. fi
  6. elif [[ -r /etc/debian_version ]];then
  7. if ! dpkg -l docker &>/dev/null;then
  8. docker_missing=1
  9. fi
  10. fi
  11. [[ $docker_missing ]] \
  12. && echo -e "\n\e[3m\xe2\x86\x92 \e[1mCould not find docker.\e[3m\n\nMost systems can install Docker by running:\n\nwget -qO- https://get.docker.com/ | sh\n";
  13. # Find base dir
  14. BASE_DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"
  15. source "${BASE_DIR}"/data/include/init.sh
  16. [[ -f "data/env/dockerbunker.env" ]] && source "data/env/dockerbunker.env" || init_dockerbunker
  17. unset AVAILABLE_SERVICES count
  18. # All available services
  19. declare -a ALL_SERVICES=( \
  20. "Static HTML Site" \
  21. "Bitbucket" \
  22. "Cryptpad" \
  23. "CS50 IDE" \
  24. "Dillinger" \
  25. "Drone CI" \
  26. "Ghost" \
  27. "GitBucket" \
  28. "Gitea" \
  29. "Gitlab CE" \
  30. "Gogs" \
  31. "Hastebin" \
  32. "IPsec VPN Server" \
  33. "json-server" \
  34. "Kanboard" \
  35. "Koken" \
  36. "Mailcow (Dockerized)" \
  37. "Mailpile" \
  38. "Mastodon" \
  39. "Matomo" \
  40. "Nextcloud" \
  41. "Open Project" \
  42. "Padlock Cloud" \
  43. "Piwik" \
  44. "Rocket.Chat" \
  45. "Seafile Pro" \
  46. "Searx" \
  47. "Send" \
  48. "sFTP Server" \
  49. "Wekan" \
  50. "Wordpress" \
  51. )
  52. [[ -f "${ENV_DIR}"/custom.env ]] \
  53. && . "${ENV_DIR}"/custom.env
  54. IFS=$'\n' sorted=($(printf '%s\n' "${ALL_SERVICES[@]}"|sort))
  55. # style menu according to what status service has
  56. declare -A SERVICES_ARR
  57. for service in "${sorted[@]}";do
  58. service_name="$(echo -e "${service,,}" | tr -cd '[:alnum:]')"
  59. if [[ "${INSTALLED_SERVICES[@]}" =~ $service ]];then
  60. [[ "${STOPPED_SERVICES[@]}" =~ $service ]] && service_status="$(printf "\e[32m${service}\e[0m \e[31m(Stopped)\e[0m")" || service_status="$(printf "\e[32m${service}\e[0m")"
  61. SERVICES_ARR+=( [$service_status]="${service_name}" )
  62. AVAILABLE_SERVICES+=( "$service_status" )
  63. elif [[ "${CONFIGURED_SERVICES[@]}" =~ $service ]];then
  64. service_status="$(printf "\e[33m${service}\e[0m")"
  65. SERVICES_ARR+=( [$service_status]="${service_name}" )
  66. AVAILABLE_SERVICES+=( "$service_status" )
  67. else
  68. service_status="$(printf "${service}")"
  69. SERVICES_ARR+=( [$service_status]="${service_name}" )
  70. AVAILABLE_SERVICES+=( "$service_status" )
  71. fi
  72. done
  73. startall=$(printf "\e[1;4;33mStart all stopped containers\e[0m")
  74. stopall=$(printf "\e[1;4;33mStop all running containers\e[0m")
  75. startnginx=$(printf "\e[1;4;33mStart nginx container\e[0m")
  76. stopnginx=$(printf "\e[1;4;33mStop nginx container\e[0m")
  77. restartnginx=$(printf "\e[1;4;33mRestart nginx container\e[0m")
  78. renewcerts=$(printf "\e[1;4;33mRenew Let's Encrypt certificates\e[0m")
  79. restartall=$(printf "\e[1;4;33mRestart all containers\e[0m")
  80. destroyall=$(printf "\e[1;4;33mDestroy everything\e[0m")
  81. exitmenu=$(printf "\e[1;4;33mExit\e[0m")
  82. count=$((${#AVAILABLE_SERVICES[@]}+1))
  83. [[ ${STOPPED_SERVICES[0]} ]] \
  84. && AVAILABLE_SERVICES+=( "$startall" )
  85. [[ $(docker ps -q --filter "status=running" --filter name=^/nginx-dockerbunker$) ]] \
  86. && AVAILABLE_SERVICES+=( "$stopnginx" ) \
  87. && AVAILABLE_SERVICES+=( "$restartnginx") \
  88. && count=$(($count+2))
  89. [[ -d "${CONF_DIR}"/nginx/ssl/letsencrypt/live ]] \
  90. && [[ $(ls -A "${CONF_DIR}"/nginx/ssl/letsencrypt/live) ]] \
  91. && AVAILABLE_SERVICES+=( "$renewcerts" ) && cound=$(($count+1))
  92. [[ ${#INSTALLED_SERVICES[@]} > 0 \
  93. || ${#STATIC_SITES[@]} > 0 \
  94. || ${#CONFIGURED_SERVICES[@]} > 0 \
  95. || -f "${BASE_DIR}"/data/env/dockerbunker.env ]] \
  96. && AVAILABLE_SERVICES+=( "$destroyall" ) \
  97. && count=$(($count+1))
  98. [[ $(docker ps -q --filter "status=exited" --filter name=^/nginx-dockerbunker$) ]] \
  99. && AVAILABLE_SERVICES+=( "$startnginx" )
  100. [[ $(docker ps -q --filter "status=running" --filter name=dockerbunker) \
  101. && ${#INSTALLED_SERVICES[@]} > 1 ]] \
  102. && AVAILABLE_SERVICES+=( "$stopall" ) \
  103. && count=$(($count+1))
  104. [[ $(docker ps -q --filter "status=exited" --filter name=dockerbunker) \
  105. && ${#STOPPED_SERVICES[@]} > 1 ]] \
  106. && AVAILABLE_SERVICES+=( "$startall" ) \
  107. && count=$(($count+1))
  108. [[ ${#INSTALLED_SERVICES[@]} > 1 ]] \
  109. && AVAILABLE_SERVICES+=( "$restartall" ) \
  110. && count=$(($count+1))
  111. echo ""
  112. echo "Please select the service you want to manage"
  113. echo ""
  114. [[ ${INSTALLED_SERVICES[@]} ]] && echo -e " \e[32mGreen\e[0m: Installed"
  115. [[ ${CONFIGURED_SERVICES[@]} ]] && echo -e " \e[33mOrange\e[0m: Configured"
  116. echo ""
  117. COLUMNS=12
  118. select choice in "${AVAILABLE_SERVICES[@]}" "$exitmenu"
  119. do
  120. case $choice in
  121. "$exitmenu")
  122. exit 0
  123. ;;
  124. "$startnginx")
  125. echo ""
  126. start_nginx
  127. say_done
  128. sleep 1
  129. break
  130. ;;
  131. "$stopnginx")
  132. echo ""
  133. stop_nginx
  134. say_done
  135. sleep 1
  136. break
  137. ;;
  138. "$restartnginx")
  139. prevent_nginx_restart=1
  140. echo ""
  141. restart_nginx
  142. say_done
  143. sleep 1
  144. break
  145. ;;
  146. "$renewcerts")
  147. echo -e "\n\e[3m\xe2\x86\x92 Renew Let's Encrypt certificates\e[0m\n"
  148. "${BASE_DIR}"/certbot.sh
  149. restart_nginx
  150. say_done
  151. sleep 1
  152. break
  153. ;;
  154. "$startall")
  155. prevent_nginx_restart=1
  156. start_all
  157. say_done
  158. sleep 1
  159. break
  160. ;;
  161. "$stopall")
  162. prevent_nginx_restart=1
  163. stop_all
  164. say_done
  165. sleep 1
  166. break
  167. ;;
  168. "$destroyall")
  169. echo -e "\n\e[3m\xe2\x86\x92 Destroy everything\e[0m"
  170. echo ""
  171. echo -e "\e[1mReset dockerbunker to its initial state\e[0m"
  172. echo ""
  173. echo "The following will be removed:"
  174. echo ""
  175. echo "- All dockerbunker container(s)"
  176. echo "- All dockerbunker volume(s)"
  177. echo "- All environment file(s)"
  178. echo "- All nginx configuration files"
  179. echo "- All self-signed certificates (Let's Encrypt certificates will be retained)"
  180. echo ""
  181. prompt_confirm "Continue?" \
  182. && destroy_all=1 destroy_all
  183. say_done
  184. exit 0
  185. ;;
  186. $choice)
  187. if [[ -z $choice ]];then
  188. echo "Please choose a number from 1 to $count"
  189. else
  190. service="$(echo -e "${choice,,}" | tr -d '[:space:]')"
  191. echo ""
  192. echo -e "\n\e[3m\xe2\x86\x92 Checking service status"
  193. echo ""
  194. source "${BASE_DIR}"/data/services/${SERVICES_ARR[$choice]}/${SERVICES_ARR[$choice]}.sh
  195. break
  196. fi
  197. ;;
  198. esac
  199. done