1
0
Fork 0
mirror of https://github.com/YunoHost-Apps/searx_ynh.git synced 2024-09-03 20:16:30 +02:00

fix upgrade, change_url

This commit is contained in:
Salamandar 2024-01-29 21:27:10 +01:00
parent eeac222492
commit 72c5f996fe
3 changed files with 26 additions and 54 deletions

View file

@ -23,6 +23,8 @@ ynh_systemd_action --service_name=uwsgi --action=stop
#================================================= #=================================================
ynh_script_progression --message="Updating NGINX web server configuration..." --weight=2 ynh_script_progression --message="Updating NGINX web server configuration..." --weight=2
path_no_root=${path%/}
# Create a dedicated NGINX config
ynh_change_url_nginx_config ynh_change_url_nginx_config
#================================================= #=================================================

View file

@ -40,9 +40,7 @@ _searx_venv_install
ynh_add_config --template="requirements-ynh.txt" --destination="$install_dir/requirements-ynh.txt" ynh_add_config --template="requirements-ynh.txt" --destination="$install_dir/requirements-ynh.txt"
pushd "$install_dir" ynh_exec_as "$app" "$venvpy" -m pip install --requirement "$install_dir/requirements-ynh.txt" --no-cache-dir
ynh_exec_as "$app" "$venvpy" -m pip install --requirement ./requirements-ynh.txt --no-cache-dir
popd
#================================================= #=================================================
# CONFIGURE SEARX # CONFIGURE SEARX

View file

@ -9,12 +9,6 @@
source _common.sh source _common.sh
source /usr/share/yunohost/helpers source /usr/share/yunohost/helpers
#=================================================
# CHECK VERSION
#=================================================
upgrade_type=$(ynh_check_app_version_changed)
#================================================= #=================================================
# STANDARD UPGRADE STEPS # STANDARD UPGRADE STEPS
#================================================= #=================================================
@ -22,38 +16,32 @@ upgrade_type=$(ynh_check_app_version_changed)
#================================================= #=================================================
ynh_script_progression --message="Ensuring downward compatibility..." ynh_script_progression --message="Ensuring downward compatibility..."
mkdir -p /var/log/uwsgi/$app if [ -f "$install_dir/setup.py" ]; then
chown $app:root /var/log/uwsgi/$app # Clean up the whole install_dir except settings.yml
chmod -R u=rwX,g=rX,o= /var/log/uwsgi/$app tmpdir="$(mktemp -d)"
cp "$install_dir/searx/settings.yml" "$tmpdir"
ynh_secure_remove "$install_dir"
mkdir -p "$install_dir"
chmod 750 "$install_dir"
chown "$app:" "$install_dir"
mkdir -p "$install_dir/source/searx"
cp "$tmpdir/settings.yml" "$install_dir/source/searx"
ynh_secure_remove --file="$tmpdir"
fi
#================================================= #=================================================
# DOWNLOAD, CHECK AND UNPACK SOURCE # DOWNLOAD, CHECK AND UNPACK SOURCE
#================================================= #=================================================
ynh_script_progression --message="Upgrading source files..." --weight=3
if [ "$upgrade_type" == "UPGRADE_APP" ] # Download, check integrity, uncompress and patch the source from app.src
then ynh_setup_source --dest_dir="$install_dir/source" --full_replace=1 --keep="searx/settings.yml"
ynh_script_progression --message="Upgrading source files..." --weight=3
# Create a temporary directory
tmpdir="$(mktemp -d)"
# Backup the config file in the temp dir
cp -a "$install_dir/searx/settings.yml" "$tmpdir/settings.yml"
# Download, check integrity, uncompress and patch the source from app.src
ynh_setup_source --dest_dir="$install_dir"
# Copy the admin saved settings from tmp directory to final path
cp -a "$tmpdir/settings.yml" "$install_dir/searx/settings.yml"
# Remove the tmp directory securely
ynh_secure_remove --file="$tmpdir"
fi
#================================================= #=================================================
# NGINX CONFIGURATION # REAPPLY SYSTEM CONFIGURATIONS
#================================================= #=================================================
ynh_script_progression --message="Upgrading NGINX web server configuration..." --weight=2 ynh_script_progression --message="Upgrading system configurations related to $app..." --weight=1
path_no_root=${path%/} path_no_root=${path%/}
# Create a dedicated NGINX config # Create a dedicated NGINX config
@ -66,27 +54,11 @@ ynh_add_nginx_config "path_no_root"
#================================================= #=================================================
ynh_script_progression --message="Upgrading Searx..." --weight=7 ynh_script_progression --message="Upgrading Searx..." --weight=7
# Clean venv if it still on python2 _searx_venv_install
if [ -e $install_dir/bin ] && [ ! -e $install_dir/bin/python3 ]
then
ynh_regex_secure_remove --file=$install_dir/lib/ --regex='python[^/.]*'
ynh_regex_secure_remove --file=$install_dir/lib64/ --regex='python[^/.]*'
ynh_regex_secure_remove --file=$install_dir/share/python-wheels
fi
ynh_regex_secure_remove --file=$install_dir/lib/python3/site-packages/setuptools ynh_add_config --template="requirements-ynh.txt" --destination="$install_dir/requirements-ynh.txt"
ynh_regex_secure_remove --file=$install_dir/lib/python3/site-packages/ --regex='setuptools-[^/.]*'
ynh_regex_secure_remove --file=$install_dir/venv/lib/python3/site-packages/setuptools ynh_exec_as "$app" "$venvpy" -m pip install --requirement "$install_dir/requirements-ynh.txt" --no-cache-dir
ynh_regex_secure_remove --file=$install_dir/venv/lib/python3/site-packages/ --regex='setuptools-[^/.]*'
pushd $install_dir
python3 -m venv venv
venv/bin/pip3 install -U pip setuptools wheel pyyaml --no-cache-dir
venv/bin/pip3 install --requirement $install_dir/requirements-ynh.txt --no-cache-dir
popd
chown -R $app: "$install_dir"
#================================================= #=================================================
# CONFIGURE SEARX # CONFIGURE SEARX
@ -94,7 +66,7 @@ chown -R $app: "$install_dir"
# ynh_script_progression --message="Configuring Searx..." --weight=2 # ynh_script_progression --message="Configuring Searx..." --weight=2
# secret_key=$(ynh_string_random) # secret_key=$(ynh_string_random)
# ynh_add_config --template="settings.yml" --destination="$install_dir/searx/settings.yml" # ynh_add_config --template="settings.yml" --destination="$install_dir/source/searx/settings.yml"
#================================================= #=================================================
# CONFIGURE UWSGI FOR SEARX # CONFIGURE UWSGI FOR SEARX
@ -114,7 +86,7 @@ ynh_add_uwsgi_service
ynh_script_progression --message="Starting a systemd service..." --weight=3 ynh_script_progression --message="Starting a systemd service..." --weight=3
# Wait for searx to be fully started # Wait for searx to be fully started
ynh_systemd_action --service_name=uwsgi-app@$app.service --action=restart --line_match="spawned uWSGI master process" --log_path="/var/log/uwsgi/$app/$app.log" ynh_systemd_action --service_name="uwsgi-app@$app.service" --action=restart --line_match="spawned uWSGI master process" --log_path="/var/log/uwsgi/$app/$app.log"
#================================================= #=================================================
# END OF SCRIPT # END OF SCRIPT