linux-tutorial/codes/linux/soft/lib/utils.sh

132 lines
3.6 KiB
Bash
Raw Normal View History

2020-02-12 22:46:17 +08:00
#!/usr/bin/env bash
2020-03-10 22:54:15 +08:00
# -----------------------------------------------------------------------------------------------------
2020-02-12 22:46:17 +08:00
# Shell Utils
# @author Zhang Peng
2020-03-10 22:54:15 +08:00
# -----------------------------------------------------------------------------------------------------
2020-02-12 22:46:17 +08:00
2020-03-10 22:54:15 +08:00
# ------------------------------------------------------------------------------ env
2020-02-12 22:46:17 +08:00
# Regular Color
2020-03-10 22:54:15 +08:00
export ENV_COLOR_BLACK="\033[0;30m"
export ENV_COLOR_RED="\033[0;31m"
export ENV_COLOR_GREEN="\033[0;32m"
export ENV_COLOR_YELLOW="\033[0;33m"
export ENV_COLOR_BLUE="\033[0;34m"
export ENV_COLOR_MAGENTA="\033[0;35m"
export ENV_COLOR_CYAN="\033[0;36m"
export ENV_COLOR_WHITE="\033[0;37m"
2020-02-12 22:46:17 +08:00
# Bold Color
2020-03-10 22:54:15 +08:00
export ENV_COLOR_B_BLACK="\033[1;30m"
export ENV_COLOR_B_RED="\033[1;31m"
export ENV_COLOR_B_GREEN="\033[1;32m"
export ENV_COLOR_B_YELLOW="\033[1;33m"
export ENV_COLOR_B_BLUE="\033[1;34m"
export ENV_COLOR_B_MAGENTA="\033[1;35m"
export ENV_COLOR_B_CYAN="\033[1;36m"
export ENV_COLOR_B_WHITE="\033[1;37m"
2020-02-12 22:46:17 +08:00
# Underline Color
2020-03-10 22:54:15 +08:00
export ENV_COLOR_U_BLACK="\033[4;30m"
export ENV_COLOR_U_RED="\033[4;31m"
export ENV_COLOR_U_GREEN="\033[4;32m"
export ENV_COLOR_U_YELLOW="\033[4;33m"
export ENV_COLOR_U_BLUE="\033[4;34m"
export ENV_COLOR_U_MAGENTA="\033[4;35m"
export ENV_COLOR_U_CYAN="\033[4;36m"
export ENV_COLOR_U_WHITE="\033[4;37m"
2020-02-12 22:46:17 +08:00
# Background Color
2020-03-10 22:54:15 +08:00
export ENV_COLOR_BG_BLACK="\033[40m"
export ENV_COLOR_BG_RED="\033[41m"
export ENV_COLOR_BG_GREEN="\033[42m"
export ENV_COLOR_BG_YELLOW="\033[43m"
export ENV_COLOR_BG_BLUE="\033[44m"
export ENV_COLOR_BG_MAGENTA="\033[45m"
export ENV_COLOR_BG_CYAN="\033[46m"
export ENV_COLOR_BG_WHITE="\033[47m"
2020-02-12 22:46:17 +08:00
# Reset Color
2020-03-10 22:54:15 +08:00
export ENV_COLOR_RESET="$(tput sgr0)"
2020-02-12 22:46:17 +08:00
2020-03-10 22:54:15 +08:00
# status
export ENV_YES=0
export ENV_NO=1
export ENV_SUCCEED=0
export ENV_FAILED=1
2020-02-12 22:46:17 +08:00
2020-03-10 22:54:15 +08:00
# ------------------------------------------------------------------------------ functions
2020-02-12 22:46:17 +08:00
# 显示打印日志的时间
2020-03-10 22:54:15 +08:00
SHELL_LOG_TIMESTAMP=$(date "+%Y-%m-%d %H:%M:%S")
2020-02-12 22:46:17 +08:00
# 那个用户在操作
USER=$(whoami)
# 日志路径
2020-03-10 22:54:15 +08:00
LOG_PATH=${ENV_LOG_PATH:-/var/log/shell.log}
# 日志目录
LOG_DIR=${LOG_PATH%/*}
2020-02-12 22:46:17 +08:00
createLogFileIfNotExists() {
2020-03-10 22:54:15 +08:00
if [[ ! -x "${LOG_PATH}" ]]; then
mkdir -p "${LOG_DIR}"
2020-02-12 22:46:17 +08:00
touch "${LOG_PATH}"
fi
}
2020-04-03 15:15:02 +08:00
redOutput() {
echo -e "${ENV_COLOR_RED} $@${ENV_COLOR_RESET}"
}
greenOutput() {
echo -e "${ENV_COLOR_B_GREEN} $@${ENV_COLOR_RESET}"
}
yellowOutput() {
echo -e "${ENV_COLOR_YELLOW} $@${ENV_COLOR_RESET}"
}
blueOutput() {
echo -e "${ENV_COLOR_BLUE} $@${ENV_COLOR_RESET}"
}
magentaOutput() {
echo -e "${ENV_COLOR_MAGENTA} $@${ENV_COLOR_RESET}"
}
cyanOutput() {
echo -e "${ENV_COLOR_CYAN} $@${ENV_COLOR_RESET}"
}
whiteOutput() {
echo -e "${ENV_COLOR_WHITE} $@${ENV_COLOR_RESET}"
}
2020-02-12 22:46:17 +08:00
logInfo() {
2020-03-10 22:54:15 +08:00
echo -e "${ENV_COLOR_B_GREEN}[INFO] $@${ENV_COLOR_RESET}"
2020-02-12 22:46:17 +08:00
createLogFileIfNotExists
2020-03-10 22:54:15 +08:00
echo "[${SHELL_LOG_TIMESTAMP}] [${USER}] [INFO] [$0] $@" >> "${LOG_PATH}"
2020-02-12 22:46:17 +08:00
}
logWarn() {
2020-03-10 22:54:15 +08:00
echo -e "${ENV_COLOR_B_YELLOW}[WARN] $@${ENV_COLOR_RESET}"
2020-02-12 22:46:17 +08:00
createLogFileIfNotExists
2020-03-10 22:54:15 +08:00
echo "[${SHELL_LOG_TIMESTAMP}] [${USER}] [WARN] [$0] $@" >> "${LOG_PATH}"
2020-02-12 22:46:17 +08:00
}
logError() {
2020-03-10 22:54:15 +08:00
echo -e "${ENV_COLOR_B_RED}[ERROR] $@${ENV_COLOR_RESET}"
2020-02-12 22:46:17 +08:00
createLogFileIfNotExists
2020-03-10 22:54:15 +08:00
echo "[${SHELL_LOG_TIMESTAMP}] [${USER}] [ERROR] [$0] $@" >> "${LOG_PATH}"
2020-02-12 22:46:17 +08:00
}
printInfo() {
2020-03-10 22:54:15 +08:00
echo -e "${ENV_COLOR_B_GREEN}[INFO] $@${ENV_COLOR_RESET}"
2020-02-12 22:46:17 +08:00
}
printWarn() {
2020-03-10 22:54:15 +08:00
echo -e "${ENV_COLOR_B_YELLOW}[WARN] $@${ENV_COLOR_RESET}"
2020-02-12 22:46:17 +08:00
}
printError() {
2020-03-10 22:54:15 +08:00
echo -e "${ENV_COLOR_B_RED}[ERROR] $@${ENV_COLOR_RESET}"
2020-02-12 22:46:17 +08:00
}
callAndLog () {
$*
2020-03-10 22:54:15 +08:00
if [[ $? -eq ${ENV_SUCCEED} ]]; then
logInfo "$@"
return ${ENV_SUCCEED}
2020-02-12 22:46:17 +08:00
else
2020-03-10 22:54:15 +08:00
logError "$@ EXECUTE FAILED"
return ${ENV_FAILED}
2020-02-12 22:46:17 +08:00
fi
}