102 lines
2.2 KiB
Bash
102 lines
2.2 KiB
Bash
#!/usr/bin/env bash
|
|
|
|
BOLD=$(tput bold)
|
|
M_COLOR=$(tput setaf 5)
|
|
CYAN=$(tput setaf 6)
|
|
YELLOW=$(tput setaf 3)
|
|
RED=$(tput setaf 1)
|
|
RESET=$(tput sgr0)
|
|
RESET_BOLD="${RESET}${BOLD}"
|
|
|
|
log() {
|
|
# Print a message and send it to stdout or stderr depending upon log level, also configurable with debug etc.
|
|
#
|
|
# Arguments:
|
|
# level <type: string> <position: 1> <required: true>
|
|
# - The log level, defined within a case check in this function
|
|
# message <type: string> <position: 2> <required: true>
|
|
# - The info message
|
|
#
|
|
# Usage:
|
|
# log "info" "Could not find that directory"
|
|
#
|
|
# POSIX Compliant:
|
|
# Yes
|
|
#
|
|
|
|
# Convert the level to uppercase
|
|
local level
|
|
level=$(printf "%s" "${1}" | tr '[:lower:]' '[:upper:]')
|
|
|
|
local message
|
|
message="${2}"
|
|
|
|
local prefix="${M_COLOR}Installer${RESET} - "
|
|
|
|
case "${level}" in
|
|
INFO)
|
|
printf "%s%sINFO:%s %s%s%s\n" \
|
|
"${prefix}" \
|
|
"${CYAN}" \
|
|
"${RESET}" \
|
|
"${BOLD}" \
|
|
"${message}" \
|
|
"${RESET}" >&2
|
|
return 0
|
|
;;
|
|
WARN*)
|
|
printf "%s%sWARN:%s %s%s%s\n" \
|
|
"${prefix}" \
|
|
"${YELLOW}" \
|
|
"${RESET}" \
|
|
"${BOLD}" \
|
|
"${message}" \
|
|
"${RESET}" >&2
|
|
return 0
|
|
;;
|
|
ERROR)
|
|
printf "%s%sERROR:%s %s%s%s\n" \
|
|
"${prefix}" \
|
|
"${RED}" \
|
|
"${RESET}" \
|
|
"${BOLD}" \
|
|
"${message}" \
|
|
"${RESET}" >&2
|
|
return 0
|
|
;;
|
|
# Further log levels can be added by extending this switch statement with more comparisons
|
|
|
|
esac
|
|
}
|
|
|
|
print-break() {
|
|
printf "${M_COLOR}%.s─${RESET}" $(seq 1 "$(tput cols)")
|
|
}
|
|
|
|
main() {
|
|
local installers_directory
|
|
installers_directory="$(cd -- "$(dirname -- "${BASH_SOURCE[0]}")" &>/dev/null && pwd)/installers"
|
|
local installers=()
|
|
for installer in "${installers_directory}/"*; do
|
|
log "info" "Found installer: ${M_COLOR}${installer}${RESET_BOLD}"
|
|
installers+=("${installer}")
|
|
done
|
|
|
|
if ! ((${#installers[@]})); then
|
|
log "error" "No installers found"
|
|
exit 1
|
|
fi
|
|
|
|
for installer in "${installers[@]}"; do
|
|
log "info" "Running installer: ${M_COLOR}${installer}${RESET_BOLD}"
|
|
if ! bash "${installer}"; then
|
|
log "error" "Installer: ${M_COLOR}${installer}${RESET_BOLD} failed!"
|
|
exit 2
|
|
else
|
|
log "info" "Finished running installer ${M_COLOR}${installer}${RESET_BOLD}"
|
|
fi
|
|
done
|
|
}
|
|
|
|
main
|