1
0
Fork 0
mirror of https://github.com/YunoHost-Apps/wallabag2_ynh.git synced 2024-10-01 13:35:06 +02:00

Simplify change_url script by using newly accessible conf folder

From the PR https://github.com/YunoHost-Apps/wallabag2_ynh/pull/50, coded by JimboJoe.
This commit is contained in:
Maniack Crudelis 2018-06-29 20:30:27 +02:00 committed by GitHub
parent f83f961926
commit 1b4e2adeda
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -68,32 +68,22 @@ if [ $change_path -eq 1 ]
then then
# Make a backup of the original nginx config file if modified # Make a backup of the original nginx config file if modified
ynh_backup_if_checksum_is_different "$nginx_conf_path" ynh_backup_if_checksum_is_different "$nginx_conf_path"
if [ "$new_path" = "/" ] && [ "$old_path" != "/" ] ; then # Set global variables for nginx helper
# Replace path in several location occurrences based on different recognition patterns domain="$old_domain"
ynh_replace_string "location $old_path/ {\$" "location / {" "$nginx_conf_path" path_url="$new_path"
ynh_replace_string "location ~ ^$old_path" "location ~ ^" "$nginx_conf_path" # Store path_url setting
ynh_replace_string "location $old_path {" "location / {" "$nginx_conf_path" ynh_app_setting_set $app path_url "$path_url"
ynh_replace_string "rewrite ^ $old_path" "rewrite ^ " "$nginx_conf_path" # Create a dedicated nginx config
ynh_add_nginx_config
# Move #for-subdir comment at the beginning of the line (line not needed for "/" path) if [ "$path_url" = "/" ]
ynh_replace_string "\(.*\) #for-subdir" "#for-subdir \1" "$nginx_conf_path" then
elif [ "$new_path" != "/" ] && [ "$old_path" = "/" ] ; then # Replace "//" location (due to nginx template)
# Move #for-subdir comment at the end of the line (line needed for "/path" path) # Prevent from replacing in "http://" expressions by excluding ":" as preceding character
ynh_replace_string "#for-subdir\(.*\)" "\1 #for-subdir" "$nginx_conf_path" sed --in-place "s@\([^:]\)//@\1/@g" "$nginx_conf_path"
# Replace path in several location occurrences based on different recognition patterns
ynh_replace_string "location / {\$" "location $new_path/ {" "$nginx_conf_path"
ynh_replace_string "location ~ ^" "location ~ ^$new_path" "$nginx_conf_path"
ynh_replace_string "location / {" "location $new_path {" "$nginx_conf_path"
ynh_replace_string "rewrite ^ /" "rewrite ^ $new_path/" "$nginx_conf_path"
else else
# Replace locations starting with old_path # Move prefix comment #for-subdir at end of lines
# Look for every possible patterns for location directive (see https://nginx.org/en/docs/http/ngx_http_core_module.html#location) sed --in-place "s/#for-subdir\(.*\)/\1 #for-subdir/g" "$nginx_conf_path"
ynh_replace_string "location\( \(=\|~\|~\*\|\^~\)\)\? \(\^\)\?$old_path" "location\1 \3$new_path" "$nginx_conf_path"
# Replace path in "rewrite" directive
ynh_replace_string "rewrite ^ $old_path" "rewrite ^ $new_path" "$nginx_conf_path"
fi fi
# Calculate and store the nginx config file checksum
ynh_store_file_checksum "$nginx_conf_path" ynh_store_file_checksum "$nginx_conf_path"
fi fi
@ -115,7 +105,7 @@ fi
ynh_mysql_connect_as "$db_name" "$db_pwd" "$db_user" <<< "UPDATE craue_config_setting SET value = 'https://$new_domain$new_path' WHERE name = 'wallabag_url'" ynh_mysql_connect_as "$db_name" "$db_pwd" "$db_user" <<< "UPDATE craue_config_setting SET value = 'https://$new_domain$new_path' WHERE name = 'wallabag_url'"
# Change domain name in parameters.yml # Change domain name in parameters.yml
ynh_replace_string "domain_name: https://$old_domain$old_path" "domain_name: https://$new_domain$new_path" $final_path/app/config/parameters.yml ynh_replace_string "domain_name: .*" "domain_name: https://$new_domain$new_path" $final_path/app/config/parameters.yml
# If "Download images locally" option has been enabled in Internal Settings # If "Download images locally" option has been enabled in Internal Settings
download_images_enabled=$(ynh_mysql_connect_as "$db_name" "$db_pwd" "$db_user" <<< "SELECT value from craue_config_setting WHERE name='download_images_enabled '" | tail -n 1) download_images_enabled=$(ynh_mysql_connect_as "$db_name" "$db_pwd" "$db_user" <<< "SELECT value from craue_config_setting WHERE name='download_images_enabled '" | tail -n 1)
@ -125,6 +115,9 @@ if [ "$download_images_enabled" = "1" ] ; then
ynh_mysql_connect_as "$db_name" "$db_pwd" "$db_user" <<< "UPDATE entry SET content = REPLACE(content, '$old_domain$old_path', '$new_domain$new_path');" ynh_mysql_connect_as "$db_name" "$db_pwd" "$db_user" <<< "UPDATE entry SET content = REPLACE(content, '$old_domain$old_path', '$new_domain$new_path');"
fi fi
# Clear assets cache
ynh_secure_remove $final_path/var/cache
#================================================= #=================================================
# GENERIC FINALIZATION # GENERIC FINALIZATION
#================================================= #=================================================