mirror of
				https://github.com/librenms/librenms.git
				synced 2024-10-07 16:52:45 +00:00 
			
		
		
		
	Revert "Refactored and added support for $config['log_dir']" (#4911)
This commit is contained in:
		
							
								
								
									
										170
									
								
								daily.sh
									
									
									
									
									
								
							
							
						
						
									
										170
									
								
								daily.sh
									
									
									
									
									
								
							@@ -1,5 +1,4 @@
 | 
			
		||||
#!/usr/bin/env bash
 | 
			
		||||
################################################################################
 | 
			
		||||
# Copyright (C) 2015 Daniel Preussker, QuxLabs UG <preussker@quxlabs.com>
 | 
			
		||||
# This program is free software: you can redistribute it and/or modify
 | 
			
		||||
# it under the terms of the GNU General Public License as published by
 | 
			
		||||
@@ -13,143 +12,55 @@
 | 
			
		||||
#
 | 
			
		||||
# You should have received a copy of the GNU General Public License
 | 
			
		||||
# along with this program.  If not, see <http://www.gnu.org/licenses/>.
 | 
			
		||||
################################################################################
 | 
			
		||||
 | 
			
		||||
#######################################
 | 
			
		||||
# CONSTANTS
 | 
			
		||||
#######################################
 | 
			
		||||
DIR_LIBRENMS=$(dirname "$0");
 | 
			
		||||
LOG_DIR=$(php -r "include '${DIR_LIBRENMS}/config.php'; isset(\$config['log_dir']) ? print \$config['log_dir'] : print \$config['install_dir'] . '/logs';");
 | 
			
		||||
cd "$(dirname "$0")"
 | 
			
		||||
arg="$1"
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
#######################################
 | 
			
		||||
# Fancy-Print and run commands
 | 
			
		||||
# Globals:
 | 
			
		||||
#   LOG_DIR
 | 
			
		||||
# Arguments:
 | 
			
		||||
#   Text
 | 
			
		||||
#   Command
 | 
			
		||||
# Returns:
 | 
			
		||||
#   Exit-Code of Command
 | 
			
		||||
#######################################
 | 
			
		||||
# @arg    Text
 | 
			
		||||
# @arg    Command
 | 
			
		||||
# @return Exit-Code of Command
 | 
			
		||||
status_run() {
 | 
			
		||||
    # Explicitly define our arguments
 | 
			
		||||
    local arg_text=$1;
 | 
			
		||||
    local arg_command=$2;
 | 
			
		||||
    local log_file;
 | 
			
		||||
    local exit_code;
 | 
			
		||||
    local tmp;
 | 
			
		||||
    local log_file=${LOG_DIR}/daily.log;
 | 
			
		||||
 | 
			
		||||
    # set log_file, using librenms $config['log_dir'], if set
 | 
			
		||||
    # otherwise we default to ./logs/daily.log
 | 
			
		||||
 | 
			
		||||
    printf "%-50s" "${arg_text}";
 | 
			
		||||
    echo "${arg_text}" >> ${log_file}
 | 
			
		||||
    tmp=$(bash -c "${arg_command}" 2>&1);
 | 
			
		||||
    exit_code=$?
 | 
			
		||||
    echo "${tmp}" >> ${log_file}
 | 
			
		||||
    echo "Returned: ${exit_code}" >> ${log_file}
 | 
			
		||||
 | 
			
		||||
    # print OK if the command ran succesfully
 | 
			
		||||
    # or FAIL otherwise (non-zero exit code)
 | 
			
		||||
    if [[ ${exit_code} -eq 0 ]]; then
 | 
			
		||||
        printf " \033[0;32mOK\033[0m\n";
 | 
			
		||||
    else
 | 
			
		||||
        printf " \033[0;31mFAIL\033[0m\n";
 | 
			
		||||
    fi
 | 
			
		||||
    return ${exit_code}
 | 
			
		||||
    printf "%-50s" "$1"
 | 
			
		||||
    echo "$1" >> logs/daily.log
 | 
			
		||||
    tmp=$(bash -c "$2" 2>&1)
 | 
			
		||||
    ex=$?
 | 
			
		||||
    echo "$tmp" >> logs/daily.log
 | 
			
		||||
    echo "Returned: $ex" >> logs/daily.log
 | 
			
		||||
    [ $ex -eq 0 ] && echo -e ' \033[0;32mOK\033[0m' || echo -e ' \033[0;31mFAIL\033[0m'
 | 
			
		||||
    return $ex
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
#######################################
 | 
			
		||||
# Entry into program
 | 
			
		||||
# Globals:
 | 
			
		||||
#   DIR_LIBRENMS
 | 
			
		||||
# Arguments:
 | 
			
		||||
#   
 | 
			
		||||
# Returns:
 | 
			
		||||
#   Exit-Code of Command
 | 
			
		||||
#######################################
 | 
			
		||||
main () {
 | 
			
		||||
    arg="$1";
 | 
			
		||||
    cd ${DIR_LIBRENMS};
 | 
			
		||||
 | 
			
		||||
    if [ -z "$arg" ]; then
 | 
			
		||||
        up=$(php daily.php -f update >&2; echo $?)
 | 
			
		||||
        if [ "$up" -eq 0 ]; then
 | 
			
		||||
            $0 no-code-update
 | 
			
		||||
            exit
 | 
			
		||||
        elif [ "$up" -eq 1 ]; then
 | 
			
		||||
            # Update to Master-Branch
 | 
			
		||||
            old_ver=$(git show --pretty="%H" -s HEAD)
 | 
			
		||||
            status_run 'Updating to latest codebase' 'git pull --quiet' ''
 | 
			
		||||
            new_ver=$(git show --pretty="%H" -s HEAD)
 | 
			
		||||
            if [ "$old_ver" != "$new_ver" ]; then
 | 
			
		||||
                status_run "Updated from $old_ver to $new_ver" ''
 | 
			
		||||
            fi
 | 
			
		||||
        elif [ "$up" -eq 3 ]; then
 | 
			
		||||
            # Update to last Tag
 | 
			
		||||
            old_ver=$(git describe --exact-match --tags $(git log -n1 --pretty='%h'))
 | 
			
		||||
            status_run 'Updating to latest release' 'git fetch --tags && git checkout $(git describe --tags $(git rev-list --tags --max-count=1))'
 | 
			
		||||
            new_ver=$(git describe --exact-match --tags $(git log -n1 --pretty='%h'))
 | 
			
		||||
            if [ "$old_ver" -ne "$new_ver" ]; then
 | 
			
		||||
                status_run "Updated from $old_ver to $new_ver" ''
 | 
			
		||||
            fi
 | 
			
		||||
if [ -z "$arg" ]; then
 | 
			
		||||
    up=$(php daily.php -f update >&2; echo $?)
 | 
			
		||||
    if [ "$up" -eq 0 ]; then
 | 
			
		||||
        $0 no-code-update
 | 
			
		||||
        exit
 | 
			
		||||
    elif [ "$up" -eq 1 ]; then
 | 
			
		||||
        # Update to Master-Branch
 | 
			
		||||
        old_ver=$(git show --pretty="%H" -s HEAD)
 | 
			
		||||
        status_run 'Updating to latest codebase' 'git pull --quiet'
 | 
			
		||||
        new_ver=$(git show --pretty="%H" -s HEAD)
 | 
			
		||||
        if [ "$old_ver" != "$new_ver" ]; then
 | 
			
		||||
            status_run "Updated from $old_ver to $new_ver" ''
 | 
			
		||||
        fi
 | 
			
		||||
 | 
			
		||||
        cnf=$(echo $(grep '\[.distributed_poller.\]' config.php | egrep -v -e '^//' -e '^#' | cut -d = -f 2 | sed 's/;//g'))
 | 
			
		||||
        if ((${BASH_VERSINFO[0]} < 4)); then
 | 
			
		||||
            cnf=`echo $cnf|tr [:upper:] [:lower:]`
 | 
			
		||||
        else
 | 
			
		||||
            cnf=${cnf,,}
 | 
			
		||||
    elif [ "$up" -eq 3 ]; then
 | 
			
		||||
        # Update to last Tag
 | 
			
		||||
        old_ver=$(git describe --exact-match --tags $(git log -n1 --pretty='%h'))
 | 
			
		||||
        status_run 'Updating to latest release' 'git fetch --tags && git checkout $(git describe --tags $(git rev-list --tags --max-count=1))'
 | 
			
		||||
        new_ver=$(git describe --exact-match --tags $(git log -n1 --pretty='%h'))
 | 
			
		||||
        if [ "$old_ver" -ne "$new_ver" ]; then
 | 
			
		||||
            status_run "Updated from $old_ver to $new_ver" ''
 | 
			
		||||
        fi
 | 
			
		||||
 | 
			
		||||
        if [ -z "$cnf" ] || [ "$cnf" == "0" ] || [ "$cnf" == "false" ]; then
 | 
			
		||||
            # Call ourself again in case above pull changed or added something to daily.sh
 | 
			
		||||
            $0 post-pull
 | 
			
		||||
        fi
 | 
			
		||||
    else
 | 
			
		||||
        case $arg in
 | 
			
		||||
            no-code-update)
 | 
			
		||||
                # Updates of the code are disabled, just check for schema updates
 | 
			
		||||
                # and clean up the db.
 | 
			
		||||
                status_run 'Updating SQL-Schema' 'php includes/sql-schema/update.php'
 | 
			
		||||
                status_run 'Cleaning up DB' "$0 cleanup"
 | 
			
		||||
            ;;
 | 
			
		||||
            post-pull)
 | 
			
		||||
                # List all tasks to do after pull in the order of execution
 | 
			
		||||
                status_run 'Updating SQL-Schema' 'php includes/sql-schema/update.php'
 | 
			
		||||
                status_run 'Updating submodules' "$0 submodules"
 | 
			
		||||
                status_run 'Cleaning up DB' "$0 cleanup"
 | 
			
		||||
                status_run 'Fetching notifications' "$0 notifications"
 | 
			
		||||
            ;;
 | 
			
		||||
            cleanup)
 | 
			
		||||
                # Cleanups
 | 
			
		||||
                php daily.php -f syslog
 | 
			
		||||
                php daily.php -f eventlog
 | 
			
		||||
                php daily.php -f authlog
 | 
			
		||||
                php daily.php -f perf_times
 | 
			
		||||
                php daily.php -f callback
 | 
			
		||||
                php daily.php -f device_perf
 | 
			
		||||
                php daily.php -f purgeusers
 | 
			
		||||
                php daily.php -f bill_data
 | 
			
		||||
                php daily.php -f alert_log
 | 
			
		||||
                php daily.php -f rrd_purge
 | 
			
		||||
            ;;
 | 
			
		||||
            submodules)
 | 
			
		||||
                # Init+Update our submodules
 | 
			
		||||
                git submodule --quiet init
 | 
			
		||||
                git submodule --quiet update
 | 
			
		||||
            ;;
 | 
			
		||||
            notifications)
 | 
			
		||||
                # Get notifications
 | 
			
		||||
                php daily.php -f notifications
 | 
			
		||||
            ;;
 | 
			
		||||
        esac
 | 
			
		||||
    fi
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
<<<<<<< HEAD
 | 
			
		||||
    cnf=$(echo $(grep '\[.distributed_poller.\]' config.php | egrep -v -e '^//' -e '^#' | cut -d = -f 2 | sed 's/;//g'))
 | 
			
		||||
    if ((${BASH_VERSINFO[0]} < 4)); then
 | 
			
		||||
        cnf=`echo $cnf|tr [:upper:] [:lower:]`
 | 
			
		||||
    else
 | 
			
		||||
        cnf=${cnf,,}
 | 
			
		||||
    fi
 | 
			
		||||
 | 
			
		||||
    if [ -z "$cnf" ] || [ "$cnf" == "0" ] || [ "$cnf" == "false" ]; then
 | 
			
		||||
        # Call ourself again in case above pull changed or added something to daily.sh
 | 
			
		||||
        $0 post-pull
 | 
			
		||||
@@ -194,6 +105,3 @@ else
 | 
			
		||||
        ;;
 | 
			
		||||
    esac
 | 
			
		||||
fi
 | 
			
		||||
=======
 | 
			
		||||
main "$@"
 | 
			
		||||
>>>>>>> Refactored and added support for $config['log_dir']
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user