From 36ee1f33bceb0c2a7899e28d75c0d05408b561f1 Mon Sep 17 00:00:00 2001 From: Michal Vasko Date: Mon, 24 Aug 2020 13:47:40 +0200 Subject: [PATCH] scripts FEATURE support using current user for SR modules Mostly for special cases user/group configuration when the user/group cannot be retrieved normally. Fixes #701 Signed-off-by: Heiko Thiery [patch taken from upstream: https://github.com/CESNET/netopeer2/commit/12a82701e10651fbdedb1524b27edf3bb2377488] Signed-off-by: Heiko Thiery --- CMakeLists.txt | 10 +++++----- scripts/setup.sh | 23 +++++++++++++++++++---- 2 files changed, 24 insertions(+), 9 deletions(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index 2d4175e..95e7e61 100755 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -68,19 +68,19 @@ if(NOT MODULES_OWNER) OUTPUT_VARIABLE MODULES_OWNER OUTPUT_STRIP_TRAILING_WHITESPACE ERROR_VARIABLE ERROR_STR OUTPUT_STRIP_TRAILING_WHITESPACE) if(RET) - message(FATAL_ERROR "Learning server module user failed: ${ERROR_STR}") + message(WARNING "Learning server module user failed (${ERROR_STR}), the current user will be used.") endif() endif() -set(MODULES_OWNER "${MODULES_OWNER}" CACHE STRING "System user that will become the owner of server modules") -if(NOT MODULES_GROUP) +set(MODULES_OWNER "${MODULES_OWNER}" CACHE STRING "System user that will become the owner of server modules, empty means the current user") +if(NOT MODULES_GROUP AND MODULES_OWNER) execute_process(COMMAND id -gn ${MODULES_OWNER} RESULT_VARIABLE RET OUTPUT_VARIABLE MODULES_GROUP OUTPUT_STRIP_TRAILING_WHITESPACE ERROR_VARIABLE ERROR_STR OUTPUT_STRIP_TRAILING_WHITESPACE) if(RET) - message(FATAL_ERROR "Learning server module group failed: ${ERROR_STR}") + message(WARNING "Learning server module group failed (${ERROR_STR}), the current user group will be used.") endif() endif() -set(MODULES_GROUP "${MODULES_GROUP}" CACHE STRING "System group that the server modules will belong to") +set(MODULES_GROUP "${MODULES_GROUP}" CACHE STRING "System group that the server modules will belong to, empty means the current user group") # set prefix for the PID file if(NOT PIDFILE_PREFIX) diff --git a/scripts/setup.sh b/scripts/setup.sh index 7175bc4..b5d1406 100755 --- a/scripts/setup.sh +++ b/scripts/setup.sh @@ -1,7 +1,8 @@ #!/bin/bash -# env variables NP2_MODULE_DIR, NP2_MODULE_PERMS, NP2_MODULE_OWNER, NP2_MODULE_GROUP must be defined when executing this script! -if [ -z "$NP2_MODULE_DIR" -o -z "$NP2_MODULE_PERMS" -o -z "$NP2_MODULE_OWNER" -o -z "$NP2_MODULE_GROUP" ]; then +# env variables NP2_MODULE_DIR, NP2_MODULE_PERMS must be defined and NP2_MODULE_OWNER, NP2_MODULE_GROUP will be used if +# defined when executing this script! +if [ -z "$NP2_MODULE_DIR" -o -z "$NP2_MODULE_PERMS" ]; then echo "Required environment variables not defined!" exit 1 fi @@ -33,7 +34,14 @@ MODULES=( # functions INSTALL_MODULE() { - $SYSREPOCTL -a -i $MODDIR/$1 -s $MODDIR -p $PERMS -o $OWNER -g $GROUP -v2 + CMD="'$SYSREPOCTL' -a -i $MODDIR/$1 -s '$MODDIR' -p '$PERMS' -v2" + if [ ! -z ${OWNER} ]; then + CMD="$CMD -o '$OWNER'" + fi + if [ ! -z ${GROUP} ]; then + CMD="$CMD -g '$GROUP'" + fi + eval $CMD local rc=$? if [ $rc -ne 0 ]; then exit $rc @@ -41,7 +49,14 @@ INSTALL_MODULE() { } UPDATE_MODULE() { - $SYSREPOCTL -a -U $MODDIR/$1 -s $MODDIR -p $PERMS -o $OWNER -g $GROUP -v2 + CMD="'$SYSREPOCTL' -a -U $MODDIR/$1 -s '$MODDIR' -p '$PERMS' -v2" + if [ ! -z ${OWNER} ]; then + CMD="$CMD -o '$OWNER'" + fi + if [ ! -z ${GROUP} ]; then + CMD="$CMD -g '$GROUP'" + fi + eval $CMD local rc=$? if [ $rc -ne 0 ]; then exit $rc -- 2.20.1