From f17b28743a084a5ee36b4d29e672202b09ffc84d Mon Sep 17 00:00:00 2001 From: Markus Heiser Date: Sun, 23 Feb 2020 21:05:22 +0100 Subject: [PATCH] utils/serx.sh: make uWSGI installation available for all distros (WIP) Signed-off-by: Markus Heiser --- utils/lib.sh | 116 ++++++++++++++++++++++++++++++++++++++++--------- utils/searx.sh | 12 ++--- 2 files changed, 101 insertions(+), 27 deletions(-) diff --git a/utils/lib.sh b/utils/lib.sh index c3707d58..f74187f4 100755 --- a/utils/lib.sh +++ b/utils/lib.sh @@ -693,12 +693,46 @@ apache_dissable_site() { uWSGI_SETUP="${uWSGI_SETUP:=/etc/uwsgi}" +case $DIST_ID-$DIST_VERS in + ubuntu-*|debian-*) + # init.d --> /usr/share/doc/uwsgi/README.Debian.gz + uWSGI_APPS_AVAILABLE="${uWSGI_SETUP}/apps-available" + uWSGI_APPS_ENABLED="${uWSGI_SETUP}/apps-enabled" + ;; + arch-*) + # systemd --> /usr/lib/systemd/system/uwsgi@.service + uWSGI_APPS_AVAILABLE="${uWSGI_SETUP}" + uWSGI_APPS_ENABLED="${uWSGI_SETUP}" + ;; + *) + info_msg "$DIST_ID-$DIST_VERS: uWSGI not yet implemented" + ;; +esac + uWSGI_restart() { - # usage: uWSGI_restart() + # usage: uWSGI_restart() + + local CONF="$1" + if [[ -z $CONF ]]; then + err_msg "uWSGI_restart: missing arguments" + return 42 + fi info_msg "restart uWSGI service" - systemctl restart uwsgi + + case $DIST_ID-$DIST_VERS in + ubuntu-*|debian-*) + service uwsgi restart "${CONF%.*}" + ;; + arch-*) + systemctl restart "uwsgi@${CONF%.*}" + ;; + *) + err_msg "$DIST_ID-$DIST_VERS: uWSGI not yet implemented" + return 42 + ;; + esac } uWSGI_app_available() { @@ -708,7 +742,7 @@ uWSGI_app_available() { err_msg "uWSGI_app_available: missing arguments" return 42 fi - [[ -f "${uWSGI_SETUP}/apps-available/${CONF}" ]] + [[ -f "${uWSGI_APPS_AVAILABLE}/${CONF}" ]] } uWSGI_install_app() { @@ -725,13 +759,12 @@ uWSGI_install_app() { *) pos_args+=("$i");; esac done - + mkdir -p "${uWSGI_APPS_AVAILABLE}" install_template "${template_opts[@]}" \ - "${uWSGI_SETUP}/apps-available/${pos_args[1]}" \ + "${uWSGI_APPS_AVAILABLE}/${pos_args[1]}" \ root root 644 - uWSGI_enable_app "${pos_args[1]}" - uWSGI_restart + uWSGI_restart "${pos_args[1]}" info_msg "installed uWSGI app: ${pos_args[1]}" } @@ -742,18 +775,35 @@ uWSGI_remove_app() { local CONF="$1" info_msg "remove uWSGI app: ${CONF}" uWSGI_disable_app "${CONF}" - uWSGI_restart - rm -f "${uWSGI_SETUP}/apps-available/${CONF}" + uWSGI_restart "${CONF}" + rm -f "${uWSGI_APPS_AVAILABLE}/${CONF}" } uWSGI_app_enabled() { # usage: uWSGI_app_enabled + local CONF="$1" + local exit_val=0 if [[ -z $CONF ]]; then err_msg "uWSGI_app_enabled: missing arguments" return 42 fi - [[ -f "${uWSGI_SETUP}/apps-enabled/${CONF}" ]] + case $DIST_ID-$DIST_VERS in + ubuntu-*|debian-*) + [[ -f "${uWSGI_APPS_ENABLED}/${CONF}" ]] + exit_val=$? + ;; + arch-*) + systemctl -q is-enabled "uwsgi@${CONF%.*}" + exit_val=$? + ;; + *) + # FIXME + err_msg "$DIST_ID-$DIST_VERS: uWSGI not yet implemented" + exit_val=1 + ;; + esac + return $exit_val } # shellcheck disable=SC2164 @@ -762,16 +812,29 @@ uWSGI_enable_app() { # usage: uWSGI_enable_app local CONF="$1" + if [[ -z $CONF ]]; then err_msg "uWSGI_enable_app: missing arguments" return 42 fi - pushd "${uWSGI_SETUP}/apps-enabled" >/dev/null - rm -f "$CONF" - # shellcheck disable=SC2226 - ln -s "../apps-available/${CONF}" - info_msg "enabled uWSGI app: ${CONF} (restart uWSGI required)" - popd >/dev/null + + case $DIST_ID-$DIST_VERS in + ubuntu-*|debian-*) + mkdir -p "${uWSGI_APPS_ENABLED}" + pushd "${uWSGI_APPS_ENABLED}" >/dev/null + rm -f "$CONF" + ln -s "${uWSGI_APPS_AVAILABLE}/${CONF}" . + popd >/dev/null + info_msg "enabled uWSGI app: ${CONF} (restart required)" + ;; + arch-*) + systemctl enable "uwsgi@${CONF%.*}" + ;; + *) + # FIXME + err_msg "$DIST_ID-$DIST_VERS: uWSGI not yet implemented" + ;; + esac } uWSGI_disable_app() { @@ -783,11 +846,22 @@ uWSGI_disable_app() { err_msg "uWSGI_enable_app: missing arguments" return 42 fi - rm -f "${uWSGI_SETUP}/apps-enabled/${CONF}" - # FIXME: restart uwsgi service won't stop wsgi forked processes of user searx. - # I had to kill them manually here ... - pkill -f "${uWSGI_SETUP}/apps-enabled/${CONF}" -9 - info_msg "disabled uWSGI app: ${CONF} (restart uWSGI required)" + + case $DIST_ID-$DIST_VERS in + ubuntu-*|debian-*) + service uwsgi stop "${CONF%.*}" + rm -f "${uWSGI_APPS_ENABLED}/${CONF}" + info_msg "disabled uWSGI app: ${CONF} (restart uWSGI required)" + ;; + arch-*) + systemctl stop "uwsgi@${CONF%.*}" + systemctl disable "uwsgi@${CONF%.*}" + ;; + *) + # FIXME + err_msg "$DIST_ID-$DIST_VERS: uWSGI not yet implemented" + ;; + esac } # distro's package manager diff --git a/utils/searx.sh b/utils/searx.sh index 0d011ef0..2bf26bba 100755 --- a/utils/searx.sh +++ b/utils/searx.sh @@ -66,7 +66,7 @@ APACHE_SEARX_SITE="searx.conf" # shellcheck disable=SC2034 CONFIG_FILES=( - "${uWSGI_SETUP}/apps-available/${SEARX_UWSGI_APP}" + "${uWSGI_APPS_AVAILABLE}/${SEARX_UWSGI_APP}" ) # shellcheck disable=SC2034 @@ -246,7 +246,7 @@ git pull ${SEARX_SRC}/manage.sh update_packages EOF install_settings - uWSGI_restart + uWSGI_restart "$SEARX_UWSGI_APP" } remove_all() { @@ -458,14 +458,14 @@ activate_service() { rst_title "Activate $SEARX_INSTANCE_NAME (service)" section echo uWSGI_enable_app "$SEARX_UWSGI_APP" - uWSGI_restart + uWSGI_restart "$SEARX_UWSGI_APP" } deactivate_service() { rst_title "De-Activate $SEARX_INSTANCE_NAME (service)" section echo uWSGI_disable_app "$SEARX_UWSGI_APP" - uWSGI_restart + uWSGI_restart "$SEARX_UWSGI_APP" } enable_debug() { @@ -475,7 +475,7 @@ enable_debug() { cd ${SEARX_SRC} sed -i -e "s/debug : False/debug : True/g" "$SEARX_SETTINGS_PATH" EOF - uWSGI_restart + uWSGI_restart "$SEARX_UWSGI_APP" } disable_debug() { @@ -484,7 +484,7 @@ disable_debug() { cd ${SEARX_SRC} sed -i -e "s/debug : True/debug : False/g" "$SEARX_SETTINGS_PATH" EOF - uWSGI_restart + uWSGI_restart "$SEARX_UWSGI_APP" } inspect_service() {