_common.sh 8.1 KB

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