HIRS/package/scripts/aca/aca_setup.sh

123 lines
3.5 KiB
Bash
Raw Normal View History

#!/bin/bash
# Capture location of the script to allow from invocation from any location
SCRIPT_DIR=$( dirname -- "$( readlink -f -- "$0"; )"; )
#SPRING_PROP_FILE='../../../HIRS_AttestationCAPortal/src/main/resources/application.properties'
2023-07-20 15:52:45 +00:00
HIRS_CONF_DIR=/etc/hirs/aca
LOG_FILE_NAME="hirs_aca_install_"$(date +%Y-%m-%d).log
2023-07-20 15:52:45 +00:00
LOG_DIR="/var/log/hirs/"
2023-08-23 20:30:06 +00:00
LOG_FILE="$LOG_DIR$LOG_FILE_NAME"
2023-07-20 15:52:45 +00:00
HIRS_PROP_DIR="/opt/hirs/default-properties"
#COMP_JSON='../../../HIRS_AttestationCA/src/main/resources/component-class.json'
#VENDOR_TABLE='../../../HIRS_AttestationCA/src/main/resources/vendor-table.json'
2023-08-23 20:30:06 +00:00
help () {
echo " Setup script for the HIRS ACA"
echo " Syntax: sh aca_setup.sh [-u|h|sb|sp|--skip-db|--skip-pki]"
echo " options:"
echo " -u | --unattended Run unattended"
echo " -h | --help Print this Help."
echo " -sp | --skip-pki run the setup without pki setup."
echo " -sb | --skip-db run the setup without databse setup."
echo
}
# Process parameters Argument handling
2023-08-18 16:38:41 +00:00
POSITIONAL_ARGS=()
while [[ $# -gt 0 ]]; do
case $1 in
-sd|--skip-db)
2023-08-18 16:38:41 +00:00
ARG_SKIP_DB=YES
shift # past argument
;;
-sp|--skip-pki)
2023-08-23 20:30:06 +00:00
ARG_SKIP_PKI=YES
shift # past argument
;;
-u|--unattended)
ARG_UNATTEND=YES
shift # past argument
;;
-h|--help)
help
exit 0
shift # past argument
;;
2023-08-18 16:38:41 +00:00
-*|--*)
echo "aca_setup.sh: Unknown option $1"
help
exit 1
2023-08-18 16:38:41 +00:00
;;
*)
POSITIONAL_ARGS+=("$1") # save positional arg
# shift # past argument
break
2023-08-18 16:38:41 +00:00
;;
esac
done
set -- "${POSITIONAL_ARGS[@]}" # restore positional parameters
mkdir -p $HIRS_CONF_DIR $LOG_DIR $HIRS_PROP_DIR
echo "ACA setup log file is $LOG_FILE"
if [ -z $HIRS_MYSQL_ROOT_PWD ]; then
echo "HIRS_MYSQL_ROOT_PWD is not set, using locally generated mysql root password"
else
echo "HIRS_MYSQL_ROOT_PWD is set, using previously set mysql root password"
fi
if [ "$EUID" -ne 0 ]
then echo "This script requires root. Please run as root"
exit 1
fi
echo "HIRS ACA Setup initiated on $(date +%Y-%m-%d)" > "$LOG_FILE"
2023-07-20 15:52:45 +00:00
pushd $SCRIPT_DIR &>/dev/null
2023-07-07 20:54:02 +00:00
2023-08-11 13:47:30 +00:00
# Set HIRS PKI password
if [ -z $HIRS_PKI_PWD ]; then
# Create a 32 character random password
PKI_PASS=$(head -c 64 /dev/urandom | md5sum | tr -dc 'a-zA-Z0-9')
echo "Using randomly generated password for the PKI key password" | tee -a "$LOG_FILE"
else
PKI_PASS=$HIRS_PKI_PWD
echo "Using system supplied password for the PKI key password" | tee -a "$LOG_FILE"
fi
2023-07-20 15:52:45 +00:00
# Copy HIRS configuration and data files if not a package install
#if [ -f $SPRING_PROP_FILE ]; then
# cp -n $SPRING_PROP_FILE $HIRS_CONF_DIR/.
# cp -n $COMP_JSON $HIRS_PROP_DIR/.
# cp -n $VENDOR_TABLE $HIRS_PROP_DIR/.
#fi
2023-07-13 20:40:15 +00:00
2023-08-23 20:30:06 +00:00
if [ -z "${ARG_SKIP_PKI}" ]; then
sh ../pki/pki_setup.sh $LOG_FILE $PKI_PASS $ARG_UNATTEND
2023-08-18 16:38:41 +00:00
if [ $? -eq 0 ]; then
echo "ACA PKI setup complete" | tee -a "$LOG_FILE"
else
echo "Error setting up ACA PKI" | tee -a "$LOG_FILE"
exit 1
fi
2023-08-23 20:30:06 +00:00
else
echo "Warning: Database setup not run due to command line argument: $@" | tee -a "$LOG_FILE"
2023-08-11 13:47:30 +00:00
fi
2023-08-23 20:30:06 +00:00
if [ -z "${ARG_SKIP_DB}" ]; then
sh ../db/db_create.sh $LOG_FILE $ARG_UNATTEND
2023-08-23 20:30:06 +00:00
if [ $? -eq 0 ]; then
echo "ACA database setup complete" | tee -a "$LOG_FILE"
else
echo "Error setting up ACA DB" | tee -a "$LOG_FILE"
exit 1
2023-08-23 20:30:06 +00:00
fi
else
echo "Warning: Database setup not run due to command line argument: $@" | tee -a "$LOG_FILE"
fi
2023-08-11 13:47:30 +00:00
echo "ACA setup complete" | tee -a "$LOG_FILE"
2023-07-20 15:52:45 +00:00
popd &>/dev/null