upgrade 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136
  1. #!/bin/bash
  2. #=================================================
  3. # GENERIC START
  4. #=================================================
  5. # IMPORT GENERIC HELPERS
  6. #=================================================
  7. source _common.sh
  8. source /usr/share/yunohost/helpers
  9. #=================================================
  10. # LOAD SETTINGS
  11. #=================================================
  12. app=$YNH_APP_INSTANCE_NAME
  13. domain=$(ynh_app_setting_get $app domain)
  14. path_url=$(ynh_app_setting_get $app path)
  15. admin=$(ynh_app_setting_get $app admin)
  16. is_public=$(ynh_app_setting_get $app is_public)
  17. final_path=$(ynh_app_setting_get $app final_path)
  18. language=$(ynh_app_setting_get $app language)
  19. db_name=$(ynh_app_setting_get $app db_name)
  20. #=================================================
  21. # ENSURE DOWNWARD COMPATIBILITY
  22. #=================================================
  23. # Fix is_public as a boolean value
  24. if [ "$is_public" = "Yes" ]; then
  25. ynh_app_setting_set $app is_public 1
  26. is_public=1
  27. elif [ "$is_public" = "No" ]; then
  28. ynh_app_setting_set $app is_public 0
  29. is_public=0
  30. fi
  31. # If db_name doesn't exist, create it
  32. if [ -z $db_name ]; then
  33. db_name=$(ynh_sanitize_dbid $app)
  34. ynh_app_setting_set $app db_name $db_name
  35. fi
  36. # If final_path doesn't exist, create it
  37. if [ -z $final_path ]; then
  38. final_path=/var/www/$app
  39. ynh_app_setting_set $app final_path $final_path
  40. fi
  41. #=================================================
  42. # BACKUP BEFORE UPGRADE THEN ACTIVE TRAP
  43. #=================================================
  44. # Backup the current version of the app
  45. ynh_backup_before_upgrade
  46. ynh_clean_setup () {
  47. # restore it if the upgrade fails
  48. ynh_restore_upgradebackup
  49. }
  50. # Exit if an error occurs during the execution of the script
  51. ynh_abort_if_errors
  52. #=================================================
  53. # CHECK THE PATH
  54. #=================================================
  55. # Normalize the URL path syntax
  56. path_url=$(ynh_normalize_url_path $path_url)
  57. #=================================================
  58. # STANDARD UPGRADE STEPS
  59. #=================================================
  60. DEBIAN_FRONTEND=noninteractive apt-mark unhold zabbix-server-mysql zabbix-frontend-php
  61. ynh_package_update
  62. DEBIAN_FRONTEND=noninteractive apt-get -y download zabbix-frontend-php
  63. ar x *.deb
  64. tar xzf control.tar.gz
  65. sed -i 's/apache2 | httpd, //' control
  66. tar --ignore-failed-read -cvzf control.tar.gz {post,pre}{inst,rm} md5sums control
  67. ar rcs zabbix-frontend-php+stretch_all-noapache2.deb debian-binary control.tar.gz data.tar.xz
  68. dpkg -i zabbix-frontend-php+stretch_all-noapache2.deb
  69. rm -fr zabbix-*.deb
  70. apt-get -y --only-upgrade install zabbix-server-mysql zabbix-agent
  71. DEBIAN_FRONTEND=noninteractive apt-mark hold zabbix-server-mysql zabbix-frontend-php
  72. #=================================================
  73. # SPECIFIC UPGRADE
  74. #=================================================
  75. ynh_restore_file "$final_path/conf/zabbix.conf.php" "final_path/conf/zabbix.conf.php"
  76. ynh_restore_file "/etc/zabbix/zabbix_server.conf" "/etc/zabbix/zabbix_server.conf"
  77. ynh_restore_file "/etc/zabbix/zabbix_agentd.conf" "/etc/zabbix/zabbix_agentd.conf"
  78. ynh_restore_file "/etc/zabbix/zabbix_agentd.d" "/etc/zabbix/zabbix_agentd.d"
  79. #=================================================
  80. # SETUP LOGROTATE
  81. #=================================================
  82. # Use logrotate to manage app-specific logfile(s)
  83. ynh_use_logrotate --non-append
  84. #=================================================
  85. # SETUP SYSTEMD
  86. #=================================================
  87. # Create a dedicated systemd config
  88. ynh_add_systemd_config
  89. #=================================================
  90. # GENERIC FINALIZATION
  91. #=================================================
  92. # SECURE FILES AND DIRECTORIES
  93. #=================================================
  94. # Set permissions on app files
  95. chown -R root: $final_path
  96. #=================================================
  97. # SETUP SSOWAT
  98. #=================================================
  99. # Make app public if necessary
  100. if [ $is_public -eq 1 ]
  101. then
  102. # unprotected_uris allows SSO credentials to be passed anyway
  103. ynh_app_setting_set $app unprotected_uris "/"
  104. fi
  105. #=================================================
  106. # RELOAD NGINX
  107. #=================================================
  108. systemctl reload nginx