[mod] docker-entrypoint.sh - add script to make test.sh (shellcheck)

Add script docker-entrypoint.sh to shellcheck and try to _simplify_ and
_normalize_ some parts:

- fix issues reported by shellcheck
- don't mix tab and space indent
- command 'help' replaced by '-h': ./dockerfiles/docker-entrypoint.sh -h
- replace printf in help() by 'cat <<EOF'

Signed-off-by: Markus Heiser <markus.heiser@darmarit.de>
This commit is contained in:
Markus Heiser 2021-05-10 11:26:56 +02:00
parent 1970d28a60
commit d6c321b830
3 changed files with 76 additions and 70 deletions

View file

@ -54,6 +54,8 @@ PHONY += test ci.test test.shell
ci.test: test.pep8 test.pylint test.unit test.robot ci.test: test.pep8 test.pylint test.unit test.robot
test: test.pep8 test.pylint test.unit test.robot test.shell test: test.pep8 test.pylint test.unit test.robot test.shell
test.shell: test.shell:
$(Q)shellcheck -x -s dash \
dockerfiles/docker-entrypoint.sh
$(Q)shellcheck -x -s bash \ $(Q)shellcheck -x -s bash \
utils/brand.env \ utils/brand.env \
./manage \ ./manage \

View file

@ -1,62 +1,66 @@
#!/bin/sh #!/bin/sh
help() { help() {
printf "Command line:\n\n" cat <<EOF
printf " -h Display this help\n" Command line:
printf " -d Dry run to update the configuration files.\n" -h Display this help
printf " -f Always update on the configuration files (existing files are renamed with the .old suffix)\n" -d Dry run to update the configuration files.
printf " Without this option, the new configuration files are copied with the .new suffix\n" -f Always update on the configuration files (existing files are renamed with
printf "\nEnvironment variables:\n\n" the .old suffix). Without this option, the new configuration files are
printf " INSTANCE_NAME settings.yml : general.instance_name\n" copied with the .new suffix
printf " AUTOCOMPLETE settings.yml : search.autocomplete\n" Environment variables:
printf " BASE_URL settings.yml : server.base_url\n" INSTANCE_NAME settings.yml : general.instance_name
printf " MORTY_URL settings.yml : result_proxy.url\n" AUTOCOMPLETE settings.yml : search.autocomplete
printf " MORTY_KEY settings.yml : result_proxy.key\n" BASE_URL settings.yml : server.base_url
printf " BIND_ADDRESS uwsgi bind to the specified TCP socket using HTTP protocol. Default value: \"${DEFAULT_BIND_ADDRESS}\"\n" MORTY_URL settings.yml : result_proxy.url
printf "\nVolume:\n\n" MORTY_KEY settings.yml : result_proxy.key
printf " /etc/searx the docker entry point copies settings.yml and uwsgi.ini in this directory (see the -f command line option)\n" BIND_ADDRESS uwsgi bind to the specified TCP socket using HTTP protocol.
echo Default value: ${DEFAULT_BIND_ADDRESS}
exit 0 Volume:
/etc/searx the docker entry point copies settings.yml and uwsgi.ini in
this directory (see the -f command line option)"
EOF
} }
export DEFAULT_BIND_ADDRESS="0.0.0.0:8080" export DEFAULT_BIND_ADDRESS="0.0.0.0:8080"
if [ -z "${BIND_ADDRESS}" ]; then export BIND_ADDRESS="${BIND_ADDRESS:-${DEFAULT_BIND_ADDRESS}}"
export BIND_ADDRESS="${DEFAULT_BIND_ADDRESS}"
fi
# Parse special command line
# see docs/admin/installation-docker.rst
# display the help message without the version
if [ "$1" = "help" ]; then
help
fi
# Version
export SEARX_VERSION=$(su searx -c 'python3 -c "import six; import searx.version; six.print_(searx.version.VERSION_STRING)"' 2>/dev/null)
printf 'searx version %s\n\n' "${SEARX_VERSION}"
# Parse command line # Parse command line
FORCE_CONF_UPDATE=0 FORCE_CONF_UPDATE=0
DRY_RUN=0 DRY_RUN=0
while getopts "fdh" option while getopts "fdh" option
do do
case $option in case $option in
f)
FORCE_CONF_UPDATE=1 f) FORCE_CONF_UPDATE=1 ;;
;; d) DRY_RUN=1 ;;
d)
DRY_RUN=1 h)
;; help
h) exit 0
help ;;
*)
echo "unknow option ${option}"
exit 42
;;
esac esac
done done
get_searx_version(){
su searx -c \
'python3 -c "import six; import searx.version; six.print_(searx.version.VERSION_STRING)"' \
2>/dev/null
}
SEARX_VERSION="$(get_searx_version)"
export SEARX_VERSION
echo "searx version ${SEARX_VERSION}"
# helpers to update the configuration files # helpers to update the configuration files
patch_uwsgi_settings() { patch_uwsgi_settings() {
CONF="$1" CONF="$1"
# Nothing
} }
patch_searx_settings() { patch_searx_settings() {
@ -74,10 +78,11 @@ patch_searx_settings() {
"${CONF}" "${CONF}"
# Morty configuration # Morty configuration
if [ ! -z "${MORTY_KEY}" -a ! -z "${MORTY_URL}" ]; then
sed -i -e "s/image_proxy : False/image_proxy : True/g" \ if [ -n "${MORTY_KEY}" ] && [ -n "${MORTY_URL}" ]; then
"${CONF}" sed -i -e "s/image_proxy : False/image_proxy : True/g" \
cat >> "${CONF}" <<-EOF "${CONF}"
cat >> "${CONF}" <<-EOF
# Morty configuration # Morty configuration
result_proxy: result_proxy:
@ -96,35 +101,35 @@ update_conf() {
PATCH_REF_CONF="$4" PATCH_REF_CONF="$4"
if [ -f "${CONF}" ]; then if [ -f "${CONF}" ]; then
if [ "${REF_CONF}" -nt "${CONF}" ]; then if [ "${REF_CONF}" -nt "${CONF}" ]; then
# There is a new version # There is a new version
if [ $FORCE_CONF_UPDATE -ne 0 ]; then if [ "$FORCE_CONF_UPDATE" -ne 0 ]; then
# Replace the current configuration # Replace the current configuration
printf '⚠️ Automaticaly update %s to the new version\n' "${CONF}" printf '⚠️ Automaticaly update %s to the new version\n' "${CONF}"
if [ ! -f "${OLD_CONF}" ]; then if [ ! -f "${OLD_CONF}" ]; then
printf 'The previous configuration is saved to %s\n' "${OLD_CONF}" printf 'The previous configuration is saved to %s\n' "${OLD_CONF}"
mv "${CONF}" "${OLD_CONF}" mv "${CONF}" "${OLD_CONF}"
fi fi
cp "${REF_CONF}" "${CONF}" cp "${REF_CONF}" "${CONF}"
$PATCH_REF_CONF "${CONF}" $PATCH_REF_CONF "${CONF}"
else else
# Keep the current configuration # Keep the current configuration
printf '⚠️ Check new version %s to make sure searx is working properly\n' "${NEW_CONF}" printf '⚠️ Check new version %s to make sure searx is working properly\n' "${NEW_CONF}"
cp "${REF_CONF}" "${NEW_CONF}" cp "${REF_CONF}" "${NEW_CONF}"
$PATCH_REF_CONF "${NEW_CONF}" $PATCH_REF_CONF "${NEW_CONF}"
fi fi
else else
printf 'Use existing %s\n' "${CONF}" printf 'Use existing %s\n' "${CONF}"
fi fi
else else
printf 'Create %s\n' "${CONF}" printf 'Create %s\n' "${CONF}"
cp "${REF_CONF}" "${CONF}" cp "${REF_CONF}" "${CONF}"
$PATCH_REF_CONF "${CONF}" $PATCH_REF_CONF "${CONF}"
fi fi
} }
# make sure there are uwsgi settings # make sure there are uwsgi settings
update_conf ${FORCE_CONF_UPDATE} "${UWSGI_SETTINGS_PATH}" "/usr/local/searx/dockerfiles/uwsgi.ini" "patch_uwsgi_settings" update_conf "${FORCE_CONF_UPDATE}" "${UWSGI_SETTINGS_PATH}" "/usr/local/searx/dockerfiles/uwsgi.ini" "patch_uwsgi_settings"
# make sure there are searx settings # make sure there are searx settings
update_conf "${FORCE_CONF_UPDATE}" "${SEARX_SETTINGS_PATH}" "/usr/local/searx/searx/settings.yml" "patch_searx_settings" update_conf "${FORCE_CONF_UPDATE}" "${SEARX_SETTINGS_PATH}" "/usr/local/searx/searx/settings.yml" "patch_searx_settings"
@ -135,7 +140,6 @@ if [ $DRY_RUN -eq 1 ]; then
exit exit
fi fi
#
touch /var/run/uwsgi-logrotate touch /var/run/uwsgi-logrotate
chown -R searx:searx /var/log/uwsgi /var/run/uwsgi-logrotate chown -R searx:searx /var/log/uwsgi /var/run/uwsgi-logrotate
unset MORTY_KEY unset MORTY_KEY

View file

@ -39,7 +39,7 @@ Command line
docker run --rm -it searxng/searxng -h docker run --rm -it searxng/searxng -h
.. program-output:: ../dockerfiles/docker-entrypoint.sh help .. program-output:: ../dockerfiles/docker-entrypoint.sh -h
Build the image Build the image