Daniel Gibbs 9 лет назад
Родитель
Сommit
9437b6c2b4
1 измененных файлов с 140 добавлено и 57 удалено
  1. 140 57
      lgsminstall.sh

+ 140 - 57
lgsminstall.sh

@@ -15,31 +15,45 @@ if [ -f ".dev-debug" ]; then
 fi
 
 version="170305"
-sname="core"
 rootdir="$(dirname $(readlink -f "${BASH_SOURCE[0]}"))"
 selfname="$(basename $(readlink -f "${BASH_SOURCE[0]}"))"
+lgsmdir="${rootdir}/lgsm"
+tmpdir="${lgsmdir}/tmp"
 servicename="${selfname}"
+shortname="core"
+shortname="core"
+shortname="core"
+configdir="${lgsmdir}/config"
+gameconfigdir="${configdir}/${servername}"
 
 ## Github Branch Select
 # Allows for the use of different function files
 # from a different repo and/or branch.
 githubuser="GameServerManagers"
 githubrepo="LinuxGSM"
-githubbranch="config"
+githubbranch="feature/config"
+
+## Github Branch Select
+# Allows for the use of different function files
+# from a different repo and/or branch.
+githubuser="GameServerManagers"
+githubrepo="LinuxGSM"
+githubbranch="feature/config"
 
 # LinuxGSM installer
-if [ "${sname}" == "core" ]; then
+if [ "${shortname}" == "core" ]; then
 	userinput=$1
 	if [ -z "${userinput}" ]; then
 		userinput="empty"
 	fi
-	serverslist=$(grep "${userinput}" lgsm/data/serverlist.csv|awk -F "," '{print $2}')
+	serverslist=$(grep "${userinput}" <(curl -s "https://raw.githubusercontent.com/${githubuser}/${githubrepo}/${githubbranch}/lgsm/data/serverlist.csv")|awk -F "," '{print $2}')
 	echo "USERINPUT: $userinput"
 	echo "SERVERLIST: $serverslist"
 	if [ "${userinput}" == "${serverslist}" ]; then
 		echo "installing"
-		sname=$(grep $userinput lgsm/data/serverlist.csv|awk -F "," '{print $1}')
-		servername=$(grep $userinput lgsm/data/serverlist.csv|awk -F "," '{print $2}')
+		shortname=$(grep ${userinput} <(curl -s "https://raw.githubusercontent.com/${githubuser}/${githubrepo}/${githubbranch}/lgsm/data/serverlist.csv")|awk -F "," '{print $1}')
+		servername=$(grep ${userinput} <(curl -s "https://raw.githubusercontent.com/${githubuser}/${githubrepo}/${githubbranch}/lgsm/data/serverlist.csv")|awk -F "," '{print $2}')
+		gamename=$(grep ${userinput} <(curl -s "https://raw.githubusercontent.com/${githubuser}/${githubrepo}/${githubbranch}/lgsm/data/serverlist.csv")|awk -F "," '{print $3}')
 		if [ -e "${servername}" ]; then
 			i=2
 		while [ -e "$servername-$i" ] ; do
@@ -48,11 +62,13 @@ if [ "${sname}" == "core" ]; then
 			servername="${servername}-$i"
 		fi
 		cp "${selfname}" "${servername}"
-		sed -i -e "s/sname=\"core\"/sname=\"${sname}\"/g" "${servername}"
+		sed -i -e "s/shortname=\"core\"/shortname=\"${shortname}\"/g" "${servername}"
+		sed -i -e "s/servername=\"core\"/servername=\"${servername}\"/g" "${servername}"
+		sed -i -e "s/gamename=\"core\"/gamename=\"${gamename}\"/g" "${gamename}"
 		exit
-	elif [ "$userinput" == "list" ]; then
+	elif [ "${userinput}" == "list" ]; then
 		{
-			awk -F "," '{print $2 "\t" $3}' "lgsm/data/serverlist.csv"
+			awk -F "," '{print $2 "\t" $3}' <(curl -s "https://raw.githubusercontent.com/${githubuser}/${githubrepo}/${githubbranch}/lgsm/data/serverlist.csv")
 		} | column -s $'\t' -t
 		exit
 	else
@@ -65,74 +81,141 @@ if [ "${sname}" == "core" ]; then
 	fi
 fi
 
