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:v2.9.2" [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: "${BASE_DIR}"/data/services/mastodon/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. start_containers
  40. echo -en "\n \e[3m\xe2\x86\x92 Execute \`tootctl cache clear\`\e[0m "
  41. docker exec -t mastodon-service-dockerbunker sh -c 'tootctl cache clear'
  42. sleep 5
  43. restart_nginx
  44. }
  45. configure() {
  46. pre_configure_routine
  47. echo -e "# \e[4mMastodon Settings\e[0m"
  48. set_domain
  49. configure_mx
  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. PROPER_NAME="${PROPER_NAME}"
  61. SERVICE_NAME="${SERVICE_NAME}"
  62. SSL_CHOICE=${SSL_CHOICE}
  63. LE_EMAIL=${LE_EMAIL}
  64. SERVICE_DOMAIN="${SERVICE_DOMAIN}"
  65. LOCAL_DOMAIN=${SERVICE_DOMAIN}
  66. SECRET_KEY_BASE=$(tr -dc 'a-zA-Z0-9' < /dev/urandom | head -c 128)
  67. OTP_SECRET=$(tr -dc 'a-zA-Z0-9' < /dev/urandom | head -c 128)
  68. VAPID_PRIVATE_KEY=
  69. VAPID_PUBLIC_KEY=
  70. REDIS_HOST=redis
  71. REDIS_PORT=6379
  72. DB_HOST=postgres
  73. DB_USER=postgres
  74. DB_NAME=postgres
  75. DB_PASS=
  76. DB_PORT=5432
  77. ES_HOST=es
  78. ES_PORT=9200
  79. SMTP_SERVER=${MX_HOSTNAME}
  80. SMTP_PORT=587
  81. SMTP_LOGIN=${MX_EMAIL}
  82. SMTP_PASSWORD=${MX_PASSWORD}
  83. SMTP_FROM_ADDRESS=${MX_EMAIL}
  84. STREAMING_CLUSTER_NUM=1
  85. SERVICE_SPECIFIC_MX=${SERVICE_SPECIFIC_MX}
  86. EOF
  87. source "${SERVICE_ENV}"
  88. if [[ $OSTYPE =~ "darwin" ]];then
  89. [[ $oldLC_ALL ]] && export LC_ALL=$oldLC_ALL || unset LC_ALL
  90. fi
  91. echo ""
  92. mastodon_generatevapidkeys_dockerbunker
  93. source "${ENV_DIR}"/${SERVICE_NAME}_tmp.env
  94. rm "${ENV_DIR}"/${SERVICE_NAME}_tmp.env
  95. sed -i "s/VAPID_PRIVATE_KEY=.*/VAPID_PRIVATE_KEY=${VAPID_PRIVATE_KEY}/" "${ENV_DIR}"/${SERVICE_NAME}.env
  96. sed -i "s/VAPID_PUBLIC_KEY=.*/VAPID_PUBLIC_KEY=${VAPID_PUBLIC_KEY}/" "${ENV_DIR}"/${SERVICE_NAME}.env
  97. post_configure_routine
  98. }
  99. setup() {
  100. initial_setup_routine
  101. SUBSTITUTE=( "\${SERVICE_DOMAIN}" )
  102. basic_nginx
  103. mastodon_postgres_dockerbunker
  104. mastodon_redis_dockerbunker
  105. mastodon_dbmigrateandprecompileassets_dockerbunker
  106. docker_run mastodon_elasticsearch_dockerbunker
  107. docker_run mastodon_streaming_dockerbunker
  108. docker_run mastodon_service_dockerbunker
  109. docker_run mastodon_sidekiq_dockerbunker
  110. post_setup_routine
  111. echo -e "\nAfter signing up on ${SERVICE_DOMAIN} make your user an admin by running\n\n\
  112. ${SERVICES_DIR}/${SERVICE_NAME}/./mastodon.sh make_admin username\n"
  113. }
  114. if [[ $1 == "letsencrypt" ]];then
  115. $1 $*
  116. else
  117. $1
  118. fi