#!/bin/sh /etc/rc.common
# Copyright (C) 2010-2018 OpenWrt.org

START=95
STOP=10

NAME=mysqld

LOGGER="/usr/bin/logger -p user.err -s -t $NAME --"

MYSQLADMIN=/usr/bin/mysqladmin
MYSQLD=/usr/bin/$NAME
MYSQLDSAFE=/usr/bin/mysqld_safe

# mysqladmin likes to read /root/.my.cnf which could cause issues.
export HOME=/etc/mysql

# Safeguard (relative paths, core dumps...)
cd /

mysqld_get_param() {
	$MYSQLD --print-defaults \
		| tr " " "\n" \
		| grep -- "--$1" \
		| tail -n 1 \
		| cut -d= -f2
}

# Checks if a server is running and accessible.
#
# check_alive insists on a pingable server
# check_dead also fails if there is a lost mysqld in the process list
#
# Usage: boolean mysqld_status [check_alive|check_dead]
mysqld_status() {
	if $MYSQLADMIN ping >/dev/null 2>&1; then
		ping_alive=1
	else
		ping_alive=0
	fi

	ps_alive=0
	pidfile=$(mysqld_get_param pid-file)
	if [ -f "$pidfile" ] && kill -0 $(cat "$pidfile") >/dev/null 2>&1; then
		ps_alive=1
	fi

	if { [ "$1" = check_alive ] && [ $ping_alive = 1 ]; } || \
		{ [ "$1" = check_dead ] && [ $ping_alive = 0 ] \
					&& [ $ps_alive = 0 ]; }
	then
		return 0 # EXIT_SUCCESS
	else
		return 1 # EXIT_FAILURE
	fi
}

start() {
	conf=/etc/mysql/my.cnf
	logdir=/var/log/mysql
	rundir=/var/run/mysqld

	hint="please fix your server configuration in /etc/mysql/"

	for i in $MYSQLD $MYSQLADMIN $MYSQLDSAFE; do
		if [ ! -x $i ]; then
			$LOGGER $i is missing
			exit 1
		fi
	done

	if [ ! -r $conf ]; then
		$LOGGER $conf cannot be read
		exit 1
	fi

	config_load $NAME

	config_get_bool enabled general enabled 0
	if [ $enabled -eq 0 ]; then
		$LOGGER service not enabled in /etc/config/$NAME
		exit 1
	fi

	config_get options general options

	datadir=$(mysqld_get_param datadir)
	tmpdir=$(mysqld_get_param tmpdir)

	if [ -z "$datadir" ]; then
		$LOGGER datadir is not set
		$LOGGER $hint
		exit 1
	fi

	if [ -z "$tmpdir" ]; then
		$LOGGER tmpdir is not set
		$LOGGER $hint
		exit 1
	fi

	if [ ! -f "$datadir/mysql/tables_priv.MAD" ]; then
		args="--force"
		basedir=$(mysqld_get_param basedir)
		[ -n "$basedir" ] && args="$args --basedir=$basedir"

		$LOGGER Cannot detect privileges table. You might need to run
		$LOGGER \'mysql_install_db "$args"\'
		$LOGGER to initialize the system tables.
		exit 1
	fi

	# Start daemon
	if mysqld_status check_alive; then
		$LOGGER already running
	else
		for i in $logdir $rundir; do
			opts="-m 0750"
			if ! [ -e $i ]; then
				# $rundir needs to be accessible for
				# clients
				if [ $i = $rundir ]; then
					opts=
				fi
				mkdir -p $opts $i
				[ -d $i ] && chown mariadb:mariadb $i
			fi
		done

		$MYSQLDSAFE $options >/dev/null 2>&1 &
	fi
}

stop() {
	if ! mysqld_status check_dead; then
		$MYSQLADMIN shutdown
	fi
}

reload() {
	if mysqld_status check_alive; then
		$MYSQLADMIN reload
	else
		$LOGGER not running
	fi
}