upgrade 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134
  1. #!/bin/bash
  2. #=================================================
  3. # GENERIC STARTING
  4. #=================================================
  5. # IMPORT GENERIC HELPERS
  6. #=================================================
  7. source _common.sh
  8. source /usr/share/yunohost/helpers
  9. #=================================================
  10. # LOAD SETTINGS
  11. #=================================================
  12. ynh_print_info "Loading installation settings..."
  13. app=$YNH_APP_INSTANCE_NAME
  14. domain=$(ynh_app_setting_get $app domain)
  15. path_url=$(ynh_app_setting_get $app path)
  16. is_public=$(ynh_app_setting_get $app is_public)
  17. final_path=$(ynh_app_setting_get $app final_path)
  18. #=================================================
  19. # SPECIAL UPGRADE FOR VERSIONS < 1.2.0
  20. #=================================================
  21. # Apply renaming that occured in v1.2.0 ("vpnadmin" -> "${app}")
  22. if [ -f /etc/nginx/conf.d/${domain}.d/vpnadmin.conf ]; then
  23. ynh_replace_string "/var/www/vpnadmin/" "/var/www/${app}/" "/etc/nginx/conf.d/${domain}.d/vpnadmin.conf"
  24. ynh_replace_string "vpnadmin.sock" "${app}.sock" "/etc/nginx/conf.d/${domain}.d/vpnadmin.conf"
  25. mv /etc/nginx/conf.d/${domain}.d/vpnadmin.conf /etc/nginx/conf.d/${domain}.d/${app}.conf
  26. fi
  27. if [ -f /etc/php5/fpm/pool.d/vpnadmin.conf ]; then
  28. ynh_replace_string "/var/www/vpnadmin/" "/var/www/${app}/" /etc/php5/fpm/pool.d/vpnadmin.conf
  29. ynh_replace_string "vpnadmin.sock" "${app}.sock" /etc/php5/fpm/pool.d/vpnadmin.conf
  30. mv /etc/php5/fpm/pool.d/vpnadmin.conf /etc/php/7.0/fpm/pool.d/${app}.conf
  31. fi
  32. if [ -d /var/www/vpnadmin ]; then
  33. mv /var/www/vpnadmin /var/www/${app}
  34. fi
  35. ## Versions known to have a buggy backup script
  36. #buggy_versions="1.0.0 1.0.1 1.1.0"
  37. #curr_version=$(read_manifest version)
  38. #if echo $buggy_versions | grep -w $curr_version > /dev/null; then
  39. # echo "Your current version of ${app} is very old: ${curr_version}. Please ignore the next warning." >&2
  40. #fi
  41. #
  42. ##=================================================
  43. ## BACKUP BEFORE UPGRADE THEN ACTIVE TRAP
  44. ##=================================================
  45. #
  46. #ynh_backup_before_upgrade
  47. #ynh_clean_setup () {
  48. # ynh_restore_upgradebackup
  49. #}
  50. ## Exit if an error occurs during the execution of the script
  51. ynh_abort_if_errors
  52. #=================================================
  53. # DO UPGRADE
  54. #=================================================
  55. # INSTALL DEPENDENCIES
  56. #=================================================
  57. ynh_print_info "Installing dependencies..."
  58. ynh_install_app_dependencies "$pkg_dependencies"
  59. #=================================================
  60. # DEPLOY FILES FROM PACKAGE
  61. #=================================================
  62. # Keep a copy of existing config files before overwriting them
  63. tmpdir=$(mktemp -d /tmp/vpnclient-upgrade-XXX)
  64. cp -r /etc/openvpn/client* ${tmpdir}
  65. # Deploy files from package
  66. vpnclient_deploy_files_and_services "${domain}" "${app}" "${service_name}"
  67. # Restore previously existing config files
  68. cp -r ${tmpdir}/client* /etc/openvpn/
  69. ynh_secure_remove ${tmpdir}
  70. #=================================================
  71. # RELOAD RELEVANT SERVICES
  72. #=================================================
  73. ynh_print_info "Reload services..."
  74. systemctl reload php7.0-fpm
  75. systemctl reload nginx
  76. ### Make sure that the yunohost services have a description and need-lock enabled
  77. # main service
  78. yunohost service add $service_name --description "Tunnels the internet traffic through a VPN" --need_lock
  79. # checker service
  80. yunohost service add $service_checker_name --description "Makes sure that the VPN service is running" --need_lock
  81. # Reload systemd configuration
  82. systemctl daemon-reload
  83. ### Restart services
  84. # restart main service if needed
  85. if systemctl is-active $service_name >/dev/null;
  86. then
  87. yunohost service restart $service_name
  88. fi
  89. # restart checker service if needed
  90. if systemctl is-active $service_checker_name >/dev/null;
  91. then
  92. yunohost service restart $service_checker_name
  93. fi
  94. # restart checker service timer
  95. if systemctl is-active $service_name.timer >/dev/null;
  96. then
  97. yunohost service restart $service_checker_name.timer
  98. fi
  99. #=================================================
  100. # END OF SCRIPT
  101. #=================================================
  102. ynh_print_info "Upgrade of $app completed"