upgrade 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899
  1. #!/bin/bash
  2. #=================================================
  3. # GENERIC START
  4. #=================================================
  5. # IMPORT GENERIC HELPERS
  6. #=================================================
  7. source /usr/share/yunohost/helpers
  8. source _common.sh
  9. ynh_setting() {
  10. app=${1}
  11. setting=${2}
  12. sudo grep "^${setting}:" "/etc/yunohost/apps/${app}/settings.yml" | sed s/^[^:]\\+:\\s*[\"\']\\?// | sed s/\\s*[\"\']\$//
  13. }
  14. #=================================================
  15. # LOAD SETTINGS
  16. #=================================================
  17. app=$YNH_APP_INSTANCE_NAME
  18. domain=$(ynh_app_setting_get $app domain)
  19. path_url=$(ynh_app_setting_get $app path)
  20. is_public=$(ynh_app_setting_get $app is_public)
  21. final_path=$(ynh_app_setting_get $app final_path)
  22. server_name=$(ynh_app_setting_get $app server_name)
  23. #=================================================
  24. # SPECIAL UPGRADE FOR VERSIONS < 1.2.0
  25. #=================================================
  26. # Apply renaming that occured in v1.2.0 ("vpnadmin" -> "${app}")
  27. if [ -f /etc/nginx/conf.d/${domain}.d/vpnadmin.conf ]; then
  28. sudo sed "s|/var/www/vpnadmin/|/var/www/${app}/|g" -i "/etc/nginx/conf.d/${domain}.d/vpnadmin.conf"
  29. sudo sed "s|vpnadmin.sock|${app}.sock|g" -i "/etc/nginx/conf.d/${domain}.d/vpnadmin.conf"
  30. mv /etc/nginx/conf.d/${domain}.d/vpnadmin.conf /etc/nginx/conf.d/${domain}.d/${app}.conf
  31. fi
  32. if [ -f /etc/php5/fpm/pool.d/vpnadmin.conf ]; then
  33. sudo sed "s|/var/www/vpnadmin/|/var/www/${app}/|g" -i /etc/php5/fpm/pool.d/vpnadmin.conf
  34. sudo sed "s|vpnadmin.sock|${app}.sock|g" -i /etc/php5/fpm/pool.d/vpnadmin.conf
  35. mv /etc/php5/fpm/pool.d/vpnadmin.conf /etc/php5/fpm/pool.d/${app}.conf
  36. fi
  37. test -d /var/www/vpnadmin && mv /var/www/vpnadmin /var/www/${app}
  38. ## Versions known to have a buggy backup script
  39. #buggy_versions="1.0.0 1.0.1 1.1.0"
  40. #curr_version=$(read_manifest version)
  41. #if echo $buggy_versions | grep -w $curr_version > /dev/null; then
  42. # echo "Your current version of ${app} is very old: ${curr_version}. Please ignore the next warning." >&2
  43. #fi
  44. #
  45. ##=================================================
  46. ## BACKUP BEFORE UPGRADE THEN ACTIVE TRAP
  47. ##=================================================
  48. #
  49. #ynh_backup_before_upgrade
  50. #ynh_clean_setup () {
  51. # ynh_restore_upgradebackup
  52. #}
  53. ## Exit if an error occurs during the execution of the script
  54. #ynh_abort_if_errors
  55. #=================================================
  56. # DO UPGRADE
  57. #=================================================
  58. # INSTALL DEPENDENCIES
  59. #=================================================
  60. ynh_install_app_dependencies "$pkg_dependencies"
  61. #=================================================
  62. # DEPLOY FILES FROM PACKAGE
  63. #=================================================
  64. # Keep a copy of existing config files before overwriting them
  65. tmpdir=$(mktemp -d /tmp/vpnclient-upgrade-XXX)
  66. sudo cp -r /etc/openvpn/client* ${tmpdir}
  67. # Deploy files from package
  68. vpnclient_deploy_files_and_services "${domain}" "${app}"
  69. # Restore previously existing config files
  70. sudo cp -r ${tmpdir}/client* /etc/openvpn/
  71. sudo rm -rf ${tmpdir}
  72. #=================================================
  73. # RELOAD RELEVANT SERVICES
  74. #=================================================
  75. ynh_systemctl reload php5-fpm
  76. ynh_systemctl reload nginx
  77. ynh_systemctl restart ynh-vpnclient
  78. exit 0