_common.sh 8.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217
  1. #!/bin/bash
  2. #=================================================
  3. # COMMON VARIABLES
  4. #=================================================
  5. ## new filenames starting 0.00~ynh5
  6. # make a filename/service name from domain/path
  7. if [[ "$path" == /* ]]; then
  8. url_path="${path:1}"
  9. fi
  10. if [[ "__${url_path}__" == '____' ]]; then
  11. flohmarkt_filename="$domain"
  12. else
  13. flohmarkt_filename="$domain-${url_path}"
  14. fi
  15. # this filename is used for logfile name and systemd.service name
  16. # and for symlinking install_dir and data_dir
  17. flohmarkt_filename="${YNH_APP_ID}_${flohmarkt_filename//[^A-Za-z0-9._-]/_}"
  18. # directory flohmarkts software is installed to
  19. # contains ./venv and ./src as sub-directories
  20. flohmarkt_install="$install_dir"
  21. flohmarkt_sym_install="$( dirname $flohmarkt_install )/$flohmarkt_filename"
  22. flohmarkt_venv_dir="${flohmarkt_install}/venv"
  23. flohmarkt_app_dir="${flohmarkt_install}/app"
  24. # directory containing logfiles
  25. flohmarkt_log_dir="/var/log/${YNH_APP_ID}/${flohmarkt_filename}"
  26. # filename for logfiles - ¡ojo! if not ends with .log will be interpreted
  27. # as a directory by ynh_use_logrotate
  28. # https://github.com/YunoHost/issues/issues/2383
  29. flohmarkt_logfile="${flohmarkt_log_dir}/${app}.log"
  30. # flohmarkt data_dir
  31. flohmarkt_data_dir="$data_dir"
  32. flohmarkt_sym_data_dir="$( dirname $flohmarkt_data_dir )/$flohmarkt_filename"
  33. ## old filenames before 0.00~ynh5 - for reference and needed to
  34. # migrate (see below)
  35. flohmarkt_old_install="/opt/flohmarkt"
  36. flohmarkt_old_venv_dir="${flohmarkt_old_install}/venv"
  37. flohmarkt_old_app_dir="${flohmarkt_old_install}/flohmarkt"
  38. flohmarkt_old_log_dir="/var/log/flohmarkt/"
  39. flohmarkt_old_logfile="flohmarkt"
  40. flohmarkt_old_service="flohmarkt"
  41. #=================================================
  42. # PERSONAL HELPERS
  43. #=================================================
  44. # set file permissions and owner for installation
  45. flohmarkt_ynh_set_permission() {
  46. # install dir - only root needs to write and $app reads
  47. chown root:$app -R "$flohmarkt_install"
  48. chmod g-w,o-rwx -R "$flohmarkt_install"
  49. }
  50. # start flohmarkt service
  51. flohmarkt_ynh_start_service() {
  52. ynh_systemd_action --service_name=$flohmarkt_filename --action="start" \
  53. --line_match='INFO: *Application startup complete.' --log_path="$flohmarkt_logfile" \
  54. --timeout=30
  55. }
  56. # stop flohmarkt service
  57. flohmarkt_ynh_stop_service() {
  58. ynh_systemd_action --service_name=$flohmarkt_filename --action="stop"
  59. }
  60. # start couchdb and wait for success
  61. flohmarkt_ynh_start_couchdb() {
  62. ynh_systemd_action --service_name=couchdb --action="start" --timeout=30 \
  63. --log_path="/var/log/couchdb/couchdb.log" \
  64. --line_match='Apache CouchDB has started on http://127.0.0.1'
  65. }
  66. # stop couchdb
  67. flohmarkt_ynh_stop_couchdb() {
  68. ynh_systemd_action --service_name=couchdb --action="stop" --timeout=30 \
  69. --log_path="/var/log/couchdb/couchdb.log" \
  70. --line_match='SIGTERM received - shutting down'
  71. }
  72. # install or upgrade couchdb
  73. flohmarkt_ynh_up_inst_couchdb() {
  74. echo "\
  75. couchdb couchdb/mode select standalone
  76. couchdb couchdb/mode seen true
  77. couchdb couchdb/bindaddress string 127.0.0.1
  78. couchdb couchdb/bindaddress seen true
  79. couchdb couchdb/cookie string $couchdb_magic_cookie
  80. couchdb couchdb/adminpass password $password_couchdb_admin
  81. couchdb couchdb/adminpass seen true
  82. couchdb couchdb/adminpass_again password $password_couchdb_admin
  83. couchdb couchdb/adminpass_again seen true" | debconf-set-selections
  84. DEBIAN_FRONTEND=noninteractive # apt-get install -y --force-yes couchdb
  85. ynh_install_extra_app_dependencies \
  86. --repo="deb https://apache.jfrog.io/artifactory/couchdb-deb/ $(lsb_release -c -s) main" \
  87. --key="https://couchdb.apache.org/repo/keys.asc" \
  88. --package="couchdb"
  89. }
  90. flohmarkt_ynh_dump_couchdb() {
  91. ../settings/scripts/couchdb-dump/couchdb-dump.sh -b -H 127.0.0.1 -d "${app}" \
  92. -q -u admin -p "${password_couchdb_admin}" -f "${YNH_CWD}/${app}.json"
  93. }
  94. flohmarkt_ynh_import_couchdb() {
  95. ls -l ../settings/scripts/couchdb-dump/couchdb-dump.sh ${YNH_CWD}/${app}.json
  96. ../settings/scripts/couchdb-dump/couchdb-dump.sh -r -c -H 127.0.0.1 -d "${app}" \
  97. -q -u admin -p "${password_couchdb_admin}" -f "${YNH_CWD}/${app}.json"
  98. }
  99. flohmarkt_ynh_delete_couchdb_user() {
  100. # https://codeberg.org/flohmarkt/flohmarkt_ynh/issues/46 - more than one revision?
  101. local couchdb_user_revision=$( curl -sX GET "http://127.0.0.1:5984/_users/org.couchdb.user%3A${app}" \
  102. --user "admin:${password_couchdb_admin}" | jq -r ._rev )
  103. curl -s -X DELETE "http://127.0.0.1:5984/_users/org.couchdb.user%3A${app}?rev=${couchdb_user_revision}" \
  104. --user "admin:${password_couchdb_admin}"
  105. }
  106. flohmarkt_ynh_delete_couchdb_db() {
  107. curl -s -X DELETE "http://127.0.0.1:5984/${app}" --user "admin:${password_couchdb_admin}"
  108. }
  109. flohmarkt_ynh_create_couchdb_user() {
  110. curl -s -X PUT "http://127.0.0.1:5984/_users/org.couchdb.user:${app}" --user "admin:${password_couchdb_admin}"\
  111. -H "Accept: application/json" -H "Content-Type: application/json" \
  112. -d "{\"name\": \"${app}\", \"password\": \"${password_couchdb_flohmarkt}\", \"roles\": [], \"type\": \"user\"}"
  113. }
  114. flohmarkt_ynh_couchdb_user_permissions() {
  115. curl -s -X PUT "http://127.0.0.1:5984/${app}/_security" --user "admin:${password_couchdb_admin}"\
  116. -H "Accept: application/json" -H "Content-Type: application/json" \
  117. -d "{\"members\":{\"names\": [\"${app}\"],\"roles\": [\"editor\"]}}"
  118. }
  119. flohmarkt_ynh_restore_couchdb() {
  120. # @@ todo for now we'll make sure dbuser and db do not exist
  121. # matrix:
  122. # Is there a way to interact with the admin during the scripts/* run?
  123. # absolutely not, and it's by design.
  124. # at bear minimum if you use the manifest v2 and app helpers, the script should fail.
  125. flohmarkt_ynh_delete_couchdb_user || true
  126. flohmarkt_ynh_delete_couchdb_db || true
  127. flohmarkt_ynh_import_couchdb
  128. flohmarkt_ynh_create_couchdb_user
  129. flohmarkt_ynh_couchdb_user_permissions
  130. }
  131. # create venv
  132. flohmarkt_ynh_create_venv() {
  133. python3 -m venv --without-pip "$flohmarkt_venv_dir"
  134. }
  135. # install requirements.txt in venv
  136. flohmarkt_ynh_venv_requirements() {
  137. (
  138. set +o nounset
  139. source "$flohmarkt_venv_dir/bin/activate"
  140. set -o nounset
  141. set -x
  142. $flohmarkt_venv_dir/bin/python3 -m ensurepip
  143. $flohmarkt_venv_dir/bin/pip3 install -r "$flohmarkt_app_dir/requirements.txt"
  144. )
  145. }
  146. # move files and directories to their new places
  147. flohmarkt_ynh_upgrade_path_ynh5() {
  148. # flohmarkt and couchdb are already stopped in upgrade script
  149. # move app_dir into new 'app' folder
  150. mv "$flohmarkt_install/flohmarkt" "$flohmarkt_app_dir"
  151. # yunohost seems to move the venv dir automatically, but this
  152. # doesn't work, because the paths inside the venv are not adjusted
  153. # delete the old, not working venv and create a new one:
  154. ynh_secure_remove --file="$flohmarkt_venv_dir"
  155. flohmarkt_ynh_create_venv
  156. flohmarkt_ynh_venv_requirements
  157. # remove old $install_dir
  158. ynh_secure_remove --file="$flohmarkt_old_install"
  159. # move logfile directory
  160. mkdir -p "$flohmarkt_log_dir"
  161. mv ${flohmarkt_old_log_dir}/${flohmarkt_old_logfile}.* "$flohmarkt_log_dir"
  162. # update settings for above
  163. # @@ automatically done? maybe?
  164. # remove systemd.service - will be generated newly by upgrade
  165. # ynh_remove_systemd_config --service="$flohmarkt_old_service"
  166. ynh_systemd_action --action=stop --service_name="$flohmarkt_old_service"
  167. ynh_systemd_action --action=disable --service_name="$flohmarkt_old_service"
  168. ynh_secure_remove --file="/etc/systemd/system/multi-user.target.wants/flohmarkt.service"
  169. ynh_secure_remove --file="/etc/systemd/system/flohmarkt.service"
  170. # funktioniert nicht? issue?
  171. #ynh_systemd_action --action=daemon-reload
  172. # DEBUG + systemctl daemon-reload flohmarkt
  173. # WARNING Too many arguments.
  174. systemctl daemon-reload
  175. # unit flohmarkt is automatically appended and therefor this fails:
  176. #ynh_systemd_action --action=reset-failed
  177. systemctl reset-failed
  178. # create symlinks
  179. ln -s "$flohmarkt_install" "$flohmarkt_sym_install"
  180. ln -s "$flohmarkt_data_dir" "$flohmarkt_sym_data_dir"
  181. }
  182. #=================================================
  183. # EXPERIMENTAL HELPERS
  184. #=================================================
  185. #=================================================
  186. # FUTURE OFFICIAL HELPERS
  187. #=================================================