123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159 |
- #!/usr/bin/env bash
- while true;do ls | grep -q dockerbunker.sh;if [[ $? == 0 ]];then BASE_DIR=$PWD;break;else cd ../;fi;done
- PROPER_NAME="Mastodon"
- SERVICE_NAME="$(echo -e "${PROPER_NAME,,}" | tr -d '[:space:]')"
- PROMPT_SSL=1
- declare -A WEB_SERVICES
- declare -a environment=( "data/env/dockerbunker.env" "data/include/init.sh" )
- for env in "${environment[@]}";do
- [[ -f "${BASE_DIR}"/$env ]] && source "${BASE_DIR}"/$env
- done
- 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" )
- declare -a add_to_network=( "${SERVICE_NAME}-service-dockerbunker" "${SERVICE_NAME}-streaming-dockerbunker" )
- 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" )
- declare -a networks=( "dockerbunker-${SERVICE_NAME}" )
- 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" )
- if [[ $1 == "make_admin" ]];then
- if [[ -z $2 || $3 ]];then
- echo "Usage: "${BASE_DIR}"/data/services/mastodon/mastodon.sh make_admin username"
- exit 1
- else
- mastodon_makeadmin_dockerbunker $2
- exit 0
- fi
- fi
- [[ -z $1 ]] && options_menu
- upgrade() {
- get_current_images_sha256
- docker_pull
- stop_containers
- remove_containers
- mastodon_postgres_dockerbunker
- mastodon_redis_dockerbunker
- mastodon_dbmigrateandprecompileassets_dockerbunker
- [[ ${ES_ENABLED} ]] && docker_run mastodon_elasticsearch_dockerbunker
- docker_run mastodon_service_dockerbunker
- docker_run mastodon_sidekiq_dockerbunker
- docker_run mastodon_streaming_dockerbunker
- delete_old_images
- start_containers
- echo -en "\n \e[3m\xe2\x86\x92 Execute \`tootctl cache clear\`\e[0m "
- docker exec -t mastodon-service-dockerbunker sh -c 'tootctl cache clear'
- sleep 5
- restart_nginx
- }
- configure() {
- pre_configure_routine
- echo -e "# \e[4mMastodon Settings\e[0m"
- set_domain
- configure_mx
-
- # avoid tr illegal byte sequence in macOS when generating random strings
- if [[ $OSTYPE =~ "darwin" ]];then
- if [[ $LC_ALL ]];then
- oldLC_ALL=$LC_ALL
- export LC_ALL=C
- else
- export LC_ALL=C
- fi
- fi
- cat <<-EOF >> "${SERVICE_ENV}"
- PROPER_NAME="${PROPER_NAME}"
- SERVICE_NAME="${SERVICE_NAME}"
- SSL_CHOICE=${SSL_CHOICE}
- LE_EMAIL=${LE_EMAIL}
- SERVICE_DOMAIN="${SERVICE_DOMAIN}"
- LOCAL_DOMAIN=${SERVICE_DOMAIN}
- SECRET_KEY_BASE=$(tr -dc 'a-zA-Z0-9' < /dev/urandom | head -c 128)
- OTP_SECRET=$(tr -dc 'a-zA-Z0-9' < /dev/urandom | head -c 128)
- VAPID_PRIVATE_KEY=
- VAPID_PUBLIC_KEY=
- REDIS_HOST=redis
- REDIS_PORT=6379
- DB_HOST=postgres
- DB_USER=postgres
- DB_NAME=postgres
- DB_PASS=
- DB_PORT=5432
- ES_HOST=es
- ES_PORT=9200
- SMTP_SERVER=${MX_HOSTNAME}
- SMTP_PORT=587
- SMTP_LOGIN=${MX_EMAIL}
- SMTP_PASSWORD=${MX_PASSWORD}
- SMTP_FROM_ADDRESS=${MX_EMAIL}
- STREAMING_CLUSTER_NUM=1
- SERVICE_SPECIFIC_MX=${SERVICE_SPECIFIC_MX}
- EOF
- source "${SERVICE_ENV}"
- if [[ $OSTYPE =~ "darwin" ]];then
- [[ $oldLC_ALL ]] && export LC_ALL=$oldLC_ALL || unset LC_ALL
- fi
- echo ""
- mastodon_generatevapidkeys_dockerbunker
- source "${ENV_DIR}"/${SERVICE_NAME}_tmp.env
- rm "${ENV_DIR}"/${SERVICE_NAME}_tmp.env
- sed -i "s/VAPID_PRIVATE_KEY=.*/VAPID_PRIVATE_KEY=${VAPID_PRIVATE_KEY}/" "${ENV_DIR}"/${SERVICE_NAME}.env
- sed -i "s/VAPID_PUBLIC_KEY=.*/VAPID_PUBLIC_KEY=${VAPID_PUBLIC_KEY}/" "${ENV_DIR}"/${SERVICE_NAME}.env
- post_configure_routine
- }
- setup() {
- initial_setup_routine
- SUBSTITUTE=( "\${SERVICE_DOMAIN}" )
- basic_nginx
- mastodon_postgres_dockerbunker
- mastodon_redis_dockerbunker
- mastodon_dbmigrateandprecompileassets_dockerbunker
- docker_run mastodon_elasticsearch_dockerbunker
- docker_run mastodon_streaming_dockerbunker
- docker_run mastodon_service_dockerbunker
- docker_run mastodon_sidekiq_dockerbunker
- post_setup_routine
- echo -e "\nAfter signing up on ${SERVICE_DOMAIN} make your user an admin by running\n\n\
- ${SERVICES_DIR}/${SERVICE_NAME}/./mastodon.sh make_admin username\n"
- }
- if [[ $1 == "letsencrypt" ]];then
- $1 $*
- else
- $1
- fi
|