gameservergame-servergame-servershacktoberfestdedicated-game-serversgamelinuxgsmserverbashgaminglinuxmultiplayer-game-servershell
		
		
		
		
			You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							105 lines
						
					
					
						
							4.4 KiB
						
					
					
				
			
		
		
		
			
			
			
		
		
	
	
							105 lines
						
					
					
						
							4.4 KiB
						
					
					
				| #!/bin/bash | |
| # LinuxGSM logs.sh function | |
| # Author: Daniel Gibbs | |
| # Contributor: UltimateByte | |
| # Website: https://linuxgsm.com | |
| # Description: Acts as a log rotator, removing old logs. | |
| 
 | |
| local commandname="LOGS" | |
| local commandaction="Log-Manager" | |
| 
 | |
| # Check if logfile variable and file exist, create logfile if it doesn't exist | |
| if [ -n "${consolelog}" ]; then | |
| 	if [ ! -e "${consolelog}" ]; then | |
| 		touch "${consolelog}" | |
| 	fi | |
| fi | |
| 
 | |
| # For games not displaying a console, and having logs into their game directory | |
| check_status.sh | |
| if [ "${status}" != "0" ] && [ "${function_selfname}" == "command_start.sh" ] && [ -n "${gamelogfile}" ]; then | |
| 	if [ -n "$(find "${systemdir}" -name "gamelog*.log")" ]; then | |
| 		fn_print_info "Moving game logs to ${gamelogdir}" | |
| 		fn_script_log_info "Moving game logs to ${gamelogdir}" | |
| 		echo -en "\n" | |
| 		sleep 0.5 | |
| 		mv "${systemdir}"/gamelog*.log "${gamelogdir}" | |
| 	fi | |
| fi | |
| 
 | |
| # Log manager will start the cleanup if it finds logs older than "${logdays}" | |
| if [ $(find "${lgsmlogdir}"/ -type f -mtime +"${logdays}" | wc -l) -ne "0" ]; then | |
| 	fn_print_dots "Starting" | |
| 	# Set common logs directories | |
| 	commonlogs="${systemdir}/logs" | |
| 	commonsourcelogs="${systemdir}/*/logs" | |
| 	# Set addon logs directories | |
| 	sourcemodlogdir="${systemdir}/addons/sourcemod/logs" | |
| 	ulxlogdir="${systemdir}/data/ulx_logs" | |
| 	darkrplogdir="${systemdir}/data/darkrp_logs" | |
| 	legacyserverlogdir="${logdir}/server" | |
| 	# Setting up counting variables | |
| 	scriptcount="0" ; consolecount="0" ; gamecount="0" ; srcdscount="0" ; smcount="0" ; ulxcount="0" ; darkrpcount="0" ; legacycount="0" | |
| 	sleep 0.5 | |
| 	fn_print_ok_nl "Starting" | |
| 	fn_print_info_nl "Removing logs older than ${logdays} days" | |
| 	fn_script_log_info "Removing logs older than ${logdays} days" | |
| 	# Logging logfiles to be removed according to "${logdays}", counting and removing them | |
| 	# Script logfiles | |
| 	find "${lgsmlogdir}"/ -type f -mtime +"${logdays}" | tee >> "${lgsmlog}" | |
| 	scriptcount=$(find "${lgsmlogdir}"/ -type f -mtime +"${logdays}" | wc -l) | |
| 	find "${lgsmlogdir}"/ -mtime +"${logdays}" -type f -exec rm -f {} \; | |
| 	# SRCDS and unreal logfiles | |
| 	if [ "${engine}" == "unreal2" ]||[ "${engine}" == "source" ]; then | |
| 		find "${gamelogdir}"/ -type f -mtime +"${logdays}" | tee >> "${lgsmlog}" | |
| 		gamecount=$(find "${gamelogdir}"/ -type f -mtime +"${logdays}" | wc -l) | |
| 		find "${gamelogdir}"/ -mtime +"${logdays}" -type f -exec rm -f {} \; | |
| 	fi | |
| 	# Console logfiles | |
| 	if [ -n "${consolelog}" ]; then | |
| 		find "${consolelogdir}"/ -type f -mtime +"${logdays}" | tee >> "${lgsmlog}" | |
| 		consolecount=$(find "${consolelogdir}"/ -type f -mtime +"${logdays}" | wc -l) | |
| 		find "${consolelogdir}"/ -mtime +"${logdays}" -type f -exec rm -f {} \; | |
| 	fi | |
| 	# Common logfiles | |
| 	if [ -d "${commonlogs}" ]; then | |
| 		find "${commonlogs}"/ -type f -mtime +"${logdays}" | tee >> "${lgsmlog}" | |
| 		smcount=$(find "${commonlogs}"/ -type f -mtime +"${logdays}" | wc -l) | |
| 		find "${commonlogs}"/ -mtime +"${logdays}" -type f -exec rm -f {} \; | |
| 	fi | |
| 	if [ -d "${commonsourcelogs}" ]; then | |
| 		find "${commonsourcelogs}"/* -type f -mtime +"${logdays}" | tee >> "${lgsmlog}" | |
| 		smcount=$(find "${commonsourcelogs}"/* -type f -mtime +"${logdays}" | wc -l) | |
| 		find "${commonsourcelogs}"/* -mtime +"${logdays}" -type f -exec rm -f {} \; | |
| 	fi | |
| 	# Source addons logfiles | |
| 	if [ "${engine}" == "source" ]; then | |
| 		# SourceMod logfiles | |
| 		if [ -d "${sourcemodlogdir}" ]; then | |
| 			find "${sourcemodlogdir}"/ -type f -mtime +"${logdays}" | tee >> "${lgsmlog}" | |
| 			smcount=$(find "${sourcemodlogdir}"/ -type f -mtime +"${logdays}" | wc -l) | |
| 			find "${sourcemodlogdir}"/ -mtime +"${logdays}" -type f -exec rm -f {} \; | |
| 		fi | |
| 		# Garry's Mod logfiles | |
| 		if [ "${gamename}" == "Garry's Mod" ]; then | |
| 			# ULX logfiles | |
| 			if [ -d "${ulxlogdir}" ]; then | |
| 				find "${ulxlogdir}"/ -type f -mtime +"${logdays}" | tee >> "${lgsmlog}" | |
| 				ulxcount=$(find "${ulxlogdir}"/ -type f -mtime +"${logdays}" | wc -l) | |
| 				find "${ulxlogdir}"/ -mtime +"${logdays}" -type f -exec rm -f {} \; | |
| 			fi | |
| 			# DarkRP logfiles | |
| 			if [ -d "${darkrplogdir}" ]; then | |
| 				find "${darkrplogdir}"/ -type f -mtime +"${logdays}" | tee >> "${lgsmlog}" | |
| 				darkrpcount=$(find "${darkrplogdir}"/ -type f -mtime +"${logdays}" | wc -l) | |
| 				find "${darkrplogdir}"/ -mtime +"${logdays}" -type f -exec rm -f {} \; | |
| 			fi | |
| 		fi | |
| 	fi | |
| 
 | |
| 	# Count total amount of files removed | |
| 	countlogs=$((${scriptcount} + ${consolecount} + ${gamecount} + ${srcdscount} + ${smcount} + ${ulxcount} + ${darkrpcount})) | |
| 	# Job done | |
| 	fn_print_ok_nl "Removed ${countlogs} log files" | |
| 	fn_script_log "Removed ${countlogs} log files" | |
| fi
 | |
| 
 |