Tidying config utils

This commit is contained in:
Bob Mottram 2018-02-25 14:51:29 +00:00
parent 229a9c3091
commit 34e59ae030
1 changed files with 54 additions and 58 deletions

View File

@ -106,10 +106,10 @@ function get_completion_param {
param_name="$1" param_name="$1"
if [ ${#param_name} -gt 0 ]; then if [ ${#param_name} -gt 0 ]; then
if [ $COMPLETION_FILE ]; then if [ "$COMPLETION_FILE" ]; then
if [ -f $COMPLETION_FILE ]; then if [ -f "$COMPLETION_FILE" ]; then
if grep -q "${param_name}:" $COMPLETION_FILE; then if grep -q "${param_name}:" "$COMPLETION_FILE"; then
param_value=$(cat $COMPLETION_FILE | grep "${param_name}:" | head -n 1 | awk -F ':' '{print $2}') param_value=$(grep "${param_name}:" "$COMPLETION_FILE" | head -n 1 | awk -F ':' '{print $2}')
echo "$param_value" echo "$param_value"
return return
fi fi
@ -123,7 +123,7 @@ function set_completion_param {
param_name="$1" param_name="$1"
param_value="$2" param_value="$2"
if [ ! $COMPLETION_FILE ]; then if [ ! "$COMPLETION_FILE" ]; then
COMPLETION_FILE=$HOME/${PROJECT_NAME}-completed.txt COMPLETION_FILE=$HOME/${PROJECT_NAME}-completed.txt
fi fi
if [ ${#COMPLETION_FILE} -eq 0 ]; then if [ ${#COMPLETION_FILE} -eq 0 ]; then
@ -132,14 +132,14 @@ function set_completion_param {
if [ ${#param_name} -gt 0 ]; then if [ ${#param_name} -gt 0 ]; then
if [ ${#param_value} -gt 0 ]; then if [ ${#param_value} -gt 0 ]; then
if [ -f $COMPLETION_FILE ]; then if [ -f "$COMPLETION_FILE" ]; then
if grep -q "${param_name}:" $COMPLETION_FILE; then if grep -q "${param_name}:" "$COMPLETION_FILE"; then
sed -i "s|${param_name}:.*|${param_name}:${param_value}|g" $COMPLETION_FILE sed -i "s|${param_name}:.*|${param_name}:${param_value}|g" "$COMPLETION_FILE"
else else
echo "${param_name}:${param_value}" >> $COMPLETION_FILE echo "${param_name}:${param_value}" >> "$COMPLETION_FILE"
fi fi
else else
echo "${param_name}:${param_value}" > $COMPLETION_FILE echo "${param_name}:${param_value}" > "$COMPLETION_FILE"
fi fi
fi fi
fi fi
@ -148,7 +148,7 @@ function set_completion_param {
function mark_completed { function mark_completed {
param_name="$1" param_name="$1"
if [ ! $COMPLETION_FILE ]; then if [ ! "$COMPLETION_FILE" ]; then
COMPLETION_FILE=$HOME/${PROJECT_NAME}-completed.txt COMPLETION_FILE=$HOME/${PROJECT_NAME}-completed.txt
fi fi
if [ ${#COMPLETION_FILE} -eq 0 ]; then if [ ${#COMPLETION_FILE} -eq 0 ]; then
@ -156,12 +156,12 @@ function mark_completed {
fi fi
if [ ${#param_name} -gt 0 ]; then if [ ${#param_name} -gt 0 ]; then
if [ -f $COMPLETION_FILE ]; then if [ -f "$COMPLETION_FILE" ]; then
if ! grep -Fxq "${param_name}" $COMPLETION_FILE; then if ! grep -Fxq "${param_name}" "$COMPLETION_FILE"; then
echo "${param_name}" >> $COMPLETION_FILE echo "${param_name}" >> "$COMPLETION_FILE"
fi fi
else else
echo "${param_name}" > $COMPLETION_FILE echo "${param_name}" > "$COMPLETION_FILE"
fi fi
fi fi
} }
@ -169,16 +169,16 @@ function mark_completed {
function is_completed { function is_completed {
param_name="$1" param_name="$1"
if [ ! $COMPLETION_FILE ]; then if [ ! "$COMPLETION_FILE" ]; then
COMPLETION_FILE=$HOME/${PROJECT_NAME}-completed.txt COMPLETION_FILE="$HOME/${PROJECT_NAME}-completed.txt"
fi fi
if [ ${#COMPLETION_FILE} -eq 0 ]; then if [ ${#COMPLETION_FILE} -eq 0 ]; then
COMPLETION_FILE=$HOME/${PROJECT_NAME}-completed.txt COMPLETION_FILE="$HOME/${PROJECT_NAME}-completed.txt"
fi fi
if [ ${#param_name} -gt 0 ]; then if [ ${#param_name} -gt 0 ]; then
if [ -f $COMPLETION_FILE ]; then if [ -f "$COMPLETION_FILE" ]; then
if grep -Fxq "${param_name}" $COMPLETION_FILE; then if grep -Fxq "${param_name}" "$COMPLETION_FILE"; then
echo "1" echo "1"
return return
fi fi
@ -191,15 +191,11 @@ function read_config_param {
param_name="$1" param_name="$1"
if [ ${#param_name} -gt 0 ]; then if [ ${#param_name} -gt 0 ]; then
if [ $CONFIGURATION_FILE ]; then if [ "$CONFIGURATION_FILE" ]; then
if [ -f $CONFIGURATION_FILE ]; then if [ -f "$CONFIGURATION_FILE" ]; then
if grep -q "${param_name}=" $CONFIGURATION_FILE; then if grep -q "${param_name}=" "$CONFIGURATION_FILE"; then
param_value=$(cat $CONFIGURATION_FILE | grep "${param_name}=" | head -n 1 | awk -F '=' '{print $2}') param_value=$(grep "${param_name}=" "$CONFIGURATION_FILE" | head -n 1 | awk -F '=' '{print $2}')
if [[ "${param_value}" != *" "* ]]; then export "${param_name}"="${param_value}"
export ${param_name}=${param_value}
else
export ${param_name}="${param_value}"
fi
fi fi
fi fi
fi fi
@ -210,10 +206,10 @@ function config_param_exists {
param_name="$1" param_name="$1"
if [ ${#param_name} -gt 0 ]; then if [ ${#param_name} -gt 0 ]; then
if [ $CONFIGURATION_FILE ]; then if [ "$CONFIGURATION_FILE" ]; then
if [ -f $CONFIGURATION_FILE ]; then if [ -f "$CONFIGURATION_FILE" ]; then
if grep -q "${param_name}=" $CONFIGURATION_FILE; then if grep -q "${param_name}=" "$CONFIGURATION_FILE"; then
param_value=$(cat $CONFIGURATION_FILE | grep "${param_name}=" | head -n 1 | awk -F '=' '{print $2}') param_value=$(grep "${param_name}=" "$CONFIGURATION_FILE" | head -n 1 | awk -F '=' '{print $2}')
if [ ${#param_value} -gt 0 ]; then if [ ${#param_value} -gt 0 ]; then
echo "1" echo "1"
return return
@ -229,7 +225,7 @@ function write_config_param {
param_name="$1" param_name="$1"
param_value="$2" param_value="$2"
if [ ! $CONFIGURATION_FILE ]; then if [ ! "$CONFIGURATION_FILE" ]; then
CONFIGURATION_FILE=$HOME/${PROJECT_NAME}.cfg CONFIGURATION_FILE=$HOME/${PROJECT_NAME}.cfg
fi fi
if [ ${#CONFIGURATION_FILE} -eq 0 ]; then if [ ${#CONFIGURATION_FILE} -eq 0 ]; then
@ -238,14 +234,14 @@ function write_config_param {
if [ ${#param_name} -gt 0 ]; then if [ ${#param_name} -gt 0 ]; then
if [ ${#param_value} -gt 0 ]; then if [ ${#param_value} -gt 0 ]; then
if [ -f $CONFIGURATION_FILE ]; then if [ -f "$CONFIGURATION_FILE" ]; then
if grep -q "${param_name}=" $CONFIGURATION_FILE; then if grep -q "${param_name}=" "$CONFIGURATION_FILE"; then
sed -i "s|${param_name}=.*|${param_name}=${param_value}|g" $CONFIGURATION_FILE sed -i "s|${param_name}=.*|${param_name}=${param_value}|g" "$CONFIGURATION_FILE"
else else
echo "${param_name}=${param_value}" >> $CONFIGURATION_FILE echo "${param_name}=${param_value}" >> "$CONFIGURATION_FILE"
fi fi
else else
echo "${param_name}=${param_value}" > $CONFIGURATION_FILE echo "${param_name}=${param_value}" > "$CONFIGURATION_FILE"
fi fi
fi fi
fi fi
@ -255,10 +251,10 @@ function remove_config_param {
param_name="$1" param_name="$1"
if [ ${#param_name} -gt 0 ]; then if [ ${#param_name} -gt 0 ]; then
if [ $CONFIGURATION_FILE ]; then if [ "$CONFIGURATION_FILE" ]; then
if [ -f $CONFIGURATION_FILE ]; then if [ -f "$CONFIGURATION_FILE" ]; then
if grep -q "${param_name}=" $CONFIGURATION_FILE; then if grep -q "${param_name}=" "$CONFIGURATION_FILE"; then
sed -i "/${param_name}=/d" $CONFIGURATION_FILE sed -i "/${param_name}=/d" "$CONFIGURATION_FILE"
fi fi
fi fi
fi fi
@ -269,13 +265,13 @@ function remove_completion_param {
param_name="$1" param_name="$1"
if [ ${#param_name} -gt 0 ]; then if [ ${#param_name} -gt 0 ]; then
if [ $COMPLETION_FILE ]; then if [ "$COMPLETION_FILE" ]; then
if [ -f $COMPLETION_FILE ]; then if [ -f "$COMPLETION_FILE" ]; then
if grep -Fxq "${param_name}" $COMPLETION_FILE; then if grep -Fxq "${param_name}" "$COMPLETION_FILE"; then
sed -i "/${param_name}/d" $COMPLETION_FILE sed -i "/${param_name}/d" "$COMPLETION_FILE"
fi fi
if grep -q "${param_name}:" $COMPLETION_FILE; then if grep -q "${param_name}:" "$COMPLETION_FILE"; then
sed -i "/${param_name}:/d" $COMPLETION_FILE sed -i "/${param_name}:/d" "$COMPLETION_FILE"
fi fi
fi fi
fi fi
@ -291,16 +287,16 @@ function save_configuration_values {
function read_configuration_values { function read_configuration_values {
# if not installing on a Beaglebone then use sdb as the USB drive by default # if not installing on a Beaglebone then use sdb as the USB drive by default
if [ ! $INSTALLING_ON_BBB ]; then if [ ! "$INSTALLING_ON_BBB" ]; then
if [[ $USB_DRIVE == /dev/sda1 ]]; then if [[ $USB_DRIVE == /dev/sda1 ]]; then
USB_DRIVE=/dev/sdb1 USB_DRIVE=/dev/sdb1
fi fi
fi fi
if [ -f $CONFIGURATION_FILE ]; then if [ -f "$CONFIGURATION_FILE" ]; then
# Ensure that a copy of the config exists for upgrade purposes # Ensure that a copy of the config exists for upgrade purposes
if [[ $CONFIGURATION_FILE != "/root/${PROJECT_NAME}.cfg" ]]; then if [[ $CONFIGURATION_FILE != "/root/${PROJECT_NAME}.cfg" ]]; then
cp $CONFIGURATION_FILE /root/${PROJECT_NAME}.cfg cp "$CONFIGURATION_FILE" "/root/${PROJECT_NAME}.cfg"
fi fi
for v in "${configuration_variables[@]}" for v in "${configuration_variables[@]}"
@ -308,8 +304,9 @@ function read_configuration_values {
read_config_param "$v" read_config_param "$v"
done done
if grep -q "DEBIAN_REPO" $CONFIGURATION_FILE; then if grep -q "DEBIAN_REPO" "$CONFIGURATION_FILE"; then
read_config_param "DEBIAN_REPO" read_config_param "DEBIAN_REPO"
# shellcheck disable=SC2034
CHECK_MESSAGE=$"Check your internet connection, /etc/network/interfaces and /etc/resolvconf/resolv.conf.d/head, then delete $COMPLETION_FILE, run 'rm -fR /var/lib/apt/lists/* && apt-get update --fix-missing' and run this script again. If hash sum mismatches persist then try setting $DEBIAN_REPO to a different mirror and also change /etc/apt/sources.list." CHECK_MESSAGE=$"Check your internet connection, /etc/network/interfaces and /etc/resolvconf/resolv.conf.d/head, then delete $COMPLETION_FILE, run 'rm -fR /var/lib/apt/lists/* && apt-get update --fix-missing' and run this script again. If hash sum mismatches persist then try setting $DEBIAN_REPO to a different mirror and also change /etc/apt/sources.list."
fi fi
fi fi
@ -317,7 +314,7 @@ function read_configuration_values {
function read_configuration { function read_configuration {
if [[ $INSTALLING_FROM_CONFIGURATION_FILE == "yes" ]]; then if [[ $INSTALLING_FROM_CONFIGURATION_FILE == "yes" ]]; then
if [ ! -f $CONFIGURATION_FILE ]; then if [ ! -f "$CONFIGURATION_FILE" ]; then
echo $"The configuration file $CONFIGURATION_FILE was not found" echo $"The configuration file $CONFIGURATION_FILE was not found"
exit 8935 exit 8935
fi fi
@ -336,8 +333,8 @@ function check_system_type {
# check that domain names are valid and that they are unique for each app # check that domain names are valid and that they are unique for each app
function check_domains { function check_domains {
specified_domains=$(cat $CONFIGURATION_FILE | grep "_DOMAIN_NAME" | uniq) specified_domains=$(grep "_DOMAIN_NAME" "$CONFIGURATION_FILE" | uniq)
domains_array=($specified_domains) domains_array=("$specified_domains")
checked_domains=() checked_domains=()
for d in "${domains_array[@]}" for d in "${domains_array[@]}"
@ -346,8 +343,7 @@ function check_domains {
if [[ "$domain_param" != "DEFAULT_DOMAIN_NAME" ]]; then if [[ "$domain_param" != "DEFAULT_DOMAIN_NAME" ]]; then
domain_value=$(echo "$d" | awk -F '=' '{print $2}') domain_value=$(echo "$d" | awk -F '=' '{print $2}')
if [[ "$domain_value" != "${LOCAL_NAME}.local" ]]; then if [[ "$domain_value" != "${LOCAL_NAME}.local" ]]; then
item_in_array "${domain_value}" "${checked_domains[@]}" if ! item_in_array "${domain_value}" "${checked_domains[@]}"; then
if [[ $? != 0 ]]; then
# test that this is a valid domain name # test that this is a valid domain name
function_check test_domain_name function_check test_domain_name
test_domain_name "$domain_value" test_domain_name "$domain_value"