-source lgsm/config/_default.cfg
-source lgsm/config/common.cfg
-source lgsm/config/${servicename}.cfg
-
-
-########################
-######## Script ########
-###### Do not edit #####
-########################
+# Bootstrap
 
-# Fetches core_dl for file downloads
-fn_fetch_core_dl(){
-github_file_url_dir="lgsm/functions"
-github_file_url_name="${functionfile}"
-filedir="${functionsdir}"
-filename="${github_file_url_name}"
-githuburl="https://raw.githubusercontent.com/${githubuser}/${githubrepo}/${githubbranch}/${github_file_url_dir}/${github_file_url_name}"
-# If the file is missing, then download
-if [ ! -f "${filedir}/${filename}" ]; then
-	if [ ! -d "${filedir}" ]; then
-		mkdir -p "${filedir}"
-	fi
-	echo -e "    fetching ${filename}...\c"
-	# Check curl exists and use available path
-	curlpaths="$(command -v curl 2>/dev/null) $(which curl >/dev/null 2>&1) /usr/bin/curl /bin/curl /usr/sbin/curl /sbin/curl)"
-	for curlcmd in ${curlpaths}
-	do
-		if [ -x "${curlcmd}" ]; then
-			break
+# Fetches bootstrap files (configs and core functions)
+fn_boostrap_fetch_file(){
+	fileurl="${1}"
+	filedir="${2}"
+	filename="${3}"
+	executecmd="${4:-0}"
+	run="${5:-0}"
+	force="${6:-0}"
+	# If the file is missing, then download
+	if [ ! -f "${filedir}/${filename}" ]; then
+		if [ ! -d "${filedir}" ]; then
+			mkdir -p "${filedir}"
 		fi
-	done
-	# If curl exists download file
-	if [ "$(basename ${curlcmd})" == "curl" ]; then
-		curlfetch=$(${curlcmd} -s --fail -o "${filedir}/${filename}" "${githuburl}" 2>&1)
-		if [ $? -ne 0 ]; then
+		# Check curl exists and use available path
+		curlpaths="$(command -v curl 2>/dev/null) $(which curl >/dev/null 2>&1) /usr/bin/curl /bin/curl /usr/sbin/curl /sbin/curl)"
+		for curlcmd in ${curlpaths}
+		do
+			if [ -x "${curlcmd}" ]; then
+				break
+			fi
+		done
+		# If curl exists download file
+		if [ "$(basename ${curlcmd})" == "curl" ]; then
+			# trap to remove part downloaded files
+			echo -ne "    fetching ${filename}...\c"
+			curlcmd=$(${curlcmd} -s --fail -L -o "${filedir}/${filename}" "${fileurl}" 2>&1)
+			local exitcode=$?
+			if [ ${exitcode} -ne 0 ]; then
+				echo -e "\e[0;31mFAIL\e[0m\n"
+				echo -e "${fileurl}" | tee -a "${scriptlog}"
+				echo "${curlcmd}" | tee -a "${scriptlog}"
+				exit 1
+			else
+				echo -e "\e[0;32mOK\e[0m"
+			fi
+		else
 			echo -e "\e[0;31mFAIL\e[0m\n"
-			echo "${curlfetch}"
-			echo -e "${githuburl}\n"
+			echo "Curl is not installed!"
+			echo -e ""
 			exit 1
-		else
-			echo -e "\e[0;32mOK\e[0m"
 		fi
-	else
-		echo -e "\e[0;31mFAIL\e[0m\n"
-		echo "Curl is not installed!"
-		echo -e ""
-		exit 1
+		# make file executecmd if executecmd is set
+		if [ "${executecmd}" == "executecmd" ]; then
+			chmod +x "${filedir}/${filename}"
+		fi
 	fi
-	chmod +x "${filedir}/${filename}"
-fi
-source "${filedir}/${filename}"
+
+	if [ -f "${filedir}/${filename}" ]; then
+		# run file if run is set
+		if [ "${run}" == "run" ]; then
+			source "${filedir}/${filename}"
+		fi
+	fi
+}
+
+fn_boostrap_fetch_function(){
+	github_file_url_dir="lgsm/functions" # github dir containing the file
+	github_file_url_name="${functionfile}" # name of the github file
+	githuburl="https://raw.githubusercontent.com/${githubuser}/${githubrepo}/${githubbranch}/${github_file_url_dir}/${github_file_url_name}"
+	fileurl="${githuburl}"
+	filedir="${functionsdir}"
+	filename="${github_file_url_name}"
+	executecmd="executecmd"
+	run="run"
+	force="noforce"
+	md5="nomd5"
+	fn_boostrap_fetch_file "${fileurl}" "${filedir}" "${filename}" "${executecmd}" "${run}" "${force}" "${md5}"
 }
 
+fn_boostrap_fetch_config(){
+	github_file_url_dir="${1}" # github dir containing the file
+	github_file_url_name="${2}" # name of the github file
+	githuburl="https://raw.githubusercontent.com/${githubuser}/${githubrepo}/${githubbranch}/${github_file_url_dir}/${github_file_url_name}"
+	fileurl="${githuburl}"
+	filedir="${3}"
+	filename="${4}"
+	executecmd="noexecutecmd"
+	run="norun"
+	force="noforce"
+	md5="nomd5"
+	fn_boostrap_fetch_file "${fileurl}" "${filedir}" "${filename}" "${executecmd}" "${run}" "${force}" "${md5}"
+}
+
+# Load the default config. If missing download it. If changed reload it.
+if [ ! -f "${tmpdir}/config/${servername}/_default.cfg" ];then
+	fn_boostrap_fetch_config "lgsm/config/${servername}" "_default.cfg" "${tmpdir}/config/${servername}" "_default.cfg" "noexecutecmd" "norun" "noforce" "nomd5"
+fi
+if [ ! -f "${gameconfigdir}/_default.cfg" ];then
+	echo "hello"
+	cp "${tmpdir}/config/${servername}/_default.cfg" "${gameconfigdir}/_default.cfg"
+else
+	function_file_diff=$(diff -q ${tmpdir}/config/${servername}/_default.cfg ${gameconfigdir}/_default.cfg)
+	if [ "${function_file_diff}" != "" ]; then
+		echo "config different onverwriting"
+		cp "${tmpdir}/config/${servername}/_default.cfg" "${gameconfigdir}/_default.cfg"
+	fi
+	source lgsm/config/${servername}/_default.cfg
+fi
+
+if [ ! -f "${gameconfigdir}/common.cfg" ];then
+	fn_boostrap_fetch_config "lgsm/config" "common-template.cfg" "${lgsmdir}/config/${servername}" "common.cfg" "${executecmd}" "noexecutecmd" "norun" "noforce" "nomd5"
+	source lgsm/config/${servername}/common.cfg
+else
+	source lgsm/config/${servername}/common.cfg
+fi
+
+if [ ! -f "${gameconfigdir}/${servicename}.cfg" ];then
+	fn_boostrap_fetch_config "lgsm/config" "instance-template.cfg" "${lgsmdir}/config/${servername}" "${servicename}.cfg" "noexecutecmd" "norun" "noforce" "nomd5"
+	source lgsm/config/${servername}/${servicename}.cfg
+else
+	source lgsm/config/${servername}/${servicename}.cfg
+fi
+
+########################
+######## Script ########
+###### Do not edit #####
+########################
+
 core_dl.sh(){
 # Functions are defined in core_functions.sh.
 functionfile="${FUNCNAME}"
-fn_fetch_core_dl
+fn_boostrap_fetch_function
 }
 
 core_functions.sh(){
 # Functions are defined in core_functions.sh.
 functionfile="${FUNCNAME}"
-fn_fetch_core_dl
+fn_boostrap_fetch_function
 }
 
 # Prevent from running this script as root.
 if [ "$(whoami)" = "root" ]; then
-	if [ ! -f "${functionsdir}/core_functions.sh" ]||[ ! -f "${functionsdir}/check_root.sh" ]||[ ! -f "${functionsdir}/core_messages.sh" ]||[ ! -f "${functionsdir}/core_exit.sh" ]; then
+	if [ ! -f "${functionsdir}/core_functions.sh" ]||[ ! -f "${functionsdir}/check_root.sh" ]||[ ! -f "${functionsdir}/core_messages.sh" ]||[ ! -f "${functionsdir}/exit 1" ]; then
 		echo "[ FAIL ] Do NOT run this script as root!"
 		exit 1
 	else