#!/bin/bash # LinuxGSM core_messages.sh module # Author: Daniel Gibbs # Contributors: http://linuxgsm.com/contrib # Website: https://linuxgsm.com # Description: Defines on-screen messages such as [ OK ] and how script logs look. functionselfname="$(basename "$(readlink -f "${BASH_SOURCE[0]}")")" # nl: new line: message is following by a new line. # eol: end of line: message is placed at the end of the current line. fn_ansi_loader() { if [ "${ansi}" != "off" ]; then # echo colors default="\e[0m" black="\e[30m" red="\e[31m" lightred="\e[91m" green="\e[32m" lightgreen="\e[92m" yellow="\e[33m" lightyellow="\e[93m" blue="\e[34m" lightblue="\e[94m" magenta="\e[35m" lightmagenta="\e[95m" cyan="\e[36m" lightcyan="\e[96m" darkgrey="\e[90m" lightgrey="\e[37m" white="\e[97m" fi # carriage return & erase to end of line. creeol="\r\033[K" } fn_sleep_time() { if [ "${sleeptime}" != "0" ] || [ "${travistest}" != "1" ]; then if [ -z "${sleeptime}" ]; then sleeptime=0.5 fi sleep "${sleeptime}" fi } # Log display ######################## ## Feb 28 14:56:58 ut99-server: Monitor: fn_script_log() { if [ -d "${lgsmlogdir}" ]; then if [ -n "${commandname}" ]; then echo -e "$(date '+%b %d %H:%M:%S.%3N') ${selfname}: ${commandname}: ${1}" >> "${lgsmlog}" else echo -e "$(date '+%b %d %H:%M:%S.%3N') ${selfname}: ${1}" >> "${lgsmlog}" fi fi } ## Feb 28 14:56:58 ut99-server: Monitor: PASS: fn_script_log_pass() { if [ -d "${lgsmlogdir}" ]; then if [ -n "${commandname}" ]; then echo -e "$(date '+%b %d %H:%M:%S.%3N') ${selfname}: ${commandname}: PASS: ${1}" >> "${lgsmlog}" else echo -e "$(date '+%b %d %H:%M:%S.%3N') ${selfname}: PASS: ${1}" >> "${lgsmlog}" fi fi exitcode=0 } ## Feb 28 14:56:58 ut99-server: Monitor: FATAL: fn_script_log_fatal() { if [ -d "${lgsmlogdir}" ]; then if [ -n "${commandname}" ]; then echo -e "$(date '+%b %d %H:%M:%S.%3N') ${selfname}: ${commandname}: FATAL: ${1}" >> "${lgsmlog}" else echo -e "$(date '+%b %d %H:%M:%S.%3N') ${selfname}: FATAL: ${1}" >> "${lgsmlog}" fi fi exitcode=1 } ## Feb 28 14:56:58 ut99-server: Monitor: ERROR: fn_script_log_error() { if [ -d "${lgsmlogdir}" ]; then if [ -n "${commandname}" ]; then echo -e "$(date '+%b %d %H:%M:%S.%3N') ${selfname}: ${commandname}: ERROR: ${1}" >> "${lgsmlog}" else echo -e "$(date '+%b %d %H:%M:%S.%3N') ${selfname}: ERROR: ${1}" >> "${lgsmlog}" fi fi exitcode=2 } ## Feb 28 14:56:58 ut99-server: Monitor: WARN: fn_script_log_warn() { if [ -d "${lgsmlogdir}" ]; then if [ -n "${commandname}" ]; then echo -e "$(date '+%b %d %H:%M:%S.%3N') ${selfname}: ${commandname}: WARN: ${1}" >> "${lgsmlog}" else echo -e "$(date '+%b %d %H:%M:%S.%3N') ${selfname}: WARN: ${1}" >> "${lgsmlog}" fi fi exitcode=3 } ## Feb 28 14:56:58 ut99-server: Monitor: INFO: fn_script_log_info() { if [ -d "${lgsmlogdir}" ]; then if [ -n "${commandname}" ]; then echo -e "$(date '+%b %d %H:%M:%S.%3N') ${selfname}: ${commandname}: INFO: ${1}" >> "${lgsmlog}" else echo -e "$(date '+%b %d %H:%M:%S.%3N') ${selfname}: INFO: ${1}" >> "${lgsmlog}" fi fi } ## Feb 28 14:56:58 ut99-server: Monitor: UPDATE: fn_script_log_update() { if [ -d "${lgsmlogdir}" ]; then if [ -n "${commandname}" ]; then echo -e "$(date '+%b %d %H:%M:%S.%3N') ${selfname}: ${commandname}: UPDATE: ${1}" >> "${lgsmlog}" else echo -e "$(date '+%b %d %H:%M:%S.%3N') ${selfname}: UPDATE: ${1}" >> "${lgsmlog}" fi fi } # On-Screen - Automated functions ################################## # [ .... ] fn_print_dots() { if [ "${commandaction}" ]; then echo -en "${creeol}[ .... ] ${commandaction} ${selfname}: $*" else echo -en "${creeol}[ .... ] $*" fi fn_sleep_time } fn_print_dots_nl() { if [ "${commandaction}" ]; then echo -e "${creeol}[ .... ] ${commandaction} ${selfname}: $*" else echo -e "${creeol}[ .... ] $*" fi fn_sleep_time echo -en "\n" } # [ OK ] fn_print_ok() { if [ "${commandaction}" ]; then echo -en "${creeol}[${green} OK ${default}] ${commandaction} ${selfname}: $*" else echo -en "${creeol}[${green} OK ${default}] $*" fi fn_sleep_time } fn_print_ok_nl() { if [ "${commandaction}" ]; then echo -en "${creeol}[${green} OK ${default}] ${commandaction} ${selfname}: $*" else echo -en "${creeol}[${green} OK ${default}] $*" fi fn_sleep_time echo -en "\n" } # [ FAIL ] fn_print_fail() { if [ "${commandaction}" ]; then echo -en "${creeol}[${red} FAIL ${default}] ${commandaction} ${selfname}: $*" else echo -en "${creeol}[${red} FAIL ${default}] $*" fi fn_sleep_time } fn_print_fail_nl() { if [ "${commandaction}" ]; then echo -en "${creeol}[${red} FAIL ${default}] ${commandaction} ${selfname}: $*" else echo -en "${creeol}[${red} FAIL ${default}] $*" fi fn_sleep_time echo -en "\n" } # [ ERROR ] fn_print_error() { if [ "${commandaction}" ]; then echo -en "${creeol}[${red} ERROR ${default}] ${commandaction} ${selfname}: $*" else echo -en "${creeol}[${red} ERROR ${default}] $*" fi fn_sleep_time } fn_print_error_nl() { if [ "${commandaction}" ]; then echo -en "${creeol}[${red} ERROR ${default}] ${commandaction} ${selfname}: $*" else echo -en "${creeol}[${red} ERROR ${default}] $*" fi fn_sleep_time echo -en "\n" } # [ WARN ] fn_print_warn() { if [ "${commandaction}" ]; then echo -en "${creeol}[${lightyellow} WARN ${default}] ${commandaction} ${selfname}: $*" else echo -en "${creeol}[${lightyellow} WARN ${default}] $*" fi fn_sleep_time } fn_print_warn_nl() { if [ "${commandaction}" ]; then echo -en "${creeol}[${lightyellow} WARN ${default}] ${commandaction} ${selfname}: $*" else echo -en "${creeol}[${lightyellow} WARN ${default}] $*" fi fn_sleep_time echo -en "\n" } # [ INFO ] fn_print_info() { if [ "${commandaction}" ]; then echo -en "${creeol}[${cyan} INFO ${default}] ${commandaction} ${selfname}: $*" else echo -en "${creeol}[${cyan} INFO ${default}] $*" fi fn_sleep_time } fn_print_info_nl() { if [ "${commandaction}" ]; then echo -en "${creeol}[${cyan} INFO ${default}] ${commandaction} ${selfname}: $*" else echo -en "${creeol}[${cyan} INFO ${default}] $*" fi fn_sleep_time echo -en "\n" } # [ START ] fn_print_start() { if [ "${commandaction}" ]; then echo -en "${creeol}[${lightgreen} START ${default}] ${commandaction} ${selfname}: $*" else echo -en "${creeol}[${lightgreen} START ${default}] $*" fi fn_sleep_time } fn_print_start_nl() { if [ "${commandaction}" ]; then echo -en "${creeol}[${lightgreen} START ${default}] ${commandaction} ${selfname}: $*" else echo -en "${creeol}[${lightgreen} START ${default}] $*" fi fn_sleep_time echo -en "\n" } # On-Screen - Interactive messages ################################## # No More Room in Hell Debug # ================================= fn_print_header() { echo -e "" echo -e "${lightyellow}${gamename} ${commandaction}${default}" echo -e "=================================${default}" } # Complete! fn_print_complete() { echo -en "${green}Complete!${default} $*" fn_sleep_time } fn_print_complete_nl() { echo -e "${green}Complete!${default} $*" fn_sleep_time } # Failure! fn_print_failure() { echo -en "${red}Failure!${default} $*" fn_sleep_time } fn_print_failure_nl() { echo -e "${red}Failure!${default} $*" fn_sleep_time } # Error! fn_print_error2() { echo -en "${red}Error!${default} $*" fn_sleep_time } fn_print_error2_nl() { echo -e "${red}Error!${default} $*" fn_sleep_time } # Warning! fn_print_warning() { echo -en "${lightyellow}Warning!${default} $*" fn_sleep_time } fn_print_warning_nl() { echo -e "${lightyellow}Warning!${default} $*" fn_sleep_time } # Information! fn_print_information() { echo -en "${cyan}Information!${default} $*" fn_sleep_time } fn_print_information_nl() { echo -e "${cyan}Information!${default} $*" fn_sleep_time } # Y/N Prompt fn_prompt_yn() { local prompt="$1" local initial="$2" if [ "${initial}" == "Y" ]; then prompt+=" [Y/n] " elif [ "${initial}" == "N" ]; then prompt+=" [y/N] " else prompt+=" [y/n] " fi while true; do read -e -i "${initial}" -p "${prompt}" -r yn case "${yn}" in [Yy] | [Yy][Ee][Ss]) return 0 ;; [Nn] | [Nn][Oo]) return 1 ;; *) echo -e "Please answer yes or no." ;; esac done } # Prompt for message fn_prompt_message() { while true; do unset prompt local prompt="$1" read -e -p "${prompt}" -r answer if fn_prompt_yn "Continue" Y; then break fi done echo "${answer}" } # On-Screen End of Line ################################## # YES fn_print_yes_eol() { echo -en "${cyan}YES${default}" fn_sleep_time } fn_print_yes_eol_nl() { echo -e "${cyan}YES${default}" fn_sleep_time } # NO fn_print_no_eol() { echo -en "${red}NO${default}" fn_sleep_time } fn_print_no_eol_nl() { echo -e "${red}NO${default}" fn_sleep_time } # OK fn_print_ok_eol() { echo -en "${green}OK${default}" fn_sleep_time } fn_print_ok_eol_nl() { echo -e "${green}OK${default}" fn_sleep_time } # FAIL fn_print_fail_eol() { echo -en "${red}FAIL${default}" fn_sleep_time } fn_print_fail_eol_nl() { echo -e "${red}FAIL${default}" fn_sleep_time } # ERROR fn_print_error_eol() { echo -en "${red}ERROR${default}" fn_sleep_time } fn_print_error_eol_nl() { echo -e "${red}ERROR${default}" fn_sleep_time } # WAIT fn_print_wait_eol() { echo -en "${cyan}WAIT${default}" fn_sleep_time } fn_print_wait_eol_nl() { echo -e "${cyan}WAIT${default}" fn_sleep_time } # WARN fn_print_warn_eol() { echo -en "${lightyellow}WARN${default}" fn_sleep_time } fn_print_warn_eol_nl() { echo -e "${lightyellow}WARN${default}" fn_sleep_time } # INFO fn_print_info_eol() { echo -en "${cyan}INFO${default}" fn_sleep_time } fn_print_info_eol_nl() { echo -e "${cyan}INFO${default}" fn_sleep_time } # QUERYING fn_print_querying_eol() { echo -en "${cyan}QUERYING${default}" fn_sleep_time } fn_print_querying_eol_nl() { echo -e "${cyan}QUERYING${default}" fn_sleep_time } # CHECKING fn_print_checking_eol() { echo -en "${cyan}CHECKING${default}" fn_sleep_time } fn_print_checking_eol_nl() { echo -e "${cyan}CHECKING${default}" fn_sleep_time } # DELAY fn_print_delay_eol() { echo -en "${green}DELAY${default}" fn_sleep_time } fn_print_delay_eol_nl() { echo -e "${green}DELAY${default}" fn_sleep_time } # CANCELED fn_print_canceled_eol() { echo -en "${lightyellow}CANCELED${default}" fn_sleep_time } fn_print_canceled_eol_nl() { echo -e "${lightyellow}CANCELED${default}" fn_sleep_time } # REMOVED fn_print_removed_eol() { echo -en "${red}REMOVED${default}" fn_sleep_time } fn_print_removed_eol_nl() { echo -e "${red}REMOVED${default}" fn_sleep_time } # UPDATE fn_print_update_eol() { echo -en "${cyan}UPDATE${default}" fn_sleep_time } fn_print_update_eol_nl() { echo -e "${cyan}UPDATE${default}" fn_sleep_time } fn_print_ascii_logo() { echo -e "" echo -e " mdMMMMbm" echo -e " mMMMMMMMMMMm" echo -e " mMMMMMMMMMMMMm" echo -e " mMMMMMMMMMMMMMMm" echo -e " hMMMV^VMMV^VMMMh" echo -e " MMMMM MM MMMMM" echo -e " hMMs vv sMMh" echo -e " hMMM: :MMMh" echo -e " .hMMMh hMMMh." echo -e " -dMMMh ${lightgrey}__${default} hMMMd-" echo -e " :mMMMs ${lightgrey}||${default} sMMMm:" echo -e " :MMMM+ ${lightgrey}||${default} ${red}_${default} +NMMN:" echo -e " .mMMM+ ${lightgrey}========${default} +MMMm." echo -e " yMMMy ${darkgrey}##############${default} yMMMy" echo -e " mMMM: ${darkgrey}##############${default} :MMMm" echo -e " mMM ${lightyellow}nn${default} ${lightyellow}nn${default} ${lightyellow}nn${default} ${lightyellow}nn${default} MMm" echo -e " o ${lightyellow}nNNNNNNNn${default} ${lightyellow}nNNNNNNNn${default} o" echo -e " ${lightyellow}nNNNNNNNNNn${default} ${lightyellow}nNNNNNNNNNn${default}" echo -e " ${lightyellow}nNNNNNNNNNNN${default} ${lightyellow}NNNNNNNNNNNn${default}" echo -e " ${lightyellow}+NNNNNNNNN:${default} ${lightyellow}:NNNNNNNNN+${default}" echo -e " ${lightyellow}nNNNNNNN${default} /\ ${lightyellow}NNNNNNNn${default}" echo -e " ${lightyellow}nnnnn${default} db ${lightyellow}nnnnn${default}" echo -e "" echo -e "${lightyellow}888${default} ${lightyellow}d8b${default} ${default}.d8888b. .d8888b. 888b d888" echo -e "${lightyellow}888 Y8P ${default}d88P Y88b d88P Y88b 8888b d8888" echo -e "${lightyellow}888${default} ${default}888${default} 888 Y88b. 88888b.d88888" echo -e "${lightyellow}888${default} ${lightyellow}888${default} ${lightyellow}88888b.${default} ${lightyellow}888${default} ${lightyellow}888${default} ${lightyellow}888${default} ${lightyellow}888${default} 888 Y888b. 888Y88888P888" echo -e "${lightyellow}888${default} ${lightyellow}888${default} ${lightyellow}888${default} ${lightyellow}88b${default} ${lightyellow}888${default} ${lightyellow}888${default} ${lightyellow}Y8bd8P${default} 888 88888 Y88b. 888 Y888P 888" echo -e "${lightyellow}888${default} ${lightyellow}888${default} ${lightyellow}888${default} ${lightyellow}888${default} ${lightyellow}888${default} ${lightyellow}888${default} ${lightyellow}X88K${default} 888 888 888 888 Y8P 888" echo -e "${lightyellow}888${default} ${lightyellow}888${default} ${lightyellow}888${default} ${lightyellow}888${default} ${lightyellow}Y88b${default} ${lightyellow}88Y${default} ${lightyellow}.d8pq8b.${default} Y88b d88P Y88b d88P 888 * 888" echo -e "${lightyellow}LinuxGSM${default} ${lightyellow}888${default} ${lightyellow}888${default} ${lightyellow}888${default} ${lightyellow}Y8888Y${default} ${lightyellow}888${default} ${lightyellow}888${default} Y2012P88 Y8888P 888 888" echo -e "" } fn_print_restart_warning() { fn_print_warn "${selfname} will be restarted" fn_script_log_warn "${selfname} will be restarted" totalseconds=3 for seconds in {3..1}; do fn_print_warn "${selfname} will be restarted: ${totalseconds}" totalseconds=$((totalseconds - 1)) sleep 1 if [ "${seconds}" == "0" ]; then break fi done fn_print_warn_nl "${selfname} will be restarted" } # Functions below are used to ensure that logs and UI correctly reflect the command it is actually running. # Useful when a command has to call upon another command causing the other command to overrite commandname variables # Used to remember the command that ran first. fn_firstcommand_set() { if [ -z "${firstcommandname}" ]; then firstcommandname="${commandname}" firstcommandaction="${commandaction}" fi } # Used to reset commandname variables to the command the script ran first. fn_firstcommand_reset() { commandname="${firstcommandname}" commandaction="${firstcommandaction}" }