mirror of
https://github.com/tigerblue77/Dell_iDRAC_fan_controller_Docker.git
synced 2025-11-02 21:13:16 +00:00
Set functions variables "local" and "readonly" when possible
This commit is contained in:
@@ -43,13 +43,13 @@ fi
|
|||||||
|
|
||||||
# If server model is Gen 14 (*40) or newer
|
# If server model is Gen 14 (*40) or newer
|
||||||
if [[ $SERVER_MODEL =~ .*[RT][[:space:]]?[0-9][4-9]0.* ]]; then
|
if [[ $SERVER_MODEL =~ .*[RT][[:space:]]?[0-9][4-9]0.* ]]; then
|
||||||
DELL_POWEREDGE_GEN_14_OR_NEWER=true
|
readonly DELL_POWEREDGE_GEN_14_OR_NEWER=true
|
||||||
CPU1_TEMPERATURE_INDEX=2
|
readonly CPU1_TEMPERATURE_INDEX=2
|
||||||
CPU2_TEMPERATURE_INDEX=4
|
readonly CPU2_TEMPERATURE_INDEX=4
|
||||||
else
|
else
|
||||||
DELL_POWEREDGE_GEN_14_OR_NEWER=false
|
readonly DELL_POWEREDGE_GEN_14_OR_NEWER=false
|
||||||
CPU1_TEMPERATURE_INDEX=1
|
readonly CPU1_TEMPERATURE_INDEX=1
|
||||||
CPU2_TEMPERATURE_INDEX=2
|
readonly CPU2_TEMPERATURE_INDEX=2
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Log main informations
|
# Log main informations
|
||||||
|
|||||||
26
functions.sh
26
functions.sh
@@ -18,8 +18,8 @@ function apply_user_fan_control_profile() {
|
|||||||
# Usage : convert_decimal_value_to_hexadecimal $DECIMAL_NUMBER
|
# Usage : convert_decimal_value_to_hexadecimal $DECIMAL_NUMBER
|
||||||
# Returns : hexadecimal value of DECIMAL_NUMBER
|
# Returns : hexadecimal value of DECIMAL_NUMBER
|
||||||
function convert_decimal_value_to_hexadecimal() {
|
function convert_decimal_value_to_hexadecimal() {
|
||||||
local DECIMAL_NUMBER=$1
|
local -r DECIMAL_NUMBER=$1
|
||||||
local HEXADECIMAL_NUMBER=$(printf '0x%02x' $DECIMAL_NUMBER)
|
local -r HEXADECIMAL_NUMBER=$(printf '0x%02x' $DECIMAL_NUMBER)
|
||||||
echo $HEXADECIMAL_NUMBER
|
echo $HEXADECIMAL_NUMBER
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -27,8 +27,8 @@ function convert_decimal_value_to_hexadecimal() {
|
|||||||
# Usage : convert_hexadecimal_value_to_decimal "$HEXADECIMAL_NUMBER"
|
# Usage : convert_hexadecimal_value_to_decimal "$HEXADECIMAL_NUMBER"
|
||||||
# Returns : decimal value of HEXADECIMAL_NUMBER
|
# Returns : decimal value of HEXADECIMAL_NUMBER
|
||||||
function convert_hexadecimal_value_to_decimal() {
|
function convert_hexadecimal_value_to_decimal() {
|
||||||
local HEXADECIMAL_NUMBER=$1
|
local -r HEXADECIMAL_NUMBER=$1
|
||||||
local DECIMAL_NUMBER=$(printf '%d' $HEXADECIMAL_NUMBER)
|
local -r DECIMAL_NUMBER=$(printf '%d' $HEXADECIMAL_NUMBER)
|
||||||
echo $DECIMAL_NUMBER
|
echo $DECIMAL_NUMBER
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -39,13 +39,13 @@ function retrieve_temperatures() {
|
|||||||
print_error "Illegal number of parameters.\nUsage: retrieve_temperatures \$IS_EXHAUST_TEMPERATURE_SENSOR_PRESENT \$IS_CPU2_TEMPERATURE_SENSOR_PRESENT"
|
print_error "Illegal number of parameters.\nUsage: retrieve_temperatures \$IS_EXHAUST_TEMPERATURE_SENSOR_PRESENT \$IS_CPU2_TEMPERATURE_SENSOR_PRESENT"
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
local IS_EXHAUST_TEMPERATURE_SENSOR_PRESENT=$1
|
local -r IS_EXHAUST_TEMPERATURE_SENSOR_PRESENT=$1
|
||||||
local IS_CPU2_TEMPERATURE_SENSOR_PRESENT=$2
|
local -r IS_CPU2_TEMPERATURE_SENSOR_PRESENT=$2
|
||||||
|
|
||||||
local DATA=$(ipmitool -I $IDRAC_LOGIN_STRING sdr type temperature | grep degrees)
|
local -r DATA=$(ipmitool -I $IDRAC_LOGIN_STRING sdr type temperature | grep degrees)
|
||||||
|
|
||||||
# Parse CPU data
|
# Parse CPU data
|
||||||
local CPU_DATA=$(echo "$DATA" | grep "3\." | grep -Po '\d{2}')
|
local -r CPU_DATA=$(echo "$DATA" | grep "3\." | grep -Po '\d{2}')
|
||||||
CPU1_TEMPERATURE=$(echo $CPU_DATA | awk "{print \$$CPU1_TEMPERATURE_INDEX;}")
|
CPU1_TEMPERATURE=$(echo $CPU_DATA | awk "{print \$$CPU1_TEMPERATURE_INDEX;}")
|
||||||
if $IS_CPU2_TEMPERATURE_SENSOR_PRESENT; then
|
if $IS_CPU2_TEMPERATURE_SENSOR_PRESENT; then
|
||||||
CPU2_TEMPERATURE=$(echo $CPU_DATA | awk "{print \$$CPU2_TEMPERATURE_INDEX;}")
|
CPU2_TEMPERATURE=$(echo $CPU_DATA | awk "{print \$$CPU2_TEMPERATURE_INDEX;}")
|
||||||
@@ -107,7 +107,7 @@ function graceful_exit() {
|
|||||||
|
|
||||||
# Helps debugging when people are posting their output
|
# Helps debugging when people are posting their output
|
||||||
function get_Dell_server_model() {
|
function get_Dell_server_model() {
|
||||||
IPMI_FRU_content=$(ipmitool -I $IDRAC_LOGIN_STRING fru 2>/dev/null) # FRU stands for "Field Replaceable Unit"
|
local -r IPMI_FRU_content=$(ipmitool -I $IDRAC_LOGIN_STRING fru 2>/dev/null) # FRU stands for "Field Replaceable Unit"
|
||||||
|
|
||||||
SERVER_MANUFACTURER=$(echo "$IPMI_FRU_content" | grep "Product Manufacturer" | awk -F ': ' '{print $2}')
|
SERVER_MANUFACTURER=$(echo "$IPMI_FRU_content" | grep "Product Manufacturer" | awk -F ': ' '{print $2}')
|
||||||
SERVER_MODEL=$(echo "$IPMI_FRU_content" | grep "Product Name" | awk -F ': ' '{print $2}')
|
SERVER_MODEL=$(echo "$IPMI_FRU_content" | grep "Product Name" | awk -F ': ' '{print $2}')
|
||||||
@@ -128,24 +128,24 @@ function CPU1_OVERHEATING() { [ $CPU1_TEMPERATURE -gt $CPU_TEMPERATURE_THRESHOLD
|
|||||||
function CPU2_OVERHEATING() { [ $CPU2_TEMPERATURE -gt $CPU_TEMPERATURE_THRESHOLD ]; }
|
function CPU2_OVERHEATING() { [ $CPU2_TEMPERATURE -gt $CPU_TEMPERATURE_THRESHOLD ]; }
|
||||||
|
|
||||||
function print_error() {
|
function print_error() {
|
||||||
local ERROR_MESSAGE="$1"
|
local -r ERROR_MESSAGE="$1"
|
||||||
printf "/!\ Error /!\ %s." "$ERROR_MESSAGE" >&2
|
printf "/!\ Error /!\ %s." "$ERROR_MESSAGE" >&2
|
||||||
}
|
}
|
||||||
|
|
||||||
function print_error_and_exit() {
|
function print_error_and_exit() {
|
||||||
local ERROR_MESSAGE="$1"
|
local -r ERROR_MESSAGE="$1"
|
||||||
print_error "$ERROR_MESSAGE"
|
print_error "$ERROR_MESSAGE"
|
||||||
printf " Exiting.\n" >&2
|
printf " Exiting.\n" >&2
|
||||||
exit 1
|
exit 1
|
||||||
}
|
}
|
||||||
|
|
||||||
function print_warning() {
|
function print_warning() {
|
||||||
local WARNING_MESSAGE="$1"
|
local -r WARNING_MESSAGE="$1"
|
||||||
printf "/!\ Warning /!\ %s." "$WARNING_MESSAGE"
|
printf "/!\ Warning /!\ %s." "$WARNING_MESSAGE"
|
||||||
}
|
}
|
||||||
|
|
||||||
function print_warning_and_exit() {
|
function print_warning_and_exit() {
|
||||||
local WARNING_MESSAGE="$1"
|
local -r WARNING_MESSAGE="$1"
|
||||||
print_warning "$WARNING_MESSAGE"
|
print_warning "$WARNING_MESSAGE"
|
||||||
printf " Exiting.\n"
|
printf " Exiting.\n"
|
||||||
exit 0
|
exit 0
|
||||||
|
|||||||
Reference in New Issue
Block a user