2023-08-18 16:38:41 +00:00
|
|
|
#!/bin/bash
|
|
|
|
#####################################################################################
|
|
|
|
#
|
2023-08-31 20:29:40 +00:00
|
|
|
# Functions to check mysql and start if not running.
|
2023-08-18 16:38:41 +00:00
|
|
|
# Also a function for checking if running in a container
|
|
|
|
#
|
|
|
|
#####################################################################################
|
2023-08-31 20:29:40 +00:00
|
|
|
SQL_SERVICE="mariadb"
|
2023-08-18 16:38:41 +00:00
|
|
|
|
2023-09-18 20:48:29 +00:00
|
|
|
# Checks to see if running in a container
|
|
|
|
# -p to print status
|
2023-08-18 16:38:41 +00:00
|
|
|
check_for_container () {
|
2023-09-18 20:48:29 +00:00
|
|
|
PRINT_STATUS=$1
|
2023-08-18 16:38:41 +00:00
|
|
|
# Check if we're in a Docker container
|
2024-03-01 17:04:26 +00:00
|
|
|
command -v systemctl
|
|
|
|
if [[ $? -eq 0 ]]; then
|
|
|
|
#if [[ $(cat /proc/1/cgroup | head -n 1) == *"docker"* ]] || [[ -f /.dockerenv ]]; then
|
2023-08-18 16:38:41 +00:00
|
|
|
DOCKER_CONTAINER=true
|
2023-09-18 20:48:29 +00:00
|
|
|
if [[ $PRINT_STATUS == "-p" ]]; then echo "ACA is running in a container..." | tee -a "$LOG_FILE"; fi
|
2023-08-18 16:38:41 +00:00
|
|
|
else
|
|
|
|
DOCKER_CONTAINER=false
|
2023-09-18 20:48:29 +00:00
|
|
|
if [[ $PRINT_STATUS == "-p" ]]; then echo "ACA is not running in a container..." | tee -a "$LOG_FILE"; fi
|
2023-08-18 16:38:41 +00:00
|
|
|
fi
|
|
|
|
if [ -d /opt/hirs/scripts/db ]; then
|
|
|
|
MYSQL_DIR="/opt/hirs/scripts/db"
|
|
|
|
else
|
|
|
|
MYSQL_DIR="$SCRIPT_DIR/../db"
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
2023-08-31 20:29:40 +00:00
|
|
|
# Check for mysql command line
|
2023-08-23 20:30:06 +00:00
|
|
|
check_mariadb_install () {
|
|
|
|
type mysql >/dev/null 2>&1 && installed=true || installed=false
|
|
|
|
if [ $installed = true ]; then
|
|
|
|
echo "mysql has been installed"
|
|
|
|
else
|
|
|
|
echo "mysql has NOT been installed, aborting install"
|
|
|
|
exit 1;
|
|
|
|
fi
|
|
|
|
}
|
2023-08-31 20:29:40 +00:00
|
|
|
# Starts mariadb during intial install
|
2023-08-18 16:38:41 +00:00
|
|
|
start_mysqlsd () {
|
2023-09-18 20:48:29 +00:00
|
|
|
PRINT_STATUS=$1
|
2023-10-10 18:29:37 +00:00
|
|
|
PROCESS="mysqld"
|
|
|
|
source /etc/os-release
|
|
|
|
if [ $ID = "ubuntu" ]; then
|
|
|
|
PROCESS="mariadb"
|
|
|
|
fi
|
2024-02-21 18:16:13 +00:00
|
|
|
# Make sure log file has correct permissions
|
|
|
|
chown -R mysql:mysql /var/lib/mysql/ >> "$LOG_FILE"
|
2023-08-18 16:38:41 +00:00
|
|
|
# Check if mysql is already running, if not initialize
|
2023-10-10 18:29:37 +00:00
|
|
|
if [[ $(pgrep -c -u mysql $PROCESS) -eq 0 ]]; then
|
2023-08-18 16:38:41 +00:00
|
|
|
# Check if running in a container
|
|
|
|
if [ $DOCKER_CONTAINER = true ]; then
|
|
|
|
# if in Docker container, avoid services that invoke the D-Bus
|
|
|
|
# Check if mariadb is setup
|
|
|
|
if [ ! -d "/var/lib/mysql/mysql/" ]; then
|
|
|
|
echo "Installing mariadb"
|
2023-09-27 18:40:18 +00:00
|
|
|
/usr/bin/mysql_install_db >> "$LOG_FILE"
|
|
|
|
fi
|
|
|
|
if [[ $PRINT_STATUS == "-p" ]]; then echo "Starting mysql..."; fi
|
2023-10-13 16:38:34 +00:00
|
|
|
/usr/bin/mysqld_safe --skip-syslog >> "$LOG_FILE" &
|
2023-10-13 15:42:54 +00:00
|
|
|
chown -R mysql:mysql /var/lib/mysql/ >> "$LOG_FILE"
|
|
|
|
echo "Attempting to start mariadb"
|
2023-09-27 18:40:18 +00:00
|
|
|
else #not a container
|
|
|
|
systemctl enable $SQL_SERVICE & >> "$LOG_FILE";
|
2023-10-13 15:42:54 +00:00
|
|
|
systemctl start $SQL_SERVICE & >> "$LOG_FILE";
|
2023-08-18 16:38:41 +00:00
|
|
|
fi
|
2023-08-31 20:29:40 +00:00
|
|
|
else # mysql process is running
|
2023-09-27 18:40:18 +00:00
|
|
|
# check if mysql service is running
|
2023-08-31 20:29:40 +00:00
|
|
|
if [ ! $DOCKER_CONTAINER = true ]; then
|
2023-09-27 18:40:18 +00:00
|
|
|
DB_STATUS=$(systemctl status mysql |grep 'running' | wc -l )
|
2023-08-31 20:29:40 +00:00
|
|
|
if [ $DB_STATUS -eq 0 ]; then
|
|
|
|
echo "mariadb not running , attempting to restart"
|
2023-09-27 18:40:18 +00:00
|
|
|
systemctl start mariadb >> "$LOG_FILE";
|
2024-02-16 18:40:03 +00:00
|
|
|
sleep 2
|
2023-08-31 20:29:40 +00:00
|
|
|
fi
|
2023-09-27 18:40:18 +00:00
|
|
|
fi # non contanier mysql start
|
2023-08-23 20:30:06 +00:00
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
2023-08-31 20:29:40 +00:00
|
|
|
# Basic check for marai db status, attempts restart if not running
|
|
|
|
check_mysql () {
|
2023-10-11 19:56:36 +00:00
|
|
|
PROCESS="mysqld"
|
|
|
|
source /etc/os-release
|
|
|
|
if [ $ID = "ubuntu" ]; then
|
|
|
|
PROCESS="mariadb"
|
|
|
|
fi
|
|
|
|
|
2023-08-31 20:29:40 +00:00
|
|
|
echo "Checking mysqld status..."
|
|
|
|
if [ $DOCKER_CONTAINER = true ]; then
|
2023-10-11 19:56:36 +00:00
|
|
|
if [[ $(pgrep -c -u mysql $PROCESS ) -eq 0 ]]; then
|
2023-08-31 20:29:40 +00:00
|
|
|
echo "mariadb not running , attempting to restart"
|
2023-10-13 15:42:54 +00:00
|
|
|
chown mysql:mysql /var/log/mariadb/mariadb.log >> "$LOG_FILE";
|
2023-10-13 16:38:34 +00:00
|
|
|
/usr/bin/mysqld_safe --skip-syslog >> "$LOG_FILE" &
|
2023-08-31 20:29:40 +00:00
|
|
|
fi
|
|
|
|
else # not in a contianer
|
|
|
|
DB_STATUS=$(systemctl status mysql |grep 'running' | wc -l )
|
|
|
|
if [ $DB_STATUS -eq 0 ]; then
|
|
|
|
echo "mariadb not running , attempting to restart"
|
|
|
|
systemctl start mariadb
|
|
|
|
fi
|
2023-09-06 20:09:27 +00:00
|
|
|
fi
|
2023-08-31 20:29:40 +00:00
|
|
|
|
|
|
|
|
2023-10-10 18:29:37 +00:00
|
|
|
# Wait for mysql to start before continuing.
|
|
|
|
count=1;
|
2023-10-11 19:56:36 +00:00
|
|
|
if [[ $PRINT_STATUS == "-p" ]]; then echo "Testing mysqld connection..."| tee -a "$LOG_FILE"; fi
|
2023-10-10 18:29:37 +00:00
|
|
|
|
|
|
|
until mysqladmin ping -h "localhost" --silent ; do
|
|
|
|
((count++))
|
|
|
|
if [[ $count -gt 20 ]]; then
|
|
|
|
break;
|
|
|
|
fi
|
|
|
|
sleep 1;
|
2023-08-31 20:29:40 +00:00
|
|
|
done
|
2023-10-10 18:29:37 +00:00
|
|
|
if [[ $count -gt 20 ]]; then
|
|
|
|
echo "Timed out waiting for Mariadb to respond"
|
2023-10-13 15:42:54 +00:00
|
|
|
exit 1;
|
2023-10-10 18:29:37 +00:00
|
|
|
else
|
|
|
|
echo "Mariadb started"
|
|
|
|
fi
|
2023-09-18 20:48:29 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
# Check for mysql root password , abort if not available
|
|
|
|
check_mysql_root () {
|
|
|
|
if [ -z $HIRS_MYSQL_ROOT_PWD ]; then
|
|
|
|
if [ ! -f /etc/hirs/aca/aca.properties ]; then
|
|
|
|
echo "aca.properties does not exist."
|
|
|
|
else
|
|
|
|
source /etc/hirs/aca/aca.properties;
|
|
|
|
DB_ADMIN_PWD=$mysql_admin_password
|
|
|
|
fi
|
|
|
|
else #HIRS_MYSQL_ROOT_PWD set
|
|
|
|
DB_ADMIN_PWD=$HIRS_MYSQL_ROOT_PWD
|
|
|
|
fi
|
2023-08-31 20:29:40 +00:00
|
|
|
|
2023-09-18 20:48:29 +00:00
|
|
|
# Allow user to enter password if not using env variabel or file
|
|
|
|
if [ -z $DB_ADMIN_PWD ]; then
|
|
|
|
read -p "Enter mysql root password" DB_ADMIN_PWD
|
|
|
|
else
|
|
|
|
DB_ADMIN_PWD=$mysql_admin_password
|
|
|
|
fi
|
|
|
|
|
|
|
|
# Make sure root password is correct
|
|
|
|
$(mysql -u root -p$DB_ADMIN_PWD -e 'quit' &> /dev/null);
|
|
|
|
if [ $? -eq 0 ]; then
|
|
|
|
echo "root password verified" | tee -a "$LOG_FILE"
|
|
|
|
else
|
|
|
|
echo "MYSQL root password was not the default, not supplied, or was incorrect"
|
|
|
|
echo " please set the HIRS_MYSQL_ROOT_PWD system variable and retry."
|
|
|
|
echo " ********** ACA Mysql setup aborted ********" ;
|
|
|
|
exit 1;
|
|
|
|
fi
|
2023-08-31 20:29:40 +00:00
|
|
|
}
|
|
|
|
|
2023-09-18 20:48:29 +00:00
|
|
|
check_db_cleared () {
|
|
|
|
$(mysql -u root -e 'quit' &> /dev/null);
|
|
|
|
if [ $? -eq 0 ]; then
|
|
|
|
echo " Empty root password verified" | tee -a "$LOG_FILE"
|
|
|
|
else
|
|
|
|
echo " Mysql Root password is not empty"
|
|
|
|
fi
|
|
|
|
HIRS_DB_USER_EXISTS="$(mysql -uroot -sse "SELECT EXISTS(SELECT 1 FROM mysql.user WHERE user = 'hirs_db')")"
|
2023-09-27 18:40:18 +00:00
|
|
|
if [[ $HIRS_DB_USER_EXISTS == 1 ]]; then
|
2023-09-18 20:48:29 +00:00
|
|
|
echo " hirs_db user exists"
|
|
|
|
else
|
|
|
|
echo " hirs_db user does not exist"
|
|
|
|
|
|
|
|
fi
|
|
|
|
HIRS_DB_EXISTS=`mysql -uroot -e "SHOW DATABASES" | grep hirs_db`
|
|
|
|
if [[ $HIRS_DB_EXISTS == "hirs_db" ]]; then
|
|
|
|
echo " hirs_db databse exists"
|
|
|
|
else
|
|
|
|
echo " hirs_db database does not exists"
|
|
|
|
fi
|
|
|
|
}
|
2023-09-27 18:40:18 +00:00
|
|
|
|
2024-02-23 20:19:02 +00:00
|
|
|
clear_hirs_user () {
|
|
|
|
$(mysql -u root -e 'quit' &> /dev/null);
|
|
|
|
if [ $? -eq 0 ]; then
|
|
|
|
HIRS_DB_USER_EXISTS="$(mysql -uroot -sse "SELECT EXISTS(SELECT 1 FROM mysql.user WHERE user = 'hirs_db')")"
|
|
|
|
if [[ $HIRS_DB_USER_EXISTS == 1 ]]; then
|
|
|
|
mysql -u root --password=$DB_ADMIN_PWD -e "DROP USER 'hirs_db'@'localhost';"
|
|
|
|
echo "hirs_db user found and deleted"
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
clear_hirs_db () {
|
|
|
|
$(mysql -u root -e 'quit' &> /dev/null);
|
|
|
|
if [ $? -eq 0 ]; then
|
|
|
|
mysql -u root --password=$DB_ADMIN_PWD -e "DROP DATABASE IF EXISTS hirs_db;"
|
|
|
|
fi
|
|
|
|
}
|
2023-08-31 20:29:40 +00:00
|
|
|
# restart maraidb
|
|
|
|
mysqld_reboot () {
|
|
|
|
# reboot mysql server
|
|
|
|
mysql -u root --password=$DB_ADMIN_PWD -e "SHUTDOWN"
|
|
|
|
sleep 2
|
|
|
|
check_for_container
|
2023-10-13 16:38:34 +00:00
|
|
|
start_mysqlsd >> "$LOG_FILE";
|
2023-10-10 18:29:37 +00:00
|
|
|
}
|