seafilepro.sh 9.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268
  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="Seafile Pro"
  4. SERVICE_NAME="$(echo -e "${PROPER_NAME,,}" | tr -d '[:space:]')"
  5. PROMPT_SSL=true
  6. safe_to_keep_volumes_when_reconfiguring=1
  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 WEB_SERVICES
  12. declare -a containers=( "${SERVICE_NAME}-db-dockerbunker" "${SERVICE_NAME}-service-dockerbunker" "${SERVICE_NAME}-elasticsearch-dockerbunker" "${SERVICE_NAME}-memcached-dockerbunker" )
  13. declare -a add_to_network=( "${SERVICE_NAME}-service-dockerbunker" )
  14. declare -A volumes=( [${SERVICE_NAME}-data-vol-3]="/opt/seafile" [${SERVICE_NAME}-data-vol-2]="/shared" [${SERVICE_NAME}-elasticsearch-vol-1]="/usr/share/elasticsearch/data" [${SERVICE_NAME}-data-vol-1]="/seafile" [${SERVICE_NAME}-db-vol-1]="/var/lib/mysql" )
  15. declare -a networks=( "dockerbunker-${SERVICE_NAME}" )
  16. declare -A IMAGES=( [db]="mariadb:10.3" [service]="chaosbunker/seafile-pro" [memcached]="memcached:1.5.6" [elasticsearch]="seafileltd/elasticsearch-with-ik:5.6.16" )
  17. previous_version="6.3.14"
  18. current_version="7.0.7"
  19. [[ -z $1 ]] && options_menu
  20. upgrade() {
  21. prompt_confirm "\nMigrate from Seafile Pro 6.x.x to 7.x.x?\n"
  22. if [[ $? == 0 ]];then
  23. if [[ -z ${SEAFILE_ADMIN_EMAIL} ]] || [[ -z ${SEAFILE_ADMIN_PASSWORD} ]];then
  24. ! grep -q SEAFILE_ADMIN_EMAIL ${SERVICE_ENV} \
  25. && echo SEAFILE_ADMIN_EMAIL= >> ${SERVICE_ENV}
  26. ! grep -q SEAFILE_ADMIN_PASSWORD ${SERVICE_ENV} \
  27. && echo SEAFILE_ADMIN_PASSWORD= >> ${SERVICE_ENV}
  28. echo -e "\nPlease enter your Admin Email and Password in ${SERVICE_ENV} before upgrading"
  29. exit 0
  30. fi
  31. if [ -z "${TIME_ZONE}" ]; then
  32. read -p "Time Zone: " TIME_ZONE
  33. echo "TIME_ZONE=${TIME_ZONE}" >> ${SERVICE_ENV}
  34. fi
  35. stop_containers
  36. if ! grep "es_host = elasticsearch" /var/lib/docker/volumes/seafilepro-data-vol-1/_data/conf/seafevents.conf;then
  37. echo -e "\nopen /var/lib/docker/volumes/seafilepro-data-vol-1/_data/conf/seafevents.conf and add the following configuration in the [INDEX FILES] section:\n"
  38. echo -e "\texternal_es_server = true"
  39. echo -e "\tes_host = elasticsearch"
  40. echo -e "\tes_port = 9200"
  41. fi
  42. if ! grep "path = /shared/seafile/pro-data/seafevents.db" /var/lib/docker/volumes/seafilepro-data-vol-1/_data/conf/seafevents.conf;then
  43. echo -e "\nopen /var/lib/docker/volumes/seafilepro-data-vol-1/_data/conf/seafevents.conf and change the 'path' value in the [DATABASE] configuration to:\n"
  44. echo -e "\tpath = /shared/seafile/pro-data/seafevents.db\n"
  45. fi
  46. if ! grep "\'LOCATION\': \'memcached:11211\'" /var/lib/docker/volumes/seafilepro-data-vol-1/_data/conf/seahub_settings.py;then
  47. echo -e "\nopen /var/lib/docker/volumes/seafilepro-data-vol-1/_data/conf/seahub_settings.py and change the 'LOCATION' value to 'memcached:11211' in the CACHES dict:\n"
  48. echo -e "CACHES = {
  49. 'default': {
  50. 'BACKEND': 'django_pylibmc.memcached.PyLibMCCache',
  51. 'LOCATION': 'memcached:11211',
  52. },
  53. 'locmem': {
  54. 'BACKEND': 'django.core.cache.backends.locmem.LocMemCache',
  55. },
  56. }
  57. COMPRESS_CACHE_BACKEND = 'locmem'"
  58. fi
  59. create_volumes
  60. ! [[ -d /var/lib/docker/volumes/seafilepro-data-vol-2/_data/seafile/seafile-data ]] && \
  61. echo "Moving seafile-data into seafilepro-data-vol-2:/shared/seafile/seafile-data" && \
  62. mv /var/lib/docker/volumes/seafilepro-data-vol-1/_data/seafile-data /var/lib/docker/volumes/seafilepro-data-vol-2/_data/seafile
  63. ! [[ -d /var/lib/docker/volumes/seafilepro-data-vol-2/_data/seafile/seahub-data ]] && \
  64. echo "Moving seahub-data into seafilepro-data-vol-2:/shared/seafile/seafile-data" && \
  65. mv /var/lib/docker/volumes/seafilepro-data-vol-1/_data/seahub-data /var/lib/docker/volumes/seafilepro-data-vol-2/_data/seafile
  66. ! [[ -d /var/lib/docker/volumes/seafilepro-elasticsearch-vol-1/_data/nodes ]] && \
  67. echo "Moving elasticsearch data into seafilepro-elasticsearch-vol-1:/usr/share/elasticsearch/data" && \
  68. mv /var/lib/docker/volumes/seafilepro-data-vol-1/_data/pro-data/search/data/elasticsearch/nodes /var/lib/docker/volumes/seafilepro-elasticsearch-vol-1/_data
  69. ! [[ -d /var/lib/docker/volumes/seafilepro-data-vol-3/_data/ccnet ]] && \
  70. echo "Moving /seafile data into seafilepro-data-vol-3:/opt/seafile" && \
  71. mv /var/lib/docker/volumes/seafilepro-data-vol-1/_data/* /var/lib/docker/volumes/seafileprodata-vol-3/_data/
  72. [[ -d /var/lib/docker/volumes/seafilepro-data-vol-3/_data/pro-data ]] && \
  73. rm /var/lib/docker/volumes/seafilepro-data-vol-3/_data/pro-data
  74. echo ${previous_version} > /var/lib/docker/volumes/seafilepro-data-vol-2/_data/seafile/seafile-data/current_version
  75. echo SEAFILE_SERVER_HOSTNAME=${SERVICE_DOMAIN} >> ${SERVICE_ENV}
  76. pull_and_compare
  77. remove_containers
  78. docker_run seafilepro_db_dockerbunker
  79. docker run -it --rm \
  80. --name=${FUNCNAME[0]//_/-} \
  81. --network ${NETWORK} \
  82. --network dockerbunker-seafilepro \
  83. -e SEAFILE_VERSION=${current_version} \
  84. --env-file "${SERVICE_ENV}" \
  85. -e DB_ROOT_PASSWD=${DBROOT} \
  86. -e SEAFILE_SERVER_HOSTNAME=${SERVICE_DOMAIN} \
  87. -v ${SERVICE_NAME}-data-vol-2:${volumes[${SERVICE_NAME}-data-vol-2]} \
  88. -v ${SERVICE_NAME}-data-vol-3:${volumes[${SERVICE_NAME}-data-vol-3]} \
  89. ${IMAGES[service]} /scripts/upgrade.py
  90. docker exec -it seafilepro-db-dockerbunker /usr/bin/mysql -u root -p${DBROOT} -e "grant all on *.* to 'root'@'%.%.%.%' identified by '${DBROOT}';"
  91. for database in {ccnet_db,seafile_db,seahub_db}; do sudo docker exec -it seafilepro-db-dockerbunker /usr/bin/mysql -u root -p${DBROOT} -e "grant all on ${database}.* to 'seafile'@'%.%.%.%' identified by '${DBPASS}';"; done
  92. docker exec -it seafilepro-db-dockerbunker mysql_upgrade -u root -p${DBROOT}
  93. docker_run_all
  94. remove_from_STOPPED_SERVICES
  95. delete_old_images
  96. activate_nginx_conf
  97. restart_nginx
  98. else
  99. pull_and_compare
  100. stop_containers
  101. remove_containers
  102. docker_run seafilepro_db_dockerbunker
  103. seafilepro_setup_dockerbunker "upgrade ${current_version}"
  104. docker_run_all
  105. [[ -z ${FILE_COMMENT_MIGRATED} ]] \
  106. && echo -e "\n\e[1mMigrate database table for file comments\e[0m" \
  107. && docker exec -it seafilepro-service-dockerbunker ./seahub.sh python-env seahub/manage.py migrate_file_comment \
  108. && exit_response \
  109. && echo "FILE_COMMENT_MIGRATED=1" >> "${ENV_DIR}"/${SERVICE_NAME}.env
  110. echo -e "\n\e[1mRunning mysql_upgrade on all databases\e[0m"
  111. docker exec -it seafilepro-db-dockerbunker mysql_upgrade -u root -p${DBROOT}
  112. fi
  113. }
  114. configure() {
  115. pre_configure_routine
  116. echo -e "# \e[4mSeafile Pro Settings\e[0m"
  117. set_domain
  118. if [ "${SEAFILE_ADMIN_EMAIL}" ]; then
  119. read -p "Admin E-Mail: " -ei "${SEAFILE_ADMIN_EMAIL}" SEAFILE_ADMIN_EMAIL
  120. else
  121. read -p "Admin E-Mail: " SEAFILE_ADMIN_EMAIL
  122. fi
  123. unset SEAFILE_ADMIN_PASSWORD
  124. while [[ "${#SEAFILE_ADMIN_PASSWORD}" -le 6 || "${SEAFILE_ADMIN_PASSWORD}" != *[A-Z]* || "${SEAFILE_ADMIN_PASSWORD}" != *[a-z]* || "${SEAFILE_ADMIN_PASSWORD}" != *[0-9]* ]];do
  125. if [ ${VALIDATE} ];then
  126. echo -e "\n\e[31m Password does not meet requirements\e[0m"
  127. fi
  128. stty_orig="$(stty -g)"
  129. stty -echo
  130. read -p " $(printf "\n \e[4mPassword requirements\e[0m\n Minimum Length 6,Uppercase, Lowercase, Integer\n\n Enter Password:") " -ei "" SEAFILE_ADMIN_PASSWORD
  131. stty "${stty_orig}"
  132. echo ""
  133. VALIDATE=1
  134. done
  135. unset VALIDATE
  136. echo ""
  137. if [ "${TIME_ZONE}" ]; then
  138. read -p "Time Zone: " -ei "${TIME_ZONE}" TIME_ZONE
  139. else
  140. read -p "Time Zone: " TIME_ZONE
  141. fi
  142. # avoid tr illegal byte sequence in macOS when generating random strings
  143. if [[ $OSTYPE =~ "darwin" ]];then
  144. if [[ $LC_ALL ]];then
  145. oldLC_ALL=$LC_ALL
  146. export LC_ALL=C
  147. else
  148. export LC_ALL=C
  149. fi
  150. fi
  151. cat <<-EOF >> "${SERVICE_ENV}"
  152. # ------------------------------
  153. # General Settings
  154. # ------------------------------
  155. PROPER_NAME="${PROPER_NAME}"
  156. SERVICE_NAME=${SERVICE_NAME}
  157. SSL_CHOICE=${SSL_CHOICE}
  158. LE_EMAIL=${LE_EMAIL}
  159. SERVICE_DOMAIN=${SERVICE_DOMAIN}
  160. TIME_ZONE=${TIME_ZONE}
  161. # ------------------------------
  162. # SQL database configuration
  163. # ------------------------------
  164. # Please use long, random alphanumeric strings (A-Za-z0-9)
  165. DBROOT=$(</dev/urandom tr -dc A-Za-z0-9 | head -c 28)
  166. DBPASS=$(</dev/urandom tr -dc A-Za-z0-9 | head -c 28)
  167. DB_HOST=db
  168. DBUSER=seafile
  169. SEAFILE_ADMIN_EMAIL=${SEAFILE_ADMIN_EMAIL}
  170. SEAFILE_ADMIN_PASSWORD=${SEAFILE_ADMIN_PASSWORD}
  171. EOF
  172. if [[ $OSTYPE =~ "darwin" ]];then
  173. unset LC_ALL
  174. fi
  175. post_configure_routine
  176. }
  177. setup() {
  178. initial_setup_routine
  179. SUBSTITUTE=( "\${SERVICE_DOMAIN}" )
  180. basic_nginx
  181. [[ $keep_volumes ]] \
  182. && echo -en "\n\e[1mStarting up ${PROPER_NAME} database container\e[0m" \
  183. && seafilepro_db_dockerbunker \
  184. && exit_response
  185. if [[ -z $keep_volumes ]];then
  186. echo "Starting interactive Seafile Pro setup"
  187. echo ""
  188. echo "MySQL Server: db"
  189. echo "Port: 3306"
  190. echo "MySQL User: seafile"
  191. prompt_confirm "Display MySQL root and user passwords"
  192. [[ $? == 0 ]] && echo -e "MySQL root password: ${DBROOT}\nMySQL user password: ${DBPASS}" || echo -e "\e[33mPlease obtain the MySQL root password from ${SERVICE_ENV}\e[0m\n"
  193. echo ""
  194. echo -e "\n\e[1mStarting up ${PROPER_NAME} setup container\e[0m" \
  195. && docker_run seafilepro_db_dockerbunker \
  196. && seafilepro_setup_dockerbunker setup \
  197. && exit_response
  198. fi
  199. docker_run_all
  200. post_setup_routine
  201. }
  202. if [[ $1 == "letsencrypt" ]];then
  203. $1 $*
  204. else
  205. $1
  206. fi