upgrade 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126
  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. final_path=$(ynh_app_setting_get $app final_path)
  15. dns_method=$(ynh_app_setting_get $app dns_method)
  16. nameservers=$(ynh_app_setting_get $app nameservers)
  17. #=================================================
  18. # SPECIAL UPGRADE FOR VERSIONS < 1.2.0
  19. #=================================================
  20. # Removing configuration files with naming that occured in versions < 1.2.0 ("vpnadmin" instead off "$app")
  21. if [ -d /etc/nginx/conf.d/*.d/$app.conf ]; then
  22. ynh_secure_remove /etc/nginx/conf.d/*.d/$app.conf
  23. fi
  24. if [ -d /etc/php/*/fpm/pool.d/$app.conf ]; then
  25. ynh_secure_remove /etc/php/*/fpm/pool.d/$app.conf
  26. fi
  27. if [ -d /var/www/$app ]; then
  28. ynh_secure_remove /var/www/$app
  29. fi
  30. if [ -d /var/www/vpnadmin ]; then
  31. ynh_secure_remove /var/www/vpnadmin
  32. fi
  33. #=================================================
  34. # SPECIAL UPGRADE FOR VERSIONS < 2.0
  35. #=================================================
  36. if [ -z "$dns_method" ]; then
  37. ynh_app_setting_set --app=$app --key=dns_method --value=custom
  38. fi
  39. if [ -z "$nameservers" ]; then
  40. nameservers="$(grep -o -P '\s*nameserver\s+\K[abcdefabcdef\d.:]+' /etc/resolv.dnsmasq.conf | sort | uniq | paste -s -d, -)"
  41. ynh_app_setting_set --app=$app --key=nameservers --value="$nameservers"
  42. fi
  43. ## Versions known to have a buggy backup script
  44. #buggy_versions="1.0.0 1.0.1 1.1.0"
  45. #curr_version=$(read_manifest version)
  46. #if echo $buggy_versions | grep -w $curr_version > /dev/null; then
  47. # echo "Your current version of ${app} is very old: ${curr_version}. Please ignore the next warning." >&2
  48. #fi
  49. #
  50. ##=================================================
  51. ## BACKUP BEFORE UPGRADE THEN ACTIVE TRAP
  52. ##=================================================
  53. #
  54. #ynh_backup_before_upgrade
  55. #ynh_clean_setup () {
  56. # ynh_restore_upgradebackup
  57. #}
  58. ## Exit if an error occurs during the execution of the script
  59. ynh_abort_if_errors
  60. #=================================================
  61. # DO UPGRADE
  62. #=================================================
  63. # INSTALL DEPENDENCIES
  64. #=================================================
  65. ynh_print_info "Installing dependencies..."
  66. ynh_install_app_dependencies "$pkg_dependencies"
  67. #=================================================
  68. # DEPLOY FILES FROM PACKAGE
  69. #=================================================
  70. # Keep a copy of existing config files before overwriting them
  71. tmpdir=$(mktemp -d /tmp/vpnclient-upgrade-XXX)
  72. cp -r /etc/openvpn/client* ${tmpdir}
  73. # Deploy files from package
  74. vpnclient_deploy_files_and_services
  75. # Restore previously existing config files
  76. cp -r ${tmpdir}/client* /etc/openvpn/
  77. ynh_secure_remove ${tmpdir}
  78. #=================================================
  79. # SERVICE INTEGRATION IN YUNOHOST
  80. #=================================================
  81. ### Make sure that the yunohost services have a description and need-lock enabled
  82. # main service
  83. yunohost service add $service_name --description "Tunnels the internet traffic through a VPN" --need_lock --test_status="systemctl is-active openvpn@client.service" --log "/var/log/ynh-vpnclient.log"
  84. # checker service (this service was previously integrated in yunohost but we do not do this anymore)
  85. if ynh_exec_warn_less yunohost service status $service_checker_name >/dev/null
  86. then
  87. yunohost service remove $service_checker_name
  88. fi
  89. #=================================================
  90. # RESTART RELEVANT SERVICES
  91. #=================================================
  92. ynh_print_info "Restart services..."
  93. # this is meant to propagate the new files and configs
  94. systemctl -q is-active $service_name && yunohost service restart $service_name
  95. # Not sure if these are really necessary ...
  96. systemctl -q is-active $service_checker_name && systemctl restart $service_checker_name
  97. systemctl -q is-active $service_checker_name.timer && systemctl restart $service_checker_name.timer
  98. #=================================================
  99. # END OF SCRIPT
  100. #=================================================
  101. ynh_print_info "Upgrade of $app completed"