Skip to content
Snippets Groups Projects
Select Git revision
  • ea618c4858a94edeea075dfcb950e2df9ebca3f7
  • main default protected
  • f-sss4grpc
  • dev
  • 108-implement-rpc-call-for-server-side-scripting
  • f-windows-conan-create
  • f-to-string
  • f-update-requirements
  • f-related-projects
  • f-role
  • f-remote-path
  • f-rel-path
  • f-consol-message
  • v0.3.0
  • v0.2.2
  • v0.2.1
  • v0.2.0
  • v0.1.2
  • v0.1.1
  • v0.1
  • v0.0.19
  • v0.0.18
  • v0.0.16
  • v0.0.15
  • v0.0.10
  • v0.0.9
  • v0.0.8
  • v0.0.7
  • v0.0.6
  • v0.0.5
  • v0.0.4
  • v0.0.3
  • v0.0.2
33 results

info.h

Blame
  • Code owners
    Assign users and groups as approvers for specific file changes. Learn more.
    helpers.sh 2.86 KiB
    # This file is a part of the CaosDB Project.
    #
    # Copyright (C) 2018 Research Group Biomedical Physics,
    # Max-Planck-Institute for Dynamics and Self-Organization Göttingen
    # Copyright 2019, 2020 Daniel Hornung
    # Copyright 2020 Henrik tom Wörden, IndiScale GmbH
    #
    # This program is free software: you can redistribute it and/or modify
    # it under the terms of the GNU Affero General Public License as
    # published by the Free Software Foundation, either version 3 of the
    # License, or (at your option) any later version.
    #
    # This program is distributed in the hope that it will be useful,
    # but WITHOUT ANY WARRANTY; without even the implied warranty of
    # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    # GNU Affero General Public License for more details.
    #
    # You should have received a copy of the GNU Affero General Public License
    # along with this program. If not, see <https://www.gnu.org/licenses/>.
    
    
    
    ###############################################################################
    #                         Helper function definitions                         #
    ###############################################################################
    
    # When sourcing this file, the following variables must be set:
    #
    # MYSQL_CMD : source $UTILSPATH/load_settings.sh
    
    
    
    function mysql_execute {
    	  #TODO is it meaningful that here always the database user is used???
    	  set +e
        env
    	  $MYSQL_CMD $(get_db_args) -e "$1"
    	  ret=${PIPESTATUS[0]}
    	  if [ "$ret" -ne 0 ]; then
    		    failure "MYSQL ERROR"
    	  fi
    	  set -e
    }
    
    function get_mysql_args {
    	echo "$(get_mysql_args_nodb) --database=$DATABASE_NAME"
    }
    
    function get_db_args {
    	echo "$(get_db_args_nodb) --database=$DATABASE_NAME"
    }
    
    function get_db_args_nodb {
    	if [ "$DATABASE_USER" ]; then
    		mysql_con_arguments="--user=$DATABASE_USER"
    	fi
    	if [ "$DATABASE_USER_PW" ]; then
    		mysql_con_arguments="$mysql_con_arguments --password=$DATABASE_USER_PW"
    	fi
    	if [[ "$MYSQL_HOST" && ( "$MYSQL_HOST" != "localhost" ) ]]; then
    		mysql_con_arguments="$mysql_con_arguments --host=$MYSQL_HOST"
    		if [ "$MYSQL_PORT" ]; then
    			mysql_con_arguments="$mysql_con_arguments --port=$MYSQL_PORT"
    		fi
    	fi
    	echo $mysql_con_arguments
    }
    
    function get_mysql_args_nodb {
    	if [ "$LOGIN_PATH" ]; then
    		mysql_con_arguments="--login-path=$LOGIN_PATH"
    	else
    		if [ "$MYSQL_USER" ]; then
    			mysql_con_arguments="--user=$MYSQL_USER"
    		fi
    		if [ "$MYSQL_USER_PASSWORD" ]; then
    			mysql_con_arguments="$mysql_con_arguments --password=$MYSQL_USER_PASSWORD"
    		fi
    		if [[ "$MYSQL_HOST" && ( "$MYSQL_HOST" != "localhost" ) ]]; then
    			mysql_con_arguments="$mysql_con_arguments --host=$MYSQL_HOST"
    			if [ "$MYSQL_PORT" ]; then
    				mysql_con_arguments="$mysql_con_arguments --port=$MYSQL_PORT"
    			fi
    		fi
    	fi
    	echo $mysql_con_arguments
    }
    
    function success {
        echo "[OK]"
        exit 0
    }
    
    function failure {
        echo "[FAILED] $*"
        exit 1
    }
    
    function uptodate {
        echo "[UPTODATE]"
        exit 0
    }