123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547 |
- #!/usr/bin/env bash
- # -*- coding: utf-8; mode: sh indent-tabs-mode: nil -*-
- # SPDX-License-Identifier: AGPL-3.0-or-later
- # shellcheck source=utils/lib.sh
- source "$(dirname "${BASH_SOURCE[0]}")/lib.sh"
- # shellcheck source=utils/brand.env
- source "${REPO_ROOT}/utils/brand.env"
- source_dot_config
- SEARX_URL="${PUBLIC_URL:-http://$(uname -n)/searx}"
- source "${REPO_ROOT}/utils/lxc-searx.env"
- in_container && lxc_set_suite_env
- # ----------------------------------------------------------------------------
- # config
- # ----------------------------------------------------------------------------
- MORTY_LISTEN="${MORTY_LISTEN:-127.0.0.1:3000}"
- PUBLIC_URL_PATH_MORTY="${PUBLIC_URL_PATH_MORTY:-/morty/}"
- PUBLIC_URL_MORTY="${PUBLIC_URL_MORTY:-$(echo "$SEARX_URL" | sed -e's,^\(.*://[^/]*\).*,\1,g')${PUBLIC_URL_PATH_MORTY}}"
- # shellcheck disable=SC2034
- MORTY_TIMEOUT=5
- SERVICE_NAME="morty"
- SERVICE_USER="${SERVICE_USER:-${SERVICE_NAME}}"
- SERVICE_HOME_BASE="${SERVICE_HOME_BASE:-/usr/local}"
- SERVICE_HOME="${SERVICE_HOME_BASE}/${SERVICE_USER}"
- SERVICE_SYSTEMD_UNIT="${SYSTEMD_UNITS}/${SERVICE_NAME}.service"
- # shellcheck disable=SC2034
- SERVICE_GROUP="${SERVICE_USER}"
- # shellcheck disable=SC2034
- SERVICE_ENV_DEBUG=false
- GO_ENV="${SERVICE_HOME}/.go_env"
- GO_PKG_URL="https://dl.google.com/go/go1.13.5.linux-amd64.tar.gz"
- GO_TAR=$(basename "$GO_PKG_URL")
- # shellcheck disable=SC2034
- CONFIG_FILES=()
- # Apache Settings
- APACHE_MORTY_SITE="morty.conf"
- NGINX_MORTY_SITE="morty.conf"
- # ----------------------------------------------------------------------------
- usage() {
- # ----------------------------------------------------------------------------
- # shellcheck disable=SC1117
- cat <<EOF
- usage::
- $(basename "$0") shell
- $(basename "$0") install [all|user]
- $(basename "$0") update [morty]
- $(basename "$0") remove [all]
- $(basename "$0") activate [service]
- $(basename "$0") deactivate [service]
- $(basename "$0") inspect [service]
- $(basename "$0") option [debug-on|debug-off|new-key]
- $(basename "$0") apache [install|remove]
- $(basename "$0") nginx [install|remove]
- $(basename "$0") info [searx]
- shell
- start interactive shell from user ${SERVICE_USER}
- install / remove
- all: complete setup of morty service
- user: add/remove service user '$SERVICE_USER' ($SERVICE_HOME)
- update morty
- Update morty installation ($SERVICE_HOME)
- activate service
- activate and start service daemon (systemd unit)
- deactivate service
- stop and deactivate service daemon (systemd unit)
- inspect service
- show service status and log
- option
- set one of the available options
- :new-key: set new morty key
- apache : ${PUBLIC_URL_MORTY}
- :install: apache site with a reverse proxy (ProxyPass)
- :remove: apache site ${APACHE_MORTY_SITE}
- nginx (${PUBLIC_URL_MORTY})
- :install: nginx site with a reverse proxy (ProxyPass)
- :remove: nginx site ${NGINX_MORTY_SITE}
- If needed, set the environment variables in the '${DOT_CONFIG#"$REPO_ROOT/"}' file::
- PUBLIC_URL_MORTY: ${PUBLIC_URL_MORTY}
- MORTY_LISTEN: ${MORTY_LISTEN}
- SERVICE_USER: ${SERVICE_USER}
- EOF
- if in_container; then
- # in containers the service is listening on 0.0.0.0 (see lxc-searx.env)
- for ip in $(global_IPs) ; do
- if [[ $ip =~ .*:.* ]]; then
- echo " container URL (IPv6): http://[${ip#*|}]:3000/"
- else
- # IPv4:
- echo " container URL (IPv4): http://${ip#*|}:3000/"
- fi
- done
- fi
- echo
- info_searx
- [[ -n ${1} ]] && err_msg "$1"
- }
- info_searx() {
- # shellcheck disable=SC1117
- cat <<EOF
- To activate result and image proxy in searx, edit settings.yml (read:
- ${DOCS_URL}/admin/morty.html)::
- result_proxy:
- url : ${PUBLIC_URL_MORTY}
- server:
- image_proxy : True
- EOF
- }
- main() {
- required_commands \
- sudo install git wget curl \
- || exit
- local _usage="ERROR: unknown or missing $1 command $2"
- case $1 in
- --getenv) var="$2"; echo "${!var}"; exit 0;;
- -h|--help) usage; exit 0;;
- shell)
- sudo_or_exit
- interactive_shell "${SERVICE_USER}"
- ;;
- inspect)
- case $2 in
- service)
- sudo_or_exit
- inspect_service
- ;;
- *) usage "$_usage"; exit 42;;
- esac ;;
- install)
- rst_title "$SERVICE_NAME" part
- sudo_or_exit
- case $2 in
- all) install_all ;;
- user) assert_user ;;
- *) usage "$_usage"; exit 42;;
- esac ;;
- update)
- sudo_or_exit
- case $2 in
- morty) update_morty ;;
- *) usage "$_usage"; exit 42;;
- esac ;;
- remove)
- sudo_or_exit
- case $2 in
- all) remove_all;;
- user) drop_service_account "${SERVICE_USER}" ;;
- *) usage "$_usage"; exit 42;;
- esac ;;
- activate)
- sudo_or_exit
- case $2 in
- service) systemd_activate_service "${SERVICE_NAME}" ;;
- *) usage "$_usage"; exit 42;;
- esac ;;
- deactivate)
- sudo_or_exit
- case $2 in
- service) systemd_deactivate_service "${SERVICE_NAME}" ;;
- *) usage "$_usage"; exit 42;;
- esac ;;
- apache)
- sudo_or_exit
- case $2 in
- install) install_apache_site ;;
- remove) remove_apache_site ;;
- *) usage "$_usage"; exit 42;;
- esac ;;
- nginx)
- sudo_or_exit
- case $2 in
- install) install_nginx_site ;;
- remove) remove_nginx_site ;;
- *) usage "$_usage"; exit 42;;
- esac ;;
- info)
- case $2 in
- searx) info_searx ;;
- *) usage "$_usage"; exit 42;;
- esac ;;
- option)
- sudo_or_exit
- case $2 in
- new-key) set_new_key ;;
- debug-on) enable_debug ;;
- debug-off) disable_debug ;;
- *) usage "$_usage"; exit 42;;
- esac ;;
- doc) rst-doc ;;
- *) usage "ERROR: unknown or missing command $1"; exit 42;;
- esac
- }
- install_all() {
- MORTY_KEY="$(head -c 32 /dev/urandom | base64)"
- rst_title "Install $SERVICE_NAME (service)"
- assert_user
- wait_key
- install_go "${GO_PKG_URL}" "${GO_TAR}" "${SERVICE_USER}"
- wait_key
- install_morty
- wait_key
- systemd_install_service "${SERVICE_NAME}" "${SERVICE_SYSTEMD_UNIT}"
- wait_key
- if ! service_is_available "http://${MORTY_LISTEN}" ; then
- err_msg "Morty does not listening on: http://${MORTY_LISTEN}"
- fi
- if apache_is_installed; then
- info_msg "Apache is installed on this host."
- if ask_yn "Do you want to install a reverse proxy (ProxyPass)" Yn; then
- install_apache_site
- fi
- elif nginx_is_installed; then
- info_msg "nginx is installed on this host."
- if ask_yn "Do you want to install a reverse proxy (ProxyPass)" Yn; then
- install_nginx_site
- fi
- fi
- info_searx
- if ask_yn "Add image and result proxy to searx settings.yml?" Yn; then
- "${REPO_ROOT}/utils/searx.sh" option result-proxy "${PUBLIC_URL_MORTY}" "${MORTY_KEY}"
- "${REPO_ROOT}/utils/searx.sh" option image-proxy-on
- fi
- if ask_yn "Do you want to inspect the installation?" Ny; then
- inspect_service
- fi
- }
- remove_all() {
- rst_title "De-Install $SERVICE_NAME (service)"
- rst_para "\
- It goes without saying that this script can only be used to remove
- installations that were installed with this script."
- if systemd_remove_service "${SERVICE_NAME}" "${SERVICE_SYSTEMD_UNIT}"; then
- drop_service_account "${SERVICE_USER}"
- fi
- }
- assert_user() {
- rst_title "user $SERVICE_USER" section
- echo
- tee_stderr 1 <<EOF | bash | prefix_stdout
- useradd --shell /bin/bash --system \
- --home-dir "$SERVICE_HOME" \
- --comment 'Web content sanitizer proxy' $SERVICE_USER
- mkdir "$SERVICE_HOME"
- chown -R "$SERVICE_GROUP:$SERVICE_GROUP" "$SERVICE_HOME"
- groups $SERVICE_USER
- EOF
- SERVICE_HOME="$(sudo -i -u "$SERVICE_USER" echo \$HOME)"
- export SERVICE_HOME
- echo "export SERVICE_HOME=$SERVICE_HOME"
- cat > "$GO_ENV" <<EOF
- export GOPATH=\$HOME/go-apps
- export PATH=\$PATH:\$HOME/local/go/bin:\$GOPATH/bin
- EOF
- echo "Environment $GO_ENV has been setup."
- tee_stderr <<EOF | sudo -i -u "$SERVICE_USER"
- grep -qFs -- 'source $GO_ENV' ~/.profile || echo 'source $GO_ENV' >> ~/.profile
- EOF
- }
- morty_is_installed() {
- [[ -f $SERVICE_HOME/go-apps/bin/morty ]]
- }
- _svcpr=" ${_Yellow}|${SERVICE_USER}|${_creset} "
- install_morty() {
- rst_title "Install morty in user's ~/go-apps" section
- echo
- tee_stderr <<EOF | sudo -i -u "$SERVICE_USER" 2>&1 | prefix_stdout "$_svcpr"
- go get -v -u github.com/asciimoo/morty
- EOF
- tee_stderr <<EOF | sudo -i -u "$SERVICE_USER" 2>&1 | prefix_stdout "$_svcpr"
- cd \$GOPATH/src/github.com/asciimoo/morty
- go test
- go test -benchmem -bench .
- EOF
- }
- update_morty() {
- rst_title "Update morty" section
- echo
- tee_stderr <<EOF | sudo -i -u "$SERVICE_USER" 2>&1 | prefix_stdout "$_svcpr"
- go get -v -u github.com/asciimoo/morty
- EOF
- tee_stderr <<EOF | sudo -i -u "$SERVICE_USER" 2>&1 | prefix_stdout "$_svcpr"
- cd \$GOPATH/src/github.com/asciimoo/morty
- go test
- go test -benchmem -bench .
- EOF
- }
- set_service_env_debug() {
- # usage: set_service_env_debug [false|true]
- # shellcheck disable=SC2034
- local SERVICE_ENV_DEBUG="${1:-false}"
- if systemd_remove_service "${SERVICE_NAME}" "${SERVICE_SYSTEMD_UNIT}"; then
- systemd_install_service "${SERVICE_NAME}" "${SERVICE_SYSTEMD_UNIT}"
- fi
- }
- inspect_service() {
- rst_title "service status & log"
- cat <<EOF
- sourced ${DOT_CONFIG#"$REPO_ROOT/"} :
- MORTY_LISTEN : ${MORTY_LISTEN}
- EOF
- if service_account_is_available "$SERVICE_USER"; then
- info_msg "service account $SERVICE_USER available."
- else
- err_msg "service account $SERVICE_USER not available!"
- fi
- if go_is_available "$SERVICE_USER"; then
- info_msg "~$SERVICE_USER: go is installed"
- else
- err_msg "~$SERVICE_USER: go is not installed"
- fi
- if morty_is_installed; then
- info_msg "~$SERVICE_USER: morty app is installed"
- else
- err_msg "~$SERVICE_USER: morty app is not installed!"
- fi
- if ! service_is_available "http://${MORTY_LISTEN}" ; then
- err_msg "Morty does not listening on: http://${MORTY_LISTEN}"
- echo -e "${_Green}stop with [${_BCyan}CTRL-C${_Green}] or .."
- wait_key
- fi
- if ! service_is_available "${PUBLIC_URL_MORTY}"; then
- warn_msg "Public service at ${PUBLIC_URL_MORTY} is not available!"
- if ! in_container; then
- warn_msg "Check if public name is correct and routed or use the public IP from above."
- fi
- fi
- if in_container; then
- lxc_suite_info
- else
- info_msg "public URL --> ${PUBLIC_URL_MORTY}"
- info_msg "morty URL --> http://${MORTY_LISTEN}"
- fi
- local _debug_on
- if ask_yn "Enable morty debug mode (needs reinstall of systemd service)?"; then
- enable_debug
- _debug_on=1
- else
- systemctl --no-pager -l status "${SERVICE_NAME}"
- fi
- echo
- # shellcheck disable=SC2059
- printf "// use ${_BCyan}CTRL-C${_creset} to stop monitoring the log"
- read -r -s -n1 -t 5
- echo
- while true; do
- trap break 2
- journalctl -f -u "${SERVICE_NAME}"
- done
- if [[ $_debug_on == 1 ]]; then
- FORCE_SELECTION=Y disable_debug
- fi
- return 0
- }
- enable_debug() {
- warn_msg "Do not enable debug in production enviroments!!"
- info_msg "Enabling debug option needs to reinstall systemd service!"
- set_service_env_debug true
- }
- disable_debug() {
- info_msg "Disabling debug option needs to reinstall systemd service!"
- set_service_env_debug false
- }
- set_new_key() {
- rst_title "Set morty key"
- echo
- MORTY_KEY="$(head -c 32 /dev/urandom | base64)"
- info_msg "morty key: '${MORTY_KEY}'"
- warn_msg "this will need to reinstall services .."
- MSG="${_Green}press any [${_BCyan}KEY${_Green}] to continue // stop with [${_BCyan}CTRL-C${_creset}]" wait_key
- systemd_install_service "${SERVICE_NAME}" "${SERVICE_SYSTEMD_UNIT}"
- "${REPO_ROOT}/utils/searx.sh" option result-proxy "${PUBLIC_URL_MORTY}" "${MORTY_KEY}"
- "${REPO_ROOT}/utils/searx.sh" option image-proxy-on
- }
- install_apache_site() {
- rst_title "Install Apache site $APACHE_MORTY_SITE"
- rst_para "\
- This installs a reverse proxy (ProxyPass) into apache site (${APACHE_MORTY_SITE})"
- ! apache_is_installed && err_msg "Apache is not installed."
- if ! ask_yn "Do you really want to continue?" Yn; then
- return
- else
- install_apache
- fi
- apache_install_site "${APACHE_MORTY_SITE}"
- info_msg "testing public url .."
- if ! service_is_available "${PUBLIC_URL_MORTY}"; then
- err_msg "Public service at ${PUBLIC_URL_MORTY} is not available!"
- fi
- }
- remove_apache_site() {
- rst_title "Remove Apache site $APACHE_MORTY_SITE"
- rst_para "\
- This removes apache site ${APACHE_MORTY_SITE}."
- ! apache_is_installed && err_msg "Apache is not installed."
- if ! ask_yn "Do you really want to continue?" Yn; then
- return
- fi
- apache_remove_site "$APACHE_MORTY_SITE"
- }
- install_nginx_site() {
- rst_title "Install nginx site $NGINX_MORTY_SITE"
- rst_para "\
- This installs a reverse proxy (ProxyPass) into nginx site (${NGINX_MORTY_SITE})"
- ! nginx_is_installed && err_msg "nginx is not installed."
- if ! ask_yn "Do you really want to continue?" Yn; then
- return
- else
- install_nginx
- fi
- "${REPO_ROOT}/utils/searx.sh" install uwsgi
- # shellcheck disable=SC2034
- SEARX_SRC=$("${REPO_ROOT}/utils/searx.sh" --getenv SEARX_SRC)
- # shellcheck disable=SC2034
- SEARX_URL_PATH=$("${REPO_ROOT}/utils/searx.sh" --getenv SEARX_URL_PATH)
- nginx_install_app "${NGINX_MORTY_SITE}"
- info_msg "testing public url .."
- if ! service_is_available "${PUBLIC_URL_MORTY}"; then
- err_msg "Public service at ${PUBLIC_URL_MORTY} is not available!"
- fi
- }
- remove_nginx_site() {
- rst_title "Remove nginx site $NGINX_MORTY_SITE"
- rst_para "\
- This removes nginx site ${NGINX_MORTY_SITE}."
- ! nginx_is_installed && err_msg "nginx is not installed."
- if ! ask_yn "Do you really want to continue?" Yn; then
- return
- fi
- nginx_remove_site "$NGINX_MORTY_SITE"
- }
- rst-doc() {
- eval "echo \"$(< "${REPO_ROOT}/docs/build-templates/morty.rst")\""
- echo -e "\n.. START install systemd unit"
- cat <<EOF
- .. tabs::
- .. group-tab:: systemd
- .. code:: bash
- EOF
- eval "echo \"$(< "${TEMPLATES}/${SERVICE_SYSTEMD_UNIT}")\"" | prefix_stdout " "
- echo -e "\n.. END install systemd unit"
- # for DIST_NAME in ubuntu-20.04 arch fedora centos; do
- # (
- # DIST_ID=${DIST_NAME%-*}
- # DIST_VERS=${DIST_NAME#*-}
- # [[ $DIST_VERS =~ $DIST_ID ]] && DIST_VERS=
- # # ...
- # )
- # done
- }
- # ----------------------------------------------------------------------------
- main "$@"
- # ----------------------------------------------------------------------------
|