mastodon.sh 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159
  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="Mastodon"
  4. SERVICE_NAME="$(echo -e "${PROPER_NAME,,}" | tr -d '[:space:]')"
  5. PROMPT_SSL=1
  6. declare -A WEB_SERVICES
  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 containers=( "${SERVICE_NAME}-postgres-dockerbunker" "${SERVICE_NAME}-redis-dockerbunker" "${SERVICE_NAME}-service-dockerbunker" "${SERVICE_NAME}-streaming-dockerbunker" "${SERVICE_NAME}-sidekiq-dockerbunker" "${SERVICE_NAME}-elasticsearch-dockerbunker" )
  12. declare -a add_to_network=( "${SERVICE_NAME}-service-dockerbunker" "${SERVICE_NAME}-streaming-dockerbunker" )
  13. declare -A volumes=( [${SERVICE_NAME}-data-vol-1]="/mastodon/public/system" [${SERVICE_NAME}-data-vol-2]="/mastodon/public/assets" [${SERVICE_NAME}-data-vol-3]="/mastodon/public/packs" [${SERVICE_NAME}-postgres-vol-1]="/var/lib/postgresql/data" [${SERVICE_NAME}-elasticsearch-vol-1]="/usr/share/elasticsearch/data" [${SERVICE_NAME}-redis-vol-1]="/data" )
  14. declare -a networks=( "dockerbunker-${SERVICE_NAME}" )
  15. declare -A IMAGES=( [service]="tootsuite/mastodon" [redis]="redis:5.0-alpine" [postgres]="postgres:9.6-alpine" [elasticsearch]="docker.elastic.co/elasticsearch/elasticsearch-oss:6.1.3" )
  16. if [[ $1 == "make_admin" ]];then
  17. if [[ -z $2 || $3 ]];then
  18. echo "Usage: ./mastodon.sh make_admin username"
  19. exit 1
  20. else
  21. mastodon_makeadmin_dockerbunker $2
  22. exit 0
  23. fi
  24. fi
  25. [[ -z $1 ]] && options_menu
  26. upgrade() {
  27. get_current_images_sha256
  28. docker_pull
  29. stop_containers
  30. remove_containers
  31. mastodon_postgres_dockerbunker
  32. mastodon_redis_dockerbunker
  33. mastodon_dbmigrateandprecompileassets_dockerbunker
  34. [[ ${ES_ENABLED} ]] && docker_run mastodon_elasticsearch_dockerbunker
  35. docker_run mastodon_service_dockerbunker
  36. docker_run mastodon_sidekiq_dockerbunker
  37. docker_run mastodon_streaming_dockerbunker
  38. delete_old_images
  39. restart_nginx
  40. }
  41. configure() {
  42. pre_configure_routine
  43. echo -e "# \e[4mMastodon Settings\e[0m"
  44. set_domain
  45. configure_mx
  46. if [ "${ES_ENABLED}" ]; then
  47. read -p "Enable Elasticsearch: " -ei "${ES_ENABLED}" ES_ENABLED
  48. else
  49. read -p "Enable Elasticsearch: " -ei "false" ES_ENABLED
  50. fi
  51. # avoid tr illegal byte sequence in macOS when generating random strings
  52. if [[ $OSTYPE =~ "darwin" ]];then
  53. if [[ $LC_ALL ]];then
  54. oldLC_ALL=$LC_ALL
  55. export LC_ALL=C
  56. else
  57. export LC_ALL=C
  58. fi
  59. fi
  60. cat <<-EOF >> "${SERVICE_ENV}"
  61. PROPER_NAME="${PROPER_NAME}"
  62. SERVICE_NAME="${SERVICE_NAME}"
  63. SSL_CHOICE=${SSL_CHOICE}
  64. LE_EMAIL=${LE_EMAIL}
  65. SERVICE_DOMAIN="${SERVICE_DOMAIN}"
  66. LOCAL_DOMAIN=${SERVICE_DOMAIN}
  67. SECRET_KEY_BASE=$(tr -dc 'a-zA-Z0-9' < /dev/urandom | head -c 128)
  68. OTP_SECRET=$(tr -dc 'a-zA-Z0-9' < /dev/urandom | head -c 128)
  69. VAPID_PRIVATE_KEY=
  70. VAPID_PUBLIC_KEY=
  71. REDIS_HOST=redis
  72. REDIS_PORT=6379
  73. DB_HOST=postgres
  74. DB_USER=postgres
  75. DB_NAME=postgres
  76. DB_PASS=
  77. DB_PORT=5432
  78. ES_ENABLED=${ES_ENABLED}
  79. ES_HOST=es
  80. ES_PORT=9200
  81. SMTP_SERVER=${MX_HOSTNAME}
  82. SMTP_PORT=587
  83. SMTP_LOGIN=${MX_EMAIL}
  84. SMTP_PASSWORD=${MX_PASSWORD}
  85. SMTP_FROM_ADDRESS=${MX_EMAIL}
  86. STREAMING_CLUSTER_NUM=1
  87. SERVICE_SPECIFIC_MX=${SERVICE_SPECIFIC_MX}
  88. EOF
  89. source "${SERVICE_ENV}"
  90. if [[ $OSTYPE =~ "darwin" ]];then
  91. [[ $oldLC_ALL ]] && export LC_ALL=$oldLC_ALL || unset LC_ALL
  92. fi
  93. echo ""
  94. mastodon_generatevapidkeys_dockerbunker
  95. source "${ENV_DIR}"/${SERVICE_NAME}_tmp.env
  96. rm "${ENV_DIR}"/${SERVICE_NAME}_tmp.env
  97. sed -i "s/VAPID_PRIVATE_KEY=.*/VAPID_PRIVATE_KEY=${VAPID_PRIVATE_KEY}/" "${ENV_DIR}"/${SERVICE_NAME}.env
  98. sed -i "s/VAPID_PUBLIC_KEY=.*/VAPID_PUBLIC_KEY=${VAPID_PUBLIC_KEY}/" "${ENV_DIR}"/${SERVICE_NAME}.env
  99. post_configure_routine
  100. }
  101. setup() {
  102. initial_setup_routine
  103. SUBSTITUTE=( "\${SERVICE_DOMAIN}" )
  104. basic_nginx
  105. mastodon_postgres_dockerbunker
  106. mastodon_redis_dockerbunker
  107. mastodon_dbmigrateandprecompileassets_dockerbunker
  108. [[ ${ES_ENABLED} ]] && docker_run mastodon_elasticsearch_dockerbunker
  109. docker_run mastodon_service_dockerbunker
  110. docker_run mastodon_sidekiq_dockerbunker
  111. docker_run mastodon_streaming_dockerbunker
  112. post_setup_routine
  113. echo -e "\nAfter signing up on ${SERVICE_DOMAIN} make your user an admin by running\n\n\
  114. ${SERVICES_DIR}/${SERVICE_NAME}/./make_admin.sh username\n"
  115. }
  116. if [[ $1 == "letsencrypt" ]];then
  117. $1 $*
  118. else
  119. $1
  120. fi